On 26/09/19 10:46AM, Thomas Klaeger via GitGitGadget wrote:
> From: Thomas Klaeger <thklae...@gmail.com>
> 
> Git for Windows 2.x ships with an executable that starts the Git Bash
> with all the environment variables and what not properly set up. It is
> also adjusted according to the Terminal emulator option chosen when
> installing Git for Windows (while `bash.exe --login -i` would always
> launch with Windows' default console).
> 
> So let's use that executable (usually C:\Program Files\Git\git-bash.exe)
> instead of `bash.exe --login -i` if its presence was detected.
> 
> This fixes https://github.com/git-for-windows/git/issues/490
> 
> Signed-off-by: Thomas Kläger <thomas.klae...@10a.ch>
> Signed-off-by: Johannes Schindelin <johannes.schinde...@gmx.de>
> ---
>  git-gui.sh | 12 ++++++++++--
>  1 file changed, 10 insertions(+), 2 deletions(-)
> 
> diff --git a/git-gui.sh b/git-gui.sh
> index f9b323abff..5a1bfd736e 100755
> --- a/git-gui.sh
> +++ b/git-gui.sh
> @@ -2700,10 +2700,18 @@ if {![is_bare]} {
>  }
  
This hunk is kind of hard to understand. I'm writing what I make of it. 
Please correct me if I read it wrong.

Since this is a 4 year old commit not even authored by you, you might 
not have all the answers. That's OK. But I'd still like to point these 
things out. I do have a question at the end so please read the entire 
thing :)

>  if {[is_Windows]} {
> +     # Use /git-bash.exe if available
> +     set normalized [file normalize $::argv0]

argv0 would be the location of git-gui. We get an absolute path for the 
git-gui executable in the variable normalized.

> +     regsub "/mingw../libexec/git-core/git-gui$" \
> +             $normalized "/git-bash.exe" cmdLine

This finds the install location of git-bash by doing a string 
substitution. I'm assuming the path before /mingw.. is the installation 
directory of git, and so that's where git-bash would reside. We put that 
directory in cmdLine.

Nitpick: most of the code here uses snake case. So s/cmdLine/cmd_line/

> +     if {$cmdLine != $normalized && [file exists $cmdLine]} {

Why the $cmdLine != $normalized? When would they be equal? The string 
substitution should always change $cmdLine.

> +             set cmdLine [list "Git Bash" $cmdLine &]
> +     } else {
> +             set cmdLine [list "Git Bash" bash --login -l &]
> +     }
>       .mbar.repository add command \
>               -label [mc "Git Bash"] \
> -             -command {eval exec [auto_execok start] \
> -                                       [list "Git Bash" bash --login -l &]}
> +             -command {eval exec [auto_execok start] $cmdLine}
>  }
>  
>  if {[is_Windows] || ![is_bare]} {

The way of finding the path of git-bash is very hacky and would break as 
soon as there are any changes in the install locations. Plus, it is not 
at all easy to understand what's going on at first look.

Is there no better way of finding out git-bash's location? Is there 
something like the PATH environment variable in Windows that we can use 
to locate git-bash's executable? I have never developed in Windows so I 
have no idea how things work there.

On Linux for example, the exec() family of functions look into the PATH 
environment variable for the executable, so it is a pretty clean 
mechanism to execute programs.

-- 
Regards,
Pratyush Yadav

Reply via email to