Parallelize prompt modules (#46)

This commit is contained in:
Matan Kushner 2019-05-09 23:51:50 -04:00 committed by GitHub
parent c6ee5c6ac1
commit 8b5055d510
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 39 additions and 12 deletions

1
Cargo.lock generated
View File

@ -689,6 +689,7 @@ dependencies = [
"criterion 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", "criterion 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)",
"dirs 1.0.5 (registry+https://github.com/rust-lang/crates.io-index)", "dirs 1.0.5 (registry+https://github.com/rust-lang/crates.io-index)",
"git2 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)", "git2 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)",
"rayon 1.0.3 (registry+https://github.com/rust-lang/crates.io-index)",
"serde_json 1.0.39 (registry+https://github.com/rust-lang/crates.io-index)", "serde_json 1.0.39 (registry+https://github.com/rust-lang/crates.io-index)",
"tempfile 3.0.7 (registry+https://github.com/rust-lang/crates.io-index)", "tempfile 3.0.7 (registry+https://github.com/rust-lang/crates.io-index)",
"toml 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", "toml 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)",

View File

@ -11,6 +11,7 @@ dirs = "1.0.5"
git2 = "0.8.0" git2 = "0.8.0"
toml = "0.5.0" toml = "0.5.0"
serde_json = "1.0.39" serde_json = "1.0.39"
rayon = "1.0.3"
[dev-dependencies] [dev-dependencies]
tempfile = "3.0.7" tempfile = "3.0.7"

View File

@ -6,6 +6,8 @@ use criterion::Criterion;
use clap::{App, Arg}; use clap::{App, Arg};
use starship::context::Context; use starship::context::Context;
use starship::modules; use starship::modules;
use std::fs;
use tempfile::TempDir;
fn char_segment(c: &mut Criterion) { fn char_segment(c: &mut Criterion) {
let args = App::new("starship") let args = App::new("starship")
@ -40,5 +42,28 @@ fn line_break_segment(c: &mut Criterion) {
}); });
} }
criterion_group!(benches, dir_segment, char_segment, line_break_segment); fn git_branch_segment(c: &mut Criterion) {
let tmp_dir = TempDir::new().unwrap();
let repo_dir = tmp_dir.path().join("rocket-controls");
fs::create_dir(&repo_dir).unwrap();
git2::Repository::init(&repo_dir).unwrap();
let args = App::new("starship")
.arg(Arg::with_name("status_code"))
.get_matches_from(vec!["starship", "0"]);
let context = Context::new_with_dir(args, "~");
c.bench_function("git_branch segment", move |b| {
b.iter(|| modules::handle("git_branch", &context))
});
}
criterion_group!(
benches,
char_segment,
dir_segment,
line_break_segment,
git_branch_segment
);
criterion_main!(benches); criterion_main!(benches);

View File

@ -8,7 +8,7 @@ pub struct Context<'a> {
pub current_dir: PathBuf, pub current_dir: PathBuf,
pub dir_files: Vec<PathBuf>, pub dir_files: Vec<PathBuf>,
pub arguments: ArgMatches<'a>, pub arguments: ArgMatches<'a>,
pub repository: Option<Repository>, pub repo_root: Option<PathBuf>,
} }
impl<'a> Context<'a> { impl<'a> Context<'a> {
@ -36,13 +36,15 @@ impl<'a> Context<'a> {
.map(|entry| entry.path()) .map(|entry| entry.path())
.collect::<Vec<PathBuf>>(); .collect::<Vec<PathBuf>>();
let repository: Option<Repository> = Repository::discover(&current_dir).ok(); let repo_root: Option<PathBuf> = Repository::discover(&current_dir)
.ok()
.and_then(|repo| repo.workdir().map(|repo| repo.to_path_buf()));
Context { Context {
arguments, arguments,
current_dir, current_dir,
dir_files, dir_files,
repository, repo_root,
} }
} }

View File

@ -23,9 +23,8 @@ pub fn segment(context: &Context) -> Option<Module> {
let current_dir = &context.current_dir; let current_dir = &context.current_dir;
let dir_string; let dir_string;
if let Some(repo) = &context.repository { if let Some(repo_root) = &context.repo_root {
// Contract the path to the git repo root // Contract the path to the git repo root
let repo_root = repo.workdir().unwrap();
let repo_folder_name = repo_root.file_name().unwrap().to_str().unwrap(); let repo_folder_name = repo_root.file_name().unwrap().to_str().unwrap();
dir_string = contract_path(&current_dir, repo_root, repo_folder_name); dir_string = contract_path(&current_dir, repo_root, repo_folder_name);

View File

@ -7,12 +7,10 @@ use super::{Context, Module};
/// ///
/// Will display the branch name if the current directory is a git repo /// Will display the branch name if the current directory is a git repo
pub fn segment(context: &Context) -> Option<Module> { pub fn segment(context: &Context) -> Option<Module> {
if context.repository.is_none() { let repo_root = context.repo_root.as_ref()?;
return None; let repository = Repository::open(repo_root).ok()?;
}
let repository = context.repository.as_ref().unwrap(); match get_current_branch(&repository) {
match get_current_branch(repository) {
Ok(branch_name) => { Ok(branch_name) => {
const GIT_BRANCH_CHAR: &str = ""; const GIT_BRANCH_CHAR: &str = "";
let segment_color = Color::Purple.bold(); let segment_color = Color::Purple.bold();

View File

@ -1,4 +1,5 @@
use clap::ArgMatches; use clap::ArgMatches;
use rayon::prelude::*;
use std::io::{self, Write}; use std::io::{self, Write};
use crate::context::Context; use crate::context::Context;
@ -29,7 +30,7 @@ pub fn prompt(args: ArgMatches) {
writeln!(handle).unwrap(); writeln!(handle).unwrap();
let modules = prompt_order let modules = prompt_order
.iter() .par_iter()
.map(|module| modules::handle(module, &context)) // Compute modules .map(|module| modules::handle(module, &context)) // Compute modules
.flatten() .flatten()
.collect::<Vec<Module>>(); // Remove segments set to `None` .collect::<Vec<Module>>(); // Remove segments set to `None`