配置
Nushell 配置与env.nu
和config.nu
Nushell 使用一个配置系统,在启动时加载并运行两个 Nushell 脚本文件: 首先是env.nu
,然后是config.nu
。 这些文件的路径可以通过调用echo $nu.env-path
和echo $nu.config-path
找到。 env.nu
是用来定义环境变量的,之后这些环境变量定义将在config.nu
中可用; config.nu
可以用来在全局命名空间中添加定义、别名等等。
(你可以把 Nushell 的配置加载顺序想象成在启动时执行两行 REPL:source /path/to/env.nu
和source /path/to/config.nu
。因此,用env.nu
表示环境,用config.nu
表示其他配置只是一个约定。)
当你在没有设置这些文件的情况下启动 Nushell,Nushell 会提示你下载default env.nu
和default config.nu
。 你可以通过浏览这些默认文件,了解环境变量的默认值和所有可配置项的列表。
配置 $env.config
Nushell 的主要设置是以记录的形式保存在 config
环境变量中。这个记录可以用以下方式创建:
$env.config = {
...
}
你也可以隐藏(shadow)$env.config
并更新它:
$env.config = ($env.config | upsert <field name> <field value>)
按照约定,这个变量被定义在config.nu
文件中。
环境
你可以在 Nushell 会话期间使用 $env.<var> = <val>
在 env.nu
文件中设置环境变量。比如:
$env.FOO = 'BAR'
(尽管 $env.config
是一个环境变量,按照惯例它仍然在 config.nu
中定义。)
以下是值得关注的且为 Nushell 所特有的几个相对重要的环境变量:
LS_COLORS
: 在ls
中为每个文件类型设置颜色PROMPT_COMMAND
: 为设置提示而执行的代码(块或字符串)PROMPT_COMMAND_RIGHT
: 为设置正确的提示而执行的代码(块)PROMPT_INDICATOR = "〉"
: 提示后打印的提示符(默认为 ">" 类似的 Unicode 符号)PROMPT_INDICATOR_VI_INSERT = ": "
PROMPT_INDICATOR_VI_NORMAL = "〉 "
PROMPT_MULTILINE_INDICATOR = "::: "
使用内置命令进行配置
从 Nushell 0.64 版本开始新增了两个内置命令(config nu
和 config env
), 通过这两个命令,你可以使用自定义的编辑器或者 IDE 快速地更改 Nushell 配置信息
Nushell 遵循如下的规则来匹配编辑器:
$config.buffer_editor
$env.EDITOR
$env.VISUAL
- 如果上面都未匹配成功,则针对 Windows 运行
notepad
, 其他系统nano
颜色配置部分
你可以在 相关章节 中了解更多关于设置颜色和主题的信息。
将 Nu 配置为登录 Shell
要把 Nu 作为一个登录 Shell,你需要配置$env
变量。这样,在你将使用 Nu 为登录 Shell 时才有足够的支持来运行外部命令。
你可以通过在另一个 Shell(如 Bash)中运行 Nu 来建立完整的环境变量集。一旦你进入 Nu,你可以运行这样的命令:
$env | reject config | transpose key val | each {|r| echo $"$env.($r.key) = '($r.val)'"} | str join (char nl)
这将打印出 $env.<var> = <val>
行,每个环境变量一行包含其设置。您可能不需要所有这些变量,例如,PS1
变量是 bash
特有的。
接下来,在一些发行版上,你还需要确保 Nu 在/etc/shells
列表中:
> cat /etc/shells
# /etc/shells: valid login shells
/bin/sh
/bin/dash
/bin/bash
/bin/rbash
/usr/bin/screen
/usr/bin/fish
/home/sophia/.cargo/bin/nu
这样你就可以使用chsh
命令来将 Nu 设置为你的登录 Shell。在你注销后下次登录时,应该可以看到一个闪亮的 Nu 提示。
使用 login.nu
进行配置
如果 Nushell 被用作登录 Shell,你可以使用一个特定的配置文件,该文件只在该情况下才会被加载。因此,一个名为 login.nu
的文件必须在标准配置目录中。
文件 login.nu
的加载在 env.nu
和 config.nu
之后,所以你可以覆盖这些配置,如果你需要的话。
有一个环境变量 $nu.loginshell-path
包含该文件的路径。
macOS: 保持 open
为 /usr/bin/open
一些工具(例如 Emacs)依靠open
命令来打开 Mac 上的文件。 由于 Nushell 有自己的open
命令,它有不同的语义并隐藏了/usr/bin/open
,这样某些工具在试图使用它时将出错。 一个解决这个问题的方法是为 Nushell 的open
定义一个自定义命令,并在你的config.nu
文件中为系统的open
创建一个别名,像这样:
def nuopen [arg, --raw (-r)] { if $raw { open -r $arg } else { open $arg } }
alias open = ^open
PATH
配置
要在 PATH 变量 中添加一个路径,你可以在 env.nu
中使用 $env.<var> = <val>
和 append
完成,如下:
$env.PATH = ($env.PATH | split row (char esep) | append '/some/path')
这将把 /some/path
追加到 PATH
的末尾;你也可以使用 prepend
将该路径添加到PATH
的开头。