Hi, I’ve got myself stuck on an issue, I’ve started a big rebase (I know that was already a bad idea to begin with, but, just in case, the information I’m looking for could always come in handy in other occasions), I reordered a few commits and squashed some, while in the process I resolved a few conflicts, then after I resolved one of them and got to the next conflict I realised that I shouldn’t have put a certain commit there, is there a way to rewind the process to the previous step while staying in the rebase? That way I could move the commit to where it should be and continue.
I know you can edit the todo (git --edit-todo), but that only works for the next commits, I also can’t just reset back by the number of commits I want, e.g. git reset --hard HEAD~4, because for the rebase those commits remain as done and doing git rebase --continue only brings me to where I am already, the next conflict to resolve.
So I wonder, is there a way to move out commits of the done list back into todo? Also for example if I trashed an unmerged file completely while messing around, so I can get it back to its initial state, this would be extremely useful

  • QuazarOmegaOPA
    link
    fedilink
    arrow-up
    2
    ·
    edit-2
    8 months ago

    Really cool, I’ll give jj a try sometime, thanks for bringing it to my attention!
    As for the rebase I’ll try in a toy repo, if it works as expected it would be great, this time I ended up aborting and starting over, then doing several rebases on the same range of commits to eventually get to the result I wanted without having to fear losing/breaking something or caving due to the cognitive load of managing many commits at a time

    • dblsaiko@discuss.tchncs.de
      link
      fedilink
      arrow-up
      2
      ·
      8 months ago

      Another thing about jj which I really love: it makes it a lot more easy to maintain a bunch of PR branches at once. Look at this 8-way-merge here on my fork (2xsaiko): https://github.com/mesonbuild/meson/network. The tip of that is what I’m developing on top of and then squashing changes into one of the commits in one of the branches which are mostly PRs. And rebasing the entire thing on top of upstream’s master is essentially trivial, best case it’s one command. See https://ofcr.se/jujutsu-merge-workflow for details on how it’s done!

      • QuazarOmegaOPA
        link
        fedilink
        arrow-up
        2
        ·
        8 months ago

        That looks pretty crazy! I kinda want to unlock this power ngl