minor-ent-fixes #8
1 changed files with 17 additions and 8 deletions
|
|
@ -35,7 +35,10 @@ enum Commands {
|
||||||
Show { issue_id: String },
|
Show { issue_id: String },
|
||||||
|
|
||||||
/// Modify the state of an issue
|
/// Modify the state of an issue
|
||||||
State { issue_id: String, new_state: Option<State> },
|
State {
|
||||||
|
issue_id: String,
|
||||||
|
new_state: Option<State>,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
fn handle_command(args: &Args, issues_dir: &std::path::Path) -> anyhow::Result<()> {
|
fn handle_command(args: &Args, issues_dir: &std::path::Path) -> anyhow::Result<()> {
|
||||||
|
|
@ -47,6 +50,7 @@ fn handle_command(args: &Args, issues_dir: &std::path::Path) -> anyhow::Result<(
|
||||||
println!("{} {} ({:?})", uuid, issue.title(), issue.state);
|
println!("{} {} ({:?})", uuid, issue.title(), issue.state);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Commands::New {
|
Commands::New {
|
||||||
description: Some(description),
|
description: Some(description),
|
||||||
} => {
|
} => {
|
||||||
|
|
@ -54,11 +58,13 @@ fn handle_command(args: &Args, issues_dir: &std::path::Path) -> anyhow::Result<(
|
||||||
issue.set_description(description)?;
|
issue.set_description(description)?;
|
||||||
println!("created new issue '{}'", issue.title());
|
println!("created new issue '{}'", issue.title());
|
||||||
}
|
}
|
||||||
|
|
||||||
Commands::New { description: None } => {
|
Commands::New { description: None } => {
|
||||||
let mut issue = entomologist::issue::Issue::new(issues_dir)?;
|
let mut issue = entomologist::issue::Issue::new(issues_dir)?;
|
||||||
issue.edit_description()?;
|
issue.edit_description()?;
|
||||||
println!("created new issue '{}'", issue.title());
|
println!("created new issue '{}'", issue.title());
|
||||||
}
|
}
|
||||||
|
|
||||||
Commands::Edit { issue_id } => {
|
Commands::Edit { issue_id } => {
|
||||||
let mut issues =
|
let mut issues =
|
||||||
entomologist::issues::Issues::new_from_dir(std::path::Path::new(issues_dir))?;
|
entomologist::issues::Issues::new_from_dir(std::path::Path::new(issues_dir))?;
|
||||||
|
|
@ -67,10 +73,11 @@ fn handle_command(args: &Args, issues_dir: &std::path::Path) -> anyhow::Result<(
|
||||||
issue.edit_description()?;
|
issue.edit_description()?;
|
||||||
}
|
}
|
||||||
None => {
|
None => {
|
||||||
println!("issue {} not found", issue_id);
|
return Err(anyhow::anyhow!("issue {} not found", issue_id));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Commands::Show { issue_id } => {
|
Commands::Show { issue_id } => {
|
||||||
let issues =
|
let issues =
|
||||||
entomologist::issues::Issues::new_from_dir(std::path::Path::new(issues_dir))?;
|
entomologist::issues::Issues::new_from_dir(std::path::Path::new(issues_dir))?;
|
||||||
|
|
@ -85,17 +92,20 @@ fn handle_command(args: &Args, issues_dir: &std::path::Path) -> anyhow::Result<(
|
||||||
println!("{}", issue.description);
|
println!("{}", issue.description);
|
||||||
}
|
}
|
||||||
None => {
|
None => {
|
||||||
println!("issue {} not found", issue_id);
|
return Err(anyhow::anyhow!("issue {} not found", issue_id));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Commands::State { issue_id, new_state } => {
|
|
||||||
|
Commands::State {
|
||||||
|
issue_id,
|
||||||
|
new_state,
|
||||||
|
} => {
|
||||||
let mut issues =
|
let mut issues =
|
||||||
entomologist::issues::Issues::new_from_dir(std::path::Path::new(issues_dir))?;
|
entomologist::issues::Issues::new_from_dir(std::path::Path::new(issues_dir))?;
|
||||||
match issues.issues.get_mut(issue_id) {
|
match issues.issues.get_mut(issue_id) {
|
||||||
Some(issue) => {
|
Some(issue) => {
|
||||||
let current_state = issue.state.clone();
|
let current_state = issue.state.clone();
|
||||||
|
|
||||||
match new_state {
|
match new_state {
|
||||||
Some(s) => {
|
Some(s) => {
|
||||||
issue.set_state(s.clone())?;
|
issue.set_state(s.clone())?;
|
||||||
|
|
@ -107,10 +117,9 @@ fn handle_command(args: &Args, issues_dir: &std::path::Path) -> anyhow::Result<(
|
||||||
println!("state: {}", current_state);
|
println!("state: {}", current_state);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
None => {
|
None => {
|
||||||
println!("issue {} not found", issue_id);
|
return Err(anyhow::anyhow!("issue {} not found", issue_id));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue