Compare commits
No commits in common. "d95bca7bc567769606646d1a5e13c2aeb6b535f8" and "5556e6bf3149c0c1664d6d747f2b83e4e34468f0" have entirely different histories.
d95bca7bc5
...
5556e6bf31
@ -72,7 +72,125 @@ function lgg {
|
|||||||
}
|
}
|
||||||
|
|
||||||
<# == zoxide cd == #>
|
<# == zoxide cd == #>
|
||||||
Invoke-Expression (& { (zoxide init powershell | Out-String) })
|
|
||||||
|
# =============================================================================
|
||||||
|
#
|
||||||
|
# Utility functions for zoxide.
|
||||||
|
#
|
||||||
|
|
||||||
|
# Call zoxide binary, returning the output as UTF-8.
|
||||||
|
function global:__zoxide_bin {
|
||||||
|
$encoding = [Console]::OutputEncoding
|
||||||
|
try {
|
||||||
|
[Console]::OutputEncoding = [System.Text.Utf8Encoding]::new()
|
||||||
|
$result = zoxide @args
|
||||||
|
return $result
|
||||||
|
} finally {
|
||||||
|
[Console]::OutputEncoding = $encoding
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# pwd based on zoxide's format.
|
||||||
|
function global:__zoxide_pwd {
|
||||||
|
$cwd = Get-Location
|
||||||
|
if ($cwd.Provider.Name -eq "FileSystem") {
|
||||||
|
$cwd.ProviderPath
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# cd + custom logic based on the value of _ZO_ECHO.
|
||||||
|
function global:__zoxide_cd($dir, $literal) {
|
||||||
|
$dir = if ($literal) {
|
||||||
|
Set-Location -LiteralPath $dir -Passthru -ErrorAction Stop
|
||||||
|
} else {
|
||||||
|
if ($dir -eq '-' -and ($PSVersionTable.PSVersion -lt 6.1)) {
|
||||||
|
Write-Error "cd - is not supported below PowerShell 6.1. Please upgrade your version of PowerShell."
|
||||||
|
}
|
||||||
|
elseif ($dir -eq '+' -and ($PSVersionTable.PSVersion -lt 6.2)) {
|
||||||
|
Write-Error "cd + is not supported below PowerShell 6.2. Please upgrade your version of PowerShell."
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Set-Location -Path $dir -Passthru -ErrorAction Stop
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# =============================================================================
|
||||||
|
#
|
||||||
|
# Hook configuration for zoxide.
|
||||||
|
#
|
||||||
|
|
||||||
|
# Hook to add new entries to the database.
|
||||||
|
$global:__zoxide_oldpwd = __zoxide_pwd
|
||||||
|
function global:__zoxide_hook {
|
||||||
|
$result = __zoxide_pwd
|
||||||
|
if ($result -ne $global:__zoxide_oldpwd) {
|
||||||
|
if ($null -ne $result) {
|
||||||
|
zoxide add -- $result
|
||||||
|
}
|
||||||
|
$global:__zoxide_oldpwd = $result
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Initialize hook.
|
||||||
|
$global:__zoxide_hooked = (Get-Variable __zoxide_hooked -ErrorAction SilentlyContinue -ValueOnly)
|
||||||
|
if ($global:__zoxide_hooked -ne 1) {
|
||||||
|
$global:__zoxide_hooked = 1
|
||||||
|
$global:__zoxide_prompt_old = $function:prompt
|
||||||
|
|
||||||
|
function global:prompt {
|
||||||
|
if ($null -ne $__zoxide_prompt_old) {
|
||||||
|
& $__zoxide_prompt_old
|
||||||
|
}
|
||||||
|
$null = __zoxide_hook
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# =============================================================================
|
||||||
|
#
|
||||||
|
# When using zoxide with --no-cmd, alias these internal functions as desired.
|
||||||
|
#
|
||||||
|
|
||||||
|
# Jump to a directory using only keywords.
|
||||||
|
function global:__zoxide_z {
|
||||||
|
if ($args.Length -eq 0) {
|
||||||
|
__zoxide_cd ~ $true
|
||||||
|
}
|
||||||
|
elseif ($args.Length -eq 1 -and ($args[0] -eq '-' -or $args[0] -eq '+')) {
|
||||||
|
__zoxide_cd $args[0] $false
|
||||||
|
}
|
||||||
|
elseif ($args.Length -eq 1 -and (Test-Path $args[0] -PathType Container)) {
|
||||||
|
__zoxide_cd $args[0] $true
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$result = __zoxide_pwd
|
||||||
|
if ($null -ne $result) {
|
||||||
|
$result = __zoxide_bin query --exclude $result -- @args
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$result = __zoxide_bin query -- @args
|
||||||
|
}
|
||||||
|
if ($LASTEXITCODE -eq 0) {
|
||||||
|
__zoxide_cd $result $true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Jump to a directory using interactive search.
|
||||||
|
function global:__zoxide_zi {
|
||||||
|
$result = __zoxide_bin query -i -- @args
|
||||||
|
if ($LASTEXITCODE -eq 0) {
|
||||||
|
__zoxide_cd $result $true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# =============================================================================
|
||||||
|
#
|
||||||
|
# Commands for zoxide. Disable these using --no-cmd.
|
||||||
|
#
|
||||||
|
|
||||||
|
Set-Alias -Name z -Value __zoxide_z -Option AllScope -Scope Global -Force
|
||||||
|
Set-Alias -Name zi -Value __zoxide_zi -Option AllScope -Scope Global -Force
|
||||||
Remove-Alias cd
|
Remove-Alias cd
|
||||||
Set-Alias -Name cd -Value z
|
Set-Alias -Name cd -Value z
|
||||||
Set-Alias -Name cdi -Value zi
|
Set-Alias -Name cdi -Value zi
|
||||||
|
Loading…
Reference in New Issue
Block a user