ALT Linux Team development discussions
 help / color / mirror / Atom feed
From: "Dmitry V. Levin" <ldv@altlinux.org>
To: ALT Devel discussion list <devel@lists.altlinux.org>
Subject: Re: [devel] git -- хитрая задачка
Date: Wed, 25 Aug 2010 03:56:32 +0400
Message-ID: <20100824235632.GA12033@altlinux.org> (raw)
In-Reply-To: <20100824201802.GB6097@atlas.home>

[-- Attachment #1: Type: text/plain, Size: 1844 bytes --]

On Wed, Aug 25, 2010 at 12:18:02AM +0400, Sergey Vlasov wrote:
> On Tue, Aug 24, 2010 at 10:00:17PM +0400, Денис Смирнов wrote:
> > On Tue, Aug 24, 2010 at 01:58:26PM +0400, Dmitry V. Levin wrote:
> > 
> > >> git merge-base первый второй
> > >> Вернёт "первый", если он является предком второго. МОжет есть проще, не
> > >> знаю.
> > DVL> http://git.altlinux.org/people/ldv/packages/?p=girar-builder.git;a=blob;f=gb-task-check-girar#l13
> > 
> > А чем это лучше git merge-base (при том что он код возврата дает)?
> 
> http://git.altlinux.org/people/ldv/packages/?p=gear.git;a=commitdiff;h=705d10e6596636220f65aa9c05f41a1ca69503de

Там, кстати, в commit message вкралась опечатка, меняющая смысл.

> Ну и, насколько я помню, в merge-all-branches из kernel-build-tools
> аналогичный способ (точнее, через git rev-list --max-count=1) в
> каких-то ситуациях работал существенно быстрее, чем через git
> merge-base.

Да, я это тоже заметил.
Например, у меня в coreutils.git это выглядит так:

$ time git rev-list --max-count=1 ^master coreutils-current
0.00user 0.00system 0:00.00elapsed 160%CPU (0avgtext+0avgdata 0maxresident)k
0inputs+0outputs (0major+494minor)pagefaults 0swaps

$ time git log -n1 --pretty=format:1 ^master coreutils-current > /dev/null 
0.00user 0.00system 0:00.00elapsed 160%CPU (0avgtext+0avgdata 0maxresident)k
0inputs+0outputs (0major+500minor)pagefaults 0swaps

$ time git merge-base coreutils-current master
1d10eb8b1eeff9dd0fe1bbbc212e9535203acff0
0.71user 0.01system 0:00.72elapsed 100%CPU (0avgtext+0avgdata 0maxresident)k
0inputs+0outputs (0major+9166minor)pagefaults 0swaps

Судя по статистике minor pagefaults, git rev-list --max-count=1 немного
дешевле чем git log -n1 --pretty=format:1, и любой из них существенно
дешевле и гораздо быстрее чем git merge-base.


-- 
ldv

[-- Attachment #2: Type: application/pgp-signature, Size: 198 bytes --]

  reply	other threads:[~2010-08-24 23:56 UTC|newest]

Thread overview: 23+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-08-24  8:31 Денис Смирнов
2010-08-24  9:17 ` Андрей Черепанов
2010-08-24  9:40   ` Денис Смирнов
2010-08-24  9:39 ` Alexander Myltsev
2010-08-24  9:42   ` Денис Смирнов
2010-08-24  9:47     ` Alexander Myltsev
2010-08-24  9:49     ` Andrey Rahmatullin
2010-08-24  9:58       ` Dmitry V. Levin
2010-08-24 18:00         ` Денис Смирнов
2010-08-24 20:18           ` Sergey Vlasov
2010-08-24 23:56             ` Dmitry V. Levin [this message]
2010-08-24 17:58       ` Денис Смирнов
2010-08-24 18:54         ` Sergey Vlasov
2010-08-25 20:35           ` Денис Смирнов
2010-08-26 11:51             ` Sergey Vlasov
2010-08-24  9:53 ` Dmitry V. Levin
2010-08-24 11:35   ` Денис Смирнов
2010-08-24 11:41     ` Alexander Myltsev
2010-08-24 17:48       ` Денис Смирнов
2010-08-24 11:43     ` Andrey Rahmatullin
2010-08-24 11:45       ` Денис Смирнов
2010-08-24 11:52     ` Ildar Mulyukov
2010-08-24 17:46       ` Денис Смирнов

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20100824235632.GA12033@altlinux.org \
    --to=ldv@altlinux.org \
    --cc=devel@lists.altlinux.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link

ALT Linux Team development discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
		devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
	public-inbox-index devel

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.devel


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git