]> git.ipfire.org Git - thirdparty/git.git/commitdiff
git-gui: simplify PATH de-duplication
authorMark Levedahl <mlevedahl@gmail.com>
Wed, 20 Aug 2025 15:31:43 +0000 (11:31 -0400)
committerJohannes Sixt <j6t@kdbg.org>
Thu, 21 Aug 2025 18:35:26 +0000 (20:35 +0200)
git-gui since 8fe7861c51 ("git-gui: assure PATH has only absolute
elements.", 2025-04-11) uses a list to maintain order and a dict to
detect duplicated elements without quadratic complexity.  But, Tcl's
dict explicitly maintains keys in the order first added, thus the list
is not needed.  Simplify the code.

Signed-off-by: Mark Levedahl <mlevedahl@gmail.com>
Signed-off-by: Johannes Sixt <j6t@kdbg.org>
git-gui.sh

index a931d7f7c99029899e18917c8e8ea190753dd0e1..9e0c47f842086b1dac7f468e3811117bfeedfd1d 100755 (executable)
@@ -103,7 +103,6 @@ if {[is_Windows]} {
        set _path_sep {:}
 }
 
-set _search_path {}
 set _path_seen [dict create]
 foreach p [split $env(PATH) $_path_sep] {
        # Keep only absolute paths, getting rid of ., empty, etc.
@@ -112,12 +111,9 @@ foreach p [split $env(PATH) $_path_sep] {
        }
        # Keep only the first occurence of any duplicates.
        set norm_p [file normalize $p]
-       if {[dict exists $_path_seen $norm_p]} {
-               continue
-       }
        dict set _path_seen $norm_p 1
-       lappend _search_path $norm_p
 }
+set _search_path [dict keys $_path_seen]
 unset _path_seen
 
 set env(PATH) [join $_search_path $_path_sep]