diff options
author | Philip Oakley <philipoakley@iee.org> | 2015-12-14 10:37:02 +0000 |
---|---|---|
committer | Philip Oakley <philipoakley@iee.org> | 2017-01-20 20:55:01 +0000 |
commit | 2c1b06dff9a2b953c3692bacca6eeaa78d33fd01 (patch) | |
tree | 8be943ba523dc915ccfeb7a85cf8dd75257a6ab7 /lib | |
parent | git-gui: set version 0.21 (diff) | |
download | tgif-2c1b06dff9a2b953c3692bacca6eeaa78d33fd01.tar.xz |
git-gui: remove duplicate entries from .gitconfig's gui.recentrepo
The git gui's recent repo list may become contaminated with duplicate
entries. The git gui would barf when attempting to remove one entry.
Remove them all - there is no option within 'git config' to selectively
remove one of the entries.
This issue was reported on the 'Git User' list
(https://groups.google.com/forum/#!topic/git-users/msev4KsQGFc,
Warning: gui.recentrepo has multiply values while executing).
And also by zosrothko as a Git-for-Windows issue
https://github.com/git-for-windows/git/issues/1014.
On startup the gui checks that entries in the recentrepo list are still
valid repos and deletes thoses that are not. If duplicate entries are
present the 'git config --unset' will barf and this prevents the gui
from starting.
Subsequent patches fix other parts of recentrepo logic used for syncing
internal lists with the external .gitconfig.
Reported-by: Alexey Astakhov <asstv7@gmail.com>
Signed-off-by: Philip Oakley <philipoakley@iee.org>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/choose_repository.tcl | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/lib/choose_repository.tcl b/lib/choose_repository.tcl index 75d1da8d31..133ca0ac35 100644 --- a/lib/choose_repository.tcl +++ b/lib/choose_repository.tcl @@ -247,7 +247,7 @@ proc _get_recentrepos {} { proc _unset_recentrepo {p} { regsub -all -- {([()\[\]{}\.^$+*?\\])} $p {\\\1} p - git config --global --unset gui.recentrepo "^$p\$" + git config --global --unset-all gui.recentrepo "^$p\$" load_config 1 } |