mirror of
https://github.com/starship/starship.git
synced 2026-06-23 02:05:51 +07:00
Add stringify_segment rustdoc
This commit is contained in:
@@ -4,13 +4,13 @@ extern crate test;
|
|||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
|
use clap::{App, Arg};
|
||||||
use starship::{modules, print};
|
use starship::{modules, print};
|
||||||
use test::Bencher;
|
use test::Bencher;
|
||||||
use clap::{App, Arg};
|
|
||||||
|
|
||||||
#[bench]
|
#[bench]
|
||||||
fn full_prompt_bench(b: &mut Bencher) {
|
fn full_prompt_bench(b: &mut Bencher) {
|
||||||
b.iter(||{
|
b.iter(|| {
|
||||||
let args = App::new("starship")
|
let args = App::new("starship")
|
||||||
.arg(Arg::with_name("status_code"))
|
.arg(Arg::with_name("status_code"))
|
||||||
.get_matches_from(vec!["starship", "0"]);
|
.get_matches_from(vec!["starship", "0"]);
|
||||||
@@ -25,7 +25,7 @@ mod tests {
|
|||||||
let args = App::new("starship")
|
let args = App::new("starship")
|
||||||
.arg(Arg::with_name("status_code"))
|
.arg(Arg::with_name("status_code"))
|
||||||
.get_matches_from(vec!["starship", "0"]);
|
.get_matches_from(vec!["starship", "0"]);
|
||||||
|
|
||||||
let segment = modules::handle("char", &args);
|
let segment = modules::handle("char", &args);
|
||||||
print::stringify_segment(segment)
|
print::stringify_segment(segment)
|
||||||
});
|
});
|
||||||
@@ -37,7 +37,7 @@ mod tests {
|
|||||||
let args = App::new("starship")
|
let args = App::new("starship")
|
||||||
.arg(Arg::with_name("status_code"))
|
.arg(Arg::with_name("status_code"))
|
||||||
.get_matches_from(vec!["starship", "0"]);
|
.get_matches_from(vec!["starship", "0"]);
|
||||||
|
|
||||||
let segment = modules::handle("dir", &args);
|
let segment = modules::handle("dir", &args);
|
||||||
print::stringify_segment(segment)
|
print::stringify_segment(segment)
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ use ansi_term::{Color, Style};
|
|||||||
use clap::ArgMatches;
|
use clap::ArgMatches;
|
||||||
|
|
||||||
/// Creates a segment for the prompt character
|
/// Creates a segment for the prompt character
|
||||||
///
|
///
|
||||||
/// The char segment prints an arrow character in a color dependant on the exit-
|
/// The char segment prints an arrow character in a color dependant on the exit-
|
||||||
/// code of the last executed command:
|
/// code of the last executed command:
|
||||||
/// - If the exit-code was "0", the arrow will be formatted with `COLOR_SUCCESS`
|
/// - If the exit-code was "0", the arrow will be formatted with `COLOR_SUCCESS`
|
||||||
@@ -1,8 +1,8 @@
|
|||||||
use super::Segment;
|
use super::Segment;
|
||||||
use dirs;
|
|
||||||
use std::env;
|
|
||||||
use ansi_term::{Color, Style};
|
use ansi_term::{Color, Style};
|
||||||
use clap::ArgMatches;
|
use clap::ArgMatches;
|
||||||
|
use dirs;
|
||||||
|
use std::env;
|
||||||
|
|
||||||
/// Creates a segment with the current directory
|
/// Creates a segment with the current directory
|
||||||
pub fn segment(_: &ArgMatches) -> Segment {
|
pub fn segment(_: &ArgMatches) -> Segment {
|
||||||
|
|||||||
+5
-5
@@ -1,9 +1,9 @@
|
|||||||
mod char;
|
mod character;
|
||||||
mod directory;
|
mod directory;
|
||||||
mod line_break;
|
mod line_break;
|
||||||
|
|
||||||
use clap::ArgMatches;
|
|
||||||
use ansi_term::Style;
|
use ansi_term::Style;
|
||||||
|
use clap::ArgMatches;
|
||||||
|
|
||||||
pub struct Segment {
|
pub struct Segment {
|
||||||
pub style: Style,
|
pub style: Style,
|
||||||
@@ -18,21 +18,21 @@ impl Default for Segment {
|
|||||||
style: Style::default(),
|
style: Style::default(),
|
||||||
value: String::from(" "),
|
value: String::from(" "),
|
||||||
prefix: None,
|
prefix: None,
|
||||||
suffix: None
|
suffix: None,
|
||||||
}));
|
}));
|
||||||
|
|
||||||
Segment {
|
Segment {
|
||||||
style: Style::default(),
|
style: Style::default(),
|
||||||
value: String::from(""),
|
value: String::from(""),
|
||||||
prefix: None,
|
prefix: None,
|
||||||
suffix: default_suffix
|
suffix: default_suffix,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn handle(module: &str, args: &ArgMatches) -> Segment {
|
pub fn handle(module: &str, args: &ArgMatches) -> Segment {
|
||||||
match module {
|
match module {
|
||||||
"char" | "character" => char::segment(&args),
|
"char" | "character" => character::segment(&args),
|
||||||
"dir" | "directory" => directory::segment(&args),
|
"dir" | "directory" => directory::segment(&args),
|
||||||
"line_break" => line_break::segment(&args),
|
"line_break" => line_break::segment(&args),
|
||||||
|
|
||||||
|
|||||||
+21
-3
@@ -5,26 +5,44 @@ use clap::ArgMatches;
|
|||||||
pub fn prompt(args: ArgMatches) {
|
pub fn prompt(args: ArgMatches) {
|
||||||
let default_prompt = vec!["directory", "line_break", "character"];
|
let default_prompt = vec!["directory", "line_break", "character"];
|
||||||
|
|
||||||
default_prompt.into_iter()
|
default_prompt
|
||||||
|
.into_iter()
|
||||||
.map(|module| modules::handle(module, &args))
|
.map(|module| modules::handle(module, &args))
|
||||||
.map(|segment| stringify_segment(segment))
|
.map(|segment| stringify_segment(segment))
|
||||||
.for_each(|segment_string| print!("{}", segment_string));
|
.for_each(|segment_string| print!("{}", segment_string));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Create a string with the formatted contents of a segment
|
||||||
|
///
|
||||||
|
/// Will recursively also format the prefix and suffix of the segment being
|
||||||
|
/// stringified.
|
||||||
|
///
|
||||||
|
/// # Example
|
||||||
|
/// ```
|
||||||
|
/// use starship::modules::Segment;
|
||||||
|
///
|
||||||
|
/// let segment = Segment {
|
||||||
|
/// value: String::from("->"),
|
||||||
|
/// ..Default::default()
|
||||||
|
/// };
|
||||||
|
///
|
||||||
|
/// let result = starship::print::stringify_segment(segment);
|
||||||
|
/// assert_eq!(result, "-> ");
|
||||||
|
/// ```
|
||||||
pub fn stringify_segment(segment: Segment) -> String {
|
pub fn stringify_segment(segment: Segment) -> String {
|
||||||
let Segment {
|
let Segment {
|
||||||
prefix,
|
prefix,
|
||||||
value,
|
value,
|
||||||
style,
|
style,
|
||||||
suffix,
|
suffix,
|
||||||
} = segment;
|
} = segment;
|
||||||
|
|
||||||
let mut segment_string = String::new();
|
let mut segment_string = String::new();
|
||||||
|
|
||||||
if let Some(prefix) = prefix {
|
if let Some(prefix) = prefix {
|
||||||
segment_string += &stringify_segment(*prefix);
|
segment_string += &stringify_segment(*prefix);
|
||||||
}
|
}
|
||||||
|
|
||||||
segment_string += &style.paint(value).to_string();
|
segment_string += &style.paint(value).to_string();
|
||||||
|
|
||||||
if let Some(suffix) = suffix {
|
if let Some(suffix) = suffix {
|
||||||
|
|||||||
Reference in New Issue
Block a user