From 1bc155556a8e49ad6497d545068f1663848800ee Mon Sep 17 00:00:00 2001 From: Abdellah El Morabit Date: Tue, 25 Nov 2025 20:36:39 +0100 Subject: [PATCH] checkpoint --- alacritty/alacritty.toml | 38 +-- fish/completions/fisher.fish | 7 + fish/completions/tide.fish | 12 + fish/conf.d/_tide_init.fish | 41 +++ fish/config.fish | 79 ++++++ fish/fish_plugins | 2 + fish/fish_variables | 205 +++++++++++++++ fish/functions/_tide_1_line_prompt.fish | 19 ++ fish/functions/_tide_2_line_prompt.fish | 31 +++ fish/functions/_tide_cache_variables.fish | 17 ++ fish/functions/_tide_detect_os.fish | 75 ++++++ fish/functions/_tide_find_and_remove.fish | 3 + fish/functions/_tide_item_aws.fish | 11 + fish/functions/_tide_item_character.fish | 17 ++ fish/functions/_tide_item_chruby.fish | 3 + fish/functions/_tide_item_cmd_duration.fish | 12 + fish/functions/_tide_item_context.fish | 15 ++ fish/functions/_tide_item_crystal.fish | 4 + fish/functions/_tide_item_direnv.fish | 7 + fish/functions/_tide_item_distrobox.fish | 4 + fish/functions/_tide_item_docker.fish | 5 + fish/functions/_tide_item_elixir.fish | 4 + fish/functions/_tide_item_gcloud.fish | 8 + fish/functions/_tide_item_git.fish | 67 +++++ fish/functions/_tide_item_go.fish | 4 + fish/functions/_tide_item_java.fish | 4 + fish/functions/_tide_item_jobs.fish | 3 + fish/functions/_tide_item_kubectl.fish | 4 + fish/functions/_tide_item_nix_shell.fish | 3 + fish/functions/_tide_item_node.fish | 4 + fish/functions/_tide_item_os.fish | 3 + fish/functions/_tide_item_php.fish | 4 + fish/functions/_tide_item_private_mode.fish | 3 + fish/functions/_tide_item_pulumi.fish | 19 ++ fish/functions/_tide_item_rustc.fish | 4 + fish/functions/_tide_item_shlvl.fish | 4 + fish/functions/_tide_item_status.fish | 15 ++ fish/functions/_tide_item_terraform.fish | 6 + fish/functions/_tide_item_time.fish | 3 + fish/functions/_tide_item_toolbox.fish | 4 + fish/functions/_tide_item_vi_mode.fish | 16 ++ fish/functions/_tide_item_virtual_env.fish | 11 + fish/functions/_tide_parent_dirs.fish | 7 + fish/functions/_tide_print_item.fish | 22 ++ fish/functions/_tide_pwd.fish | 38 +++ .../_tide_remove_unusable_items.fish | 25 ++ fish/functions/_tide_sub_bug-report.fish | 73 ++++++ fish/functions/_tide_sub_configure.fish | 95 +++++++ fish/functions/fish_mode_prompt.fish | 1 + fish/functions/fish_prompt.fish | 90 +++++++ fish/functions/fisher.fish | 240 ++++++++++++++++++ fish/functions/tide.fish | 27 ++ .../tide/configure/choices/all/finish.fish | 33 +++ .../tide/configure/choices/all/icons.fish | 33 +++ .../configure/choices/all/prompt_colors.fish | 26 ++ .../choices/all/prompt_connection.fish | 28 ++ .../prompt_connection_andor_frame_color.fish | 36 +++ .../configure/choices/all/prompt_spacing.fish | 21 ++ .../tide/configure/choices/all/show_time.fish | 31 +++ .../tide/configure/choices/all/style.fish | 57 +++++ .../choices/classic/classic_prompt_color.fish | 38 +++ .../classic/classic_prompt_separators.fish | 40 +++ .../choices/lean/lean_prompt_height.fish | 26 ++ .../powerline/powerline_prompt_frame.fish | 46 ++++ .../powerline/powerline_prompt_heads.fish | 40 +++ .../powerline/powerline_prompt_height.fish | 30 +++ .../powerline/powerline_prompt_tails.fish | 48 ++++ .../rainbow/rainbow_prompt_separators.fish | 40 +++ .../tide/configure/configs/classic.fish | 151 +++++++++++ .../configure/configs/classic_16color.fish | 87 +++++++ .../tide/configure/configs/lean.fish | 151 +++++++++++ .../tide/configure/configs/lean_16color.fish | 87 +++++++ .../tide/configure/configs/rainbow.fish | 151 +++++++++++ .../configure/configs/rainbow_16color.fish | 91 +++++++ .../functions/_fake_tide_cache_variables.fish | 41 +++ .../functions/_fake_tide_item_character.fish | 5 + .../_fake_tide_item_cmd_duration.fish | 3 + .../functions/_fake_tide_item_git.fish | 3 + .../functions/_fake_tide_item_newline.fish | 5 + .../functions/_fake_tide_item_os.fish | 3 + .../functions/_fake_tide_item_time.fish | 3 + .../functions/_fake_tide_print_item.fish | 22 ++ .../functions/_fake_tide_prompt.fish | 42 +++ .../configure/functions/_fake_tide_pwd.fish | 11 + gh/config.yml | 27 ++ gh/hosts.yml | 5 + omf/bundle | 3 + omf/channel | 1 + omf/theme | 1 + rizin/cutter.ini | 210 +++++++++++++++ skhd/skhdrc | 8 - tmux/tmux.conf | 2 +- vifm/.DS_Store | Bin 0 -> 6148 bytes vifm/vifminfo.json | 2 +- zsh/zshrc | 5 +- 95 files changed, 3079 insertions(+), 32 deletions(-) create mode 100644 fish/completions/fisher.fish create mode 100644 fish/completions/tide.fish create mode 100644 fish/conf.d/_tide_init.fish create mode 100644 fish/config.fish create mode 100644 fish/fish_plugins create mode 100644 fish/fish_variables create mode 100644 fish/functions/_tide_1_line_prompt.fish create mode 100644 fish/functions/_tide_2_line_prompt.fish create mode 100644 fish/functions/_tide_cache_variables.fish create mode 100644 fish/functions/_tide_detect_os.fish create mode 100644 fish/functions/_tide_find_and_remove.fish create mode 100644 fish/functions/_tide_item_aws.fish create mode 100644 fish/functions/_tide_item_character.fish create mode 100644 fish/functions/_tide_item_chruby.fish create mode 100644 fish/functions/_tide_item_cmd_duration.fish create mode 100644 fish/functions/_tide_item_context.fish create mode 100644 fish/functions/_tide_item_crystal.fish create mode 100644 fish/functions/_tide_item_direnv.fish create mode 100644 fish/functions/_tide_item_distrobox.fish create mode 100644 fish/functions/_tide_item_docker.fish create mode 100644 fish/functions/_tide_item_elixir.fish create mode 100644 fish/functions/_tide_item_gcloud.fish create mode 100644 fish/functions/_tide_item_git.fish create mode 100644 fish/functions/_tide_item_go.fish create mode 100644 fish/functions/_tide_item_java.fish create mode 100644 fish/functions/_tide_item_jobs.fish create mode 100644 fish/functions/_tide_item_kubectl.fish create mode 100644 fish/functions/_tide_item_nix_shell.fish create mode 100644 fish/functions/_tide_item_node.fish create mode 100644 fish/functions/_tide_item_os.fish create mode 100644 fish/functions/_tide_item_php.fish create mode 100644 fish/functions/_tide_item_private_mode.fish create mode 100644 fish/functions/_tide_item_pulumi.fish create mode 100644 fish/functions/_tide_item_rustc.fish create mode 100644 fish/functions/_tide_item_shlvl.fish create mode 100644 fish/functions/_tide_item_status.fish create mode 100644 fish/functions/_tide_item_terraform.fish create mode 100644 fish/functions/_tide_item_time.fish create mode 100644 fish/functions/_tide_item_toolbox.fish create mode 100644 fish/functions/_tide_item_vi_mode.fish create mode 100644 fish/functions/_tide_item_virtual_env.fish create mode 100644 fish/functions/_tide_parent_dirs.fish create mode 100644 fish/functions/_tide_print_item.fish create mode 100644 fish/functions/_tide_pwd.fish create mode 100644 fish/functions/_tide_remove_unusable_items.fish create mode 100644 fish/functions/_tide_sub_bug-report.fish create mode 100644 fish/functions/_tide_sub_configure.fish create mode 100644 fish/functions/fish_mode_prompt.fish create mode 100644 fish/functions/fish_prompt.fish create mode 100644 fish/functions/fisher.fish create mode 100644 fish/functions/tide.fish create mode 100644 fish/functions/tide/configure/choices/all/finish.fish create mode 100644 fish/functions/tide/configure/choices/all/icons.fish create mode 100644 fish/functions/tide/configure/choices/all/prompt_colors.fish create mode 100644 fish/functions/tide/configure/choices/all/prompt_connection.fish create mode 100644 fish/functions/tide/configure/choices/all/prompt_connection_andor_frame_color.fish create mode 100644 fish/functions/tide/configure/choices/all/prompt_spacing.fish create mode 100644 fish/functions/tide/configure/choices/all/show_time.fish create mode 100644 fish/functions/tide/configure/choices/all/style.fish create mode 100644 fish/functions/tide/configure/choices/classic/classic_prompt_color.fish create mode 100644 fish/functions/tide/configure/choices/classic/classic_prompt_separators.fish create mode 100644 fish/functions/tide/configure/choices/lean/lean_prompt_height.fish create mode 100644 fish/functions/tide/configure/choices/powerline/powerline_prompt_frame.fish create mode 100644 fish/functions/tide/configure/choices/powerline/powerline_prompt_heads.fish create mode 100644 fish/functions/tide/configure/choices/powerline/powerline_prompt_height.fish create mode 100644 fish/functions/tide/configure/choices/powerline/powerline_prompt_tails.fish create mode 100644 fish/functions/tide/configure/choices/rainbow/rainbow_prompt_separators.fish create mode 100644 fish/functions/tide/configure/configs/classic.fish create mode 100644 fish/functions/tide/configure/configs/classic_16color.fish create mode 100644 fish/functions/tide/configure/configs/lean.fish create mode 100644 fish/functions/tide/configure/configs/lean_16color.fish create mode 100644 fish/functions/tide/configure/configs/rainbow.fish create mode 100644 fish/functions/tide/configure/configs/rainbow_16color.fish create mode 100644 fish/functions/tide/configure/functions/_fake_tide_cache_variables.fish create mode 100644 fish/functions/tide/configure/functions/_fake_tide_item_character.fish create mode 100644 fish/functions/tide/configure/functions/_fake_tide_item_cmd_duration.fish create mode 100644 fish/functions/tide/configure/functions/_fake_tide_item_git.fish create mode 100644 fish/functions/tide/configure/functions/_fake_tide_item_newline.fish create mode 100644 fish/functions/tide/configure/functions/_fake_tide_item_os.fish create mode 100644 fish/functions/tide/configure/functions/_fake_tide_item_time.fish create mode 100644 fish/functions/tide/configure/functions/_fake_tide_print_item.fish create mode 100644 fish/functions/tide/configure/functions/_fake_tide_prompt.fish create mode 100644 fish/functions/tide/configure/functions/_fake_tide_pwd.fish create mode 100644 gh/config.yml create mode 100644 gh/hosts.yml create mode 100644 omf/bundle create mode 100644 omf/channel create mode 100644 omf/theme create mode 100644 rizin/cutter.ini create mode 100644 vifm/.DS_Store diff --git a/alacritty/alacritty.toml b/alacritty/alacritty.toml index 1b70399..4dee3af 100644 --- a/alacritty/alacritty.toml +++ b/alacritty/alacritty.toml @@ -1,22 +1,25 @@ # Alacritty Configuration - # Window settings + [window] opacity = 1 -dynamic_padding = true +dynamic_padding = false decorations = "Buttonless" blur = true title = "Terminal" decorations_theme_variant = "Dark" -resize_increments = true +resize_increments = false option_as_alt = "OnlyRight" +[terminal] +shell = "/opt/homebrew/bin/fish" + # Font settings [font] normal = { family = "JetBrainsMono Nerd Font", style = "Regular" } bold = { family = "JetBrainsMono Nerd Font", style = "Bold" } italic = { family = "JetBrainsMono Nerd Font", style = "Italic" } -size = 16.0 +size = 13.0 [font.offset] x = 0 @@ -28,24 +31,24 @@ y = 0 # Cursor settings [cursor] -style = { shape = "Beam", blinking = "Always" } +style = { shape = "Block", blinking = "Always" } vi_mode_style = { shape = "Beam", blinking = "Always" } blink_interval = 500 -thickness = 0.3 - +thickness = 0.1 +unfocused_hollow = true # Colors - [colors.primary] -background = "#080808" -foreground = "#CECECE" +# background = "#090909" +# background = "#ffffff" +foreground = "#ffffff" [colors.cursor] text = "#0E1415" -cursor = "#CECECE" +cursor = "#ffffff" [colors.selection] -text = "#CECECE" +text = "#ffffff" background = "#DDF0FF" [colors.normal] @@ -56,7 +59,7 @@ yellow = "#e9bf57" blue = "#4a88e4" magenta = "#915caf" cyan = "#23acdd" -white = "#cecece" +white = "#ffffff" [colors.bright] black = "#777777" @@ -66,7 +69,7 @@ yellow = "#f0bf7a" blue = "#6f8fdb" magenta = "#e987e9" cyan = "#4ac9e2" -white = "#FFFFFF" +white = "#F2CECE" [colors.search] @@ -76,9 +79,8 @@ focused_match.background = "#DDFFDD" focused_match.foreground = "#bbbbbb" [colors.vi_mode_cursor] -text = "#0E1415" -cursor = "#CECECE" - +text = "#ffffff" +cursor = "#ffffff" # Padding (to complement dynamic padding) [window.padding] @@ -94,5 +96,5 @@ multiplier = 3 hide_when_typing = true [debug] -render_timer = false +render_timer = false diff --git a/fish/completions/fisher.fish b/fish/completions/fisher.fish new file mode 100644 index 0000000..6d23ce4 --- /dev/null +++ b/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/fish/completions/tide.fish b/fish/completions/tide.fish new file mode 100644 index 0000000..2d3784d --- /dev/null +++ b/fish/completions/tide.fish @@ -0,0 +1,12 @@ +complete tide --no-files + +set -l subcommands bug-report configure + +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 "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/fish/conf.d/_tide_init.fish b/fish/conf.d/_tide_init.fish new file mode 100644 index 0000000..939f17c --- /dev/null +++ b/fish/conf.d/_tide_init.fish @@ -0,0 +1,41 @@ +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:" + echo -ns "fisher install ilancosman/tide@v5" | fish_indent --ansi + 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 ' (echo -ns "tide configure" | fish_indent --ansi) ' 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:" + echo -ns "fisher install ilancosman/tide@v5" | fish_indent --ansi + sleep 3 + end +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/fish/config.fish b/fish/config.fish new file mode 100644 index 0000000..846ee77 --- /dev/null +++ b/fish/config.fish @@ -0,0 +1,79 @@ +# ------------------------------------------------------------ +# Core environment +# ------------------------------------------------------------ +set -x EDITOR nvim +set -x PATH "$HOME/.local/bin" $PATH +set fish_greeting + +# ------------------------------------------------------------ +# Homebrew / Development paths +# ------------------------------------------------------------ +set -x PKG_CONFIG_PATH "/opt/homebrew/lib/pkgconfig" $PKG_CONFIG_PATH +set -x PKG_CONFIG_PATH "/opt/homebrew/Cellar/raylib/5.5/lib/pkgconfig" $PKG_CONFIG_PATH + +# ----------------------------- +# Homebrew (Apple Silicon) +# ----------------------------- +if test -d /opt/homebrew/bin + set -gx PATH /opt/homebrew/bin /opt/homebrew/sbin $PATH +end + +# ------------------------------------------------------------ +# Herd configuration (PHP / NVM) +# ------------------------------------------------------------ +# set -x HERD_PHP_83_INI_SCAN_DIR "/Users/nasr/Library/Application Support/Herd/config/php/83/" +# set -x HERD_PHP_82_INI_SCAN_DIR "/Users/nasr/Library/Application Support/Herd/config/php/82/" +# set -x HERD_PHP_85_INI_SCAN_DIR "/Users/nasr/Library/Application Support/Herd/config/php/85/" +# set -x HERD_PHP_84_INI_SCAN_DIR "/Users/nasr/Library/Application Support/Herd/config/php/84/" + +# set -x PATH "/Users/nasr/Library/Application Support/Herd/bin" $PATH + +# set -x NVM_DIR "/Users/nasr/Library/Application Support/Herd/config/nvm" +# test -f "$NVM_DIR/nvm.sh"; and source "$NVM_DIR/nvm.sh" + +# Load Herd’s shell hooks if they exist +# test -f "/Applications/Herd.app/Contents/Resources/config/shell/zshrc.zsh"; and source "/Applications/Herd.app/Contents/Resources/config/shell/zshrc.zsh" + +# ------------------------------------------------------------ +# Zoxide (navigation) +# ------------------------------------------------------------ + +zoxide init fish | source +alias cd "z" +alias zi "zoxide query -i" +alias zq "zoxide query" + +# ------------------------------------------------------------ +# Aliases +# ------------------------------------------------------------ +alias vim "nvim" +alias vi "nvim" +alias ls "lsd" + +alias attach "tmux attach-session -t" +alias new "tmux new-session -t" +alias list "tmux list-sessions" +alias nnd "~/nnd" + +# ------------------------------------------------------------ +# fzf-powered file selectors +# ------------------------------------------------------------ +function edit + set file (find . -type f ! -path '*/.*' | fzf --preview 'bat --style=full --color=always {} 2>/dev/null') + test -n "$file"; and nvim "$file" +end + +function cfg + set file (find ~/.config -type f | fzf --preview 'bat --style=full --color=always {} 2>/dev/null') + test -n "$file"; and nvim "$file" +end + +# Optional: EMSDK support +# ------------------------------------------------------------ +# source (~/emsdk/emsdk_env.sh | psub) + + +set -g fish_key_bindings fish_vi_key_bindings + +set -U tide_left_prompt_items (string match -v kubectl $tide_left_prompt_items) +set -U tide_right_prompt_items (string match -v kubectl $tide_right_prompt_items) diff --git a/fish/fish_plugins b/fish/fish_plugins new file mode 100644 index 0000000..073936e --- /dev/null +++ b/fish/fish_plugins @@ -0,0 +1,2 @@ +jorgebucaran/fisher +ilancosman/tide@v5 diff --git a/fish/fish_variables b/fish/fish_variables new file mode 100644 index 0000000..5ec1d38 --- /dev/null +++ b/fish/fish_variables @@ -0,0 +1,205 @@ +# This file contains fish universal variable definitions. +# VERSION: 3.0 +SETUVAR VIRTUAL_ENV_DISABLE_PROMPT:true +SETUVAR __fish_initialized:3800 +SETUVAR _fisher_ilancosman_2F_tide_40_v5_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_item_aws\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_character\x2efish\x1e\x7e/\x2econfig/fish/functions/_tide_item_chruby\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_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_virtual_env\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/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_jorgebucaran_2F_fisher_files:\x7e/\x2econfig/fish/functions/fisher\x2efish\x1e\x7e/\x2econfig/fish/completions/fisher\x2efish +SETUVAR _fisher_plugins:jorgebucaran/fisher\x1eilancosman/tide\x40v5 +SETUVAR _fisher_upgraded_to_4_4:\x1d +SETUVAR _tide_left_items:vi_mode\x1epwd\x1egit +SETUVAR _tide_prompt_11724:\x1b\x5b30m\x1b\x5b49m\x1b\x5b36m\x1b\x5b40m\x20I\x20\x1b\x5b90m\u2502\x1b\x5b40m\x20\x40PWD\x40\x20\x1b\x5b90m\u2502\x1b\x5b40m\x20\x1b\x5b37m\x1b\x5b92mfeature/fpu/cdp\x1b\x5b91m\x1b\x5b92m\x1b\x5b92m\x1b\x5b91m\x1b\x5b93m\x20\x2b4\x1b\x5b93m\x20\x211\x1b\x5b94m\x20\x1b\x5b30m\x1b\x5b49m\ue0b0\x1e\x1b\x5b30m\x1b\x5b49m\ue0b2\x1b\x5b31m\x1b\x5b40m\x20\u2718\x201\x20\x1b\x5b90m\u2502\x1b\x5b90m\x1b\x5b40m\x204s\x20\x1b\x5b90m\u2502\x1b\x5b90m\x1b\x5b40m\x2020\x3a49\x3a42\x20\x1b\x5b30m\x1b\x5b49m +SETUVAR _tide_prompt_16970:\x1b\x5b30m\x1b\x5b49m\x1b\x5b36m\x1b\x5b40m\x20I\x20\x1b\x5b90m\u2502\x1b\x5b40m\x20\x40PWD\x40\x20\x1b\x5b90m\u2502\x1b\x5b40m\x20\x1b\x5b37m\x1b\x5b92mfeature/fpu/cdp\x1b\x5b91m\x1b\x5b92m\x1b\x5b92m\x1b\x5b91m\x1b\x5b93m\x20\x2b4\x1b\x5b93m\x20\x211\x1b\x5b94m\x20\x1b\x5b30m\x1b\x5b49m\ue0b0\x1e\x1b\x5b30m\x1b\x5b49m\ue0b2\x1b\x5b31m\x1b\x5b40m\x20\u2718\x20127\x20\x1b\x5b90m\u2502\x1b\x5b90m\x1b\x5b40m\x2017\x3a09\x3a54\x20\x1b\x5b30m\x1b\x5b49m +SETUVAR _tide_prompt_2045:\x1b\x5b38\x3b2\x3b28\x3b28\x3b28m\x1b\x5b49m\ue0ba\x1b\x5b38\x3b2\x3b135\x3b175\x3b175m\x1b\x5b48\x3b2\x3b28\x3b28\x3b28m\x20I\x20\x1b\x5b38\x3b2\x3b148\x3b148\x3b148m\u2502\x1b\x5b48\x3b2\x3b28\x3b28\x3b28m\x20\x40PWD\x40\x20\x1b\x5b38\x3b2\x3b148\x3b148\x3b148m\u2502\x1b\x5b48\x3b2\x3b28\x3b28\x3b28m\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\x1b\x5b38\x3b2\x3b255\x3b0\x3b0m\x1b\x5b38\x3b2\x3b215\x3b175\x3b0m\x1b\x5b38\x3b2\x3b215\x3b175\x3b0m\x20\x215\x1b\x5b38\x3b2\x3b0\x3b175\x3b255m\x20\x3f5\x20\x1b\x5b38\x3b2\x3b28\x3b28\x3b28m\x1b\x5b49m\u2593\u2592\u2591\x1e\x1b\x5b38\x3b2\x3b28\x3b28\x3b28m\x1b\x5b49m\u2591\u2592\u2593\x1b\x5b38\x3b2\x3b95\x3b175\x3b0m\x1b\x5b48\x3b2\x3b28\x3b28\x3b28m\x20\u2714\x20\x1b\x5b38\x3b2\x3b148\x3b148\x3b148m\u2502\x1b\x5b38\x3b2\x3b95\x3b135\x3b135m\x1b\x5b48\x3b2\x3b28\x3b28\x3b28m\x2008\x3a36\x3a13\x20PM\x20\x1b\x5b38\x3b2\x3b28\x3b28\x3b28m\x1b\x5b49m\ue0bc +SETUVAR _tide_prompt_40991:\x1b\x5b30m\x1b\x5b49m\x1b\x5b36m\x1b\x5b40m\x20I\x20\x1b\x5b90m\u2502\x1b\x5b40m\x20\x40PWD\x40\x20\x1b\x5b30m\x1b\x5b49m\ue0b0\x1e\x1b\x5b30m\x1b\x5b49m\ue0b2\x1b\x5b31m\x1b\x5b40m\x20\u2718\x201\x20\x1b\x5b90m\u2502\x1b\x5b90m\x1b\x5b40m\x2012\x3a42\x3a03\x20\x1b\x5b30m\x1b\x5b49m +SETUVAR _tide_prompt_61601:\x1b\x5b30m\x1b\x5b49m\x1b\x5b36m\x1b\x5b40m\x20I\x20\x1b\x5b90m\u2502\x1b\x5b40m\x20\x40PWD\x40\x20\x1b\x5b90m\u2502\x1b\x5b40m\x20\x1b\x5b37m\x1b\x5b92mmain\x1b\x5b91m\x1b\x5b92m\x1b\x5b92m\x1b\x5b91m\x1b\x5b93m\x1b\x5b93m\x20\x212\x1b\x5b94m\x20\x3f2\x20\x1b\x5b30m\x1b\x5b49m\ue0b0\x1e\x1b\x5b30m\x1b\x5b49m\ue0b2\x1b\x5b32m\x1b\x5b40m\x20\u2714\x20\x1b\x5b90m\u2502\x1b\x5b90m\x1b\x5b40m\x206m\x201s\x20\x1b\x5b90m\u2502\x1b\x5b90m\x1b\x5b40m\x2016\x3a02\x3a59\x20\x1b\x5b30m\x1b\x5b49m +SETUVAR _tide_prompt_7216:\x1b\x5b38\x3b2\x3b28\x3b28\x3b28m\x1b\x5b49m\ue0ba\x1b\x5b38\x3b2\x3b135\x3b175\x3b175m\x1b\x5b48\x3b2\x3b28\x3b28\x3b28m\x20I\x20\x1b\x5b38\x3b2\x3b148\x3b148\x3b148m\u2502\x1b\x5b48\x3b2\x3b28\x3b28\x3b28m\x20\x40PWD\x40\x20\x1b\x5b38\x3b2\x3b148\x3b148\x3b148m\u2502\x1b\x5b48\x3b2\x3b28\x3b28\x3b28m\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\x1b\x5b38\x3b2\x3b255\x3b0\x3b0m\x1b\x5b38\x3b2\x3b215\x3b175\x3b0m\x1b\x5b38\x3b2\x3b215\x3b175\x3b0m\x20\x217\x1b\x5b38\x3b2\x3b0\x3b175\x3b255m\x20\x3f9\x20\x1b\x5b38\x3b2\x3b28\x3b28\x3b28m\x1b\x5b49m\u2593\u2592\u2591\x1e\x1b\x5b38\x3b2\x3b28\x3b28\x3b28m\x1b\x5b49m\u2591\u2592\u2593\x1b\x5b38\x3b2\x3b215\x3b0\x3b0m\x1b\x5b48\x3b2\x3b28\x3b28\x3b28m\x20\u2718\x20127\x20\x1b\x5b38\x3b2\x3b148\x3b148\x3b148m\u2502\x1b\x5b38\x3b2\x3b95\x3b135\x3b135m\x1b\x5b48\x3b2\x3b28\x3b28\x3b28m\x2008\x3a20\x3a09\x20PM\x20\x1b\x5b38\x3b2\x3b28\x3b28\x3b28m\x1b\x5b49m\ue0bc +SETUVAR _tide_prompt_83320:\x1b\x5b30m\x1b\x5b49m\x1b\x5b37m\x1b\x5b40m\x20D\x20\x1b\x5b90m\u2502\x1b\x5b40m\x20\x40PWD\x40\x20\x1b\x5b90m\u2502\x1b\x5b40m\x20\x1b\x5b37m\x1b\x5b92mmain\x1b\x5b91m\x1b\x5b92m\x1b\x5b92m\x1b\x5b91m\x1b\x5b93m\x1b\x5b93m\x20\x212\x1b\x5b94m\x20\x3f2\x20\x1b\x5b30m\x1b\x5b49m\ue0b0\x1e\x1b\x5b30m\x1b\x5b49m\ue0b2\x1b\x5b32m\x1b\x5b40m\x20\u2714\x20\x1b\x5b90m\u2502\x1b\x5b90m\x1b\x5b40m\x2018\x3a31\x3a09\x20\x1b\x5b30m\x1b\x5b49m +SETUVAR _tide_prompt_92597:\x1b\x5b30m\x1b\x5b49m\x1b\x5b36m\x1b\x5b40m\x20I\x20\x1b\x5b90m\u2502\x1b\x5b40m\x20\x40PWD\x40\x20\x1b\x5b30m\x1b\x5b49m\ue0b0\x1e\x1b\x5b30m\x1b\x5b49m\ue0b2\x1b\x5b32m\x1b\x5b40m\x20\u2714\x20\x1b\x5b90m\u2502\x1b\x5b90m\x1b\x5b40m\x2018\x3a25\x3a01\x20\x1b\x5b30m\x1b\x5b49m +SETUVAR _tide_right_items:status\x1ecmd_duration\x1econtext\x1ejobs\x1enode\x1evirtual_env\x1erustc\x1ejava\x1ephp\x1ego\x1etime +SETUVAR fish_color_autosuggestion:brblack +SETUVAR fish_color_cancel:\x2dr +SETUVAR fish_color_command:normal +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:white\x1e\x2d\x2dbackground\x3dbrblack\x1e\x2d\x2dbold +SETUVAR fish_color_selection:white\x1e\x2d\x2dbackground\x3dbrblack\x1e\x2d\x2dbold +SETUVAR fish_color_status:red +SETUVAR fish_color_user:brgreen +SETUVAR fish_color_valid_path:\x2d\x2dunderline +SETUVAR fish_key_bindings:fish_default_key_bindings +SETUVAR fish_pager_color_background:\x1d +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\x1e\x2d\x2dbold +SETUVAR fish_pager_color_secondary_background:\x1d +SETUVAR fish_pager_color_secondary_completion:\x1d +SETUVAR fish_pager_color_secondary_description:\x1d +SETUVAR fish_pager_color_secondary_prefix:\x1d +SETUVAR fish_pager_color_selected_background:\x2dr +SETUVAR fish_pager_color_selected_completion:\x1d +SETUVAR fish_pager_color_selected_description:\x1d +SETUVAR fish_pager_color_selected_prefix:\x1d +SETUVAR tide_aws_bg_color:1C1C1C +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_chruby_bg_color:1C1C1C +SETUVAR tide_chruby_color:B31209 +SETUVAR tide_chruby_icon:\ue23e +SETUVAR tide_cmd_duration_bg_color:1C1C1C +SETUVAR tide_cmd_duration_color:87875F +SETUVAR tide_cmd_duration_decimals:0 +SETUVAR tide_cmd_duration_icon:\x1d +SETUVAR tide_cmd_duration_threshold:3000 +SETUVAR tide_context_always_display:false +SETUVAR tide_context_bg_color:1C1C1C +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:1C1C1C +SETUVAR tide_crystal_color:FFFFFF +SETUVAR tide_crystal_icon:\u2b22 +SETUVAR tide_direnv_bg_color:1C1C1C +SETUVAR tide_direnv_bg_color_denied:1C1C1C +SETUVAR tide_direnv_color:D7AF00 +SETUVAR tide_direnv_color_denied:FF0000 +SETUVAR tide_direnv_icon:\u25bc +SETUVAR tide_distrobox_bg_color:1C1C1C +SETUVAR tide_distrobox_color:FF00FF +SETUVAR tide_distrobox_icon:\u2b22 +SETUVAR tide_docker_bg_color:1C1C1C +SETUVAR tide_docker_color:2496ED +SETUVAR tide_docker_default_contexts:default\x1ecolima +SETUVAR tide_docker_icon:\uf308 +SETUVAR tide_elixir_bg_color:1C1C1C +SETUVAR tide_elixir_color:4E2A8E +SETUVAR tide_elixir_icon:\ue62d +SETUVAR tide_gcloud_bg_color:1C1C1C +SETUVAR tide_gcloud_color:4285F4 +SETUVAR tide_gcloud_icon:\uf7ac +SETUVAR tide_git_bg_color:1C1C1C +SETUVAR tide_git_bg_color_unstable:1C1C1C +SETUVAR tide_git_bg_color_urgent:1C1C1C +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:\x1d +SETUVAR tide_git_truncation_length:24 +SETUVAR tide_git_truncation_strategy:\x1d +SETUVAR tide_go_bg_color:1C1C1C +SETUVAR tide_go_color:00ACD7 +SETUVAR tide_go_icon:\ue627 +SETUVAR tide_java_bg_color:1C1C1C +SETUVAR tide_java_color:ED8B00 +SETUVAR tide_java_icon:\ue256 +SETUVAR tide_jobs_bg_color:1C1C1C +SETUVAR tide_jobs_color:5FAF00 +SETUVAR tide_jobs_icon:\uf013 +SETUVAR tide_kubectl_bg_color:1C1C1C +SETUVAR tide_kubectl_color:326CE5 +SETUVAR tide_kubectl_icon:\u2388 +SETUVAR tide_left_prompt_frame_enabled:false +SETUVAR tide_left_prompt_items:vi_mode\x1epwd\x1egit +SETUVAR tide_left_prompt_prefix:\ue0ba +SETUVAR tide_left_prompt_separator_diff_color:\ue0b0 +SETUVAR tide_left_prompt_separator_same_color:\u2502 +SETUVAR tide_left_prompt_suffix:\u2593\u2592\u2591 +SETUVAR tide_nix_shell_bg_color:1C1C1C +SETUVAR tide_nix_shell_color:7EBAE4 +SETUVAR tide_nix_shell_icon:\uf313 +SETUVAR tide_node_bg_color:1C1C1C +SETUVAR tide_node_color:44883E +SETUVAR tide_node_icon:\u2b22 +SETUVAR tide_os_bg_color:1C1C1C +SETUVAR tide_os_color:EEEEEE +SETUVAR tide_os_icon:\uf179 +SETUVAR tide_php_bg_color:1C1C1C +SETUVAR tide_php_color:617CBE +SETUVAR tide_php_icon:\ue608 +SETUVAR tide_private_mode_bg_color:1C1C1C +SETUVAR tide_private_mode_color:FFFFFF +SETUVAR tide_private_mode_icon:\ufaf8 +SETUVAR tide_prompt_add_newline_before:false +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:true +SETUVAR tide_pulumi_bg_color:1C1C1C +SETUVAR tide_pulumi_color:F7BF2A +SETUVAR tide_pulumi_icon:\uf1b2 +SETUVAR tide_pwd_bg_color:1C1C1C +SETUVAR tide_pwd_color_anchors:00AFFF +SETUVAR tide_pwd_color_dirs:0087AF +SETUVAR tide_pwd_color_truncated_dirs:8787AF +SETUVAR tide_pwd_icon:\x1d +SETUVAR tide_pwd_icon_home:\x1d +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 +SETUVAR tide_right_prompt_frame_enabled:false +SETUVAR tide_right_prompt_items:status\x1ecmd_duration\x1econtext\x1ejobs\x1edirenv\x1enode\x1evirtual_env\x1erustc\x1ejava\x1ephp\x1epulumi\x1echruby\x1ego\x1egcloud\x1edistrobox\x1etoolbox\x1eterraform\x1eaws\x1enix_shell\x1ecrystal\x1eelixir\x1etime +SETUVAR tide_right_prompt_prefix:\u2591\u2592\u2593 +SETUVAR tide_right_prompt_separator_diff_color:\ue0b2 +SETUVAR tide_right_prompt_separator_same_color:\u2502 +SETUVAR tide_right_prompt_suffix:\ue0bc +SETUVAR tide_rustc_bg_color:1C1C1C +SETUVAR tide_rustc_color:F74C00 +SETUVAR tide_rustc_icon:\ue7a8 +SETUVAR tide_shlvl_bg_color:1C1C1C +SETUVAR tide_shlvl_color:d78700 +SETUVAR tide_shlvl_icon:\uf120 +SETUVAR tide_shlvl_threshold:1 +SETUVAR tide_status_bg_color:1C1C1C +SETUVAR tide_status_bg_color_failure:1C1C1C +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:1C1C1C +SETUVAR tide_terraform_color:844FBA +SETUVAR tide_terraform_icon:\x1d +SETUVAR tide_time_bg_color:1C1C1C +SETUVAR tide_time_color:5F8787 +SETUVAR tide_time_format:\x25r +SETUVAR tide_toolbox_bg_color:1C1C1C +SETUVAR tide_toolbox_color:613583 +SETUVAR tide_toolbox_icon:\u2b22 +SETUVAR tide_vi_mode_bg_color_default:1C1C1C +SETUVAR tide_vi_mode_bg_color_insert:1C1C1C +SETUVAR tide_vi_mode_bg_color_replace:1C1C1C +SETUVAR tide_vi_mode_bg_color_visual:1C1C1C +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_virtual_env_bg_color:1C1C1C +SETUVAR tide_virtual_env_color:00AFAF +SETUVAR tide_virtual_env_icon:\ue73c diff --git a/fish/functions/_tide_1_line_prompt.fish b/fish/functions/_tide_1_line_prompt.fish new file mode 100644 index 0000000..5772223 --- /dev/null +++ b/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/fish/functions/_tide_2_line_prompt.fish b/fish/functions/_tide_2_line_prompt.fish new file mode 100644 index 0000000..e9017af --- /dev/null +++ b/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/fish/functions/_tide_cache_variables.fish b/fish/functions/_tide_cache_variables.fish new file mode 100644 index 0000000..31e3850 --- /dev/null +++ b/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/fish/functions/_tide_detect_os.fish b/fish/functions/_tide_detect_os.fish new file mode 100644 index 0000000..5a3263f --- /dev/null +++ b/fish/functions/_tide_detect_os.fish @@ -0,0 +1,75 @@ +# 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 '*' + return 1 + end +end diff --git a/fish/functions/_tide_find_and_remove.fish b/fish/functions/_tide_find_and_remove.fish new file mode 100644 index 0000000..29f2180 --- /dev/null +++ b/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/fish/functions/_tide_item_aws.fish b/fish/functions/_tide_item_aws.fish new file mode 100644 index 0000000..7cb6338 --- /dev/null +++ b/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/fish/functions/_tide_item_character.fish b/fish/functions/_tide_item_character.fish new file mode 100644 index 0000000..10bb324 --- /dev/null +++ b/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/fish/functions/_tide_item_chruby.fish b/fish/functions/_tide_item_chruby.fish new file mode 100644 index 0000000..02d5fbd --- /dev/null +++ b/fish/functions/_tide_item_chruby.fish @@ -0,0 +1,3 @@ +function _tide_item_chruby + test -n "$RUBY_VERSION" && _tide_print_item chruby $tide_chruby_icon' ' $RUBY_VERSION +end diff --git a/fish/functions/_tide_item_cmd_duration.fish b/fish/functions/_tide_item_cmd_duration.fish new file mode 100644 index 0000000..bc48bac --- /dev/null +++ b/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/fish/functions/_tide_item_context.fish b/fish/functions/_tide_item_context.fish new file mode 100644 index 0000000..575c438 --- /dev/null +++ b/fish/functions/_tide_item_context.fish @@ -0,0 +1,15 @@ +function _tide_item_context + if set -q SSH_TTY + set -lx tide_context_color $tide_context_color_ssh + test "$tide_context_hostname_parts" = 0 && _tide_print_item context $USER || + h=(string split . $hostname) _tide_print_item context $USER@(string join . $h[..$tide_context_hostname_parts]) + else if test "$EUID" = 0 + set -lx tide_context_color $tide_context_color_root + test "$tide_context_hostname_parts" = 0 && _tide_print_item context $USER || + h=(string split . $hostname) _tide_print_item context $USER@(string join . $h[..$tide_context_hostname_parts]) + else if test "$tide_context_always_display" = true + set -lx tide_context_color $tide_context_color_default + test "$tide_context_hostname_parts" = 0 && _tide_print_item context $USER || + h=(string split . $hostname) _tide_print_item context $USER@(string join . $h[..$tide_context_hostname_parts]) + end +end diff --git a/fish/functions/_tide_item_crystal.fish b/fish/functions/_tide_item_crystal.fish new file mode 100644 index 0000000..cec9752 --- /dev/null +++ b/fish/functions/_tide_item_crystal.fish @@ -0,0 +1,4 @@ +function _tide_item_crystal + path is $_tide_parent_dirs/shard.yml && + _tide_print_item crystal $tide_crystal_icon' ' (crystal --version | string match -r "[\d.]+")[1] +end diff --git a/fish/functions/_tide_item_direnv.fish b/fish/functions/_tide_item_direnv.fish new file mode 100644 index 0000000..5084674 --- /dev/null +++ b/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/fish/functions/_tide_item_distrobox.fish b/fish/functions/_tide_item_distrobox.fish new file mode 100644 index 0000000..5e06a8b --- /dev/null +++ b/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/fish/functions/_tide_item_git.fish b/fish/functions/_tide_item_git.fish new file mode 100644 index 0000000..c419695 --- /dev/null +++ b/fish/functions/_tide_item_git.fish @@ -0,0 +1,67 @@ +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 + read -f step <$gdir/rebase-merge/msgnum + read -f total_steps <$gdir/rebase-merge/end + test -f $gdir/rebase-merge/interactive && set -f operation rebase-i || set -f operation rebase-m + else if test -d $gdir/rebase-apply + read -f step <$gdir/rebase-apply/next + read -f total_steps <$gdir/rebase-apply/last + 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/fish/functions/_tide_item_go.fish b/fish/functions/_tide_item_go.fish new file mode 100644 index 0000000..7c5919f --- /dev/null +++ b/fish/functions/_tide_item_go.fish @@ -0,0 +1,4 @@ +function _tide_item_go + path is $_tide_parent_dirs/go.mod && + _tide_print_item go $tide_go_icon' ' (go version | string match -r "[\d.]+") +end diff --git a/fish/functions/_tide_item_java.fish b/fish/functions/_tide_item_java.fish new file mode 100644 index 0000000..6105acc --- /dev/null +++ b/fish/functions/_tide_item_java.fish @@ -0,0 +1,4 @@ +function _tide_item_java + path is $_tide_parent_dirs/pom.xml && + _tide_print_item java $tide_java_icon' ' (java -version &| string match -r "[\d.]+")[1] +end diff --git a/fish/functions/_tide_item_jobs.fish b/fish/functions/_tide_item_jobs.fish new file mode 100644 index 0000000..96cf902 --- /dev/null +++ b/fish/functions/_tide_item_jobs.fish @@ -0,0 +1,3 @@ +function _tide_item_jobs + set -q _tide_jobs && _tide_print_item jobs $tide_jobs_icon +end diff --git a/fish/functions/_tide_item_kubectl.fish b/fish/functions/_tide_item_kubectl.fish new file mode 100644 index 0000000..ab044b3 --- /dev/null +++ b/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/fish/functions/_tide_item_nix_shell.fish b/fish/functions/_tide_item_nix_shell.fish new file mode 100644 index 0000000..647f606 --- /dev/null +++ b/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/fish/functions/_tide_item_node.fish b/fish/functions/_tide_item_node.fish new file mode 100644 index 0000000..0588051 --- /dev/null +++ b/fish/functions/_tide_item_node.fish @@ -0,0 +1,4 @@ +function _tide_item_node + path is $_tide_parent_dirs/package.json && + _tide_print_item node $tide_node_icon' ' (node --version | string trim --chars=v) +end diff --git a/fish/functions/_tide_item_os.fish b/fish/functions/_tide_item_os.fish new file mode 100644 index 0000000..8a6208c --- /dev/null +++ b/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/fish/functions/_tide_item_php.fish b/fish/functions/_tide_item_php.fish new file mode 100644 index 0000000..abc104e --- /dev/null +++ b/fish/functions/_tide_item_php.fish @@ -0,0 +1,4 @@ +function _tide_item_php + path is $_tide_parent_dirs/composer.json && + _tide_print_item php $tide_php_icon' ' (php --version | string match -r 'PHP ([\d.]+)')[2] +end diff --git a/fish/functions/_tide_item_private_mode.fish b/fish/functions/_tide_item_private_mode.fish new file mode 100644 index 0000000..4eb4684 --- /dev/null +++ b/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/fish/functions/_tide_item_pulumi.fish b/fish/functions/_tide_item_pulumi.fish new file mode 100644 index 0000000..9f5e2db --- /dev/null +++ b/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 sub -e40 | read -f path_hash + else if command -q shasum + echo -n "$yaml_path" | shasum | string sub -e40 | read -f path_hash + end + + if test -n "$path_hash" + string match -rg 'name: *(.*)' <$yaml_path | read -l project_name + set -l workspace_file "$HOME/.pulumi/workspaces/$project_name-$path_hash-workspace.json" + + if test -e $workspace_file + string match -rg '"stack": *"(.*)"' <$workspace_file | read -l stack + _tide_print_item pulumi $tide_pulumi_icon' ' $stack + end + end + end +end diff --git a/fish/functions/_tide_item_rustc.fish b/fish/functions/_tide_item_rustc.fish new file mode 100644 index 0000000..2e71645 --- /dev/null +++ b/fish/functions/_tide_item_rustc.fish @@ -0,0 +1,4 @@ +function _tide_item_rustc + path is $_tide_parent_dirs/Cargo.toml && + _tide_print_item rustc $tide_rustc_icon' ' (rustc --version | string split ' ')[2] +end diff --git a/fish/functions/_tide_item_shlvl.fish b/fish/functions/_tide_item_shlvl.fish new file mode 100644 index 0000000..95dd5ff --- /dev/null +++ b/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/fish/functions/_tide_item_status.fish b/fish/functions/_tide_item_status.fish new file mode 100644 index 0000000..3a040fd --- /dev/null +++ b/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/fish/functions/_tide_item_terraform.fish b/fish/functions/_tide_item_terraform.fish new file mode 100644 index 0000000..8d99fb7 --- /dev/null +++ b/fish/functions/_tide_item_terraform.fish @@ -0,0 +1,6 @@ +function _tide_item_terraform + if path is $_tide_parent_dirs/.terraform + terraform workspace show | read -l workspace + test $workspace != default && _tide_print_item terraform $tide_terraform_icon' ' $workspace + end +end diff --git a/fish/functions/_tide_item_time.fish b/fish/functions/_tide_item_time.fish new file mode 100644 index 0000000..b8522bc --- /dev/null +++ b/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/fish/functions/_tide_item_toolbox.fish b/fish/functions/_tide_item_toolbox.fish new file mode 100644 index 0000000..0b33f29 --- /dev/null +++ b/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="(.*)"' \..|.)\" \$dir_section + while v=\$parent_dir/\$trunc*/ set -q v[2] && string match -qr \"(?\$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/fish/functions/_tide_remove_unusable_items.fish b/fish/functions/_tide_remove_unusable_items.fish new file mode 100644 index 0000000..a2e5698 --- /dev/null +++ b/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 chruby crystal direnv distrobox docker elixir gcloud git go java kubectl nix_shell node php pulumi rustc terraform toolbox virtual_env + 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 virtual_env + set cli_names python python3 + case nix_shell + set cli_names nix nix-shell + 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/fish/functions/_tide_sub_bug-report.fish b/fish/functions/_tide_sub_bug-report.fish new file mode 100644 index 0000000..5f087c8 --- /dev/null +++ b/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@v5" + 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/fish/functions/_tide_sub_configure.fish b/fish/functions/_tide_sub_configure.fish new file mode 100644 index 0000000..cb87290 --- /dev/null +++ b/fish/functions/_tide_sub_configure.fish @@ -0,0 +1,95 @@ +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 + 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 + command -q clear && clear + set_color -o + string pad --width (math --scale=0 "$fake_columns/2" + (string length $text)/2) $text + set_color normal +end + +function _tide_option -a symbol text + set -ga _tide_option_list $symbol + + set_color -o + echo "($symbol) $text" + set_color normal +end + +function _tide_menu + set -l list_with_slashes (string join '/' $_tide_option_list) + + echo '(r) Restart from the beginning' + echo '(q) Quit and do nothing'\n + + while true + set_color -o + read --nchars 1 --prompt-str "Choice [$list_with_slashes/r/q] " input + set_color normal + + switch $input + case r + set -e _tide_option_list + _next_choice all/style + break + case q + set -e _tide_selected_option # Skip through all the _next_choices + set -e _tide_option_list + command -q clear && clear + break + case $_tide_option_list + set -e _tide_option_list + set -g _tide_selected_option $input + break + end + end +end + +function _tide_display_prompt -a var_name var_value + test -n "$var_name" && set -g $var_name $var_value + _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" + + string unescape $prompt[2..] + set_color normal + echo +end diff --git a/fish/functions/fish_mode_prompt.fish b/fish/functions/fish_mode_prompt.fish new file mode 100644 index 0000000..f37cf7d --- /dev/null +++ b/fish/functions/fish_mode_prompt.fish @@ -0,0 +1 @@ +# Disable default vi prompt diff --git a/fish/functions/fish_prompt.fish b/fish/functions/fish_prompt.fish new file mode 100644 index 0000000..3e820c4 --- /dev/null +++ b/fish/functions/fish_prompt.fish @@ -0,0 +1,90 @@ +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) + + eval " +function fish_prompt + _tide_status=\$status _tide_pipestatus=\$pipestatus if not set -e _tide_repaint + jobs -q && set -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" +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" + + eval " +function fish_prompt + _tide_status=\$status _tide_pipestatus=\$pipestatus if not set -e _tide_repaint + jobs -q && set -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 + +eval "function _tide_on_fish_exit --on-event fish_exit + set -e $prompt_var +end" diff --git a/fish/functions/fisher.fish b/fish/functions/fisher.fish new file mode 100644 index 0000000..e915cb8 --- /dev/null +++ b/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/fish/functions/tide.fish b/fish/functions/tide.fish new file mode 100644 index 0000000..84bbbf1 --- /dev/null +++ b/fish/functions/tide.fish @@ -0,0 +1,27 @@ +function tide --description 'Manage your Tide prompt' + argparse --stop-nonopt v/version h/help -- $argv + + if set -q _flag_version + echo 'tide, version 5.6.0' + 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' \ + ' bug-report print info for use in bug reports' +end diff --git a/fish/functions/tide/configure/choices/all/finish.fish b/fish/functions/tide/configure/choices/all/finish.fish new file mode 100644 index 0000000..f60a128 --- /dev/null +++ b/fish/functions/tide/configure/choices/all/finish.fish @@ -0,0 +1,33 @@ +function finish + set_color red + _tide_title 'Overwrite tide config?' + set_color normal + + _tide_option y Yes + echo + + _tide_menu + switch $_tide_selected_option + case y + _tide_finish + command -q clear && clear + end +end + +function _tide_finish + set -e _tide_selected_option # Skip through all the _next_choices + + # 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 + source (functions --details fish_prompt) +end diff --git a/fish/functions/tide/configure/choices/all/icons.fish b/fish/functions/tide/configure/choices/all/icons.fish new file mode 100644 index 0000000..e53bffa --- /dev/null +++ b/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 + switch $_tide_selected_option + case 1 + _disable_icons + end + _next_choice all/finish +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/fish/functions/tide/configure/choices/all/prompt_colors.fish b/fish/functions/tide/configure/choices/all/prompt_colors.fish new file mode 100644 index 0000000..90b1a9d --- /dev/null +++ b/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 + switch $_tide_selected_option + case 1 + _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 2 + _next_choice all/show_time + end +end diff --git a/fish/functions/tide/configure/choices/all/prompt_connection.fish b/fish/functions/tide/configure/choices/all/prompt_connection.fish new file mode 100644 index 0000000..ae31ef3 --- /dev/null +++ b/fish/functions/tide/configure/choices/all/prompt_connection.fish @@ -0,0 +1,28 @@ +function prompt_connection + _tide_title 'Prompt Connection' + + _tide_option 1 Disconnected + _tide_display_prompt fake_tide_prompt_icon_connection ' ' + + _tide_option 2 Dotted + _tide_display_prompt fake_tide_prompt_icon_connection '·' + + _tide_option 3 Solid + _tide_display_prompt fake_tide_prompt_icon_connection '─' + + _tide_menu + switch $_tide_selected_option + case 1 + set -g fake_tide_prompt_icon_connection ' ' + case 2 + set -g fake_tide_prompt_icon_connection '·' + case 3 + 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_prompt_frame + end +end diff --git a/fish/functions/tide/configure/choices/all/prompt_connection_andor_frame_color.fish b/fish/functions/tide/configure/choices/all/prompt_connection_andor_frame_color.fish new file mode 100644 index 0000000..b8803b4 --- /dev/null +++ b/fish/functions/tide/configure/choices/all/prompt_connection_andor_frame_color.fish @@ -0,0 +1,36 @@ +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 + _tide_display_prompt fake_tide_prompt_color_frame_and_connection 808080 + + _tide_option 2 Light + _tide_display_prompt fake_tide_prompt_color_frame_and_connection 6C6C6C + + _tide_option 3 Dark + _tide_display_prompt fake_tide_prompt_color_frame_and_connection 585858 + + _tide_option 4 Darkest + _tide_display_prompt fake_tide_prompt_color_frame_and_connection 444444 + + _tide_menu + switch $_tide_selected_option + case 1 + set -g fake_tide_prompt_color_frame_and_connection 808080 + case 2 + set -g fake_tide_prompt_color_frame_and_connection 6C6C6C + case 3 + set -g fake_tide_prompt_color_frame_and_connection 585858 + case 4 + set -g fake_tide_prompt_color_frame_and_connection 444444 + end + _next_choice all/prompt_spacing +end diff --git a/fish/functions/tide/configure/choices/all/prompt_spacing.fish b/fish/functions/tide/configure/choices/all/prompt_spacing.fish new file mode 100644 index 0000000..a5bb98b --- /dev/null +++ b/fish/functions/tide/configure/choices/all/prompt_spacing.fish @@ -0,0 +1,21 @@ +function prompt_spacing + _tide_title 'Prompt Spacing' + + _tide_option 1 Compact + _tide_display_prompt + printf \e\[1A # Move cursor up 1 row + _tide_display_prompt + + _tide_option 2 Sparse + _tide_display_prompt + _tide_display_prompt + + _tide_menu + switch $_tide_selected_option + case 1 + set -g fake_tide_prompt_add_newline_before false + case 2 + set -g fake_tide_prompt_add_newline_before true + end + _next_choice all/icons +end diff --git a/fish/functions/tide/configure/choices/all/show_time.fish b/fish/functions/tide/configure/choices/all/show_time.fish new file mode 100644 index 0000000..8cf1843 --- /dev/null +++ b/fish/functions/tide/configure/choices/all/show_time.fish @@ -0,0 +1,31 @@ +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' + _tide_display_prompt fake_tide_time_format %T + + _tide_option 3 '12-hour format' + _tide_display_prompt fake_tide_time_format '%r' + + _tide_menu + switch $_tide_selected_option + case 1 + set -g fake_tide_time_format '' + set -e fake_tide_right_prompt_items[-1] + case 2 + set -g fake_tide_time_format %T + case 3 + 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/fish/functions/tide/configure/choices/all/style.fish b/fish/functions/tide/configure/choices/all/style.fish new file mode 100644 index 0000000..ae52bc5 --- /dev/null +++ b/fish/functions/tide/configure/choices/all/style.fish @@ -0,0 +1,57 @@ +function style + _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_style_menu + switch $_tide_selected_option + case 1 + _load_config lean + set -g _tide_configure_style lean + case 2 + _load_config classic + set -g _tide_configure_style classic + case 3 + _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)/../../configs/$name.fish | source +end + +function _tide_style_menu # Exactly like _tide_menu except that it doesn't have (r) option + set -l list_with_slashes (string join '/' $_tide_option_list) + + echo '(q) Quit and do nothing'\n + + while true + set_color -o + read --nchars 1 --prompt-str "Choice [$list_with_slashes/q] " input + set_color normal + + switch $input + case q + set -e _tide_selected_option # Skip through all the _next_choices + set -e _tide_option_list + command -q clear && clear + break + case $_tide_option_list + set -e _tide_option_list + set -g _tide_selected_option $input + break + end + end +end diff --git a/fish/functions/tide/configure/choices/classic/classic_prompt_color.fish b/fish/functions/tide/configure/choices/classic/classic_prompt_color.fish new file mode 100644 index 0000000..2189f36 --- /dev/null +++ b/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 + switch $_tide_selected_option + case 1 + _set_all_items_bg_color 585858 + case 2 + _set_all_items_bg_color 444444 + case 3 + _set_all_items_bg_color 303030 + case 4 + _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/fish/functions/tide/configure/choices/classic/classic_prompt_separators.fish b/fish/functions/tide/configure/choices/classic/classic_prompt_separators.fish new file mode 100644 index 0000000..17b88e4 --- /dev/null +++ b/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 + switch $_tide_selected_option + case 1 + set -g fake_tide_left_prompt_separator_same_color  + set -g fake_tide_right_prompt_separator_same_color  + case 2 + set -g fake_tide_left_prompt_separator_same_color '│' + set -g fake_tide_right_prompt_separator_same_color '│' + case 3 + set -g fake_tide_left_prompt_separator_same_color '╱' + set -g fake_tide_right_prompt_separator_same_color '╱' + case 4 + 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/fish/functions/tide/configure/choices/lean/lean_prompt_height.fish b/fish/functions/tide/configure/choices/lean/lean_prompt_height.fish new file mode 100644 index 0000000..4db04a8 --- /dev/null +++ b/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 + switch $_tide_selected_option + case 1 + _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 2 + _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/fish/functions/tide/configure/choices/powerline/powerline_prompt_frame.fish b/fish/functions/tide/configure/choices/powerline/powerline_prompt_frame.fish new file mode 100644 index 0000000..19b3588 --- /dev/null +++ b/fish/functions/tide/configure/choices/powerline/powerline_prompt_frame.fish @@ -0,0 +1,46 @@ +function powerline_prompt_frame + _tide_title 'Prompt Frame' + + _tide_option 1 'No frame' + set fake_tide_left_prompt_frame_enabled false + set fake_tide_right_prompt_frame_enabled false + set -a fake_tide_left_prompt_items character + _tide_display_prompt + set -e fake_tide_left_prompt_items[-1] + + _tide_option 2 Left + set fake_tide_left_prompt_frame_enabled true + set fake_tide_right_prompt_frame_enabled false + _tide_display_prompt + + _tide_option 3 Right + set fake_tide_left_prompt_frame_enabled false + set fake_tide_right_prompt_frame_enabled true + set -a fake_tide_left_prompt_items character + _tide_display_prompt + set -e fake_tide_left_prompt_items[-1] + + _tide_option 4 Full + set fake_tide_left_prompt_frame_enabled true + set fake_tide_right_prompt_frame_enabled true + _tide_display_prompt + + _tide_menu + switch $_tide_selected_option + case 1 + set fake_tide_left_prompt_frame_enabled false + set fake_tide_right_prompt_frame_enabled false + set -a fake_tide_left_prompt_items character + case 2 + set fake_tide_left_prompt_frame_enabled true + set fake_tide_right_prompt_frame_enabled false + case 3 + set fake_tide_left_prompt_frame_enabled false + set fake_tide_right_prompt_frame_enabled true + set -a fake_tide_left_prompt_items character + case 4 + set fake_tide_left_prompt_frame_enabled true + set fake_tide_right_prompt_frame_enabled true + end + _next_choice all/prompt_connection_andor_frame_color +end diff --git a/fish/functions/tide/configure/choices/powerline/powerline_prompt_heads.fish b/fish/functions/tide/configure/choices/powerline/powerline_prompt_heads.fish new file mode 100644 index 0000000..ac187c9 --- /dev/null +++ b/fish/functions/tide/configure/choices/powerline/powerline_prompt_heads.fish @@ -0,0 +1,40 @@ +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 Blurred + set -g fake_tide_left_prompt_suffix '▓▒░' + set -g fake_tide_right_prompt_prefix '░▒▓' + _tide_display_prompt + + _tide_option 3 Slanted + set -g fake_tide_left_prompt_suffix '' + set -g fake_tide_right_prompt_prefix '' + _tide_display_prompt + + _tide_option 4 Round + set -g fake_tide_left_prompt_suffix '' + set -g fake_tide_right_prompt_prefix '' + _tide_display_prompt + + _tide_menu + switch $_tide_selected_option + case 1 + set -g fake_tide_left_prompt_suffix  + set -g fake_tide_right_prompt_prefix  + case 2 + set -g fake_tide_left_prompt_suffix '▓▒░' + set -g fake_tide_right_prompt_prefix '░▒▓' + case 3 + set -g fake_tide_left_prompt_suffix '' + set -g fake_tide_right_prompt_prefix '' + case 4 + 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/fish/functions/tide/configure/choices/powerline/powerline_prompt_height.fish b/fish/functions/tide/configure/choices/powerline/powerline_prompt_height.fish new file mode 100644 index 0000000..83fef05 --- /dev/null +++ b/fish/functions/tide/configure/choices/powerline/powerline_prompt_height.fish @@ -0,0 +1,30 @@ +function powerline_prompt_height + _tide_title 'Prompt Height' + + _tide_option 1 'One line' + _tide_find_and_remove newline fake_tide_left_prompt_items + set fake_tide_left_prompt_frame_enabled false + set fake_tide_right_prompt_frame_enabled false + _tide_display_prompt + + _tide_option 2 'Two lines' + set -g fake_tide_left_prompt_items $fake_tide_left_prompt_items newline + set fake_tide_left_prompt_frame_enabled true + set fake_tide_right_prompt_frame_enabled true + _tide_display_prompt + + _tide_menu + switch $_tide_selected_option + case 1 + _tide_find_and_remove newline 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 2 + _tide_find_and_remove newline fake_tide_left_prompt_items + set -g fake_tide_left_prompt_items $fake_tide_left_prompt_items newline + set fake_tide_left_prompt_frame_enabled true + set fake_tide_right_prompt_frame_enabled true + _next_choice all/prompt_connection + end +end diff --git a/fish/functions/tide/configure/choices/powerline/powerline_prompt_tails.fish b/fish/functions/tide/configure/choices/powerline/powerline_prompt_tails.fish new file mode 100644 index 0000000..02f4609 --- /dev/null +++ b/fish/functions/tide/configure/choices/powerline/powerline_prompt_tails.fish @@ -0,0 +1,48 @@ +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 Blurred + set -g fake_tide_left_prompt_prefix '░▒▓' + set -g fake_tide_right_prompt_suffix '▓▒░' + _tide_display_prompt + + _tide_option 3 Sharp + set -g fake_tide_left_prompt_prefix  + set -g fake_tide_right_prompt_suffix  + _tide_display_prompt + + _tide_option 4 Slanted + set -g fake_tide_left_prompt_prefix '' + set -g fake_tide_right_prompt_suffix '' + _tide_display_prompt + + _tide_option 5 Round + set -g fake_tide_left_prompt_prefix '' + set -g fake_tide_right_prompt_suffix '' + _tide_display_prompt + + _tide_menu + switch $_tide_selected_option + case 1 + set -g fake_tide_left_prompt_prefix '' + set -g fake_tide_right_prompt_suffix '' + case 2 + set -g fake_tide_left_prompt_prefix '░▒▓' + set -g fake_tide_right_prompt_suffix '▓▒░' + case 3 + set -g fake_tide_left_prompt_prefix  + set -g fake_tide_right_prompt_suffix  + case 4 + set -g fake_tide_left_prompt_prefix '' + set -g fake_tide_right_prompt_suffix '' + case 5 + set -g fake_tide_left_prompt_prefix '' + set -g fake_tide_right_prompt_suffix '' + end + _next_choice powerline/powerline_prompt_height +end diff --git a/fish/functions/tide/configure/choices/rainbow/rainbow_prompt_separators.fish b/fish/functions/tide/configure/choices/rainbow/rainbow_prompt_separators.fish new file mode 100644 index 0000000..29f6ccc --- /dev/null +++ b/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 + switch $_tide_selected_option + case 1 + set -g fake_tide_left_prompt_separator_diff_color  + set -g fake_tide_right_prompt_separator_diff_color  + case 2 + set -g fake_tide_left_prompt_separator_diff_color '' + set -g fake_tide_right_prompt_separator_diff_color '' + case 3 + set -g fake_tide_left_prompt_separator_diff_color '' + set -g fake_tide_right_prompt_separator_diff_color '' + case 4 + 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/fish/functions/tide/configure/configs/classic.fish b/fish/functions/tide/configure/configs/classic.fish new file mode 100644 index 0000000..f844676 --- /dev/null +++ b/fish/functions/tide/configure/configs/classic.fish @@ -0,0 +1,151 @@ +tide_aws_bg_color 444444 +tide_aws_color FF9900 +tide_aws_icon  +tide_character_color $_tide_color_green +tide_character_color_failure FF0000 +tide_character_icon ❯ +tide_character_vi_icon_default ❮ +tide_character_vi_icon_replace ▶ +tide_character_vi_icon_visual V +tide_chruby_bg_color 444444 +tide_chruby_color B31209 +tide_chruby_icon  +tide_cmd_duration_bg_color 444444 +tide_cmd_duration_color 87875F +tide_cmd_duration_decimals 0 +tide_cmd_duration_icon +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_crystal_icon ⬢ +tide_direnv_bg_color 444444 +tide_direnv_bg_color_denied 444444 +tide_direnv_color $_tide_color_gold +tide_direnv_color_denied FF0000 +tide_direnv_icon ▼ +tide_distrobox_bg_color 444444 +tide_distrobox_color FF00FF +tide_distrobox_icon ⬢ +tide_docker_bg_color 444444 +tide_docker_color 2496ED +tide_docker_default_contexts default colima +tide_docker_icon  +tide_elixir_bg_color 444444 +tide_elixir_color 4E2A8E +tide_elixir_icon  +tide_gcloud_bg_color 444444 +tide_gcloud_color 4285F4 +tide_gcloud_icon  +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_icon +tide_git_truncation_length 24 +tide_git_truncation_strategy +tide_go_bg_color 444444 +tide_go_color 00ACD7 +tide_go_icon  +tide_java_bg_color 444444 +tide_java_color ED8B00 +tide_java_icon  +tide_jobs_bg_color 444444 +tide_jobs_color $_tide_color_dark_green +tide_jobs_icon  +tide_kubectl_bg_color 444444 +tide_kubectl_color 326CE5 +tide_kubectl_icon ⎈ +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_nix_shell_icon  +tide_node_bg_color 444444 +tide_node_color 44883E +tide_node_icon ⬢ +tide_os_bg_color 444444 +tide_os_color EEEEEE +tide_os_icon $os_branding_icon +tide_php_bg_color 444444 +tide_php_color 617CBE +tide_php_icon  +tide_private_mode_bg_color 444444 +tide_private_mode_color FFFFFF +tide_private_mode_icon 﫸 +tide_prompt_add_newline_before true +tide_prompt_color_frame_and_connection 6C6C6C +tide_prompt_color_separator_same_color 949494 +tide_prompt_icon_connection ' ' +tide_prompt_min_cols 34 +tide_prompt_pad_items true +tide_pulumi_bg_color 444444 +tide_pulumi_color F7BF2A +tide_pulumi_icon '' +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_icon +tide_pwd_icon_home +tide_pwd_icon_unwritable  +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 +tide_right_prompt_frame_enabled true +tide_right_prompt_items status cmd_duration context jobs direnv node virtual_env rustc java php pulumi chruby go gcloud kubectl distrobox toolbox terraform aws nix_shell crystal elixir +tide_right_prompt_prefix  +tide_right_prompt_separator_diff_color  +tide_right_prompt_separator_same_color  +tide_right_prompt_suffix '' +tide_rustc_bg_color 444444 +tide_rustc_color F74C00 +tide_rustc_icon  +tide_shlvl_bg_color 444444 +tide_shlvl_color d78700 +tide_shlvl_icon  +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_status_icon ✔ +tide_status_icon_failure ✘ +tide_terraform_bg_color 444444 +tide_terraform_color 844FBA +tide_terraform_icon +tide_time_bg_color 444444 +tide_time_color 5F8787 +tide_time_format %T +tide_toolbox_bg_color 444444 +tide_toolbox_color 613583 +tide_toolbox_icon ⬢ +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_vi_mode_icon_default D +tide_vi_mode_icon_insert I +tide_vi_mode_icon_replace R +tide_vi_mode_icon_visual V +tide_virtual_env_bg_color 444444 +tide_virtual_env_color 00AFAF +tide_virtual_env_icon  diff --git a/fish/functions/tide/configure/configs/classic_16color.fish b/fish/functions/tide/configure/configs/classic_16color.fish new file mode 100644 index 0000000..6043117 --- /dev/null +++ b/fish/functions/tide/configure/configs/classic_16color.fish @@ -0,0 +1,87 @@ +tide_aws_bg_color black +tide_aws_color yellow +tide_character_color brgreen +tide_character_color_failure brred +tide_chruby_bg_color black +tide_chruby_color red +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_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_virtual_env_bg_color black +tide_virtual_env_color cyan diff --git a/fish/functions/tide/configure/configs/lean.fish b/fish/functions/tide/configure/configs/lean.fish new file mode 100644 index 0000000..853bde9 --- /dev/null +++ b/fish/functions/tide/configure/configs/lean.fish @@ -0,0 +1,151 @@ +tide_aws_bg_color normal +tide_aws_color FF9900 +tide_aws_icon  +tide_character_color $_tide_color_green +tide_character_color_failure FF0000 +tide_character_icon ❯ +tide_character_vi_icon_default ❮ +tide_character_vi_icon_replace ▶ +tide_character_vi_icon_visual V +tide_chruby_bg_color normal +tide_chruby_color B31209 +tide_chruby_icon  +tide_cmd_duration_bg_color normal +tide_cmd_duration_color 87875F +tide_cmd_duration_decimals 0 +tide_cmd_duration_icon +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_crystal_icon ⬢ +tide_direnv_bg_color normal +tide_direnv_bg_color_denied normal +tide_direnv_color $_tide_color_gold +tide_direnv_color_denied FF0000 +tide_direnv_icon ▼ +tide_distrobox_bg_color normal +tide_distrobox_color FF00FF +tide_distrobox_icon ⬢ +tide_docker_bg_color normal +tide_docker_color 2496ED +tide_docker_default_contexts default colima +tide_docker_icon  +tide_elixir_bg_color normal +tide_elixir_color 4E2A8E +tide_elixir_icon  +tide_gcloud_bg_color normal +tide_gcloud_color 4285F4 +tide_gcloud_icon  +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_icon +tide_git_truncation_length 24 +tide_git_truncation_strategy +tide_go_bg_color normal +tide_go_color 00ACD7 +tide_go_icon  +tide_java_bg_color normal +tide_java_color ED8B00 +tide_java_icon  +tide_jobs_bg_color normal +tide_jobs_color $_tide_color_dark_green +tide_jobs_icon  +tide_kubectl_bg_color normal +tide_kubectl_color 326CE5 +tide_kubectl_icon ⎈ +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_nix_shell_icon  +tide_node_bg_color normal +tide_node_color 44883E +tide_node_icon ⬢ +tide_os_bg_color normal +tide_os_color normal +tide_os_icon $os_branding_icon +tide_php_bg_color normal +tide_php_color 617CBE +tide_php_icon  +tide_private_mode_bg_color normal +tide_private_mode_color FFFFFF +tide_private_mode_icon 﫸 +tide_prompt_add_newline_before true +tide_prompt_color_frame_and_connection 6C6C6C +tide_prompt_color_separator_same_color 949494 +tide_prompt_icon_connection ' ' +tide_prompt_min_cols 34 +tide_prompt_pad_items false +tide_pulumi_bg_color normal +tide_pulumi_color F7BF2A +tide_pulumi_icon '' +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_icon +tide_pwd_icon_home +tide_pwd_icon_unwritable  +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 +tide_right_prompt_frame_enabled false +tide_right_prompt_items status cmd_duration context jobs direnv node virtual_env rustc java php pulumi chruby go gcloud kubectl distrobox toolbox terraform aws nix_shell crystal elixir +tide_right_prompt_prefix ' ' +tide_right_prompt_separator_diff_color ' ' +tide_right_prompt_separator_same_color ' ' +tide_right_prompt_suffix '' +tide_rustc_bg_color normal +tide_rustc_color F74C00 +tide_rustc_icon  +tide_shlvl_bg_color normal +tide_shlvl_color d78700 +tide_shlvl_icon  +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_status_icon ✔ +tide_status_icon_failure ✘ +tide_terraform_bg_color normal +tide_terraform_color 844FBA +tide_terraform_icon +tide_time_bg_color normal +tide_time_color 5F8787 +tide_time_format %T +tide_toolbox_bg_color normal +tide_toolbox_color 613583 +tide_toolbox_icon ⬢ +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_vi_mode_icon_default D +tide_vi_mode_icon_insert I +tide_vi_mode_icon_replace R +tide_vi_mode_icon_visual V +tide_virtual_env_bg_color normal +tide_virtual_env_color 00AFAF +tide_virtual_env_icon  diff --git a/fish/functions/tide/configure/configs/lean_16color.fish b/fish/functions/tide/configure/configs/lean_16color.fish new file mode 100644 index 0000000..546868d --- /dev/null +++ b/fish/functions/tide/configure/configs/lean_16color.fish @@ -0,0 +1,87 @@ +tide_aws_bg_color normal +tide_aws_color yellow +tide_character_color brgreen +tide_character_color_failure brred +tide_chruby_bg_color normal +tide_chruby_color red +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_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_virtual_env_bg_color normal +tide_virtual_env_color cyan diff --git a/fish/functions/tide/configure/configs/rainbow.fish b/fish/functions/tide/configure/configs/rainbow.fish new file mode 100644 index 0000000..5087f36 --- /dev/null +++ b/fish/functions/tide/configure/configs/rainbow.fish @@ -0,0 +1,151 @@ +tide_aws_bg_color FF9900 +tide_aws_color 232F3E +tide_aws_icon  +tide_character_color $_tide_color_green +tide_character_color_failure FF0000 +tide_character_icon ❯ +tide_character_vi_icon_default ❮ +tide_character_vi_icon_replace ▶ +tide_character_vi_icon_visual V +tide_chruby_bg_color B31209 +tide_chruby_color 000000 +tide_chruby_icon  +tide_cmd_duration_bg_color C4A000 +tide_cmd_duration_color 000000 +tide_cmd_duration_decimals 0 +tide_cmd_duration_icon +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_crystal_icon ⬢ +tide_direnv_bg_color $_tide_color_gold +tide_direnv_bg_color_denied FF0000 +tide_direnv_color 000000 +tide_direnv_color_denied 000000 +tide_direnv_icon ▼ +tide_distrobox_bg_color FF00FF +tide_distrobox_color 000000 +tide_distrobox_icon ⬢ +tide_docker_bg_color 2496ED +tide_docker_color 000000 +tide_docker_default_contexts default colima +tide_docker_icon  +tide_elixir_bg_color 4E2A8E +tide_elixir_color 000000 +tide_elixir_icon  +tide_gcloud_bg_color 4285F4 +tide_gcloud_color 000000 +tide_gcloud_icon  +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_icon +tide_git_truncation_length 24 +tide_git_truncation_strategy +tide_go_bg_color 00ACD7 +tide_go_color 000000 +tide_go_icon  +tide_java_bg_color ED8B00 +tide_java_color 000000 +tide_java_icon  +tide_jobs_bg_color 444444 +tide_jobs_color 4E9A06 +tide_jobs_icon  +tide_kubectl_bg_color 326CE5 +tide_kubectl_color 000000 +tide_kubectl_icon ⎈ +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_nix_shell_icon  +tide_node_bg_color 44883E +tide_node_color 000000 +tide_node_icon ⬢ +tide_os_bg_color $os_branding_bg_color +tide_os_color $os_branding_color +tide_os_icon $os_branding_icon +tide_php_bg_color 617CBE +tide_php_color 000000 +tide_php_icon  +tide_private_mode_bg_color F1F3F4 +tide_private_mode_color 000000 +tide_private_mode_icon 﫸 +tide_prompt_add_newline_before true +tide_prompt_color_frame_and_connection 6C6C6C +tide_prompt_color_separator_same_color 949494 +tide_prompt_icon_connection ' ' +tide_prompt_min_cols 34 +tide_prompt_pad_items true +tide_pulumi_bg_color F7BF2A +tide_pulumi_color 000000 +tide_pulumi_icon '' +tide_pwd_bg_color 3465A4 +tide_pwd_color_anchors E4E4E4 +tide_pwd_color_dirs E4E4E4 +tide_pwd_color_truncated_dirs BCBCBC +tide_pwd_icon +tide_pwd_icon_home +tide_pwd_icon_unwritable  +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 +tide_right_prompt_frame_enabled true +tide_right_prompt_items status cmd_duration context jobs direnv node virtual_env rustc java php pulumi chruby go gcloud kubectl distrobox toolbox terraform aws nix_shell crystal elixir +tide_right_prompt_prefix  +tide_right_prompt_separator_diff_color  +tide_right_prompt_separator_same_color  +tide_right_prompt_suffix '' +tide_rustc_bg_color F74C00 +tide_rustc_color 000000 +tide_rustc_icon  +tide_shlvl_bg_color 808000 +tide_shlvl_color 000000 +tide_shlvl_icon  +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_status_icon ✔ +tide_status_icon_failure ✘ +tide_terraform_bg_color 800080 +tide_terraform_color 000000 +tide_terraform_icon +tide_time_bg_color D3D7CF +tide_time_color 000000 +tide_time_format %T +tide_toolbox_bg_color 613583 +tide_toolbox_color 000000 +tide_toolbox_icon ⬢ +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_vi_mode_icon_default D +tide_vi_mode_icon_insert I +tide_vi_mode_icon_replace R +tide_vi_mode_icon_visual V +tide_virtual_env_bg_color 444444 +tide_virtual_env_color 00AFAF +tide_virtual_env_icon  diff --git a/fish/functions/tide/configure/configs/rainbow_16color.fish b/fish/functions/tide/configure/configs/rainbow_16color.fish new file mode 100644 index 0000000..7803596 --- /dev/null +++ b/fish/functions/tide/configure/configs/rainbow_16color.fish @@ -0,0 +1,91 @@ +tide_aws_bg_color yellow +tide_aws_color brblack +tide_character_color brgreen +tide_character_color_failure brred +tide_chruby_bg_color red +tide_chruby_color black +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_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_virtual_env_bg_color brblack +tide_virtual_env_color cyan diff --git a/fish/functions/tide/configure/functions/_fake_tide_cache_variables.fish b/fish/functions/tide/configure/functions/_fake_tide_cache_variables.fish new file mode 100644 index 0000000..4661ab1 --- /dev/null +++ b/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/fish/functions/tide/configure/functions/_fake_tide_item_character.fish b/fish/functions/tide/configure/functions/_fake_tide_item_character.fish new file mode 100644 index 0000000..73ae055 --- /dev/null +++ b/fish/functions/tide/configure/functions/_fake_tide_item_character.fish @@ -0,0 +1,5 @@ +function _fake_tide_item_character + set_color $fake_tide_character_color + contains newline $fake_tide_left_prompt_items || echo -ns ' ' + echo -ns $fake_tide_character_icon +end diff --git a/fish/functions/tide/configure/functions/_fake_tide_item_cmd_duration.fish b/fish/functions/tide/configure/functions/_fake_tide_item_cmd_duration.fish new file mode 100644 index 0000000..5aa13b2 --- /dev/null +++ b/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/fish/functions/tide/configure/functions/_fake_tide_item_git.fish b/fish/functions/tide/configure/functions/_fake_tide_item_git.fish new file mode 100644 index 0000000..fb5b957 --- /dev/null +++ b/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/fish/functions/tide/configure/functions/_fake_tide_item_newline.fish b/fish/functions/tide/configure/functions/_fake_tide_item_newline.fish new file mode 100644 index 0000000..c614bab --- /dev/null +++ b/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/fish/functions/tide/configure/functions/_fake_tide_item_os.fish b/fish/functions/tide/configure/functions/_fake_tide_item_os.fish new file mode 100644 index 0000000..5255721 --- /dev/null +++ b/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/fish/functions/tide/configure/functions/_fake_tide_item_time.fish b/fish/functions/tide/configure/functions/_fake_tide_item_time.fish new file mode 100644 index 0000000..bbce0b5 --- /dev/null +++ b/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/fish/functions/tide/configure/functions/_fake_tide_print_item.fish b/fish/functions/tide/configure/functions/_fake_tide_print_item.fish new file mode 100644 index 0000000..30cd024 --- /dev/null +++ b/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/fish/functions/tide/configure/functions/_fake_tide_prompt.fish b/fish/functions/tide/configure/functions/_fake_tide_prompt.fish new file mode 100644 index 0000000..11f20ca --- /dev/null +++ b/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/fish/functions/tide/configure/functions/_fake_tide_pwd.fish b/fish/functions/tide/configure/functions/_fake_tide_pwd.fish new file mode 100644 index 0000000..433eafa --- /dev/null +++ b/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/gh/config.yml b/gh/config.yml new file mode 100644 index 0000000..8b25011 --- /dev/null +++ b/gh/config.yml @@ -0,0 +1,27 @@ +# The current version of the config schema +version: 1 +# What protocol to use when performing git operations. Supported values: ssh, https +git_protocol: https +# What editor gh should run when creating issues, pull requests, etc. If blank, will refer to environment. +editor: +# When to interactively prompt. This is a global config that cannot be overridden by hostname. Supported values: enabled, disabled +prompt: enabled +# Preference for editor-based interactive prompting. This is a global config that cannot be overridden by hostname. Supported values: enabled, disabled +prefer_editor_prompt: disabled +# A pager program to send command output to, e.g. "less". If blank, will refer to environment. Set the value to "cat" to disable the pager. +pager: +# Aliases allow you to create nicknames for gh commands +aliases: + co: pr checkout +# The path to a unix socket through which to send HTTP connections. If blank, HTTP traffic will be handled by net/http.DefaultTransport. +http_unix_socket: +# What web browser gh should use when opening URLs. If blank, will refer to environment. +browser: +# Whether to display labels using their RGB hex color codes in terminals that support truecolor. Supported values: enabled, disabled +color_labels: disabled +# Whether customizable, 4-bit accessible colors should be used. Supported values: enabled, disabled +accessible_colors: disabled +# Whether an accessible prompter should be used. Supported values: enabled, disabled +accessible_prompter: disabled +# Whether to use a animated spinner as a progress indicator. If disabled, a textual progress indicator is used instead. Supported values: enabled, disabled +spinner: enabled diff --git a/gh/hosts.yml b/gh/hosts.yml new file mode 100644 index 0000000..98ec87f --- /dev/null +++ b/gh/hosts.yml @@ -0,0 +1,5 @@ +github.com: + git_protocol: https + users: + nasrlol: + user: nasrlol diff --git a/omf/bundle b/omf/bundle new file mode 100644 index 0000000..94c5d3c --- /dev/null +++ b/omf/bundle @@ -0,0 +1,3 @@ +package vi-mode +theme default +theme gentoo diff --git a/omf/channel b/omf/channel new file mode 100644 index 0000000..2bf5ad0 --- /dev/null +++ b/omf/channel @@ -0,0 +1 @@ +stable diff --git a/omf/theme b/omf/theme new file mode 100644 index 0000000..23574f3 --- /dev/null +++ b/omf/theme @@ -0,0 +1 @@ +gentoo diff --git a/rizin/cutter.ini b/rizin/cutter.ini new file mode 100644 index 0000000..4d72d61 --- /dev/null +++ b/rizin/cutter.ini @@ -0,0 +1,210 @@ +[General] +ACDMonthlyAnalyticsLastPosted=784289513.312351 +AKLastIDMSEnvironment=0 +AKLastLocale="en_US@rg=bezzzz" +AppleAccentColor=-1 +AppleActionOnDoubleClick=Maximize +AppleAntiAliasingThreshold=4 +AppleAquaColorVariant=6 +AppleEnableMenuBarTransparency=true +AppleEnableSwipeNavigateWithScrolls=false +AppleHighlightColor=0.698039 0.843137 1.000000 Blue +AppleInterfaceStyle=Dark +AppleKeyboardUIMode=3 +AppleLanguages=en-US, nl-BE +AppleLanguagesSchemaVersion=5400 +AppleLiveTextEnabled=false +AppleLocale="en_US@rg=bezzzz" +AppleMenuBarVisibleInFullscreen=true +AppleMiniaturizeOnDoubleClick=false +ApplePressAndHoldEnabled=false +AppleReduceDesktopTinting=true +AppleScrollerPagingBehavior=false +AppleShowAllExtensions=true +AppleShowScrollBars=Automatic +AppleTextDirection=false +CFFontRenderingFontSmoothingDisabled=false +CGDisableCursorLocationMagnification=true +ColorPalette=0 +Country=BE +InitialKeyRepeat=10 +InitialKeyRepeat_Level_Saved=6 +KB_DoubleQuoteOption=“abc” +KB_SingleQuoteOption=‘abc’ +KB_SpellingLanguage=@Variant(\0\0\0\b\0\0\0\x1\0\0\0<\0K\0\x42\0_\0S\0p\0\x65\0l\0l\0i\0n\0g\0L\0\x61\0n\0g\0u\0\x61\0g\0\x65\0I\0s\0\x41\0u\0t\0o\0m\0\x61\0t\0i\0\x63\0\0\0\x1\x1) +KeyRepeat=1 +MultipleSessionEnabled=true +NSAutomaticCapitalizationEnabled=true +NSAutomaticPeriodSubstitutionEnabled=true +NSAutomaticWindowAnimationsEnabled=false +NSGlassDiffusionSetting=true +NSLinguisticDataAssetsRequestLastInterval=86400 +NSLinguisticDataAssetsRequestTime=@DateTime(\0\0\0\x10\0\0\0\0\0\0%\x8dM\x2\x39\x35@\0) +NSLinguisticDataAssetsRequested=en, fr, en_US, nl, de, nb, nn, nl_BE, ar, mul, mul_Latn, mul_Hani, es, it +NSLinguisticDataAssetsRequestedByChecker=en, nl, fr, de, nb, nn, ar, es, it +NSNavPanelFileLastListModeForOpenModeKey=2 +NSNavPanelFileListModeForOpenMode2=2 +NSPreferredSpellServerLanguage=nl +NSPreferredSpellServerVendors=@Variant(\0\0\0\b\0\0\0\x1\0\0\0\x4\0n\0l\0\0\0\n\0\0\0\n\0\x41\0p\0p\0l\0\x65) +NSPreferredWebServices=@Variant(\0\0\0\b\0\0\0\x1\0\0\0<\0N\0S\0W\0\x65\0\x62\0S\0\x65\0r\0v\0i\0\x63\0\x65\0s\0P\0r\0o\0v\0i\0\x64\0\x65\0r\0W\0\x65\0\x62\0S\0\x65\0\x61\0r\0\x63\0h\0\0\0\b\0\0\0\x2\0\0\0(\0N\0S\0\x44\0\x65\0\x66\0\x61\0u\0l\0t\0\x44\0i\0s\0p\0l\0\x61\0y\0N\0\x61\0m\0\x65\0\0\0\n\0\0\0\f\0G\0o\0o\0g\0l\0\x65\0\0\0(\0N\0S\0P\0r\0o\0v\0i\0\x64\0\x65\0r\0I\0\x64\0\x65\0n\0t\0i\0\x66\0i\0\x65\0r\0\0\0\n\0\0\0\x1c\0\x63\0o\0m\0.\0g\0o\0o\0g\0l\0\x65\0.\0w\0w\0w) +NSQuitAlwaysKeepsWindows=true +NSScrollViewRubberbanding=false +NSShowFeedbackMenu=true +NSSpellCheckerAutomaticallyIdentifiesLanguages=true +NSSpellCheckerContainerTransitionComplete=true +NSSpellCheckerDictionaryContainerTransitionComplete=true +NSSpellCheckerInputAnalyticsTime=@DateTime(\0\0\0\x10\0\0\0\0\0\0%\x8b\xa6\x3\xf5\x1d\xb4\0) +NSUserDictionaryReplacementItems=@Variant(\0\0\0\t\0\0\0\x1\0\0\0\b\0\0\0\x3\0\0\0\x4\0o\0n\0\0\0\x4\0\0\0\0\0\0\0\x1\0\0\0\xe\0r\0\x65\0p\0l\0\x61\0\x63\0\x65\0\0\0\n\0\0\0\x6\0o\0m\0w\0\0\0\b\0w\0i\0t\0h\0\0\0\n\0\0\0\x14\0O\0n\0 \0m\0y\0 \0w\0\x61\0y\0!) +NSUserKeyEquivalents=@Variant(\0\0\0\b\0\0\0\0) +NSUserQuotesArray=“, ”, ‘, ’ +NSWindowResizeTime=0.0010000000474974513 +NavPanelFileListModeForOpenMode=2 +PKFPANInitialEligibilityCheckPerformedKey=true +QLPanelAnimationDuration=0 +SLSMenuBarUseBlurredAppearance=true +UIPreferredContentSizeCategoryName=UICTContentSizeCategoryL +_AKBAACertMarkerKey=@ByteArray(\xbd\xe8\xf5\xec\xde\x8c>\xde\x33\xb0\x12\x91s\b\xef\x15\x32@\xdb\xa4s@i\xe\x95\x9d\xe5.\xa0!s\f) +_HIHideMenuBar=false +colors.angui.navbar.str=@Variant(\0\0\0\x43\0\xff\xff\0\0\0\0\0\0\0\0) +colors.b0x00=@Variant(\0\0\0\x43\x1\xff\xffss\x86\x86\x99\x99\0\0) +colors.b0x7f=@Variant(\0\0\0\x43\x1\xff\xff``pppp\0\0) +colors.b0xff=@Variant(\0\0\0\x43\x1\xff\xff\xab\xab\xb0\xb0\xb6\xb6\0\0) +colors.bin=@Variant(\0\0\0\x43\x1\xff\xffPP\xd0\xd0\xe0\xe0\0\0) +colors.btext=@Variant(\0\0\0\x43\x1\xff\xffPP\xd0\xd0\xe0\xe0\0\0) +colors.call=@Variant(\0\0\0\x43\x1\xff\xff\xff\xffww33\0\0) +colors.cjmp=@Variant(\0\0\0\x43\x1\xff\xff\xc2\xc2\xd9\xd9LL\0\0) +colors.cmp=@Variant(\0\0\0\x43\x1\xff\xffPP\xd0\xd0\xe0\xe0\0\0) +colors.comment=@Variant(\0\0\0\x43\x1\xff\xff\x95\x95\xe6\xe6\xcb\xcb\0\0) +colors.creg=@Variant(\0\0\0\x43\x1\xff\xff\xff\xffww33\0\0) +colors.crypto=@Variant(\0\0\0\x43\x1\xff\xff\0\0\x37\x37\xda\xda\0\0) +colors.diff.match=@Variant(\0\0\0\x43\x1\xff\xffvvvvvv\0\0) +colors.diff.new=@Variant(\0\0\0\x43\x1\xff\xff\xc5\xc5\xf\xf\x1f\x1f\0\0) +colors.diff.unknown=@Variant(\0\0\0\x43\x1\xff\xff\x88\x88\x17\x17\x98\x98\0\0) +colors.diff.unmatch=@Variant(\0\0\0\x43\x1\xff\xff\xc1\xc1\x9c\x9c\0\0\0\0) +colors.flag=@Variant(\0\0\0\x43\x1\xff\xff\\\\\xcf\xcf\xe6\xe6\0\0) +colors.fline=@Variant(\0\0\0\x43\x1\xff\xffUU\xb4\xb4\xd4\xd4\0\0) +colors.floc=@Variant(\0\0\0\x43\x1\xff\xff::\x96\x96\xdd\xdd\0\0) +colors.flow=@Variant(\0\0\0\x43\x1\xff\xff\xc2\xc2\xd9\xd9LL\0\0) +colors.flow2=@Variant(\0\0\0\x43\x1\xff\xff\xd0\xd0\xd0\xd0\xd0\xd0\0\0) +colors.fname=@Variant(\0\0\0\x43\x1\xff\xff\xff\xffjj\0\0\0\0) +colors.func_var=@Variant(\0\0\0\x43\x1\xff\xff\x95\x95\xe6\xe6\xcb\xcb\0\0) +colors.func_var_addr=@Variant(\0\0\0\x43\x1\xff\xff\xf2\xf2\x87\x87yy\0\0) +colors.func_var_type=@Variant(\0\0\0\x43\x1\xff\xff\xff\xff\xd5\xd5\x80\x80\0\0) +colors.graph.false=@Variant(\0\0\0\x43\x1\xff\xff\xf0\xf0qqxx\0\0) +colors.graph.true=@Variant(\0\0\0\x43\x1\xff\xff\xba\xba\xe6\xe6~~\0\0) +colors.graph.ujump=@Variant(\0\0\0\x43\x1\xff\xffUU\xb4\xb4\xd4\xd4\0\0) +colors.gui.alt_background=@Variant(\0\0\0\x43\x1\xff\xff\x1c\x1c\x1f\x1f$$\0\0) +colors.gui.background=@Variant(\0\0\0\x43\x1\xff\xff%%((++\0\0) +colors.gui.border=@Variant(\0\0\0\x43\x1\xff\xff\x64\x64\x64\x64\x64\x64\0\0) +colors.gui.breakpoint_background=@Variant(\0\0\0\x43\x1\xff\xff\x8c\x8cLLLL\0\0) +colors.gui.cflow=@Variant(\0\0\0\x43\x1\xff\xff\xc1\xc1\x9c\x9c\0\0\0\0) +colors.gui.dataoffset=@Variant(\0\0\0\x43\x1\xff\xff\xff\xff\xff\xff\xff\xff\0\0) +colors.gui.disass_selected=@Variant(\0\0\0\x43\x1\xff\xff\x1f\x1f\"\"((\0\0) +colors.gui.flirt=@Variant(\0\0\0\x43\x1\xff\xff\xd8\xd8\xbb\xbb!!\0\0) +colors.gui.imports=@Variant(\0\0\0\x43\x1\xff\xff\x32\x32\x8c\x8c\xff\xff\0\0) +colors.gui.item_invalid=@Variant(\0\0\0\x43\x1\xff\xff\x9b\x9b\x9b\x9b\x9b\x9b\0\0) +colors.gui.item_unsafe=@Variant(\0\0\0\x43\x1\xff\xff\xff\xff\x81\x81{{\0\0) +colors.gui.main=@Variant(\0\0\0\x43\x1\xff\xff!!\xd8\xd8\x93\x93\0\0) +colors.gui.navbar.code=@Variant(\0\0\0\x43\x1\xff\xff\x82\x82\xc8\xc8oo\0\0) +colors.gui.navbar.empty=@Variant(\0\0\0\x43\x1\xff\xff\x64\x64\x64\x64\x64\x64\0\0) +colors.gui.navbar.err=@Variant(\0\0\0\x43\x1\xff\xff\x3\x3\xaa\xaa\xf5\xf5\0\0) +colors.gui.navbar.pc=@Variant(\0\0\0\x43\x1\xff\xff\x42\x42\xee\xee\xf4\xf4\0\0) +colors.gui.navbar.seek=@Variant(\0\0\0\x43\x1\xff\xff\xe9\xe9VVVV\0\0) +colors.gui.navbar.str=@Variant(\0\0\0\x43\x1\xff\xffoo\x86\x86\xd8\xd8\0\0) +colors.gui.navbar.sym=@Variant(\0\0\0\x43\x1\xff\xff\xdd\xdd\xa3\xa3hh\0\0) +colors.gui.overview.border=@Variant(\0\0\0\x43\x1\x32\x32\x63\x63\xda\xda\xe8\xe8\0\0) +colors.gui.overview.fill=@Variant(\0\0\0\x43\x1((\xff\xff\xff\xff\xff\xff\0\0) +colors.gui.overview.node=@Variant(\0\0\0\x43\x1\xff\xff\x64\x64\x64\x64\x64\x64\0\0) +colors.gui.tooltip.background="@Variant(\0\0\0\x43\x1\xff\xff**,,..\0\0)" +colors.gui.tooltip.foreground=@Variant(\0\0\0\x43\x1\xff\xff\xfa\xfa\xfc\xfc\xfe\xfe\0\0) +colors.help=@Variant(\0\0\0\x43\x1\xff\xff\xc2\xc2\xd9\xd9LL\0\0) +colors.highlightPC=@Variant(\0\0\0\x43\x1\xff\xffWW\x1a\x1a\a\a\0\0) +colors.input=@Variant(\0\0\0\x43\x1\xff\xff\x80\x80\x80\x80\x80\x80\0\0) +colors.jmp=@Variant(\0\0\0\x43\x1\xff\xff\xc2\xc2\xd9\xd9LL\0\0) +colors.lineHighlight=@Variant(\0\0\0\x43\x1\x96\x96\x15\x15\x1d\x1d\x1d\x1d\0\0) +colors.math=@Variant(\0\0\0\x43\x1\xff\xffPP\xd0\xd0\xe0\xe0\0\0) +colors.meta=@Variant(\0\0\0\x43\x1\xff\xffvvvvvv\0\0) +colors.mov=@Variant(\0\0\0\x43\x1\xff\xff\xd9\xd9\xd8\xd8\xd7\xd7\0\0) +colors.nop=@Variant(\0\0\0\x43\x1\xff\xff\xa3\xa3zz\xcc\xcc\0\0) +colors.num=@Variant(\0\0\0\x43\x1\xff\xff\xf2\xf2\x87\x87yy\0\0) +colors.offset=@Variant(\0\0\0\x43\x1\xff\xff\xed\xed\x93\x93\x66\x66\0\0) +colors.other=@Variant(\0\0\0\x43\x1\xff\xff\x80\x80\x80\x80\x80\x80\0\0) +colors.pop=@Variant(\0\0\0\x43\x1\xff\xffPP\xd0\xd0\xe0\xe0\0\0) +colors.push=@Variant(\0\0\0\x43\x1\xff\xffPP\xd0\xd0\xe0\xe0\0\0) +colors.reg=@Variant(\0\0\0\x43\x1\xff\xff\xe6\xe6\xe1\xe1\xcf\xcf\0\0) +colors.ret=@Variant(\0\0\0\x43\x1\xff\xff\xd0\xd0````\0\0) +colors.swi=@Variant(\0\0\0\x43\x1\xff\xff\xd0\xd0````\0\0) +colors.trap=@Variant(\0\0\0\x43\x1\xff\xff\xd0\xd0````\0\0) +colors.ucall=@Variant(\0\0\0\x43\x1\xff\xff\\\\\xcf\xcf\xe6\xe6\0\0) +colors.ujmp=@Variant(\0\0\0\x43\x1\xff\xff\xc2\xc2\xd9\xd9LL\0\0) +colors.usrcmt=@Variant(\0\0\0\x43\x1\xff\xff\xfa\xfann22\0\0) +colors.wordHighlight=@Variant(\0\0\0\x43\x1\xff\xff\x34\x34::GG\0\0) +console.wrap=true +firstExecution=false +functionsWidgetLayout=vertical +newFileLastClicked=1 +recentFileList=@Invalid() +recentProjectsList=@Invalid() +shouldShowRSVPDataDetectors=false +theme=ayu +theme_version=1 +userMenuExtraStyle=2 +version=6 + +[com] +apple\AppleModemSettingTool\LastCountryCode=BE +apple\ColorSync\Devices=@Variant(\0\0\0\b\0\0\0\x2\0\0\0`\0\x44\0\x65\0v\0i\0\x63\0\x65\0.\0m\0n\0t\0r\0.\0\x33\0\x37\0\x44\0\x38\0\x38\0\x33\0\x32\0\x41\0-\0\x32\0\x44\0\x36\0\x36\0-\0\x30\0\x32\0\x43\0\x41\0-\0\x42\0\x39\0\x46\0\x37\0-\0\x38\0\x46\0\x33\0\x30\0\x41\0\x33\0\x30\0\x31\0\x42\0\x32\0\x33\0\x30\0\0\0\b\0\0\0\x1\0\0\0\x1c\0\x43\0u\0s\0t\0o\0m\0P\0r\0o\0\x66\0i\0l\0\x65\0s\0\0\0\b\0\0\0\x1\0\0\0\x2\0\x31\0\0\0\n\0\0\0\x66\0/\0S\0y\0s\0t\0\x65\0m\0/\0L\0i\0\x62\0r\0\x61\0r\0y\0/\0\x43\0o\0l\0o\0r\0S\0y\0n\0\x63\0/\0P\0r\0o\0\x66\0i\0l\0\x65\0s\0/\0\x41\0\x64\0o\0\x62\0\x65\0R\0G\0\x42\0\x31\0\x39\0\x39\0\x38\0.\0i\0\x63\0\x63\0\0\0`\0\x44\0\x65\0v\0i\0\x63\0\x65\0.\0m\0n\0t\0r\0.\0\x36\0\x42\0\x36\0\x41\0\x43\0\x33\0\x35\0\x34\0-\0\x41\0\x43\0\x46\0\x32\0-\0\x34\0\x33\0\x39\0\x30\0-\0\x41\0\x39\0\x31\0\x32\0-\0\x46\0\x37\0\x34\0\x45\0\x41\0\x31\0\x45\0\x37\0\x43\0\x32\0\x43\0\x37\0\0\0\b\0\0\0\x1\0\0\0\x1c\0\x43\0u\0s\0t\0o\0m\0P\0r\0o\0\x66\0i\0l\0\x65\0s\0\0\0\b\0\0\0\x1\0\0\0\xe\0H\0\x44\0M\0I\0 \0H\0\x44\0\0\0\n\0\0\0\xaa\0/\0L\0i\0\x62\0r\0\x61\0r\0y\0/\0\x43\0o\0l\0o\0r\0S\0y\0n\0\x63\0/\0P\0r\0o\0\x66\0i\0l\0\x65\0s\0/\0\x44\0i\0s\0p\0l\0\x61\0y\0s\0/\0U\0\x32\0\x38\0\x45\0\x35\0\x37\0\x30\0-\0\x43\0\x46\0\x30\0\x46\0\x41\0\x32\0\x33\0\x31\0-\0\x37\0\x46\0\x33\0\x42\0-\0\x34\0\x37\0\x39\0\x39\0-\0\x38\0\x39\0\x43\0\x42\0-\0\x30\0\x33\0\x31\0\x31\0\x38\0\x41\0\x46\0\x45\0\x35\0\x46\0\x36\0\x31\0.\0i\0\x63\0\x63) +apple\finder\SyncExtensions=@Variant(\0\0\0\b\0\0\0\x2\0\0\0 \0\x63\0o\0l\0l\0\x61\0\x62\0o\0r\0\x61\0t\0i\0o\0n\0M\0\x61\0p\0\0\0\b\0\0\0\0\0\0\0\f\0\x64\0i\0r\0M\0\x61\0p\0\0\0\b\0\0\0\0) +apple\gms\availability\accessNotGrantedUseCases=@Invalid() +apple\gms\availability\disabledUseCases=codeLM.denyThisUseCaseOnJune6of2024 +apple\gms\availability\disallowedUseCases=@Invalid() +apple\gms\availability\essentialAssetReadiness=true +apple\gms\availability\foundationModelsCompatibilityVersionsInfo=@ByteArray(bplist00\xd1\x1\x2Tinfo\xa0\b\v\x10\0\0\0\0\0\0\x1\x1\0\0\0\0\0\0\0\x3\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\x11) +apple\gms\availability\key=@Variant(\0\0\0\t\0\0\0\x1\0\0\0\x4\0\0\0\0\0\0\0\x2) +apple\gms\availability\unifiedReasons=@ByteArray({}) +apple\gms\availability\useCaseReadiness="@ByteArray({\"summarization.magicPaper\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.KeyboardEmojiGenerator:emoji:emoji\":[[\"*\",0]],\"textComposition.ProfessionalTone\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground:sketch:personalized_sketch\":[[\"*\",0]],\"textComposition.BulletsTransform\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"summarization.summarizeMailMessageThreadOnDemand\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"com.apple.Settings.AppleIntelligence.Diffusion\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground:emoji:personalized_emoji\":[[\"*\",0]],\"textComposition.ProofreadingReview\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"summarization.generativePlayground\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"classification.classifyTextMessageThread\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"memoryCreation.Title\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textUnderstanding.TextEventExtraction\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textComposition.MailReplyQA\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textComposition.FriendlyTone\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground:emoji:emoji\":[[\"*\",0]],\"com.apple.Shortcuts.AskAFMAction3B\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"spatialPhotos.relive.main\":[[\"*\",0]],\"com.apple.vision.adt\":[[\"*\",0]],\"summarization.textAssistant\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textComposition.OpenEndedTone\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground:illustration:style_scribble\":[[\"*\",0]],\"handwriting.synthesis\":[[\"cs\",0],[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fi\",0],[\"fr\",0],[\"id\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"ms\",0],[\"nb\",0],[\"nl\",0],[\"nn\",0],[\"pl\",0],[\"pt\",0],[\"ro\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"yue\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textComposition.MessagesReply\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"summarization.notesAudioTranscriptOnDemand\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"classification.classifyUserNotification\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground:sketch:sketch\":[[\"*\",0]],\"summarization.safariReader\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textComposition.MailReply\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textComposition.TakeawaysTransform\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"Shortcuts.AskAFMAction.automated.image\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"memoryCreation.LibraryUnderstanding\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground:animation:animation\":[[\"*\",0]],\"textComposition.MailReplyLongFormRewrite\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"summarization.summarizeUserNotification\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground:animation:personalized_animation\":[[\"*\",0]],\"summarization.summarizeUserNotificationThread\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"com.apple.photos.semanticSearch.test\":[[\"*\",0]],\"textComposition.MagicRewrite\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"summarization.summarizeMailMessage\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"memoryCreation.GlobalTraits\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"classification.classifyMailMessage\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"com.apple.WritingTools\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"Shortcuts.AskAFMAction.automated\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"summarization.summarizeTextMessageThread\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"com.apple.PaperKit.ImageGeneration\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"Shortcuts.AskAFMAction\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textComposition.MessagesAction\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"classification.classifyTextMessage\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground:illustration:personalized_illustration\":[[\"*\",0]],\"GenerativeEdit.CleanUp\":[[\"*\",0]],\"summarization.notesAudioTranscript\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground:animation:style_scribble\":[[\"*\",0]],\"summarization.summarizeMailMessageThread\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.KeyboardEmojiGenerator\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground:illustration:illustration\":[[\"*\",0]],\"VisualGeneration.KeyboardEmojiGenerator:emoji:personalized_emoji\":[[\"*\",0]],\"com.apple.Settings.AppleIntelligence\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textComposition.ConciseTone\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textComposition.MailReplyLongFormBasic\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"memoryCreation.AutonamingMessages\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"summarization.summarizeTextMessage\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"memoryCreation.QueryUnderstanding\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"messages.smartReply\":[[\"en\",0]],\"memoryCreation.Storyteller\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"VisualGeneration.GenerativePlayground:sketch:style_scribble\":[[\"*\",0]],\"memoryCreation.AssetCuration\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textUnderstanding.TextPersonExtraction\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"summarization.summarizeMailMessageOnDemand\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"summarization.visualIntelligenceCamera\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"com.apple.FoundationModels\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"Shortcuts.AskAFMAction.image\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"memoryCreation.AssetCurationOutlier\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]],\"textComposition.TablesTransform\":[[\"da\",0],[\"de\",0],[\"en\",0],[\"es\",0],[\"fr\",0],[\"it\",0],[\"ja\",0],[\"ko\",0],[\"nb\",0],[\"nl\",0],[\"pt\",0],[\"sv\",0],[\"tr\",0],[\"vi\",0],[\"zh\",0],[\"zh_HK\",0],[\"zh_TW\",0]]})" +apple\gms\availability\useCasesWhoseAssetsAreOutOfStorage=@Invalid() +apple\gms\availability\useCasesWhoseAssetsNotReady=@ByteArray(bplist00\xa0\b\0\0\0\0\0\0\x1\x1\0\0\0\0\0\0\0\x1\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\t) +apple\keyboard\fnState=true +apple\mouse\doubleClickThreshold=0.15 +apple\mouse\linear=false +apple\mouse\scaling=0.125 +apple\mouse\tapBehavior=1 +apple\scrollwheel\scaling=0.3125 +apple\sound\beep\feedback=1 +apple\sound\beep\flash=0 +apple\sound\beep\sound=/System/Library/Sounds/Pop.aiff +apple\sound\beep\volume=1 +apple\springing\delay=0.3536081314086914 +apple\springing\enabled=true +apple\swipescrolldirection=true +apple\trackpad\enableSecondaryClick=true +apple\trackpad\fiveFingerPinchSwipeGesture=2 +apple\trackpad\forceClick=true +apple\trackpad\fourFingerHorizSwipeGesture=2 +apple\trackpad\fourFingerPinchSwipeGesture=2 +apple\trackpad\fourFingerVertSwipeGesture=2 +apple\trackpad\momentumScroll=true +apple\trackpad\pinchGesture=true +apple\trackpad\rotateGesture=true +apple\trackpad\scaling=0.5 +apple\trackpad\scrollBehavior=2 +apple\trackpad\scrolling=0.4412 +apple\trackpad\threeFingerDragGesture=false +apple\trackpad\threeFingerHorizSwipeGesture=1 +apple\trackpad\threeFingerTapGesture=0 +apple\trackpad\threeFingerVertSwipeGesture=1 +apple\trackpad\twoFingerDoubleTapGesture=1 +apple\trackpad\twoFingerFromRightEdgeSwipeGesture=0 +apple\trackpad\version=5 + +[layouts] +1\docks=@Variant(\0\0\0\b\0\0\0\0) +1\geometry=@ByteArray() +1\name=Default +1\state=@ByteArray() +2\docks=@Variant(\0\0\0\b\0\0\0\0) +2\geometry=@ByteArray() +2\name=Debug +2\state=@ByteArray() +size=2 diff --git a/skhd/skhdrc b/skhd/skhdrc index 5cdd690..31f6322 100755 --- a/skhd/skhdrc +++ b/skhd/skhdrc @@ -1,10 +1,2 @@ cmd - return : /usr/bin/open -na /Applications/Alacritty.app -cmd - h : /opt/homebrew/bin/yabai -m window --focus west -cmd - l : /opt/homebrew/bin/yabai -m window --focus east -cmd - j : /opt/homebrew/bin/yabai -m window --focus south -cmd - k : /opt/homebrew/bin/yabai -m window --focus north - -alt + shift - space : /opt/homebrew/bin/yabai -m window --toggle float -alt + shift - f : /opt/homebrew/bin/yabai -m window --toggle zoom-fullscreen - diff --git a/tmux/tmux.conf b/tmux/tmux.conf index 4271679..2b52441 100644 --- a/tmux/tmux.conf +++ b/tmux/tmux.conf @@ -3,7 +3,7 @@ set -g @plugin 'tmux-plugins/tpm' run '~/.tmux/plugins/tpm/tpm' # General -set -g default-shell /bin/zsh +set -g default-shell /opt/homebrew/bin/fish set -g default-terminal 'tmux-256color' set -g mouse off set -g history-limit 100 diff --git a/vifm/.DS_Store b/vifm/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..27f50f611bd1b17f0d381d31314a880d6a537147 GIT binary patch literal 6148 zcmeHKK~BR!475uGL0od=xL>IFKw5@w%z1<)&G}o`1fz+3W4cEcIFc>eJruzb64x&>8KJ$(A0d zrN{A`#Lub6el9QXeJ-PU>gGF}!(PLDN_T_;reX2s*J8!&gf2B{T}`K{~+Fuv3Hu;v0cTgE!8=pEB?TAnr~Y literal 0 HcmV?d00001 diff --git a/vifm/vifminfo.json b/vifm/vifminfo.json index 3e442cb..705341c 100644 --- a/vifm/vifminfo.json +++ b/vifm/vifminfo.json @@ -1 +1 @@ -{"gtabs":[{"panes":[{"ptabs":[{"history":[{"dir":"/Users/nasr/torque/scala-3-project-template","file":"..","relpos":0,"ts":1763211312},{"dir":"/Users/nasr/torque","file":"scala-3-project-template","relpos":1,"ts":1763211312},{"dir":"/Users/nasr/torque/scala-3-project-template","file":"..","relpos":0,"ts":1763211312},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.torque","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763212637},{"dir":"/Users/nasr","file":"torque","relpos":38,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"test","relpos":4,"ts":1763212637},{"dir":"/Users/nasr","file":"torque","relpos":38,"ts":1763212637},{"dir":"/Users","file":"nasr","relpos":3,"ts":1763212637},{"dir":"/Users/nasr","file":"torque","relpos":38,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"project","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/project","file":"target","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"src","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"src","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.torque","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr","file":"torque","relpos":38,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"test","relpos":4,"ts":1763212637},{"dir":"/Users/nasr","file":"torque","relpos":38,"ts":1763212637},{"dir":"/Users","file":"nasr","relpos":3,"ts":1763212637},{"dir":"/Users/nasr","file":"torque","relpos":38,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"project","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/project","file":"target","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"src","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"src","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.torque","file":"..","relpos":0,"ts":1763212711},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.torque","relpos":1,"ts":1763212711},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.torque","file":"Main.scala","relpos":1,"ts":1763212711},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.torque","relpos":1,"ts":1763212711},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.torque","file":"..","relpos":0,"ts":1763212711},{"dir":"/Users/nasr/torque/src/main/scala","file":"..","relpos":0,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763242443},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763242443},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main/scala","file":"..","relpos":0,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main/scala","file":"com","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com","file":"nsrddyn","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn","file":"torque","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque","file":"cpu","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"FPU","relpos":2,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/FPU","file":"FPU.scala","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala","file":"com","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com","file":"nsrddyn","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn","file":"torque","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque","file":"cpu","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"FPU","relpos":2,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/FPU","file":"FloatLoad.scala","relpos":2,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"FPU","relpos":2,"ts":1763314074},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn","file":"..","relpos":0,"ts":1763314074}],"filters":{"invert":true,"dot":true,"manual":"","auto":""},"last-location":"/Users/nasr/torque/src/main/scala/com/nsrddyn","sorting":[2],"preview":true}]},{"ptabs":[{"history":[{"dir":"/Users/nasr/torque","file":"..","relpos":0,"ts":1763133114},{"dir":"/Users","file":"nasr","relpos":3,"ts":1763242978},{"dir":"/Users/nasr","file":"torque","relpos":35,"ts":1763242978},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala","file":"com","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com","file":"nsrddyn","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn","file":"torque","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque","file":"cpu","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"ALU","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/ALU","file":"..","relpos":0,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"FPU","relpos":2,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/FPU","file":"ALU","relpos":1,"ts":1763243523},{"dir":"/Users/nasr","file":"torque","relpos":35,"ts":1763243523},{"dir":"/Users/nasr/torque","file":"src","relpos":2,"ts":1763243523}],"filters":{"invert":true,"dot":true,"manual":"","auto":""},"last-location":"/Users/nasr/torque","sorting":[2],"preview":true}]}],"active-pane":0,"preview":true,"splitter":{"pos":-1,"ratio":0.5,"orientation":"v","expanded":false}}],"active-gtab":0,"trash":[{"trashed":"/Users/nasr/.local/share/vifm/Trash/000_com.nsrddyn.com","original":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/com.nsrddyn.com"},{"trashed":"/Users/nasr/.local/share/vifm/Trash/000_com.nsrddyn.com","original":"/Users/nasr/torque/com.nsrddyn.com"}],"marks":{"H":{"dir":"/Users/nasr/","file":"..","ts":1763133037},"b":{"dir":"/Users/nasr/bin/","file":"..","ts":1763133037},"h":{"dir":"/Users/nasr/","file":"..","ts":1763133037},"k":{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"MatrixLoad.scala","ts":1763242947},"z":{"dir":"/Users/nasr/.config/vifm","file":"..","ts":1763133037}},"bmarks":{},"cmd-hist":[{"text":"lj","ts":1763133114},{"text":"mkdir resources","ts":1763133376},{"text":"mkdir l","ts":1763133376},{"text":"mkdir scala","ts":1763133376},{"text":"mhk","ts":1763133376},{"text":"mkdir test","ts":1763133376},{"text":"mkdir resources scala","ts":1763133376},{"text":"mkdir example","ts":1763133376},{"text":"touch Hello.scala","ts":1763133376},{"text":"mkdir main","ts":1763133376},{"text":"rm -rf ","ts":1763133494},{"text":"qiut","ts":1763211312},{"text":"quit","ts":1763211312},{"text":"mkdir com.nsrddyn.com","ts":1763212637},{"text":"rename com.nsrddyn.torque scala","ts":1763212637},{"text":"mv com.nsrddyn.torque scala","ts":1763212637},{"text":"rename scala","ts":1763212637},{"text":"mv com.nsrddyn.com","ts":1763212637},{"text":"move test/","ts":1763212637},{"text":"move Main.scala com.nsrddyn.vcom","ts":1763212637},{"text":"move com.nsrddyn.com","ts":1763212637},{"text":"delete ","ts":1763212637},{"text":"make Main.scala","ts":1763212637},{"text":"touch Main.scala","ts":1763212637},{"text":"rename com.nsrddyn.torque","ts":1763212711},{"text":"vim","ts":1763212711},{"text":"view","ts":1763212711},{"text":"move Main.scala com.nsrddyn.com","ts":1763242701},{"text":"mkdir ALU","ts":1763242701},{"text":"rename CPU","ts":1763242701},{"text":"rename CPU.scala","ts":1763242701},{"text":"move ","ts":1763242701},{"text":"rename C","ts":1763242701},{"text":"move ALU/","ts":1763242701},{"text":"classify","ts":1763242701},{"text":"classify ","ts":1763242701},{"text":"edit","ts":1763314074},{"text":"move jjj","ts":1763314074},{"text":"move ALU","ts":1763314074},{"text":"mv ALU","ts":1763314074},{"text":"mv MatrixLoad.scala FPU","ts":1763314074},{"text":"delete","ts":1763314074},{"text":"q","ts":1763314074}],"prompt-hist":[{"text":"IntLoad.scala","ts":1763314074}],"regs":{"\"":["/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/IntLoad.scala","/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/MatrixLoad.scala"]},"dir-stack":[],"use-term-multiplexer":false} \ No newline at end of file +{"gtabs":[{"panes":[{"ptabs":[{"history":[{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.torque","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr","file":"torque","relpos":38,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"test","relpos":4,"ts":1763212637},{"dir":"/Users/nasr","file":"torque","relpos":38,"ts":1763212637},{"dir":"/Users","file":"nasr","relpos":3,"ts":1763212637},{"dir":"/Users/nasr","file":"torque","relpos":38,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"project","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/project","file":"target","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"src","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque","file":"src","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.com","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.com","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main","file":"resources","relpos":1,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/resources","file":"..","relpos":0,"ts":1763212637},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.torque","file":"..","relpos":0,"ts":1763212711},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.torque","relpos":1,"ts":1763212711},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.torque","file":"Main.scala","relpos":1,"ts":1763212711},{"dir":"/Users/nasr/torque/src/main/scala","file":"com.nsrddyn.torque","relpos":1,"ts":1763212711},{"dir":"/Users/nasr/torque/src/main/scala/com.nsrddyn.torque","file":"..","relpos":0,"ts":1763212711},{"dir":"/Users/nasr/torque/src/main/scala","file":"..","relpos":0,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763242443},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763242443},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main/scala","file":"..","relpos":0,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763242443},{"dir":"/Users/nasr/torque/src/main/scala","file":"com","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com","file":"nsrddyn","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn","file":"torque","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque","file":"cpu","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"FPU","relpos":2,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/FPU","file":"FPU.scala","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala","file":"com","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com","file":"nsrddyn","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn","file":"torque","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque","file":"cpu","relpos":1,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"FPU","relpos":2,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/FPU","file":"FloatLoad.scala","relpos":2,"ts":1763242701},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"FPU","relpos":2,"ts":1763314074},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn","file":"..","relpos":0,"ts":1763314074},{"dir":"/Users/nasr","file":"jvm","relpos":30,"ts":1763510103},{"dir":"/Users/nasr/jvm","file":"torque","relpos":1,"ts":1763510103},{"dir":"/Users/nasr/jvm/torque","file":"src","relpos":2,"ts":1763510103},{"dir":"/Users/nasr/jvm/torque/src","file":"main","relpos":1,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main","file":"scala","relpos":1,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala","file":"com","relpos":1,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com","file":"..","relpos":0,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala","file":"com","relpos":1,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com","file":"..","relpos":0,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala","file":"com","relpos":1,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com","file":"..","relpos":0,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala","file":"com","relpos":1,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com","file":"..","relpos":0,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala","file":"com","relpos":1,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com","file":"nsrddyn","relpos":1,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn","file":"cpu","relpos":1,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn/cpu","file":"ALU","relpos":1,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn","file":"tools","relpos":2,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn/tools","file":"..","relpos":0,"ts":1763510221},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn","file":"tools","relpos":2,"ts":1763510412},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn/tools","file":"Benchmark.scala","relpos":1,"ts":1763510412},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn","file":"tools","relpos":2,"ts":1763510972},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn/tools","file":"Measurable.scala","relpos":1,"ts":1763510972},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn","file":"tools","relpos":2,"ts":1763655645},{"dir":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn/tools","file":"Measurable.scala","relpos":1,"ts":1763655645}],"filters":{"invert":true,"dot":true,"manual":"","auto":""},"last-location":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn/tools","sorting":[2],"preview":true}]},{"ptabs":[{"history":[{"dir":"/Users/nasr/torque","file":"..","relpos":0,"ts":1763133114},{"dir":"/Users","file":"nasr","relpos":3,"ts":1763242978},{"dir":"/Users/nasr","file":"torque","relpos":35,"ts":1763242978},{"dir":"/Users/nasr/torque/src","file":"main","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main","file":"scala","relpos":2,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala","file":"com","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com","file":"nsrddyn","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn","file":"torque","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque","file":"cpu","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"ALU","relpos":1,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/ALU","file":"..","relpos":0,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"FPU","relpos":2,"ts":1763243523},{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/FPU","file":"ALU","relpos":1,"ts":1763243523},{"dir":"/Users/nasr","file":"torque","relpos":35,"ts":1763243523},{"dir":"/Users/nasr/torque","file":"src","relpos":2,"ts":1763243523},{"dir":"/Users/nasr","file":"","relpos":0,"ts":1763510103}],"filters":{"invert":true,"dot":true,"manual":"","auto":""},"last-location":"/Users/nasr","sorting":[2],"preview":true}]}],"active-pane":0,"preview":true,"splitter":{"pos":-1,"ratio":0.5,"orientation":"v","expanded":false}}],"active-gtab":0,"trash":[{"trashed":"/Users/nasr/.local/share/vifm/Trash/000_Benchmark.scala","original":"/Users/nasr/jvm/torque/src/main/scala/com/nsrddyn/tools/Benchmark.scala"},{"trashed":"/Users/nasr/.local/share/vifm/Trash/000_com.nsrddyn.com","original":"/Users/nasr/torque/com.nsrddyn.com"},{"trashed":"/Users/nasr/.local/share/vifm/Trash/000_com.nsrddyn.com","original":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu/com.nsrddyn.com"}],"marks":{"H":{"dir":"/Users/nasr/","file":"..","ts":1763133037},"b":{"dir":"/Users/nasr/bin/","file":"..","ts":1763133037},"h":{"dir":"/Users/nasr/","file":"..","ts":1763133037},"k":{"dir":"/Users/nasr/torque/src/main/scala/com/nsrddyn/torque/cpu","file":"MatrixLoad.scala","ts":1763242947},"z":{"dir":"/Users/nasr/.config/vifm","file":"..","ts":1763133037}},"bmarks":{},"cmd-hist":[{"text":"lj","ts":1763133114},{"text":"mkdir resources","ts":1763133376},{"text":"mkdir l","ts":1763133376},{"text":"mkdir scala","ts":1763133376},{"text":"mhk","ts":1763133376},{"text":"mkdir test","ts":1763133376},{"text":"mkdir resources scala","ts":1763133376},{"text":"mkdir example","ts":1763133376},{"text":"touch Hello.scala","ts":1763133376},{"text":"mkdir main","ts":1763133376},{"text":"rm -rf ","ts":1763133494},{"text":"qiut","ts":1763211312},{"text":"quit","ts":1763211312},{"text":"mkdir com.nsrddyn.com","ts":1763212637},{"text":"rename com.nsrddyn.torque scala","ts":1763212637},{"text":"mv com.nsrddyn.torque scala","ts":1763212637},{"text":"rename scala","ts":1763212637},{"text":"mv com.nsrddyn.com","ts":1763212637},{"text":"move test/","ts":1763212637},{"text":"move Main.scala com.nsrddyn.vcom","ts":1763212637},{"text":"move com.nsrddyn.com","ts":1763212637},{"text":"delete ","ts":1763212637},{"text":"make Main.scala","ts":1763212637},{"text":"touch Main.scala","ts":1763212637},{"text":"rename com.nsrddyn.torque","ts":1763212711},{"text":"vim","ts":1763212711},{"text":"view","ts":1763212711},{"text":"move Main.scala com.nsrddyn.com","ts":1763242701},{"text":"mkdir ALU","ts":1763242701},{"text":"rename CPU","ts":1763242701},{"text":"rename CPU.scala","ts":1763242701},{"text":"move ","ts":1763242701},{"text":"rename C","ts":1763242701},{"text":"move ALU/","ts":1763242701},{"text":"classify","ts":1763242701},{"text":"classify ","ts":1763242701},{"text":"move jjj","ts":1763314074},{"text":"move ALU","ts":1763314074},{"text":"mv ALU","ts":1763314074},{"text":"mv MatrixLoad.scala FPU","ts":1763314074},{"text":"mkdir tools","ts":1763510221},{"text":"touch ","ts":1763510221},{"text":"touch Benchmark.scala","ts":1763510221},{"text":"touch Benchmark.Scala","ts":1763510412},{"text":"edit","ts":1763510412},{"text":"rename Benchmark.scala","ts":1763510469},{"text":"Remove","ts":1763512283},{"text":"delete","ts":1763512283},{"text":"q","ts":1763512283}],"search-hist":[{"text":"jvm/","ts":1763510103}],"prompt-hist":[{"text":"IntLoad.scala","ts":1763314074}],"regs":{"\"":["/Users/nasr/.local/share/vifm/Trash/000_Benchmark.scala"]},"dir-stack":[],"use-term-multiplexer":false} \ No newline at end of file diff --git a/zsh/zshrc b/zsh/zshrc index 25af4f8..344131b 100644 --- a/zsh/zshrc +++ b/zsh/zshrc @@ -1,5 +1,5 @@ export ZSH="$HOME/.oh-my-zsh" -ZSH_THEME="sorin" +ZSH_THEME="steeef" # set by `omz` plugins=(git) source $ZSH/oh-my-zsh.sh @@ -42,9 +42,6 @@ export NVM_DIR="/Users/nasr/Library/Application Support/Herd/config/nvm" [ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm [[ -f "/Applications/Herd.app/Contents/Resources/config/shell/zshrc.zsh" ]] && builtin source "/Applications/Herd.app/Contents/Resources/config/shell/zshrc.zsh" -# Angular autocompletion -source <(ng completion script) - # Homebrew configuration export PATH="$HOME/.local/bin:$PATH" export PKG_CONFIG_PATH="/opt/homebrew/lib/pkgconfig:$PKG_CONFIG_PATH" # Add Homebrew pkg-config path