mirror of
https://github.com/Llewellynvdm/starship.git
synced 2024-11-28 07:46:28 +00:00
Set status with arg rather than env
This commit is contained in:
parent
e2ba7a1354
commit
e519c3f4a6
11
src/main.rs
11
src/main.rs
@ -6,7 +6,7 @@ mod modules;
|
|||||||
mod print;
|
mod print;
|
||||||
|
|
||||||
use ansi_term::Style;
|
use ansi_term::Style;
|
||||||
use clap::App;
|
use clap::{App, Arg};
|
||||||
|
|
||||||
pub struct Segment {
|
pub struct Segment {
|
||||||
style: Style,
|
style: Style,
|
||||||
@ -16,14 +16,19 @@ pub struct Segment {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
App::new("Starship")
|
let args = App::new("Starship")
|
||||||
.about("The cross-platform prompt for astronauts. ✨🚀")
|
.about("The cross-platform prompt for astronauts. ✨🚀")
|
||||||
// pull the version number from Cargo.toml
|
// pull the version number from Cargo.toml
|
||||||
.version(crate_version!())
|
.version(crate_version!())
|
||||||
// pull the authors from Cargo.toml
|
// pull the authors from Cargo.toml
|
||||||
.author(crate_authors!())
|
.author(crate_authors!())
|
||||||
.after_help("https://github.com/matchai/starship")
|
.after_help("https://github.com/matchai/starship")
|
||||||
|
.arg(
|
||||||
|
Arg::with_name("status_code")
|
||||||
|
.help("The status code of the previously run command")
|
||||||
|
.required(true),
|
||||||
|
)
|
||||||
.get_matches();
|
.get_matches();
|
||||||
|
|
||||||
print::prompt();
|
print::prompt(args);
|
||||||
}
|
}
|
||||||
|
@ -1,34 +1,49 @@
|
|||||||
use crate::Segment;
|
use crate::Segment;
|
||||||
use ansi_term::{Color, Style};
|
use ansi_term::{Color, Style};
|
||||||
use std::env;
|
use clap::ArgMatches;
|
||||||
|
|
||||||
pub fn segment() -> Segment {
|
pub fn segment(args: &ArgMatches) -> Segment {
|
||||||
const PROMPT_CHAR: &str = "➜ ";
|
const PROMPT_CHAR: &str = "➜ ";
|
||||||
const COLOR_SUCCESS: Color = Color::Green;
|
const COLOR_SUCCESS: Color = Color::Green;
|
||||||
const COLOR_FAILURE: Color = Color::Red;
|
const COLOR_FAILURE: Color = Color::Red;
|
||||||
|
|
||||||
let default_prefix = Segment {
|
|
||||||
value: String::from("testPrefix"),
|
|
||||||
style: Style::default(),
|
|
||||||
prefix: None,
|
|
||||||
suffix: None,
|
|
||||||
};
|
|
||||||
|
|
||||||
let color;
|
let color;
|
||||||
if let Ok(status) = env::var("status") {
|
if args.value_of("status_code").unwrap() == "0" {
|
||||||
if status == "0" {
|
|
||||||
color = COLOR_SUCCESS;
|
color = COLOR_SUCCESS;
|
||||||
} else {
|
} else {
|
||||||
color = COLOR_FAILURE;
|
color = COLOR_FAILURE;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
panic!("No status environment variable provided");
|
|
||||||
}
|
|
||||||
|
|
||||||
Segment {
|
Segment {
|
||||||
prefix: Some(Box::new(default_prefix)),
|
prefix: None,
|
||||||
value: String::from(PROMPT_CHAR),
|
value: String::from(PROMPT_CHAR),
|
||||||
style: Style::new().fg(color),
|
style: Style::from(color),
|
||||||
suffix: None,
|
suffix: None,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
use clap::{App, Arg};
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn char_section_success_status() {
|
||||||
|
let args = App::new("starship")
|
||||||
|
.arg(Arg::with_name("status_code"))
|
||||||
|
.get_matches_from(vec!["starship", "0"]);
|
||||||
|
|
||||||
|
let segment = segment(&args);
|
||||||
|
assert_eq!(segment.style, Style::from(Color::Green));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn char_section_failure_status() {
|
||||||
|
let args = App::new("starship")
|
||||||
|
.arg(Arg::with_name("status_code"))
|
||||||
|
.get_matches_from(vec!["starship", "1"]);
|
||||||
|
|
||||||
|
let segment = segment(&args);
|
||||||
|
assert_eq!(segment.style, Style::from(Color::Red));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
mod char;
|
mod char;
|
||||||
|
|
||||||
use crate::Segment;
|
use crate::Segment;
|
||||||
|
use clap::ArgMatches;
|
||||||
|
|
||||||
pub fn handle(module: &str) -> Segment {
|
pub fn handle(module: &str, args: &ArgMatches) -> Segment {
|
||||||
match module {
|
match module {
|
||||||
"char" => char::segment(),
|
"char" => char::segment(&args),
|
||||||
|
|
||||||
_ => panic!("Unknown module: {}", module),
|
_ => panic!("Unknown module: {}", module),
|
||||||
}
|
}
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
use crate::modules;
|
use crate::modules;
|
||||||
use crate::Segment;
|
use crate::Segment;
|
||||||
|
use clap::ArgMatches;
|
||||||
|
|
||||||
pub fn prompt() {
|
pub fn prompt(args: ArgMatches) {
|
||||||
let default_prompt = vec!["char"];
|
let default_prompt = vec!["char"];
|
||||||
|
|
||||||
for module in default_prompt {
|
for module in default_prompt {
|
||||||
let segment = modules::handle(module);
|
let segment = modules::handle(module, &args);
|
||||||
print_segment(segment);
|
print_segment(segment);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user