@@ -2905,6 +2905,66 @@ int xwcstoutf(char *utf, const wchar_t *wcs, size_t utflen)
2905
2905
return -1 ;
2906
2906
}
2907
2907
2908
+ #ifdef ENSURE_MSYSTEM_IS_SET
2909
+ #if !defined(RUNTIME_PREFIX ) || !defined(HAVE_WPGMPTR )
2910
+ static size_t append_system_bin_dirs (char * path UNUSED , size_t size UNUSED )
2911
+ {
2912
+ return 0 ;
2913
+ }
2914
+ #else
2915
+ static size_t append_system_bin_dirs (char * path , size_t size )
2916
+ {
2917
+ char prefix [32768 ];
2918
+ const char * slash ;
2919
+ size_t len = xwcstoutf (prefix , _wpgmptr , sizeof (prefix )), off = 0 ;
2920
+
2921
+ if (len == 0 || len >= sizeof (prefix ) ||
2922
+ !(slash = find_last_dir_sep (prefix )))
2923
+ return 0 ;
2924
+ /* strip trailing `git.exe` */
2925
+ len = slash - prefix ;
2926
+
2927
+ /* strip trailing `cmd` or `mingw64\bin` or `mingw32\bin` or `bin` or `libexec\git-core` */
2928
+ if (strip_suffix_mem (prefix , & len , "\\mingw64\\libexec\\git-core" ) ||
2929
+ strip_suffix_mem (prefix , & len , "\\mingw64\\bin" ))
2930
+ off += xsnprintf (path + off , size - off ,
2931
+ "%.*s\\mingw64\\bin;" , (int )len , prefix );
2932
+ else if (strip_suffix_mem (prefix , & len , "\\clangarm64\\libexec\\git-core" ) ||
2933
+ strip_suffix_mem (prefix , & len , "\\clangarm64\\bin" ))
2934
+ off += xsnprintf (path + off , size - off ,
2935
+ "%.*s\\clangarm64\\bin;" , (int )len , prefix );
2936
+ else if (strip_suffix_mem (prefix , & len , "\\mingw32\\libexec\\git-core" ) ||
2937
+ strip_suffix_mem (prefix , & len , "\\mingw32\\bin" ))
2938
+ off += xsnprintf (path + off , size - off ,
2939
+ "%.*s\\mingw32\\bin;" , (int )len , prefix );
2940
+ else if (strip_suffix_mem (prefix , & len , "\\cmd" ) ||
2941
+ strip_suffix_mem (prefix , & len , "\\bin" ) ||
2942
+ strip_suffix_mem (prefix , & len , "\\libexec\\git-core" ))
2943
+ off += xsnprintf (path + off , size - off ,
2944
+ "%.*s\\mingw%d\\bin;" , (int )len , prefix ,
2945
+ (int )(sizeof (void * ) * 8 ));
2946
+ else
2947
+ return 0 ;
2948
+
2949
+ off += xsnprintf (path + off , size - off ,
2950
+ "%.*s\\usr\\bin;" , (int )len , prefix );
2951
+ return off ;
2952
+ }
2953
+ #endif
2954
+ #endif
2955
+
2956
+ static int is_system32_path (const char * path )
2957
+ {
2958
+ WCHAR system32 [MAX_PATH ], wpath [MAX_PATH ];
2959
+
2960
+ if (xutftowcs_path (wpath , path ) < 0 ||
2961
+ !GetSystemDirectoryW (system32 , ARRAY_SIZE (system32 )) ||
2962
+ _wcsicmp (system32 , wpath ))
2963
+ return 0 ;
2964
+
2965
+ return 1 ;
2966
+ }
2967
+
2908
2968
static void setup_windows_environment (void )
2909
2969
{
2910
2970
char * tmp = getenv ("TMPDIR" );
@@ -2945,7 +3005,8 @@ static void setup_windows_environment(void)
2945
3005
strbuf_addstr (& buf , tmp );
2946
3006
if ((tmp = getenv ("HOMEPATH" ))) {
2947
3007
strbuf_addstr (& buf , tmp );
2948
- if (is_directory (buf .buf ))
3008
+ if (!is_system32_path (buf .buf ) &&
3009
+ is_directory (buf .buf ))
2949
3010
setenv ("HOME" , buf .buf , 1 );
2950
3011
else
2951
3012
tmp = NULL ; /* use $USERPROFILE */
@@ -2956,6 +3017,41 @@ static void setup_windows_environment(void)
2956
3017
if (!tmp && (tmp = getenv ("USERPROFILE" )))
2957
3018
setenv ("HOME" , tmp , 1 );
2958
3019
}
3020
+
3021
+ if (!getenv ("PLINK_PROTOCOL" ))
3022
+ setenv ("PLINK_PROTOCOL" , "ssh" , 0 );
3023
+
3024
+ #ifdef ENSURE_MSYSTEM_IS_SET
3025
+ if (!(tmp = getenv ("MSYSTEM" )) || !tmp [0 ]) {
3026
+ const char * home = getenv ("HOME" ), * path = getenv ("PATH" );
3027
+ char buf [32768 ];
3028
+ size_t off = 0 ;
3029
+
3030
+ #if defined(__aarch64__ ) || defined(_M_ARM64 ) || defined(_M_ARM64EC )
3031
+ setenv ("MSYSTEM" , "CLANGARM64" , 1 );
3032
+ #elif defined(__MINGW64__ ) || defined(_M_AMD64 )
3033
+ setenv ("MSYSTEM" , "MINGW64" , 1 );
3034
+ #else
3035
+ setenv ("MSYSTEM" , "MINGW32" , 1 );
3036
+ #endif
3037
+
3038
+ if (home )
3039
+ off += xsnprintf (buf + off , sizeof (buf ) - off ,
3040
+ "%s\\bin;" , home );
3041
+ off += append_system_bin_dirs (buf + off , sizeof (buf ) - off );
3042
+ if (path )
3043
+ off += xsnprintf (buf + off , sizeof (buf ) - off ,
3044
+ "%s" , path );
3045
+ else if (off > 0 )
3046
+ buf [off - 1 ] = '\0' ;
3047
+ else
3048
+ buf [0 ] = '\0' ;
3049
+ setenv ("PATH" , buf , 1 );
3050
+ }
3051
+ #endif
3052
+
3053
+ if (!getenv ("LC_ALL" ) && !getenv ("LC_CTYPE" ) && !getenv ("LANG" ))
3054
+ setenv ("LC_CTYPE" , "C.UTF-8" , 1 );
2959
3055
}
2960
3056
2961
3057
static void get_current_user_sid (PSID * sid , HANDLE * linked_token )
0 commit comments