2024-03-31 17:55:33 +03:00
|
|
|
use anyhow::{bail, Result};
|
|
|
|
use std::io::{self, stdout, Write};
|
2023-08-27 00:35:07 +03:00
|
|
|
use std::time::Duration;
|
2022-08-17 17:31:53 +03:00
|
|
|
|
2024-03-29 00:11:16 +03:00
|
|
|
use crate::embedded::{WriteStrategy, EMBEDDED_FILES};
|
2019-05-22 14:50:23 +03:00
|
|
|
use crate::exercise::{Exercise, Mode};
|
2019-01-10 00:04:08 +03:00
|
|
|
use crate::verify::test;
|
2019-01-09 22:33:43 +03:00
|
|
|
use indicatif::ProgressBar;
|
|
|
|
|
2020-06-04 17:31:17 +03:00
|
|
|
// Invoke the rust compiler on the path of the given exercise,
|
|
|
|
// and run the ensuing binary.
|
|
|
|
// The verbose argument helps determine whether or not to show
|
|
|
|
// the output from the test harnesses (if the mode of the exercise is test)
|
2024-03-31 17:55:33 +03:00
|
|
|
pub fn run(exercise: &Exercise, verbose: bool) -> Result<()> {
|
2019-04-11 23:41:24 +03:00
|
|
|
match exercise.mode {
|
2024-03-31 17:55:33 +03:00
|
|
|
Mode::Test => test(exercise, verbose),
|
|
|
|
Mode::Compile | Mode::Clippy => compile_and_run(exercise),
|
2019-03-06 23:47:00 +03:00
|
|
|
}
|
|
|
|
}
|
2019-01-09 22:33:58 +03:00
|
|
|
|
2022-08-17 17:31:53 +03:00
|
|
|
// Resets the exercise by stashing the changes.
|
2024-03-29 00:11:16 +03:00
|
|
|
pub fn reset(exercise: &Exercise) -> io::Result<()> {
|
|
|
|
EMBEDDED_FILES.write_exercise_to_disk(&exercise.path, WriteStrategy::Overwrite)
|
2022-08-17 17:31:53 +03:00
|
|
|
}
|
|
|
|
|
2020-06-04 17:31:17 +03:00
|
|
|
// Invoke the rust compiler on the path of the given exercise
|
|
|
|
// and run the ensuing binary.
|
|
|
|
// This is strictly for non-test binaries, so output is displayed
|
2024-03-31 17:55:33 +03:00
|
|
|
fn compile_and_run(exercise: &Exercise) -> Result<()> {
|
2019-03-11 17:09:20 +03:00
|
|
|
let progress_bar = ProgressBar::new_spinner();
|
2024-03-31 17:55:33 +03:00
|
|
|
progress_bar.set_message(format!("Running {exercise}..."));
|
2023-08-27 00:35:07 +03:00
|
|
|
progress_bar.enable_steady_tick(Duration::from_millis(100));
|
2019-04-07 19:12:03 +03:00
|
|
|
|
2024-03-31 17:55:33 +03:00
|
|
|
let output = exercise.run()?;
|
2020-02-20 22:11:53 +03:00
|
|
|
progress_bar.finish_and_clear();
|
2019-03-06 23:47:00 +03:00
|
|
|
|
2024-03-31 17:55:33 +03:00
|
|
|
stdout().write_all(&output.stdout)?;
|
|
|
|
if !output.status.success() {
|
|
|
|
stdout().write_all(&output.stderr)?;
|
|
|
|
warn!("Ran {} with errors", exercise);
|
|
|
|
bail!("TODO");
|
2019-01-09 22:33:43 +03:00
|
|
|
}
|
2024-03-31 17:55:33 +03:00
|
|
|
|
|
|
|
success!("Successfully ran {}", exercise);
|
|
|
|
Ok(())
|
2019-01-09 22:33:43 +03:00
|
|
|
}
|