1
0
mirror of https://github.com/Llewellynvdm/starship.git synced 2025-01-23 07:08:25 +00:00

設定

::: tip

🔥 「設定」現在還在建置中。 許多新的設定選項會在之後的版本釋出。

:::

為了開始設定 Starship請建立下右檔案 ~/.config/starship.toml.

$ touch ~/.config/starship.toml

所有關於 Starship 的設定都在這個 TOML 檔案內:

# 不要在提示字元的開頭換行
add_newline = false

# 把提示字元中的 "" 符號換成 "➜"
[character]      # 我們正在設定的模組叫做 "character"
symbol = "➜"     #  設定 "symbol" 區段為 "➜"

# 關閉 package 模組,把它完全從提示字元藏起來
[package]
disabled = true

術語

模組 (Module) 提示字元中的一個元件,基於你的作業系統提供的背景資訊來提供訊息。 舉例來說,如果你現在的資料夾是一個 NodeJS 專案,"nodejs" 模組會顯示出現在安裝在你的電腦上的 NodeJS 版本。

區段 (Segment) 組成一個模組的子元件。 舉例來說,"nodejs" 模組內的 "symbol" 區段包含了一個會顯示在版本編號之前的字元 (預設是 ⬢)。

這是一個 node 模組的表示法。 在下面的例子裡,"symbol" 跟 "version" 都是模組內的區段。 每個模組也包含了使用預設終端機顏色的一個前綴 (prefix) 跟一個後綴 (suffix)。

[prefix]      [symbol]     [version]    [suffix]
 "via "         "⬢"        "v10.4.1"       ""

風格字串

Starship 內大多數的模組允許你設定他們的顯示風格。 這要透過一個條目 (通常叫做 style),這個條目使用一個字串來進行設定。 這裡給幾個風格字串的例子,以及這些字串的功用。 對於完整語法的詳細說明,請參照 進階設定指南

  • "fg:green bg:blue" 在一個藍色背景上設定綠色文字
  • "bg:blue fg:bright-green" 在一個藍色背景上設定亮綠色文字
  • "bold fg:27" 設定具有 ANSI 顏色 27 號的粗體文字
  • "underline bg:#bf5700" 在一個燒橙色背景上設定有底線的文字
  • "bold italic fg:purple" 設定粗體、斜體且紫色的文字
  • "" 明確地關閉所有風格

注意風格產出的樣子取決於你的終端機模擬器。 例如,有些終端機模擬器會提升顏色的亮度而不是讓文字變粗體,而且有些色彩主題對一般與加亮顏色使用的是相同色碼。 除此之外,為了要有斜體字,你的終端機一定要支援斜體。

提示字元

以下是針對提示字元內容的設定。

選項

變數 預設 說明
add_newline true 在提示字元前面加上換行字元。
prompt_order 連結 調整各個提示字元模組的顯示順序。

範例

# ~/.config/starship.toml

# 停用在提示字元前換行的功能
add_newline = false
# 覆寫 default_prompt_order 並使用自訂的 prompt_order
prompt_order=["rust","line_break","package","line_break","character"]

預設的提示字元順序

預設 prompt_order 是用來在 prompt_order 為空時或者沒有提供時定義模組顯示在提示字元的順序。 預設如下:

prompt_order = [
    "username",
    "hostname",
    "kubernetes",
    "directory",
    "git_branch",
    "git_state",
    "git_status",
    "package",
    "dotnet",
    "golang",
    "java",
    "nodejs",
    "python",
    "ruby",
    "rust",
    "nix_shell",
    "conda",
    "memory_usage",
    "aws",
    "env_var",
    "cmd_duration",
    "line_break",
    "jobs",
    "battery",
    "time",
    "character",
]

AWS

aws 模組顯示現在 AWS 的區域與概況。 這是根據 AWS_REGIONAWS_DEFAULT_REGIONAWS_PROFILE 環境變數及 ~/.aws/config 檔案。

選項

變數 預設 說明
symbol "☁️ " 顯示在目前 AWS 配置之前的符號。
style "bold yellow" 這個模組的風格。
disabled false 停用 AWS 模組。

範例

# ~/.config/starship.toml

[aws]
style = "bold blue"
symbol = "🅰 "

