diff options
| author | komaeda <819880950@qq.com> | 2019-03-16 12:54:09 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-03-16 12:54:09 +0100 |
| commit | 8f9d7ce3d8aa33b466a7d48acef818c32f8282fe (patch) | |
| tree | 2f234f3b7ed1efbf7c493e9087856c74e454eb01 /src | |
| parent | abf175111d9bd997bc1c4ef5e078308fad681480 (diff) | |
| parent | 3b5dfac44e881c10b0ee47c320e5e7825aed4ddb (diff) | |
Merge pull request #120 from abagshaw/master
Start verification at most recently modified file
Diffstat (limited to 'src')
| -rw-r--r-- | src/main.rs | 7 | ||||
| -rw-r--r-- | src/verify.rs | 18 |
2 files changed, 19 insertions, 6 deletions
diff --git a/src/main.rs b/src/main.rs index 0e2c975..3418685 100644 --- a/src/main.rs +++ b/src/main.rs @@ -52,7 +52,7 @@ fn main() { } if matches.subcommand_matches("verify").is_some() { - match verify() { + match verify(None) { Ok(_) => {} Err(_) => std::process::exit(1), } @@ -81,14 +81,15 @@ fn watch() -> notify::Result<()> { let mut watcher: RecommendedWatcher = Watcher::new(tx, Duration::from_secs(2))?; watcher.watch("./exercises", RecursiveMode::Recursive)?; - let _ignored = verify(); + let _ignored = verify(None); loop { match rx.recv() { Ok(event) => match event { DebouncedEvent::Create(b) | DebouncedEvent::Chmod(b) | DebouncedEvent::Write(b) => { if b.extension() == Some(OsStr::new("rs")) { - let _ignored = verify(); + println!("----------**********----------\n"); + let _ignored = verify(Some(b.as_path().to_str().unwrap())); } } _ => {} diff --git a/src/verify.rs b/src/verify.rs index ab08a27..5aa2f5c 100644 --- a/src/verify.rs +++ b/src/verify.rs @@ -5,13 +5,25 @@ use std::fs; use std::process::Command; use toml::Value; -pub fn verify() -> Result<(), ()> { +pub fn verify(start_at: Option<&str>) -> Result<(), ()> { let toml: Value = fs::read_to_string("info.toml").unwrap().parse().unwrap(); let tomlvec: &Vec<Value> = toml.get("exercises").unwrap().as_array().unwrap(); + let mut hit_start_at = false; + for i in tomlvec { + let path = i.get("path").unwrap().as_str().unwrap(); + + if let Some(start_at) = start_at { + if start_at.ends_with(path) { + hit_start_at = true; + } else if !hit_start_at { + continue; + } + } + match i.get("mode").unwrap().as_str().unwrap() { - "test" => test(i.get("path").unwrap().as_str().unwrap())?, - "compile" => compile_only(i.get("path").unwrap().as_str().unwrap())?, + "test" => test(path)?, + "compile" => compile_only(path)?, _ => (), } } |
