Hi Johannes, thanks for testing! It's good to have people who care about details. On 17.12.20 20:45, Johannes Sixt wrote: > Am 01.11.20 um 18:05 schrieb Stefan Haller: >> Do an automatic rescan whenever the git-gui window receives focus. Most other >> GUI tools do this, and it's very convenient; no more pressing F5 manually. >> >> People who don't like this behavior can turn it off using >> "git config gui.autorescan false". >> >> Stefan Haller (2): >> git-gui: Delay rescan until idle time >> git-gui: Auto-rescan on activate >> >> git-gui.sh | 26 ++++++++++++++++++++++---- >> 1 file changed, 22 insertions(+), 4 deletions(-) >> > > I've been using these patches in the past days. > > I am still a bit ambivalent on whether I like the behavior. I do switch > among windows *a lot* and there is a short flicker on every rescan. And > there is muscle memory... Yes, the flicker is annoying. It also happens when you manually rescan (F5) though, so it's not a new problem. You just see it more often now. I didn't succeed to fix it yet, but I also didn't try very hard. Another problem that's related and can be annoying is that the text selection is lost on rescan; so if you select some lines because you want to stage them, and then before staging you briefly switch back to your editor to check something else, then you have to start over when you come back. I guess this could be fixed by remembering the selection on rescan, in a similar way how we remember the scroll position. As for muscle memory, in my experience this is something that you unlearn pretty quickly. On the contrary, I'm now having having trouble using git gui on machines that don't have the patch, because I got so used to relying on the window to always be up to date automatically. For me, I have to say that the auto-rescan is a total game-changer, even with all the problems that it still has. I don't want to do without it any more. > It is unclear which file is selected automatically when there are > unstaged changes. But there is one misbehavior: after I have invoked the > merge tool, resolved the conflict, and then switch back to Git GUI, the > conflicted file is not selected anymore when it is not the first file in > the list. That is *very* annoying. I tried to reproduce this, but couldn't. It would be helpful if you could post a more detailed reproduction recipe. Another related aspect: if you select an untracked file and then trigger a manual rescan, the file is no longer selected; it selects the first tracked, modified file instead. I don't know why it does this, I find this annoying. The auto-rescan doesn't have this behavior, it keeps the untracked file selected, which I like. > And then there is the following use-case. While Git GUI is not active > (think Git GUI and Gitk side-by-side and Gitk active), I click on a > particular file that is not at the top of the list; then Git GUI becomes > active and rescans, but also forgets on which file I have clicked. But I > expected the clicked-on file to become visible, which it doesn't, and I > have to click again. This is mildly annoying. Like Pratyush, I can't see why this should happen, and I can't reproduce it on my machine (Mac). What system are you on? -Stefan