mirror of
https://github.com/notohh/rustlings.git
synced 2024-11-21 21:42:23 -05:00
Use exercises as leaked
This commit is contained in:
parent
f0ce2c1afa
commit
787bec9875
5 changed files with 21 additions and 18 deletions
|
@ -13,7 +13,7 @@ use crate::{exercise::Exercise, state_file::StateFile};
|
|||
|
||||
use self::state::{Filter, UiState};
|
||||
|
||||
pub fn list(state_file: &mut StateFile, exercises: &[Exercise]) -> Result<()> {
|
||||
pub fn list(state_file: &mut StateFile, exercises: &'static [Exercise]) -> Result<()> {
|
||||
let mut stdout = io::stdout().lock();
|
||||
stdout.execute(EnterAlternateScreen)?;
|
||||
enable_raw_mode()?;
|
||||
|
|
|
@ -16,18 +16,18 @@ pub enum Filter {
|
|||
None,
|
||||
}
|
||||
|
||||
pub struct UiState<'a> {
|
||||
pub table: Table<'a>,
|
||||
pub struct UiState {
|
||||
pub table: Table<'static>,
|
||||
pub message: String,
|
||||
pub filter: Filter,
|
||||
exercises: &'a [Exercise],
|
||||
exercises: &'static [Exercise],
|
||||
progress: u16,
|
||||
selected: usize,
|
||||
table_state: TableState,
|
||||
last_ind: usize,
|
||||
}
|
||||
|
||||
impl<'a> UiState<'a> {
|
||||
impl UiState {
|
||||
pub fn with_updated_rows(mut self, state_file: &StateFile) -> Self {
|
||||
let mut rows_counter: usize = 0;
|
||||
let mut progress: u16 = 0;
|
||||
|
@ -79,7 +79,7 @@ impl<'a> UiState<'a> {
|
|||
self
|
||||
}
|
||||
|
||||
pub fn new(state_file: &StateFile, exercises: &'a [Exercise]) -> Self {
|
||||
pub fn new(state_file: &StateFile, exercises: &'static [Exercise]) -> Self {
|
||||
let header = Row::new(["Next", "State", "Name", "Path"]);
|
||||
|
||||
let max_name_len = exercises
|
||||
|
|
16
src/main.rs
16
src/main.rs
|
@ -56,7 +56,7 @@ enum Subcommands {
|
|||
List,
|
||||
}
|
||||
|
||||
fn find_exercise<'a>(name: &str, exercises: &'a [Exercise]) -> Result<(usize, &'a Exercise)> {
|
||||
fn find_exercise(name: &str, exercises: &'static [Exercise]) -> Result<(usize, &'static Exercise)> {
|
||||
if name == "next" {
|
||||
for (ind, exercise) in exercises.iter().enumerate() {
|
||||
if !exercise.looks_done()? {
|
||||
|
@ -89,7 +89,7 @@ Try running `cargo --version` to diagnose the problem.",
|
|||
let exercises = InfoFile::parse()?.exercises.leak();
|
||||
|
||||
if matches!(args.command, Some(Subcommands::Init)) {
|
||||
init::init(&exercises).context("Initialization failed")?;
|
||||
init::init(exercises).context("Initialization failed")?;
|
||||
println!(
|
||||
"\nDone initialization!\n
|
||||
Run `cd rustlings` to go into the generated directory.
|
||||
|
@ -107,7 +107,7 @@ If you are just starting with Rustlings, run the command `rustlings init` to ini
|
|||
exit(1);
|
||||
}
|
||||
|
||||
let mut state_file = StateFile::read_or_default(&exercises);
|
||||
let mut state_file = StateFile::read_or_default(exercises);
|
||||
|
||||
match args.command {
|
||||
None | Some(Subcommands::Watch) => {
|
||||
|
@ -116,23 +116,23 @@ If you are just starting with Rustlings, run the command `rustlings init` to ini
|
|||
// `Init` is handled above.
|
||||
Some(Subcommands::Init) => (),
|
||||
Some(Subcommands::List) => {
|
||||
list::list(&mut state_file, &exercises)?;
|
||||
list::list(&mut state_file, exercises)?;
|
||||
}
|
||||
Some(Subcommands::Run { name }) => {
|
||||
let (_, exercise) = find_exercise(&name, &exercises)?;
|
||||
let (_, exercise) = find_exercise(&name, exercises)?;
|
||||
run(exercise).unwrap_or_else(|_| exit(1));
|
||||
}
|
||||
Some(Subcommands::Reset { name }) => {
|
||||
let (ind, exercise) = find_exercise(&name, &exercises)?;
|
||||
let (ind, exercise) = find_exercise(&name, exercises)?;
|
||||
exercise.reset()?;
|
||||
state_file.reset(ind)?;
|
||||
println!("The exercise {exercise} has been reset!");
|
||||
}
|
||||
Some(Subcommands::Hint { name }) => {
|
||||
let (_, exercise) = find_exercise(&name, &exercises)?;
|
||||
let (_, exercise) = find_exercise(&name, exercises)?;
|
||||
println!("{}", exercise.hint);
|
||||
}
|
||||
Some(Subcommands::Verify) => match verify(&exercises, 0)? {
|
||||
Some(Subcommands::Verify) => match verify(exercises, 0)? {
|
||||
VerifyState::AllExercisesDone => println!("All exercises done!"),
|
||||
VerifyState::Failed(exercise) => bail!("Exercise {exercise} failed"),
|
||||
},
|
||||
|
|
|
@ -4,9 +4,9 @@ use std::io::{stdout, Write};
|
|||
|
||||
use crate::exercise::{Exercise, Mode, State};
|
||||
|
||||
pub enum VerifyState<'a> {
|
||||
pub enum VerifyState {
|
||||
AllExercisesDone,
|
||||
Failed(&'a Exercise),
|
||||
Failed(&'static Exercise),
|
||||
}
|
||||
|
||||
// Verify that the provided container of Exercise objects
|
||||
|
@ -14,7 +14,10 @@ pub enum VerifyState<'a> {
|
|||
// Any such failures will be reported to the end user.
|
||||
// If the Exercise being verified is a test, the verbose boolean
|
||||
// determines whether or not the test harness outputs are displayed.
|
||||
pub fn verify(exercises: &[Exercise], mut current_exercise_ind: usize) -> Result<VerifyState<'_>> {
|
||||
pub fn verify(
|
||||
exercises: &'static [Exercise],
|
||||
mut current_exercise_ind: usize,
|
||||
) -> Result<VerifyState> {
|
||||
while current_exercise_ind < exercises.len() {
|
||||
let exercise = &exercises[current_exercise_ind];
|
||||
|
||||
|
|
|
@ -18,7 +18,7 @@ use crate::{
|
|||
pub struct WatchState<'a> {
|
||||
writer: StdoutLock<'a>,
|
||||
exercises: &'static [Exercise],
|
||||
exercise: &'a Exercise,
|
||||
exercise: &'static Exercise,
|
||||
current_exercise_ind: usize,
|
||||
stdout: Option<Vec<u8>>,
|
||||
stderr: Option<Vec<u8>>,
|
||||
|
|
Loading…
Reference in a new issue