Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

git-svn dcommiting a single git commit

Tags:

git

git-svn

Given multiple unpushed git commits, is it possible to git-svn dcommit only one of those commits?

e.g. I have commit foo, bar, and baz, but right now I only want to have bar end up in the svn repo. Is this possible?

like image 973
baudtack Avatar asked Aug 10 '09 17:08

baudtack


2 Answers

(The following assumes your work is on master.)

First, reorder your last three commits so that bar is first.

git rebase -i HEAD~3 

An editor will pop up with something like this:

pick 498e4f4 foo pick 71547ae bar pick abf09c6 baz  # Rebase 4d3fe72..abf09c6 onto 4d3fe72 # # ... 

Reorder them in the editor that pops up so that bar comes first.

pick 71547ae bar pick 498e4f4 foo pick abf09c6 baz  # Rebase 4d3fe72..abf09c6 onto 4d3fe72 # # ... 

Git will spin for a few seconds and burp up a confirmation:

Successfully rebased and updated refs/heads/master. 

Now you can temporarily roll back to the bar commit (HEAD~2 means two commits back from HEAD) and dcommit it:

git checkout HEAD~2 git svn dcommit 

If you're paranoid like me, you can do git svn dcommit -n first to be sure you're only committing what you want.

Now jump back to master:

git checkout master 

The last bit is to rebase so that master syncs up with svn:

git svn rebase 

It's a little fuzzy to me why this is required, but I'm guessing that dcommitting in a detached HEAD state has something to do with it.

like image 62
Mark Visser Avatar answered Sep 22 '22 15:09

Mark Visser


git svn dcommit cannot selectively commit bar. if you have directly committed foo, bar and baz on your master branch then you have to do the following to get only bar in svn.

Assume bar's commit sha is something like 13abc...

and git log master shows all your 3 commits foo, bar and baz.

  • you need to create a branch from master

    git branch wip

the wip branch now has foo, bar and baz

  • reset the master's head to a commit before any of foo, bar or baz. you can do that using git reset (read the manual, the differences between hard,soft and mixed options affects uncommitted changes in your working tree)

    git reset --hard (COMMIT-ID before foo,bar,baz)

    (or)

    git reset --hard HEAD~3 (go back 3 revisions)

now your master branch has none of foo, bar or baz. verify with git log.

  • now you can cherry pick only the commits you want to dcommit to svn from the wip branch into master. so to get bar

    git cherry-pick wip 13abc (sha of bar commit)

the master only gets the bar commit alone.

  • now git svn dcommit should push bar alone.

Suggested Future usage

So for git-svn it is preferable not to make commits directly on master branch which is tracking remote svn. do your work on local branches and merge selectively to master before dcommiting.

like image 36
Pradeep Avatar answered Sep 18 '22 15:09

Pradeep