mirror of
https://github.com/starship/starship.git
synced 2025-01-25 23:59:54 +01:00
feat: Add configuration to change the character for non-zero sta… (#133)
Prompt can now switch characters in addition to switching character color. Add configuration options in so that users can do either, both, or neither.
This commit is contained in:
parent
994a865d4d
commit
39598ec691
@ -89,15 +89,17 @@ discharging_symbol = "💀"
|
|||||||
The `character` module shows a character (usually an arrow) beside where the text
|
The `character` module shows a character (usually an arrow) beside where the text
|
||||||
is entered in your terminal.
|
is entered in your terminal.
|
||||||
|
|
||||||
The character will be green if the status of your
|
The character will tell you whether the last command was successful or not. It
|
||||||
last command had a successful status code (zero), and will be red if the last
|
can do this in two ways: by changing color (red/green) or by changing its shape
|
||||||
command had an unsuccessful status code (non-zero).
|
(➜/✖). The latter will only be done if `use_symbol_for_status` is set to `true`.
|
||||||
|
|
||||||
### Options
|
### Options
|
||||||
|
|
||||||
| Variable | Default | Description |
|
| Variable | Default | Description |
|
||||||
| ---------- | ------- | ---------------------------------------------------- |
|
| ---------- | ------- | ---------------------------------------------------- |
|
||||||
| `symbol` | `"➜"` | The symbol used before the text input in the prompt. |
|
| `symbol` | `"➜"` | The symbol used before the text input in the prompt. |
|
||||||
|
| `error_symbol` | `"✖"` | The symbol used before text input if the previous command failed. |
|
||||||
|
| `use_symbol_for_status` | `false` | Indicate error status by changing the symbol. |
|
||||||
| `disabled` | `false` | Disables the `character` module. |
|
| `disabled` | `false` | Disables the `character` module. |
|
||||||
|
|
||||||
### Example
|
### Example
|
||||||
@ -107,6 +109,8 @@ command had an unsuccessful status code (non-zero).
|
|||||||
|
|
||||||
[character]
|
[character]
|
||||||
symbol = "❯"
|
symbol = "❯"
|
||||||
|
error_symbol = "✗"
|
||||||
|
use_symbol_for_status = true
|
||||||
```
|
```
|
||||||
|
|
||||||
## Command Duration
|
## Command Duration
|
||||||
|
@ -44,7 +44,7 @@ impl<'a> Module<'a> {
|
|||||||
let mut segment = Segment::new(name);
|
let mut segment = Segment::new(name);
|
||||||
segment.set_style(self.style);
|
segment.set_style(self.style);
|
||||||
// Use the provided value unless overwritten by config
|
// Use the provided value unless overwritten by config
|
||||||
segment.set_value(self.config_value(name).unwrap_or(value));
|
segment.set_value(self.config_value_str(name).unwrap_or(value));
|
||||||
self.segments.push(segment);
|
self.segments.push(segment);
|
||||||
|
|
||||||
self.segments.last_mut().unwrap()
|
self.segments.last_mut().unwrap()
|
||||||
@ -96,7 +96,7 @@ impl<'a> Module<'a> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Get a module's config value as a string
|
/// Get a module's config value as a string
|
||||||
fn config_value(&self, key: &str) -> Option<&str> {
|
pub fn config_value_str(&self, key: &str) -> Option<&str> {
|
||||||
self.config.and_then(|config| config.get_as_str(key))
|
self.config.and_then(|config| config.get_as_str(key))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,17 +10,29 @@ use ansi_term::Color;
|
|||||||
/// - If the exit-code was anything else, the arrow will be formatted with
|
/// - If the exit-code was anything else, the arrow will be formatted with
|
||||||
/// `COLOR_FAILURE` (red by default)
|
/// `COLOR_FAILURE` (red by default)
|
||||||
pub fn module<'a>(context: &'a Context) -> Option<Module<'a>> {
|
pub fn module<'a>(context: &'a Context) -> Option<Module<'a>> {
|
||||||
const PROMPT_CHAR: &str = "➜";
|
const SUCCESS_CHAR: &str = "➜";
|
||||||
|
const FAILURE_CHAR: &str = "✖";
|
||||||
let color_success = Color::Green.bold();
|
let color_success = Color::Green.bold();
|
||||||
let color_failure = Color::Red.bold();
|
let color_failure = Color::Red.bold();
|
||||||
|
|
||||||
let mut module = context.new_module("character")?;
|
let mut module = context.new_module("character")?;
|
||||||
module.get_prefix().set_value("");
|
module.get_prefix().set_value("");
|
||||||
|
|
||||||
let symbol = module.new_segment("symbol", PROMPT_CHAR);
|
|
||||||
|
|
||||||
let arguments = &context.arguments;
|
let arguments = &context.arguments;
|
||||||
if arguments.value_of("status_code").unwrap_or("0") == "0" {
|
let use_symbol = module
|
||||||
|
.config_value_bool("use_symbol_for_status")
|
||||||
|
.unwrap_or(false);
|
||||||
|
let exit_success = arguments.value_of("status_code").unwrap_or("0") == "0";
|
||||||
|
|
||||||
|
/* If an error symbol is set in the config, use symbols to indicate
|
||||||
|
success/failure, in addition to color */
|
||||||
|
let symbol = if use_symbol && !exit_success {
|
||||||
|
module.new_segment("error_symbol", FAILURE_CHAR)
|
||||||
|
} else {
|
||||||
|
module.new_segment("symbol", SUCCESS_CHAR)
|
||||||
|
};
|
||||||
|
|
||||||
|
if exit_success {
|
||||||
symbol.set_style(color_success.bold());
|
symbol.set_style(color_success.bold());
|
||||||
} else {
|
} else {
|
||||||
symbol.set_style(color_failure.bold());
|
symbol.set_style(color_failure.bold());
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
use ansi_term::Color;
|
use ansi_term::Color;
|
||||||
use std::io;
|
use std::io;
|
||||||
|
|
||||||
use crate::common;
|
use crate::common::{self, TestCommand};
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn char_module_success_status() -> io::Result<()> {
|
fn char_module_success_status() -> io::Result<()> {
|
||||||
@ -26,26 +26,49 @@ fn char_module_success_status() -> io::Result<()> {
|
|||||||
fn char_module_failure_status() -> io::Result<()> {
|
fn char_module_failure_status() -> io::Result<()> {
|
||||||
let expected = format!("{} ", Color::Red.bold().paint("➜"));
|
let expected = format!("{} ", Color::Red.bold().paint("➜"));
|
||||||
|
|
||||||
// Error status code 1
|
let exit_values = ["1", "54321", "-5000"];
|
||||||
let output = common::render_module("character")
|
|
||||||
.arg("--status=1")
|
|
||||||
.output()?;
|
|
||||||
let actual = String::from_utf8(output.stdout).unwrap();
|
|
||||||
assert_eq!(expected, actual);
|
|
||||||
|
|
||||||
// Random non-zero status code
|
for status in exit_values.iter() {
|
||||||
let output = common::render_module("character")
|
let arg = format!("--status={}", status);
|
||||||
.arg("--status=54321")
|
let output = common::render_module("character").arg(arg).output()?;
|
||||||
.output()?;
|
|
||||||
let actual = String::from_utf8(output.stdout).unwrap();
|
|
||||||
assert_eq!(expected, actual);
|
|
||||||
|
|
||||||
// Negative status code!?
|
|
||||||
let output = common::render_module("character")
|
|
||||||
.arg("--status=-5000")
|
|
||||||
.output()?;
|
|
||||||
let actual = String::from_utf8(output.stdout).unwrap();
|
let actual = String::from_utf8(output.stdout).unwrap();
|
||||||
assert_eq!(expected, actual);
|
assert_eq!(expected, actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn char_module_symbolyes_status() -> io::Result<()> {
|
||||||
|
let expected_fail = format!("{} ", Color::Red.bold().paint("✖"));
|
||||||
|
let expected_success = format!("{} ", Color::Green.bold().paint("➜"));
|
||||||
|
|
||||||
|
let exit_values = ["1", "54321", "-5000"];
|
||||||
|
|
||||||
|
// Test failure values
|
||||||
|
for status in exit_values.iter() {
|
||||||
|
let arg = format!("--status={}", status);
|
||||||
|
let output = common::render_module("character")
|
||||||
|
.use_config(toml::toml! {
|
||||||
|
[character]
|
||||||
|
use_symbol_for_status = true
|
||||||
|
})
|
||||||
|
.arg(arg)
|
||||||
|
.output()?;
|
||||||
|
let actual = String::from_utf8(output.stdout).unwrap();
|
||||||
|
assert_eq!(expected_fail, actual);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test success
|
||||||
|
let output = common::render_module("character")
|
||||||
|
.use_config(toml::toml! {
|
||||||
|
[character]
|
||||||
|
use_symbol_for_status = true
|
||||||
|
})
|
||||||
|
.arg("--status=0")
|
||||||
|
.output()?;
|
||||||
|
let actual = String::from_utf8(output.stdout).unwrap();
|
||||||
|
assert_eq!(expected_success, actual);
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user