diff --git a/docs/config/README.md b/docs/config/README.md index 8afa0184..f6dfc727 100644 --- a/docs/config/README.md +++ b/docs/config/README.md @@ -1,5 +1,12 @@ # Configuration +::: tip + +🔥 Configuration is currently being worked on. +Many new configuration options will be available in coming releases. + +::: + To get started configuring starship, create the following file: `~/.config/starship.toml`. ```sh @@ -7,9 +14,10 @@ mkdir -p ~/.config && touch ~/.config/starship.toml ``` All configuration for starship is done in this [TOML](https://github.com/toml-lang/toml) file: + ```toml # Don't print a new line at the start of the prompt -add_newline = false +format = "$all" # Replace the "❯" symbol in the prompt with "➜" [character] # The name of the module we are configuring is "character" @@ -137,7 +145,6 @@ This is the list of prompt-wide configuration options. | Option | Default | Description | | -------------- | ------------------------------ | ----------------------------------------------------- | -| `add_newline` | `true` | Add a new line before the start of the prompt. | | `format` | [link](#default-prompt-format) | Configure the format of the prompt. | | `scan_timeout` | `30` | Timeout for starship to scan files (in milliseconds). | @@ -147,7 +154,7 @@ This is the list of prompt-wide configuration options. # ~/.config/starship.toml # Disable the newline at the start of the prompt -add_newline = false +format = "$all" # Use custom format format = """ @@ -164,7 +171,7 @@ scan_timeout = 10 The default `format` is used to define the format of the prompt, if empty or no `format` is provided. The default is as shown: ```toml -format = "$all" +format = "\n$all" # Which is equivalent to format = """ diff --git a/src/configs/starship_root.rs b/src/configs/starship_root.rs index b3f7a5b2..ad507c4d 100644 --- a/src/configs/starship_root.rs +++ b/src/configs/starship_root.rs @@ -6,7 +6,6 @@ use starship_module_config_derive::ModuleConfig; pub struct StarshipRootConfig<'a> { pub format: &'a str, pub scan_timeout: u64, - pub add_newline: bool, } // List of default prompt order @@ -71,9 +70,8 @@ pub const PROMPT_ORDER: &[&str] = &[ impl<'a> RootModuleConfig<'a> for StarshipRootConfig<'a> { fn new() -> Self { StarshipRootConfig { - format: "$all", + format: "\n$all", scan_timeout: 30, - add_newline: true, } } } diff --git a/src/modules/line_break.rs b/src/modules/line_break.rs index e8c00452..e485458d 100644 --- a/src/modules/line_break.rs +++ b/src/modules/line_break.rs @@ -5,36 +5,9 @@ use crate::segment::Segment; pub fn module<'a>(context: &'a Context) -> Option> { const LINE_ENDING: &str = "\n"; - let show_newline = context.config.get_root_config().add_newline; - if !show_newline { - return None; - } - let mut module = context.new_module("line_break"); module.set_segments(vec![Segment::new(None, LINE_ENDING)]); Some(module) } - -#[cfg(test)] -mod tests { - use crate::test::ModuleRenderer; - - #[test] - fn add_newline_by_default() { - let expected = Some(String::from("\n")); - let actual = ModuleRenderer::new("line_break").collect(); - assert_eq!(expected, actual); - } - - #[test] - fn dont_add_newline_when_disabled() { - let expected = None; - let config = toml::toml! { - add_newline = false - }; - let actual = ModuleRenderer::new("line_break").config(config).collect(); - assert_eq!(expected, actual); - } -}