gitbranchgit-branch

Handling temporary changes (not to be committed) in Git


Often while working on a branch I need to introduce some "temporary" changes (such as additional debugging info, or a change which lets me better observe the thing i'm actually working on).

About these "temporary" changes:

Currently I just keep them as unstaged and I skip them manually when staging every commit. However I can't stay with this solution because:

How should I deal with it?


gitignore is obviously out of the question because I don't want to ignore the whole files and I'm still interested in changes from other committers (I need to rebase the branch to master from time to time).


Solution

  • I typically deal with this by using:

    git add -p
    

    ... to stage changes hunk-by-hunk. Then you just have to make sure to press n for your debugging changes.


    If I have more involved changes of this type, I'll create a branch called something like local-changes with a commit at its tip that introduces the debugging code. After creating a few more commits, I'd then use:

    git rebase -i master
    

    ... to reorder them so that the commit with the local changes is at the tip again. Then to update master and return to the local changes branch, you can do:

    git checkout master
    git merge local-changes^
    git checkout local-changes