cmder/vendor/init.bat

416 lines
14 KiB
Batchfile
Raw Normal View History

@echo off
2018-11-11 21:04:35 +08:00
set CMDER_INIT_START=%time%
:: Init Script for cmd.exe
:: Created as part of cmder project
:: !!! THIS FILE IS OVERWRITTEN WHEN CMDER IS UPDATED
:: !!! Use "%CMDER_ROOT%\config\user_profile.cmd" to add your own startup commands
2018-03-13 23:38:27 +08:00
:: Use /v command line arg or set to > 0 for verbose output to aid in debugging.
2018-09-02 11:08:00 +08:00
set verbose_output=0
set debug_output=0
set time_init=0
set fast_init=0
2018-03-13 23:38:27 +08:00
set max_depth=1
set "CMDER_USER_FLAGS= "
:: Find root dir
if not defined CMDER_ROOT (
2017-06-23 17:48:03 +08:00
if defined ConEmuDir (
2018-03-13 23:38:27 +08:00
for /f "delims=" %%i in ("%ConEmuDir%\..\..") do (
set "CMDER_ROOT=%%~fi"
)
2017-06-23 17:48:03 +08:00
) else (
2018-03-13 23:38:27 +08:00
for /f "delims=" %%i in ("%~dp0\..") do (
set "CMDER_ROOT=%%~fi"
)
2017-06-23 17:48:03 +08:00
)
)
2018-03-13 23:38:27 +08:00
:: Remove trailing '\' from %CMDER_ROOT%
if "%CMDER_ROOT:~-1%" == "\" SET "CMDER_ROOT=%CMDER_ROOT:~0,-1%"
2018-09-16 02:55:54 +08:00
call "%cmder_root%\vendor\bin\cexec.cmd" /setpath
call "%cmder_root%\vendor\lib\lib_base"
call "%cmder_root%\vendor\lib\lib_path"
call "%cmder_root%\vendor\lib\lib_console"
call "%cmder_root%\vendor\lib\lib_git"
call "%cmder_root%\vendor\lib\lib_profile"
2018-03-13 23:38:27 +08:00
:var_loop
if "%~1" == "" (
goto :start
) else if /i "%1" == "/f" (
set fast_init=1
) else if /i "%1" == "/t" (
set time_init=1
2018-04-04 01:20:49 +08:00
) else if /i "%1"=="/v" (
2018-09-02 11:08:00 +08:00
set verbose_output=1
2018-04-04 01:20:49 +08:00
) else if /i "%1"=="/d" (
2018-09-02 11:08:00 +08:00
set debug_output=1
2018-04-04 01:20:49 +08:00
) else if /i "%1" == "/max_depth" (
2018-03-13 23:38:27 +08:00
if "%~2" geq "1" if "%~2" leq "5" (
set "max_depth=%~2"
shift
) else (
%lib_console% show_error "'/max_depth' requires a number between 1 and 5!"
2018-03-13 23:38:27 +08:00
exit /b
)
2018-04-04 01:20:49 +08:00
) else if /i "%1" == "/c" (
2018-03-13 23:38:27 +08:00
if exist "%~2" (
if not exist "%~2\bin" mkdir "%~2\bin"
set "cmder_user_bin=%~2\bin"
if not exist "%~2\config\profile.d" mkdir "%~2\config\profile.d"
set "cmder_user_config=%~2\config"
shift
)
2018-04-04 01:20:49 +08:00
) else if /i "%1" == "/user_aliases" (
2018-03-13 23:38:27 +08:00
if exist "%~2" (
set "user_aliases=%~2"
2018-03-13 23:38:27 +08:00
shift
)
2018-04-04 01:20:49 +08:00
) else if /i "%1" == "/git_install_root" (
2018-09-03 19:08:44 +08:00
if exist "%~2" (
2018-03-13 23:38:27 +08:00
set "GIT_INSTALL_ROOT=%~2"
shift
) else (
2018-09-03 08:17:16 +08:00
%lib_console% show_error "The Git install root folder "%~2", you specified does not exist!"
2018-03-13 23:38:27 +08:00
exit /b
)
2018-04-04 01:20:49 +08:00
) else if /i "%1" == "/home" (
2018-03-13 23:38:27 +08:00
if exist "%~2" (
set "HOME=%~2"
shift
) else (
%lib_console% show_error The home folder "%2", you specified does not exist!
2018-03-13 23:38:27 +08:00
exit /b
)
2018-04-04 01:20:49 +08:00
) else if /i "%1" == "/svn_ssh" (
2018-03-13 23:38:27 +08:00
set SVN_SSH=%2
shift
2018-05-01 20:57:02 +08:00
) else (
set "CMDER_USER_FLAGS=%1 %CMDER_USER_FLAGS%"
2018-03-13 23:38:27 +08:00
)
shift
goto var_loop
:start
2018-09-03 07:18:59 +08:00
:: Sets CMDER_SHELL, CMDER_CLINK, CMDER_ALIASES
2018-09-03 06:32:20 +08:00
%lib_base% cmder_shell
2018-09-02 11:08:00 +08:00
%lib_console% debug_output init.bat "Env Var - CMDER_ROOT=%CMDER_ROOT%"
%lib_console% debug_output init.bat "Env Var - debug_output=%debug_output%"
2018-03-13 23:38:27 +08:00
if defined CMDER_USER_CONFIG (
2018-09-02 11:08:00 +08:00
%lib_console% debug_output init.bat "CMDER IS ALSO USING INDIVIDUAL USER CONFIG FROM '%CMDER_USER_CONFIG%'!"
2018-03-13 23:38:27 +08:00
)
2013-07-09 15:43:50 +08:00
:: Pick right version of clink
if "%PROCESSOR_ARCHITECTURE%"=="x86" (
2013-07-09 15:43:50 +08:00
set architecture=86
2018-03-13 23:38:27 +08:00
set architecture_bits=32
2013-07-09 15:43:50 +08:00
) else (
set architecture=64
2018-03-13 23:38:27 +08:00
set architecture_bits=64
2013-07-09 15:43:50 +08:00
)
2018-09-03 07:18:59 +08:00
if "%CMDER_CLINK%" == "1" (
2018-09-03 07:53:49 +08:00
%lib_console% verbose_output "Injecting Clink!"
2018-09-02 11:08:00 +08:00
:: Run clink
if defined CMDER_USER_CONFIG (
2018-09-03 07:18:59 +08:00
if not exist "%CMDER_USER_CONFIG%\settings" (
echo Generating clink initial settings in "%CMDER_USER_CONFIG%\settings"
echo Additional *.lua files in "%CMDER_USER_CONFIG%" are loaded on startup.\
)
"%CMDER_ROOT%\vendor\clink\clink_x%architecture%.exe" inject --quiet --profile "%CMDER_USER_CONFIG%" --scripts "%CMDER_ROOT%\vendor"
2018-09-02 11:08:00 +08:00
) else (
2018-09-03 07:18:59 +08:00
if not exist "%CMDER_ROOT%\config\settings" (
echo Generating clink initial settings in "%CMDER_ROOT%\config\settings"
echo Additional *.lua files in "%CMDER_ROOT%\config" are loaded on startup.
)
"%CMDER_ROOT%\vendor\clink\clink_x%architecture%.exe" inject --quiet --profile "%CMDER_ROOT%\config" --scripts "%CMDER_ROOT%\vendor"
2018-09-02 11:08:00 +08:00
)
2018-09-03 07:53:49 +08:00
) else (
%lib_console% verbose_output "WARNING: Incompatible 'ComSpec/Shell' Detetected Skipping Clink Injection!"
2018-09-03 06:32:20 +08:00
)
2013-07-09 15:43:50 +08:00
:: Prepare for git-for-windows
2013-11-04 01:04:36 +08:00
:: I do not even know, copypasted from their .bat
set PLINK_PROTOCOL=ssh
if not defined TERM set TERM=cygwin
2013-07-16 05:45:25 +08:00
:: The idea:
:: * if the users points as to a specific git, use that
:: * test if a git is in path and if yes, use that
:: * last, use our vendored git
:: also check that we have a recent enough version of git by examining the version string
2018-05-27 02:29:19 +08:00
setlocal enabledelayedexpansion
if defined GIT_INSTALL_ROOT (
2018-09-16 23:18:10 +08:00
if exist "%GIT_INSTALL_ROOT%\cmd\git.exe" goto :SPECIFIED_GIT
) else if "%fast_init%" == "1" (
if exist "%CMDER_ROOT%\vendor\git-for-windows\cmd\git.exe" (
%lib_console% debug_output "Skipping Git Auto-Detect!"
goto :VENDORED_GIT
)
)
2018-09-02 11:08:00 +08:00
%lib_console% debug_output init.bat "Looking for Git install root..."
2018-05-27 02:29:19 +08:00
:: get the version information for vendored git binary
%lib_git% read_version VENDORED "%CMDER_ROOT%\vendor\git-for-windows\cmd"
2018-09-16 23:18:10 +08:00
%lib_git% validate_version VENDORED %GIT_VERSION_VENDORED%
:: check if git is in path...
2018-03-13 23:38:27 +08:00
for /F "delims=" %%F in ('where git.exe 2^>nul') do (
:: get the absolute path to the user provided git binary
pushd %%~dpF
:: check if there's shim - and if yes follow the path
if exist git.shim (
for /F "tokens=2 delims== " %%I in (git.shim) do (
pushd %%~dpI
set "test_dir=!CD!"
popd
)
) else (
set "test_dir=!CD!"
)
popd
:: get the version information for the user provided git binary
%lib_git% read_version USER "!test_dir!"
%lib_git% validate_version USER !GIT_VERSION_USER!
if !errorlevel! geq 0 (
:: compare the user git version against the vendored version
%lib_git% compare_versions USER VENDORED
:: use the user provided git if its version is greater than, or equal to the vendored git
2018-03-13 23:38:27 +08:00
if !errorlevel! geq 0 if exist "!test_dir:~0,-4!\cmd\git.exe" (
set "GIT_INSTALL_ROOT=!test_dir:~0,-4!"
set test_dir=
goto :FOUND_GIT
) else if !errorlevel! geq 0 (
set "GIT_INSTALL_ROOT=!test_dir!"
set test_dir=
goto :FOUND_GIT
) else (
2018-09-02 11:08:00 +08:00
call :verbose_output Found old !GIT_VERSION_USER! in "!test_dir!", but not using...
set test_dir=
)
) else (
:: if the user provided git executable is not found
if !errorlevel! equ -255 (
2018-09-02 11:08:00 +08:00
call :verbose_output No git at "!git_executable!" found.
set test_dir=
)
)
)
:: our last hope: our own git...
:VENDORED_GIT
if exist "%CMDER_ROOT%\vendor\git-for-windows" (
set "GIT_INSTALL_ROOT=%CMDER_ROOT%\vendor\git-for-windows"
2018-09-16 23:18:10 +08:00
%lib_console% debug_output "Using vendored Git from '!GIT_INSTALL_ROOT!..."
goto :CONFIGURE_GIT
) else (
goto :NO_GIT
)
2018-09-16 23:18:10 +08:00
:SPECIFIED_GIT
%lib_console% debug_output "Using /GIT_INSTALL_ROOT from '%GIT_INSTALL_ROOT%..."
goto :CONFIGURE_GIT
:FOUND_GIT
2018-09-16 23:18:10 +08:00
%lib_console% debug_output "Using found Git from '%GIT_INSTALL_ROOT%..."
goto :CONFIGURE_GIT
:CONFIGURE_GIT
:: Add git to the path
if defined GIT_INSTALL_ROOT (
rem add the unix commands at the end to not shadow windows commands like more
if exist "!GIT_INSTALL_ROOT!\cmd\git.exe" %lib_path% enhance_path "!GIT_INSTALL_ROOT!\cmd" append
2018-03-13 23:38:27 +08:00
if exist "!GIT_INSTALL_ROOT!\mingw32" (
2018-09-18 17:26:11 +08:00
%lib_path% enhance_path "!GIT_INSTALL_ROOT!\mingw32\bin" append
2018-03-13 23:38:27 +08:00
) else if exist "!GIT_INSTALL_ROOT!\mingw64" (
2018-09-18 17:26:11 +08:00
%lib_path% enhance_path "!GIT_INSTALL_ROOT!\mingw64\bin" append
2018-03-13 23:38:27 +08:00
)
%lib_path% enhance_path "!GIT_INSTALL_ROOT!\usr\bin" append
:: define SVN_SSH so we can use git svn with ssh svn repositories
if not defined SVN_SSH set "SVN_SSH=%GIT_INSTALL_ROOT:\=\\%\\bin\\ssh.exe"
2018-11-30 19:01:21 +08:00
if not defined LANG (
:: Find locale.exe: From the git install root, from the path, using the git installed env, or fallback using the env from the path.
if not defined git_locale if exist "!GIT_INSTALL_ROOT!\usr\bin\locale.exe" set git_locale="!GIT_INSTALL_ROOT!\usr\bin\locale.exe"
if not defined git_locale for /F "delims=" %%F in ('where locale.exe 2^>nul') do (if not defined git_locale set git_locale="%%F")
if not defined git_locale if exist "!GIT_INSTALL_ROOT!\usr\bin\env.exe" set git_locale="!GIT_INSTALL_ROOT!\usr\bin\env.exe" /usr/bin/locale
if not defined git_locale set git_locale=env /usr/bin/locale
for /F "delims=" %%F in ('!git_locale! -uU 2') do (
set "LANG=%%F"
)
2018-08-23 11:50:29 +08:00
)
)
2018-08-23 11:50:29 +08:00
endlocal & set "PATH=%PATH%" & set "LANG=%LANG%" & set "SVN_SSH=%SVN_SSH%" & set "GIT_INSTALL_ROOT=%GIT_INSTALL_ROOT%"
2018-09-02 11:08:00 +08:00
%lib_console% debug_output init.bat "Env Var - GIT_INSTALL_ROOT=%GIT_INSTALL_ROOT%"
%lib_console% debug_output init.bat "Found Git in: '%GIT_INSTALL_ROOT%'"
2018-05-27 02:29:19 +08:00
goto :PATH_ENHANCE
:NO_GIT
2018-05-27 02:29:19 +08:00
:: Skip this if GIT WAS FOUND else we did 'endlocal' above!
endlocal
2018-05-27 02:29:19 +08:00
:PATH_ENHANCE
%lib_path% enhance_path "%CMDER_ROOT%\vendor\bin"
2018-04-04 01:20:49 +08:00
%lib_path% enhance_path_recursive "%CMDER_ROOT%\bin" %max_depth%
2018-03-13 23:38:27 +08:00
if defined CMDER_USER_BIN (
%lib_path% enhance_path_recursive "%CMDER_USER_BIN%" %max_depth%
2018-03-13 23:38:27 +08:00
)
%lib_path% enhance_path "%CMDER_ROOT%" append
2013-07-16 05:45:25 +08:00
:: Drop *.bat and *.cmd files into "%CMDER_ROOT%\config\profile.d"
:: to run them at startup.
%lib_profile% run_profile_d "%CMDER_ROOT%\config\profile.d"
2018-03-13 23:38:27 +08:00
if defined CMDER_USER_CONFIG (
%lib_profile% run_profile_d "%CMDER_USER_CONFIG%\profile.d"
)
2015-11-25 06:38:26 +08:00
2016-03-20 21:30:20 +08:00
:: Allows user to override default aliases store using profile.d
:: scripts run above by setting the 'aliases' env variable.
::
:: Note: If overriding default aliases store file the aliases
:: must also be self executing, see '.\user_aliases.cmd.example',
:: and be in profile.d folder.
if not defined user_aliases (
2018-03-13 23:38:27 +08:00
if defined CMDER_USER_CONFIG (
set "user_aliases=%CMDER_USER_CONFIG%\user_aliases.cmd"
2018-03-13 23:38:27 +08:00
) else (
set "user_aliases=%CMDER_ROOT%\config\user_aliases.cmd"
2018-03-13 23:38:27 +08:00
)
)
2018-09-03 07:18:59 +08:00
if "%CMDER_ALIASES%" == "1" (
2018-09-02 22:04:46 +08:00
REM The aliases environment variable is used by alias.bat to id
REM the default file to store new aliases in.
2018-09-02 11:08:00 +08:00
if not defined aliases (
set "aliases=%user_aliases%"
)
2018-09-03 07:59:14 +08:00
2018-09-02 22:04:46 +08:00
REM Make sure we have a self-extracting user_aliases.cmd file
2018-09-02 11:08:00 +08:00
setlocal enabledelayedexpansion
if not exist "%user_aliases%" (
echo Creating initial user_aliases store in "%user_aliases%"...
copy "%CMDER_ROOT%\vendor\user_aliases.cmd.example" "%user_aliases%"
) else (
type "%user_aliases%" | %WINDIR%\System32\findstr /i ";= Add aliases below here" >nul
2018-09-02 11:08:00 +08:00
if "!errorlevel!" == "1" (
echo Creating initial user_aliases store in "%user_aliases%"...
if defined CMDER_USER_CONFIG (
copy "%user_aliases%" "%user_aliases%.old_format"
copy "%CMDER_ROOT%\vendor\user_aliases.cmd.example" "%user_aliases%"
) else (
copy "%user_aliases%" "%user_aliases%.old_format"
copy "%CMDER_ROOT%\vendor\user_aliases.cmd.example" "%user_aliases%"
)
)
)
2018-09-03 07:59:14 +08:00
2018-09-02 11:08:00 +08:00
:: Update old 'user_aliases' to new self executing 'user_aliases.cmd'
if exist "%CMDER_ROOT%\config\aliases" (
echo Updating old "%CMDER_ROOT%\config\aliases" to new format...
2018-09-02 22:04:46 +08:00
type "%CMDER_ROOT%\config\aliases" >> "%user_aliases%"
del "%CMDER_ROOT%\config\aliases"
2018-09-02 11:08:00 +08:00
) else if exist "%user_aliases%.old_format" (
echo Updating old "%user_aliases%" to new format...
2018-09-02 22:04:46 +08:00
type "%user_aliases%.old_format" >> "%user_aliases%"
del "%user_aliases%.old_format"
2018-09-02 11:08:00 +08:00
)
endlocal
2016-03-20 21:30:20 +08:00
)
2018-03-13 23:38:27 +08:00
:: Add aliases to the environment
call "%user_aliases%"
:: See vendor\git-for-windows\README.portable for why we do this
:: Basically we need to execute this post-install.bat because we are
:: manually extracting the archive rather than executing the 7z sfx
2018-03-13 23:38:27 +08:00
if exist "%GIT_INSTALL_ROOT%\post-install.bat" (
2018-09-02 11:08:00 +08:00
%lib_console% verbose_output "Running Git for Windows one time Post Install...."
2018-03-13 23:38:27 +08:00
pushd "%GIT_INSTALL_ROOT%\"
"%GIT_INSTALL_ROOT%\git-bash.exe" --no-needs-console --hide --no-cd --command=post-install.bat
2017-11-11 00:05:47 +08:00
popd
)
2013-11-16 00:06:15 +08:00
:: Set home path
if not defined HOME set "HOME=%USERPROFILE%"
2018-09-02 11:08:00 +08:00
%lib_console% debug_output init.bat "Env Var - HOME=%HOME%"
set "initialConfig=%CMDER_ROOT%\config\user_profile.cmd"
if exist "%CMDER_ROOT%\config\user_profile.cmd" (
REM Create this file and place your own command in there
%lib_console% debug_output init.bat "Calling - %CMDER_ROOT%\config\user_profile.cmd"
call "%CMDER_ROOT%\config\user_profile.cmd"
2018-03-13 23:38:27 +08:00
)
2018-04-04 01:20:49 +08:00
if defined CMDER_USER_CONFIG (
set "initialConfig=%CMDER_USER_CONFIG%\user_profile.cmd"
if exist "%CMDER_USER_CONFIG%\user_profile.cmd" (
2018-04-04 01:20:49 +08:00
REM Create this file and place your own command in there
%lib_console% debug_output init.bat "Calling - %CMDER_USER_CONFIG%\user_profile.cmd
call "%CMDER_USER_CONFIG%\user_profile.cmd"
2018-04-04 01:20:49 +08:00
)
)
if not exist "%initialConfig%" (
echo Creating user startup file: "%initialConfig%"
2018-04-13 09:06:00 +08:00
(
2018-03-13 23:38:27 +08:00
echo :: use this file to run your own startup commands
2018-09-16 23:18:10 +08:00
echo :: use in front of the command to prevent printing the command
2018-03-13 23:38:27 +08:00
echo.
echo :: uncomment this to have the ssh agent load when cmder starts
echo :: call "%%GIT_INSTALL_ROOT%%/cmd/start-ssh-agent.cmd"
echo.
2018-09-16 23:18:10 +08:00
echo :: uncomment the next two lines to use pageant as the ssh authentication agent
2018-03-13 23:38:27 +08:00
echo :: SET SSH_AUTH_SOCK=/tmp/.ssh-pageant-auth-sock
echo :: call "%%GIT_INSTALL_ROOT%%/cmd/start-ssh-pageant.cmd"
echo.
echo :: you can add your plugins to the cmder path like so
echo :: set "PATH=%%CMDER_ROOT%%\vendor\whatever;%%PATH%%"
echo.
2018-05-18 20:32:05 +08:00
echo :: arguments in this batch are passed from init.bat, you can quickly parse them like so:
2018-09-17 05:23:22 +08:00
echo :: more useage can be seen by typing "cexec /?"
2018-05-01 20:57:02 +08:00
echo.
2018-09-17 05:23:22 +08:00
echo :: %%ccall%% "/customOption" "command/program"
echo.
2018-03-13 23:38:27 +08:00
echo @echo off
2018-04-04 01:20:49 +08:00
) >"%initialConfig%"
)
2018-09-03 07:18:59 +08:00
if "%CMDER_ALIASES%" == "1" if exist "%CMDER_ROOT%\bin\alias.bat" if exist "%CMDER_ROOT%\vendor\bin\alias.cmd" (
echo Cmder's 'alias' command has been moved into "%CMDER_ROOT%\vendor\bin\alias.cmd"
echo to get rid of this message either:
echo.
echo Delete the file "%CMDER_ROOT%\bin\alias.bat"
echo.
echo or
echo.
2018-09-02 06:32:21 +08:00
echo If you have customized it and want to continue using it instead of the included version
echo * Rename "%CMDER_ROOT%\bin\alias.bat" to "%CMDER_ROOT%\bin\alias.cmd".
2018-09-03 07:59:14 +08:00
echo * Search for 'user-aliases' and replace it with 'user_aliases'.
)
2018-04-04 01:20:49 +08:00
set initialConfig=
2018-09-16 23:18:10 +08:00
set CMDER_CONFIGURED=1
2018-09-04 00:59:43 +08:00
2018-11-11 21:04:35 +08:00
set CMDER_INIT_END=%time%
if %time_init% gtr 0 (
2018-11-11 21:04:35 +08:00
"%cmder_root%\vendor\bin\timer.cmd" %CMDER_INIT_START% %CMDER_INIT_END%
)
exit /b