2018-03-23 22:20:07 +08:00
|
|
|
@echo off
|
|
|
|
|
|
|
|
set lib_base=call "%~dp0lib_base.cmd"
|
|
|
|
|
|
|
|
if "%~1" == "/h" (
|
2018-05-31 20:35:02 +08:00
|
|
|
%lib_base% help "%~0"
|
2018-03-23 22:20:07 +08:00
|
|
|
) else if "%1" neq "" (
|
|
|
|
call :%*
|
|
|
|
)
|
|
|
|
|
|
|
|
exit /b
|
|
|
|
|
|
|
|
:::===============================================================================
|
2024-10-14 19:10:21 +08:00
|
|
|
:::help - shows all sub routines in a .bat/.cmd file with documentation
|
2018-03-23 22:20:07 +08:00
|
|
|
:::.
|
|
|
|
:::include:
|
|
|
|
:::.
|
2018-05-31 20:35:02 +08:00
|
|
|
::: call "lib_base.cmd"
|
2018-03-23 22:20:07 +08:00
|
|
|
:::.
|
|
|
|
:::usage:
|
|
|
|
:::.
|
2024-10-14 19:10:21 +08:00
|
|
|
::: %lib_base% help "file"
|
2018-03-23 22:20:07 +08:00
|
|
|
:::.
|
|
|
|
:::options:
|
|
|
|
:::.
|
|
|
|
::: file <in> full path to file containing lib_routines to display
|
|
|
|
:::-------------------------------------------------------------------------------
|
|
|
|
|
2024-10-14 19:10:21 +08:00
|
|
|
:help
|
|
|
|
for /f "tokens=* delims=:" %%a in ('%WINDIR%\System32\findstr /i /r "^:::" "%~1"') do (
|
2018-03-23 22:20:07 +08:00
|
|
|
if "%%a"=="." (
|
|
|
|
echo.
|
|
|
|
) else if /i "%%a" == "usage" (
|
|
|
|
echo %%a:
|
|
|
|
) else if /i "%%a" == "options" (
|
|
|
|
echo %%a:
|
|
|
|
) else if not "%%a" == "" (
|
|
|
|
echo %%a
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
pause
|
|
|
|
exit /b
|
2018-09-03 06:32:20 +08:00
|
|
|
|
|
|
|
:::===============================================================================
|
2024-10-14 19:10:21 +08:00
|
|
|
:::cmder_shell - Initializes the Cmder shell environment variables
|
|
|
|
:::.
|
|
|
|
:::description:
|
|
|
|
:::.
|
|
|
|
::: This routine sets up the Cmder shell environment by detecting the
|
|
|
|
::: command shell and initializing related variables.
|
2018-09-03 06:32:20 +08:00
|
|
|
:::.
|
|
|
|
:::include:
|
|
|
|
:::.
|
|
|
|
::: call "lib_base.cmd"
|
|
|
|
:::.
|
|
|
|
:::usage:
|
|
|
|
:::.
|
2018-09-03 07:56:17 +08:00
|
|
|
::: %lib_base% cmder_shell
|
2024-10-14 19:10:21 +08:00
|
|
|
:::-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
:cmder_shell
|
|
|
|
call :detect_comspec %ComSpec%
|
|
|
|
exit /b
|
|
|
|
|
|
|
|
:::===============================================================================
|
|
|
|
:::detect_comspec - Detects the command shell being used:::
|
2018-09-03 06:32:20 +08:00
|
|
|
:::.
|
2024-10-14 19:10:21 +08:00
|
|
|
:::description:
|
2018-09-03 06:32:20 +08:00
|
|
|
:::.
|
2024-10-14 19:10:21 +08:00
|
|
|
::: This function sets the CMDER_SHELL variable to the name of the
|
|
|
|
::: detected command shell. It also initializes the CMDER_CLINK and
|
|
|
|
::: CMDER_ALIASES variables if they are not already defined.
|
|
|
|
:::.
|
|
|
|
:::include:
|
2018-09-03 06:32:20 +08:00
|
|
|
:::.
|
2024-10-14 19:10:21 +08:00
|
|
|
::: call "lib_base.cmd"
|
|
|
|
:::.
|
|
|
|
:::usage:
|
|
|
|
:::.
|
|
|
|
::: %lib_base% detect_comspec %ComSpec%
|
2018-09-03 06:32:20 +08:00
|
|
|
:::-------------------------------------------------------------------------------
|
2022-10-15 17:16:13 +08:00
|
|
|
|
2022-09-09 20:54:25 +08:00
|
|
|
:detect_comspec
|
2022-09-09 21:11:45 +08:00
|
|
|
set CMDER_SHELL=%~n1
|
2019-08-22 18:20:19 +08:00
|
|
|
if not defined CMDER_CLINK (
|
|
|
|
set CMDER_CLINK=1
|
|
|
|
)
|
|
|
|
if not defined CMDER_ALIASES (
|
|
|
|
set CMDER_ALIASES=1
|
|
|
|
)
|
2019-10-13 22:07:23 +08:00
|
|
|
exit /b
|
2018-09-03 07:18:59 +08:00
|
|
|
|
2024-10-14 19:10:21 +08:00
|
|
|
:::===============================================================================
|
|
|
|
:::update_legacy_aliases - Updates the legacy alias definitions in the user_aliases file
|
|
|
|
:::.
|
|
|
|
:::description:
|
|
|
|
:::.
|
|
|
|
::: This function checks if the user_aliases file contains the marker
|
|
|
|
::: ";= Add aliases below here". If the marker is not found, it creates
|
|
|
|
::: an initial user_aliases store by copying the default user_aliases file
|
|
|
|
::: from the CMDER_ROOT directory. If the CMDER_USER_CONFIG environment
|
|
|
|
::: variable is defined, it creates a backup of the existing user_aliases
|
|
|
|
::: file before copying the default file.
|
|
|
|
:::.
|
|
|
|
:::include:
|
|
|
|
:::.
|
|
|
|
::: call "lib_base.cmd"
|
|
|
|
:::.
|
|
|
|
:::usage:
|
|
|
|
:::.
|
|
|
|
::: %lib_base% update_legacy_aliases
|
|
|
|
:::-------------------------------------------------------------------------------
|
|
|
|
|
2019-10-13 22:07:23 +08:00
|
|
|
:update_legacy_aliases
|
|
|
|
type "%user_aliases%" | %WINDIR%\System32\findstr /i ";= Add aliases below here" >nul
|
|
|
|
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.default" "%user_aliases%"
|
|
|
|
) else (
|
|
|
|
copy "%user_aliases%" "%user_aliases%.old_format"
|
|
|
|
copy "%CMDER_ROOT%\vendor\user_aliases.cmd.default" "%user_aliases%"
|
|
|
|
)
|
|
|
|
)
|
2018-09-03 06:32:20 +08:00
|
|
|
exit /b
|