電池

battery 模組顯示電池的電量以及現在的充電狀態。 這個模組只會在裝置的電量低於 10% 的時候看見。

選項

變數 預設 說明
full_symbol "•" 當電池充飽時顯示的符號。
charging_symbol "⇡" 當電池正在充電時顯示的符號。
discharging_symbol "⇣" 當電池正在放電時顯示的符號。
display 連結 顯示的門檻與模組的風格。
disabled false 停用 battery 模組。
也有些針對不常見的電池狀態設定的選項。
變數 說明
unknown_symbol 當電池狀態不明時顯示的符號。
empty_symbol 當電池沒電時顯示的符號。

注意:電池指示會在電池狀態不明沒電時隱藏起來,除非你在設定之中有特別指定選項。

範例

# ~/.config/starship.toml

[battery]
full_symbol = "🔋"
charging_symbol = "⚡️"
discharging_symbol = "💀"

電池顯示

display 設定是用來定義甚麼時候電池指示會顯示出來 (threshold),以及它長甚麼樣子 (style)。 如果沒有提供 display。 預設如下:

[[battery.display]]
threshold = 10
style = "bold red"

選項

display 選項是一個下列表格的陣列。

變數 說明
threshold 顯示選項的上界。
style 顯示選項使用時的風格。

範例

[[battery.display]]  # 0% 到 10% 電量之間時,使用 "bold red" 風格
threshold = 10
style = "bold red"

[[battery.display]]  # 10% 到 30% 電量之間時,使用 "bold yellow" 風格
threshold = 30
style = "bold yellow"

# 當電量超過 30% 時,電量指示就不會顯示出來

字元

character 模組在你的文字輸入處旁顯示一個字元 (通常是箭頭)。

這個字元會告訴你最後的指令是成功還是失敗。 他會用兩種方式告訴你:改變他的顏色 (紅色/綠色) 或是改變他的形狀 (/✖)。 後者只會在 use_symbol_for_status 被設定為 true 時出現。

選項

變數 預設 說明
symbol "" 使用在提示字元文字輸入處前的符號。
error_symbol "✖" 如果前一個指令失敗時,使用在文字輸入處前的符號。
use_symbol_for_status false 是否透過改變符號來提示錯誤狀態。
vicmd_symbol "" 如果 shell 正在 vim 正常模式內,在提示字元的文字輸入處前的使用的符號。
style_success "bold green" 最後的指令成功時使用的風格。
style_failure "bold red" 最後的指令失敗時使用的風格。
disabled false 停用 character 模組。

範例

# ~/.config/starship.toml

[character]
symbol = "➜"
error_symbol = "✗"
use_symbol_for_status = true

指令持續時間

cmd_duration 模組顯示最後一個指令執行所花費的時間。 這個模組只會在指令花費超過兩秒或是有設定 min_time 時,超過設定值時出現。

::: warning 不要在 Bash 中設置 DEBUG trap

如果你在 bash 中使用 Starship不要在執行 eval $(starship init $0) 之後設置 DEBUG trap不然這個模組壞掉。

:::

想使用類似 preexec 功能的 Bash 使用者可以 rcaloras 的 bash_preexec 框架。 只要在 eval $(starship init $0) 之前簡單地定義 preexec_functionsprecmd_functions 兩個陣列,然後就可以照常進行。

選項

變數 預設 說明
min_time 2 會顯示的最短時間長度。
prefix took 在指令持續時間正前方顯示的前綴。
style "bold yellow" 這個模組的風格。
disabled false 停用 cmd_duration 模組。

範例

# ~/.config/starship.toml

[cmd_duration]
min_time = 4
prefix = "underwent "

Conda

如果有設定 $CONDA_DEFAULT_ENV 時,conda 模組顯示現在 conda 的環境。 注意:這不會抑制 conda 自己的提示字元修飾字,你可能會想執行 conda config --set changeps1 False

選項

變數 預設 說明
symbol "C " 環境名稱前使用的符號。
style "bold green" 模組的風格。
disabled false 停用 conda 模組。

範例

# ~/.config/starship.toml

[conda]
style = "dimmed green"

資料夾

directory 模組顯示到現在資料夾的路徑,並裁減到前三層資料夾。 你的資料夾也會被裁減到你所在的 git 儲存庫的根目錄。

