mirror of
				https://github.com/cmderdev/cmder.git
				synced 2025-10-31 01:12:11 +08:00 
			
		
		
		
	Merge branch 'master' of https://github.com/cmderdev/cmder into alias
This commit is contained in:
		
							
								
								
									
										21
									
								
								vendor/bin/alias.cmd
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										21
									
								
								vendor/bin/alias.cmd
									
									
									
									
										vendored
									
									
								
							| @@ -69,9 +69,6 @@ set args= | ||||
|     ) | ||||
|   ) | ||||
|  | ||||
| :: echo _x=%_x% | ||||
| :: echo args=%args% | ||||
|  | ||||
| rem #endregion parseargument | ||||
|  | ||||
| if "%ALIASES%" neq "%CMDER_ROOT%\config\user_aliases.cmd" ( | ||||
| @@ -88,11 +85,29 @@ if "%ALIASES%" neq "%CMDER_ROOT%\config\user_aliases.cmd" ( | ||||
| ) | ||||
|  | ||||
| :: create with multiple parameters | ||||
| <<<<<<< HEAD | ||||
| if [%action%] == [create] ( | ||||
|   if not ["%args%"] == [""] ( | ||||
|     for /f "tokens=1,* usebackq" %%G in (`echo %args%`) do ( | ||||
|       set alias_name=%%G | ||||
|       set alias_value=%%H | ||||
| ======= | ||||
| if [%1] == [create] ( | ||||
|   if not [%2] == [] ( | ||||
|     if not [%3] == [] ( | ||||
|       set _x=%1=%2 | ||||
|       :: if command create was submitted | ||||
|       set alias_name=%~2 | ||||
|       shift | ||||
|       shift | ||||
|       echo %* | ||||
|       set alias_value=%* | ||||
|  | ||||
|       for /f "tokens=1,2,* usebackq" %%G in (`echo %*`) do ( | ||||
|         set alias_name=%%H | ||||
|         set alias_value=%%I | ||||
|       ) | ||||
| >>>>>>> ac2082d56d59b3731824e11227eae396278b9f37 | ||||
|     ) | ||||
|   ) | ||||
| ) else ( | ||||
|   | ||||
							
								
								
									
										8
									
								
								vendor/init.bat
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								vendor/init.bat
									
									
									
									
										vendored
									
									
								
							| @@ -51,9 +51,7 @@ call "%cmder_root%\vendor\lib\lib_profile" | ||||
|     ) else if /i "%1"=="/v" ( | ||||
|         set verbose_output=1 | ||||
|     ) else if /i "%1"=="/d" ( | ||||
|         if not defined VSCODE_CWD ( | ||||
|             set debug_output=1 | ||||
|         ) | ||||
|         set debug_output=1 | ||||
|     ) else if /i "%1" == "/max_depth" ( | ||||
|         if "%~2" geq "1" if "%~2" leq "5" ( | ||||
|             set "max_depth=%~2" | ||||
| @@ -235,7 +233,7 @@ for /F "delims=" %%F in ('where git.exe 2^>nul') do ( | ||||
| :VENDORED_GIT | ||||
| if exist "%CMDER_ROOT%\vendor\git-for-windows" ( | ||||
|     set "GIT_INSTALL_ROOT=%CMDER_ROOT%\vendor\git-for-windows" | ||||
|     %lib_console% debug_output "Using vendored Git from '!GIT_INSTALL_ROOT!..." | ||||
|     %lib_console% debug_output "Using vendored Git '!GIT_VERSION_VENDORED!' from '!GIT_INSTALL_ROOT!..." | ||||
|     goto :CONFIGURE_GIT | ||||
| ) else ( | ||||
|     goto :NO_GIT | ||||
| @@ -246,7 +244,7 @@ if exist "%CMDER_ROOT%\vendor\git-for-windows" ( | ||||
| goto :CONFIGURE_GIT | ||||
|  | ||||
| :FOUND_GIT | ||||
| %lib_console% debug_output "Using found Git from '%GIT_INSTALL_ROOT%..." | ||||
| %lib_console% debug_output "Using found Git '!GIT_VERSION_USER!' from '%GIT_INSTALL_ROOT%..." | ||||
| goto :CONFIGURE_GIT | ||||
|  | ||||
| :CONFIGURE_GIT | ||||
|   | ||||
							
								
								
									
										6
									
								
								vendor/lib/lib_git.cmd
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								vendor/lib/lib_git.cmd
									
									
									
									
										vendored
									
									
								
							| @@ -88,8 +88,11 @@ exit /b | ||||
| :::  [SCOPE]_BUILD <out> Scoped Build version. | ||||
| :::------------------------------------------------------------------------------- | ||||
|  | ||||
|     setlocal enabledelayedexpansion | ||||
|     :: process a `x.x.x.xxxx.x` formatted string | ||||
|     set "%~1_MAJOR=" | ||||
|     set "%~1_MINOR=" | ||||
|     set "%~1_PATCH=" | ||||
|     set "%~1_BUILD=" | ||||
|     %lib_console% debug_output :parse_version "ARGV[1]=%~1, ARGV[2]=%~2" | ||||
|     for /F "tokens=1-3* delims=.,-" %%A in ("%2") do ( | ||||
|         set "%~1_MAJOR=%%A" | ||||
| @@ -98,7 +101,6 @@ exit /b | ||||
|         set "%~1_BUILD=%%D" | ||||
|     ) | ||||
|  | ||||
|     endlocal & set "%~1_MAJOR=!%~1_MAJOR!" & set "%~1_MINOR=!%~1_MINOR!" & set "%~1_PATCH=!%~1_PATCH!" & set "%~1_BUILD=!%~1_BUILD!" | ||||
|     exit /b | ||||
|  | ||||
| :validate_version | ||||
|   | ||||
							
								
								
									
										139
									
								
								vendor/profile.ps1
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										139
									
								
								vendor/profile.ps1
									
									
									
									
										vendored
									
									
								
							| @@ -25,9 +25,9 @@ if (! $ENV:CMDER_ROOT ) { | ||||
| # Remove trailing '\' | ||||
| $ENV:CMDER_ROOT = (($ENV:CMDER_ROOT).trimend("\")) | ||||
|  | ||||
| # do not load bundled psget if a module installer is already available | ||||
| # Do not load bundled psget if a module installer is already available | ||||
| # -> recent PowerShell versions include PowerShellGet out of the box | ||||
| $moduleInstallerAvailable = [bool](Get-Command -Name 'Install-Module' -ErrorAction SilentlyContinue | Out-Null) | ||||
| $moduleInstallerAvailable = [bool](Get-Command -Name 'Install-Module' -ErrorAction SilentlyContinue) | ||||
|  | ||||
| # Add Cmder modules directory to the autoload path. | ||||
| $CmderModulePath = Join-path $PSScriptRoot "psmodules/" | ||||
| @@ -36,26 +36,21 @@ if(-not $moduleInstallerAvailable -and -not $env:PSModulePath.Contains($CmderMod | ||||
|     $env:PSModulePath = $env:PSModulePath.Insert(0, "$CmderModulePath;") | ||||
| } | ||||
|  | ||||
| try { | ||||
|     Get-command -Name "vim" -ErrorAction Stop >$null | ||||
| } catch { | ||||
|     # # You could do this but it may be a little drastic and introduce a lot of | ||||
|     # # unix tool overlap with powershel unix like aliases | ||||
|     # $env:Path += $(";" + $env:CMDER_ROOT + "\vendor\git-for-windows\usr\bin") | ||||
|     # set-alias -name "vi" -value "vim" | ||||
|     # # I think the below is safer. | ||||
| function Configure-Git($GIT_INSTALL_ROOT){ | ||||
|   $env:Path += $(";" + $GIT_INSTALL_ROOT + "\cmd") | ||||
|  | ||||
|     new-alias -name "vim" -value $($ENV:CMDER_ROOT + "\vendor\git-for-windows\usr\bin\vim.exe") | ||||
|     new-alias -name "vi" -value vim | ||||
| } | ||||
|  | ||||
| try { | ||||
|     # Check if git is on PATH, i.e. Git already installed on system | ||||
|     Get-command -Name "git" -ErrorAction Stop >$null | ||||
| } catch { | ||||
|     $env:Path += $(";" + $env:CMDER_ROOT + "\vendor\git-for-windows\cmd") | ||||
|     # for bash.exe, which in the cmd version is found as <GIT>\usr\bin\bash.exe | ||||
|     $env:Path += $(";" + $env:CMDER_ROOT + "\vendor\git-for-windows\bin") | ||||
|   # Add "$GIT_INSTALL_ROOT\usr\bin" to the path if exists and not done already | ||||
|   $GIT_INSTALL_ROOT_ESC=$GIT_INSTALL_ROOT.replace('\','\\') | ||||
|   if ((test-path "$GIT_INSTALL_ROOT\usr\bin") -and -not ($env:path -match "$GIT_INSTALL_ROOT_ESC\\usr\\bin")) { | ||||
|       $env:path = "$env:path;$GIT_INSTALL_ROOT\usr\bin" | ||||
|   } | ||||
|    | ||||
|   # Add "$GIT_INSTALL_ROOT\mingw[32|64]\bin" to the path if exists and not done already | ||||
|   if ((test-path "$GIT_INSTALL_ROOT\mingw32\bin") -and -not ($env:path -match "$GIT_INSTALL_ROOT_ESC\\mingw32\\bin")) { | ||||
|       $env:path = "$env:path;$GIT_INSTALL_ROOT\mingw32\bin" | ||||
|   } elseif ((test-path "$GIT_INSTALL_ROOT\mingw64\bin") -and -not ($env:path -match "$GIT_INSTALL_ROOT_ESC\\mingw64\\bin")) { | ||||
|       $env:path = "$env:path;$GIT_INSTALL_ROOT\mingw64\bin" | ||||
|   } | ||||
| } | ||||
|  | ||||
| $gitLoaded = $false | ||||
| @@ -84,6 +79,19 @@ function checkGit($Path) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| try { | ||||
|     # Check if git is on PATH, i.e. Git already installed on system | ||||
|     Get-command -Name "git" -ErrorAction Stop >$null | ||||
| } catch { | ||||
|     if (test-path "$env:CMDER_ROOT\vendor\git-for-windows") { | ||||
|         Configure-Git "$env:CMDER_ROOT\vendor\git-for-windows" | ||||
|     } | ||||
| } | ||||
|  | ||||
| if ( Get-command -Name "vim" -ErrorAction silentlycontinue) { | ||||
|     new-alias -name "vi" -value vim | ||||
| } | ||||
|  | ||||
| if (Get-Module PSReadline -ErrorAction "SilentlyContinue") { | ||||
|     Set-PSReadlineOption -ExtraPromptLineCount 1 | ||||
| } | ||||
| @@ -91,36 +99,6 @@ if (Get-Module PSReadline -ErrorAction "SilentlyContinue") { | ||||
| # Enhance Path | ||||
| $env:Path = "$Env:CMDER_ROOT\bin;$Env:CMDER_ROOT\vendor\bin;$env:Path;$Env:CMDER_ROOT" | ||||
|  | ||||
| # | ||||
| # Prompt Section | ||||
| #   Users should modify their user_profile.ps1 as it will be safe from updates. | ||||
| # | ||||
|  | ||||
| # Pre assign the hooks so the first run of cmder gets a working prompt. | ||||
| [ScriptBlock]$PrePrompt = {} | ||||
| [ScriptBlock]$PostPrompt = {} | ||||
| [ScriptBlock]$CmderPrompt = { | ||||
|     $Host.UI.RawUI.ForegroundColor = "White" | ||||
|     Microsoft.PowerShell.Utility\Write-Host $pwd.ProviderPath -NoNewLine -ForegroundColor Green | ||||
|     checkGit($pwd.ProviderPath) | ||||
| } | ||||
|  | ||||
| <# | ||||
| This scriptblock runs every time the prompt is returned. | ||||
| Explicitly use functions from MS namespace to protect from being overridden in the user session. | ||||
| Custom prompt functions are loaded in as constants to get the same behaviour | ||||
| #> | ||||
| [ScriptBlock]$Prompt = { | ||||
|     $realLASTEXITCODE = $LASTEXITCODE | ||||
|     $host.UI.RawUI.WindowTitle = Microsoft.PowerShell.Management\Split-Path $pwd.ProviderPath -Leaf | ||||
|     PrePrompt | Microsoft.PowerShell.Utility\Write-Host -NoNewline | ||||
|     CmderPrompt | ||||
|     Microsoft.PowerShell.Utility\Write-Host "`nλ " -NoNewLine -ForegroundColor "DarkGray" | ||||
|     PostPrompt | Microsoft.PowerShell.Utility\Write-Host -NoNewline | ||||
|     $global:LASTEXITCODE = $realLASTEXITCODE | ||||
|     return " " | ||||
| } | ||||
|  | ||||
| # Drop *.ps1 files into "$ENV:CMDER_ROOT\config\profile.d" | ||||
| # to source them at startup. | ||||
| if (-not (test-path "$ENV:CMDER_ROOT\config\profile.d")) { | ||||
| @@ -154,7 +132,7 @@ if ($ENV:CMDER_USER_CONFIG -ne "" -and (test-path "$ENV:CMDER_USER_CONFIG\profil | ||||
|     } | ||||
|     popd | ||||
| } | ||||
|      | ||||
|  | ||||
| # Renaming to "config\user_profile.ps1" to "user_profile.ps1" for consistency. | ||||
| if (test-path "$env:CMDER_ROOT\config\user-profile.ps1") { | ||||
|   rename-item  "$env:CMDER_ROOT\config\user-profile.ps1" user_profile.ps1 | ||||
| @@ -185,11 +163,54 @@ if (! (Test-Path $CmderUserProfilePath) ) { | ||||
|     Copy-Item "$env:CMDER_ROOT\vendor\user_profile.ps1.default" -Destination $CmderUserProfilePath | ||||
| } | ||||
|  | ||||
| # Once Created these code blocks cannot be overwritten | ||||
| Set-Item -Path function:\PrePrompt   -Value $PrePrompt   -Options Constant | ||||
| Set-Item -Path function:\CmderPrompt -Value $CmderPrompt -Options Constant | ||||
| Set-Item -Path function:\PostPrompt  -Value $PostPrompt  -Options Constant | ||||
| # | ||||
| # Prompt Section | ||||
| #   Users should modify their user_profile.ps1 as it will be safe from updates. | ||||
| # | ||||
|  | ||||
| # Functions can be made constant only at creation time | ||||
| # ReadOnly at least requires `-force` to be overwritten | ||||
| Set-Item -Path function:\prompt  -Value $Prompt  -Options ReadOnly | ||||
| # Only set the prompt if it is currently set to the default | ||||
| # This allows users to configure the prompt in their user_profile.ps1 or config\profile.d\*.ps1 | ||||
| if ( $(get-command prompt).Definition -match 'PS \$\(\$executionContext.SessionState.Path.CurrentLocation\)\$\(' -and ` | ||||
|   $(get-command prompt).Definition -match '\(\$nestedPromptLevel \+ 1\)\) ";') { | ||||
|   # Pre assign the hooks so the first run of cmder gets a working prompt. | ||||
|   [ScriptBlock]$PrePrompt = {} | ||||
|   [ScriptBlock]$PostPrompt = {} | ||||
|   [ScriptBlock]$CmderPrompt = { | ||||
|       $Host.UI.RawUI.ForegroundColor = "White" | ||||
|       Microsoft.PowerShell.Utility\Write-Host $pwd.ProviderPath -NoNewLine -ForegroundColor Green | ||||
|       if (get-command git -erroraction silentlycontinue) { | ||||
|           checkGit($pwd.ProviderPath) | ||||
|       } | ||||
|   } | ||||
|  | ||||
|   <# | ||||
|   This scriptblock runs every time the prompt is returned. | ||||
|   Explicitly use functions from MS namespace to protect from being overridden in the user session. | ||||
|   Custom prompt functions are loaded in as constants to get the same behaviour | ||||
|   #> | ||||
|   [ScriptBlock]$Prompt = { | ||||
|       $realLASTEXITCODE = $LASTEXITCODE | ||||
|       $host.UI.RawUI.WindowTitle = Microsoft.PowerShell.Management\Split-Path $pwd.ProviderPath -Leaf | ||||
|       PrePrompt | Microsoft.PowerShell.Utility\Write-Host -NoNewline | ||||
|       CmderPrompt | ||||
|       Microsoft.PowerShell.Utility\Write-Host "`nλ " -NoNewLine -ForegroundColor "DarkGray" | ||||
|       PostPrompt | Microsoft.PowerShell.Utility\Write-Host -NoNewline | ||||
|       $global:LASTEXITCODE = $realLASTEXITCODE | ||||
|       return " " | ||||
|   } | ||||
|  | ||||
|  | ||||
|   # Once Created these code blocks cannot be overwritten | ||||
|   # if (-not $(get-command PrePrompt).Options -match 'Constant') {Set-Item -Path function:\PrePrompt   -Value $PrePrompt   -Options Constant} | ||||
|   # if (-not $(get-command CmderPrompt).Options -match 'Constant') {Set-Item -Path function:\CmderPrompt -Value $CmderPrompt -Options Constant} | ||||
|   # if (-not $(get-command PostPrompt).Options -match 'Constant') {Set-Item -Path function:\PostPrompt  -Value $PostPrompt  -Options Constant} | ||||
|  | ||||
|   Set-Item -Path function:\PrePrompt   -Value $PrePrompt   -Options Constant | ||||
|   Set-Item -Path function:\CmderPrompt -Value $CmderPrompt -Options Constant | ||||
|   Set-Item -Path function:\PostPrompt  -Value $PostPrompt  -Options Constant | ||||
|  | ||||
|   # Functions can be made constant only at creation time | ||||
|   # ReadOnly at least requires `-force` to be overwritten | ||||
|   # if (!$(get-command Prompt).Options -match 'ReadOnly') {Set-Item -Path function:\prompt  -Value $Prompt  -Options ReadOnly} | ||||
|   Set-Item -Path function:\prompt  -Value $Prompt  -Options ReadOnly | ||||
| } | ||||
|   | ||||
							
								
								
									
										16
									
								
								vendor/user_profile.ps1.default
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								vendor/user_profile.ps1.default
									
									
									
									
										vendored
									
									
								
							| @@ -23,3 +23,19 @@ | ||||
|  | ||||
| ## <Continue to add your own> | ||||
|  | ||||
| # # Delete default powershell aliases that conflict with bash commands | ||||
| # if (get-command git) { | ||||
| #     del -force alias:cat | ||||
| #     del -force alias:clear | ||||
| #     del -force alias:cp | ||||
| #     del -force alias:diff | ||||
| #     del -force alias:echo | ||||
| #     del -force alias:kill | ||||
| #     del -force alias:ls | ||||
| #     del -force alias:mv | ||||
| #     del -force alias:ps | ||||
| #     del -force alias:pwd | ||||
| #     del -force alias:rm | ||||
| #     del -force alias:sleep | ||||
| #     del -force alias:tee | ||||
| # } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user