|
Hi all,
How exactly does git merge execute the commit? Does it use --no-verify at all? I've got a pre-commit hook to filter out testing data when merging into master, and if you merge with --no-commit, and then manually commit, the hook fires fine, but when merge autocommits, the hook doesn't get executed at all. Is there any other way to catch this event? I can add --no-commit to the branch.master.mergeoptions I suppose, but I don't want to add too much hassle for our Git users (if they're not checking in test data, of course). Regards, Liam Clarke-- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to [hidden email] More majordomo info at http://vger.kernel.org/majordomo-info.html |
|
On Wed, Feb 16, 2011 at 5:49 PM, Liam Clarke
<[hidden email]> wrote: > How exactly does git merge execute the commit? Merge calls commit_tree directly, so the standard commit hooks are bypassed. > Does it use --no-verify at all? I've got a pre-commit hook to filter out testing data when merging into master, and if you merge with --no-commit, and then manually commit, the hook fires fine, but when merge autocommits, the hook doesn't get executed at all. Is there any other way to catch this event? I can add --no-commit to the branch.master.mergeoptions I suppose, but I don't want to add too much hassle for our Git users (if they're not checking in test data, of course). I recently fixed this for prepare-commit-msg since that was the one I cared about. See http://thread.gmane.org/gmane.comp.version-control.git/151297 and http://thread.gmane.org/gmane.comp.version-control.git/166805 j. -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to [hidden email] More majordomo info at http://vger.kernel.org/majordomo-info.html |
|
Cheers Jay.
> The bypassing of pre-commit hook was and remains to be a conscious design decision. That doesn't sound good for my purposes. It also renders Git merge behaviour significantly surprising. :( > When you are pulling from your contributors who may have objectionable contents that you have to merge, the damage is already done; you _could_ yell at them to fix their branch and re-pull in theory, but that wouldn't work very well in practice. What about when I'm merging my own feature branches into master? Also, past performance indicates that yelling about bad stuff in merges works quite well when they're in the same office as you... ...but anyway, thanks for the heads up Jay. On 17/02/2011, at 5:36 PM, Jay Soffian wrote: > On Wed, Feb 16, 2011 at 5:49 PM, Liam Clarke > <[hidden email]> wrote: >> How exactly does git merge execute the commit? > > Merge calls commit_tree directly, so the standard commit hooks are bypassed. > >> Does it use --no-verify at all? I've got a pre-commit hook to filter out testing data when merging into master, and if you merge with --no-commit, and then manually commit, the hook fires fine, but when merge autocommits, the hook doesn't get executed at all. Is there any other way to catch this event? I can add --no-commit to the branch.master.mergeoptions I suppose, but I don't want to add too much hassle for our Git users (if they're not checking in test data, of course). > > I recently fixed this for prepare-commit-msg since that was the one I > cared about. See > http://thread.gmane.org/gmane.comp.version-control.git/151297 and > http://thread.gmane.org/gmane.comp.version-control.git/166805 > > j. > -- > To unsubscribe from this list: send the line "unsubscribe git" in > the body of a message to [hidden email] > More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to [hidden email] More majordomo info at http://vger.kernel.org/majordomo-info.html |
|
On Wed, Feb 16, 2011 at 11:44 PM, Liam Clarke
<[hidden email]> wrote: > Cheers Jay. > >> The bypassing of pre-commit hook was and remains to be a conscious design > decision. > > That doesn't sound good for my purposes. It also renders Git merge behaviour significantly surprising. :( I agree. Note that the grandparent statement belongs to Junio, but he also indicated at the end of the message that he didn't care too deeply. Personally, I think the commit hooks should fire whenever a commit is made, regardless of the source. Maybe the hooks should move to the low-level commit_tree, or maybe merge should invoke commit instead of commit_tree. j. -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to [hidden email] More majordomo info at http://vger.kernel.org/majordomo-info.html |
|
In reply to this post by Liam Clarke
On Wed, Feb 16, 2011 at 11:44 PM, Liam Clarke
<[hidden email]> wrote: > What about when I'm merging my own feature branches into master? Also, past performance indicates that yelling about bad stuff in merges works quite well when they're in the same office as you... BTW, why not just use the post-merge hook to amend the merge after the fact? j. -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to [hidden email] More majordomo info at http://vger.kernel.org/majordomo-info.html |
|
It can't affect the merge, but I could check for the data's existence, rm it, commit the deletion, and then scold the naughty developer... Yeah, not a bad idea actually. :) Cheers Jay.
On 17/02/2011, at 5:52 PM, Jay Soffian wrote: > On Wed, Feb 16, 2011 at 11:44 PM, Liam Clarke > <[hidden email]> wrote: >> What about when I'm merging my own feature branches into master? Also, past performance indicates that yelling about bad stuff in merges works quite well when they're in the same office as you... > > BTW, why not just use the post-merge hook to amend the merge after the fact? > > j. -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to [hidden email] More majordomo info at http://vger.kernel.org/majordomo-info.html |
| Powered by Nabble | Edit this page |