如果正在使用 fish 風格的 pwd 選項,將不會隱藏被裁減的資料夾,而是會根據你在選項中設定的數字看到每一層資料夾的縮寫。

例如,給定一個右列的路徑 ~/Dev/Nix/nixpkgs/pkgs 其中 nixpkgs 是儲存庫的根目錄,而且該選項被設定為 1。 你會看到 ~/D/N/nixpkgs/pkgs,而在這個設定之前則是 nixpkgs/pkgs

選項

變數 預設 說明
truncation_length 3 到達現在資料夾的路徑中,要被裁減掉的資料夾數目。
truncate_to_repo true 是否要裁減到你現在所在的 git 儲存庫的根目錄。
style "bold cyan" 這個模組的風格。
disabled false 停用 directory 模組。
這個模組有些進階設定選項可以控制顯示資料夾。
變數 預設 說明
fish_style_pwd_dir_length 0 當使用 fish shell 的 pwd 路徑邏輯時使用的字元數量。
use_logical_path true 顯示 shell (PWD) 提供的邏輯路徑,而不是 OS 的路徑。

範例

# ~/.config/starship.toml

[directory]
truncation_length = 8

Dotnet

dotnet 模組顯示現在資料夾使用的 .NET Core SDK 的版本。 如果這個資料夾已經選定一個 SDK則顯示這個 SDK 的版本。 如果沒有的話,則顯示最新安裝的 SDK 版本。

這個模組只會在下列檔案出現在你的現在資料夾中時,顯示在你的提示字元:global.jsonproject.json*.sln*.csproj*.fsproj*.xproj。 你也會需要安裝 .NET Core 文字命令工具來正確使用這個模組。

這個模組內部是使用它自己的機制來偵測版本。 一般來說這個模組有 dotnet --version 的兩倍快,但是它可能會在你的 .NET 專案有不尋常的資料夾結構時顯示不正確的版本。 如果精確度比速度更重要的話,你可以藉由設定模組中的 heuristic = false 選項來停用這個功能。

選項

變數 預設 說明
symbol "•NET " 在顯示 dotnet 版本之前用的符號。
style "bold blue" 這個模組的風格。
heuristic true 使用更快速的版本偵測法來保持 starship 的速度。
disabled false 停用 dotnet 模組。

範例

# ~/.config/starship.toml

[dotnet]
symbol = "🥅 "
style = "green"
heuristic = false

環境變數

env_var模組顯示一個選擇的環境變數的現在數值。 這個模組只在下列條件其中之一達到時顯示:

  • variable 設定選項符合一個存在的環境變數。
  • 沒有設定 variable 選項,但是有設定 default 選項。

選項

變數 預設 說明
symbol 顯示在變數數值之前的符號。
variable 要顯示的環境變數。
default 在選擇的變數值沒有定義時,顯示的預設值。
prefix "" 在變數值正前方顯示的前綴。
suffix "" 在變數值正後方顯示的後綴。
style "dimmed black" 這個模組的風格。
disabled false 停用 env_var 模組。

範例

# ~/.config/starship.toml

[env_var]
variable = "SHELL"
default = "unknown shell"

Git 分支

git_branch 模組顯示現在的資料夾中使用中的儲存庫的分支。

選項

變數 預設 說明
symbol " " 在你現在資料夾之中的儲存庫的分支名稱前使用的符號。
truncation_length 2^63 - 1 裁減一個 git 分支到 X 字素 (grapheme)。
truncation_symbol "…" 用來指示分支名稱被縮減的符號。 你可以用 "" 來表示不要顯示。
style "bold purple" 這個模組的風格。
disabled false 停用 git_branch 模組。

範例

# ~/.config/starship.toml

[git_branch]
symbol = "🌱 "
truncation_length = 4
truncation_symbol = ""

Git State

git_state 模組會顯示在 git 儲存庫中的資料夾內,以及會在有作業正在進行時顯示,像是:REBASINGBISECTING 等等。 如果有進展的資訊 (像是 REBASING 3/10),也會一併顯示出來。

選項

