diff --git a/config/fish/completions/app.fish b/config/fish/completions/app.fish new file mode 100644 index 0000000..a2669d3 --- /dev/null +++ b/config/fish/completions/app.fish @@ -0,0 +1,71 @@ +# @halostatue/fish-macos/completions/app.fish:v7.0.0 + +complete --command app --erase + +complete --command app --arguments bundleid \ + --exclusive --condition __fish_use_subcommand \ + --description 'Show bundle IDs for macOS apps' + +complete --command app --arguments find \ + --exclusive --condition __fish_use_subcommand \ + --description 'Find macOS apps by pattern' + +complete --command app --arguments frontmost \ + --exclusive --condition __fish_use_subcommand \ + --description 'Shows the front-most application' + +complete --command app --arguments icon \ + --exclusive --condition __fish_use_subcommand \ + --description 'Extracts a MacOS app icon as a png file' + +complete --command app --arguments quit \ + --exclusive --condition __fish_use_subcommand \ + --description 'Quit macOS apps by pattern' + +for subcommand in bundleid find + complete --command app --condition '__fish_seen_subcommand_from '$subcommand \ + --short-option x --long-option exact --description 'Exact matches only' + + complete --command app --condition '__fish_seen_subcommand_from '$subcommand \ + --short-option a --long-option all --description 'Show all matches' + + complete --command app --condition '__fish_seen_subcommand_from '$subcommand \ + --short-option q --long-option quiet --description 'Quiet (show no output)' + + complete --command app --condition '__fish_seen_subcommand_from '$subcommand \ + --short-option h --long-option help --description 'Help for app '$subcommand +end + +complete --command app --condition '__fish_seen_subcommand_from 'bundleid \ + --short-option s --long-option short --description 'Show only the bundle ID' + +complete --command app --condition '__fish_seen_subcommand_from 'frontmost \ + --short-option b --long-option bundle-id --description 'Shows the app bundle ID' +complete --command app --condition '__fish_seen_subcommand_from 'frontmost \ + --short-option p --long-option path --description 'Shows the app path' +complete --command app --condition '__fish_seen_subcommand_from 'frontmost \ + --short-option n --long-option name --description 'Shows the app name' +complete --command app --condition '__fish_seen_subcommand_from 'frontmost \ + --short-option P --long-option pid --description 'Shows the PID of the app' +complete --command app --condition '__fish_seen_subcommand_from 'frontmost \ + --short-option a --long-option all --description 'Shows all details' +complete --command app --condition '__fish_seen_subcommand_from 'frontmost \ + --short-option h --long-option help --description 'Help for app 'frontmost + +complete --command app --condition '__fish_seen_subcommand_from 'icon \ + --short-option x --long-option exact --description 'Exact matches only' +complete --command app --condition '__fish_seen_subcommand_from 'icon \ + --short-option o --long-option output --description 'Extracts to this file or directory' \ + --force-files +complete --command app --condition '__fish_seen_subcommand_from 'icon \ + --short-option w --long-option width --description 'Uses this pixel width' \ + --no-files +complete --command app --condition '__fish_seen_subcommand_from 'icon \ + --short-option h --long-option help --description 'Help for app 'icon + +complete --command app --condition '__fish_seen_subcommand_from 'quit \ + --short-option x --long-option exact --description 'Exact matches only' +complete --command app --condition '__fish_seen_subcommand_from 'quit \ + --short-option r --long-option restart --description 'Restart after quit' +complete --command app --condition '__fish_seen_subcommand_from 'quit \ + --short-option h --long-option help --description 'Help for app 'quit diff --git a/config/fish/completions/finder.fish b/config/fish/completions/finder.fish new file mode 100644 index 0000000..8267cc5 --- /dev/null +++ b/config/fish/completions/finder.fish @@ -0,0 +1,70 @@ +# @halostatue/fish-macos/completions/finder.fish:v7.0.0 + +complete --command finder --erase + +complete --command finder --arguments track \ + --exclusive --condition __fish_use_subcommand \ + --description 'Enables Finder PWD tracking' +complete --command finder --arguments untrack \ + --exclusive --condition __fish_use_subcommand \ + --description 'Disables Finder PWD tracking' +complete --command finder --arguments pwd \ + --exclusive --condition __fish_use_subcommand \ + --description 'Prints the path of the Finder window' +complete --command finder --arguments cd \ + --exclusive --condition __fish_use_subcommand \ + --description 'Changes to the path of the Finder window' +complete --command finder --arguments pushd \ + --exclusive --condition __fish_use_subcommand \ + --description 'Pushes to the path of the Finder window' +complete --command finder --arguments update \ + --exclusive --condition __fish_use_subcommand \ + --description 'Updates the Finder to PWD' +complete --command finder --arguments list \ + --exclusive --condition __fish_use_subcommand \ + --description 'Sets Finder to list view with PWD' +complete --command finder --arguments icon \ + --exclusive --condition __fish_use_subcommand \ + --description 'Sets Finder to icon view with PWD' +complete --command finder --arguments column \ + --exclusive --condition __fish_use_subcommand \ + --description 'Sets Finder to column view with PWD' +complete --command finder --arguments hidden \ + --exclusive --condition __fish_use_subcommand \ + --description 'Shows or hides `hidden` files' +complete --command finder --arguments desktop-icons \ + --exclusive --condition __fish_use_subcommand \ + --description 'Shows or hides desktop icons' +complete --command finder --arguments clean \ + --exclusive --condition __fish_use_subcommand \ + --description 'Cleans .DS_Store files' +complete --command finder --arguments quarantine \ + --exclusive --condition __fish_use_subcommand \ + --description 'Works with file quarantine data' +complete --command finder --arguments selected \ + --exclusive --condition __fish_use_subcommand \ + --description 'Print Finder selected files' + +for subcommand in cd clean column desktop-icons hidden icon list pushd pwd quarantine selected track untrack update + complete --command finder --condition '__fish_seen_subcommand_from '$subcommand \ + --short-option h --long-option help --description 'Help for finder '$subcommand +end + +for subcommand in hidden desktop-icons + complete --command finder --condition '__fish_seen_subcommand_from '$subcommand \ + --arguments off --description 'Turns '$subcommand' off' + complete --command finder --condition '__fish_seen_subcommand_from '$subcommand \ + --arguments on --description 'Turns '$subcommand' on' + complete --command finder --condition '__fish_seen_subcommand_from '$subcommand \ + --arguments toggle --description 'Toggles '$subcommand + complete --command finder --condition '__fish_seen_subcommand_from '$subcommand \ + --arguments status --description 'Shows the status of '$subcommand +end + +complete --command finder --condition '__fish_seen_subcommand_from 'quarantine \ + --arguments show --description 'Shows quarantine events' +complete --command finder --condition '__fish_seen_subcommand_from 'quarantine \ + --arguments clear --description 'Clears all quarantine events' +complete --command finder --condition '__fish_seen_subcommand_from 'quarantine \ + --arguments clean --description 'Removes 'quarantine' attributes from files' \ + --require-parameter --force-files diff --git a/config/fish/completions/fisher.fish b/config/fish/completions/fisher.fish new file mode 100644 index 0000000..6d23ce4 --- /dev/null +++ b/config/fish/completions/fisher.fish @@ -0,0 +1,7 @@ +complete --command fisher --exclusive --long help --description "Print help" +complete --command fisher --exclusive --long version --description "Print version" +complete --command fisher --exclusive --condition __fish_use_subcommand --arguments install --description "Install plugins" +complete --command fisher --exclusive --condition __fish_use_subcommand --arguments update --description "Update installed plugins" +complete --command fisher --exclusive --condition __fish_use_subcommand --arguments remove --description "Remove installed plugins" +complete --command fisher --exclusive --condition __fish_use_subcommand --arguments list --description "List installed plugins matching regex" +complete --command fisher --exclusive --condition "__fish_seen_subcommand_from update remove" --arguments "(fisher list)" diff --git a/config/fish/completions/mac.fish b/config/fish/completions/mac.fish new file mode 100644 index 0000000..1e09c6b --- /dev/null +++ b/config/fish/completions/mac.fish @@ -0,0 +1,119 @@ +# @halostatue/fish-macos/completions/mac.fish:v7.0.0 + +complete --command mac --erase + +complete --command mac --arguments airdrop \ + --exclusive --condition __fish_use_subcommand \ + --description 'Changes AirDrop settings' +complete --command mac --arguments airport \ + --exclusive --condition __fish_use_subcommand \ + --description 'Work with AirPort (WiFi) settings' +complete --command mac --arguments brightness \ + --exclusive --condition __fish_use_subcommand \ + --description 'Adjust the screen brightness level' +complete --command mac --arguments flushdns \ + --exclusive --condition __fish_use_subcommand \ + --description 'Flushes DNS' +complete --command mac --arguments font-smoothing \ + --exclusive --condition __fish_use_subcommand \ + --description 'Manages font smoothing settings' +complete --command mac --arguments lsclean \ + --exclusive --condition __fish_use_subcommand \ + --description 'Cleans LaunchServices to remove duplicate Open with... entries' +complete --command mac --arguments mail \ + --exclusive --condition __fish_use_subcommand \ + --description 'Manage various operations of Mail.app' +complete --command mac --arguments proxy-icon \ + --exclusive --condition __fish_use_subcommand \ + --description 'Manage proxy icon appearance delay' +complete --command mac --arguments transparency \ + --exclusive --condition __fish_use_subcommand \ + --description 'Manage UI transparency' +complete --command mac --arguments vol \ + --exclusive --condition __fish_use_subcommand \ + --description 'Changes Mac volume; accepts 0–100 volume percentage' + +for subcommand in airdrop airport brightness flushdns font-smoothing lsclean mail proxy-icon transparency version vol + complete --command mac --condition '__fish_seen_subcommand_from '$subcommand \ + --short-option h --long-option help --description 'Help for mac '$subcommand +end + +complete --command mac --condition '__fish_seen_subcommand_from brightness' \ + --arguments up --description 'Increases screen brightness' +complete --command mac --condition '__fish_seen_subcommand_from brightness' \ + --arguments down --description 'Decreases screen brightness' + +for subcommand in airdrop proxy-icon transparency + complete --command mac --condition '__fish_seen_subcommand_from '$subcommand \ + --arguments on --description 'Enables '$subcommand + complete --command mac --condition '__fish_seen_subcommand_from '$subcommand \ + --arguments off --description 'Disables '$subcommand + complete --command mac --condition '__fish_seen_subcommand_from '$subcommand \ + --arguments toggle --description 'Toggles '$subcommand + complete --command mac --condition '__fish_seen_subcommand_from '$subcommand \ + --arguments status --description 'Shows the status of '$subcommand +end + + +complete --command mac --condition '__fish_seen_subcommand_from 'airport \ + --arguments scan --description 'Shows available networks' +complete --command mac --condition '__fish_seen_subcommand_from 'airport \ + --arguments ssid --description 'Shows the SSID' +complete --command mac --condition '__fish_seen_subcommand_from 'airport \ + --arguments password --description 'Gets the current WiFi network password' + + +complete --command mac --condition '__fish_seen_subcommand_from 'font-smoothing \ + --arguments on --description 'Enables font smoothing; app IDs can be provided to limit control' +complete --command mac --condition '__fish_seen_subcommand_from 'font-smoothing \ + --arguments off --description 'Disables font smoothing; app IDs can be provided to limit control' + +complete --command mac --condition '__fish_seen_subcommand_from 'mail \ + --arguments vacuum --description 'Vacuums the Mail.app envelope index' +complete --command mac --condition '__fish_seen_subcommand_from 'mail \ + --arguments attachments --description 'Sets Mail.app attachment handling' \ + --require-parameter --no-files +complete --command mac --condition '__fish_seen_subcommand_from 'attachments \ + --arguments inline \ + --description 'Sets Mail.app attachment handling so that they are inline to the message' +complete --command mac --condition '__fish_seen_subcommand_from 'attachments \ + --arguments icon \ + --description 'Sets Mail.app attachment handling so that they are icons on the message' + +complete --command mac --condition '__fish_seen_subcommand_from 'version \ + --short-option s --long-option simple --description 'Simple mac version name' +complete --command mac --condition '__fish_seen_subcommand_from 'version \ + --short-option l --long-option lowercase --description 'Lowercase mac version name' +complete --command mac --condition '__fish_seen_subcommand_from 'version \ + --short-option f --long-option version --description 'Full version number' +complete --command mac --condition '__fish_seen_subcommand_from 'version \ + --short-option c --long-option comparable --description 'Simplified comparable version value' +complete --command mac --condition '__fish_seen_subcommand_from 'version \ + --short-option h --long-option help --description 'Help for mac 'version + +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments mute --description 'Mutes volume' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments unmute --description 'Unmutes volume' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments show --description 'Shows the current volume' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments 10 --description 'Sets the volume to 10%' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments 20 --description 'Sets the volume to 20%' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments 30 --description 'Sets the volume to 30%' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments 40 --description 'Sets the volume to 40%' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments 50 --description 'Sets the volume to 50%' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments 60 --description 'Sets the volume to 60%' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments 70 --description 'Sets the volume to 70%' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments 80 --description 'Sets the volume to 80%' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments 90 --description 'Sets the volume to 90%' +complete --command mac --condition '__fish_seen_subcommand_from 'vol \ + --arguments 100 --description 'Sets the volume to 100%' diff --git a/config/fish/completions/manp.fish b/config/fish/completions/manp.fish new file mode 100644 index 0000000..2034fcb --- /dev/null +++ b/config/fish/completions/manp.fish @@ -0,0 +1,8 @@ +# @halostatue/fish-macos/completions/manp.fish:v7.0.0 + +complete --command manp --erase +complete --command manp --wraps man +complete --command manp --exclusive --condition __fish_no_arguments \ + --short-option h --long-option help --description 'Show help for manp' +complete --command manp --exclusive --condition __fish_no_arguments \ + --long-option clear-cache --description 'Clear the man page PDF cache' diff --git a/config/fish/completions/nvm.fish b/config/fish/completions/nvm.fish new file mode 100644 index 0000000..14be1b7 --- /dev/null +++ b/config/fish/completions/nvm.fish @@ -0,0 +1,21 @@ +complete --command nvm --exclusive +complete --command nvm --exclusive --long version --description "Print version" +complete --command nvm --exclusive --long help --description "Print help" +complete --command nvm --long silent --description "Suppress standard output" + +complete --command nvm --exclusive --condition __fish_use_subcommand --arguments install --description "Download and activate the specified Node version" +complete --command nvm --exclusive --condition __fish_use_subcommand --arguments use --description "Activate the specified Node version in the current shell" +complete --command nvm --exclusive --condition __fish_use_subcommand --arguments list --description "List installed Node versions" +complete --command nvm --exclusive --condition __fish_use_subcommand --arguments list-remote --description "List available Node versions to install" +complete --command nvm --exclusive --condition __fish_use_subcommand --arguments current --description "Print the currently-active Node version" +complete --command nvm --exclusive --condition "__fish_seen_subcommand_from install" --arguments "( + test -e $nvm_data && string split ' ' <$nvm_data/.index +)" +complete --command nvm --exclusive --condition "__fish_seen_subcommand_from use" --arguments "(_nvm_list | string split ' ')" +complete --command nvm --exclusive --condition __fish_use_subcommand --arguments uninstall --description "Uninstall the specified Node version" +complete --command nvm --exclusive --condition "__fish_seen_subcommand_from uninstall" --arguments "( + _nvm_list | string split ' ' | string replace system '' +)" +complete --command nvm --exclusive --condition "__fish_seen_subcommand_from use uninstall" --arguments "( + set --query nvm_default_version && echo default +)" diff --git a/config/fish/completions/ql.fish b/config/fish/completions/ql.fish new file mode 100644 index 0000000..9f7518f --- /dev/null +++ b/config/fish/completions/ql.fish @@ -0,0 +1,4 @@ +# @halostatue/fish-macos/completions/ql.fish:v7.0.0 + +complete --erase --command ql +complete --command ql --wraps qlmanage diff --git a/config/fish/completions/tide.fish b/config/fish/completions/tide.fish new file mode 100644 index 0000000..1ba1960 --- /dev/null +++ b/config/fish/completions/tide.fish @@ -0,0 +1,13 @@ +complete tide --no-files + +set -l subcommands bug-report configure reload + +complete tide -x -n __fish_use_subcommand -a bug-report -d "Print info for use in bug reports" +complete tide -x -n __fish_use_subcommand -a configure -d "Run the configuration wizard" +complete tide -x -n __fish_use_subcommand -a reload -d "Reload tide configuration" + +complete tide -x -n "not __fish_seen_subcommand_from $subcommands" -s h -l help -d "Print help message" +complete tide -x -n "not __fish_seen_subcommand_from $subcommands" -s v -l version -d "Print tide version" + +complete tide -x -n '__fish_seen_subcommand_from bug-report' -l clean -d "Run clean Fish instance and install Tide" +complete tide -x -n '__fish_seen_subcommand_from bug-report' -l verbose -d "Print full Tide configuration" diff --git a/config/fish/conf.d/_tide_init.fish b/config/fish/conf.d/_tide_init.fish new file mode 100644 index 0000000..b448002 --- /dev/null +++ b/config/fish/conf.d/_tide_init.fish @@ -0,0 +1,44 @@ +function _tide_init_install --on-event _tide_init_install + set -U VIRTUAL_ENV_DISABLE_PROMPT true + + source (functions --details _tide_sub_configure) + _load_config lean + _tide_finish + + if status is-interactive + tide bug-report --check || sleep 4 + + if contains ilancosman/tide (string lower $_fisher_plugins) + set_color bryellow + echo "ilancosman/tide is a development branch. Please install from a release tag:" + _tide_fish_colorize "fisher install ilancosman/tide@v6" + sleep 3 + end + + switch (read --prompt-str="Configure tide prompt? [Y/n] " | string lower) + case y ye yes '' + tide configure + case '*' + echo -s \n 'Run ' (_tide_fish_colorize "tide configure") ' to customize your prompt.' + end + end +end + +function _tide_init_update --on-event _tide_init_update + # Warn users who install from main branch + if contains ilancosman/tide (string lower $_fisher_plugins) + set_color bryellow + echo "ilancosman/tide is a development branch. Please install from a release tag:" + _tide_fish_colorize "fisher install ilancosman/tide@v6" + sleep 3 + end + + # Set (disable) the new jobs variable + set -q tide_jobs_number_threshold || set -U tide_jobs_number_threshold 1000 +end + +function _tide_init_uninstall --on-event _tide_init_uninstall + set -e VIRTUAL_ENV_DISABLE_PROMPT + set -e (set -U --names | string match --entire -r '^_?tide') + functions --erase (functions --all | string match --entire -r '^_?tide') +end diff --git a/config/fish/conf.d/fish-ssh-agent.fish b/config/fish/conf.d/fish-ssh-agent.fish new file mode 100644 index 0000000..719087a --- /dev/null +++ b/config/fish/conf.d/fish-ssh-agent.fish @@ -0,0 +1,7 @@ +if test -z "$SSH_ENV" + set -xg SSH_ENV $HOME/.ssh/environment +end + +if not __ssh_agent_is_started + __ssh_agent_start +end diff --git a/config/fish/conf.d/halostatue_fish_brew.fish b/config/fish/conf.d/halostatue_fish_brew.fish new file mode 100644 index 0000000..0c7169d --- /dev/null +++ b/config/fish/conf.d/halostatue_fish_brew.fish @@ -0,0 +1,62 @@ +# @halostatue/fish-brew/conf.d/halostatue_fish_brew.fish:v3.2.1 + +# Find Homebrew via a known prefix. If the `__homebrew_prefix` universal +# variable is set, that will be set as the first test prefix. +if not command --query brew + set --local prefixes $HOME/.brew $HOME/.linuxbrew /opt/homebrew /usr/local + set --query --universal __homebrew_prefix + and set --prepend prefixes $__homebrew_prefix + + for prefix in $prefixes + test -x $prefix/bin/brew + or continue + + set --prepend PATH $prefix/bin + break + end +end + +if command --query brew + set --query --universal __brew_prefix + and set --erase --universal __brew_prefix + + set --local __brew_prefix (brew --prefix) + + if ! contains -- {$__brew_prefix}/bin $fish_user_paths + fish_add_path --append --move --path \ + {$__brew_prefix}/bin \ + /usr/local/bin \ + /usr/bin \ + /bin \ + {$__brew_prefix}/sbin \ + /usr/local/sbin \ + /usr/sbin \ + /sbin + end + + if test -s $HOME/.config/brew/config.fish + if status is-interactive + set --local deprecated 0 + + if set --query $__halostatue_fish_brew_config_deprecated + set deprecated $__halostatue_fish_brew_config_deprecated + end + + if test $deprecated -le 0 + echo >&2 "Sourcing ~/.config/brew/config.fish is deprecated." + echo >&2 "See https://docs.brew.sh/Manpage#environment for a better alternative." + + set --universal $__halostatue_fish_brew_config_deprecated 10 + else + set --universal $__halostatue_fish_brew_config_deprecated (math $deprecated - 1) + end + end + + source $HOME/.config/brew/config.fish + end +end + +function _halostatue_fish_brew_uninstall -e halostatue_fish_brew_uninstall + set --universal --erase __brew_prefix __halostatue_fish_brew_config_deprecated + functions --erase has_cask has_keg (status function) +end diff --git a/config/fish/conf.d/halostatue_fish_macos.fish b/config/fish/conf.d/halostatue_fish_macos.fish new file mode 100644 index 0000000..fcc266f --- /dev/null +++ b/config/fish/conf.d/halostatue_fish_macos.fish @@ -0,0 +1,14 @@ +# @halostatue/fish-macos/conf.d/halostatue_fish_macos.fish:v7.0.0 + +function _halostatue_fish_macos_uninstall -e halostatue_fish_macos_uninstall + set --function functions app finder has_app mac manp note ql remind + + for cmd in $functions + complete --erase --command $cmd + end + + set --append functions (status function) \ + (functions --all | string match --entire --regex '^__macos_app_|^__macos_finder_|^__macos_mac_') + + functions --erase $functions +end diff --git a/config/fish/conf.d/nvm.fish b/config/fish/conf.d/nvm.fish new file mode 100644 index 0000000..7545699 --- /dev/null +++ b/config/fish/conf.d/nvm.fish @@ -0,0 +1,28 @@ +set --query XDG_DATA_HOME || set --local XDG_DATA_HOME ~/.local/share +set --query nvm_mirror || set --global nvm_mirror https://nodejs.org/dist +set --query nvm_data || set --global nvm_data $XDG_DATA_HOME/nvm + +function _nvm_install --on-event nvm_install + test ! -d $nvm_data && command mkdir -p $nvm_data + echo "Downloading the Node distribution index..." 2>/dev/null + _nvm_index_update +end + +function _nvm_update --on-event nvm_update + set --query --universal nvm_data && set --erase --universal nvm_data + set --query --universal nvm_mirror && set --erase --universal nvm_mirror + set --query nvm_mirror || set --global nvm_mirror https://nodejs.org/dist +end + +function _nvm_uninstall --on-event nvm_uninstall + command rm -rf $nvm_data + + set --query nvm_current_version && _nvm_version_deactivate $nvm_current_version + + set --names | string replace --filter --regex -- "^nvm" "set --erase nvm" | source + functions --erase (functions --all | string match --entire --regex -- "^_nvm_") +end + +if status is-interactive && set --query nvm_default_version && ! set --query nvm_current_version + nvm use --silent $nvm_default_version +end diff --git a/config/fish/conf.d/paths.fish b/config/fish/conf.d/paths.fish new file mode 100644 index 0000000..83a7054 --- /dev/null +++ b/config/fish/conf.d/paths.fish @@ -0,0 +1,22 @@ +function ___paths_plugin_set_colors + if not set -q ___paths_plugin_colors + set -Ux ___paths_plugin_colors 27e6ff 29e0ff 5cd8ff 77d0ff 8ac8ff 9cbfff afb5ff c5a7ff d99bfe ea8feb f684d5 fe7abd ff73a3 ff708a fa7070 ff708a ff73a3 fe7abd f684d5 ea8feb d99bfe c5a7ff afb5ff 9cbfff 8ac8ff 77d0ff 5cd8ff 29e0ff + end + return 0 +end + +function _paths_uninstall --on-event paths_uninstall + for i in ___paths_plugin_wrap_color ___paths_plugin_output ___paths_plugin_handle_found_item ___paths_plugin_handle_source ___paths_plugin_cycle_color + functions -e $i + end + set -e ___paths_plugin_colors + set -e ___paths_plugin_current_color +end + +function _paths_install --on-event _paths_install + ___paths_plugin_set_colors +end + +function _paths_update --on-event paths_update + ___paths_plugin_set_colors +end diff --git a/config/fish/conf.d/z.fish b/config/fish/conf.d/z.fish new file mode 100644 index 0000000..59c960f --- /dev/null +++ b/config/fish/conf.d/z.fish @@ -0,0 +1,63 @@ +if test -z "$Z_DATA" + if test -z "$XDG_DATA_HOME" + set -U Z_DATA_DIR "$HOME/.local/share/z" + else + set -U Z_DATA_DIR "$XDG_DATA_HOME/z" + end + set -U Z_DATA "$Z_DATA_DIR/data" +end + +if test ! -e "$Z_DATA" + if test ! -e "$Z_DATA_DIR" + mkdir -p -m 700 "$Z_DATA_DIR" + end + touch "$Z_DATA" +end + +if test -z "$Z_CMD" + set -U Z_CMD z +end + +set -U ZO_CMD "$Z_CMD"o + +if test ! -z $Z_CMD + function $Z_CMD -d "jump around" + __z $argv + end +end + +if test ! -z $ZO_CMD + function $ZO_CMD -d "open target dir" + __z -d $argv + end +end + +if not set -q Z_EXCLUDE + set -U Z_EXCLUDE "^$HOME\$" +else if contains $HOME $Z_EXCLUDE + # Workaround: migrate old default values to a regex (see #90). + set Z_EXCLUDE (string replace -r -- "^$HOME\$" '^'$HOME'$$' $Z_EXCLUDE) +end + +# Setup completions once first +__z_complete + +function __z_on_variable_pwd --on-variable PWD + __z_add +end + +function __z_uninstall --on-event z_uninstall + functions -e __z_on_variable_pwd + functions -e $Z_CMD + functions -e $ZO_CMD + + if test ! -z "$Z_DATA" + printf "To completely erase z's data, remove:\n" >/dev/stderr + printf "%s\n" "$Z_DATA" >/dev/stderr + end + + set -e Z_CMD + set -e ZO_CMD + set -e Z_DATA + set -e Z_EXCLUDE +end diff --git a/config/fish/config.fish b/config/fish/config.fish new file mode 100644 index 0000000..2890646 --- /dev/null +++ b/config/fish/config.fish @@ -0,0 +1,7 @@ +if status is-interactive + # Commands to run in interactive sessions can go here + fish_add_path $HOME/.cargo/bin + fish_add_path $HOME/.local/bin + fish_add_path $HOME/.local/share/nvim/mason/bin + fish_add_path $HOME/.local/state/composer/vendor/bin +end diff --git a/config/fish/fish_plugins b/config/fish/fish_plugins new file mode 100644 index 0000000..ee76ccf --- /dev/null +++ b/config/fish/fish_plugins @@ -0,0 +1,9 @@ +jorgebucaran/fisher +jorgebucaran/nvm.fish +ilancosman/tide@v6 +jethrokuan/z +halostatue/fish-macos@v7 +ehfive/fish-bash2env +jgusta/paths +danhper/fish-ssh-agent +halostatue/fish-brew@v3 diff --git a/config/fish/fish_variables b/config/fish/fish_variables new file mode 100644 index 0000000..96e8e4c --- /dev/null +++ b/config/fish/fish_variables @@ -0,0 +1,212 @@ +# This file contains fish universal variable definitions. +# VERSION: 3.0 +SETUVAR VIRTUAL_ENV_DISABLE_PROMPT:true +SETUVAR ZO_CMD:zo +SETUVAR Z_CMD:z +SETUVAR Z_DATA:/Users/ivuorinen/\x2elocal/share/z/data +SETUVAR Z_DATA_DIR:/Users/ivuorinen/\x2elocal/share/z +SETUVAR Z_EXCLUDE:\x5e/Users/ivuorinen\x24 +SETUVAR --export ___paths_plugin_colors:27e6ff\x1e29e0ff\x1e5cd8ff\x1e77d0ff\x1e8ac8ff\x1e9cbfff\x1eafb5ff\x1ec5a7ff\x1ed99bfe\x1eea8feb\x1ef684d5\x1efe7abd\x1eff73a3\x1eff708a\x1efa7070\x1eff708a\x1eff73a3\x1efe7abd\x1ef684d5\x1eea8feb\x1ed99bfe\x1ec5a7ff\x1eafb5ff\x1e9cbfff\x1e8ac8ff\x1e77d0ff\x1e5cd8ff\x1e29e0ff +SETUVAR --export ___paths_plugin_current_color:4 +SETUVAR __fish_initialized:3400 +SETUVAR _fisher_danhper_2F_fish_2D_ssh_2D_agent_files:\x7e/\x2econfig/fish/functions/__ssh_agent_is_started\x2efish\x1e\x7e/\x2econfig/fish/functions/__ssh_agent_start\x2efish\x1e\x7e/\x2econfig/fish/conf\x2ed/fish\x2dssh\x2dagent\x2efish +SETUVAR _fisher_ehfive_2F_fish_2D_bash2env_files:\x7e/\x2econfig/fish/functions/__bash2env\x2esh\x1e\x7e/\x2econfig/fish/functions/bash2env\x2efish +SETUVAR _fisher_halostatue_2F_fish_2D_brew_40_v3_files:\x7e/\x2econfig/fish/functions/has_cask\x2efish\x1e\x7e/\x2econfig/fish/functions/has_keg\x2efish\x1e\x7e/\x2econfig/fish/conf\x2ed/halostatue_fish_brew\x2efish +SETUVAR _fisher_halostatue_2F_fish_2D_macos_40_v7_files:\x7e/\x2econfig/fish/functions/__macos_app_bundleid\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_app_find\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_app_frontmost\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_app_icon\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_app_quit\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_cd\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_clean\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_column\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_desktop_icons\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_hidden\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_icon\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_list\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_pushd\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_pwd\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_quarantine\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_selected\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_track\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_untrack\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_finder_update\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_airdrop\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_airport\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_brightness\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_defaults_query\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_flushdns\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_font_smoothing\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_lsclean\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_mail\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_proxy_icon\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_serialnumber\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_touchid\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_touchid_sudo\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_transparency\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_version\x2efish\x1e\x7e/\x2econfig/fish/functions/__macos_mac_vol\x2efish\x1e\x7e/\x2econfig/fish/functions/app\x2efish\x1e\x7e/\x2econfig/fish/functions/finder\x2efish\x1e\x7e/\x2econfig/fish/functions/has_app\x2efish\x1e\x7e/\x2econfig/fish/functions/mac\x2efish\x1e\x7e/\x2econfig/fish/functions/manp\x2efish\x1e\x7e/\x2econfig/fish/functions/note\x2efish\x1e\x7e/\x2econfig/fish/functions/ql\x2efish\x1e\x7e/\x2econfig/fish/functions/remind\x2efish\x1e\x7e/\x2econfig/fish/conf\x2ed/halostatue_fish_macos\x2efish\x1e\x7e/\x2econfig/fish/completions/app\x2efish\x1e\x7e/\x2econfig/fish/completions/finder\x2efish\x1e\x7e/\x2econfig/fish/completions/mac\x2efish\x1e\x7e/\x2econfig/fish/completions/manp\x2efish\x1e\x7e/\x2econfig/fish/completions/ql\x2efish +SETUVAR _fisher_ilancosman_2F_tide_40_v6_files:\x7e/\x2econfig/fish/functions/_tide_1_line_prompt\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_2_line_prompt\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_cache_variables\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_detect_os\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_find_and_remove\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_fish_colorize\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_aws\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_character\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_cmd_duration\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_context\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_crystal\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_direnv\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_distrobox\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_docker\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_elixir\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_gcloud\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_git\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_go\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_java\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_jobs\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_kubectl\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_nix_shell\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_node\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_os\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_php\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_private_mode\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_pulumi\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_python\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_ruby\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_rustc\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_shlvl\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_status\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_terraform\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_time\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_toolbox\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_vi_mode\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_zig\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_parent_dirs\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_print_item\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_pwd\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_remove_unusable_items\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_sub_bug\x2dreport\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_sub_configure\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_sub_reload\x2efish\x1e\x7e/\x2econfig/fish/functions/fish_mode_prompt\x2efish\x1e\x7e/\x2econfig/fish/functions/fish_prompt\x2efish\x1e\x7e/\x2econfig/fish/functions/tide\x1e\x7e/\x2econfig/fish/functions/tide\x2efish\x1e\x7e/\x2econfig/fish/conf\x2ed/_tide_init\x2efish\x1e\x7e/\x2econfig/fish/completions/tide\x2efish +SETUVAR _fisher_jethrokuan_2F_z_files:\x7e/\x2econfig/fish/functions/__z\x2efish\x1e\x7e/\x2econfig/fish/functions/__z_add\x2efish\x1e\x7e/\x2econfig/fish/functions/__z_clean\x2efish\x1e\x7e/\x2econfig/fish/functions/__z_complete\x2efish\x1e\x7e/\x2econfig/fish/conf\x2ed/z\x2efish +SETUVAR _fisher_jgusta_2F_paths_files:\x7e/\x2econfig/fish/functions/paths\x2efish\x1e\x7e/\x2econfig/fish/conf\x2ed/paths\x2efish +SETUVAR _fisher_jorgebucaran_2F_fisher_files:\x7e/\x2econfig/fish/functions/fisher\x2efish\x1e\x7e/\x2econfig/fish/completions/fisher\x2efish +SETUVAR _fisher_jorgebucaran_2F_nvm_2E_fish_files:\x7e/\x2econfig/fish/functions/_nvm_index_update\x2efish\x1e\x7e/\x2econfig/fish/functions/_nvm_list\x2efish\x1e\x7e/\x2econfig/fish/functions/_nvm_version_activate\x2efish\x1e\x7e/\x2econfig/fish/functions/_nvm_version_deactivate\x2efish\x1e\x7e/\x2econfig/fish/functions/nvm\x2efish\x1e\x7e/\x2econfig/fish/conf\x2ed/nvm\x2efish\x1e\x7e/\x2econfig/fish/completions/nvm\x2efish +SETUVAR _fisher_plugins:jorgebucaran/fisher\x1ejorgebucaran/nvm\x2efish\x1eilancosman/tide\x40v6\x1ejethrokuan/z\x1ehalostatue/fish\x2dmacos\x40v7\x1eehfive/fish\x2dbash2env\x1ejgusta/paths\x1edanhper/fish\x2dssh\x2dagent\x1ehalostatue/fish\x2dbrew\x40v3 +SETUVAR _fisher_upgraded_to_4_4:\x1d +SETUVAR _tide_left_items:os\x1epwd\x1egit\x1enewline\x1echaracter +SETUVAR _tide_prompt_4323:\x1b\x5bm\x0f\x1b\x5bm\x0f\x1b\x5bm\x0f\x1b\x5bm\x0f\x1b\x5bm\x0f\x1b\x5bm\x0f\uf179\x1b\x5b38\x3b2\x3b148\x3b148\x3b148m\x20\x1b\x5bm\x0f\x1b\x5bm\x0f\x40PWD\x40\x1b\x5b38\x3b2\x3b148\x3b148\x3b148m\x20\x1b\x5bm\x0f\x1b\x5bm\x0f\x1b\x5b38\x3b2\x3b95\x3b215\x3b0m\uf1d3\x20\x1b\x5b37m\x1b\x5b38\x3b2\x3b95\x3b215\x3b0mmain\x1b\x5b38\x3b2\x3b255\x3b0\x3b0m\x1b\x5b38\x3b2\x3b95\x3b215\x3b0m\x1b\x5b38\x3b2\x3b95\x3b215\x3b0m\x20\x2a1\x1b\x5b38\x3b2\x3b255\x3b0\x3b0m\x1b\x5b38\x3b2\x3b215\x3b175\x3b0m\x1b\x5b38\x3b2\x3b215\x3b175\x3b0m\x20\x2116\x1b\x5b38\x3b2\x3b0\x3b175\x3b255m\x20\x3f4\x1b\x5bm\x0f\x1b\x5bm\x0f\x1b\x5bm\x0f\x20\x1e\x1b\x5b38\x3b2\x3b95\x3b215\x3b0m\u276f\x1e\x1b\x5bm\x0f\x1b\x5bm\x0f\x1b\x5bm\x0f\x20\x1b\x5bm\x0f\x1b\x5bm\x0f\x1b\x5b38\x3b2\x3b68\x3b136\x3b62m\ue24f\x2022\x2e13\x2e1\x1b\x5b38\x3b2\x3b148\x3b148\x3b148m\x20\x1b\x5bm\x0f\x1b\x5bm\x0f\x1b\x5b38\x3b2\x3b0\x3b175\x3b175m\U000f0320\x203\x2e13\x2e2\x1b\x5bm\x0f\x1b\x5bm\x0f\x1b\x5bm\x0f +SETUVAR _tide_prompt_78628:\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\uf179\x1b\x5b38\x3b2\x3b148\x3b148\x3b148m\x20\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\x40PWD\x40\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\x20\x1e\x1b\x5b38\x3b2\x3b95\x3b215\x3b0m\u276f\x1e\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\x20\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\x1b\x5b38\x3b2\x3b135\x3b135\x3b95m\uf252\x207m\x2013s\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm\x1b\x28B\x1b\x5bm +SETUVAR _tide_right_items:status\x1ecmd_duration\x1econtext\x1ejobs\x1enode\x1epython\x1ejava\x1ephp\x1eruby\x1ekubectl\x1eterraform\x1eaws +SETUVAR fish_color_autosuggestion:brblack +SETUVAR fish_color_cancel:\x2dr +SETUVAR fish_color_command:blue +SETUVAR fish_color_comment:red +SETUVAR fish_color_cwd:green +SETUVAR fish_color_cwd_root:red +SETUVAR fish_color_end:green +SETUVAR fish_color_error:brred +SETUVAR fish_color_escape:brcyan +SETUVAR fish_color_history_current:\x2d\x2dbold +SETUVAR fish_color_host:normal +SETUVAR fish_color_host_remote:yellow +SETUVAR fish_color_normal:normal +SETUVAR fish_color_operator:brcyan +SETUVAR fish_color_param:cyan +SETUVAR fish_color_quote:yellow +SETUVAR fish_color_redirection:cyan\x1e\x2d\x2dbold +SETUVAR fish_color_search_match:bryellow\x1e\x2d\x2dbackground\x3dbrblack +SETUVAR fish_color_selection:white\x1e\x2d\x2dbold\x1e\x2d\x2dbackground\x3dbrblack +SETUVAR fish_color_status:red +SETUVAR fish_color_user:brgreen +SETUVAR fish_color_valid_path:\x2d\x2dunderline +SETUVAR fish_greeting:\x1d +SETUVAR fish_key_bindings:fish_default_key_bindings +SETUVAR fish_pager_color_completion:normal +SETUVAR fish_pager_color_description:yellow\x1e\x2di +SETUVAR fish_pager_color_prefix:normal\x1e\x2d\x2dbold\x1e\x2d\x2dunderline +SETUVAR fish_pager_color_progress:brwhite\x1e\x2d\x2dbackground\x3dcyan +SETUVAR fish_pager_color_selected_background:\x2dr +SETUVAR fish_user_paths:/Users/ivuorinen/\x2elocal/state/composer/vendor/bin\x1e/Users/ivuorinen/\x2elocal/share/nvim/mason/bin\x1e/Users/ivuorinen/\x2elocal/share/bob/nvim\x2dbin\x1e/Users/ivuorinen/\x2elocal/bin +SETUVAR tide_aws_bg_color:normal +SETUVAR tide_aws_color:FF9900 +SETUVAR tide_aws_icon:\uf270 +SETUVAR tide_character_color:5FD700 +SETUVAR tide_character_color_failure:FF0000 +SETUVAR tide_character_icon:\u276f +SETUVAR tide_character_vi_icon_default:\u276e +SETUVAR tide_character_vi_icon_replace:\u25b6 +SETUVAR tide_character_vi_icon_visual:V +SETUVAR tide_cmd_duration_bg_color:normal +SETUVAR tide_cmd_duration_color:87875F +SETUVAR tide_cmd_duration_decimals:0 +SETUVAR tide_cmd_duration_icon:\uf252 +SETUVAR tide_cmd_duration_threshold:3000 +SETUVAR tide_context_always_display:false +SETUVAR tide_context_bg_color:normal +SETUVAR tide_context_color_default:D7AF87 +SETUVAR tide_context_color_root:D7AF00 +SETUVAR tide_context_color_ssh:D7AF87 +SETUVAR tide_context_hostname_parts:1 +SETUVAR tide_crystal_bg_color:normal +SETUVAR tide_crystal_color:FFFFFF +SETUVAR tide_crystal_icon:\ue62f +SETUVAR tide_direnv_bg_color:normal +SETUVAR tide_direnv_bg_color_denied:normal +SETUVAR tide_direnv_color:D7AF00 +SETUVAR tide_direnv_color_denied:FF0000 +SETUVAR tide_direnv_icon:\u25bc +SETUVAR tide_distrobox_bg_color:normal +SETUVAR tide_distrobox_color:FF00FF +SETUVAR tide_distrobox_icon:\U000f01a7 +SETUVAR tide_docker_bg_color:normal +SETUVAR tide_docker_color:2496ED +SETUVAR tide_docker_default_contexts:default\x1ecolima +SETUVAR tide_docker_icon:\uf308 +SETUVAR tide_elixir_bg_color:normal +SETUVAR tide_elixir_color:4E2A8E +SETUVAR tide_elixir_icon:\ue62d +SETUVAR tide_gcloud_bg_color:normal +SETUVAR tide_gcloud_color:4285F4 +SETUVAR tide_gcloud_icon:\U000f02ad +SETUVAR tide_git_bg_color:normal +SETUVAR tide_git_bg_color_unstable:normal +SETUVAR tide_git_bg_color_urgent:normal +SETUVAR tide_git_color_branch:5FD700 +SETUVAR tide_git_color_conflicted:FF0000 +SETUVAR tide_git_color_dirty:D7AF00 +SETUVAR tide_git_color_operation:FF0000 +SETUVAR tide_git_color_staged:D7AF00 +SETUVAR tide_git_color_stash:5FD700 +SETUVAR tide_git_color_untracked:00AFFF +SETUVAR tide_git_color_upstream:5FD700 +SETUVAR tide_git_icon:\uf1d3 +SETUVAR tide_git_truncation_length:24 +SETUVAR tide_git_truncation_strategy:\x1d +SETUVAR tide_go_bg_color:normal +SETUVAR tide_go_color:00ACD7 +SETUVAR tide_go_icon:\ue627 +SETUVAR tide_java_bg_color:normal +SETUVAR tide_java_color:ED8B00 +SETUVAR tide_java_icon:\ue256 +SETUVAR tide_jobs_bg_color:normal +SETUVAR tide_jobs_color:5FAF00 +SETUVAR tide_jobs_icon:\uf013 +SETUVAR tide_jobs_number_threshold:1000 +SETUVAR tide_kubectl_bg_color:normal +SETUVAR tide_kubectl_color:326CE5 +SETUVAR tide_kubectl_icon:\U000f10fe +SETUVAR tide_left_prompt_frame_enabled:false +SETUVAR tide_left_prompt_items:os\x1epwd\x1egit\x1enewline\x1echaracter +SETUVAR tide_left_prompt_prefix: +SETUVAR tide_left_prompt_separator_diff_color:\x20 +SETUVAR tide_left_prompt_separator_same_color:\x20 +SETUVAR tide_left_prompt_suffix:\x20 +SETUVAR tide_nix_shell_bg_color:normal +SETUVAR tide_nix_shell_color:7EBAE4 +SETUVAR tide_nix_shell_icon:\uf313 +SETUVAR tide_node_bg_color:normal +SETUVAR tide_node_color:44883E +SETUVAR tide_node_icon:\ue24f +SETUVAR tide_os_bg_color:normal +SETUVAR tide_os_color:normal +SETUVAR tide_os_icon:\uf179 +SETUVAR tide_php_bg_color:normal +SETUVAR tide_php_color:617CBE +SETUVAR tide_php_icon:\ue608 +SETUVAR tide_private_mode_bg_color:normal +SETUVAR tide_private_mode_color:FFFFFF +SETUVAR tide_private_mode_icon:\U000f05f9 +SETUVAR tide_prompt_add_newline_before:true +SETUVAR tide_prompt_color_frame_and_connection:6C6C6C +SETUVAR tide_prompt_color_separator_same_color:949494 +SETUVAR tide_prompt_icon_connection:\x20 +SETUVAR tide_prompt_min_cols:34 +SETUVAR tide_prompt_pad_items:false +SETUVAR tide_prompt_transient_enabled:true +SETUVAR tide_pulumi_bg_color:normal +SETUVAR tide_pulumi_color:F7BF2A +SETUVAR tide_pulumi_icon:\uf1b2 +SETUVAR tide_pwd_bg_color:normal +SETUVAR tide_pwd_color_anchors:00AFFF +SETUVAR tide_pwd_color_dirs:0087AF +SETUVAR tide_pwd_color_truncated_dirs:8787AF +SETUVAR tide_pwd_icon:\uf07c +SETUVAR tide_pwd_icon_home:\uf015 +SETUVAR tide_pwd_icon_unwritable:\uf023 +SETUVAR tide_pwd_markers:\x2ebzr\x1e\x2ecitc\x1e\x2egit\x1e\x2ehg\x1e\x2enode\x2dversion\x1e\x2epython\x2dversion\x1e\x2eruby\x2dversion\x1e\x2eshorten_folder_marker\x1e\x2esvn\x1e\x2eterraform\x1eCargo\x2etoml\x1ecomposer\x2ejson\x1eCVS\x1ego\x2emod\x1epackage\x2ejson\x1ebuild\x2ezig +SETUVAR tide_python_bg_color:normal +SETUVAR tide_python_color:00AFAF +SETUVAR tide_python_icon:\U000f0320 +SETUVAR tide_right_prompt_frame_enabled:false +SETUVAR tide_right_prompt_items:status\x1ecmd_duration\x1econtext\x1ejobs\x1edirenv\x1enode\x1epython\x1erustc\x1ejava\x1ephp\x1epulumi\x1eruby\x1ego\x1egcloud\x1ekubectl\x1edistrobox\x1etoolbox\x1eterraform\x1eaws\x1enix_shell\x1ecrystal\x1eelixir\x1ezig +SETUVAR tide_right_prompt_prefix:\x20 +SETUVAR tide_right_prompt_separator_diff_color:\x20 +SETUVAR tide_right_prompt_separator_same_color:\x20 +SETUVAR tide_right_prompt_suffix: +SETUVAR tide_ruby_bg_color:normal +SETUVAR tide_ruby_color:B31209 +SETUVAR tide_ruby_icon:\ue23e +SETUVAR tide_rustc_bg_color:normal +SETUVAR tide_rustc_color:F74C00 +SETUVAR tide_rustc_icon:\ue7a8 +SETUVAR tide_shlvl_bg_color:normal +SETUVAR tide_shlvl_color:d78700 +SETUVAR tide_shlvl_icon:\uf120 +SETUVAR tide_shlvl_threshold:1 +SETUVAR tide_status_bg_color:normal +SETUVAR tide_status_bg_color_failure:normal +SETUVAR tide_status_color:5FAF00 +SETUVAR tide_status_color_failure:D70000 +SETUVAR tide_status_icon:\u2714 +SETUVAR tide_status_icon_failure:\u2718 +SETUVAR tide_terraform_bg_color:normal +SETUVAR tide_terraform_color:844FBA +SETUVAR tide_terraform_icon:\U000f1062 +SETUVAR tide_time_bg_color:normal +SETUVAR tide_time_color:5F8787 +SETUVAR tide_time_format: +SETUVAR tide_toolbox_bg_color:normal +SETUVAR tide_toolbox_color:613583 +SETUVAR tide_toolbox_icon:\ue24f +SETUVAR tide_vi_mode_bg_color_default:normal +SETUVAR tide_vi_mode_bg_color_insert:normal +SETUVAR tide_vi_mode_bg_color_replace:normal +SETUVAR tide_vi_mode_bg_color_visual:normal +SETUVAR tide_vi_mode_color_default:949494 +SETUVAR tide_vi_mode_color_insert:87AFAF +SETUVAR tide_vi_mode_color_replace:87AF87 +SETUVAR tide_vi_mode_color_visual:FF8700 +SETUVAR tide_vi_mode_icon_default:D +SETUVAR tide_vi_mode_icon_insert:I +SETUVAR tide_vi_mode_icon_replace:R +SETUVAR tide_vi_mode_icon_visual:V +SETUVAR tide_zig_bg_color:normal +SETUVAR tide_zig_color:F7A41D +SETUVAR tide_zig_icon:\ue6a9 diff --git a/config/fish/functions/.c.fish b/config/fish/functions/.c.fish new file mode 100644 index 0000000..d685939 --- /dev/null +++ b/config/fish/functions/.c.fish @@ -0,0 +1,4 @@ +function .c --wraps='cd ~/Code' --description 'alias .c=cd ~/Code' + cd ~/Code $argv + +end diff --git a/config/fish/functions/.d.fish b/config/fish/functions/.d.fish new file mode 100644 index 0000000..aa32bf7 --- /dev/null +++ b/config/fish/functions/.d.fish @@ -0,0 +1,4 @@ +function .d --wraps='cd ~/.dotfiles' --description 'alias .d=cd ~/.dotfiles' + cd ~/.dotfiles $argv + +end diff --git a/config/fish/functions/__bash2env.sh b/config/fish/functions/__bash2env.sh new file mode 100755 index 0000000..94ddd44 --- /dev/null +++ b/config/fish/functions/__bash2env.sh @@ -0,0 +1,56 @@ +#!/usr/bin/env bash +# Copyright (c) 2022 Huang-Huang Bao +# +# This software is released under the MIT License. +# https://opensource.org/licenses/MIT + +# shellcheck disable=SC2076 +set -e + +disallowd_vars_arr=( + _ + fish_kill_signal + fish_killring + fish_pid + history + hostname + PWD + pipestatus + SHLVL + status + status_generation + version +) +disallowd_vars=" ${disallowd_vars_arr[*]} " + +fish_escape() { + value="${1//\\/\\\\}" + value="${value//\'/\\\'}" + echo "'${value}'" +} + +flag_impure="$__FISH_BASH2ENV_IMPURE" +unset __FISH_BASH2ENV_IMPURE + +if [[ -z "$flag_impure" ]]; then + old_env=" $(env -0 | tr '\0' ' ') " +fi + +eval_status= +eval "$*" 1>&2 || eval_status=$? + +env -0 | while IFS= read -rs -d $'\0' line; do + if [[ -z "$flag_impure" && "${old_env}" =~ " ${line} " ]]; then + continue + fi + + name="${line%%=*}" + if [[ "${disallowd_vars}" =~ " ${name} " ]]; then + continue + fi + + value="$(fish_escape "${line#*=}")" + echo "set -gx ${name} ${value}" +done + +exit $eval_status diff --git a/config/fish/functions/__macos_app_bundleid.fish b/config/fish/functions/__macos_app_bundleid.fish new file mode 100644 index 0000000..3e57ca6 --- /dev/null +++ b/config/fish/functions/__macos_app_bundleid.fish @@ -0,0 +1,53 @@ +# @halostatue/fish-macos/functions/__macos_app_bundleid.fish:v7.0.0 + +function __macos_app_bundleid + argparse --name 'app bundleid' x/exact a/all h/help q/quiet s/short -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: app bundleid [options] pattern... + +Shows the bundle identifier for each of the applications found for the +pattern (see `app find` for how applications are found). + +Options: + -x, --exact Perform exact matches only + -a, --all Show all matches + -q, --quiet Suppress error output + -s, --short Prints out the bundle IDs only + -h, --help Show this help + +Examples: + > app bundleid 1password + /Applications/1Password for Safari.app: com.1password.safari + /Applications/1Password.app: com.1password.1password + + > app bundleid -x 1password + /Applications/1Password.app: com.1password.1password' + return 0 + end + + if test (count $argv) -eq 0 + echo >&2 'app bundleid: Not enough arguments.' + __macos_app_bundleid --help >&2 + return 1 + end + + set --function apps (__macos_app_find $_flag_exact $_flag_all $argv) + or return 1 + + for app in $apps + set --local bundle_id (mdls -name kMDItemCFBundleIdentifier -r $app) + + if test -z $bundle_id + set --query _flag_quiet + or echo >&2 'Error getting bundle ID for "'$app'"' + else + if set --query _flag_short + echo $bundle_id + else + echo $app: $bundle_id + end + end + end +end diff --git a/config/fish/functions/__macos_app_find.fish b/config/fish/functions/__macos_app_find.fish new file mode 100644 index 0000000..2124103 --- /dev/null +++ b/config/fish/functions/__macos_app_find.fish @@ -0,0 +1,85 @@ +# @halostatue/fish-macos/functions/__macos_app_find.fish:v7.0.0 + +function __macos_app_find + argparse --name 'app find' x/exact a/all q/quiet h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: app find [options] pattern... + +Shows installed apps by the provided pattern or patterns. Searches for +apps in /Applications, /Applications/Setapp, /Applications/Utilities, +~/Applications, /Appliciations/Xcode.app/Contents/Applications, +/Developer/Applications, and /System/Applications. + +Options: + -x, --exact Perform exact matches only + -a, --all Show all matches + -q, --quiet Do not print matches + -h, --help Show this help + +Examples: + > app find --all 1password + /Applications/1Password for Safari.app + /Applications/1Password.app + + > app find --exact 1password + /Applications/1Password.app' + return 0 + end + + if test (count $argv) -eq 0 + echo >&2 'app find: Not enough arguments.' + __macos_app_find --help >&2 + return 1 + end + + set --function a Applications + set --function paths \ + /$a \ + ~/$a \ + /$a/Setapp \ + /$a/Utilities \ + /$a/Xcode.app/Contents/$a \ + /Developer/Applications \ + /System/Applications + + set --function found 0 + + for pattern in $argv + set pattern (string replace '\.app/?$' '' $pattern) + set --local apps {$paths}/*.app {$paths}/*.localized/*.app + for candidate in $apps + set --local found_item 0 + + if set --query _flag_exact + if string match --ignore-case --entire --quiet /$pattern.app $candidate + set found_item 1 + end + else if string match --ignore-case --entire --quiet $pattern $candidate + set found_item 1 + end + + if test $found_item -eq 1 + set --query _flag_quiet + or echo $candidate + + set found (math $found + $found_item) + + set --query _flag_quiet + and return 0 + + set --query _flag_all + or return 0 + end + + end + end + + test $found -gt 0 + and return 0 + + set --query _flag_quiet + or echo >&2 'No applications found.' + return 1 +end diff --git a/config/fish/functions/__macos_app_frontmost.fish b/config/fish/functions/__macos_app_frontmost.fish new file mode 100644 index 0000000..b5b1d29 --- /dev/null +++ b/config/fish/functions/__macos_app_frontmost.fish @@ -0,0 +1,110 @@ +# @halostatue/fish-macos/functions/__macos_app_frontmost.fish:v7.0.0 + +function __macos_app_frontmost::info + set --function value (lsappinfo info -only $argv[2] $argv[1] | string split =)[2] + or return 1 + + string replace --all '"' '' $value + return 0 +end + +function __macos_app_frontmost + argparse --name 'app frontmost' \ + h/help b/bundle-id p/path n/name P/pid a/all \ + -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: app frontmost [options] + +Retrieves details about the front-most application. + +Options: + -b, --bundle-id Shows the app bundle ID + -p, --path Shows the app path + -n, --name Shows the app name + -P, --pid Shows the PID of the app + -a, --all Shows all details + -h, --help Show this help + +Example: + > app frontmost + iTerm2' + return 0 + end + + set --function front (lsappinfo front) + or return 1 + + set --function items 0 + + if set --query _flag_all + set items 4 + else + set --query _flag_bundle_id _flag_path _flag_name _flag_pid + set --local missing $status + + switch $missing + case 0 + set _flag_all 1 + set items 4 + case 4 + set _flag_name 1 + set items 1 + case '*' + set items (math 4 - $missing) + end + end + + if set --query _flag_name || set --query _flag_all + set --function name (__macos_app_frontmost::info $front name) + or return 1 + end + + if set --query _flag_bundle_id || set --query _flag_all + set --function bundle_id (__macos_app_frontmost::info $front bundleID) + or return 1 + end + + if set --query _flag_path || set --query _flag_all + set --function bundle_path (__macos_app_frontmost::info $front bundlepath) + or return 1 + end + + if set --query _flag_pid || set --query _flag_all + set --function pid (__macos_app_frontmost::info $front pid) + or return 1 + end + + if set --query _flag_all + printf "%s: %s %s (%s)\n" $name $bundle_id $bundle_path $pid + else + if set --query _flag_name + printf "%s" $name + test $items -gt 1 && printf ": " + set items (math $items - 1) + end + + if set --query _flag_bundle_id + printf "%s" $bundle_id + test $items -gt 1 && printf " " + set items (math $items - 1) + end + + if set --query _flag_path + printf "%s" $bundle_path + test $items -gt 1 && printf " " + set items (math $items - 1) + end + + if set --query _flag_pid + if test $items -gt 1 + printf "(%s)" $pid + else + printf "%s" $pid + end + end + + printf "\n" + end +end diff --git a/config/fish/functions/__macos_app_icon.fish b/config/fish/functions/__macos_app_icon.fish new file mode 100644 index 0000000..ed760f2 --- /dev/null +++ b/config/fish/functions/__macos_app_icon.fish @@ -0,0 +1,94 @@ +# @halostatue/fish-macos/functions/__macos_app_icon.fish:v7.0.0 + +function __macos_app_icon + argparse --name 'app quit' x/exact h/help 'o/output=' 'w/width=' -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: app icon [options] pattern... + +Extracts macOS app icons as PNG (see `app find` for how applications +are found). + +Options: + -x, --exact Perform exact matches only + -oOUTPUT Output to the file or directory specified + --output OUTPUT Output to the file or directory specified + -wWIDTH Outputs to a maximum of WIDTH pixels + --width WIDTH Outputs to a maximum of WIDTH pixels + -h, --help Show this help' + return 0 + end + + if test (count $argv) -eq 0 + echo >&2 'app icon: Not enough arguments.' + __macos_app_icon --help >&2 + return 1 + end + + + if set --query _flag_exact + set --function apps (__macos_app_find --exact $argv) + or return 1 + else + set --function apps (__macos_app_find --all $argv) + or return 1 + end + + set --function app_count (count $apps) + + set --function output_path $PWD + if not test -z $_flag_output + if test -e $_flag_output + if test -f $_flag_output + if test $app_count -gt 1 + echo >&2 'app icon: More than one application found, but only one output file specified.' + return 1 + end + + set output_path (dirname $_flag_output) + set output_file (basename $_flag_output) + else if test -d $_flag_output + set output_path $_flag_output + else + echo >&2 'app icon: Output to a non-file or directory specified.' + return 1 + end + else + set output_path $_flag_output + mkdir -p $output_path + end + end + + for app in $apps + set --local icon $app/Contents/Resources/( + defaults read $app/Contents/Info CFBundleIconFile | + string replace --regex '\.icns$' '' + ).icns + + set --local name (basename $app .app)_icon.png + set --local tmp $TMPDIR/$name + set --local max_width (sips -g pixelWidth $icon | tail -1 | awk '{ print $2; }') + + set --local outfile + set --local width + + if test -z $output_file + set outfile $output_path/$name + else + set outfile $output_path/$output_file + end + + if test -z $_flag_width + set width $max_width + else if test $_flag_width -gt $max_width + set width $max_width + else + set width $_flag_width + end + + sips -s format png --resampleHeightWidthMax $width $icon --out $outfile >/dev/null 2>&1 + + echo Wrote $app icon to $outfile. + end +end diff --git a/config/fish/functions/__macos_app_quit.fish b/config/fish/functions/__macos_app_quit.fish new file mode 100644 index 0000000..8e161ae --- /dev/null +++ b/config/fish/functions/__macos_app_quit.fish @@ -0,0 +1,42 @@ +# @halostatue/fish-macos/functions/__macos_app_quit.fish:v7.0.0 + +function __macos_app_quit + argparse --name 'app quit' x/exact r/restart h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: app quit [options] pattern... + +Quits apps identified by the provided pattern or patterns (see +`app find` for how applications are found). + +Options: + -x, --exact Quits only applications with exact matches + -r, --restart Restarts the application that was quit + -h, --help Show this help' + return 0 + end + + if test (count $argv) -eq 0 + echo >&2 'app bundleid: Not enough arguments.' + __macos_app_quit --help >&2 + return 1 + end + + if set --query _flag_exact + set --function apps (__macos_app_find --exact $argv) + or return 1 + else + set --function apps (__macos_app_find --all $argv) + or return 1 + end + + for app in $apps + printf 'quit app "%s"' $app | osascript >/dev/null + + if set --query _flag_restart + sleep 2 + open -a $app + end + end +end diff --git a/config/fish/functions/__macos_finder_cd.fish b/config/fish/functions/__macos_finder_cd.fish new file mode 100644 index 0000000..87adaeb --- /dev/null +++ b/config/fish/functions/__macos_finder_cd.fish @@ -0,0 +1,18 @@ +# @halostatue/fish-macos/functions/__macos_finder_cd.fish:v7.0.0 + +function __macos_finder_cd + argparse --name 'finder cd' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder cd [options] [window#] + +Changes the current path to the path of the Finder window. + +Options: + -h, --help Show this help' + return 0 + end + + cd (__macos_finder_pwd::get $argv[1]) +end diff --git a/config/fish/functions/__macos_finder_clean.fish b/config/fish/functions/__macos_finder_clean.fish new file mode 100644 index 0000000..f3489c2 --- /dev/null +++ b/config/fish/functions/__macos_finder_clean.fish @@ -0,0 +1,30 @@ +# @halostatue/fish-macos/functions/__macos_finder_clean.fish:v7.0.0 + +function __macos_finder_clean + argparse --name 'finder clean' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder clean [options] [path...] + +Removes .DS_Store files from the paths provided, or the current path if +one is not provided. + +Options: + -h, --help Show this help' + return 0 + end + + if set --query argv[1] + set --function paths $argv + else + set --function paths . + end + + for path in $paths + test -d $path + or continue + + find $path -type f -name '*.DS_Store' -ls -delete + end +end diff --git a/config/fish/functions/__macos_finder_column.fish b/config/fish/functions/__macos_finder_column.fish new file mode 100644 index 0000000..f379cc5 --- /dev/null +++ b/config/fish/functions/__macos_finder_column.fish @@ -0,0 +1,18 @@ +# @halostatue/fish-macos/functions/__macos_finder_column.fish:v7.0.0 + +function __macos_finder_column + argparse --name 'finder column' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder column [options] [window#] + +Updates the Finder window to PWD using column view. + +Options: + -h, --help Show this help' + return 0 + end + + __macos_finder_pwd::update --column $argv +end diff --git a/config/fish/functions/__macos_finder_desktop_icons.fish b/config/fish/functions/__macos_finder_desktop_icons.fish new file mode 100644 index 0000000..2b95cf6 --- /dev/null +++ b/config/fish/functions/__macos_finder_desktop_icons.fish @@ -0,0 +1,44 @@ +# @halostatue/fish-macos/functions/__macos_finder_desktop_icons.fish:v7.0.0 + +function __macos_finder_desktop_icons + argparse --name 'finder desktop-icons' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder desktop-icons [options] STATE + +Shows or hides the desktop icons. If not specified, shows the current state. + +States: + off Hides the desktop icons + on Shows the desktop icons + [status] Shows desktop icon visibility + toggle Toggles desktop icon visibility + +Options: + -h, --help Show this help' + return 0 + end + + set --function action (string lower -- $argv[1]) + set --function key CreateDesktop + + switch $action + case off + __macos_finder_defaults::set $key false + case on + __macos_finder_defaults::set $key true + case toggle + if test (__macos_mac_defaults_query com.apple.Finder $key 1) -eq 1 + __macos_finder_defaults::set $key false + else + __macos_finder_defaults::set $key true + end + case status '' + if test (__macos_mac_defaults_query com.apple.Finder $key 1) -eq 1 + echo 'Desktop icons are hidden.' + else + echo 'Desktop icons are visible.' + end + end +end diff --git a/config/fish/functions/__macos_finder_hidden.fish b/config/fish/functions/__macos_finder_hidden.fish new file mode 100644 index 0000000..d7a061d --- /dev/null +++ b/config/fish/functions/__macos_finder_hidden.fish @@ -0,0 +1,45 @@ +# @halostatue/fish-macos/functions/__macos_finder_hidden.fish:v7.0.0 + +function __macos_finder_hidden + argparse --name 'finder hidden' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder hidden [options] STATE + +Shows or hides files that are normally hidden from the Finder. If not +specified, shows the current state. + +States: + off Hides files that are normally hidden from the Finder + on Shows files that are normally hidden from the Finder + [status] Shows the status of the hidden files setting + toggle Toggles the hidden files setting + +Options: + -h, --help Show this help' + return 0 + end + + set --function action (string lower -- $argv[1]) + set --function key AppleShowAllFiles + + switch $action + case off + __macos_finder_defaults::set $key false + case on + __macos_finder_defaults::set $key true + case toggle + if test (__macos_mac_defaults_query com.apple.Finder $key 0) -eq 1 + __macos_finder_defaults::set $key false + else + __macos_finder_defaults::set $key true + end + case status '' + if test (__macos_mac_defaults_query com.apple.Finder $key 0) -eq 1 + echo 'Hidden files are visible in finder.' + else + echo 'Hidden files are hidden in finder.' + end + end +end diff --git a/config/fish/functions/__macos_finder_icon.fish b/config/fish/functions/__macos_finder_icon.fish new file mode 100644 index 0000000..b0eb1ac --- /dev/null +++ b/config/fish/functions/__macos_finder_icon.fish @@ -0,0 +1,18 @@ +# @halostatue/fish-macos/functions/__macos_finder_icon.fish:v7.0.0 + +function __macos_finder_icon + argparse --name 'finder icon' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder icon [options] [window#] + +Updates the Finder window to PWD using icon view. + +Options: + -h, --help Show this help' + return 0 + end + + __macos_finder_pwd::update --icon $argv +end diff --git a/config/fish/functions/__macos_finder_list.fish b/config/fish/functions/__macos_finder_list.fish new file mode 100644 index 0000000..e3869ce --- /dev/null +++ b/config/fish/functions/__macos_finder_list.fish @@ -0,0 +1,18 @@ +# @halostatue/fish-macos/functions/__macos_finder_list.fish:v7.0.0 + +function __macos_finder_list + argparse --name 'finder list' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder list [options] [window#] + +Updates the Finder window to PWD using list view. + +Options: + -h, --help Show this help' + return 0 + end + + __macos_finder_pwd::update --list $argv +end diff --git a/config/fish/functions/__macos_finder_pushd.fish b/config/fish/functions/__macos_finder_pushd.fish new file mode 100644 index 0000000..b5c79df --- /dev/null +++ b/config/fish/functions/__macos_finder_pushd.fish @@ -0,0 +1,18 @@ +# @halostatue/fish-macos/functions/__macos_finder_pushd.fish:v7.0.0 + +function __macos_finder_pushd + argparse --name 'finder pushd' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder pushd [options] [window#] + +Changes the current path to the path of the Finder window with pushd. + +Options: + -h, --help Show this help' + return 0 + end + + pushd (__macos_finder_pwd::get $argv[1]) +end diff --git a/config/fish/functions/__macos_finder_pwd.fish b/config/fish/functions/__macos_finder_pwd.fish new file mode 100644 index 0000000..668f13e --- /dev/null +++ b/config/fish/functions/__macos_finder_pwd.fish @@ -0,0 +1,18 @@ +# @halostatue/fish-macos/functions/__macos_finder_pwd.fish:v7.0.0 + +function __macos_finder_pwd + argparse --name 'finder pwd' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder pwd [options] [window#] + +Prints the path of the Finder window. + +Options: + -h, --help Show this help' + return 0 + end + + __macos_finder_pwd::get $argv[1] +end diff --git a/config/fish/functions/__macos_finder_quarantine.fish b/config/fish/functions/__macos_finder_quarantine.fish new file mode 100644 index 0000000..6e590c7 --- /dev/null +++ b/config/fish/functions/__macos_finder_quarantine.fish @@ -0,0 +1,60 @@ +# @halostatue/fish-macos/functions/__macos_finder_quarantine.fish:v7.0.0 + +function __macos_finder_quarantine::run + set --query argv[1] + or return 1 + + set --function databases ~/Library/Preferences/com.apple.LaunchServices.QuarantineEventsV* + set --function cmd sqlite3 -separator ' | ' + + for db in $databases + $cmd $db $argv + end +end + +function __macos_finder_quarantine + argparse --name 'finder quarantine' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder [options] [SUBCOMMAND] [FILE...] + +Manage quarantine events. + +Subcommands: + [show] Shows quarantine events by agent and URL. + clean FILE... Removes quarantine attributes from the specified file(s). + At least one file is required. + clear Clears all quarantine events. + +Options: + -h, --help Show this help' + return 0 + end + + set --function verb (string lower -- $argv[1]) + set --erase argv[1] + + switch $verb + case show '' + __macos_finder_quarantine::run " +SELECT LSQuarantineAgentName, LSQuarantineDataURLString + FROM LSQuarantineEvent + WHERE LSQuarantineDataURLString != '' + ORDER BY LSQuarantineAgentName, LSQuarantineDataURLString;" + case clear + __macos_finder_quarantine::run 'DELETE FROM LSQuarantineEvent;' + case clean + if not set --query argv[1] + echo >&2 'finder quarantine clean requires at least one file parameter' + return 1 + end + + for attr in com.apple.{metadata:{kMDItemDownloadedDate,kMDItemWhereFroms},quarantine} + xattr -r -d $attr $argv + end + case '*' + echo >&2 "finder quarantine: unknown command '"$verb"'. Use 'show', 'clear', or 'clean'." + return 1 + end +end diff --git a/config/fish/functions/__macos_finder_selected.fish b/config/fish/functions/__macos_finder_selected.fish new file mode 100644 index 0000000..e7ed459 --- /dev/null +++ b/config/fish/functions/__macos_finder_selected.fish @@ -0,0 +1,28 @@ +# @halostatue/fish-macos/functions/__macos_finder_selected.fish:v7.0.0 + +function __macos_finder_selected + argparse --name 'finder selected' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder selected [options] [window#] + +Print the selected files on the command-line. + +Options: + -h, --help Show this help' + return 0 + end + + echo ' + tell application "Finder" to set theSelection to selection + set output to "" + set itemCount to count theSelection + repeat with itemIndex from 1 to itemCount + if itemIndex is less than itemCount then set theDelimiter to "\n" + if itemIndex is itemCount then set theDelimiter to "" + set currentItem to (item itemIndex of theSelection as alias) + set currentItem to POSIX path of currentItem + set output to output & currentItem & theDelimiter + end repeat' | osascript +end diff --git a/config/fish/functions/__macos_finder_track.fish b/config/fish/functions/__macos_finder_track.fish new file mode 100644 index 0000000..63499d1 --- /dev/null +++ b/config/fish/functions/__macos_finder_track.fish @@ -0,0 +1,26 @@ +# @halostatue/fish-macos/functions/__macos_finder_track.fish:v7.0.0 + +function __macos_finder_track + argparse --name 'finder track' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder track [options] + +Makes the first Finder window track with the shell PWD. This should be used +in a single shell instance only, and updates only when the PWD value is +updated. + +Options: + -h, --help Show this help' + return 0 + end + + if not functions --query __macos_finder_tracking + function __macos_finder_tracking --on-variable PWD + __macos_finder_pwd::update + end + end + + __macos_finder_pwd::update +end diff --git a/config/fish/functions/__macos_finder_untrack.fish b/config/fish/functions/__macos_finder_untrack.fish new file mode 100644 index 0000000..8189f31 --- /dev/null +++ b/config/fish/functions/__macos_finder_untrack.fish @@ -0,0 +1,18 @@ +# @halostatue/fish-macos/functions/__macos_finder_untrack.fish:v7.0.0 + +function __macos_finder_untrack + argparse --name 'finder untrack' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder untrack [options] + +Unlinks the shell PWD from the first Finder window. + +Options: + -h, --help Show this help' + return 0 + end + + functions --erase __macos_finder_tracking +end diff --git a/config/fish/functions/__macos_finder_update.fish b/config/fish/functions/__macos_finder_update.fish new file mode 100644 index 0000000..605efef --- /dev/null +++ b/config/fish/functions/__macos_finder_update.fish @@ -0,0 +1,18 @@ +# @halostatue/fish-macos/functions/__macos_finder_update.fish:v7.0.0 + +function __macos_finder_update + argparse --name 'finder update' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: finder update [options] [window#] + +Updates the Finder window to PWD. + +Options: + -h, --help Show this help' + return 0 + end + + __macos_finder_pwd::update $argv +end diff --git a/config/fish/functions/__macos_mac_airdrop.fish b/config/fish/functions/__macos_mac_airdrop.fish new file mode 100644 index 0000000..7a715aa --- /dev/null +++ b/config/fish/functions/__macos_mac_airdrop.fish @@ -0,0 +1,45 @@ +# @halostatue/fish-macos/functions/__macos_mac_airdrop.fish:v7.0.0 + +function __macos_mac_airdrop + argparse --name 'mac airdrop' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac airdrop STATE + +Turns AirDrop on or off. Requires administrative permissions and +executes with sudo. + +States: + off Disables AirDrop. + on Enables AirDrop. + [status] Shows the status of AirDrop. + toggle Toggles the status of AirDrop. + +Options: + -h, --help Show this help' + return 0 + end + + set --function subcommand (string lower -- $argv[1]) + set --erase argv[1] + + switch $subcommand + case on + sudo ifconfig awdl0 up + case off + sudo ifconfig awdl0 down + case status '' + ifconfig awdl0 | awk '/status:/ { print $2; }' + case toggle + if test (__macos_mac_airdrop status) == active + __macos_mac_airdrop off + else + __macos_mac_airdrop on + end + case '*' + echo >&2 'mac airdrop: unknown state.' + __macos_mac_airdrop --help >&2 + return 1 + end +end diff --git a/config/fish/functions/__macos_mac_airport.fish b/config/fish/functions/__macos_mac_airport.fish new file mode 100644 index 0000000..44992b6 --- /dev/null +++ b/config/fish/functions/__macos_mac_airport.fish @@ -0,0 +1,75 @@ +# @halostatue/fish-macos/functions/__macos_mac_airport.fish:v7.0.0 + +function __macos_mac_airport::ssid + __macos_mac_airport::run -I | string replace --filter --regex '\s+SSID: (\S+)' '$1' +end + +function __macos_mac_airport::run + /System/Library/PrivateFrameworks/Apple80211.framework/Versions/Current/Resources/airport \ + $argv +end + +function __macos_mac_airport + argparse --name 'mac airport' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac airport STATE + mac airport SUBCOMMAND [SSID] + +Performs various WiFi (AirPort) operations. If no state or subcommand is +provided, the scan subcommand will be run by default. Otherwise a state (off, +on, toggle) or a subcommand must be provided. + +States: + off Disables the WiFi adapter. + on Enables the WiFi adapter. + toggle Toggles the status of the WiFi adapter. + +Subcommands: + password [SSID] Shows the password of the current or specified SSID. + scan Scans for WiFi networks.. + ssid Shows the current WiFi network SSID. + status Shows the status of the WiFi adapter. + +Options: + -h, --help Show this help' + return 0 + end + + set --function cmd (string lower -- $argv[1]) + set --erase argv[1] + + switch $cmd + case scan '' + printf "Scanning...\r" + __macos_mac_airport::run -s + case network ssid + __macos_mac_airport::ssid + case off + networksetup -setairportpower en0 off + case on + networksetup -setairportpower en0 on + case status + networksetup -getairportpower en0 | string replace --regex '^[^:]+: ' '' | string lower + case toggle + if test (__macos_mac_airport status) == on + __macos_mac_airport off + else + __macos_mac_airport on + end + case password + set --local ssid + if set --query argv[1] + set ssid $argv[1] + else + set ssid (__macos_mac_airport::ssid) + end + + security find-generic-password -D "AirPort network password" -l $ssid -gw + case '*' + echo >&2 'mac airport: Unknown command.' + __macos_mac_airport --help >&2 + return 1 + end +end diff --git a/config/fish/functions/__macos_mac_brightness.fish b/config/fish/functions/__macos_mac_brightness.fish new file mode 100644 index 0000000..7a01425 --- /dev/null +++ b/config/fish/functions/__macos_mac_brightness.fish @@ -0,0 +1,38 @@ +# @halostatue/fish-macos/functions/__macos_mac_brightness.fish:v7.0.0 + +function __macos_mac_brightness + argparse --name 'mac brightness' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac brightness [options] DIRECTION + +Adjust the screen brightness level. + +Direction: + up Increases the screen brightness level. + down Decreases the screen brightness level. + +Options: + -h, --help Show this help' + return 0 + end + + set --function direction (string lower -- $argv[1]) + set --erase argv[1] + + switch $direction + case down + echo 'tell application "System Events" + key code 145 + end tell' | osascript >/dev/null + case up '' + echo 'tell application "System Events" + key code 144 + end tell' | osascript >/dev/null + case '*' + echo >&2 'mac brightness: Unknown direction' + __macos_mac_brightness --help >&2 + return 1 + end +end diff --git a/config/fish/functions/__macos_mac_defaults_query.fish b/config/fish/functions/__macos_mac_defaults_query.fish new file mode 100644 index 0000000..5740e70 --- /dev/null +++ b/config/fish/functions/__macos_mac_defaults_query.fish @@ -0,0 +1,9 @@ +# @halostatue/fish-macos/functions/__macos_mac_defaults_query.fish:v7.0.0 + +function __macos_mac_defaults_query + if set --function value (defaults read $argv[1] $argv[2] 2>/dev/null) + echo $value + else + echo $argv[3] + end +end diff --git a/config/fish/functions/__macos_mac_flushdns.fish b/config/fish/functions/__macos_mac_flushdns.fish new file mode 100644 index 0000000..2ea0920 --- /dev/null +++ b/config/fish/functions/__macos_mac_flushdns.fish @@ -0,0 +1,19 @@ +# @halostatue/fish-macos/functions/__macos_mac_flushdns.fish:v7.0.0 + +function __macos_mac_flushdns + argparse --name 'mac flushdns' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac flushdns [options] + +Flushes the DNS cache. Requires sudo. + +Options: + -h, --help Show this help' + return 0 + end + + sudo dscacheutil -flushcache + and sudo killall -HUP mDNSResponder +end diff --git a/config/fish/functions/__macos_mac_font_smoothing.fish b/config/fish/functions/__macos_mac_font_smoothing.fish new file mode 100644 index 0000000..0fddbf8 --- /dev/null +++ b/config/fish/functions/__macos_mac_font_smoothing.fish @@ -0,0 +1,62 @@ +# @halostatue/fish-macos/functions/__macos_mac_font_smoothing.fish:v7.0.0 + +function __macos_mac_font_smoothing + argparse --name 'mac font-smoothing' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac font-smoothing [options] off|on [APP...] + +Enables or disables font smoothing. If no apps are provided, sets the +global font smoothing preference. If apps are provided, font smoothing +will be set for each app. See `app bundleid` for how apps are resolved. + +States: + off Turns off font smoothing + on Turns on font smoothing + +Options: + -h, --help Show this help' + return 0 + end + + set --function state (string lower -- $argv[1]) + set --erase argv[1] + + switch $state + case on + if test (count $argv) -eq 0 + defaults delete -g CGFontRenderingFontSmoothingDisabled + else + for app in (__macos_app_bundleid --exact --short --all $argv) + defaults delete $app CGFontRenderingFontSmoothingDisabled + + if test $app = com.microsoft.VSCode + defaults delete $app.helper CGFontRenderingFontSmoothingDisabled + defaults delete $app.helper.EH CGFontRenderingFontSmoothingDisabled + defaults delete $app.helper.NP CGFontRenderingFontSmoothingDisabled + end + end + end + + case off + if test (count $argv) -eq 0 + defaults write -g CGFontRenderingFontSmoothingDisabled -bool false + else + for app in (__macos_app_bundleid --exact --short --all $argv) + defaults write $app CGFontRenderingFontSmoothingDisabled -bool false + + if test $app = com.microsoft.VSCode + defaults write $app.helper CGFontRenderingFontSmoothingDisabled -bool false + defaults write $app.helper.EH CGFontRenderingFontSmoothingDisabled -bool false + defaults write $app.helper.NP CGFontRenderingFontSmoothingDisabled -bool false + end + end + end + + case '*' + echo >&2 'mac font-smoothing: Unknown state.' + __macos_mac_font_smoothing --help >&2 + return 1 + end +end diff --git a/config/fish/functions/__macos_mac_lsclean.fish b/config/fish/functions/__macos_mac_lsclean.fish new file mode 100644 index 0000000..b3b282c --- /dev/null +++ b/config/fish/functions/__macos_mac_lsclean.fish @@ -0,0 +1,20 @@ +# @halostatue/fish-macos/functions/__macos_mac_lsclean.fish:v7.0.0 + +function __macos_mac_lsclean + argparse --name 'mac lsclean' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac lsclean [options] + +Cleans the LaunchServices registration list. + +Options: + -h, --help Show this help' + return 0 + end + + /System/Library/Frameworks/CoreServices.framework/Frameworks/LaunchServices.framework/Support/lsregister \ + -kill -r -domain local -domain system -domain user + and killall Finder +end diff --git a/config/fish/functions/__macos_mac_mail.fish b/config/fish/functions/__macos_mac_mail.fish new file mode 100644 index 0000000..ed851de --- /dev/null +++ b/config/fish/functions/__macos_mac_mail.fish @@ -0,0 +1,68 @@ +# @halostatue/fish-macos/functions/__macos_mac_mail.fish:v7.0.0 + +# Speed up Mail.app by vacuuming the Envelope Index +# - Code from: http://web.archive.org/web/20071008123746/http://www.hawkwings.net/2007/03/03/scripts-to-automate-the-mailapp-envelope-speed-trick/ +# - Originally by "pmbuko" with modifications by Romulo +# - Updated by Brett Terpstra 2012 +# - Updated by Mathias Törnblom 2015 to support V3 in El Capitan and still keep backwards compatibility +# - Updated by Andrei Miclaus 2017 to support V4 in Sierra +# - Updated by Austin Ziegler 2022 to not actually care what the OS version is (and translated to fish). The only +# restriction is that you must have opened Mail.app at least once on any OS upgrade so that if any version changes +# have happened, Mail.app has taken care of that for you. +function __macos_mac_mail + argparse --name 'mac mail' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac mail [options] SUBCOMMAND [arg] + +Performs operations on Mail.app configuration and database. + +Before running vacuum after any OS upgrade, Mail.app must have been opened +at least once so that the database and index formats have been updated. + +Subcommands: + vacuum Vacuums the envelope index to improve performance. + attachments inline Sets Mail.app attachment handling to inline. + attachments icon Sets Mail.app attachment handling to icon. + +Options: + -h, --help Show this help' + return 0 + end + + set --function subcommand (string lower -- $argv[1]) + set --erase argv[1] + + switch $subcommand + case vacuum + set --function mail_version ( + path filter --type dir ~/Library/Mail/* | + path basename | + string match --all --entire --regex V\\d + ) + set --function mail_path ~/Library/Mail/$mail_version/MailData/Envelope\ Index + + osascript -e 'tell application "Mail" to quit' + + set --function before (ls -lnah $mail_path | awk '{ print $5; }') + /usr/bin/sqlite3 $mail_path vacuum + set --function after (ls -lnah $mail_path | awk '{ print $5; }') + + printf "Mail index before: %s\nMail index after: %s\n" $before $after + osascript -e 'tell application "Mail" to activate' + + case attachments + switch (string lower -- $argv[1]) + case inline + defaults delete com.apple.mail DisableInlineAttachmentViewing + case icon + defaults write com.apple.mail DisableInlineAttachmentViewing -bool true + end + + case '*' + echo >&2 'mac mail: Unknown command.' + __macos_mac_mail --help >&2 + return 1 + end +end diff --git a/config/fish/functions/__macos_mac_proxy_icon.fish b/config/fish/functions/__macos_mac_proxy_icon.fish new file mode 100644 index 0000000..010e449 --- /dev/null +++ b/config/fish/functions/__macos_mac_proxy_icon.fish @@ -0,0 +1,66 @@ +# @halostatue/fish-macos/functions/__macos_mac_proxy_icon.fish:v7.0.0 + +function __macos_mac_proxy_icon + argparse --name 'mac proxy-icon' h/help q/query -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac proxy-icon [options] STATE + +Enables or disables the visibility of the proxy icon without delay. macOS +versions older than Monterey always show the proxy icon. + +States: + FLOAT Sets the display of the proxy icon to FLOAT fractional seconds. + off Sets the display of the proxy icon to default. + on Sets the display of the proxy icon to 0 seconds. + [status] Shows the duration of the proxy icon display. + toggle Toggles the display of the proxy icon. + +Options: + -q, --query When getting status, suppresses output. + -h, --help Show this help' + return 0 + end + + set --function state (string lower -- $argv[1]) + set --erase argv[1] + + switch $state + case status '' + set --function value (__macos_mac_defaults_query -g NSToolbarTitleViewRolloverDelay 0.5) + + if set --query _flag_query + test $value -eq 0 + else if test $value -eq 0 + printf "immediate (0 seconds)\n" + else + printf "%0.2f seconds\n" $value + end + + case toggle + if __macos_mac_proxy_icon --query status + __macos_mac_proxy_icon off + else + __macos_mac_proxy_icon on + end + + case on + defaults write -g NSToolbarTitleViewRolloverDelay -float 0 + and killall Finder + + case off + defaults delete -g NSToolbarTitleViewRolloverDelay + and killall Finder + + case '*' + if string match --regex '^\\d+$|^\\d*\.\\d+$' $state + defaults write -g NSToolbarTitleViewRolloverDelay -float $state + and killall Finder + else + echo >&2 'mac proxy-icon: Unknown state.' + __macos_mac_proxy_icon --help >&2 + return 1 + end + end +end diff --git a/config/fish/functions/__macos_mac_serialnumber.fish b/config/fish/functions/__macos_mac_serialnumber.fish new file mode 100644 index 0000000..015ce5c --- /dev/null +++ b/config/fish/functions/__macos_mac_serialnumber.fish @@ -0,0 +1,22 @@ +# @halostatue/fish-macos/functions/__macos_mac_serialnumber.fish:v7.0.0 + +function __macos_mac_serialnumber + argparse --name 'mac serialnumber' h/help c/copy -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac serialnumber [options] + +Gets the serial number for the current macOS device. + +Options: + -c, --copy Copy to the clipboard + -h, --help Show this help' + return 0 + end + + set --function serial (ioreg -l | string replace --filter --regex --all '^.*"IOPlatformSerialNumber"\s+=\s+"([^"]+)"' '$1') + + set --query _flag_copy && echo $serial | pbcopy + echo $serial +end diff --git a/config/fish/functions/__macos_mac_touchid.fish b/config/fish/functions/__macos_mac_touchid.fish new file mode 100644 index 0000000..c73829e --- /dev/null +++ b/config/fish/functions/__macos_mac_touchid.fish @@ -0,0 +1,42 @@ +# @halostatue/fish-macos/functions/__macos_mac_touchid.fish:v7.0.0 + +function __macos_mac_touchid + argparse --name 'mac touchid' h/help q/quiet -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac touchid SUBSYSTEM [STATE] + +Enables or disables Touch ID support. Requires administrative permissions +and executes with sudo. + +Subsystems: + sudo Manages Touch ID support for sudo + +States: + off Disables Touch ID. + on Enables Touch ID. + [status] Shows the status of Touch ID. + toggle Toggles the status of Touch ID. + +Options: + -h, --help Show this help' + return 0 + end + + set --function subsystem (string lower -- $argv[1]) + set --erase argv[1] + + if set --query _flag_quiet + set --append argv --quiet + end + + switch $subsystem + case sudo + __macos_mac_touchid_sudo $argv + case '*' + echo >&2 'mac touchid: unknown subsystem.' + __macos_mac_touchid --help >&2 + return 1 + end +end diff --git a/config/fish/functions/__macos_mac_touchid_sudo.fish b/config/fish/functions/__macos_mac_touchid_sudo.fish new file mode 100644 index 0000000..622bffe --- /dev/null +++ b/config/fish/functions/__macos_mac_touchid_sudo.fish @@ -0,0 +1,195 @@ +# @halostatue/fish-macos/functions/__macos_mac_touchid_sudo.fish:v7.0.0 + +# Massively simplified. This version _only_ works if /etc/pam.d/sudo includes `auth +# include sudo_local` and requires manual removal of `pam_reattach` and `pam_tid` from +# `/etc/pam.d/sudo` _manually_ if present. + +function __macos_mac_touchid_sudo::check_supported + if string match -rq '^\s*auth\s+include\s+sudo_local$' &2 + printf >&2 "\n auth include sudo_local\n\n" + printf >&2 "Once this has been added, try again.\n" + + return 1 +end + +function __macos_mac_touchid_sudo::check_old_install + set --function found + + string match -rq '^\s*auth\s+sufficient\s+pam_tid\.so' &2 "Sudo support for "$found" present in /etc/pam.d/sudo.\n\n" + echo "This is unsupported by 'mac touchid sudo' and must be manually \ + removed before continuing." | fmt -s >&2 + + return 0 + end + + return 1 +end + +function __macos_mac_touchid_sudo::print_status + set --query _flag_quiet + or printf "%-15s: %s\n" $argv +end + +function __macos_mac_touchid_sudo::remove_one + path is --type file --perm read /etc/pam.d/sudo_local + and grep -q $argv[1] /etc/pam.d/sudo_local + and sudo sed -i '' -e "/$argv[1]/d" /etc/pam.d/sudo_local +end + +function __macos_mac_touchid_sudo::remove + osascript -e 'tell application "System Preferences" to quit' + + for ext in pam_tid pam_reattach + __macos_mac_touchid_sudo::remove_one {$ext} /etc/pam.d/sudo_local + and __macos_mac_touchid_sudo::print_status $ext disabled + end + + if ! test -s /etc/pam.d/sudo_local + # If /etc/pam.d/sudo_local is empty, remove it. + sudo rm -f /etc/pam.d/sudo_local + end +end + +function __macos_mac_touchid_sudo::add + set --function targets + + test -f /etc/pam.d/sudo_local + or sudo touch /etc/pam.d/sudo_local + + if set --query argv[1] + set --function reattach $argv[1] + + if string match -rq '^\s*auth\s+optional\s+'$argv[1] /dev/null + and begin + __macos_mac_touchid_sudo::print_status pam_reattach enabled + __macos_mac_touchid_sudo::print_status pam_tid enabled + end + else + printf "%-10s %-14s %s\n" auth sufficient pam_tid.so | + sudo tee -a /etc/pam.d/sudo_local >/dev/null + and __macos_mac_touchid_sudo::print_status pam_tid enabled + end +end + +function __macos_mac_touchid_sudo + argparse --name 'mac touchid sudo' h/help q/quiet -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac touchid sudo [STATE] + +Enables or disables Touch ID support for sudo. Requires administrative +permissions to edit /etc/pam.d/sudo_local and executes with sudo. + +If pam_reattach is installed, this will be managed as well. Note that if +pam_reattach is installed using sudo, it is imperative that Touch ID +support be disabled first or you may be in a situation where you cannot +use sudo. Note that MacPorts-installed pam_reattach will never be used. + +States: + off Disables Touch ID. + on Enables Touch ID. + [status] Shows the status of Touch ID. + toggle Toggles the status of Touch ID. + +Options: + -h, --help Show this help' + return 0 + end + + + __macos_mac_touchid_sudo::check_supported + or return + + __macos_mac_touchid_sudo::check_old_install + and return + + set --function subcommand (string lower -- $argv[1]) + set --erase argv[1] + + switch $subcommand + case on + set --local reattach /opt/local /opt/homebrew /usr/local /usr + set reattach (path filter --type file $reattach/lib/pam/pam_reattach.so) + + if set --query reattach[1] + set reattach (string replace --all --regex / \\/ $reattach[1]) + end + + __macos_mac_touchid_sudo::add $reattach + + case off + __macos_mac_touchid_sudo::remove + + case status '' + set --local pam_tid disabled + set --local pam_reattach disabled + + grep -q pam_tid.so /etc/pam.d/sudo_local + and set pam_tid enabled + + grep -q pam_reattach.so /etc/pam.d/sudo_local + and set pam_reattach enabled + + if set --query _flag_quiet + test $pam_tid = enabled + else + __macos_mac_touchid_sudo::print_status pam_tid $pam_tid + __macos_mac_touchid_sudo::print_status pam_reattach $pam_reattach + end + + case toggle + if __macos_mac_touchid_sudo status --quiet + __macos_mac_touchid_sudo off + else + __macos_mac_touchid_sudo on + end + + case '*' + echo >&2 'mac touchid: unknown state.' + __macos_mac_touchid_sudo --help >&2 + return 1 + end +end diff --git a/config/fish/functions/__macos_mac_transparency.fish b/config/fish/functions/__macos_mac_transparency.fish new file mode 100644 index 0000000..9320ef9 --- /dev/null +++ b/config/fish/functions/__macos_mac_transparency.fish @@ -0,0 +1,60 @@ +# @halostatue/fish-macos/functions/__macos_mac_transparency.fish:v7.0.0 + +function __macos_mac_transparency + argparse --name 'mac transparency' h/help q/query -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac transparency [options] STATE + +Enables or disables interface transparency by setting the universal +access "reduce transparency" setting. + +States: + off Disables interface transparency + on Enables interface transparency + [status] Shows the status of interface transparency + toggle Toggles interface transparency + +Options: + -q, --query When getting status, suppresses output. + -h, --help Show this help' + return 0 + end + + set function state (string lower -- $argv[1]) + set --erase argv[1] + + switch $state + case status '' + set function value (__macos_mac_defaults_query com.apple.universalaccess reduceTransparency 0) + + if set --query _flag_query + test $value -eq 0 + else + if test $value -eq 0 + echo on + else + echo off + end + end + + case on + defaults delete com.apple.universalaccess reduceTransparency + + case off + defaults write com.apple.universalaccess reduceTransparency -bool true + + case toggle + if __macos_mac_transparency status --query + __macos_mac_transparency off + else + __macos_mac_transparency on + end + + case '*' + echo >&2 'mac transparency: unknown state' + __macos_mac_transparency --help >&2 + return 1 + end +end diff --git a/config/fish/functions/__macos_mac_version.fish b/config/fish/functions/__macos_mac_version.fish new file mode 100644 index 0000000..b80e797 --- /dev/null +++ b/config/fish/functions/__macos_mac_version.fish @@ -0,0 +1,86 @@ +# @halostatue/fish-macos/functions/__macos_mac_version.fish:v7.0.0 + +function __macos_mac_version + argparse \ + --exclusive s,v \ + --exclusive l,v \ + --exclusive s,c \ + --exclusive l,c \ + --exclusive v,c \ + h/help s/simple l/lowercase v/version c/comparable -- $argv + + if set --query _flag_help + echo 'Usage: mac version [options] + +Shows the current mac version. + +Options: + -s, --simple Removes spaces from the version displayed + -l, --lowercase Converts the version to all lowercase + -c, --comparable Outputs the comparable version value + -v, --version Outputs the macOS version (same as sw_vers -productVersion)' + return 0 + end + + set --function os_version (sw_vers -productVersion) + + if set --query _flag_version + echo $os_version + return $status + end + + set os_version (__macos_version_to_comparable $os_version) + or return 1 + + if set --query _flag_comparable + echo $os_version + return 0 + end + + switch $os_version + case 1005000 + set os_version Leopard + case 1006000 + set os_version Snow Leopard + case 1007000 + set os_version Lion + case 1008000 + set os_version Mountain Lion + case 1009000 + set os_version Mavericks + case 1010000 + set os_version Yosemite + case 1011000 + set os_version El Capitan + case 1012000 + set os_version Sierra + case 1013000 + set os_version High Sierra + case 1014000 + set os_version Mojave + case 1015000 + set os_version Catalina + case 1100000 + set os_version Big Sur + case 1200000 + set os_version Monterey + case 1300000 + set os_version Ventura + case 1400000 + set os_version Sonoma + case 1500000 + set os_version Sequoia + case '*' + return 1 + end + + if set --query _flag_simple + set os_version (string replace --all ' ' '' "$os_version") + end + + if set --query _flag_lowercase + set os_version (string lower -- "$os_version") + end + + echo $os_version +end diff --git a/config/fish/functions/__macos_mac_vol.fish b/config/fish/functions/__macos_mac_vol.fish new file mode 100644 index 0000000..9e3d335 --- /dev/null +++ b/config/fish/functions/__macos_mac_vol.fish @@ -0,0 +1,45 @@ +# @halostatue/fish-macos/functions/__macos_mac_vol.fish:v7.0.0 + +function __macos_mac_vol + argparse --name 'mac vol' h/help -- $argv + or return 1 + + if set --query _flag_help + echo 'Usage: mac vol [options] LEVEL + +Control the volume level. + +Levels: + mute Mutes the volume level. + unmute Unmutes the volume level. + 0 .. 100 Sets the volume level at LEVEL %. + [show] Shows the current volume level. + +Options: + -h, --help Show this help' + return 0 + end + + set --function action (string lower -- $argv[1]) + set --erase argv[1] + + switch $action + case mute + osascript -e 'set volume output muted true' + case unmute + osascript -e 'set volume output muted false' + case (seq 0 100) + osascript -e "set volume output volume "$action + case show '' + if test (osascript -e 'output muted of (get volume settings)') = true + echo muted + else + osascript -e "output volume of (get volume settings)" + end + + case '*' + echo >&2 'mac vol: Unknown level' + __macos_mac_vol --help >&2 + return 1 + end +end diff --git a/config/fish/functions/__ssh_agent_is_started.fish b/config/fish/functions/__ssh_agent_is_started.fish new file mode 100644 index 0000000..a9da28a --- /dev/null +++ b/config/fish/functions/__ssh_agent_is_started.fish @@ -0,0 +1,23 @@ +function __ssh_agent_is_started -d "check if ssh agent is already started" + if test -n "$SSH_CONNECTION" + # This is an SSH session + ssh-add -l > /dev/null 2>&1 + if test $status -eq 0 -o $status -eq 1 + # An SSH agent was forwarded + return 0 + end + end + + if begin; test -f "$SSH_ENV"; and test -z "$SSH_AGENT_PID"; end + source $SSH_ENV > /dev/null + end + + if test -z "$SSH_AGENT_PID" + return 1 + end + + ssh-add -l > /dev/null 2>&1 + if test $status -eq 2 + return 1 + end +end diff --git a/config/fish/functions/__ssh_agent_start.fish b/config/fish/functions/__ssh_agent_start.fish new file mode 100644 index 0000000..3766fe4 --- /dev/null +++ b/config/fish/functions/__ssh_agent_start.fish @@ -0,0 +1,5 @@ +function __ssh_agent_start -d "start a new ssh agent" + ssh-agent -c | sed 's/^echo/#echo/' > $SSH_ENV + chmod 600 $SSH_ENV + source $SSH_ENV > /dev/null +end diff --git a/config/fish/functions/__z.fish b/config/fish/functions/__z.fish new file mode 100644 index 0000000..0b02005 --- /dev/null +++ b/config/fish/functions/__z.fish @@ -0,0 +1,174 @@ +function __z -d "Jump to a recent directory." + function __print_help -d "Print z help." + printf "Usage: $Z_CMD [-celrth] string1 string2...\n\n" + printf " -c --clean Removes directories that no longer exist from $Z_DATA\n" + printf " -d --dir Opens matching directory using system file manager.\n" + printf " -e --echo Prints best match, no cd\n" + printf " -l --list List matches and scores, no cd\n" + printf " -p --purge Delete all entries from $Z_DATA\n" + printf " -r --rank Search by rank\n" + printf " -t --recent Search by recency\n" + printf " -x --delete Removes the current directory from $Z_DATA\n" + printf " -h --help Print this help\n\n" + end + function __z_legacy_escape_regex + # taken from escape_string_pcre2 in fish + # used to provide compatibility with fish 2 + for c in (string split -- '' $argv) + if contains $c (string split '' '.^$*+()?[{}\\|-]') + printf \\ + end + printf '%s' $c + end + end + + set -l options h/help c/clean e/echo l/list p/purge r/rank t/recent d/directory x/delete + + argparse $options -- $argv + + if set -q _flag_help + __print_help + return 0 + else if set -q _flag_clean + __z_clean + printf "%s cleaned!\n" $Z_DATA + return 0 + else if set -q _flag_purge + echo >$Z_DATA + printf "%s purged!\n" $Z_DATA + return 0 + else if set -q _flag_delete + sed -i -e "\:^$PWD|.*:d" $Z_DATA + return 0 + end + + set -l typ + + if set -q _flag_rank + set typ rank + else if set -q _flag_recent + set typ recent + end + + set -l z_script ' + function frecent(rank, time) { + dx = t-time + if( dx < 3600 ) return rank*4 + if( dx < 86400 ) return rank*2 + if( dx < 604800 ) return rank/2 + return rank/4 + } + + function output(matches, best_match, common) { + # list or return the desired directory + if( list ) { + cmd = "sort -nr" + for( x in matches ) { + if( matches[x] ) { + printf "%-10s %s\n", matches[x], x | cmd + } + } + } else { + if( common ) best_match = common + print best_match + } + } + + function common(matches) { + # find the common root of a list of matches, if it exists + for( x in matches ) { + if( matches[x] && (!short || length(x) < length(short)) ) { + short = x + } + } + if( short == "/" ) return + for( x in matches ) if( matches[x] && index(x, short) != 1 ) { + return + } + return short + } + + BEGIN { + hi_rank = ihi_rank = -9999999999 + } + { + if( typ == "rank" ) { + rank = $2 + } else if( typ == "recent" ) { + rank = $3 - t + } else rank = frecent($2, $3) + if( $1 ~ q ) { + matches[$1] = rank + } else if( tolower($1) ~ tolower(q) ) imatches[$1] = rank + if( matches[$1] && matches[$1] > hi_rank ) { + best_match = $1 + hi_rank = matches[$1] + } else if( imatches[$1] && imatches[$1] > ihi_rank ) { + ibest_match = $1 + ihi_rank = imatches[$1] + } + } + + END { + # prefer case sensitive + if( best_match ) { + output(matches, best_match, common(matches)) + } else if( ibest_match ) { + output(imatches, ibest_match, common(imatches)) + } + } + ' + + set -l qs + for arg in $argv + set -l escaped $arg + if string escape --style=regex '' >/dev/null 2>&1 # use builtin escape if available + set escaped (string escape --style=regex -- $escaped) + else + set escaped (__z_legacy_escape_regex $escaped) + end + # Need to escape twice, see https://www.math.utah.edu/docs/info/gawk_5.html#SEC32 + set escaped (string replace --all -- \\ \\\\ $escaped) + set qs $qs $escaped + end + set -l q (string join -- '.*' $qs) + + if set -q _flag_list + # Handle list separately as it can print common path information to stderr + # which cannot be captured from a subcommand. + command awk -v t=(date +%s) -v list="list" -v typ="$typ" -v q="$q" -F "|" $z_script "$Z_DATA" + return + end + + set target (command awk -v t=(date +%s) -v typ="$typ" -v q="$q" -F "|" $z_script "$Z_DATA") + + if test "$status" -gt 0 + return + end + + if test -z "$target" + printf "'%s' did not match any results\n" "$argv" + return 1 + end + + if set -q _flag_echo + printf "%s\n" "$target" + else if set -q _flag_directory + if test -n "$ZO_METHOD" + type -q "$ZO_METHOD"; and "$ZO_METHOD" "$target"; and return $status + echo "Cannot open with ZO_METHOD set to $ZO_METHOD"; and return 1 + else if test "$OS" = Windows_NT + # Be careful, in msys2, explorer always return 1 + type -q explorer; and explorer "$target" + return 0 + echo "Cannot open file explorer" + return 1 + else + type -q xdg-open; and xdg-open "$target"; and return $status + type -q open; and open "$target"; and return $status + echo "Not sure how to open file manager"; and return 1 + end + else + pushd "$target" + end +end diff --git a/config/fish/functions/__z_add.fish b/config/fish/functions/__z_add.fish new file mode 100644 index 0000000..20d5d7e --- /dev/null +++ b/config/fish/functions/__z_add.fish @@ -0,0 +1,49 @@ +function __z_add -d "Add PATH to .z file" + test -n "$fish_private_mode"; and return 0 + + for i in $Z_EXCLUDE + if string match -r $i $PWD >/dev/null + return 0 #Path excluded + end + end + + set -l tmpfile (mktemp $Z_DATA.XXXXXX) + + if test -f $tmpfile + set -l path (string replace --all \\ \\\\ $PWD) + command awk -v path=$path -v now=(date +%s) -F "|" ' + BEGIN { + rank[path] = 1 + time[path] = now + } + $2 >= 1 { + if( $1 == path ) { + rank[$1] = $2 + 1 + time[$1] = now + } + else { + rank[$1] = $2 + time[$1] = $3 + } + count += $2 + } + END { + if( count > 1000 ) { + for( i in rank ) print i "|" 0.9*rank[i] "|" time[i] # aging + } + else for( i in rank ) print i "|" rank[i] "|" time[i] + } + ' $Z_DATA 2>/dev/null >$tmpfile + + if test ! -z "$Z_OWNER" + chown $Z_OWNER:(id -ng $Z_OWNER) $tmpfile + end + # + # Don't use redirection here as it can lead to a race condition where $Z_DATA is clobbered. + # Note: There is a still a possible race condition where an old version of $Z_DATA is + # read by one instance of Fish before another instance of Fish writes its copy. + # + command mv $tmpfile $Z_DATA + or command rm $tmpfile + end +end diff --git a/config/fish/functions/__z_clean.fish b/config/fish/functions/__z_clean.fish new file mode 100644 index 0000000..ae1721a --- /dev/null +++ b/config/fish/functions/__z_clean.fish @@ -0,0 +1,11 @@ +function __z_clean -d "Clean up .z file to remove paths no longer valid" + set -l tmpfile (mktemp $Z_DATA.XXXXXX) + + if test -f $tmpfile + while read line + set -l path (string split '|' $line)[1] + test -d $path; and echo $line + end <$Z_DATA >$tmpfile + command mv -f $tmpfile $Z_DATA + end +end diff --git a/config/fish/functions/__z_complete.fish b/config/fish/functions/__z_complete.fish new file mode 100644 index 0000000..a626456 --- /dev/null +++ b/config/fish/functions/__z_complete.fish @@ -0,0 +1,13 @@ +function __z_complete -d "add completions" + complete -c $Z_CMD -a "(__z -l | string replace -r '^\\S*\\s*' '')" -f -k + complete -c $ZO_CMD -a "(__z -l | string replace -r '^\\S*\\s*' '')" -f -k + + complete -c $Z_CMD -s c -l clean -d "Cleans out $Z_DATA" + complete -c $Z_CMD -s e -l echo -d "Prints best match, no cd" + complete -c $Z_CMD -s l -l list -d "List matches, no cd" + complete -c $Z_CMD -s p -l purge -d "Purges $Z_DATA" + complete -c $Z_CMD -s r -l rank -d "Searches by rank, cd" + complete -c $Z_CMD -s t -l recent -d "Searches by recency, cd" + complete -c $Z_CMD -s h -l help -d "Print help" + complete -c $Z_CMD -s x -l delete -d "Removes the current directory from $Z_DATA" +end diff --git a/config/fish/functions/_nvm_index_update.fish b/config/fish/functions/_nvm_index_update.fish new file mode 100644 index 0000000..c66753d --- /dev/null +++ b/config/fish/functions/_nvm_index_update.fish @@ -0,0 +1,20 @@ +function _nvm_index_update + test ! -d $nvm_data && command mkdir -p $nvm_data + + set --local index $nvm_data/.index + + if not command curl -q --location --silent $nvm_mirror/index.tab >$index.temp + command rm -f $index.temp + echo "nvm: Can't update index, host unavailable: \"$nvm_mirror\"" >&2 + return 1 + end + + command awk -v OFS=\t ' + /v0.9.12/ { exit } # Unsupported + NR > 1 { + print $1 (NR == 2 ? " latest" : $10 != "-" ? " lts/" tolower($10) : "") + } + ' $index.temp >$index + + command rm -f $index.temp +end diff --git a/config/fish/functions/_nvm_list.fish b/config/fish/functions/_nvm_list.fish new file mode 100644 index 0000000..1623bb8 --- /dev/null +++ b/config/fish/functions/_nvm_list.fish @@ -0,0 +1,14 @@ +function _nvm_list + set --local versions $nvm_data/* + + set --query versions[1] && + string match --entire --regex -- ( + string replace --all -- $nvm_data/ "" $versions | + string match --regex -- "v\d.+" | + string escape --style=regex | + string join "|" + ) <$nvm_data/.index + + command --all node | + string match --quiet --invert --regex -- "^$nvm_data" && echo system +end diff --git a/config/fish/functions/_nvm_version_activate.fish b/config/fish/functions/_nvm_version_activate.fish new file mode 100644 index 0000000..f7dfef7 --- /dev/null +++ b/config/fish/functions/_nvm_version_activate.fish @@ -0,0 +1,4 @@ +function _nvm_version_activate --argument-names ver + set --global --export nvm_current_version $ver + set --prepend PATH $nvm_data/$ver/bin +end diff --git a/config/fish/functions/_nvm_version_deactivate.fish b/config/fish/functions/_nvm_version_deactivate.fish new file mode 100644 index 0000000..24dd36e --- /dev/null +++ b/config/fish/functions/_nvm_version_deactivate.fish @@ -0,0 +1,5 @@ +function _nvm_version_deactivate --argument-names ver + test "$nvm_current_version" = "$ver" && set --erase nvm_current_version + set --local index (contains --index -- $nvm_data/$ver/bin $PATH) && + set --erase PATH[$index] +end diff --git a/config/fish/functions/_tide_1_line_prompt.fish b/config/fish/functions/_tide_1_line_prompt.fish new file mode 100644 index 0000000..5772223 --- /dev/null +++ b/config/fish/functions/_tide_1_line_prompt.fish @@ -0,0 +1,19 @@ +function _tide_1_line_prompt + set -g add_prefix + _tide_side=left for item in $_tide_left_items + _tide_item_$item + end + set_color $prev_bg_color -b normal + echo $tide_left_prompt_suffix + + set -g add_prefix + _tide_side=right for item in $_tide_right_items + _tide_item_$item + end + set_color $prev_bg_color -b normal + echo $tide_right_prompt_suffix +end + +function _tide_item_pwd + _tide_print_item pwd @PWD@ +end diff --git a/config/fish/functions/_tide_2_line_prompt.fish b/config/fish/functions/_tide_2_line_prompt.fish new file mode 100644 index 0000000..e9017af --- /dev/null +++ b/config/fish/functions/_tide_2_line_prompt.fish @@ -0,0 +1,31 @@ +function _tide_2_line_prompt + set -g add_prefix + _tide_side=left for item in $_tide_left_items + _tide_item_$item + end + if not set -e add_prefix + set_color $prev_bg_color -b normal + echo $tide_left_prompt_suffix + end + + echo + + set -g add_prefix + _tide_side=right for item in $_tide_right_items + _tide_item_$item + end + if not set -e add_prefix + set_color $prev_bg_color -b normal + echo $tide_right_prompt_suffix + end +end + +function _tide_item_pwd + _tide_print_item pwd @PWD@ +end + +function _tide_item_newline + set_color $prev_bg_color -b normal + v=tide_"$_tide_side"_prompt_suffix echo $$v + set -g add_prefix +end diff --git a/config/fish/functions/_tide_cache_variables.fish b/config/fish/functions/_tide_cache_variables.fish new file mode 100644 index 0000000..31e3850 --- /dev/null +++ b/config/fish/functions/_tide_cache_variables.fish @@ -0,0 +1,17 @@ +function _tide_cache_variables + # Same-color-separator color + set_color $tide_prompt_color_separator_same_color | read -gx _tide_color_separator_same_color + + # git + contains git $_tide_left_items $_tide_right_items && set_color $tide_git_color_branch | read -gx _tide_location_color + + # private_mode + if contains private_mode $_tide_left_items $_tide_right_items && test -n "$fish_private_mode" + set -gx _tide_private_mode + else + set -e _tide_private_mode + end + + # item padding + test "$tide_prompt_pad_items" = true && set -gx _tide_pad ' ' || set -e _tide_pad +end diff --git a/config/fish/functions/_tide_detect_os.fish b/config/fish/functions/_tide_detect_os.fish new file mode 100644 index 0000000..cf38388 --- /dev/null +++ b/config/fish/functions/_tide_detect_os.fish @@ -0,0 +1,77 @@ +# Outputs icon, color, bg_color +function _tide_detect_os + set -lx defaultColor 080808 CED7CF + switch (uname | string lower) + case darwin + printf %s\n  D6D6D6 333333 # from apple.com header + case freebsd openbsd dragonfly + printf %s\n  FFFFFF AB2B28 # https://freebsdfoundation.org/about-us/about-the-foundation/project/ + case 'cygwin*' 'mingw*_nt*' 'msys_nt*' + printf %s\n  FFFFFF 00CCFF # https://answers.microsoft.com/en-us/windows/forum/all/what-is-the-official-windows-8-blue-rgb-or-hex/fd57144b-f69b-42d8-8c21-6ca911646e44 + case linux + if test (uname -o) = Android + echo ﲎ # This character is evil and messes up code display, so it's put on its own line + # https://developer.android.com/distribute/marketing-tools/brand-guidelines + printf %s\n 3DDC84 3C3F41 # fg is from above link, bg is from Android Studio default dark theme + else + _tide_detect_os_linux_cases /etc/os-release ID || + _tide_detect_os_linux_cases /etc/os-release ID_LIKE || + _tide_detect_os_linux_cases /etc/lsb-release DISTRIB_ID || + printf %s\n  $defaultColor + end + case '*' + echo -ns '?' + end +end + +function _tide_detect_os_linux_cases -a file key + test -e $file || return + set -l split_file (string split '=' <$file) + set -l key_index (contains --index $key $split_file) || return + set -l value (string trim --chars='"' $split_file[(math $key_index + 1)]) + + # Anything which would have pure white background has been changed to D4D4D4 + # It was just too bright otherwise + switch (string lower $value) + case alpine + printf %s\n  FFFFFF 0D597F # from alpine logo + case arch + printf %s\n  1793D1 4D4D4D # from arch wiki header + case centos + printf %s\n  000000 D4D4D4 # https://wiki.centos.org/ArtWork/Brand/Logo, monochromatic + case debian + printf %s\n  C70036 D4D4D4 # from debian logo https://www.debian.org/logos/openlogo-nd-100.png + case devuan + printf %s\n  $defaultColor # logo is monochromatic + case elementary + printf %s\n  000000 D4D4D4 # https://elementary.io/brand, encouraged to be monochromatic + case fedora + printf %s\n  FFFFFF 294172 # from logo https://fedoraproject.org/w/uploads/2/2d/Logo_fedoralogo.png + case gentoo + printf %s\n  FFFFFF 54487A # https://wiki.gentoo.org/wiki/Project:Artwork/Colors + case mageia + printf %s\n  FFFFFF 262F45 # https://wiki.mageia.org/en/Artwork_guidelines + case manjaro + printf %s\n  FFFFFF 35BF5C # from https://gitlab.manjaro.org/artwork/branding/logo/-/blob/master/logo.svg + case mint linuxmint + printf %s\n  FFFFFF 69B53F # extracted from https://linuxmint.com/web/img/favicon.ico + case nixos + printf %s\n  FFFFFF 5277C3 # https://github.com/NixOS/nixos-artwork/tree/master/logo + case opensuse-leap opensuse-tumbleweed opensuse-microos + printf %s\n  73BA25 173f4f # https://en.opensuse.org/openSUSE:Artwork_brand + case raspbian + printf %s\n  FFFFFF A22846 # https://static.raspberrypi.org/files/Raspberry_Pi_Visual_Guidelines_2020.pdf + case rhel + printf %s\n  EE0000 000000 # https://www.redhat.com/en/about/brand/standards/color + case sabayon + printf %s\n  $defaultColor # Can't find colors, and they are rebranding anyway + case slackware + printf %s\n  $defaultColor # Doesn't really have a logo, and the colors are too close to PWD blue anyway + case ubuntu + printf %s\n  E95420 D4D4D4 # https://design.ubuntu.com/brand/ + case void + printf %s\n  FFFFFF 478061 # from https://alpha.de.repo.voidlinux.org/logos/void.svg + case '*' + return 1 + end +end diff --git a/config/fish/functions/_tide_find_and_remove.fish b/config/fish/functions/_tide_find_and_remove.fish new file mode 100644 index 0000000..29f2180 --- /dev/null +++ b/config/fish/functions/_tide_find_and_remove.fish @@ -0,0 +1,3 @@ +function _tide_find_and_remove -a name list --no-scope-shadowing + contains --index $name $$list | read -l index && set -e "$list"[$index] +end diff --git a/config/fish/functions/_tide_fish_colorize.fish b/config/fish/functions/_tide_fish_colorize.fish new file mode 100644 index 0000000..f79b188 --- /dev/null +++ b/config/fish/functions/_tide_fish_colorize.fish @@ -0,0 +1,7 @@ +function _tide_fish_colorize + if command -q fish_indent + echo -ns "$argv" | fish_indent --ansi + else + echo -ns "$argv" + end +end diff --git a/config/fish/functions/_tide_item_aws.fish b/config/fish/functions/_tide_item_aws.fish new file mode 100644 index 0000000..7cb6338 --- /dev/null +++ b/config/fish/functions/_tide_item_aws.fish @@ -0,0 +1,11 @@ +function _tide_item_aws + # AWS_PROFILE overrides AWS_DEFAULT_PROFILE, AWS_REGION overrides AWS_DEFAULT_REGION + set -q AWS_PROFILE && set -l AWS_DEFAULT_PROFILE $AWS_PROFILE + set -q AWS_REGION && set -l AWS_DEFAULT_REGION $AWS_REGION + + if test -n "$AWS_DEFAULT_PROFILE" && test -n "$AWS_DEFAULT_REGION" + _tide_print_item aws $tide_aws_icon' ' "$AWS_DEFAULT_PROFILE/$AWS_DEFAULT_REGION" + else if test -n "$AWS_DEFAULT_PROFILE$AWS_DEFAULT_REGION" + _tide_print_item aws $tide_aws_icon' ' "$AWS_DEFAULT_PROFILE$AWS_DEFAULT_REGION" + end +end diff --git a/config/fish/functions/_tide_item_character.fish b/config/fish/functions/_tide_item_character.fish new file mode 100644 index 0000000..10bb324 --- /dev/null +++ b/config/fish/functions/_tide_item_character.fish @@ -0,0 +1,17 @@ +function _tide_item_character + test $_tide_status = 0 && set_color $tide_character_color || set_color $tide_character_color_failure + + set -q add_prefix || echo -ns ' ' + + test "$fish_key_bindings" = fish_default_key_bindings && echo -ns $tide_character_icon || + switch $fish_bind_mode + case insert + echo -ns $tide_character_icon + case default + echo -ns $tide_character_vi_icon_default + case replace replace_one + echo -ns $tide_character_vi_icon_replace + case visual + echo -ns $tide_character_vi_icon_visual + end +end diff --git a/config/fish/functions/_tide_item_cmd_duration.fish b/config/fish/functions/_tide_item_cmd_duration.fish new file mode 100644 index 0000000..bc48bac --- /dev/null +++ b/config/fish/functions/_tide_item_cmd_duration.fish @@ -0,0 +1,12 @@ +function _tide_item_cmd_duration + test $CMD_DURATION -gt $tide_cmd_duration_threshold && t=( + math -s0 "$CMD_DURATION/3600000" # Hours + math -s0 "$CMD_DURATION/60000"%60 # Minutes + math -s$tide_cmd_duration_decimals "$CMD_DURATION/1000"%60) if test $t[1] != 0 + _tide_print_item cmd_duration $tide_cmd_duration_icon' ' "$t[1]h $t[2]m $t[3]s" + else if test $t[2] != 0 + _tide_print_item cmd_duration $tide_cmd_duration_icon' ' "$t[2]m $t[3]s" + else + _tide_print_item cmd_duration $tide_cmd_duration_icon' ' "$t[3]s" + end +end diff --git a/config/fish/functions/_tide_item_context.fish b/config/fish/functions/_tide_item_context.fish new file mode 100644 index 0000000..cbdf420 --- /dev/null +++ b/config/fish/functions/_tide_item_context.fish @@ -0,0 +1,14 @@ +function _tide_item_context + if set -q SSH_TTY + set -fx tide_context_color $tide_context_color_ssh + else if test "$EUID" = 0 + set -fx tide_context_color $tide_context_color_root + else if test "$tide_context_always_display" = true + set -fx tide_context_color $tide_context_color_default + else + return + end + + string match -qr "^(?(\.?[^\.]*){0,$tide_context_hostname_parts})" @$hostname + _tide_print_item context $USER$h +end diff --git a/config/fish/functions/_tide_item_crystal.fish b/config/fish/functions/_tide_item_crystal.fish new file mode 100644 index 0000000..620dde4 --- /dev/null +++ b/config/fish/functions/_tide_item_crystal.fish @@ -0,0 +1,6 @@ +function _tide_item_crystal + if path is $_tide_parent_dirs/shard.yml + crystal --version | string match -qr "(?[\d.]+)" + _tide_print_item crystal $tide_crystal_icon' ' $v + end +end diff --git a/config/fish/functions/_tide_item_direnv.fish b/config/fish/functions/_tide_item_direnv.fish new file mode 100644 index 0000000..f3c892b --- /dev/null +++ b/config/fish/functions/_tide_item_direnv.fish @@ -0,0 +1,7 @@ +function _tide_item_direnv + set -q DIRENV_DIR || return + direnv status | string match -q 'Found RC allowed false' && + set -lx tide_direnv_color $tide_direnv_color_denied && + set -lx tide_direnv_bg_color $tide_direnv_bg_color_denied + _tide_print_item direnv $tide_direnv_icon +end diff --git a/config/fish/functions/_tide_item_distrobox.fish b/config/fish/functions/_tide_item_distrobox.fish new file mode 100644 index 0000000..5e06a8b --- /dev/null +++ b/config/fish/functions/_tide_item_distrobox.fish @@ -0,0 +1,4 @@ +function _tide_item_distrobox + test -e /etc/profile.d/distrobox_profile.sh && test -e /run/.containerenv && + _tide_print_item distrobox $tide_distrobox_icon' ' (string match -rg 'name="(.*)"' .*)' <$CLOUDSDK_CONFIG/configurations/config_$config && + _tide_print_item gcloud $tide_gcloud_icon' ' $project +end diff --git a/config/fish/functions/_tide_item_git.fish b/config/fish/functions/_tide_item_git.fish new file mode 100644 index 0000000..3154acc --- /dev/null +++ b/config/fish/functions/_tide_item_git.fish @@ -0,0 +1,72 @@ +function _tide_item_git + if git branch --show-current 2>/dev/null | string shorten -"$tide_git_truncation_strategy"m$tide_git_truncation_length | read -l location + git rev-parse --git-dir --is-inside-git-dir | read -fL gdir in_gdir + set location $_tide_location_color$location + else if test $pipestatus[1] != 0 + return + else if git tag --points-at HEAD | string shorten -"$tide_git_truncation_strategy"m$tide_git_truncation_length | read location + git rev-parse --git-dir --is-inside-git-dir | read -fL gdir in_gdir + set location '#'$_tide_location_color$location + else + git rev-parse --git-dir --is-inside-git-dir --short HEAD | read -fL gdir in_gdir location + set location @$_tide_location_color$location + end + + # Operation + if test -d $gdir/rebase-merge + # Turn ANY into ALL, via double negation + if not path is -v $gdir/rebase-merge/{msgnum,end} + read -f step <$gdir/rebase-merge/msgnum + read -f total_steps <$gdir/rebase-merge/end + end + test -f $gdir/rebase-merge/interactive && set -f operation rebase-i || set -f operation rebase-m + else if test -d $gdir/rebase-apply + if not path is -v $gdir/rebase-apply/{next,last} + read -f step <$gdir/rebase-apply/next + read -f total_steps <$gdir/rebase-apply/last + end + if test -f $gdir/rebase-apply/rebasing + set -f operation rebase + else if test -f $gdir/rebase-apply/applying + set -f operation am + else + set -f operation am/rebase + end + else if test -f $gdir/MERGE_HEAD + set -f operation merge + else if test -f $gdir/CHERRY_PICK_HEAD + set -f operation cherry-pick + else if test -f $gdir/REVERT_HEAD + set -f operation revert + else if test -f $gdir/BISECT_LOG + set -f operation bisect + end + + # Git status/stash + Upstream behind/ahead + test $in_gdir = true && set -l _set_dir_opt -C $gdir/.. + # Suppress errors in case we are in a bare repo or there is no upstream + set -l stat (git $_set_dir_opt --no-optional-locks status --porcelain 2>/dev/null) + string match -qr '(0|(?.*))\n(0|(?.*))\n(0|(?.*)) +(0|(?.*))\n(0|(?.*))(\n(0|(?.*))\t(0|(?.*)))?' \ + "$(git $_set_dir_opt stash list 2>/dev/null | count + string match -r ^UU $stat | count + string match -r ^[ADMR]. $stat | count + string match -r ^.[ADMR] $stat | count + string match -r '^\?\?' $stat | count + git rev-list --count --left-right @{upstream}...HEAD 2>/dev/null)" + + if test -n "$operation$conflicted" + set -g tide_git_bg_color $tide_git_bg_color_urgent + else if test -n "$staged$dirty$untracked" + set -g tide_git_bg_color $tide_git_bg_color_unstable + end + + _tide_print_item git $_tide_location_color$tide_git_icon' ' (set_color white; echo -ns $location + set_color $tide_git_color_operation; echo -ns ' '$operation ' '$step/$total_steps + set_color $tide_git_color_upstream; echo -ns ' ⇣'$behind ' ⇡'$ahead + set_color $tide_git_color_stash; echo -ns ' *'$stash + set_color $tide_git_color_conflicted; echo -ns ' ~'$conflicted + set_color $tide_git_color_staged; echo -ns ' +'$staged + set_color $tide_git_color_dirty; echo -ns ' !'$dirty + set_color $tide_git_color_untracked; echo -ns ' ?'$untracked) +end diff --git a/config/fish/functions/_tide_item_go.fish b/config/fish/functions/_tide_item_go.fish new file mode 100644 index 0000000..b9aacae --- /dev/null +++ b/config/fish/functions/_tide_item_go.fish @@ -0,0 +1,6 @@ +function _tide_item_go + if path is $_tide_parent_dirs/go.mod + go version | string match -qr "(?[\d.]+)" + _tide_print_item go $tide_go_icon' ' $v + end +end diff --git a/config/fish/functions/_tide_item_java.fish b/config/fish/functions/_tide_item_java.fish new file mode 100644 index 0000000..804ec05 --- /dev/null +++ b/config/fish/functions/_tide_item_java.fish @@ -0,0 +1,6 @@ +function _tide_item_java + if path is $_tide_parent_dirs/pom.xml + java -version &| string match -qr "(?[\d.]+)" + _tide_print_item java $tide_java_icon' ' $v + end +end diff --git a/config/fish/functions/_tide_item_jobs.fish b/config/fish/functions/_tide_item_jobs.fish new file mode 100644 index 0000000..2a02118 --- /dev/null +++ b/config/fish/functions/_tide_item_jobs.fish @@ -0,0 +1,7 @@ +function _tide_item_jobs + set -q _tide_jobs && if test $_tide_jobs -ge $tide_jobs_number_threshold + _tide_print_item jobs $tide_jobs_icon' ' $_tide_jobs + else + _tide_print_item jobs $tide_jobs_icon + end +end diff --git a/config/fish/functions/_tide_item_kubectl.fish b/config/fish/functions/_tide_item_kubectl.fish new file mode 100644 index 0000000..ab044b3 --- /dev/null +++ b/config/fish/functions/_tide_item_kubectl.fish @@ -0,0 +1,4 @@ +function _tide_item_kubectl + kubectl config view --minify --output 'jsonpath={.current-context}/{..namespace}' 2>/dev/null | read -l context && + _tide_print_item kubectl $tide_kubectl_icon' ' (string replace -r '/(|default)$' '' $context) +end diff --git a/config/fish/functions/_tide_item_nix_shell.fish b/config/fish/functions/_tide_item_nix_shell.fish new file mode 100644 index 0000000..647f606 --- /dev/null +++ b/config/fish/functions/_tide_item_nix_shell.fish @@ -0,0 +1,3 @@ +function _tide_item_nix_shell + set -q IN_NIX_SHELL && _tide_print_item nix_shell $tide_nix_shell_icon' ' $IN_NIX_SHELL +end diff --git a/config/fish/functions/_tide_item_node.fish b/config/fish/functions/_tide_item_node.fish new file mode 100644 index 0000000..fc57832 --- /dev/null +++ b/config/fish/functions/_tide_item_node.fish @@ -0,0 +1,6 @@ +function _tide_item_node + if path is $_tide_parent_dirs/package.json + node --version | string match -qr "v(?.*)" + _tide_print_item node $tide_node_icon' ' $v + end +end diff --git a/config/fish/functions/_tide_item_os.fish b/config/fish/functions/_tide_item_os.fish new file mode 100644 index 0000000..8a6208c --- /dev/null +++ b/config/fish/functions/_tide_item_os.fish @@ -0,0 +1,3 @@ +function _tide_item_os + _tide_print_item os $tide_os_icon +end diff --git a/config/fish/functions/_tide_item_php.fish b/config/fish/functions/_tide_item_php.fish new file mode 100644 index 0000000..c8d28d9 --- /dev/null +++ b/config/fish/functions/_tide_item_php.fish @@ -0,0 +1,6 @@ +function _tide_item_php + if path is $_tide_parent_dirs/composer.json + php --version | string match -qr "(?[\d.]+)" + _tide_print_item php $tide_php_icon' ' $v + end +end diff --git a/config/fish/functions/_tide_item_private_mode.fish b/config/fish/functions/_tide_item_private_mode.fish new file mode 100644 index 0000000..4eb4684 --- /dev/null +++ b/config/fish/functions/_tide_item_private_mode.fish @@ -0,0 +1,3 @@ +function _tide_item_private_mode + set -q _tide_private_mode && _tide_print_item private_mode $tide_private_mode_icon +end diff --git a/config/fish/functions/_tide_item_pulumi.fish b/config/fish/functions/_tide_item_pulumi.fish new file mode 100644 index 0000000..6302a7e --- /dev/null +++ b/config/fish/functions/_tide_item_pulumi.fish @@ -0,0 +1,19 @@ +function _tide_item_pulumi + if path filter $_tide_parent_dirs/Pulumi.yaml | read -l yaml_path + if command -q sha1sum + echo -n "$yaml_path" | sha1sum | string match -qr "(?.{40})" + else if command -q shasum + echo -n "$yaml_path" | shasum | string match -qr "(?.{40})" + else + return + end + + string match -qr 'name: *(?.*)' <$yaml_path + set -l workspace_file "$HOME/.pulumi/workspaces/$project_name-$path_hash-workspace.json" + + if test -e $workspace_file + string match -qr '"stack": *"(?.*)"' <$workspace_file + _tide_print_item pulumi $tide_pulumi_icon' ' $stack + end + end +end diff --git a/config/fish/functions/_tide_item_python.fish b/config/fish/functions/_tide_item_python.fish new file mode 100644 index 0000000..57f7075 --- /dev/null +++ b/config/fish/functions/_tide_item_python.fish @@ -0,0 +1,27 @@ +function _tide_item_python + if test -n "$VIRTUAL_ENV" + if command -q python3 + python3 --version | string match -qr "(?[\d.]+)" + else + python --version | string match -qr "(?[\d.]+)" + end + string match -qr "^.*/(?.*)/(?.*)" $VIRTUAL_ENV + # pipenv $VIRTUAL_ENV looks like /home/ilan/.local/share/virtualenvs/pipenv_project-EwRYuc3l + # Detect whether we are using pipenv by looking for 'virtualenvs'. If so, remove the hash at the end. + if test "$dir" = virtualenvs + string match -qr "(?.*)-.*" $base + _tide_print_item python $tide_python_icon' ' "$v ($base)" + else if contains -- "$base" virtualenv venv .venv env # avoid generic names + _tide_print_item python $tide_python_icon' ' "$v ($dir)" + else + _tide_print_item python $tide_python_icon' ' "$v ($base)" + end + else if path is .python-version Pipfile __init__.py pyproject.toml requirements.txt setup.py + if command -q python3 + python3 --version | string match -qr "(?[\d.]+)" + else + python --version | string match -qr "(?[\d.]+)" + end + _tide_print_item python $tide_python_icon' ' $v + end +end diff --git a/config/fish/functions/_tide_item_ruby.fish b/config/fish/functions/_tide_item_ruby.fish new file mode 100644 index 0000000..bde84eb --- /dev/null +++ b/config/fish/functions/_tide_item_ruby.fish @@ -0,0 +1,6 @@ +function _tide_item_ruby + if path is $_tide_parent_dirs/{*.gemspec,Gemfile,Rakefile,.ruby-version} + ruby --version | string match -qr "(?[\d.]+)" + _tide_print_item ruby $tide_ruby_icon' ' $v + end +end diff --git a/config/fish/functions/_tide_item_rustc.fish b/config/fish/functions/_tide_item_rustc.fish new file mode 100644 index 0000000..b46cd99 --- /dev/null +++ b/config/fish/functions/_tide_item_rustc.fish @@ -0,0 +1,6 @@ +function _tide_item_rustc + if path is $_tide_parent_dirs/Cargo.toml + rustc --version | string match -qr "(?[\d.]+)" + _tide_print_item rustc $tide_rustc_icon' ' $v + end +end diff --git a/config/fish/functions/_tide_item_shlvl.fish b/config/fish/functions/_tide_item_shlvl.fish new file mode 100644 index 0000000..95dd5ff --- /dev/null +++ b/config/fish/functions/_tide_item_shlvl.fish @@ -0,0 +1,4 @@ +function _tide_item_shlvl + # Non-interactive shells do not increment SHLVL, so we don't need to subtract 1 + test $SHLVL -gt $tide_shlvl_threshold && _tide_print_item shlvl $tide_shlvl_icon' ' $SHLVL +end diff --git a/config/fish/functions/_tide_item_status.fish b/config/fish/functions/_tide_item_status.fish new file mode 100644 index 0000000..3a040fd --- /dev/null +++ b/config/fish/functions/_tide_item_status.fish @@ -0,0 +1,15 @@ +function _tide_item_status + if string match -qv 0 $_tide_pipestatus # If there is a failure anywhere in the pipestatus + if test "$_tide_pipestatus" = 1 # If simple failure + contains character $_tide_left_items || tide_status_bg_color=$tide_status_bg_color_failure \ + tide_status_color=$tide_status_color_failure _tide_print_item status $tide_status_icon_failure' ' 1 + else + fish_status_to_signal $_tide_pipestatus | string replace SIG '' | string join '|' | read -l out + test $_tide_status = 0 && _tide_print_item status $tide_status_icon' ' $out || + tide_status_bg_color=$tide_status_bg_color_failure tide_status_color=$tide_status_color_failure \ + _tide_print_item status $tide_status_icon_failure' ' $out + end + else if not contains character $_tide_left_items + _tide_print_item status $tide_status_icon + end +end diff --git a/config/fish/functions/_tide_item_terraform.fish b/config/fish/functions/_tide_item_terraform.fish new file mode 100644 index 0000000..c079ce3 --- /dev/null +++ b/config/fish/functions/_tide_item_terraform.fish @@ -0,0 +1,5 @@ +function _tide_item_terraform + path is $_tide_parent_dirs/.terraform && + terraform workspace show | string match -v default | read -l w && + _tide_print_item terraform $tide_terraform_icon' ' $w +end diff --git a/config/fish/functions/_tide_item_time.fish b/config/fish/functions/_tide_item_time.fish new file mode 100644 index 0000000..b8522bc --- /dev/null +++ b/config/fish/functions/_tide_item_time.fish @@ -0,0 +1,3 @@ +function _tide_item_time + _tide_print_item time (date +$tide_time_format) +end diff --git a/config/fish/functions/_tide_item_toolbox.fish b/config/fish/functions/_tide_item_toolbox.fish new file mode 100644 index 0000000..0b33f29 --- /dev/null +++ b/config/fish/functions/_tide_item_toolbox.fish @@ -0,0 +1,4 @@ +function _tide_item_toolbox + test -e /run/.toolboxenv && + _tide_print_item toolbox $tide_toolbox_icon' ' (string match -rg 'name="(.*)"' [\d.]+(-dev)?)" + _tide_print_item zig $tide_zig_icon' ' $v + end +end diff --git a/config/fish/functions/_tide_parent_dirs.fish b/config/fish/functions/_tide_parent_dirs.fish new file mode 100644 index 0000000..9f31b04 --- /dev/null +++ b/config/fish/functions/_tide_parent_dirs.fish @@ -0,0 +1,7 @@ +function _tide_parent_dirs --on-variable PWD + set -g _tide_parent_dirs (string escape ( + for dir in (string split / -- $PWD) + set -la parts $dir + string join / -- $parts + end)) +end diff --git a/config/fish/functions/_tide_print_item.fish b/config/fish/functions/_tide_print_item.fish new file mode 100644 index 0000000..db5c98b --- /dev/null +++ b/config/fish/functions/_tide_print_item.fish @@ -0,0 +1,22 @@ +function _tide_print_item -a item + v=tide_"$item"_bg_color set -f item_bg_color $$v + + if set -e add_prefix + set_color $item_bg_color -b normal + v=tide_"$_tide_side"_prompt_prefix echo -ns $$v + else if test "$item_bg_color" = "$prev_bg_color" + v=tide_"$_tide_side"_prompt_separator_same_color echo -ns $_tide_color_separator_same_color$$v + else if test $_tide_side = left + set_color $prev_bg_color -b $item_bg_color + echo -ns $tide_left_prompt_separator_diff_color + else + set_color $item_bg_color -b $prev_bg_color + echo -ns $tide_right_prompt_separator_diff_color + end + + v=tide_"$item"_color set_color $$v -b $item_bg_color + + echo -ns $_tide_pad $argv[2..] $_tide_pad + + set -g prev_bg_color $item_bg_color +end diff --git a/config/fish/functions/_tide_pwd.fish b/config/fish/functions/_tide_pwd.fish new file mode 100644 index 0000000..5447dd4 --- /dev/null +++ b/config/fish/functions/_tide_pwd.fish @@ -0,0 +1,42 @@ +set_color -o $tide_pwd_color_anchors | read -l color_anchors +set_color $tide_pwd_color_truncated_dirs | read -l color_truncated +set -l reset_to_color_dirs (set_color normal -b $tide_pwd_bg_color; set_color $tide_pwd_color_dirs) + +set -l unwritable_icon $tide_pwd_icon_unwritable' ' +set -l home_icon $tide_pwd_icon_home' ' +set -l pwd_icon $tide_pwd_icon' ' + +eval "function _tide_pwd + if set -l split_pwd (string replace -r '^$HOME' '~' -- \$PWD | string split /) + test -w . && set -f split_output \"$pwd_icon\$split_pwd[1]\" \$split_pwd[2..] || + set -f split_output \"$unwritable_icon\$split_pwd[1]\" \$split_pwd[2..] + set split_output[-1] \"$color_anchors\$split_output[-1]$reset_to_color_dirs\" + else + set -f split_output \"$home_icon$color_anchors~\" + end + + string join / -- \$split_output | string length -V | read -g _tide_pwd_len + + i=1 for dir_section in \$split_pwd[2..-2] + string join -- / \$split_pwd[..\$i] | string replace '~' $HOME | read -l parent_dir # Uses i before increment + + math \$i+1 | read i + + if path is \$parent_dir/\$dir_section/\$tide_pwd_markers + set split_output[\$i] \"$color_anchors\$dir_section$reset_to_color_dirs\" + else if test \$_tide_pwd_len -gt \$dist_btwn_sides + string match -qr \"(?\..|.)\" \$dir_section + + set -l glob \$parent_dir/\$trunc*/ + set -e glob[(contains -i \$parent_dir/\$dir_section/ \$glob)] # This is faster than inverse string match + + while string match -qr \"^\$parent_dir/\$(string escape --style=regex \$trunc)\" \$glob && + string match -qr \"(?\$(string escape --style=regex \$trunc).)\" \$dir_section + end + test -n \"\$trunc\" && set split_output[\$i] \"$color_truncated\$trunc$reset_to_color_dirs\" && + string join / \$split_output | string length -V | read _tide_pwd_len + end + end + + string join -- / \"$reset_to_color_dirs\$split_output[1]\" \$split_output[2..] +end" diff --git a/config/fish/functions/_tide_remove_unusable_items.fish b/config/fish/functions/_tide_remove_unusable_items.fish new file mode 100644 index 0000000..deb4c10 --- /dev/null +++ b/config/fish/functions/_tide_remove_unusable_items.fish @@ -0,0 +1,25 @@ +function _tide_remove_unusable_items + # Remove tool-specific items for tools the machine doesn't have installed + set -l removed_items + for item in aws crystal direnv distrobox docker elixir gcloud git go java kubectl nix_shell node php pulumi python ruby rustc terraform toolbox zig + contains $item $tide_left_prompt_items $tide_right_prompt_items || continue + + set -l cli_names $item + switch $item + case distrobox # there is no 'distrobox' command inside the container + set cli_names distrobox-export # 'distrobox-export' and 'distrobox-host-exec' are available + case nix_shell + set cli_names nix nix-shell + case python + set cli_names python python3 + end + type --query $cli_names || set -a removed_items $item + end + + set -U _tide_left_items (for item in $tide_left_prompt_items + contains $item $removed_items || echo $item + end) + set -U _tide_right_items (for item in $tide_right_prompt_items + contains $item $removed_items || echo $item + end) +end diff --git a/config/fish/functions/_tide_sub_bug-report.fish b/config/fish/functions/_tide_sub_bug-report.fish new file mode 100644 index 0000000..a8065c8 --- /dev/null +++ b/config/fish/functions/_tide_sub_bug-report.fish @@ -0,0 +1,73 @@ +function _tide_sub_bug-report + argparse c/clean v/verbose check -- $argv + + set -l fish_path (status fish-path) + + if set -q _flag_clean + HOME=(mktemp -d) $fish_path --init-command "curl --silent \ + https://raw.githubusercontent.com/jorgebucaran/fisher/main/functions/fisher.fish | + source && fisher install ilancosman/tide@v6" + else if set -q _flag_verbose + set --long | string match -r "^_?tide.*" | # Get only tide variables + string match -r --invert "^_tide_prompt_var.*" # Remove _tide_prompt_var + else + set -l fish_version ($fish_path --version | string match -r "fish, version (\d\.\d\.\d)")[2] + _tide_check_version Fish fish-shell/fish-shell "(\d\.\d\.\d)" $fish_version || return + + set -l tide_version (tide --version | string match -r "tide, version (\d\.\d\.\d)")[2] + _tide_check_version Tide IlanCosman/tide "v(\d\.\d\.\d)" $tide_version || return + + if command --query git + test (git --version | string match -r "git version ([\d\.]*)" | string replace --all . '')[2] -gt 2220 + _tide_check_condition \ + "Your git version is too old." \ + "Tide requires at least version 2.22." \ + "Please update before submitting a bug report." || return + end + + # Check that omf is not installed + not functions --query omf + _tide_check_condition \ + "Tide does not work with oh-my-fish installed." \ + "Please uninstall it before submitting a bug report." || return + + if not set -q _flag_check + set -l fish_startup_time ($fish_path -ic "time $fish_path -c exit" 2>| + string match -r "Executed in(.*)fish" | string trim)[2] + + read --local --prompt-str "What operating system are you using? (e.g Ubuntu 20.04): " os + read --local --prompt-str "What terminal emulator are you using? (e.g Kitty): " terminal_emulator + + printf '%b\n' "\nPlease copy the following information into the issue:\n" \ + "fish version: $fish_version" \ + "tide version: $tide_version" \ + "term: $TERM" \ + "os: $os" \ + "terminal emulator: $terminal_emulator" \ + "fish startup: $fish_startup_time" \ + "fisher plugins: $_fisher_plugins" + end + end +end + +function _tide_check_version -a program_name repo_name regex_to_get_version current_version + curl --silent https://github.com/$repo_name/releases/latest | + string match -r ".*$repo_name/releases/tag/$regex_to_get_version.*" | + read --local --line __ latestVersion + + string match --quiet -r "^$latestVersion" "$current_version" + _tide_check_condition \ + "Your $program_name version is out of date." \ + "The latest is $latestVersion. You have $current_version." \ + "Please update before submitting a bug report." +end + +function _tide_check_condition + if test "$status" != 0 + set_color red + printf '%s\n' $argv + set_color normal + return 1 + end + return 0 +end diff --git a/config/fish/functions/_tide_sub_configure.fish b/config/fish/functions/_tide_sub_configure.fish new file mode 100644 index 0000000..22faf3a --- /dev/null +++ b/config/fish/functions/_tide_sub_configure.fish @@ -0,0 +1,156 @@ +set -g _tide_color_dark_blue 0087AF +set -g _tide_color_dark_green 5FAF00 +set -g _tide_color_gold D7AF00 +set -g _tide_color_green 5FD700 +set -g _tide_color_light_blue 00AFFF + +# Create an empty fake function for each item +for func in _fake(functions --all | string match --entire _tide_item) + function $func + end +end + +for file in (status dirname)/tide/configure/{choices, functions}/**.fish + source $file +end + +function _tide_sub_configure + set -l choices (path basename (status dirname)/tide/configure/choices/**.fish | path change-extension '') + argparse auto $choices= -- $argv + + for var in (set -l --names | string match -e _flag) + set -x $var $$var + end + + if set -q _flag_auto + set -fx _flag_finish 'Overwrite your current tide config' + else if test $COLUMNS -lt 55 -o $LINES -lt 21 + echo 'Terminal size too small; must be at least 55 x 21' + return 1 + end + + _tide_detect_os | read -g --line os_branding_icon os_branding_color os_branding_bg_color + + set -g fake_columns $COLUMNS + test $fake_columns -gt 90 && set fake_columns 90 + set -g fake_lines $LINES + + set -g _tide_selected_option + _next_choice all/style +end + +function _next_choice -a nextChoice + set -q _tide_selected_option || return 0 + set -l cmd (string split '/' $nextChoice)[2] + $cmd +end + +function _tide_title -a text + set -q _flag_auto && return + + command -q clear && clear + set_color -o + string pad --width (math --scale=0 "$fake_columns/2" + (string length $text)/2) $text + set_color normal + + set -g _tide_configure_first_option_after_title +end + +function _tide_option -a symbol text + set -ga _tide_symbol_list $symbol + set -ga _tide_option_list $text + + if not set -q _flag_auto + set -g _tide_configure_first_prompt_after_option + + set_color -o + set -e _tide_configure_first_option_after_title || echo + echo "($symbol) $text" + set_color normal + end +end + +function _tide_menu -a func + if set -q _flag_auto + set -l flag_var_name _flag_$func + set -g _tide_selected_option $$flag_var_name + + if test -z "$_tide_selected_option" + echo "Missing input for choice '$func'" + _tide_exit_configure + else if not contains $_tide_selected_option $_tide_option_list + echo "Invalid input '$_tide_selected_option' for choice '$func'" + _tide_exit_configure + else + set -e _tide_symbol_list + set -e _tide_option_list + end + return + end + + argparse no-restart -- $argv # Add no-restart option for first menu + + echo + if not set -q _flag_no_restart + set -f r r + echo '(r) Restart from the beginning' + end + echo '(q) Quit and do nothing'\n + + while read --nchars 1 --prompt-str \ + "$(set_color -o)Choice [$(string join '/' $_tide_symbol_list $r q)] $(set_color normal)" input + switch $input + case r + set -q _flag_no_restart && continue + set -e _tide_symbol_list + set -e _tide_option_list + _next_choice all/style + break + case q + _tide_exit_configure + set -e _tide_symbol_list + set -e _tide_option_list + command -q clear && clear + break + case $_tide_symbol_list + set -g _tide_selected_option $_tide_option_list[(contains -i $input $_tide_symbol_list)] + test "$func" != finish && + set -a _tide_configure_current_options --$func=(string escape $_tide_selected_option) + set -e _tide_symbol_list + set -e _tide_option_list + break + end + end +end + +function _tide_display_prompt + set -q _flag_auto && return + + _fake_tide_cache_variables + set -l prompt (_fake_tide_prompt) + + set -l bottom_left_prompt_string_length (string length --visible $prompt[-1]) + set -l right_prompt_string (string pad --width (math $fake_columns-$bottom_left_prompt_string_length) $prompt[1]) + set -l prompt[-1] "$prompt[-1]$right_prompt_string" + + if set -q _configure_transient + if contains newline $fake_tide_left_prompt_items + string unescape $prompt[3..] + else + _fake_tide_item_character + echo + end + else + if not set -q _tide_configure_first_prompt_after_option + test "$fake_tide_prompt_add_newline_before" = true && echo + end + string unescape $prompt[2..] + end + + set -e _tide_configure_first_prompt_after_option + set_color normal +end + +function _tide_exit_configure + set -e _tide_selected_option # Skip through all switch and _next_choice +end diff --git a/config/fish/functions/_tide_sub_reload.fish b/config/fish/functions/_tide_sub_reload.fish new file mode 100644 index 0000000..5a45fbd --- /dev/null +++ b/config/fish/functions/_tide_sub_reload.fish @@ -0,0 +1,3 @@ +function _tide_sub_reload + source (functions --details fish_prompt) +end diff --git a/config/fish/functions/app.fish b/config/fish/functions/app.fish new file mode 100644 index 0000000..834f8b9 --- /dev/null +++ b/config/fish/functions/app.fish @@ -0,0 +1,46 @@ +# @halostatue/fish-macos/functions/app.fish:v7.0.0 + +function app --description 'Operate on macOS applications' + argparse --stop-nonopt h/help -- $argv + + if set --query _flag_help + echo 'Usage: app [options] subcommand [arguments...] + +Operates on macOS apps by name. + +Subcommands: + bundleid Shows the bundleID for installed matching apps + find Shows installed matching apps + frontmost Shows the frontmost application + icon Saves the icon for matching apps to disk + quit Quits and optionally restarts matching apps + +Options: + -h, --help Show this help' + return 0 + end + + set --function cmd $argv[1] + set --erase argv[1] + + switch (string lower -- $cmd) + case bundleid + __macos_app_bundleid $argv + case find + __macos_app_find $argv + case frontmost + __macos_app_frontmost $argv + case icon + __macos_app_icon $argv + case quit + __macos_app_quit $argv + case '' + echo >&2 'app: No command provided.' + app --help >&2 + return 1 + case '*' + echo >&2 'app: Unknown command.' + app --help >&2 + return 1 + end +end diff --git a/config/fish/functions/bash2env.fish b/config/fish/functions/bash2env.fish new file mode 100644 index 0000000..39a7e6c --- /dev/null +++ b/config/fish/functions/bash2env.fish @@ -0,0 +1,39 @@ +# Copyright (c) 2022 Huang-Huang Bao +# +# This software is released under the MIT License. +# https://opensource.org/licenses/MIT + +function bash2env -d "Import environment variables modified by given bash command" + argparse --stop-nonopt h/help i/impure -- $argv + or set argv + + function _print_usage + echo 'Usage:' \ + (set_color $fish_color_command)'bash2env' \ + (set_color $fish_color_normal)'[-i/--impure]' \ + (set_color $fish_color_param)"" + end + + if test -n "$_flag_help" + _print_usage + return + end + if test (count $argv) -eq 0 + _print_usage + return 22 + end + + if test -n "$_flag_impure" + set _flag_impure 1 + end + + set -l DIR (dirname (status -f)) + __FISH_BASH2ENV_IMPURE=$_flag_impure command \ + bash $DIR/__bash2env.sh $argv | source + + for code in $pipestatus + if test $code != 0 + return $code + end + end +end diff --git a/config/fish/functions/finder.fish b/config/fish/functions/finder.fish new file mode 100644 index 0000000..38f6088 --- /dev/null +++ b/config/fish/functions/finder.fish @@ -0,0 +1,151 @@ +# @halostatue/fish-macos/functions/finder.fish:v7.0.0 + +function __macos_finder_defaults::query + set --query argv[1] + or return 1 + + set --function value (defaults read com.apple.Finder $argv[1] 2>/dev/null) + or return 1 + + switch $value + case 1 + true + case '*' + false + end +end + +function __macos_finder_defaults::set + set --query argv[1] + or return 1 + + set --query argv[2] + or return 1 + + defaults write com.apple.Finder $argv[1] -bool $argv[2] + and killall Finder +end + +function __macos_finder_pwd::get + set --function window 1 + + if set --query argv[1] + set window $argv[1] + end + + echo 'tell application "Finder" + if ('$window' <= (count Finder windows)) then + get POSIX path of (target of window '$window' as alias) + else + get POSIX path of (desktop as alias) + end if +end tell' | osascript +end +function __macos_finder_pwd::update + argparse --exclusive column,list,icon column list icon -- $argv + or return 1 + + set --function window_count 1 + set --function view '' + set --function view_type '' + + if set --query _flag_column + set view_type column + else if set --query _flag_list + set view_type list + else if set --query _flag_icon + set view_type icon + end + + if test $view_type != '' + set view 'set the current view of the front Finder window to '$view_type' view' + end + + set --query argv[1]; and set window_count $argv[1] + + echo 'tell application "Finder" + if ('$window_count' <= (count Finder windows)) then + set the target of window '$window_count' to (POSIX file "'$PWD'") as string + else + open (POSIX file "'$PWD'") as string + end if + ' $view ' +end tell' | osascript >/dev/null +end + +# Based on bashfinder: https://github.com/NapoleonWils0n/bashfinder.git +# and my port to zsh. +function finder --description 'Manipulate the finder with the current shell' + argparse --stop-nonopt h/help -- $argv + + if set --query _flag_help + echo 'Usage: finder [options] subcommand [arguments...] + +Interacts with the Finder. If a window number parameter is accepted in a +command, the first (front-most) window is number 1. If a lower window is +specified, or no window is specified, that window becomes the first window. + +Subcommands: + cd Changes to the path of the Finder window + clean Removes .DS_Store files + column Changes the Finder window to PWD using column view + desktop-icons Shows or hides the desktop icons + hidden Shows or hides files that are normally hidden from the Finder + icon Changes the Finder window to PWD using icon view + list Changes the Finder window to PWD using list view + pushd Changes to the path of the Finder window with pushd + pwd Prints the path of the Finder window + quarantine Manages quarantine events + selected Print the selected files on the command-line + track Makes the first Finder window track with the shell PWD + untrack Disables Finder directory tracking + update Updates the Finder window to PWD + +Options: + -h, --help Show this help' + return 0 + end + + set --function verb (string lower -- $argv[1]) + set --erase argv[1] + + switch $verb + case cd + __macos_finder_cd $argv + case clean + __macos_finder_clean $argv + case desktop-icons + __macos_finder_desktop_icons $argv + case hidden + __macos_finder_hidden $argv + case update + __macos_finder_update $argv + case list + __macos_finder_list $argv + case icon + __macos_finder_icon $argv + case column + __macos_finder_column $argv + case pwd + __macos_finder_pwd::get $argv[1] + case pushd + __macos_finder_pushd $argv + case quarantine + __macos_finder_quarantine $argv + case selected + __macos_finder_selected + case track + __macos_finder_track + case untrack + __macos_finder_untrack + case '' + echo >&2 'finder: No command provided.' + finder --help >&2 + return 1 + case '*' + echo $verb + echo >&2 'finder: Unknown command.' + finder --help >&2 + return 1 + end +end diff --git a/config/fish/functions/fish_mode_prompt.fish b/config/fish/functions/fish_mode_prompt.fish new file mode 100644 index 0000000..f37cf7d --- /dev/null +++ b/config/fish/functions/fish_mode_prompt.fish @@ -0,0 +1 @@ +# Disable default vi prompt diff --git a/config/fish/functions/fish_prompt.fish b/config/fish/functions/fish_prompt.fish new file mode 100644 index 0000000..3b58b7b --- /dev/null +++ b/config/fish/functions/fish_prompt.fish @@ -0,0 +1,171 @@ +function fish_prompt +end # In case this file gets loaded non-interactively, e.g by conda +status is-interactive || exit + +_tide_remove_unusable_items +_tide_cache_variables +_tide_parent_dirs +source (functions --details _tide_pwd) + +set -l prompt_var _tide_prompt_$fish_pid +set -U $prompt_var # Set var here so if we erase $prompt_var, bg job won't set a uvar + +set_color normal | read -l color_normal +status fish-path | read -l fish_path + +# _tide_repaint prevents us from creating a second background job +function _tide_refresh_prompt --on-variable $prompt_var --on-variable COLUMNS + set -g _tide_repaint + commandline -f repaint +end + +if contains newline $_tide_left_items # two line prompt initialization + test "$tide_prompt_add_newline_before" = true && set -l add_newline '\n' + + set_color $tide_prompt_color_frame_and_connection -b normal | read -l prompt_and_frame_color + + set -l column_offset 5 + test "$tide_left_prompt_frame_enabled" = true && + set -l top_left_frame "$prompt_and_frame_color╭─" && + set -l bot_left_frame "$prompt_and_frame_color╰─" && + set column_offset (math $column_offset-2) + test "$tide_right_prompt_frame_enabled" = true && + set -l top_right_frame "$prompt_and_frame_color─╮" && + set -l bot_right_frame "$prompt_and_frame_color─╯" && + set column_offset (math $column_offset-2) + + if test "$tide_prompt_transient_enabled" = true + eval " +function fish_prompt + _tide_status=\$status _tide_pipestatus=\$pipestatus if not set -e _tide_repaint + jobs -q && jobs -p | count | read -lx _tide_jobs + $fish_path -c \"set _tide_pipestatus \$_tide_pipestatus +set _tide_parent_dirs \$_tide_parent_dirs +PATH=\$(string escape \"\$PATH\") CMD_DURATION=\$CMD_DURATION fish_bind_mode=\$fish_bind_mode set $prompt_var (_tide_2_line_prompt)\" & + builtin disown + + command kill \$_tide_last_pid 2>/dev/null + set -g _tide_last_pid \$last_pid + end + + if not set -q _tide_transient + math \$COLUMNS-(string length -V \"\$$prompt_var[1][1]\$$prompt_var[1][3]\")+$column_offset | read -lx dist_btwn_sides + + echo -n $add_newline'$top_left_frame'(string replace @PWD@ (_tide_pwd) \"\$$prompt_var[1][1]\")'$prompt_and_frame_color' + string repeat -Nm(math max 0, \$dist_btwn_sides-\$_tide_pwd_len) '$tide_prompt_icon_connection' + + echo \"\$$prompt_var[1][3]$top_right_frame\" + end + echo -n \e\[0J\"$bot_left_frame\$$prompt_var[1][2]$color_normal \" +end + +function fish_right_prompt + set -e _tide_transient || string unescape \"\$$prompt_var[1][4]$bot_right_frame$color_normal\" +end" + else + eval " +function fish_prompt + _tide_status=\$status _tide_pipestatus=\$pipestatus if not set -e _tide_repaint + jobs -q && jobs -p | count | read -lx _tide_jobs + $fish_path -c \"set _tide_pipestatus \$_tide_pipestatus +set _tide_parent_dirs \$_tide_parent_dirs +PATH=\$(string escape \"\$PATH\") CMD_DURATION=\$CMD_DURATION fish_bind_mode=\$fish_bind_mode set $prompt_var (_tide_2_line_prompt)\" & + builtin disown + + command kill \$_tide_last_pid 2>/dev/null + set -g _tide_last_pid \$last_pid + end + + math \$COLUMNS-(string length -V \"\$$prompt_var[1][1]\$$prompt_var[1][3]\")+$column_offset | read -lx dist_btwn_sides + + echo -ns $add_newline'$top_left_frame'(string replace @PWD@ (_tide_pwd) \"\$$prompt_var[1][1]\")'$prompt_and_frame_color' + string repeat -Nm(math max 0, \$dist_btwn_sides-\$_tide_pwd_len) '$tide_prompt_icon_connection' + echo -ns \"\$$prompt_var[1][3]$top_right_frame\"\n\"$bot_left_frame\$$prompt_var[1][2]$color_normal \" +end + +function fish_right_prompt + string unescape \"\$$prompt_var[1][4]$bot_right_frame$color_normal\" +end" + end +else # one line prompt initialization + test "$tide_prompt_add_newline_before" = true && set -l add_newline '\0' + + math 5 -$tide_prompt_min_cols | read -l column_offset + test $column_offset -ge 0 && set column_offset "+$column_offset" + + if test "$tide_prompt_transient_enabled" = true + eval " +function fish_prompt + set -lx _tide_status \$status + _tide_pipestatus=\$pipestatus if not set -e _tide_repaint + jobs -q && jobs -p | count | read -lx _tide_jobs + $fish_path -c \"set _tide_pipestatus \$_tide_pipestatus +set _tide_parent_dirs \$_tide_parent_dirs +PATH=\$(string escape \"\$PATH\") CMD_DURATION=\$CMD_DURATION fish_bind_mode=\$fish_bind_mode set $prompt_var (_tide_1_line_prompt)\" & + builtin disown + + command kill \$_tide_last_pid 2>/dev/null + set -g _tide_last_pid \$last_pid + end + + if set -q _tide_transient + echo -n \e\[0J + add_prefix= _tide_item_character + echo -n '$color_normal ' + else + math \$COLUMNS-(string length -V \"\$$prompt_var[1][1]\$$prompt_var[1][2]\")$column_offset | read -lx dist_btwn_sides + string replace @PWD@ (_tide_pwd) $add_newline \$$prompt_var[1][1]'$color_normal ' + end +end + +function fish_right_prompt + set -e _tide_transient || string unescape \"\$$prompt_var[1][2]$color_normal\" +end" + else + eval " +function fish_prompt + _tide_status=\$status _tide_pipestatus=\$pipestatus if not set -e _tide_repaint + jobs -q && jobs -p | count | read -lx _tide_jobs + $fish_path -c \"set _tide_pipestatus \$_tide_pipestatus +set _tide_parent_dirs \$_tide_parent_dirs +PATH=\$(string escape \"\$PATH\") CMD_DURATION=\$CMD_DURATION fish_bind_mode=\$fish_bind_mode set $prompt_var (_tide_1_line_prompt)\" & + builtin disown + + command kill \$_tide_last_pid 2>/dev/null + set -g _tide_last_pid \$last_pid + end + + math \$COLUMNS-(string length -V \"\$$prompt_var[1][1]\$$prompt_var[1][2]\")$column_offset | read -lx dist_btwn_sides + string replace @PWD@ (_tide_pwd) $add_newline \$$prompt_var[1][1]'$color_normal ' +end + +function fish_right_prompt + string unescape \"\$$prompt_var[1][2]$color_normal\" +end" + end +end + +eval "function _tide_on_fish_exit --on-event fish_exit + set -e $prompt_var +end" + +if test "$tide_prompt_transient_enabled" = true + function _tide_enter_transient + # If the commandline will be executed, or is empty + if commandline --is-valid || test -z "$(commandline)" + # Pager open usually means selecting, not running + # Can be untrue, but it's better than the alternative + if not commandline --paging-mode + set -g _tide_transient + set -g _tide_repaint + commandline -f repaint + end + end + commandline -f execute + end + + bind \r _tide_enter_transient + bind \n _tide_enter_transient + bind -M insert \r _tide_enter_transient + bind -M insert \n _tide_enter_transient +end diff --git a/config/fish/functions/fisher.fish b/config/fish/functions/fisher.fish new file mode 100644 index 0000000..e915cb8 --- /dev/null +++ b/config/fish/functions/fisher.fish @@ -0,0 +1,240 @@ +function fisher --argument-names cmd --description "A plugin manager for Fish" + set --query fisher_path || set --local fisher_path $__fish_config_dir + set --local fisher_version 4.4.5 + set --local fish_plugins $__fish_config_dir/fish_plugins + + switch "$cmd" + case -v --version + echo "fisher, version $fisher_version" + case "" -h --help + echo "Usage: fisher install Install plugins" + echo " fisher remove Remove installed plugins" + echo " fisher update Update installed plugins" + echo " fisher update Update all installed plugins" + echo " fisher list [] List installed plugins matching regex" + echo "Options:" + echo " -v, --version Print version" + echo " -h, --help Print this help message" + echo "Variables:" + echo " \$fisher_path Plugin installation path. Default: $__fish_config_dir" | string replace --regex -- $HOME \~ + case ls list + string match --entire --regex -- "$argv[2]" $_fisher_plugins + case install update remove + isatty || read --local --null --array stdin && set --append argv $stdin + + set --local install_plugins + set --local update_plugins + set --local remove_plugins + set --local arg_plugins $argv[2..-1] + set --local old_plugins $_fisher_plugins + set --local new_plugins + + test -e $fish_plugins && set --local file_plugins (string match --regex -- '^[^\s]+$' <$fish_plugins | string replace -- \~ ~) + + if ! set --query argv[2] + if test "$cmd" != update + echo "fisher: Not enough arguments for command: \"$cmd\"" >&2 && return 1 + else if ! set --query file_plugins + echo "fisher: \"$fish_plugins\" file not found: \"$cmd\"" >&2 && return 1 + end + set arg_plugins $file_plugins + end + + for plugin in $arg_plugins + set plugin (test -e "$plugin" && realpath $plugin || string lower -- $plugin) + contains -- "$plugin" $new_plugins || set --append new_plugins $plugin + end + + if set --query argv[2] + for plugin in $new_plugins + if contains -- "$plugin" $old_plugins + test "$cmd" = remove && + set --append remove_plugins $plugin || + set --append update_plugins $plugin + else if test "$cmd" = install + set --append install_plugins $plugin + else + echo "fisher: Plugin not installed: \"$plugin\"" >&2 && return 1 + end + end + else + for plugin in $new_plugins + contains -- "$plugin" $old_plugins && + set --append update_plugins $plugin || + set --append install_plugins $plugin + end + + for plugin in $old_plugins + contains -- "$plugin" $new_plugins || set --append remove_plugins $plugin + end + end + + set --local pid_list + set --local source_plugins + set --local fetch_plugins $update_plugins $install_plugins + set --local fish_path (status fish-path) + + echo (set_color --bold)fisher $cmd version $fisher_version(set_color normal) + + for plugin in $fetch_plugins + set --local source (command mktemp -d) + set --append source_plugins $source + + command mkdir -p $source/{completions,conf.d,themes,functions} + + $fish_path --command " + if test -e $plugin + command cp -Rf $plugin/* $source + else + set temp (command mktemp -d) + set repo (string split -- \@ $plugin) || set repo[2] HEAD + + if set path (string replace --regex -- '^(https://)?gitlab.com/' '' \$repo[1]) + set name (string split -- / \$path)[-1] + set url https://gitlab.com/\$path/-/archive/\$repo[2]/\$name-\$repo[2].tar.gz + else + set url https://api.github.com/repos/\$repo[1]/tarball/\$repo[2] + end + + echo Fetching (set_color --underline)\$url(set_color normal) + + if command curl -q --silent -L \$url | command tar -xzC \$temp -f - 2>/dev/null + command cp -Rf \$temp/*/* $source + else + echo fisher: Invalid plugin name or host unavailable: \\\"$plugin\\\" >&2 + command rm -rf $source + end + + command rm -rf \$temp + end + + set files $source/* && string match --quiet --regex -- .+\.fish\\\$ \$files + " & + + set --append pid_list (jobs --last --pid) + end + + wait $pid_list 2>/dev/null + + for plugin in $fetch_plugins + if set --local source $source_plugins[(contains --index -- "$plugin" $fetch_plugins)] && test ! -e $source + if set --local index (contains --index -- "$plugin" $install_plugins) + set --erase install_plugins[$index] + else + set --erase update_plugins[(contains --index -- "$plugin" $update_plugins)] + end + end + end + + for plugin in $update_plugins $remove_plugins + if set --local index (contains --index -- "$plugin" $_fisher_plugins) + set --local plugin_files_var _fisher_(string escape --style=var -- $plugin)_files + + if contains -- "$plugin" $remove_plugins + for name in (string replace --filter --regex -- '.+/conf\.d/([^/]+)\.fish$' '$1' $$plugin_files_var) + emit {$name}_uninstall + end + printf "%s\n" Removing\ (set_color red --bold)$plugin(set_color normal) " "$$plugin_files_var | string replace -- \~ ~ + set --erase _fisher_plugins[$index] + end + + command rm -rf (string replace -- \~ ~ $$plugin_files_var) + + functions --erase (string replace --filter --regex -- '.+/functions/([^/]+)\.fish$' '$1' $$plugin_files_var) + + for name in (string replace --filter --regex -- '.+/completions/([^/]+)\.fish$' '$1' $$plugin_files_var) + complete --erase --command $name + end + + set --erase $plugin_files_var + end + end + + if set --query update_plugins[1] || set --query install_plugins[1] + command mkdir -p $fisher_path/{functions,themes,conf.d,completions} + end + + for plugin in $update_plugins $install_plugins + set --local source $source_plugins[(contains --index -- "$plugin" $fetch_plugins)] + set --local files $source/{functions,themes,conf.d,completions}/* + + if set --local index (contains --index -- $plugin $install_plugins) + set --local user_files $fisher_path/{functions,themes,conf.d,completions}/* + set --local conflict_files + + for file in (string replace -- $source/ $fisher_path/ $files) + contains -- $file $user_files && set --append conflict_files $file + end + + if set --query conflict_files[1] && set --erase install_plugins[$index] + echo -s "fisher: Cannot install \"$plugin\": please remove or move conflicting files first:" \n" "$conflict_files >&2 + continue + end + end + + for file in (string replace -- $source/ "" $files) + command cp -RLf $source/$file $fisher_path/$file + end + + set --local plugin_files_var _fisher_(string escape --style=var -- $plugin)_files + + set --query files[1] && set --universal $plugin_files_var (string replace -- $source $fisher_path $files | string replace -- ~ \~) + + contains -- $plugin $_fisher_plugins || set --universal --append _fisher_plugins $plugin + contains -- $plugin $install_plugins && set --local event install || set --local event update + + printf "%s\n" Installing\ (set_color --bold)$plugin(set_color normal) " "$$plugin_files_var | string replace -- \~ ~ + + for file in (string match --regex -- '.+/[^/]+\.fish$' $$plugin_files_var | string replace -- \~ ~) + source $file + if set --local name (string replace --regex -- '.+conf\.d/([^/]+)\.fish$' '$1' $file) + emit {$name}_$event + end + end + end + + command rm -rf $source_plugins + + if set --query _fisher_plugins[1] + set --local commit_plugins + + for plugin in $file_plugins + contains -- (string lower -- $plugin) (string lower -- $_fisher_plugins) && set --append commit_plugins $plugin + end + + for plugin in $_fisher_plugins + contains -- (string lower -- $plugin) (string lower -- $commit_plugins) || set --append commit_plugins $plugin + end + + string replace --regex -- $HOME \~ $commit_plugins >$fish_plugins + else + set --erase _fisher_plugins + command rm -f $fish_plugins + end + + set --local total (count $install_plugins) (count $update_plugins) (count $remove_plugins) + + test "$total" != "0 0 0" && echo (string join ", " ( + test $total[1] = 0 || echo "Installed $total[1]") ( + test $total[2] = 0 || echo "Updated $total[2]") ( + test $total[3] = 0 || echo "Removed $total[3]") + ) plugin/s + case \* + echo "fisher: Unknown command: \"$cmd\"" >&2 && return 1 + end +end + +if ! set --query _fisher_upgraded_to_4_4 + set --universal _fisher_upgraded_to_4_4 + if functions --query _fisher_list + set --query XDG_DATA_HOME[1] || set --local XDG_DATA_HOME ~/.local/share + command rm -rf $XDG_DATA_HOME/fisher + functions --erase _fisher_{list,plugin_parse} + fisher update >/dev/null 2>/dev/null + else + for var in (set --names | string match --entire --regex '^_fisher_.+_files$') + set $var (string replace -- ~ \~ $$var) + end + functions --erase _fisher_fish_postexec + end +end diff --git a/config/fish/functions/has_app.fish b/config/fish/functions/has_app.fish new file mode 100644 index 0000000..d09f507 --- /dev/null +++ b/config/fish/functions/has_app.fish @@ -0,0 +1,14 @@ +# @halostatue/fish-macos/functions/has_app.fish:v7.0.0 + +function has_app --description 'Returns true if the named application exists' + # Suppress these flags being passed to __macos_app_find + argparse a/all q/quiet -- $argv + or return 1 + + if not set --query argv[1] + echo >&2 Usage: (status function) APPNAME... + return 1 + end + + __macos_app_find --exact --quiet $argv +end diff --git a/config/fish/functions/has_cask.fish b/config/fish/functions/has_cask.fish new file mode 100644 index 0000000..00ad6f5 --- /dev/null +++ b/config/fish/functions/has_cask.fish @@ -0,0 +1,23 @@ +# @halostatue/fish-brew/functions/has_cask.fish:v3.2.1 + +function has_cask --description 'Test if the named cask or casks are installed' + command --query brew + or return 1 + + argparse --min-args 1 A/all -- $argv + or return 1 + + set --function found 0 + + for cask in $argv + if test -d (brew --prefix)/Caskroom/$cask + set found (math $found + 1) + end + end + + if set --query _flag_all + test $found -eq (count $argv) + else + test $found -ne 0 + end +end diff --git a/config/fish/functions/has_keg.fish b/config/fish/functions/has_keg.fish new file mode 100644 index 0000000..d3a3419 --- /dev/null +++ b/config/fish/functions/has_keg.fish @@ -0,0 +1,23 @@ +# @halostatue/fish-brew/functions/has_keg.fish:v3.2.1 + +function has_keg --description 'Test if the named keg or kegs are installed' + command --query brew + or return 1 + + argparse --min-args 1 A/all -- $argv + or return 1 + + set --function found 0 + + for keg in $argv + if test -d (brew --prefix)/Cellar/$keg + set found (math $found + 1) + end + end + + if set --query _flag_all + test $found -eq (count $argv) + else + test $found -ne 0 + end +end diff --git a/config/fish/functions/mac.fish b/config/fish/functions/mac.fish new file mode 100644 index 0000000..eeab524 --- /dev/null +++ b/config/fish/functions/mac.fish @@ -0,0 +1,68 @@ +# @halostatue/fish-macos/functions/mac.fish:v7.0.0 + +function mac --description 'Manage several macOS functions' + argparse --stop-nonopt h/help -- $argv + + if set --query _flag_help + echo 'Usage: mac [options] subcommand [arguments...] + +Manage several macOS functions. + +Subcommands: + airdrop Manages AirDrop. + airport Performs various WiFi (AirPort) operations + brightness Changes the screen brightness + flushdns Flushes the DNS cache + font-smoothing Enables or disables font smoothing + lsclean Cleans the LaunchServices registration list + mail Speed up Mail.app by vacuuming the envelope index + proxy-icon Enables or disables proxy icon delay + serialnumber Gets the machine serial number + touchid Manages Touch ID authorization for sudo + transparency Enables or disables interface transparency + version Shows the current macOS version + vol Controls the volume level + +Options: + -h, --help Show this help' + return 0 + end + + set --function subcommand (string lower -- $argv[1]) + set --erase argv[1] + + switch $subcommand + case airdrop + __macos_mac_airdrop $argv + case airport + __macos_mac_airport $argv + case flushdns + __macos_mac_flushdns $argv + case font-smoothing + __macos_mac_font_smoothing $argv + case lsclean + __macos_mac_lsclean $argv + case mail + __macos_mac_mail $argv + case proxy-icon + __macos_mac_proxy_icon $argv + case serialnumber + __macos_mac_serialnumber $argv + case touchid + __macos_mac_touchid $argv + case transparency + __macos_mac_transparency $argv + case vol + __macos_mac_vol $argv + case version + __macos_mac_version $argv + case '' + echo >&2 'mac: No command provided.' + mac --help >&2 + return 1 + case '*' + echo >&2 'mac: Unknown command.' + mac --help >&2 + return 1 + end +end diff --git a/config/fish/functions/manp.fish b/config/fish/functions/manp.fish new file mode 100644 index 0000000..9fd1637 --- /dev/null +++ b/config/fish/functions/manp.fish @@ -0,0 +1,77 @@ +# @halostatue/fish-macos/functions/manp.fish:v7.0.0 + +# Based on man2pdf.sh created by Pico Mitchell (of Random Applications) +# on 11/16/22, licensed under the MIT license. +function manp --description 'View a man page as a PDF' + set --function cache_path "/private/tmp/man PDFs" + + if set --query --universal manp_cache_path + set cache_path $manp_cache_path + end + + argparse --stop-nonopt h/help C/clear-cache -- $argv + + if set --query _flag_help + echo 'Usage: '(status function)' --help + '(status function)' --clear-cache + '(status function)' [section] [man page] + +Opens a macOS man page as a PDF. The generated PDFs are cached +in $manp_cache_path (/private/tmp/man PDFs). + +Use --clear-cache to clear the cached PDFs manually. By default +they will be cleared on any OS upgrade.' + return 0 + end + + if set --query _flag_clear_cache + /bin/rm -rf $cache_path + return $status + end + + set --function man_path (/usr/bin/man -w $argv 2> /dev/null) + + if test -f $man_path + # Save every man page PDF into a sub-folder for the current OS version + # (and build) since man pages can be updated between OS versions, and + # don't want to retrieve an old cached version from a previous OS + # (when not saving to a temporary location). + set --local os_path $cache_path"/"(/usr/bin/sw_vers -productVersion)" ("(/usr/bin/sw_vers -buildVersion)")" + + if not test -d $os_path + # If the man PDFs base path exists, but not the current OS sub- + # folder, that likely means that there has been an OS update + # since the last run, so clear the cache of the old man PDFs + # from the previous OS version by deleting the base path which + # will be re-created when the new latest OS sub-folder is + # created below. + if test -d $cache_path + /bin/rm -rf $cache_path + end + + /bin/mkdir -p $os_path + end + + set --local man_filename (path basename $man_path) + set --local man_section (path extension $man_filename | string replace . '') + set man_filename (string replace .$man_section '' $man_filename) + + if test $man_section != 1 + set man_filename $man_filename" ("$man_section")" + end + + set --local pdf_path $os_path/man" "$man_filename.pdf + + if not test -f $pdf_path + /usr/bin/mandoc -T pdf $man_path >$pdf_path + end + + if set --query $manp_pdf_app_name + /usr/bin/open -af $manp_pdf_app_name $pdf_path + else + /usr/bin/open $pdf_path + end + else + /usr/bin/man $argv + end +end diff --git a/config/fish/functions/note.fish b/config/fish/functions/note.fish new file mode 100644 index 0000000..92ec39d --- /dev/null +++ b/config/fish/functions/note.fish @@ -0,0 +1,38 @@ +# @halostatue/fish-macos/functions/note.fish:v7.0.0 + +function note --description 'Add a note to Notes.app' + is_mac 'mountain lion' + or return 1 + + has_app Notes + or return 1 + + if set --query argv + set --function text $argv + else + set --function text (cat - | sed -e 's/$/
/') + end + + test -z $text + or return 1 + + set --function head $text[1] + + if set --query text[2] + set --function body $text[2..-1] + end + + if set --query body + set --function properties '{name: "'$head'", body: "'($body[1..-1])'"}' + else + set --function properties '{name: "'$head'"}' + end + + echo 'tell application "Notes" + tell account "iCloud" + tell folder "Notes" + make new note with properties ' $properties ' + end tell + end tell +end tell' | osascript >/dev/null +end diff --git a/config/fish/functions/nvm.fish b/config/fish/functions/nvm.fish new file mode 100644 index 0000000..f86c75c --- /dev/null +++ b/config/fish/functions/nvm.fish @@ -0,0 +1,235 @@ +function nvm --description "Node version manager" + for silent in --silent -s + if set --local index (contains --index -- $silent $argv) + set --erase argv[$index] && break + end + set --erase silent + end + + set --local cmd $argv[1] + set --local ver $argv[2] + + if set --query silent && ! set --query cmd[1] + echo "nvm: Version number not specified (see nvm -h for usage)" >&2 + return 1 + end + + if ! set --query ver[1] && contains -- "$cmd" install use + for file in .nvmrc .node-version + set file (_nvm_find_up $PWD $file) && read ver <$file && break + end + + if ! set --query ver[1] + echo "nvm: Invalid version or missing \".nvmrc\" file" >&2 + return 1 + end + end + + set --local their_version $ver + + switch "$cmd" + case -v --version + echo "nvm, version 2.2.17" + case "" -h --help + echo "Usage: nvm install Download and activate the specified Node version" + echo " nvm install Install the version specified in the nearest .nvmrc file" + echo " nvm use Activate the specified Node version in the current shell" + echo " nvm use Activate the version specified in the nearest .nvmrc file" + echo " nvm list List installed Node versions" + echo " nvm list-remote List available Node versions to install" + echo " nvm list-remote List Node versions matching a given regex pattern" + echo " nvm current Print the currently-active Node version" + echo " nvm uninstall Uninstall the specified Node version" + echo "Options:" + echo " -s, --silent Suppress standard output" + echo " -v, --version Print the version of nvm" + echo " -h, --help Print this help message" + echo "Variables:" + echo " nvm_arch Override architecture, e.g. x64-musl" + echo " nvm_mirror Use a mirror for downloading Node binaries" + echo " nvm_default_version Set the default version for new shells" + echo " nvm_default_packages Install a list of packages every time a Node version is installed" + echo " nvm_data Set a custom directory for storing nvm data" + echo "Examples:" + echo " nvm install latest Install the latest version of Node" + echo " nvm use 14.15.1 Use Node version 14.15.1" + echo " nvm use system Activate the system's Node version" + + case install + _nvm_index_update + + string match --entire --regex -- (_nvm_version_match $ver) <$nvm_data/.index | read ver alias + + if ! set --query ver[1] + echo "nvm: Invalid version number or alias: \"$their_version\"" >&2 + return 1 + end + + if test ! -e $nvm_data/$ver + set --local os (command uname -s | string lower) + set --local ext tar.gz + set --local arch (command uname -m) + + switch $os + case aix + set arch ppc64 + case sunos + case linux + case darwin + case {MSYS_NT,MINGW\*_NT}\* + set os win + set ext zip + case \* + echo "nvm: Unsupported operating system: \"$os\"" >&2 + return 1 + end + + switch $arch + case i\*86 + set arch x86 + case x86_64 + set arch x64 + case arm64 + string match --regex --quiet "v(?\d+)" $ver + if test "$os" = darwin -a $major -lt 16 + set arch x64 + end + case armv6 armv6l + set arch armv6l + case armv7 armv7l + set arch armv7l + case armv8 armv8l aarch64 + set arch arm64 + end + + set --query nvm_arch && set arch $nvm_arch + + set --local dir "node-$ver-$os-$arch" + set --local url $nvm_mirror/$ver/$dir.$ext + + command mkdir -p $nvm_data/$ver + + if ! set --query silent + echo -e "Installing Node \x1b[1m$ver\x1b[22m $alias" + echo -e "Fetching \x1b[4m$url\x1b[24m\x1b[7m" + end + + if ! command curl -q $silent --progress-bar --location $url | + command tar --extract --gzip --directory $nvm_data/$ver 2>/dev/null + command rm -rf $nvm_data/$ver + echo -e "\033[F\33[2K\x1b[0mnvm: Invalid mirror or host unavailable: \"$url\"" >&2 + return 1 + end + + set --query silent || echo -en "\033[F\33[2K\x1b[0m" + + if test "$os" = win + command mv $nvm_data/$ver/$dir $nvm_data/$ver/bin + else + command mv $nvm_data/$ver/$dir/* $nvm_data/$ver + command rm -rf $nvm_data/$ver/$dir + end + end + + if test $ver != "$nvm_current_version" + set --query nvm_current_version && _nvm_version_deactivate $nvm_current_version + _nvm_version_activate $ver + + set --query nvm_default_packages[1] && npm install --global $silent $nvm_default_packages + end + + set --query silent || printf "Now using Node %s (npm %s) %s\n" (_nvm_node_info) + case use + test $ver = default && set ver $nvm_default_version + _nvm_list | string match --entire --regex -- (_nvm_version_match $ver) | read ver __ + + if ! set --query ver[1] + echo "nvm: Can't use Node \"$their_version\", version must be installed first" >&2 + return 1 + end + + if test $ver != "$nvm_current_version" + set --query nvm_current_version && _nvm_version_deactivate $nvm_current_version + test $ver != system && _nvm_version_activate $ver + end + + set --query silent || printf "Now using Node %s (npm %s) %s\n" (_nvm_node_info) + case uninstall + if test -z "$ver" + echo "nvm: Not enough arguments for command: \"$cmd\"" >&2 + return 1 + end + + test $ver = default && test ! -z "$nvm_default_version" && set ver $nvm_default_version + + _nvm_list | string match --entire --regex -- (_nvm_version_match $ver) | read ver __ + + if ! set -q ver[1] + echo "nvm: Node version not installed or invalid: \"$their_version\"" >&2 + return 1 + end + + set --query silent || printf "Uninstalling Node %s %s\n" $ver (string replace ~ \~ "$nvm_data/$ver/bin/node") + + _nvm_version_deactivate $ver + + command rm -rf $nvm_data/$ver + case current + _nvm_current + case ls list + _nvm_list | _nvm_list_format (_nvm_current) $argv[2] + case lsr {ls,list}-remote + _nvm_index_update || return + _nvm_list | command awk ' + FILENAME == "-" && (is_local[$1] = FNR == NR) { next } { + print $0 (is_local[$1] ? " ✓" : "") + } + ' - $nvm_data/.index | _nvm_list_format (_nvm_current) $argv[2] + case \* + echo "nvm: Unknown command or option: \"$cmd\" (see nvm -h for usage)" >&2 + return 1 + end +end + +function _nvm_find_up --argument-names path file + test -e "$path/$file" && echo $path/$file || begin + test ! -z "$path" || return + _nvm_find_up (string replace --regex -- '/[^/]*$' "" $path) $file + end +end + +function _nvm_version_match --argument-names ver + string replace --regex -- '^v?(\d+|\d+\.\d+)$' 'v$1.' $ver | + string replace --filter --regex -- '^v?(\d+)' 'v$1' | + string escape --style=regex || string lower '\b'$ver'(?:/\w+)?$' +end + +function _nvm_list_format --argument-names current regex + command awk -v current="$current" -v regex="$regex" ' + $0 ~ regex { + aliases[versions[i++] = $1] = $2 " " $3 + pad = (n = length($1)) > pad ? n : pad + } + END { + if (!i) exit 1 + while (i--) + printf((current == versions[i] ? " ▶ " : " ") "%"pad"s %s\n", + versions[i], aliases[versions[i]]) + } + ' +end + +function _nvm_current + command --search --quiet node || return + set --query nvm_current_version && echo $nvm_current_version || echo system +end + +function _nvm_node_info + set --local npm_path (string replace bin/npm-cli.js "" (realpath (command --search npm))) + test -f $npm_path/package.json || set --local npm_version_default (command npm --version) + command node --eval " + console.log(process.version) + console.log('$npm_version_default' ? '$npm_version_default': require('$npm_path/package.json').version) + console.log(process.execPath) + " | string replace -- ~ \~ +end diff --git a/config/fish/functions/paths.fish b/config/fish/functions/paths.fish new file mode 100644 index 0000000..09eccfd --- /dev/null +++ b/config/fish/functions/paths.fish @@ -0,0 +1,175 @@ +function ___paths_plugin_wrap_color + set_color normal + set_color "$argv[1]" + echo -n (set_color "$argv[1]")"$argv[2..]" + set_color normal +end + +# duplicated in conf.d +function ___paths_plugin_set_colors + if not set -q ___paths_plugin_colors + set -Ux ___paths_plugin_colors 27e6ff 29e0ff 5cd8ff 77d0ff 8ac8ff 9cbfff afb5ff c5a7ff d99bfe ea8feb f684d5 fe7abd ff73a3 ff708a fa7070 ff708a ff73a3 fe7abd f684d5 ea8feb d99bfe c5a7ff afb5ff 9cbfff 8ac8ff 77d0ff 5cd8ff 29e0ff + end + return 0 +end + +function ___paths_plugin_cycle_color + if not set -q ___paths_plugin_current_color + set -Ux ___paths_plugin_current_color 1 + else if test $___paths_plugin_current_color -gt (count $___paths_plugin_colors) + set -Ux ___paths_plugin_current_color 1 + end + echo $___paths_plugin_colors[$___paths_plugin_current_color] + set -Ux ___paths_plugin_current_color (math $___paths_plugin_current_color + 1) +end + +function ___paths_plugin_handle_found_item -a testName outFlags + set -f flags (string split -n ' ' -- "$outFlags") + set -f options (fish_opt -s c -l clean) + set -a options (fish_opt -s s -l single) + set -a options (fish_opt -s k -l no-color) + set -a options (fish_opt -s n -l inline) + argparse $options -- $flags + + set -f arrow "=>" + # check if file exists + if test -e "$testName" + set -f nameOut (string trim -- "$testName") + if not set -q _flag_c # is not clean + if test -L "$testName" # is symlink + set -f __linkname (readlink -f "$testName") + set __linkname (string trim -- "$__linkname") + set testName (string trim -- "$testName") + if not set -q _flag_k # is color + set nameOut (___paths_plugin_wrap_color (___paths_plugin_cycle_color) $testName) (___paths_plugin_wrap_color "yellow" "$arrow") (___paths_plugin_wrap_color (___paths_plugin_cycle_color) $__linkname) + else # is color + set nameOut (echo -n "$testName" "$arrow" "$__linkname") + end + else # is not symlink + if not set -q _flag_k # is color + set testName (string trim -- "$testName") + set nameOut (___paths_plugin_wrap_color (___paths_plugin_cycle_color) "$testName") + else + set testName (string trim -- "$testName") + set nameOut "$testName" + end + end + + set nameOut (string trim -- "$nameOut") + # do the tick + if set -q _flag_k # is not color + set nameOut "- $nameOut" + else # is color + set nameOut (___paths_plugin_wrap_color "yellow" "-") "$nameOut" + end + end + set nameOut (string trim -- "$nameOut") + echo -n $nameOut + end +end + +function paths --description "Reveal the executable matches in shell paths or fish autoload." + set -f options (fish_opt -s c -l clean) + set -a options (fish_opt -s s -l single) + set -a options (fish_opt -s k -l no-color) + set -a options (fish_opt -s q -l quiet) + set -a options (fish_opt -s n -l inline) + argparse $options -- $argv + + if test (count $argv) -lt 1 + echo "paths - executable matches in shell paths or fish autoload." + and echo "usage: paths [-c|-s|-k] " + and echo -e "\t-c or --no-color: output without color" + and echo -e "\t-s or --single: output without color or headers, the first result" + and echo -e "\t-k or --clean: output without tick marks or headers" + # and echo -e "\t-n or --inline: output without endline" + and return 1 + end + + set -f foundStatus 1 + set -f input (string trim -- $argv) + # deprecated + if set -q _flag_q + set _flag_c True + end + + if set -q _flag_s + set _flag_k True + set _flag_c True + end + + set -f outFlags '' + set -q _flag_n; and set -a outFlags -n + set -q _flag_c; and set -a outFlags -c + set -q _flag_k; and set -a outFlags -k + set -q _flag_s; and set -a outFlags -s + set outFlags (string split -n " " -- "$outFlags") + ___paths_plugin_set_colors + # loop over list of path lists + for pVar in VIRTUAL_ENV fisher_path fish_function_path fish_user_paths PATH + set -e acc + set -f acc '' + set -e hit + # see if variable is empty + if test -z "$pVar" + continue + end + set -f acc (begin + for t in $$pVar + for snit in "$t/$input.fish" "$t/$input" + set -f found (___paths_plugin_handle_found_item "$snit" "$outFlags") + set found (string trim -- "$found") + if test -n "$found" + set -f hit True + echo "$found" + if set -q _flag_s + break + end + end + end + if set -q _flag_s + if set -q hit + break + end + end + end + end) + + # prepend source + if not set -q _flag_c + if set -q hit + set pVar (string trim -- "$pVar") + echo -e -n "$pVar\n" + end + end + + if test -n "$acc" + set foundStatus 0 + for fk in $acc + echo $fk + if set -q _flag_s + # stop after one + return $foundStatus + end + end + end + end + + # check + set -l built (type --type $input 12&>/dev/null) + if test -n "$built" + and test "$built" = 'builtin' + set $foundStatus 0 + if not set -q _flag_c + echo -e -n "builtin\n" + if set -q _flag_k + echo - "$input" + else # is color + echo (___paths_plugin_wrap_color "yellow" "-") (___paths_plugin_wrap_color (___paths_plugin_cycle_color) "$input") + end + else + echo "$input" + end + end + return $foundStatus +end diff --git a/config/fish/functions/ql.fish b/config/fish/functions/ql.fish new file mode 100644 index 0000000..5cde1ab --- /dev/null +++ b/config/fish/functions/ql.fish @@ -0,0 +1,20 @@ +# @halostatue/fish-macos/functions/ql.fish:v7.0.0 + +function ql --description 'QuickLook a file or directory' + # Updated based on https://gist.github.com/chockenberry/13c15466417b88e40f23e58df8091dac + if set --query argv[1] + qlmanage -p $argv >/dev/null 2>/dev/null + else + set --function root (mktemp -d) + command cat >$root/ql.stdin + set --function mime_type (file --brief --mime-type $root/ql.stdin) + set --function extension (grep $mime_type /etc/apache2/mime.types | awk '{ print $2; }') + + if test -z $extension + qlmanage -p $root/ql.stdin >/dev/null 2>/dev/null + else + mv $root/ql.{stdin,$extension} + qlmanage -p $root/ql.$extension >/dev/null 2>/dev/null + end + end +end diff --git a/config/fish/functions/remind.fish b/config/fish/functions/remind.fish new file mode 100644 index 0000000..084d055 --- /dev/null +++ b/config/fish/functions/remind.fish @@ -0,0 +1,26 @@ +# @halostatue/fish-macos/functions/remind.fish:v7.0.0 + +function remind --description 'Add a reminder to Reminders.app' + is_mac 'mountain lion' + or return 1 + + has_app Reminders + or return 1 + + if set --query argv + set --function text $argv + else + set --function text (cat - | sed -e 's/$/
/') + end + + test -z $text + and return 0 + + echo $text : text + + echo 'tell application "Reminders" + tell the default list + make new reminder with properties {name: "'$text'"} + end tell +end tell' | osascript >/dev/null +end diff --git a/config/fish/functions/tide.fish b/config/fish/functions/tide.fish new file mode 100644 index 0000000..092a722 --- /dev/null +++ b/config/fish/functions/tide.fish @@ -0,0 +1,28 @@ +function tide --description 'Manage your Tide prompt' + argparse --stop-nonopt v/version h/help -- $argv + + if set -q _flag_version + echo 'tide, version 6.1.1' + else if set -q _flag_help + _tide_help + else if functions --query _tide_sub_$argv[1] + _tide_sub_$argv[1] $argv[2..] + else + _tide_help + return 1 + end +end + +function _tide_help + printf %s\n \ + 'Usage: tide [options] subcommand [options]' \ + '' \ + 'Options:' \ + ' -v or --version print tide version number' \ + ' -h or --help print this help message' \ + '' \ + 'Subcommands:' \ + ' configure run interactive configuration wizard' \ + ' reload reload tide configuration' \ + ' bug-report print info for use in bug reports' +end diff --git a/config/fish/functions/tide/configure/choices/all/finish.fish b/config/fish/functions/tide/configure/choices/all/finish.fish new file mode 100644 index 0000000..f670b1e --- /dev/null +++ b/config/fish/functions/tide/configure/choices/all/finish.fish @@ -0,0 +1,46 @@ +function finish + _tide_title Finish + + echo + set_color red + _tide_option y 'Overwrite your current tide config' + set_color normal + echo + + _tide_option p 'Exit and print the config you just generated' + echo + + _tide_menu (status function) + switch $_tide_selected_option + case 'Overwrite your current tide config' + _tide_finish + command -q clear && clear + set -q _flag_auto || _tide_print_configure_current_options + case 'Exit and print the config you just generated' + _tide_exit_configure + command -q clear && clear + _tide_print_configure_current_options + end +end + +function _tide_finish + _tide_exit_configure + + # Deal with prompt char/vi mode + contains character $fake_tide_left_prompt_items || set -p fake_tide_left_prompt_items vi_mode + + # Set the real variables + for fakeVar in (set --names | string match -r "^fake_tide.*") + set -U (string replace 'fake_' '' $fakeVar) $$fakeVar + end + + # Make sure old prompt won't display + set -e $_tide_prompt_var 2>/dev/null + + # Re-initialize the prompt + tide reload +end + +function _tide_print_configure_current_options + _tide_fish_colorize "tide configure --auto $_tide_configure_current_options" +end diff --git a/config/fish/functions/tide/configure/choices/all/icons.fish b/config/fish/functions/tide/configure/choices/all/icons.fish new file mode 100644 index 0000000..be167bb --- /dev/null +++ b/config/fish/functions/tide/configure/choices/all/icons.fish @@ -0,0 +1,33 @@ +function icons + _tide_title Icons + + _tide_option 1 'Few icons' + _tide_display_prompt + + _tide_option 2 'Many icons' + _enable_icons + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case 'Few icons' + _disable_icons + end + _next_choice all/transient +end + +function _enable_icons + set -p fake_tide_left_prompt_items os + set -g fake_tide_pwd_icon  + set -g fake_tide_pwd_icon_home  + set -g fake_tide_cmd_duration_icon  + set -g fake_tide_git_icon  +end + +function _disable_icons + _tide_find_and_remove os fake_tide_left_prompt_items + set fake_tide_pwd_icon + set fake_tide_pwd_icon_home + set fake_tide_cmd_duration_icon + set fake_tide_git_icon +end diff --git a/config/fish/functions/tide/configure/choices/all/prompt_colors.fish b/config/fish/functions/tide/configure/choices/all/prompt_colors.fish new file mode 100644 index 0000000..247ef4e --- /dev/null +++ b/config/fish/functions/tide/configure/choices/all/prompt_colors.fish @@ -0,0 +1,26 @@ +function prompt_colors + _tide_title 'Prompt Colors' + + _tide_option 1 'True color' + _tide_display_prompt + + _tide_option 2 '16 colors' + _load_config "$_tide_configure_style"_16color + set -g _tide_16color true + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case 'True color' + _load_config "$_tide_configure_style" + set -e _tide_16color + switch $_tide_configure_style + case lean rainbow + _next_choice all/show_time + case classic + _next_choice classic/classic_prompt_color + end + case '16 colors' + _next_choice all/show_time + end +end diff --git a/config/fish/functions/tide/configure/choices/all/prompt_connection.fish b/config/fish/functions/tide/configure/choices/all/prompt_connection.fish new file mode 100644 index 0000000..ff76546 --- /dev/null +++ b/config/fish/functions/tide/configure/choices/all/prompt_connection.fish @@ -0,0 +1,31 @@ +function prompt_connection + _tide_title 'Prompt Connection' + + _tide_option 1 Disconnected + set -g fake_tide_prompt_icon_connection ' ' + _tide_display_prompt + + _tide_option 2 Dotted + set -g fake_tide_prompt_icon_connection '·' + _tide_display_prompt + + _tide_option 3 Solid + set -g fake_tide_prompt_icon_connection '─' + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case Disconnected + set -g fake_tide_prompt_icon_connection ' ' + case Dotted + set -g fake_tide_prompt_icon_connection '·' + case Solid + set -g fake_tide_prompt_icon_connection '─' + end + switch $_tide_configure_style + case lean + _next_choice all/prompt_connection_andor_frame_color + case classic rainbow + _next_choice powerline/powerline_right_prompt_frame + end +end diff --git a/config/fish/functions/tide/configure/choices/all/prompt_connection_andor_frame_color.fish b/config/fish/functions/tide/configure/choices/all/prompt_connection_andor_frame_color.fish new file mode 100644 index 0000000..cefbf2c --- /dev/null +++ b/config/fish/functions/tide/configure/choices/all/prompt_connection_andor_frame_color.fish @@ -0,0 +1,40 @@ +function prompt_connection_andor_frame_color + if test "$_tide_16color" = true || + test "$fake_tide_left_prompt_frame_enabled" = false -a \ + "$fake_tide_right_prompt_frame_enabled" = false -a \ + "$fake_tide_prompt_icon_connection" = ' ' + _next_choice all/prompt_spacing + return 0 + end + + _tide_title "Connection & Frame Color" + + _tide_option 1 Lightest + set -g fake_tide_prompt_color_frame_and_connection 808080 + _tide_display_prompt + + _tide_option 2 Light + set -g fake_tide_prompt_color_frame_and_connection 6C6C6C + _tide_display_prompt + + _tide_option 3 Dark + set -g fake_tide_prompt_color_frame_and_connection 585858 + _tide_display_prompt + + _tide_option 4 Darkest + set -g fake_tide_prompt_color_frame_and_connection 444444 + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case Lightest + set -g fake_tide_prompt_color_frame_and_connection 808080 + case Light + set -g fake_tide_prompt_color_frame_and_connection 6C6C6C + case Dark + set -g fake_tide_prompt_color_frame_and_connection 585858 + case Darkest + set -g fake_tide_prompt_color_frame_and_connection 444444 + end + _next_choice all/prompt_spacing +end diff --git a/config/fish/functions/tide/configure/choices/all/prompt_spacing.fish b/config/fish/functions/tide/configure/choices/all/prompt_spacing.fish new file mode 100644 index 0000000..f68be68 --- /dev/null +++ b/config/fish/functions/tide/configure/choices/all/prompt_spacing.fish @@ -0,0 +1,22 @@ +function prompt_spacing + _tide_title 'Prompt Spacing' + + _tide_option 1 Compact + set -g fake_tide_prompt_add_newline_before false + _tide_display_prompt + _tide_display_prompt + + _tide_option 2 Sparse + set -g fake_tide_prompt_add_newline_before true + _tide_display_prompt + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case Compact + set -g fake_tide_prompt_add_newline_before false + case Sparse + set -g fake_tide_prompt_add_newline_before true + end + _next_choice all/icons +end diff --git a/config/fish/functions/tide/configure/choices/all/show_time.fish b/config/fish/functions/tide/configure/choices/all/show_time.fish new file mode 100644 index 0000000..b66c785 --- /dev/null +++ b/config/fish/functions/tide/configure/choices/all/show_time.fish @@ -0,0 +1,33 @@ +function show_time + _tide_title 'Show current time?' + + _tide_option 1 No + _tide_display_prompt + + set -a fake_tide_right_prompt_items time + + _tide_option 2 '24-hour format' + set -g fake_tide_time_format %T + _tide_display_prompt + + _tide_option 3 '12-hour format' + set -g fake_tide_time_format %r + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case No + set -g fake_tide_time_format '' + set -e fake_tide_right_prompt_items[-1] + case '24-hour format' + set -g fake_tide_time_format %T + case '12-hour format' + set -g fake_tide_time_format %r + end + switch $_tide_configure_style + case lean + _next_choice "$_tide_configure_style"/"$_tide_configure_style"_prompt_height + case classic rainbow + _next_choice "$_tide_configure_style"/"$_tide_configure_style"_prompt_separators + end +end diff --git a/config/fish/functions/tide/configure/choices/all/style.fish b/config/fish/functions/tide/configure/choices/all/style.fish new file mode 100644 index 0000000..fe9a58f --- /dev/null +++ b/config/fish/functions/tide/configure/choices/all/style.fish @@ -0,0 +1,36 @@ +function style + set -g _tide_configure_current_options + + _tide_title 'Prompt Style' + + _tide_option 1 Lean + _load_config lean + _tide_display_prompt + + _tide_option 2 Classic + _load_config classic + _tide_display_prompt + + _tide_option 3 Rainbow + _load_config rainbow + _tide_display_prompt + + _tide_menu (status function) --no-restart + switch $_tide_selected_option + case Lean + _load_config lean + set -g _tide_configure_style lean + case Classic + _load_config classic + set -g _tide_configure_style classic + case Rainbow + _load_config rainbow + set -g _tide_configure_style rainbow + end + _next_choice all/prompt_colors +end + +function _load_config -a name + string replace -r '^' 'set -g fake_' <(status dirname)/../../icons.fish | source + string replace -r '^' 'set -g fake_' <(status dirname)/../../configs/$name.fish | source +end diff --git a/config/fish/functions/tide/configure/choices/all/transient.fish b/config/fish/functions/tide/configure/choices/all/transient.fish new file mode 100644 index 0000000..df2b6b6 --- /dev/null +++ b/config/fish/functions/tide/configure/choices/all/transient.fish @@ -0,0 +1,22 @@ +function transient + _tide_title 'Enable transient prompt?' + + _tide_option 1 No + _tide_display_prompt + _tide_display_prompt + _tide_display_prompt + + _tide_option 2 Yes + _configure_transient= _tide_display_prompt + _configure_transient= _tide_display_prompt + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case No + set fake_tide_prompt_transient_enabled false + case Yes + set fake_tide_prompt_transient_enabled true + end + _next_choice all/finish +end diff --git a/config/fish/functions/tide/configure/choices/classic/classic_prompt_color.fish b/config/fish/functions/tide/configure/choices/classic/classic_prompt_color.fish new file mode 100644 index 0000000..77ceeaf --- /dev/null +++ b/config/fish/functions/tide/configure/choices/classic/classic_prompt_color.fish @@ -0,0 +1,38 @@ +function classic_prompt_color + _tide_title 'Prompt Color' + + _tide_option 1 Lightest + _set_all_items_bg_color 585858 + _tide_display_prompt + + _tide_option 2 Light + _set_all_items_bg_color 444444 + _tide_display_prompt + + _tide_option 3 Dark + _set_all_items_bg_color 303030 + _tide_display_prompt + + _tide_option 4 Darkest + _set_all_items_bg_color 1C1C1C + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case Lightest + _set_all_items_bg_color 585858 + case Light + _set_all_items_bg_color 444444 + case Dark + _set_all_items_bg_color 303030 + case Darkest + _set_all_items_bg_color 1C1C1C + end + _next_choice all/show_time +end + +function _set_all_items_bg_color -a color + for var in (set --names | string match -r "fake_.*_bg_color.*") + set $var $color + end +end diff --git a/config/fish/functions/tide/configure/choices/classic/classic_prompt_separators.fish b/config/fish/functions/tide/configure/choices/classic/classic_prompt_separators.fish new file mode 100644 index 0000000..20af6cd --- /dev/null +++ b/config/fish/functions/tide/configure/choices/classic/classic_prompt_separators.fish @@ -0,0 +1,40 @@ +function classic_prompt_separators + _tide_title 'Prompt Separators' + + _tide_option 1 Angled + set -g fake_tide_left_prompt_separator_same_color  + set -g fake_tide_right_prompt_separator_same_color  + _tide_display_prompt + + _tide_option 2 Vertical + set -g fake_tide_left_prompt_separator_same_color │ + set -g fake_tide_right_prompt_separator_same_color │ + _tide_display_prompt + + _tide_option 3 Slanted + set -g fake_tide_left_prompt_separator_same_color ╱ + set -g fake_tide_right_prompt_separator_same_color ╱ + _tide_display_prompt + + _tide_option 4 Round + set -g fake_tide_left_prompt_separator_same_color  + set -g fake_tide_right_prompt_separator_same_color  + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case Angled + set -g fake_tide_left_prompt_separator_same_color  + set -g fake_tide_right_prompt_separator_same_color  + case Vertical + set -g fake_tide_left_prompt_separator_same_color │ + set -g fake_tide_right_prompt_separator_same_color │ + case Slanted + set -g fake_tide_left_prompt_separator_same_color ╱ + set -g fake_tide_right_prompt_separator_same_color ╱ + case Round + set -g fake_tide_left_prompt_separator_same_color  + set -g fake_tide_right_prompt_separator_same_color  + end + _next_choice powerline/powerline_prompt_heads +end diff --git a/config/fish/functions/tide/configure/choices/lean/lean_prompt_height.fish b/config/fish/functions/tide/configure/choices/lean/lean_prompt_height.fish new file mode 100644 index 0000000..2077241 --- /dev/null +++ b/config/fish/functions/tide/configure/choices/lean/lean_prompt_height.fish @@ -0,0 +1,26 @@ +function lean_prompt_height + _tide_title 'Prompt Height' + + _tide_option 1 'One line' + _tide_find_and_remove newline fake_tide_left_prompt_items + set -g fake_tide_left_prompt_suffix '' + _tide_display_prompt + + _tide_option 2 'Two lines' + set -g fake_tide_left_prompt_items $fake_tide_left_prompt_items[1..-2] newline $fake_tide_left_prompt_items[-1] + set -g fake_tide_left_prompt_suffix ' ' + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case 'One line' + _tide_find_and_remove newline fake_tide_left_prompt_items + set fake_tide_left_prompt_suffix '' + _next_choice all/prompt_connection_andor_frame_color + case 'Two lines' + _tide_find_and_remove newline fake_tide_left_prompt_items + set -g fake_tide_left_prompt_items $fake_tide_left_prompt_items[1..-2] newline $fake_tide_left_prompt_items[-1] + set -g fake_tide_left_prompt_suffix ' ' + _next_choice all/prompt_connection + end +end diff --git a/config/fish/functions/tide/configure/choices/powerline/powerline_prompt_heads.fish b/config/fish/functions/tide/configure/choices/powerline/powerline_prompt_heads.fish new file mode 100644 index 0000000..0030cad --- /dev/null +++ b/config/fish/functions/tide/configure/choices/powerline/powerline_prompt_heads.fish @@ -0,0 +1,32 @@ +function powerline_prompt_heads + _tide_title 'Prompt Heads' + + _tide_option 1 Sharp + set -g fake_tide_left_prompt_suffix  + set -g fake_tide_right_prompt_prefix  + _tide_display_prompt + + _tide_option 2 Slanted + set -g fake_tide_left_prompt_suffix  + set -g fake_tide_right_prompt_prefix  + _tide_display_prompt + + _tide_option 3 Round + set -g fake_tide_left_prompt_suffix  + set -g fake_tide_right_prompt_prefix  + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case Sharp + set -g fake_tide_left_prompt_suffix  + set -g fake_tide_right_prompt_prefix  + case Slanted + set -g fake_tide_left_prompt_suffix  + set -g fake_tide_right_prompt_prefix  + case Round + set -g fake_tide_left_prompt_suffix  + set -g fake_tide_right_prompt_prefix  + end + _next_choice powerline/powerline_prompt_tails +end diff --git a/config/fish/functions/tide/configure/choices/powerline/powerline_prompt_style.fish b/config/fish/functions/tide/configure/choices/powerline/powerline_prompt_style.fish new file mode 100644 index 0000000..b374757 --- /dev/null +++ b/config/fish/functions/tide/configure/choices/powerline/powerline_prompt_style.fish @@ -0,0 +1,51 @@ +function powerline_prompt_style + _tide_title 'Powerline Prompt Style' + + _tide_option 1 'One line' + _tide_find_and_remove newline fake_tide_left_prompt_items + _tide_find_and_remove character fake_tide_left_prompt_items + set fake_tide_left_prompt_frame_enabled false + set fake_tide_right_prompt_frame_enabled false + _tide_display_prompt + + set -a fake_tide_left_prompt_items newline + + _tide_option 2 'Two lines, character' + set -a fake_tide_left_prompt_items character + set fake_tide_left_prompt_frame_enabled false + set fake_tide_right_prompt_frame_enabled false + _tide_display_prompt + + _tide_option 3 'Two lines, frame' + _tide_find_and_remove character fake_tide_left_prompt_items + set fake_tide_left_prompt_frame_enabled true + set fake_tide_right_prompt_frame_enabled true + _tide_display_prompt + + _tide_option 4 'Two lines, character and frame' + set -a fake_tide_left_prompt_items character + set fake_tide_left_prompt_frame_enabled true + set fake_tide_right_prompt_frame_enabled true + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case 'One line' + _tide_find_and_remove newline fake_tide_left_prompt_items + _tide_find_and_remove character fake_tide_left_prompt_items + set fake_tide_left_prompt_frame_enabled false + set fake_tide_right_prompt_frame_enabled false + _next_choice all/prompt_connection_andor_frame_color + case 'Two lines, character' + set fake_tide_left_prompt_frame_enabled false + set fake_tide_right_prompt_frame_enabled false + _next_choice all/prompt_connection + case 'Two lines, frame' + _tide_find_and_remove character fake_tide_left_prompt_items + set fake_tide_left_prompt_frame_enabled true + set fake_tide_right_prompt_frame_enabled true + _next_choice all/prompt_connection + case 'Two lines, character and frame' + _next_choice all/prompt_connection + end +end diff --git a/config/fish/functions/tide/configure/choices/powerline/powerline_prompt_tails.fish b/config/fish/functions/tide/configure/choices/powerline/powerline_prompt_tails.fish new file mode 100644 index 0000000..6b1574b --- /dev/null +++ b/config/fish/functions/tide/configure/choices/powerline/powerline_prompt_tails.fish @@ -0,0 +1,40 @@ +function powerline_prompt_tails + _tide_title 'Prompt Tails' + + _tide_option 1 Flat + set -g fake_tide_left_prompt_prefix '' + set -g fake_tide_right_prompt_suffix '' + _tide_display_prompt + + _tide_option 2 Sharp + set -g fake_tide_left_prompt_prefix  + set -g fake_tide_right_prompt_suffix  + _tide_display_prompt + + _tide_option 3 Slanted + set -g fake_tide_left_prompt_prefix  + set -g fake_tide_right_prompt_suffix  + _tide_display_prompt + + _tide_option 4 Round + set -g fake_tide_left_prompt_prefix  + set -g fake_tide_right_prompt_suffix  + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case Flat + set -g fake_tide_left_prompt_prefix '' + set -g fake_tide_right_prompt_suffix '' + case Sharp + set -g fake_tide_left_prompt_prefix  + set -g fake_tide_right_prompt_suffix  + case Slanted + set -g fake_tide_left_prompt_prefix  + set -g fake_tide_right_prompt_suffix  + case Round + set -g fake_tide_left_prompt_prefix  + set -g fake_tide_right_prompt_suffix  + end + _next_choice powerline/powerline_prompt_style +end diff --git a/config/fish/functions/tide/configure/choices/powerline/powerline_right_prompt_frame.fish b/config/fish/functions/tide/configure/choices/powerline/powerline_right_prompt_frame.fish new file mode 100644 index 0000000..a2d0a5b --- /dev/null +++ b/config/fish/functions/tide/configure/choices/powerline/powerline_right_prompt_frame.fish @@ -0,0 +1,20 @@ +function powerline_right_prompt_frame + _tide_title 'Right Prompt Frame' + + _tide_option 1 No + set fake_tide_right_prompt_frame_enabled false + _tide_display_prompt + + _tide_option 2 Yes + set fake_tide_right_prompt_frame_enabled true + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case No + set fake_tide_right_prompt_frame_enabled false + case Yes + set fake_tide_right_prompt_frame_enabled true + end + _next_choice all/prompt_connection_andor_frame_color +end diff --git a/config/fish/functions/tide/configure/choices/rainbow/rainbow_prompt_separators.fish b/config/fish/functions/tide/configure/choices/rainbow/rainbow_prompt_separators.fish new file mode 100644 index 0000000..14b9319 --- /dev/null +++ b/config/fish/functions/tide/configure/choices/rainbow/rainbow_prompt_separators.fish @@ -0,0 +1,40 @@ +function rainbow_prompt_separators + _tide_title 'Prompt Separators' + + _tide_option 1 Angled + set -g fake_tide_left_prompt_separator_diff_color  + set -g fake_tide_right_prompt_separator_diff_color  + _tide_display_prompt + + _tide_option 2 Vertical + set -g fake_tide_left_prompt_separator_diff_color '' + set -g fake_tide_right_prompt_separator_diff_color '' + _tide_display_prompt + + _tide_option 3 Slanted + set -g fake_tide_left_prompt_separator_diff_color '' + set -g fake_tide_right_prompt_separator_diff_color '' + _tide_display_prompt + + _tide_option 4 Round + set -g fake_tide_left_prompt_separator_diff_color '' + set -g fake_tide_right_prompt_separator_diff_color '' + _tide_display_prompt + + _tide_menu (status function) + switch $_tide_selected_option + case Angled + set -g fake_tide_left_prompt_separator_diff_color  + set -g fake_tide_right_prompt_separator_diff_color  + case Vertical + set -g fake_tide_left_prompt_separator_diff_color '' + set -g fake_tide_right_prompt_separator_diff_color '' + case Slanted + set -g fake_tide_left_prompt_separator_diff_color '' + set -g fake_tide_right_prompt_separator_diff_color '' + case Round + set -g fake_tide_left_prompt_separator_diff_color '' + set -g fake_tide_right_prompt_separator_diff_color '' + end + _next_choice powerline/powerline_prompt_heads +end diff --git a/config/fish/functions/tide/configure/configs/classic.fish b/config/fish/functions/tide/configure/configs/classic.fish new file mode 100644 index 0000000..8973cbc --- /dev/null +++ b/config/fish/functions/tide/configure/configs/classic.fish @@ -0,0 +1,116 @@ +tide_aws_bg_color 444444 +tide_aws_color FF9900 +tide_character_color $_tide_color_green +tide_character_color_failure FF0000 +tide_cmd_duration_bg_color 444444 +tide_cmd_duration_color 87875F +tide_cmd_duration_decimals 0 +tide_cmd_duration_threshold 3000 +tide_context_always_display false +tide_context_bg_color 444444 +tide_context_color_default D7AF87 +tide_context_color_root $_tide_color_gold +tide_context_color_ssh D7AF87 +tide_context_hostname_parts 1 +tide_crystal_bg_color 444444 +tide_crystal_color FFFFFF +tide_direnv_bg_color 444444 +tide_direnv_bg_color_denied 444444 +tide_direnv_color $_tide_color_gold +tide_direnv_color_denied FF0000 +tide_distrobox_bg_color 444444 +tide_distrobox_color FF00FF +tide_docker_bg_color 444444 +tide_docker_color 2496ED +tide_docker_default_contexts default colima +tide_elixir_bg_color 444444 +tide_elixir_color 4E2A8E +tide_gcloud_bg_color 444444 +tide_gcloud_color 4285F4 +tide_git_bg_color 444444 +tide_git_bg_color_unstable 444444 +tide_git_bg_color_urgent 444444 +tide_git_color_branch $_tide_color_green +tide_git_color_conflicted FF0000 +tide_git_color_dirty $_tide_color_gold +tide_git_color_operation FF0000 +tide_git_color_staged $_tide_color_gold +tide_git_color_stash $_tide_color_green +tide_git_color_untracked $_tide_color_light_blue +tide_git_color_upstream $_tide_color_green +tide_git_truncation_length 24 +tide_git_truncation_strategy +tide_go_bg_color 444444 +tide_go_color 00ACD7 +tide_java_bg_color 444444 +tide_java_color ED8B00 +tide_jobs_bg_color 444444 +tide_jobs_color $_tide_color_dark_green +tide_jobs_number_threshold 1000 +tide_kubectl_bg_color 444444 +tide_kubectl_color 326CE5 +tide_left_prompt_frame_enabled true +tide_left_prompt_items pwd git newline +tide_left_prompt_prefix '' +tide_left_prompt_separator_diff_color  +tide_left_prompt_separator_same_color  +tide_left_prompt_suffix  +tide_nix_shell_bg_color 444444 +tide_nix_shell_color 7EBAE4 +tide_node_bg_color 444444 +tide_node_color 44883E +tide_os_bg_color 444444 +tide_os_color EEEEEE +tide_php_bg_color 444444 +tide_php_color 617CBE +tide_private_mode_bg_color 444444 +tide_private_mode_color FFFFFF +tide_prompt_add_newline_before true +tide_prompt_color_frame_and_connection 6C6C6C +tide_prompt_color_separator_same_color 949494 +tide_prompt_min_cols 34 +tide_prompt_pad_items true +tide_prompt_transient_enabled false +tide_pulumi_bg_color 444444 +tide_pulumi_color F7BF2A +tide_pwd_bg_color 444444 +tide_pwd_color_anchors $_tide_color_light_blue +tide_pwd_color_dirs $_tide_color_dark_blue +tide_pwd_color_truncated_dirs 8787AF +tide_pwd_markers .bzr .citc .git .hg .node-version .python-version .ruby-version .shorten_folder_marker .svn .terraform Cargo.toml composer.json CVS go.mod package.json build.zig +tide_python_bg_color 444444 +tide_python_color 00AFAF +tide_right_prompt_frame_enabled true +tide_right_prompt_items status cmd_duration context jobs direnv node python rustc java php pulumi ruby go gcloud kubectl distrobox toolbox terraform aws nix_shell crystal elixir zig +tide_right_prompt_prefix  +tide_right_prompt_separator_diff_color  +tide_right_prompt_separator_same_color  +tide_right_prompt_suffix '' +tide_ruby_bg_color 444444 +tide_ruby_color B31209 +tide_rustc_bg_color 444444 +tide_rustc_color F74C00 +tide_shlvl_bg_color 444444 +tide_shlvl_color d78700 +tide_shlvl_threshold 1 +tide_status_bg_color 444444 +tide_status_bg_color_failure 444444 +tide_status_color $_tide_color_dark_green +tide_status_color_failure D70000 +tide_terraform_bg_color 444444 +tide_terraform_color 844FBA +tide_time_bg_color 444444 +tide_time_color 5F8787 +tide_time_format %T +tide_toolbox_bg_color 444444 +tide_toolbox_color 613583 +tide_vi_mode_bg_color_default 444444 +tide_vi_mode_bg_color_insert 444444 +tide_vi_mode_bg_color_replace 444444 +tide_vi_mode_bg_color_visual 444444 +tide_vi_mode_color_default 949494 +tide_vi_mode_color_insert 87AFAF +tide_vi_mode_color_replace 87AF87 +tide_vi_mode_color_visual FF8700 +tide_zig_bg_color 444444 +tide_zig_color F7A41D diff --git a/config/fish/functions/tide/configure/configs/classic_16color.fish b/config/fish/functions/tide/configure/configs/classic_16color.fish new file mode 100644 index 0000000..670170f --- /dev/null +++ b/config/fish/functions/tide/configure/configs/classic_16color.fish @@ -0,0 +1,89 @@ +tide_aws_bg_color black +tide_aws_color yellow +tide_character_color brgreen +tide_character_color_failure brred +tide_cmd_duration_bg_color black +tide_cmd_duration_color brblack +tide_context_bg_color black +tide_context_color_default yellow +tide_context_color_root bryellow +tide_context_color_ssh yellow +tide_crystal_bg_color black +tide_crystal_color brwhite +tide_direnv_bg_color black +tide_direnv_bg_color_denied black +tide_direnv_color bryellow +tide_direnv_color_denied brred +tide_distrobox_bg_color black +tide_distrobox_color brmagenta +tide_docker_bg_color black +tide_docker_color blue +tide_elixir_bg_color black +tide_elixir_color magenta +tide_gcloud_bg_color black +tide_gcloud_color blue +tide_git_bg_color black +tide_git_bg_color_unstable black +tide_git_bg_color_urgent black +tide_git_color_branch brgreen +tide_git_color_conflicted brred +tide_git_color_dirty bryellow +tide_git_color_operation brred +tide_git_color_staged bryellow +tide_git_color_stash brgreen +tide_git_color_untracked brblue +tide_git_color_upstream brgreen +tide_go_bg_color black +tide_go_color brcyan +tide_java_bg_color black +tide_java_color yellow +tide_jobs_bg_color black +tide_jobs_color green +tide_kubectl_bg_color black +tide_kubectl_color blue +tide_nix_shell_bg_color black +tide_nix_shell_color brblue +tide_node_bg_color black +tide_node_color green +tide_os_bg_color black +tide_os_color brwhite +tide_php_bg_color black +tide_php_color blue +tide_private_mode_bg_color black +tide_private_mode_color brwhite +tide_prompt_color_frame_and_connection brblack +tide_prompt_color_separator_same_color brblack +tide_pulumi_bg_color black +tide_pulumi_color yellow +tide_pwd_bg_color black +tide_pwd_color_anchors brcyan +tide_pwd_color_dirs cyan +tide_pwd_color_truncated_dirs magenta +tide_python_bg_color black +tide_python_color cyan +tide_ruby_bg_color black +tide_ruby_color red +tide_rustc_bg_color black +tide_rustc_color red +tide_shlvl_bg_color black +tide_shlvl_color yellow +tide_status_bg_color black +tide_status_bg_color_failure black +tide_status_color green +tide_status_color_failure red +tide_terraform_bg_color black +tide_terraform_color magenta +tide_time_bg_color black +tide_time_color brblack +tide_toolbox_bg_color black +tide_toolbox_color magenta +tide_vi_mode_bg_color_default black +tide_vi_mode_bg_color_insert black +tide_vi_mode_bg_color_replace black +tide_vi_mode_bg_color_visual black +tide_vi_mode_color_default white +tide_vi_mode_color_insert cyan +tide_vi_mode_color_replace green +tide_vi_mode_color_visual yellow +tide_zig_bg_color black +tide_zig_color yellow diff --git a/config/fish/functions/tide/configure/configs/lean.fish b/config/fish/functions/tide/configure/configs/lean.fish new file mode 100644 index 0000000..a958a17 --- /dev/null +++ b/config/fish/functions/tide/configure/configs/lean.fish @@ -0,0 +1,116 @@ +tide_aws_bg_color normal +tide_aws_color FF9900 +tide_character_color $_tide_color_green +tide_character_color_failure FF0000 +tide_cmd_duration_bg_color normal +tide_cmd_duration_color 87875F +tide_cmd_duration_decimals 0 +tide_cmd_duration_threshold 3000 +tide_context_always_display false +tide_context_bg_color normal +tide_context_color_default D7AF87 +tide_context_color_root $_tide_color_gold +tide_context_color_ssh D7AF87 +tide_context_hostname_parts 1 +tide_crystal_bg_color normal +tide_crystal_color FFFFFF +tide_direnv_bg_color normal +tide_direnv_bg_color_denied normal +tide_direnv_color $_tide_color_gold +tide_direnv_color_denied FF0000 +tide_distrobox_bg_color normal +tide_distrobox_color FF00FF +tide_docker_bg_color normal +tide_docker_color 2496ED +tide_docker_default_contexts default colima +tide_elixir_bg_color normal +tide_elixir_color 4E2A8E +tide_gcloud_bg_color normal +tide_gcloud_color 4285F4 +tide_git_bg_color normal +tide_git_bg_color_unstable normal +tide_git_bg_color_urgent normal +tide_git_color_branch $_tide_color_green +tide_git_color_conflicted FF0000 +tide_git_color_dirty $_tide_color_gold +tide_git_color_operation FF0000 +tide_git_color_staged $_tide_color_gold +tide_git_color_stash $_tide_color_green +tide_git_color_untracked $_tide_color_light_blue +tide_git_color_upstream $_tide_color_green +tide_git_truncation_length 24 +tide_git_truncation_strategy +tide_go_bg_color normal +tide_go_color 00ACD7 +tide_java_bg_color normal +tide_java_color ED8B00 +tide_jobs_bg_color normal +tide_jobs_color $_tide_color_dark_green +tide_jobs_number_threshold 1000 +tide_kubectl_bg_color normal +tide_kubectl_color 326CE5 +tide_left_prompt_frame_enabled false +tide_left_prompt_items pwd git newline character +tide_left_prompt_prefix '' +tide_left_prompt_separator_diff_color ' ' +tide_left_prompt_separator_same_color ' ' +tide_left_prompt_suffix ' ' +tide_nix_shell_bg_color normal +tide_nix_shell_color 7EBAE4 +tide_node_bg_color normal +tide_node_color 44883E +tide_os_bg_color normal +tide_os_color normal +tide_php_bg_color normal +tide_php_color 617CBE +tide_private_mode_bg_color normal +tide_private_mode_color FFFFFF +tide_prompt_add_newline_before true +tide_prompt_color_frame_and_connection 6C6C6C +tide_prompt_color_separator_same_color 949494 +tide_prompt_min_cols 34 +tide_prompt_pad_items false +tide_prompt_transient_enabled false +tide_pulumi_bg_color normal +tide_pulumi_color F7BF2A +tide_pwd_bg_color normal +tide_pwd_color_anchors $_tide_color_light_blue +tide_pwd_color_dirs $_tide_color_dark_blue +tide_pwd_color_truncated_dirs 8787AF +tide_pwd_markers .bzr .citc .git .hg .node-version .python-version .ruby-version .shorten_folder_marker .svn .terraform Cargo.toml composer.json CVS go.mod package.json build.zig +tide_python_bg_color normal +tide_python_color 00AFAF +tide_right_prompt_frame_enabled false +tide_right_prompt_items status cmd_duration context jobs direnv node python rustc java php pulumi ruby go gcloud kubectl distrobox toolbox terraform aws nix_shell crystal elixir zig +tide_right_prompt_prefix ' ' +tide_right_prompt_separator_diff_color ' ' +tide_right_prompt_separator_same_color ' ' +tide_right_prompt_suffix '' +tide_ruby_bg_color normal +tide_ruby_color B31209 +tide_rustc_bg_color normal +tide_rustc_color F74C00 +tide_shlvl_bg_color normal +tide_shlvl_color d78700 +tide_shlvl_threshold 1 +tide_status_bg_color normal +tide_status_bg_color_failure normal +tide_status_color $_tide_color_dark_green +tide_status_color_failure D70000 +tide_terraform_bg_color normal +tide_terraform_color 844FBA +tide_time_bg_color normal +tide_time_color 5F8787 +tide_time_format %T +tide_toolbox_bg_color normal +tide_toolbox_color 613583 +tide_vi_mode_bg_color_default normal +tide_vi_mode_bg_color_insert normal +tide_vi_mode_bg_color_replace normal +tide_vi_mode_bg_color_visual normal +tide_vi_mode_color_default 949494 +tide_vi_mode_color_insert 87AFAF +tide_vi_mode_color_replace 87AF87 +tide_vi_mode_color_visual FF8700 +tide_zig_bg_color normal +tide_zig_color F7A41D diff --git a/config/fish/functions/tide/configure/configs/lean_16color.fish b/config/fish/functions/tide/configure/configs/lean_16color.fish new file mode 100644 index 0000000..16c2511 --- /dev/null +++ b/config/fish/functions/tide/configure/configs/lean_16color.fish @@ -0,0 +1,89 @@ +tide_aws_bg_color normal +tide_aws_color yellow +tide_character_color brgreen +tide_character_color_failure brred +tide_cmd_duration_bg_color normal +tide_cmd_duration_color brblack +tide_context_bg_color normal +tide_context_color_default yellow +tide_context_color_root bryellow +tide_context_color_ssh yellow +tide_crystal_bg_color normal +tide_crystal_color brwhite +tide_direnv_bg_color normal +tide_direnv_bg_color_denied normal +tide_direnv_color bryellow +tide_direnv_color_denied brred +tide_distrobox_bg_color normal +tide_distrobox_color brmagenta +tide_docker_bg_color normal +tide_docker_color blue +tide_elixir_bg_color normal +tide_elixir_color magenta +tide_gcloud_bg_color normal +tide_gcloud_color blue +tide_git_bg_color normal +tide_git_bg_color_unstable normal +tide_git_bg_color_urgent normal +tide_git_color_branch brgreen +tide_git_color_conflicted brred +tide_git_color_dirty bryellow +tide_git_color_operation brred +tide_git_color_staged bryellow +tide_git_color_stash brgreen +tide_git_color_untracked brblue +tide_git_color_upstream brgreen +tide_go_bg_color normal +tide_go_color brcyan +tide_java_bg_color normal +tide_java_color yellow +tide_jobs_bg_color normal +tide_jobs_color green +tide_kubectl_bg_color normal +tide_kubectl_color blue +tide_nix_shell_bg_color normal +tide_nix_shell_color brblue +tide_node_bg_color normal +tide_node_color green +tide_os_bg_color normal +tide_os_color brwhite +tide_php_bg_color normal +tide_php_color blue +tide_private_mode_bg_color normal +tide_private_mode_color brwhite +tide_prompt_color_frame_and_connection brblack +tide_prompt_color_separator_same_color brblack +tide_pulumi_bg_color normal +tide_pulumi_color yellow +tide_pwd_bg_color normal +tide_pwd_color_anchors brcyan +tide_pwd_color_dirs cyan +tide_pwd_color_truncated_dirs magenta +tide_python_bg_color normal +tide_python_color cyan +tide_ruby_bg_color normal +tide_ruby_color red +tide_rustc_bg_color normal +tide_rustc_color red +tide_shlvl_bg_color normal +tide_shlvl_color yellow +tide_status_bg_color normal +tide_status_bg_color_failure normal +tide_status_color green +tide_status_color_failure red +tide_terraform_bg_color normal +tide_terraform_color magenta +tide_time_bg_color normal +tide_time_color brblack +tide_toolbox_bg_color normal +tide_toolbox_color magenta +tide_vi_mode_bg_color_default normal +tide_vi_mode_bg_color_insert normal +tide_vi_mode_bg_color_replace normal +tide_vi_mode_bg_color_visual normal +tide_vi_mode_color_default white +tide_vi_mode_color_insert cyan +tide_vi_mode_color_replace green +tide_vi_mode_color_visual yellow +tide_zig_bg_color normal +tide_zig_color yellow diff --git a/config/fish/functions/tide/configure/configs/rainbow.fish b/config/fish/functions/tide/configure/configs/rainbow.fish new file mode 100644 index 0000000..60c1592 --- /dev/null +++ b/config/fish/functions/tide/configure/configs/rainbow.fish @@ -0,0 +1,116 @@ +tide_aws_bg_color FF9900 +tide_aws_color 232F3E +tide_character_color $_tide_color_green +tide_character_color_failure FF0000 +tide_cmd_duration_bg_color C4A000 +tide_cmd_duration_color 000000 +tide_cmd_duration_decimals 0 +tide_cmd_duration_threshold 3000 +tide_context_always_display false +tide_context_bg_color 444444 +tide_context_color_default D7AF87 +tide_context_color_root $_tide_color_gold +tide_context_color_ssh D7AF87 +tide_context_hostname_parts 1 +tide_crystal_bg_color FFFFFF +tide_crystal_color 000000 +tide_direnv_bg_color $_tide_color_gold +tide_direnv_bg_color_denied FF0000 +tide_direnv_color 000000 +tide_direnv_color_denied 000000 +tide_distrobox_bg_color FF00FF +tide_distrobox_color 000000 +tide_docker_bg_color 2496ED +tide_docker_color 000000 +tide_docker_default_contexts default colima +tide_elixir_bg_color 4E2A8E +tide_elixir_color 000000 +tide_gcloud_bg_color 4285F4 +tide_gcloud_color 000000 +tide_git_bg_color 4E9A06 +tide_git_bg_color_unstable C4A000 +tide_git_bg_color_urgent CC0000 +tide_git_color_branch 000000 +tide_git_color_conflicted 000000 +tide_git_color_dirty 000000 +tide_git_color_operation 000000 +tide_git_color_staged 000000 +tide_git_color_stash 000000 +tide_git_color_untracked 000000 +tide_git_color_upstream 000000 +tide_git_truncation_length 24 +tide_git_truncation_strategy +tide_go_bg_color 00ACD7 +tide_go_color 000000 +tide_java_bg_color ED8B00 +tide_java_color 000000 +tide_jobs_bg_color 444444 +tide_jobs_color 4E9A06 +tide_jobs_number_threshold 1000 +tide_kubectl_bg_color 326CE5 +tide_kubectl_color 000000 +tide_left_prompt_frame_enabled true +tide_left_prompt_items pwd git newline +tide_left_prompt_prefix '' +tide_left_prompt_separator_diff_color  +tide_left_prompt_separator_same_color  +tide_left_prompt_suffix  +tide_nix_shell_bg_color 7EBAE4 +tide_nix_shell_color 000000 +tide_node_bg_color 44883E +tide_node_color 000000 +tide_os_bg_color $os_branding_bg_color +tide_os_color $os_branding_color +tide_php_bg_color 617CBE +tide_php_color 000000 +tide_private_mode_bg_color F1F3F4 +tide_private_mode_color 000000 +tide_prompt_add_newline_before true +tide_prompt_color_frame_and_connection 6C6C6C +tide_prompt_color_separator_same_color 949494 +tide_prompt_min_cols 34 +tide_prompt_pad_items true +tide_prompt_transient_enabled false +tide_pulumi_bg_color F7BF2A +tide_pulumi_color 000000 +tide_pwd_bg_color 3465A4 +tide_pwd_color_anchors E4E4E4 +tide_pwd_color_dirs E4E4E4 +tide_pwd_color_truncated_dirs BCBCBC +tide_pwd_markers .bzr .citc .git .hg .node-version .python-version .ruby-version .shorten_folder_marker .svn .terraform Cargo.toml composer.json CVS go.mod package.json build.zig +tide_python_bg_color 444444 +tide_python_color 00AFAF +tide_right_prompt_frame_enabled true +tide_right_prompt_items status cmd_duration context jobs direnv node python rustc java php pulumi ruby go gcloud kubectl distrobox toolbox terraform aws nix_shell crystal elixir zig +tide_right_prompt_prefix  +tide_right_prompt_separator_diff_color  +tide_right_prompt_separator_same_color  +tide_right_prompt_suffix '' +tide_ruby_bg_color B31209 +tide_ruby_color 000000 +tide_rustc_bg_color F74C00 +tide_rustc_color 000000 +tide_shlvl_bg_color 808000 +tide_shlvl_color 000000 +tide_shlvl_threshold 1 +tide_status_bg_color 2E3436 +tide_status_bg_color_failure CC0000 +tide_status_color 4E9A06 +tide_status_color_failure FFFF00 +tide_terraform_bg_color 800080 +tide_terraform_color 000000 +tide_time_bg_color D3D7CF +tide_time_color 000000 +tide_time_format %T +tide_toolbox_bg_color 613583 +tide_toolbox_color 000000 +tide_vi_mode_bg_color_default 949494 +tide_vi_mode_bg_color_insert 87AFAF +tide_vi_mode_bg_color_replace 87AF87 +tide_vi_mode_bg_color_visual FF8700 +tide_vi_mode_color_default 000000 +tide_vi_mode_color_insert 000000 +tide_vi_mode_color_replace 000000 +tide_vi_mode_color_visual 000000 +tide_zig_bg_color F7A41D +tide_zig_color 000000 diff --git a/config/fish/functions/tide/configure/configs/rainbow_16color.fish b/config/fish/functions/tide/configure/configs/rainbow_16color.fish new file mode 100644 index 0000000..a040f58 --- /dev/null +++ b/config/fish/functions/tide/configure/configs/rainbow_16color.fish @@ -0,0 +1,93 @@ +tide_aws_bg_color yellow +tide_aws_color brblack +tide_character_color brgreen +tide_character_color_failure brred +tide_cmd_duration_bg_color yellow +tide_cmd_duration_color black +tide_context_bg_color brblack +tide_context_color_default yellow +tide_context_color_root yellow +tide_context_color_ssh yellow +tide_crystal_bg_color brwhite +tide_crystal_color black +tide_direnv_bg_color bryellow +tide_direnv_bg_color_denied brred +tide_direnv_color black +tide_direnv_color_denied black +tide_distrobox_bg_color brmagenta +tide_distrobox_color black +tide_docker_bg_color blue +tide_docker_color black +tide_elixir_bg_color magenta +tide_elixir_color black +tide_gcloud_bg_color blue +tide_gcloud_color black +tide_git_bg_color green +tide_git_bg_color_unstable yellow +tide_git_bg_color_urgent red +tide_git_color_branch black +tide_git_color_conflicted black +tide_git_color_dirty black +tide_git_color_operation black +tide_git_color_staged black +tide_git_color_stash black +tide_git_color_untracked black +tide_git_color_upstream black +tide_go_bg_color brcyan +tide_go_color black +tide_java_bg_color yellow +tide_java_color black +tide_jobs_bg_color brblack +tide_jobs_color green +tide_kubectl_bg_color blue +tide_kubectl_color black +tide_nix_shell_bg_color brblue +tide_nix_shell_color black +tide_node_bg_color green +tide_node_color black +tide_os_bg_color white +tide_os_color black +tide_php_bg_color blue +tide_php_color black +tide_private_mode_bg_color brwhite +tide_private_mode_color black +tide_prompt_color_frame_and_connection brblack +tide_prompt_color_separator_same_color brblack +tide_pulumi_bg_color yellow +tide_pulumi_color black +tide_pwd_bg_color blue +tide_pwd_color_anchors brwhite +tide_pwd_color_dirs brwhite +tide_pwd_color_truncated_dirs white +tide_python_bg_color brblack +tide_python_color cyan +tide_ruby_bg_color red +tide_ruby_color black +tide_rustc_bg_color red +tide_rustc_color black +tide_shlvl_bg_color yellow +tide_shlvl_color black +tide_status_bg_color black +tide_status_bg_color_failure red +tide_status_color green +tide_status_color_failure bryellow +tide_terraform_bg_color magenta +tide_terraform_color black +tide_time_bg_color white +tide_time_color black +tide_toolbox_bg_color magenta +tide_toolbox_color black +tide_vi_mode_bg_color_default white +tide_vi_mode_bg_color_insert cyan +tide_vi_mode_bg_color_replace green +tide_vi_mode_bg_color_visual yellow +tide_vi_mode_color_default black +tide_vi_mode_color_insert black +tide_vi_mode_color_replace black +tide_vi_mode_color_visual black +tide_vi_mode_icon_default D +tide_vi_mode_icon_insert I +tide_vi_mode_icon_replace R +tide_vi_mode_icon_visual V +tide_zig_bg_color yellow +tide_zig_color black diff --git a/config/fish/functions/tide/configure/functions/_fake_tide_cache_variables.fish b/config/fish/functions/tide/configure/functions/_fake_tide_cache_variables.fish new file mode 100644 index 0000000..4661ab1 --- /dev/null +++ b/config/fish/functions/tide/configure/functions/_fake_tide_cache_variables.fish @@ -0,0 +1,41 @@ +function _fake_tide_cache_variables + # pwd + set_color -o $fake_tide_pwd_color_anchors | read -gx _fake_tide_color_anchors + set -gx _fake_tide_color_truncated_dirs "$(set_color $fake_tide_pwd_color_truncated_dirs)" + set -gx _fake_tide_reset_to_color_dirs (set_color normal -b $fake_tide_pwd_bg_color; set_color $fake_tide_pwd_color_dirs) + + # git + contains git $fake_tide_left_prompt_items $fake_tide_right_prompt_items && + set -gx _fake_tide_location_color "$(set_color $fake_tide_git_color_branch)" + + # private_mode + if contains private_mode $fake_tide_left_prompt_items $fake_tide_right_prompt_items && test -n "$fish_private_mode" + set -gx _fake_tide_private_mode + else + set -e _fake_tide_private_mode + end + + # Same-color-separator color + set -gx _fake_tide_color_separator_same_color "$(set_color $fake_tide_prompt_color_separator_same_color)" + + # two line prompt + if contains newline $fake_tide_left_prompt_items + set_color $fake_tide_prompt_color_frame_and_connection -b normal | read -gx _fake_tide_prompt_and_frame_color + else + set -e _fake_tide_prompt_and_frame_color + end + + # newline before + if test "$fake_tide_prompt_add_newline_before" = true + set -g _fake_tide_add_newline '' + else + set -e _fake_tide_add_newline + end + + # item padding + if test "$fake_tide_prompt_pad_items" = true + set -gx _fake_tide_pad ' ' + else + set -e _fake_tide_pad + end +end diff --git a/config/fish/functions/tide/configure/functions/_fake_tide_item_character.fish b/config/fish/functions/tide/configure/functions/_fake_tide_item_character.fish new file mode 100644 index 0000000..94892ec --- /dev/null +++ b/config/fish/functions/tide/configure/functions/_fake_tide_item_character.fish @@ -0,0 +1,8 @@ +function _fake_tide_item_character + set_color $fake_tide_character_color + if contains newline $fake_tide_left_prompt_items || set -q _configure_transient + echo -ns $fake_tide_character_icon + else + echo -ns ' '$fake_tide_character_icon + end +end diff --git a/config/fish/functions/tide/configure/functions/_fake_tide_item_cmd_duration.fish b/config/fish/functions/tide/configure/functions/_fake_tide_item_cmd_duration.fish new file mode 100644 index 0000000..5aa13b2 --- /dev/null +++ b/config/fish/functions/tide/configure/functions/_fake_tide_item_cmd_duration.fish @@ -0,0 +1,3 @@ +function _fake_tide_item_cmd_duration + _fake_tide_print_item cmd_duration $fake_tide_cmd_duration_icon' ' 5s +end diff --git a/config/fish/functions/tide/configure/functions/_fake_tide_item_git.fish b/config/fish/functions/tide/configure/functions/_fake_tide_item_git.fish new file mode 100644 index 0000000..fb5b957 --- /dev/null +++ b/config/fish/functions/tide/configure/functions/_fake_tide_item_git.fish @@ -0,0 +1,3 @@ +function _fake_tide_item_git + _fake_tide_print_item git (set_color $fake_tide_git_color_branch) $fake_tide_git_icon' ' main +end diff --git a/config/fish/functions/tide/configure/functions/_fake_tide_item_newline.fish b/config/fish/functions/tide/configure/functions/_fake_tide_item_newline.fish new file mode 100644 index 0000000..c614bab --- /dev/null +++ b/config/fish/functions/tide/configure/functions/_fake_tide_item_newline.fish @@ -0,0 +1,5 @@ +function _fake_tide_item_newline + set_color $prev_bg_color -b normal + var=fake_tide_"$_fake_tide_side"_prompt_suffix echo $$var + set -g add_prefix +end diff --git a/config/fish/functions/tide/configure/functions/_fake_tide_item_os.fish b/config/fish/functions/tide/configure/functions/_fake_tide_item_os.fish new file mode 100644 index 0000000..5255721 --- /dev/null +++ b/config/fish/functions/tide/configure/functions/_fake_tide_item_os.fish @@ -0,0 +1,3 @@ +function _fake_tide_item_os + _fake_tide_print_item os $fake_tide_os_icon +end diff --git a/config/fish/functions/tide/configure/functions/_fake_tide_item_time.fish b/config/fish/functions/tide/configure/functions/_fake_tide_item_time.fish new file mode 100644 index 0000000..bbce0b5 --- /dev/null +++ b/config/fish/functions/tide/configure/functions/_fake_tide_item_time.fish @@ -0,0 +1,3 @@ +function _fake_tide_item_time + _fake_tide_print_item time (date +$fake_tide_time_format) +end diff --git a/config/fish/functions/tide/configure/functions/_fake_tide_print_item.fish b/config/fish/functions/tide/configure/functions/_fake_tide_print_item.fish new file mode 100644 index 0000000..30cd024 --- /dev/null +++ b/config/fish/functions/tide/configure/functions/_fake_tide_print_item.fish @@ -0,0 +1,22 @@ +function _fake_tide_print_item -a item + var=fake_tide_"$item"_bg_color set -f item_bg_color $$var + + if set -e add_prefix + set_color $item_bg_color -b normal + var=fake_tide_"$_fake_tide_side"_prompt_prefix echo -ns $$var + else if test "$item_bg_color" = "$prev_bg_color" + var=fake_tide_"$_fake_tide_side"_prompt_separator_same_color echo -ns $_fake_tide_color_separator_same_color$$var + else if test "$_fake_tide_side" = left + set_color $prev_bg_color -b $item_bg_color + echo -ns $fake_tide_left_prompt_separator_diff_color + else + set_color $item_bg_color -b $prev_bg_color + echo -ns $fake_tide_right_prompt_separator_diff_color + end + + var=fake_tide_"$item"_color set_color $$var -b $item_bg_color + + echo -ns $_fake_tide_pad $argv[2..] $_fake_tide_pad + + set -g prev_bg_color $item_bg_color +end diff --git a/config/fish/functions/tide/configure/functions/_fake_tide_prompt.fish b/config/fish/functions/tide/configure/functions/_fake_tide_prompt.fish new file mode 100644 index 0000000..11f20ca --- /dev/null +++ b/config/fish/functions/tide/configure/functions/_fake_tide_prompt.fish @@ -0,0 +1,42 @@ +function _fake_tide_prompt + set -g add_prefix + _fake_tide_side=left set -f left (for item in $fake_tide_left_prompt_items + _fake_tide_item_$item + end + if not set -e add_prefix + set_color $prev_bg_color -b normal + echo -ns $fake_tide_left_prompt_suffix + end) + + set -g add_prefix + _fake_tide_side=right set -f right (for item in $fake_tide_right_prompt_items + _fake_tide_item_$item + end + if not set -e add_prefix + set_color $prev_bg_color -b normal + echo -ns $fake_tide_right_prompt_suffix + end) + + if set -q _fake_tide_prompt_and_frame_color # If prompt is two lines + test "$fake_tide_left_prompt_frame_enabled" = true && + set left[1] "$_fake_tide_prompt_and_frame_color╭─$left[1]" && + set left[2] "$_fake_tide_prompt_and_frame_color╰─$left[2]" + test "$fake_tide_right_prompt_frame_enabled" = true && + set right[1] "$right[1]$_fake_tide_prompt_and_frame_color─╮" && + set right[2] "$right[2]$_fake_tide_prompt_and_frame_color─╯" + + # 5 = @PWD@ length which will be replaced + math $fake_columns+5-(string length --visible "$left[1]$right[1]") | read -lx dist_btwn_sides + echo -ns "$right[2]"\n(string replace @PWD@ (_fake_tide_pwd) "$left[1]")$_fake_tide_prompt_and_frame_color + + string repeat --no-newline --max (math max 0, $dist_btwn_sides-$_tide_pwd_len) $fake_tide_prompt_icon_connection + echo -ns "$right[1]"\n"$left[2] " + else + math $fake_columns+5-(string length --visible "$left[1]$right[1]") -$fake_tide_prompt_min_cols | read -lx dist_btwn_sides + string replace @PWD@ (_fake_tide_pwd) "$right[1]" "$left[1] " + end +end + +function _fake_tide_item_pwd + _fake_tide_print_item pwd @PWD@ +end diff --git a/config/fish/functions/tide/configure/functions/_fake_tide_pwd.fish b/config/fish/functions/tide/configure/functions/_fake_tide_pwd.fish new file mode 100644 index 0000000..433eafa --- /dev/null +++ b/config/fish/functions/tide/configure/functions/_fake_tide_pwd.fish @@ -0,0 +1,11 @@ +function _fake_tide_pwd + set -l out ( + set_color $fake_tide_pwd_color_dirs + echo -ns $fake_tide_pwd_icon' ' '~/' + set_color -o $fake_tide_pwd_color_anchors + echo -ns src + set_color normal -b $fake_tide_pwd_bg_color + ) + set -g _tide_pwd_len (string length --visible $out) + echo -ns $out +end diff --git a/config/fish/functions/tide/configure/icons.fish b/config/fish/functions/tide/configure/icons.fish new file mode 100644 index 0000000..70611cd --- /dev/null +++ b/config/fish/functions/tide/configure/icons.fish @@ -0,0 +1,40 @@ +tide_aws_icon  # Actual aws glyph is harder to see +tide_character_icon ❯ +tide_character_vi_icon_default ❮ +tide_character_vi_icon_replace ▶ +tide_character_vi_icon_visual V +tide_cmd_duration_icon +tide_crystal_icon  +tide_direnv_icon ▼ +tide_distrobox_icon 󰆧 +tide_docker_icon  +tide_elixir_icon  +tide_gcloud_icon 󰊭 # Actual google cloud glyph is harder to see +tide_git_icon +tide_go_icon  +tide_java_icon  +tide_jobs_icon  +tide_kubectl_icon 󱃾 +tide_nix_shell_icon  +tide_node_icon  # Actual nodejs glyph is harder to see +tide_os_icon $os_branding_icon +tide_php_icon  +tide_private_mode_icon 󰗹 +tide_prompt_icon_connection ' ' +tide_pulumi_icon  +tide_pwd_icon +tide_pwd_icon_home +tide_pwd_icon_unwritable  +tide_python_icon 󰌠 +tide_ruby_icon  +tide_rustc_icon  +tide_shlvl_icon  +tide_status_icon ✔ +tide_status_icon_failure ✘ +tide_terraform_icon 󱁢 +tide_toolbox_icon  +tide_vi_mode_icon_default D +tide_vi_mode_icon_insert I +tide_vi_mode_icon_replace R +tide_vi_mode_icon_visual V +tide_zig_icon 