Add: support to start watch at any exercise
This commit is contained in:
parent
ea4b8ade51
commit
3877fa0a68
20
src/main.rs
20
src/main.rs
|
@ -57,9 +57,9 @@ struct VerifyArgs {}
|
||||||
#[argh(subcommand, name = "watch")]
|
#[argh(subcommand, name = "watch")]
|
||||||
/// Reruns `verify` when files were edited
|
/// Reruns `verify` when files were edited
|
||||||
struct WatchArgs {
|
struct WatchArgs {
|
||||||
#[argh(positional)]
|
#[argh(option)]
|
||||||
/// the name of the exercise at which start to watch
|
/// the name of the exercise at which start to watch
|
||||||
name: String
|
name: Option<String>
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(FromArgs, PartialEq, Debug)]
|
#[derive(FromArgs, PartialEq, Debug)]
|
||||||
|
@ -221,7 +221,21 @@ fn main() {
|
||||||
}
|
}
|
||||||
|
|
||||||
Subcommands::Watch(_subargs) => {
|
Subcommands::Watch(_subargs) => {
|
||||||
if let Err(e) = watch(&exercises, verbose) {
|
let mut watch_exercises: Vec<Exercise> = exercises;
|
||||||
|
match _subargs.name {
|
||||||
|
Some(ref name) => {
|
||||||
|
watch_exercises = watch_exercises
|
||||||
|
.into_iter()
|
||||||
|
.skip_while(|e| e.name != *name).collect::<Vec<_>>();
|
||||||
|
if watch_exercises.len() == 0 {
|
||||||
|
// can't find matched exercise
|
||||||
|
println!("Error : Could not found the exrecise");
|
||||||
|
std::process::exit(1);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
None => ()
|
||||||
|
}
|
||||||
|
if let Err(e) = watch(&watch_exercises, verbose) {
|
||||||
println!(
|
println!(
|
||||||
"Error: Could not watch your progress. Error message was {:?}.",
|
"Error: Could not watch your progress. Error message was {:?}.",
|
||||||
e
|
e
|
||||||
|
|
Loading…
Reference in a new issue