變數 預設 說明
rebase "REBASING" rebase 進行中顯示的文字。
merge "MERGING" merge 進行中顯示的文字。
revert "REVERTING" revert 進行中顯示的文字。
cherry_pick "CHERRY-PICKING" cherry-pick 進行中顯示的文字。
bisect "BISECTING" bisect 進行中顯示的文字。
am "AM" apply-mailbox (git am) 進行中顯示的文字。
am_or_rebase "AM/REBASE" 當不容易分辨是 apply-mailboxrebase 正在進行中時顯示的文字。
progress_divider "/" 用來分開現在與總共進度量的符號。 (例如:" of " 會得到 "3 of 10" 的效果)
style "bold yellow" 這個模組的風格。
disabled false 停用 git_state 模組。

範例

# ~/.config/starship.toml

[git_state]
progress_divider = " of "
cherry_pick = "🍒 PICKING"

Git Status

git_status 模組顯示用來表示現在資料夾之中儲存庫狀態的符號。

選項

變數 預設 說明
conflicted "=" 這個分支有合併衝突。
ahead "⇡" 這個分支超前正在追蹤的分支。
behind "⇣" 這個分支落後正在追蹤的分支。
diverged "⇕" 這個分支偏離正在追蹤的分支。
untracked "?" 工作資料夾中有沒有追蹤的檔案。
stashed "$" 本地儲存庫有 stash。
modified "!" 工作資料夾中有修改過的檔案。
staged "+" 一個新檔案被加入了暫存區 (staging area)。
renamed "»" 一個被改名的檔案被加入了暫存區 (staging area)。
deleted "✘" 一個刪除檔案的動作被加入了暫存區 (staging area)。
show_sync_count false 顯示超前/落後追蹤的分支的數量。
prefix [ 在 git 狀態正前方顯示的前綴。
suffix ] 在 git 狀態正後方顯示的後綴。
style "bold red" 這個模組的風格。
disabled false 停用 git_status 模組。

範例

# ~/.config/starship.toml

[git_status]
conflicted = "🏳"
ahead = "🏎💨"
behind = "😰"
diverged = "😵"
untracked = "🤷‍"
stashed = "📦"
modified = "📝"
staged = ""
renamed = "👅"
deleted = "🗑"

Golang

golang 模組顯示現在安裝的 Golang 版本。 這個模組在下列其中一個條件達成時顯示:

  • 現在資料夾中含有一個 go.mod 檔案
  • 現在資料夾中含有一個 go.sum 檔案
  • 現在資料夾中含有一個 glide.yaml 檔案
  • 現在資料夾中含有一個 Gopkg.yml 檔案
  • 現在資料夾中含有一個 Gopkg.lock 檔案
  • 現在資料夾中含有一個 Godeps 資料夾
  • 現在資料夾中含有一個檔案具有 .go 副檔名

選項

變數 預設 說明
symbol "🐹 " 顯示在 Golang 版本之前的符號。
style "bold cyan" 這個模組的風格。
disabled false 停用 golang 模組。

範例

# ~/.config/starship.toml

[golang]
symbol = "🏎💨 "

主機名稱

hostname 模組顯示系統的主機名稱。

選項

變數 預設 說明
ssh_only true 只在連接到一個 SSH session 時顯示主機名稱。
prefix "" 在主機名稱正前方顯示的前綴。
suffix "" 在主機名稱正後方顯示的後綴。
trim_at "." 擷取出主機名稱的斷點,以第一個符合的為準。 "." 會讓它停在第一個點的符號。 "" 會停用任何的截斷功能。
style "bold dimmed green" 這個模組的風格。
disabled false 停用 hostname 模組。

範例

# ~/.config/starship.toml

[hostname]
ssh_only = false
prefix = "⟪"
suffix = "⟫"
trim_at = ".companyname.com"
disabled = false

工作

jobs 模組顯示現在正在執行中的工作。 這個模組只會在有背景工作正在執行時顯示。 這個模組會在工作數量超過一個,或者有設定 threshold 時且數量超過設定值時,顯示工作的數量。

選項

變數 預設 說明
symbol "✦" 在顯示工作數量之前用的符號。
threshold 1 在超過指定值時顯示工作數量。
style "bold blue" 這個模組的風格。
disabled false 停用 jobs 模組。

範例

# ~/.config/starship.toml

