From: Catalin Marinas <catalin.marinas@gmail.com>
To: "Karl Hasselström" <kha@treskal.com>
Cc: git@vger.kernel.org
Subject: Re: [RFC][StGit PATCH] Add support for merge-friendly branches
Date: Thu, 28 May 2009 15:38:44 +0100 [thread overview]
Message-ID: <b0943d9e0905280738n51476ab7vd0498ea7a236c4a7@mail.gmail.com> (raw)
In-Reply-To: <20090528124817.GA22262@diana.vm.bytemark.co.uk>
2009/5/28 Karl Hasselström <kha@treskal.com>:
> On 2009-05-28 12:12:42 +0100, Catalin Marinas wrote:
>
>> The patch proposes a new StGit command called "publish". This
>> command allows one to develop patches normally on a StGit branch but
>> publish the stack changes to a separate, merge-friendly branch whose
>> history is not re-writable.
>
> Hmm, interesting. I don't think I'd want to use a command like this
> myself, but I can see how it might be useful.
For me it is useful. I publish a kernel tree with over 100 patches.
Later I find that one patch is buggy. The current merge-friendly
solution is to add another patch but I may want to just update the
buggy patch as it's easier when time comes to submit upstream. This,
however, rewrites the history. So with the "publish" command I just
generate another commit on top of the public branch and I always end
up with the same tree as on my stack.
>> + # check for same tree (already up to date)
>> + if public_tree.sha1 == stack.head.data.tree.sha1:
>> + out.info('"%s" already up to date' % public_ref)
>> + return
>> +
>> + # check for rebased stack. In this case we emulate a merge with the stack
>> + # base by setting two parents.
>> + merge_base = repository.get_merge_base(public_head, stack.base)
>> + if merge_base.sha1 != stack.base.sha1:
>> + public_head = __create_commit(repository, stack.head.data.tree,
>> + [public_head, stack.base], options)
>> + repository.refs.set(public_ref, public_head, 'publish')
>> + out.info('Merged the stack base into "%s"' % public_ref)
>> + return
>
> Hmm. Couldn't the merge base conceivably be higher up in the stack?
> Like, right at the beginning, don't we have public_head == stack.head?
> That would be caught by the "same tree" check" a bit earlier, but
> after adding another patch, don't we have public_head == stack.head^ ?
> Which would give merge_base == public_head.
We could have public_head == stack.head^... but that's not an issue.
The merge_base above is checked against the base of the stack rather
than the top as we assume that the base isn't volatile. So even if
public_head is the same as some patch commit, the merge_base above
would always be the base of the stack. Only if the stack base was
updated, we get a different merge_base (equal to the previous stack
base).
>> + def get_merge_base(self, commit1, commit2):
>> + """Return the merge base of two commits."""
>> + sha1 = self.run(['git', 'merge-base',
>> + commit1.sha1, commit2.sha1]).output_one_line()
>> + return self.get_commit(sha1)
>
> This funcion should probably return a list of zero or more merge
> bases. See the --all flag to git merge-base.
OK, I'll add this and check the stack base against this set(list).
--
Catalin
next prev parent reply other threads:[~2009-05-28 14:38 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-05-28 11:12 [RFC][StGit PATCH] Add support for merge-friendly branches Catalin Marinas
[not found] ` <20090528111212.21925.45527.stgit-hhZApKj8DF/YkXV2EHHjLW3o5bpOHsLO@public.gmane.org>
2009-05-28 12:12 ` Fwd: " martin f krafft
2009-05-28 12:48 ` Karl Hasselström
2009-05-28 14:38 ` Catalin Marinas [this message]
2009-05-28 14:51 ` Catalin Marinas
2009-05-29 7:20 ` Karl Hasselström
2009-05-29 8:40 ` Catalin Marinas
2009-05-29 9:12 ` Karl Hasselström
2009-05-29 10:13 ` Catalin Marinas
2009-05-29 8:37 ` Karl Hasselström
2009-05-29 9:16 ` Catalin Marinas
2009-05-29 11:59 ` Karl Hasselström
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=b0943d9e0905280738n51476ab7vd0498ea7a236c4a7@mail.gmail.com \
--to=catalin.marinas@gmail.com \
--cc=git@vger.kernel.org \
--cc=kha@treskal.com \
/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
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).