Re: GSoC idea: allow "git rebase --interactive" todo lines to take options

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 02/26/2014 11:52 AM, Jeff King wrote:
> On Wed, Feb 26, 2014 at 09:04:30AM +0100, Michael Haggerty wrote:
> 
>> It would be nice to support more flexibility in the todo-list commands
>> by allowing the commands to take options.  Maybe
>>
>> * Convert a commit into a merge commit:
>>
>>       pick -p c0ffeee -p e1ee712 deadbab The oneline of the commit after
> 
> This seems like a reasonable feature to me. All of your examples are
> possible with an "e"dit and another git command, but the convenience may
> be worth it (though personally, most of the examples you gave are
> particularly interesting to me[1]).
> 
> I'd worry a little that it is not a summer's worth of work, but I
> suspect there are other parts of rebase--interactive that could use
> attention once the student is familiar with the code.
> 
>> * After squashing two commits, add a "Signed-off-by" line to the
>>   commit log message:
>>
>>     pick deadbee Implement feature XXX
>>     squash --signoff f1a5c00 Fix to feature XXX
>>
>>   or GPG-sign a commit:
>>
>>     pick --gpg-sign=<keyid> deadbee Implement feature XXX
>>
>> * Reset the author of the commit to the current user or a specified
>>   user:
>>
>>     pick --reset-author deadbee Implement feature XXX
>>     pick --author="A U Thor <author@xxxxxxxxxxx>" deadbab The oneline of
>> the commit after
> 
> Your first example would need some commit-tree magic, I think. But could
> you implement these two with:
> 
>    pick deadbee Implement feature XXX
>    exec git commit --amend --signoff --reset-author
> 
> ? You could even alias the "amend" command to "exec git commit --amend",
> like:
> 
>   amend --signoff --reset-author
> 
> Maybe that is unnecessarily unfriendly to the user, though.

The whole point is to make these things easy.  But I have to admit that
"amend" would be another nice todo-list command.  Once the
infrastructure is there to handle options, it would be no big deal to
add an "amend" command with a "--signoff" option and offer the same
"--signoff" option on other, existing commands.

> [1] The one feature I would like in this vein is that editing the title
>     in the instruction-sheet would modify the commit message of the
>     relevant commit. For some reason I try to do this every few weeks,
>     but of course the changes are just thrown away.

Given that commit messages can be more than one line long, a feature
like this would be confusing, I think, and perhaps subtly encourage
people to limit their commit messages to a single line, which would be a
bad thing.  Plus, until now such edits were thrown away, so there are
backwards compatibility problems if we suddenly start preserving such edits.

But using the other ideas discussed here one could do

    pick -m "New log message" <sha1>

or

    amend -m "Revised log message"

It also might be reasonable, if the user edits the title in a way that
does not simply delete characters at the end, to do an implicit "reword"
with the edited title stuck in at the first line (and maybe the original
title following it, commented out with "#").

Another, more wonkish idea I though of would be

    pick --tree=<treeish> <sha1>

to force the tree of the commit to be set to that of the specified
<treeish> while keeping the commit metadata from <sha1>.  What would
this be useful for?  When swapping two commits, it is often the case
that conflicts have to be resolved twice.  But the tree should be the
same after both commits are applied, regardless of the order in which
they are applied.  So one could change

    pick aaaaaaa
    pick bbbbbbb

to

    pick bbbbbbb
    pick --tree=bbbbbbb aaaaaaa

On the other hand, maybe "git rebase --interactive" should have the
intelligence to do this automatically whenever the set of commits
pre/post rewriting is identical, possibly if a "--reorder-only" option
is used.

Michael

-- 
Michael Haggerty
mhagger@xxxxxxxxxxxx
http://softwareswirl.blogspot.com/
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]