Update Cargo.toml on dev check

This commit is contained in:
mo8it 2024-04-16 03:30:28 +02:00
parent d1ebbaa6f6
commit aa813fbce1
4 changed files with 20 additions and 7 deletions

View file

@ -1,6 +1,8 @@
use anyhow::{Context, Result};
use clap::Subcommand;
use crate::info_file::InfoFile;
mod check;
mod init;
@ -11,10 +13,10 @@ pub enum DevCommands {
}
impl DevCommands {
pub fn run(self) -> Result<()> {
pub fn run(self, info_file: InfoFile) -> Result<()> {
match self {
DevCommands::Init => init::init().context(INIT_ERR),
DevCommands::Check => check::check(),
DevCommands::Check => check::check(info_file),
}
}
}

View file

@ -1,5 +1,16 @@
use anyhow::Result;
use std::fs;
pub fn check() -> Result<()> {
todo!()
use anyhow::{Context, Result};
use crate::{info_file::InfoFile, init::cargo_toml};
pub fn check(info_file: InfoFile) -> Result<()> {
// TODO: Add checks
fs::write("Cargo.toml", cargo_toml(&info_file.exercises))
.context("Failed to update the file `Cargo.toml`")?;
println!("Everything looks fine!");
Ok(())
}

View file

@ -8,7 +8,7 @@ use std::{
use crate::{embedded::EMBEDDED_FILES, info_file::ExerciseInfo};
fn cargo_toml(exercise_infos: &[ExerciseInfo]) -> Vec<u8> {
pub fn cargo_toml(exercise_infos: &[ExerciseInfo]) -> Vec<u8> {
let mut cargo_toml = Vec::with_capacity(1 << 13);
cargo_toml.extend_from_slice(b"bin = [\n");
for exercise_info in exercise_infos {

View file

@ -76,7 +76,7 @@ fn main() -> Result<()> {
Some(Subcommands::Init) => {
return init::init(&info_file.exercises).context("Initialization failed");
}
Some(Subcommands::Dev(dev_command)) => return dev_command.run(),
Some(Subcommands::Dev(dev_command)) => return dev_command.run(info_file),
_ => (),
}