Make debug commands passable as parameters
This commit is contained in:
parent
ed758a8eaf
commit
33f18c4aeb
|
@ -24,6 +24,7 @@ use log::info;
|
||||||
use env_logger::Env;
|
use env_logger::Env;
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
use yama::commands::{fully_integrate_pointer_node, load_pile_descriptor, open_pile};
|
use yama::commands::{fully_integrate_pointer_node, load_pile_descriptor, open_pile};
|
||||||
|
use yama::debug::{debug_command, DebugCommand};
|
||||||
use yama::operations::checking::VacuumMode;
|
use yama::operations::checking::VacuumMode;
|
||||||
use yama::operations::pushpull::{determine_bypass_level, open_pile_with_work_bypass, push_to};
|
use yama::operations::pushpull::{determine_bypass_level, open_pile_with_work_bypass, push_to};
|
||||||
use yama::operations::{checking, extracting};
|
use yama::operations::{checking, extracting};
|
||||||
|
@ -80,7 +81,7 @@ enum PileCommand {
|
||||||
},
|
},
|
||||||
|
|
||||||
/// Enter a debug prompt for manually operating on the yama pile.
|
/// Enter a debug prompt for manually operating on the yama pile.
|
||||||
Debug,
|
Debug { supplied_command: Vec<String> },
|
||||||
|
|
||||||
/// Pushes a pointer from this pile to another pile.
|
/// Pushes a pointer from this pile to another pile.
|
||||||
Push {
|
Push {
|
||||||
|
@ -169,9 +170,28 @@ fn main() -> anyhow::Result<()> {
|
||||||
commands::init(".".as_ref())?;
|
commands::init(".".as_ref())?;
|
||||||
}
|
}
|
||||||
|
|
||||||
PileCommand::Debug => {
|
PileCommand::Debug { supplied_command } => {
|
||||||
let (pdesc, pile) = open_pile()?;
|
let (pdesc, pile) = open_pile()?;
|
||||||
|
if supplied_command.is_empty() {
|
||||||
debug::debug_prompt(pdesc, pile)?;
|
debug::debug_prompt(pdesc, pile)?;
|
||||||
|
} else {
|
||||||
|
let mut prefixed_command = vec![String::from("yama-debug")];
|
||||||
|
prefixed_command.extend(supplied_command.iter().cloned());
|
||||||
|
match DebugCommand::try_parse_from(prefixed_command) {
|
||||||
|
Ok(command) => {
|
||||||
|
if let Err(e) = debug_command(&pdesc, &pile, command) {
|
||||||
|
eprintln!("Failed {:?}", e);
|
||||||
|
std::process::exit(2);
|
||||||
|
} else {
|
||||||
|
std::process::exit(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Err(err) => {
|
||||||
|
eprintln!("Invalid {:?}", err);
|
||||||
|
std::process::exit(3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
PileCommand::Push {
|
PileCommand::Push {
|
||||||
|
|
|
@ -26,7 +26,7 @@ use rustyline::error::ReadlineError;
|
||||||
use rustyline::Editor;
|
use rustyline::Editor;
|
||||||
|
|
||||||
#[derive(Clap)]
|
#[derive(Clap)]
|
||||||
enum DebugCommand {
|
pub enum DebugCommand {
|
||||||
/// List the pointers that are stored in this yama pile.
|
/// List the pointers that are stored in this yama pile.
|
||||||
#[clap(name = "lsp")]
|
#[clap(name = "lsp")]
|
||||||
ListPointers {
|
ListPointers {
|
||||||
|
@ -90,7 +90,7 @@ pub fn debug_prompt<RP: RawPile>(pdesc: PileDescriptor, pile: Pile<RP>) -> anyho
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn debug_command<RP: RawPile>(
|
pub fn debug_command<RP: RawPile>(
|
||||||
_pdesc: &PileDescriptor,
|
_pdesc: &PileDescriptor,
|
||||||
pile: &Pile<RP>,
|
pile: &Pile<RP>,
|
||||||
command: DebugCommand,
|
command: DebugCommand,
|
||||||
|
|
Loading…
Reference in New Issue