summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Gay <eapoems@riseup.net>2023-09-30 23:14:13 -0400
committerDavid Gay <eapoems@riseup.net>2023-09-30 23:14:13 -0400
commit4e5f2211e0be7d189235bc88b1ca8fef29e77f87 (patch)
treeec03bea631875419ba6614e09f42af5c8a0d3308
parentf92a67d5d0010a1c9825acd7b6ec87580b429272 (diff)
Basic CLI
-rw-r--r--Cargo.toml6
-rw-r--r--src/cli.rs16
-rw-r--r--src/main.rs16
3 files changed, 31 insertions, 7 deletions
diff --git a/Cargo.toml b/Cargo.toml
index 353126b..39437c3 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -2,12 +2,14 @@
name = "dmn"
version = "0.1.0"
edition = "2021"
+description = "A CLI and library to assist with Advanced Dungeons & Dragons (AD&D)"
authors = ["David Gay <eapoems@riseup.net>"]
+repository = "https://git.aikuro.net/poems/dmn"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
-clap = "^4.4"
+clap = { version = "^4.4", features = ["cargo"] }
rand = "^0.8"
-serde = "^1.0" \ No newline at end of file
+serde = "^1.0"
diff --git a/src/cli.rs b/src/cli.rs
new file mode 100644
index 0000000..4ceaf90
--- /dev/null
+++ b/src/cli.rs
@@ -0,0 +1,16 @@
+use clap::{arg, Command, crate_authors, crate_description, crate_name, crate_version};
+
+pub fn cli() -> Command {
+ Command::new(crate_name!())
+ .about(crate_description!())
+ .author(crate_authors!())
+ .version(crate_version!())
+ .subcommand_required(true)
+ .arg_required_else_help(true)
+ .allow_external_subcommands(true)
+ .subcommand(Command::new("roll")
+ .about("Rolls dice based on a given formula.")
+ .arg(arg!(<FORMULA> "The dice rolling formula"))
+ .arg_required_else_help(true),
+ )
+}
diff --git a/src/main.rs b/src/main.rs
index 88fa2ab..c3431cd 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -1,10 +1,16 @@
+mod cli;
mod dice;
fn main() {
- const TEST_FORMULA : &str = "3d6";
- println!("Rolling {}:", TEST_FORMULA);
- match dice::roll_formula(TEST_FORMULA) {
- Some(result) => println!("{}", result),
- None => eprintln!("Error: Invalid roll formula, or die roll otherwise failed.")
+ let matches = cli::cli().get_matches();
+
+ match matches.subcommand() {
+ Some(("roll", sub_matches)) => {
+ match dice::roll_formula(sub_matches.get_one::<String>("FORMULA").expect("required")) {
+ Some(result) => println!("Rolled: {}", result),
+ None => eprintln!("Error: Invalid roll formula or calculation failed.")
+ }
+ }
+ _ => unreachable!()
}
}