[jobs]
symbol = "+ "
threshold = 4

Kubernetes

顯示現在 Kubernetes 主體名稱以及從 kubeconfig 檔案來的名稱空間 (如果有設定的話)。 這個名稱空間必須設定在 kubeconfig 檔案內,你可以透過 kubectl config set-context starship-cluster --namespace astronaut 指令做到。 如果有設定 $KUBECONFIG 環境變數,這個模組就會使用設定值;如果沒有,它就會使用 ~/.kube/config

::: tip

這個模組預設是停用的。 想要啟用它的話,請在設定檔中將 disabled 設定為 false

:::

選項

變數 預設 說明
symbol "☸ " 顯示在叢集 (cluster) 資訊之前的符號。
style "bold blue" 這個模組的風格。
disabled true 停用 kubernetes 模組。

範例

# ~/.config/starship.toml

[kubernetes]
symbol = "⛵ "
style = "dim green"
disabled = false

換行

line_break 模組將提示字元分成兩行。

選項

變數 預設 說明
disabled false 停用 line_break 模組,讓提示字元變成一行。

範例

# ~/.config/starship.toml

[line_break]
disabled = true

Nix-shell

nix_shell 模組顯示 nix-shell 環境。 這個模組會在 nix-shell 環境中顯示。

選項

變數 預設 說明
use_name false 顯示 nix-shell 的名稱。
impure_msg impure 自定義「impure」訊息。
pure_msg pure 自定義「pure」訊息。
style "bold red" 這個模組的風格。
disabled false 停用 nix_shell 模組。

範例

# ~/.config/starship.toml

[nix_shell]
disabled = true
use_name = true
impure_msg = "impure shell"
pure_msg = "pure shell"

記憶體使用量

memory_usage 模組顯示現在系統記憶體與 swap 的使用量。

預設 swap 使用量會在系統總 swap 使用量不為 0 時顯示出來。

::: tip

這個模組預設是停用的。 想要啟用它的話,請在設定檔中將 disabled 設定為 false

:::

選項

變數 預設 說明
show_percentage false 以剩餘記憶體佔有的百分比的方式顯示記憶體使用狀況。
show_swap true 如果總 swap 使用量不為零的話,顯示 swap 使用量
threshold 75 將記憶體使用量隱藏,除非使用量超過指定值。
symbol "🐏 " 顯示在記憶體使用量之前的符號。
style "bold dimmed white" 這個模組的風格。
disabled true 停用 memory_usage 模組。

範例

# ~/.config/starship.toml

[memory_usage]
show_percentage = true
show_swap = true
threshold = -1
symbol = " "
style = "bold dimmed green"

Java

java 模組顯示現在安裝的 Java 版本。 這個模組在下列其中一個條件達成時顯示:

  • 現在資料夾中包含一個 pom.xmlbuild.gradlebuild.sbt 檔案
  • 現在資料夾中包含一個檔案具有 .java.class.jar 副檔名

選項

變數 預設 說明
symbol "☕ " 顯示在 Java 版本之前的符號。
style "dimmed red" 這個模組的風格。
disabled false 停用 java 模組。

範例

# ~/.config/starship.toml

[java]
symbol = "🌟 "

NodeJS

nodejs 模組顯示現在安裝的 NodeJS 版本。 這個模組在下列其中一個條件達成時顯示:

  • 現在資料夾中包含一個 package.json 檔案
  • 現在資料夾中包含一個 node_modules 資料夾
  • 現在資料夾中包含一個檔案具有 .js 副檔名

選項

變數 預設 說明
symbol "⬢ " 在顯示 NodeJS 版本之前用的符號。
style "bold green" 這個模組的風格。
disabled false 停用 nodejs 模組。

範例

# ~/.config/starship.toml

[nodejs]
symbol = "🤖 "

套件版本

The package 模組在現在資料夾是一個套件的儲藏庫時出現,並顯示他的現在版本。 這個模組目前支援 npmcargopoetry 套件。

  • npm npm 套件的版本是從現在資料夾中的 package.json 之中擷取出來的
  • cargo cargo 套件的版本是從現在資料夾中的 Cargo.toml 之中擷取出來的
  • poetry poetry 套件的版本是從現在資料夾中的 pyproject.toml 之中擷取出來的

