Skip to content

Commit

Permalink
add clap_layered
Browse files Browse the repository at this point in the history
  • Loading branch information
reiase committed Mar 17, 2024
1 parent 1056e72 commit 099a1db
Show file tree
Hide file tree
Showing 8 changed files with 157 additions and 39 deletions.
12 changes: 12 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -49,3 +49,15 @@ overflow-checks = false
[[bench]]
name = "bench_apis"
harness = false

[[example]]
name = "clap_mini"
path = "examples/rust/clap_mini.rs"

[[example]]
name = "clap_layered"
path = "examples/rust/clap_layered.rs"

[[example]]
name = "clap_full"
path = "examples/rust/clap_full.rs"
33 changes: 0 additions & 33 deletions examples/clap_app.rs

This file was deleted.

2 changes: 2 additions & 0 deletions examples/rust/cfg.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
[example]
param1 = "from config"
53 changes: 53 additions & 0 deletions examples/rust/clap_full.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
use std::path::Path;

use clap::Parser;
use config::{self, File};
use hyperparameter::*;

/// Defines the command-line arguments for the application.
#[derive(Parser)]
#[command(after_long_help=generate_params_help())]
struct CommandLineArgs {
/// Specifies hyperparameters in the format `-D key=value` via the command line.
#[arg(short = 'D', long)]
define: Vec<String>,

/// Specifies the configuration file path.
#[arg(short = 'C', long, default_value = "examples/rust/cfg.toml")]
config: String,
}

fn foo(desc: &str) {
with_params! {
get param1 = example.param1 or "default".to_string();

println!("param1={} // {}", param1, desc);
}
}

fn main() {
let args = CommandLineArgs::parse();
let config_path = Path::new(&args.config);
let config = config::Config::builder()
.add_source(File::from(config_path))
.build()
.expect("Failed to load configuration file."); // Improved error handling

foo("Outside any specific scope");

with_params! { // Scope with configuration file parameters
params config.param_scope();

foo("Within configuration file scope");
with_params! { // Scope with command-line arguments
params ParamScope::from(&args.define);

foo("Within command-line arguments scope");
with_params! { // User-defined scope
set example.param1= "scoped".to_string();

foo("Within user-defined scope");
}
}
}
}
46 changes: 46 additions & 0 deletions examples/rust/clap_layered.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
use std::path::Path;

use clap::Parser;
use config::{self, File};
use hyperparameter::*;

/// Defines the command-line arguments for the application.
#[derive(Parser)]
#[command(after_long_help=generate_params_help())]
struct CommandLineArgs {
/// Specifies hyperparameters in the format `-D key=value` via the command line.
#[arg(short = 'D', long)]
define: Vec<String>,

/// Specifies the configuration file path.
#[arg(short = 'C', long, default_value = "examples/rust/cfg.toml")]
config: String,
}

fn main() {
let args = CommandLineArgs::parse();
let config_path = Path::new(&args.config);
let config = config::Config::builder()
.add_source(File::from(config_path))
.build()
.expect("Failed to load configuration file."); // Improved error handling

// No scope
println!("param1={} // Outside any specific scope", get_param!(example.param1, "default".to_string()));

with_params! { // Scope with configuration file parameters
params config.param_scope();

println!("param1={} // Within configuration file scope", get_param!(example.param1, "default".to_string()));
with_params! { // Scope with command-line arguments
params ParamScope::from(&args.define);

println!("param1={} // Within command-line arguments scope", get_param!(example.param1, "default".to_string(), "Example param1"));
with_params! { // User-defined scope
set example.param1= "scoped".to_string();

println!("param1={} // Within user-defined scope", get_param!(example.param1, "default".to_string()));
}
}
}
}
22 changes: 22 additions & 0 deletions examples/rust/clap_mini.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
use clap::Parser;
use hyperparameter::*;

/// Defines the command-line arguments for the application.
#[derive(Parser)]
#[command(after_long_help=generate_params_help())]
struct CommandLineArgs {
/// Specifies hyperparameters in the format `-D key=value` via the command line.
#[arg(short = 'D', long)]
define: Vec<String>,
}

fn main() {
let args = CommandLineArgs::parse();
with_params! {
params ParamScope::from(&args.define);
// Retrieves `example.param1` with a default value of `1` if not specified.
println!("param1={}", get_param!(example.param1, 1));
// Displays a help message when `<app> --help` is executed.
println!("param2={}", get_param!(example.param2, false, "Example param2"));
}
}
25 changes: 19 additions & 6 deletions src/api.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ use crate::storage::{
use crate::value::{Value, EMPTY};
use crate::xxh::XXHashable;

#[derive(Debug)]
#[derive(Debug, Clone)]
pub enum ParamScope {
Nothing,
Just(Tree),
Expand Down Expand Up @@ -180,9 +180,7 @@ macro_rules! get_param {
{
const CONST_HELP: &str = $help;
#[::linkme::distributed_slice(PARAMS)]
static help: (&str, &str) = (
CONST_KEY, CONST_HELP
);
static help: (&str, &str) = (CONST_KEY, CONST_HELP);
}
THREAD_STORAGE.with(|ts| ts.borrow_mut().get_or_else(CONST_HASH, $default))
}};
Expand Down Expand Up @@ -242,6 +240,18 @@ macro_rules! with_params {
with_params!(params $ps; $($body)*)
};

(
params $ps:expr;
params $nested:expr;

$($body:tt)*
) => {
$ps.enter();
let ret = with_params!(params $nested; $($body)*);
$ps.exit();
ret
};

(
get $name:ident = $($key:ident).+ or $default:expr;

Expand All @@ -257,7 +267,6 @@ macro_rules! with_params {

$($body:tt)*
) => {

$ps.enter();
let ret = {
let $name = get_param!($($key).+, $default);
Expand All @@ -266,7 +275,6 @@ macro_rules! with_params {
};
$ps.exit();
ret

};

(
Expand All @@ -279,6 +287,11 @@ macro_rules! with_params {
$ps.exit();
ret
}};

($($body:tt)*) => {{
let ret = {$($body)*};
ret
}};
}

#[macro_export]
Expand Down
3 changes: 3 additions & 0 deletions src/cli.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ pub static PARAMS: [(&str, &str)];

pub fn generate_params_help() -> String {
let mut params: HashMap<String, HashSet<String>> = HashMap::default();
if PARAMS.len() == 0 {
return "".to_string();
}
for kv in PARAMS {
params
.entry(kv.0.to_string())
Expand Down

0 comments on commit 099a1db

Please sign in to comment.