7.5 KiB
FAQ
デモGIFで使用される構成は何ですか?
- ターミナルエミュレータ: iTerm2
- テーマ: Minimal
- カラースキーム: Snazzy
- フォント: FiraCode Nerd Font
- シェル: Fish Shell
- 設定: matchaiのDotfiles
- プロンプト: Starship
デモのGIFのようにコマンド補完はどうしたら使用できますか?
補完サポート、または自動補完は選択したシェルによって提供されます。 デモ中では、デフォルトのFish Shellによって補完されています。 Z Shell (zsh) を利用しているのであれば、zsh-autosuggestionsを照参してください。
トップレベルのformat
と<module>.disabled
は同じように動作しますか?
はい、両方ともプロンプトでモジュールを無効にするために使用できます。 モジュールを無効にするだけの場合は、これらの理由から<module> .disabled
を無効にする方法をお勧めします。
- モジュールを無効化することは、トップレベルの
format
を削除するよりも明示的です。 - Starshipが更新されると、新しく作成されたモジュールがプロンプトに追加されます
Starshipはcross-shellとのことです。 私の好みのshellはサポートしていないようですが。
Starshipの構築方法は、事実上すべてのシェルのサポートを追加できるはずです。 Starshipのバイナリはステートレスであり、シェルに依存しないため、シェルがプロンプトのカスタマイズとシェルの拡張をサポートしている限り、Starshipを使用できます。
Starshipをbashで動作させる例を次に示します。
# Get the status code from the last command executed
STATUS=$?
# 実行中のジョブの数を取得します。
NUM_JOBS=$(jobs -p | wc -l)
# プロンプトを `starship prompt`に設定
PS1="$(starship prompt --status=$STATUS --jobs=$NUM_JOBS)"
Starshipに搭載されているBashの実装は、Command Duration モジュールのような高度な機能を可能にするためと、プリインストールされたBashの設定との互換性を確保するために、若干複雑になっています。
Starshipのプロンプト
で受け入れられるすべてのフラグのリストは、次のコマンドを取得できます。
starship prompt --help
プロンプトは提供されているコンテキストを使用しますが、フラグは「必須」ではありません。
古いバージョンの glibc を使用する Linux ディストリビューションで Starship を実行するにはどうすればよいですか?
CentOS6や7などで事前にビルドされたバイナリを使用していて、"version 'GLIBC_2.18' not found (required by starship)" のようなエラーが出た場合、glibc
の替わりに musl
でコンパイルされたバイナリを使用できます。
sh -c "$(curl -fsSL https://starship.rs/install.sh)" -- --platform unknown-linux-musl
Why do I see Executing command "..." timed out.
warnings?
Starship executes different commands to get information to display in the prompt, for example the version of a program or the current git status. To make sure starship doesn't hang while trying to execute these commands we set a time limit, if a command takes longer than this limit starship will stop the execution of the command and output the above warning, this is expected behaviour. This time limit is configurable using the command_timeout
key so if you want you can increase the time limit. You can also follow the debugging steps below to see which command is being slow and see if you can optimise it. Finally you can set the STARSHIP_LOG
env var to error
to hide these warnings.
I see symbols I don't understand or expect, what do they mean?
If you see symbols that you don't recognise you can use starship explain
to explain the currently showing modules.
Starship is doing something unexpected, how can I debug it?
You can enable the debug logs by using the STARSHIP_LOG
env var. These logs can be very verbose so it is often useful to use the module
command if you are trying to debug a particular module, for example, if you are trying to debug the rust
module you could run the following command to get the trace logs and output from the module.
env STARHIP_LOG=trace starship module rust
If starship is being slow you can try using the timings
command to see if there is a particular module or command that to blame.
env STARHIP_LOG=trace starship timings
This will output the trace log and a breakdown of all modules that either took more than 1ms to execute or produced some output.
Finally if you find a bug you can use the bug-report
command to create a Github issue.
starship bug-report
Why don't I see a glyph symbol in my prompt?
The most common cause of this is system misconfiguration. Some Linux distros in particular do not come with font support out-of-the-box. You need to ensure that:
- ロケールが、
de_DE.UTF-8
やja_JP.UTF-8
などのUTF-8に設定されている。LC_ALL
がUTF-8でない場合、変更する必要があります。 - 絵文字フォントがインストールされている。 ほとんどのシステムにはデフォルトで絵文字フォントが付属していますが、 一部 (特にArch Linux) はそうではありません。 通常、システムの パッケージマネージャーからインストールすることができます。--noto emojiは一般的な選択肢です。
- Nerd Fontを使用している。
To test your system, run the following commands in a terminal:
echo -e "\xf0\x9f\x90\x8d"
echo -e "\xee\x82\xa0"
The first line should produce a snake emoji, while the second should produce a powerline branch symbol (e0a0).
If either symbol fails to display correctly, your system is still misconfigured. Unfortunately, getting font configuration correct is sometimes difficult. Users on the Discord may be able to help. If both symbols display correctly, but you still don't see them in starship, file a bug report!
How do I uninstall Starship?
Starship is just as easy to uninstall as it is to install in the first place.
- Starshipを初期化するために使用した、シェルの設定行を削除します (例:
~/.bashrc
)。 - Starshipのバイナリを削除します。
If Starship was installed using a package manager, please refer to their docs for uninstallation instructions.
If Starship was installed using the install script, the following command will delete the binary:
# Locate and delete the starship binary
sh -c 'rm "$(which starship)"'