← Back to context

Comment by AlexCoventry

7 years ago

On the other hand, doing it is the only way you're going to learn. Just do it in a safe environment, with a snapshot of the repository.

Yep. That is the important tip, right here.

    $ pushd ..
    $ cp -a my-project my-project-before-I-did-git-surgery
    $ popd

Then relax. This is extremely important before playing with nasty Git surgical tools such as huge rebases. Borked it up?

    $ pushd ..
    $ rm -rf my-project
    $ cp -a my-project-before-I-did-git-surgery my-project
    $ popd

Undo is a great thing, and it's also important to triple check the entire state of the repository before you push, because pushing is basically committing to whatever surgery you've done. If you're having to fix stuff with -f, you're going to run into trouble; try to avoid -f ever.

  • This is so wrong. :) With git you exactly do not have to backup your local workspace, because it already is backed up in git.

    If it is committed, it is safe. You can go back to it. If you messed up your branch, just reset it to something that was good. No need to do manual backups.

    • Sure it's wrong if you know what you're doing. But that's not who the blog post is for.

      Sometimes it's okay to take liberties with good practices - especially when learning, or when the world is on fire and a push needs to happen now.

      1 reply →

    • No, it isn't, if you're playing with surgical tools that disrupt Git history, which was my point. It's a lot easier to revert to before you started than attempt to abort out of a huge rebase/squash/ugly merge conflict hell/rewrite of history. I'm not saying back up before every commit. I'm saying when `git status` is three pages long, you have 14,000 conflicts, and you're on a detached HEAD God knows where, it's your choice to spend the next hour typing the right Git commands to get back where you wanted to be, or just back out and try again. I know which one I'd prefer.

      5 replies →

  • >If you're having to fix stuff with -f, you're going to run into trouble; try to avoid -f ever.

    I disagree. I don't have much experience using git with big teams, but at least for small team where a developer usually owns a feature branch, force pushing to the branch to take into account criticism on commits can be helpful. Of course, in that case, feature branches are considered non shared.

    Git own "next" branch is actually force pushed to all the time, to remove patches which didn't make the cut for example.

    • Personal opinion - re-reviewing a pull request when someone has erased all context from your last review of that PR via a rebase and force push is a royal PITA. Especially for changes that span more than a few files. Did they address your concerns? The only way to know is to go back through all of the changes on that feature branch, and hope you don't miss anything.

      This, in contrast with just reviewing the latest commit, potentially going back to the rest of the changes with an eye towards the latest commit.

      It frankly bugs the piss out of me when people rebase and ask me to review their latest changes - it feels disrespectful of my time.

      1 reply →

    • > force pushing to the branch to take into account criticism on commits can be helpful

      Hm? Criticism on commits should be additive. The commit was made, response was made, and a new commit addresses the response. Rewriting history breaks a lot of things and removes context. Another approach:

      1) Add commit addressing criticism.

      2) Squash when merging feature in to master, which is one of the only cases where I think rewriting history is OK.

      Much cleaner master history, no rewriting history (which you should never do once another checkout sees your branch, including GitHub), and a number of other benefits. If you're routinely force pushing feature branches, something is broken in your workflow, IMO.