From c0b9b6bf1ed7a12706cbb023c2505654a7eea26c Mon Sep 17 00:00:00 2001 From: DustVoice Date: Fri, 23 Jun 2023 12:47:10 +0200 Subject: [PATCH] Update nushell, alacritty and starship configs --- .config/alacritty/alacritty.yml | 14 +- .config/nushell/.gitignore | 2 + .config/nushell/config.nu | 396 +++++++++++++++-------------- .config/nushell/env.nu | 87 +++++-- .config/nushell/scripts/.gitignore | 5 + .config/nushell/scripts/nu_scripts | 1 + .config/starship.toml | 74 +----- .emacs.d | 2 +- .gitmodules | 3 + 9 files changed, 289 insertions(+), 295 deletions(-) create mode 100644 .config/nushell/scripts/.gitignore create mode 160000 .config/nushell/scripts/nu_scripts diff --git a/.config/alacritty/alacritty.yml b/.config/alacritty/alacritty.yml index cd6e7eed..b2a0dac4 100644 --- a/.config/alacritty/alacritty.yml +++ b/.config/alacritty/alacritty.yml @@ -120,7 +120,7 @@ font: # - (macOS) Menlo # - (Linux/BSD) monospace # - (Windows) Consolas - family: Hack + family: JetBrainsMono Nerd Font # The `style` can be specified to pick a specific face. style: Regular @@ -131,7 +131,7 @@ font: # # If the bold family is not specified, it will fall back to the # value specified for the normal font. - family: Hack + family: JetBrainsMono Nerd Font # The `style` can be specified to pick a specific face. style: Bold @@ -142,7 +142,7 @@ font: # # If the italic family is not specified, it will fall back to the # value specified for the normal font. - family: Hack + family: JetBrainMono Nerd Font # The `style` can be specified to pick a specific face. style: Italic @@ -153,13 +153,13 @@ font: # # If the bold italic family is not specified, it will fall back to the # value specified for the normal font. - family: Hack + family: JetBrainsMono Nerd Font # The `style` can be specified to pick a specific face. style: Bold Italic # Point size - size: 10.0 + size: 13.0 # Offset is the extra space around each character. `offset.y` can be thought # of as modifying the line spacing, and `offset.x` as modifying the letter @@ -422,8 +422,8 @@ live_config_reload: true # - (macOS) /bin/bash --login # - (Linux/BSD) user login shell # - (Windows) powershell -#shell: -# program: /bin/bash +shell: + program: nu # args: # - --login diff --git a/.config/nushell/.gitignore b/.config/nushell/.gitignore index 893548d9..29b6652e 100644 --- a/.config/nushell/.gitignore +++ b/.config/nushell/.gitignore @@ -4,3 +4,5 @@ !/config.nu !/env.nu + +!/scripts/ diff --git a/.config/nushell/config.nu b/.config/nushell/config.nu index 91182006..56690b23 100644 --- a/.config/nushell/config.nu +++ b/.config/nushell/config.nu @@ -1,145 +1,46 @@ # Nushell Config File +# +# version = 0.80.1 -module completions { - # Custom completions for external commands (those outside of Nushell) - # Each completions has two parts: the form of the external command, including its flags and parameters - # and a helper command that knows how to complete values for those flags and parameters - # - # This is a simplified version of completions for git branches and git remotes - def "nu-complete git branches" [] { - ^git branch | lines | each { |line| $line | str replace '[\*\+] ' '' | str trim } - } - - def "nu-complete git remotes" [] { - ^git remote | lines | each { |line| $line | str trim } - } - - # Download objects and refs from another repository - export extern "git fetch" [ - repository?: string@"nu-complete git remotes" # name of the repository to fetch - branch?: string@"nu-complete git branches" # name of the branch to fetch - --all # Fetch all remotes - --append(-a) # Append ref names and object names to .git/FETCH_HEAD - --atomic # Use an atomic transaction to update local refs. - --depth: int # Limit fetching to n commits from the tip - --deepen: int # Limit fetching to n commits from the current shallow boundary - --shallow-since: string # Deepen or shorten the history by date - --shallow-exclude: string # Deepen or shorten the history by branch/tag - --unshallow # Fetch all available history - --update-shallow # Update .git/shallow to accept new refs - --negotiation-tip: string # Specify which commit/glob to report while fetching - --negotiate-only # Do not fetch, only print common ancestors - --dry-run # Show what would be done - --write-fetch-head # Write fetched refs in FETCH_HEAD (default) - --no-write-fetch-head # Do not write FETCH_HEAD - --force(-f) # Always update the local branch - --keep(-k) # Keep dowloaded pack - --multiple # Allow several arguments to be specified - --auto-maintenance # Run 'git maintenance run --auto' at the end (default) - --no-auto-maintenance # Don't run 'git maintenance' at the end - --auto-gc # Run 'git maintenance run --auto' at the end (default) - --no-auto-gc # Don't run 'git maintenance' at the end - --write-commit-graph # Write a commit-graph after fetching - --no-write-commit-graph # Don't write a commit-graph after fetching - --prefetch # Place all refs into the refs/prefetch/ namespace - --prune(-p) # Remove obsolete remote-tracking references - --prune-tags(-P) # Remove any local tags that do not exist on the remote - --no-tags(-n) # Disable automatic tag following - --refmap: string # Use this refspec to map the refs to remote-tracking branches - --tags(-t) # Fetch all tags - --recurse-submodules: string # Fetch new commits of populated submodules (yes/on-demand/no) - --jobs(-j): int # Number of parallel children - --no-recurse-submodules # Disable recursive fetching of submodules - --set-upstream # Add upstream (tracking) reference - --submodule-prefix: string # Prepend to paths printed in informative messages - --upload-pack: string # Non-default path for remote command - --quiet(-q) # Silence internally used git commands - --verbose(-v) # Be verbose - --progress # Report progress on stderr - --server-option(-o): string # Pass options for the server to handle - --show-forced-updates # Check if a branch is force-updated - --no-show-forced-updates # Don't check if a branch is force-updated - -4 # Use IPv4 addresses, ignore IPv6 addresses - -6 # Use IPv6 addresses, ignore IPv4 addresses - --help # Display the help message for this command - ] - - # Check out git branches and files - export extern "git checkout" [ - ...targets: string@"nu-complete git branches" # name of the branch or files to checkout - --conflict: string # conflict style (merge or diff3) - --detach(-d) # detach HEAD at named commit - --force(-f) # force checkout (throw away local modifications) - --guess # second guess 'git checkout ' (default) - --ignore-other-worktrees # do not check if another worktree is holding the given ref - --ignore-skip-worktree-bits # do not limit pathspecs to sparse entries only - --merge(-m) # perform a 3-way merge with the new branch - --orphan: string # new unparented branch - --ours(-2) # checkout our version for unmerged files - --overlay # use overlay mode (default) - --overwrite-ignore # update ignored files (default) - --patch(-p) # select hunks interactively - --pathspec-from-file: string # read pathspec from file - --progress # force progress reporting - --quiet(-q) # suppress progress reporting - --recurse-submodules: string # control recursive updating of submodules - --theirs(-3) # checkout their version for unmerged files - --track(-t) # set upstream info for new branch - -b: string # create and checkout a new branch - -B: string # create/reset and checkout a branch - -l # create reflog for new branch - --help # Display the help message for this command - ] - - # Push changes - export extern "git push" [ - remote?: string@"nu-complete git remotes", # the name of the remote - ...refs: string@"nu-complete git branches" # the branch / refspec - --all # push all refs - --atomic # request atomic transaction on remote side - --delete(-d) # delete refs - --dry-run(-n) # dry run - --exec: string # receive pack program - --follow-tags # push missing but relevant tags - --force-with-lease # require old value of ref to be at this value - --force(-f) # force updates - --ipv4(-4) # use IPv4 addresses only - --ipv6(-6) # use IPv6 addresses only - --mirror # mirror all refs - --no-verify # bypass pre-push hook - --porcelain # machine-readable output - --progress # force progress reporting - --prune # prune locally removed refs - --push-option(-o): string # option to transmit - --quiet(-q) # be more quiet - --receive-pack: string # receive pack program - --recurse-submodules: string # control recursive pushing of submodules - --repo: string # repository - --set-upstream(-u) # set upstream for git pull/status - --signed: string # GPG sign the push - --tags # push tags (can't be used with --all or --mirror) - --thin # use thin pack - --verbose(-v) # be more verbose - --help # Display the help message for this command - ] -} - -# Get just the extern definitions without the custom completion commands -use completions * - -# for more information on themes see +# For more information on defining custom themes, see # https://www.nushell.sh/book/coloring_and_theming.html +# And here is the theme collection +# https://github.com/nushell/nu_scripts/tree/main/themes let dark_theme = { # color for nushell primitives separator: white leading_trailing_space_bg: { attr: n } # no fg, no bg, attr none effectively turns this off header: green_bold empty: blue - bool: white + # Closures can be used to choose colors for specific values. + # The value (in this case, a bool) is piped into the closure. + bool: {|| if $in { 'light_cyan' } else { 'light_gray' } } int: white - filesize: white + filesize: {|e| + if $e == 0b { + 'white' + } else if $e < 1mb { + 'cyan' + } else { 'blue' } + } duration: white - date: white + date: {|| (date now) - $in | + if $in < 1hr { + 'purple' + } else if $in < 6hr { + 'red' + } else if $in < 1day { + 'yellow' + } else if $in < 3day { + 'green' + } else if $in < 1wk { + 'light_green' + } else if $in < 6wk { + 'cyan' + } else if $in < 52wk { + 'blue' + } else { 'dark_gray' } + } range: white float: white string: white @@ -151,35 +52,43 @@ let dark_theme = { list: white block: white hints: dark_gray + search_result: {bg: red fg: white} - # shapes are used to change the cli syntax highlighting - shape_garbage: { fg: "#FFFFFF" bg: "#FF0000" attr: b} + shape_and: purple_bold shape_binary: purple_bold + shape_block: blue_bold shape_bool: light_cyan - shape_int: purple_bold - shape_float: purple_bold - shape_range: yellow_bold - shape_internalcall: cyan_bold + shape_closure: green_bold + shape_custom: green + shape_datetime: cyan_bold + shape_directory: cyan shape_external: cyan shape_externalarg: green_bold + shape_filepath: cyan + shape_flag: blue_bold + shape_float: purple_bold + # shapes are used to change the cli syntax highlighting + shape_garbage: { fg: white bg: red attr: b} + shape_globpattern: cyan_bold + shape_int: purple_bold + shape_internalcall: cyan_bold + shape_list: cyan_bold shape_literal: blue + shape_match_pattern: green + shape_matching_brackets: { attr: u } + shape_nothing: light_cyan shape_operator: yellow + shape_or: purple_bold + shape_pipe: purple_bold + shape_range: yellow_bold + shape_record: cyan_bold + shape_redirection: purple_bold shape_signature: green_bold shape_string: green shape_string_interpolation: cyan_bold - shape_datetime: cyan_bold - shape_list: cyan_bold shape_table: blue_bold - shape_record: cyan_bold - shape_block: blue_bold - shape_filepath: cyan - shape_directory: cyan - shape_globpattern: cyan_bold shape_variable: purple - shape_flag: blue_bold - shape_custom: green - shape_nothing: light_cyan - shape_matching_brackets: { attr: u } + shape_vardecl: purple } let light_theme = { @@ -188,11 +97,35 @@ let light_theme = { leading_trailing_space_bg: { attr: n } # no fg, no bg, attr none effectively turns this off header: green_bold empty: blue - bool: dark_gray + # Closures can be used to choose colors for specific values. + # The value (in this case, a bool) is piped into the closure. + bool: {|| if $in { 'dark_cyan' } else { 'dark_gray' } } int: dark_gray - filesize: dark_gray + filesize: {|e| + if $e == 0b { + 'dark_gray' + } else if $e < 1mb { + 'cyan_bold' + } else { 'blue_bold' } + } duration: dark_gray - date: dark_gray + date: {|| (date now) - $in | + if $in < 1hr { + 'purple' + } else if $in < 6hr { + 'red' + } else if $in < 1day { + 'yellow' + } else if $in < 3day { + 'green' + } else if $in < 1wk { + 'light_green' + } else if $in < 6wk { + 'cyan' + } else if $in < 52wk { + 'blue' + } else { 'dark_gray' } + } range: dark_gray float: dark_gray string: dark_gray @@ -204,45 +137,55 @@ let light_theme = { list: white block: white hints: dark_gray + search_result: {fg: white bg: red} - # shapes are used to change the cli syntax highlighting - shape_garbage: { fg: "#FFFFFF" bg: "#FF0000" attr: b} + shape_and: purple_bold shape_binary: purple_bold + shape_block: blue_bold shape_bool: light_cyan - shape_int: purple_bold - shape_float: purple_bold - shape_range: yellow_bold - shape_internalcall: cyan_bold + shape_closure: green_bold + shape_custom: green + shape_datetime: cyan_bold + shape_directory: cyan shape_external: cyan shape_externalarg: green_bold + shape_filepath: cyan + shape_flag: blue_bold + shape_float: purple_bold + # shapes are used to change the cli syntax highlighting + shape_garbage: { fg: white bg: red attr: b} + shape_globpattern: cyan_bold + shape_int: purple_bold + shape_internalcall: cyan_bold + shape_list: cyan_bold shape_literal: blue + shape_match_pattern: green + shape_matching_brackets: { attr: u } + shape_nothing: light_cyan shape_operator: yellow + shape_or: purple_bold + shape_pipe: purple_bold + shape_range: yellow_bold + shape_record: cyan_bold + shape_redirection: purple_bold shape_signature: green_bold shape_string: green shape_string_interpolation: cyan_bold - shape_datetime: cyan_bold - shape_list: cyan_bold shape_table: blue_bold - shape_record: cyan_bold - shape_block: blue_bold - shape_filepath: cyan - shape_directory: cyan - shape_globpattern: cyan_bold shape_variable: purple - shape_flag: blue_bold - shape_custom: green - shape_nothing: light_cyan - shape_matching_brackets: { attr: u } + shape_vardecl: purple } # External completer example -# let carapace_completer = {|spans| -# carapace $spans.0 nushell $spans | from json -# } +let carapace_completer = {|spans| + carapace $spans.0 nushell $spans | from json +} # The default config record. This is where much of your global configuration is setup. let-env config = { + # true or false to enable or disable the welcome banner at startup + show_banner: false ls: { use_ls_colors: true # use the LS_COLORS environment variable to colorize output clickable_links: true # enable or disable clickable links. Your terminal has to support links. @@ -251,21 +194,81 @@ let-env config = { always_trash: false # always act as if -t was given. Can be overridden with -p } cd: { - abbreviations: true # allows `cd s/o/f` to expand to `cd some/other/folder` + abbreviations: false # allows `cd s/o/f` to expand to `cd some/other/folder` } table: { mode: rounded # basic, compact, compact_double, light, thin, with_love, rounded, reinforced, heavy, none, other index_mode: always # "always" show indexes, "never" show indexes, "auto" = show indexes when a table has "index" column + show_empty: true # show 'empty list' and 'empty record' placeholders for command output trim: { methodology: wrapping # wrapping or truncating wrapping_try_keep_words: true # A strategy used by the 'wrapping' methodology truncating_suffix: "..." # A suffix used by the 'truncating' methodology } } + + explore: { + help_banner: true + exit_esc: true + + command_bar_text: '#C4C9C6' + # command_bar: {fg: '#C4C9C6' bg: '#223311' } + + status_bar_background: {fg: '#1D1F21' bg: '#C4C9C6' } + # status_bar_text: {fg: '#C4C9C6' bg: '#223311' } + + highlight: {bg: 'yellow' fg: 'black' } + + status: { + # warn: {bg: 'yellow', fg: 'blue'} + # error: {bg: 'yellow', fg: 'blue'} + # info: {bg: 'yellow', fg: 'blue'} + } + + try: { + # border_color: 'red' + # highlighted_color: 'blue' + + # reactive: false + } + + table: { + split_line: '#404040' + + cursor: true + + line_index: true + line_shift: true + line_head_top: true + line_head_bottom: true + + show_head: true + show_index: true + + # selected_cell: {fg: 'white', bg: '#777777'} + # selected_row: {fg: 'yellow', bg: '#C1C2A3'} + # selected_column: blue + + # padding_column_right: 2 + # padding_column_left: 2 + + # padding_index_left: 2 + # padding_index_right: 1 + } + + config: { + cursor_color: {bg: 'yellow' fg: 'black' } + + # border_color: white + # list_color: green + } + } + history: { max_size: 10000 # Session has to be reloaded for this to take effect sync_on_enter: true # Enable to share history between multiple sessions, else you have to close the session to write history to file file_format: "plaintext" # "sqlite" or "plaintext" + history_isolation: true # true enables history isolation, false disables it. true will allow the history to be isolated to the current session. false will allow the history to be shared across all sessions. } completions: { case_sensitive: false # set to true to enable case-sensitive completions @@ -274,43 +277,52 @@ let-env config = { algorithm: "prefix" # prefix or fuzzy external: { enable: true # set to false to prevent nushell looking into $env.PATH to find more suggestions, `false` recommended for WSL users as this look up my be very slow - max_results: 100 # setting it lower can improve completion performance at the cost of omitting some options - completer: null # check 'carapace_completer' above as an example + max_results: 50 # setting it lower can improve completion performance at the cost of omitting some options + completer: $carapace_completer # check 'carapace_completer' above as an example } } filesize: { metric: true # true => KB, MB, GB (ISO standard), false => KiB, MiB, GiB (Windows standard) format: "auto" # b, kb, kib, mb, mib, gb, gib, tb, tib, pb, pib, eb, eib, zb, zib, auto } + cursor_shape: { + emacs: line # block, underscore, line, blink_block, blink_underscore, blink_line (line is the default) + vi_insert: line # block, underscore, line , blink_block, blink_underscore, blink_line (block is the default) + vi_normal: block # block, underscore, line, blink_block, blink_underscore, blink_line (underscore is the default) + } color_config: $dark_theme # if you want a light theme, replace `$dark_theme` to `$light_theme` use_grid_icons: true footer_mode: "25" # always, never, number_of_rows, auto - float_precision: 2 + float_precision: 2 # the precision for displaying floats in tables # buffer_editor: "emacs" # command that will be used to edit the current line buffer with ctrl+o, if unset fallback to $env.EDITOR and $env.VISUAL use_ansi_coloring: true + bracketed_paste: true # enable bracketed paste, currently useless on windows edit_mode: vi # emacs, vi shell_integration: true # enables terminal markers and a workaround to arrow keys stop working issue - show_banner: false # true or false to enable or disable the banner render_right_prompt_on_last_line: false # true or false to enable or disable right prompt to be rendered on last line of the prompt. + hooks: { - pre_prompt: [{ - $nothing # replace with source code to run before the prompt is shown + pre_prompt: [{|| + null # replace with source code to run before the prompt is shown }] - pre_execution: [{ - $nothing # replace with source code to run before the repl input is run + pre_execution: [{|| + null # replace with source code to run before the repl input is run }] env_change: { PWD: [{|before, after| - $nothing # replace with source code to run if the PWD environment is different since the last repl input + null # replace with source code to run if the PWD environment is different since the last repl input }] } - display_output: { + display_output: {|| if (term size).columns >= 100 { table -e } else { table } } + command_not_found: {|| + null # replace with source code to return an error message when a command is not found + } } menus: [ # Configuration for default nushell menus - # Note the lack of souce parameter + # Note the lack of source parameter { name: completion_menu only_buffer_difference: false @@ -379,8 +391,8 @@ let-env config = { } source: { |buffer, position| $nu.scope.commands - | where command =~ $buffer - | each { |it| {value: $it.command description: $it.usage} } + | where name =~ $buffer + | each { |it| {value: $it.name description: $it.usage} } } } { @@ -422,8 +434,8 @@ let-env config = { } source: { |buffer, position| $nu.scope.commands - | where command =~ $buffer - | each { |it| {value: $it.command description: $it.usage} } + | where name =~ $buffer + | each { |it| {value: $it.name description: $it.usage} } } } ] @@ -432,7 +444,7 @@ let-env config = { name: completion_menu modifier: none keycode: tab - mode: emacs # Options: emacs vi_normal vi_insert + mode: [emacs vi_normal vi_insert] event: { until: [ { send: menu name: completion_menu } @@ -531,4 +543,12 @@ let-env config = { ] } + +const dracula_path = './nu_scripts/themes/themes/dracula.nu' +if ($dracula_path | path exists) { + use $dracula_path + let-env config = ($env.config | merge {color_config: (dracula)}) +} + source ~/.cache/starship/init.nu +source ~/.cache/zoxide/init.nu diff --git a/.config/nushell/env.nu b/.config/nushell/env.nu index 129d23de..bc1b5488 100644 --- a/.config/nushell/env.nu +++ b/.config/nushell/env.nu @@ -1,29 +1,58 @@ # Nushell Environment Config File - -let-env STARSHIP_SHELL = "nu" - -# def create_left_prompt [] { -# starship prompt --cmd-duration $env.CMD_DURATION_MS $'--status=($env.LAST_EXIT_CODE)' $'--keymap=($env.STARSHIP_KEYMAP)' -# } # -# def create_right_prompt [] { -# let time_segment = ([ -# (date now | date format '%m/%d/%Y %r') -# ] | str join) -# -# $time_segment -# } +# version = 0.80.1 + +def create_left_prompt [] { + mut home = "" + try { + if $nu.os-info.name == "windows" { + $home = $env.USERPROFILE + } else { + $home = $env.HOME + } + } + + let dir = ([ + ($env.PWD | str substring 0..($home | str length) | str replace --string $home "~"), + ($env.PWD | str substring ($home | str length)..) + ] | str join) + + let path_color = (if (is-admin) { ansi red_bold } else { ansi green_bold }) + let separator_color = (if (is-admin) { ansi light_red_bold } else { ansi light_green_bold }) + let path_segment = $"($path_color)($dir)" + + $path_segment | str replace --all --string (char path_sep) $"($separator_color)/($path_color)" +} + +def create_right_prompt [] { + let time_segment_color = (ansi magenta) + + let time_segment = ([ + (ansi reset) + $time_segment_color + (date now | date format '%m/%d/%Y %r') + ] | str join | str replace --all "([/:])" $"(ansi light_magenta_bold)${1}($time_segment_color)" | + str replace --all "([AP]M)" $"(ansi light_magenta_underline)${1}") + + let last_exit_code = if ($env.LAST_EXIT_CODE != 0) {([ + (ansi rb) + ($env.LAST_EXIT_CODE) + ] | str join) + } else { "" } + + ([$last_exit_code, (char space), $time_segment] | str join) +} # Use nushell functions to define your right and left prompt -# let-env PROMPT_COMMAND = { create_left_prompt } -# let-env PROMPT_COMMAND_RIGHT = { create_right_prompt } +let-env PROMPT_COMMAND = {|| create_left_prompt } +let-env PROMPT_COMMAND_RIGHT = {|| create_right_prompt } # The prompt indicators are environmental variables that represent # the state of the prompt -# let-env PROMPT_INDICATOR = { "" } -# let-env PROMPT_INDICATOR_VI_INSERT = { "" } -# let-env PROMPT_INDICATOR_VI_NORMAL = { "" } -# let-env PROMPT_MULTILINE_INDICATOR = { "" } +let-env PROMPT_INDICATOR = {|| "> " } +let-env PROMPT_INDICATOR_VI_INSERT = {|| "> " } +let-env PROMPT_INDICATOR_VI_NORMAL = {|| ": " } +let-env PROMPT_MULTILINE_INDICATOR = {|| ">>> " } # Specifies how environment variables are: # - converted from a string to a value on Nushell startup (from_string) @@ -31,12 +60,12 @@ let-env STARSHIP_SHELL = "nu" # Note: The conversions happen *after* config.nu is loaded let-env ENV_CONVERSIONS = { "PATH": { - from_string: { |s| $s | split row (char esep) | path expand -n } - to_string: { |v| $v | path expand -n | str join (char esep) } + from_string: { |s| $s | split row (char esep) | path expand --no-symlink } + to_string: { |v| $v | path expand --no-symlink | str join (char esep) } } "Path": { - from_string: { |s| $s | split row (char esep) | path expand -n } - to_string: { |v| $v | path expand -n | str join (char esep) } + from_string: { |s| $s | split row (char esep) | path expand --no-symlink } + to_string: { |v| $v | path expand --no-symlink | str join (char esep) } } } @@ -44,18 +73,24 @@ let-env ENV_CONVERSIONS = { # # By default, /scripts is added let-env NU_LIB_DIRS = [ - ($nu.config-path | path dirname | path join 'scripts') + ($nu.default-config-dir | path join 'scripts') ] # Directories to search for plugin binaries when calling register # # By default, /plugins is added let-env NU_PLUGIN_DIRS = [ - ($nu.config-path | path dirname | path join 'plugins') + ($nu.default-config-dir | path join 'plugins') ] # To add entries to PATH (on Windows you might use Path), you can use the following pattern: # let-env PATH = ($env.PATH | split row (char esep) | prepend '/some/path') mkdir ~/.cache/starship -starship init nu | str replace --string "size -c" "size" | save ~/.cache/starship/init.nu +starship init nu | save -f ~/.cache/starship/init.nu + +# mkdir ~/.cache/oh-my-posh +# oh-my-posh init nu --config 'https://raw.githubusercontent.com/JanDeDobbeleer/oh-my-posh/main/themes/dracula.omp.json' --print | save -f ~/.cache/oh-my-posh/init.nu + +mkdir ~/.cache/zoxide +zoxide init nushell --cmd cd | save -f ~/.cache/zoxide/init.nu diff --git a/.config/nushell/scripts/.gitignore b/.config/nushell/scripts/.gitignore new file mode 100644 index 00000000..83582b19 --- /dev/null +++ b/.config/nushell/scripts/.gitignore @@ -0,0 +1,5 @@ +/* +/*/ +!/.gitignore + +!/nu_scripts diff --git a/.config/nushell/scripts/nu_scripts b/.config/nushell/scripts/nu_scripts new file mode 160000 index 00000000..fde7f5b7 --- /dev/null +++ b/.config/nushell/scripts/nu_scripts @@ -0,0 +1 @@ +Subproject commit fde7f5b768b09fc40a90b2e0d6013a21784f6b07 diff --git a/.config/starship.toml b/.config/starship.toml index 78df9bab..0522b482 100644 --- a/.config/starship.toml +++ b/.config/starship.toml @@ -4,79 +4,7 @@ add_newline = true scan_timeout = 30 command_timeout = 500 -format = """ -$username\ -$hostname\ -$localip\ -$shlvl\ -$singularity\ -$kubernetes\ -$directory\ -$vcsh\ -$git_branch\ -$git_commit\ -$git_state\ -$git_metrics\ -$git_status\ -$hg_branch\ -$docker_context\ -$package\ -$buf\ -$c\ -$cmake\ -$cobol\ -$container\ -$dart\ -$deno\ -$dotnet\ -$elixir\ -$elm\ -$erlang\ -$golang\ -$haskell\ -$helm\ -$java\ -$julia\ -$kotlin\ -$lua\ -$nim\ -$nodejs\ -$ocaml\ -$perl\ -$php\ -$pulumi\ -$purescript\ -$python\ -$rlang\ -$red\ -$ruby\ -$rust\ -$scala\ -$swift\ -$terraform\ -$vlang\ -$vagrant\ -$zig\ -$nix_shell\ -$conda\ -$spack\ -$memory_usage\ -$aws\ -$gcloud\ -$openstack\ -$azure\ -$env_var\ -$crystal\ -$custom\ -$sudo\ -$cmd_duration\ -$line_break\ -$jobs\ -$battery\ -$time\ -$status\ -$shell\ -$character""" +format = '$all' continuation_prompt = ">>>" diff --git a/.emacs.d b/.emacs.d index 4e105a95..07fca786 160000 --- a/.emacs.d +++ b/.emacs.d @@ -1 +1 @@ -Subproject commit 4e105a95af9c4c7e86471e5566eb7a5ff776ec92 +Subproject commit 07fca786154551f90f36535bfb21f8ca4abd5027 diff --git a/.gitmodules b/.gitmodules index 0c2dda84..3aa82465 100644 --- a/.gitmodules +++ b/.gitmodules @@ -13,3 +13,6 @@ [submodule ".emacs.d"] path = .emacs.d url = https://github.com/doomemacs/doomemacs +[submodule ".config/nushell/scripts/nu_scripts"] + path = .config/nushell/scripts/nu_scripts + url = https://github.com/nushell/nu_scripts