⚠️ 顯示出來的版本是從你的現在資料夾之中擷取出來的,並非從套件管理員取得。

選項

變數 預設 說明
symbol "📦 " 顯示在套件的版本之前的符號。
style "bold red" 這個模組的風格。
disabled false 停用 package 模組。

範例

# ~/.config/starship.toml

[package]
symbol = "🎁 "

Python

python 模組顯示現在安裝的 Python 版本

如果 pyenv_version_name 的值為 true, 會顯示 pyenv 內的版本名稱

要不然就會顯示 python -version 的版本和有啟用的 Python 虛擬環境版本

這個模組在下列任一條件時會顯示:

  • 目前資料夾中有一個 .python-version 檔案
  • 目前資料夾中有一個 requirements.txt 檔案
  • 目前資料夾中有一個 pyproject.toml 檔案
  • 目前資料夾中有一個 .py 副檔名的檔案
  • 目前資料夾中有一個 Pipfile 檔案
  • 目前資料夾中有一個 tox.ini 檔案

選項

變數 預設 說明
symbol "🐍 " 顯示在 Python 版本之前的符號。
pyenv_version_name false 使用 pyenv 取得 Python 的版本。
pyenv_prefix "pyenv " 顯示在 pyenv 版本之前的前綴 (預設顯示是 pyenv MY_VERSION)。
style "bold yellow" 這個模組的風格。
disabled false 停用 python 模組。

範例

# ~/.config/starship.toml

[python]
symbol = "👾 "
pyenv_version_name = true
pyenv_prefix = "foo "

Ruby

ruby 模組顯示現在安裝的 Ruby 版本。 這個模組在下列其中一個條件達成時顯示:

  • 目前資料夾中有一個 Gemfile 檔案
  • 目前資料夾中有一個 .rb 檔案

選項

變數 預設 說明
symbol "💎 " 顯示在 Ruby 版本之前的符號。
style "bold red" 這個模組的風格。
disabled false 停用 ruby 模組。

範例

# ~/.config/starship.toml

[ruby]
symbol = "🔺 "

Rust

rust 模組顯示現在安裝的 Rust 版本。 這個模組在下列其中一個條件達成時顯示:

  • 目前資料夾中有一個 Cargo.toml 檔案
  • 現在資料夾中包含一個檔案具有 .rs 副檔名

選項

變數 預設 說明
symbol "🦀 " 顯示在 Rust 版本之前的符號。
style "bold red" 這個模組的風格。
disabled false 停用 rust 模組。

範例

# ~/.config/starship.toml

[rust]
symbol = "⚙️ "

時間

time 模組顯示目前的當地時間. format 設定值被 chrono crate 用來控制時間如何顯示。 請看 chrono 的 strftime 文件來了解有那些選項可以使用。

::: tip

這個模組預設是停用的。 想要啟用它的話,請在設定檔中將 disabled 設定為 false

:::

選項

變數 預設 說明
12hr false 啟用 12 小時格式。
format 請看下列 用來顯示時間的 chrono 格式字串
style bold yellow 這個模組的時間的風格。
disabled true 停用 time 模組。
utc_time_offset local 設定相對於 UTC 的時差。 範圍 -24 < x < 24。 允許使用浮點數來表示 30/45 分鐘時差的時區。

如果 use_12hrtrue 的話,format 會被預設為 "%r"。 不然的話,它會被預設為 "%T"。 手動設定 format 的設定值會覆寫 use_12hr 的設定。

範例

# ~/.config/starship.toml

[time]
disabled = false
format = "🕙[ %T ]"
utc_time_offset = -5

使用者名稱

username 模組顯示現在使用中的使用者名稱。 這個模組在下列其中一個條件達成時顯示:

  • 目前使用者為 root
  • 目前使用者並非登入時的使用者
  • 使用者透過 SSH session 進行連線
  • 變數 show_always 被設為 true

選項

變數 預設 說明
style_root "bold red" 使用者為 root 時使用的風格。
style_user "bold yellow" 非 root 使用者時使用的風格。
show_always false 總是顯示 username 模組。
disabled false 停用 username 模組。

範例

# ~/.config/starship.toml

[username]
disabled = true