flexiargs 1.0.1

A flexible, rule-based command dispatcher and argument parser with strict level control.
Documentation
  • Coverage
  • 100%
    10 out of 10 items documented1 out of 1 items with examples
  • Size
  • Source code size: 41.33 kB This is the summed size of all the files inside the crates.io package for this release.
  • Documentation size: 424.54 kB This is the summed size of all files generated by rustdoc for all configured targets
  • ร˜ build duration
  • this release: 26s Average build duration of successful builds.
  • all releases: 22s Average build duration of successful builds in releases after 2024-10-23.
  • Links
  • Homepage
  • LinuxProativo/flexiargs
    1 0 0
  • crates.io
  • Dependencies
  • Versions
  • Owners
  • LinuxProativo

๐Ÿ” Overview

flexiargs is a lightweight and dependency-friendly Rust crate designed for rule-based command-line argument parsing without relying on macros, derive systems, or bloated abstractions.

Instead of hiding behavior behind procedural magic, flexiargs provides a clean and explicit API that allows developers to bind CLI arguments directly to variables while retaining full control over parsing logic and application flow.

Built with simplicity and flexibility in mind, it gives you low-level control when you need it, without sacrificing ergonomics. With flexiargs, you can easily manage:

  • โš™๏ธ Parsing behavior and argument rules;

  • โœ… Validation and constraint handling;

  • ๐Ÿ“ฆ Unmatched or forwarded arguments;

  • ๐Ÿš€ Execution flow and command dispatching;

  • ๐Ÿงฉ Custom CLI architectures and dynamic behaviors;

Unlike heavy CLI frameworks, flexiargs focuses on predictable behavior, small footprint, and straightforward integration, making it ideal for projects where control and portability matter. Perfect for:

  • ๐Ÿ“ฆ Package managers;

  • ๐Ÿ› ๏ธ System utilities;

  • ๐Ÿ“ฅ Installers and bootstrap tools;

  • ๐Ÿงฉ Embedded CLI environments;

  • ๐Ÿš Custom shell-like applications;

  • ๐Ÿงช Internal developer tooling;

  • โšก Lightweight standalone binaries;

  • ๐Ÿš€ Experimental runtime environments;

โœจ Features

flexiargs is designed to keep CLI parsing simple, explicit, and predictable, without relying on macros or heavy abstractions. Instead of hiding behavior behind complex frameworks, it exposes clear rule-based control over how arguments are interpreted and processed.

  • ๐Ÿงฉ Simple rule-based parser API
    Defines parsing rules in a declarative way, without DSLs or code generation. You have full control over how each argument is interpreted.

  • ๐Ÿšซ No procedural macros
    No dependency on derive or procedural macros. This reduces compile time, avoids hidden behavior, and improves debugging clarity.

  • ๐Ÿ”  Supports short and long flags
    Full support for both short flags (-v, -h) and long flags (--verbose, --help) for flexible CLI design.

  • ๐Ÿ“ Supports argument formats

    • --flag=value
      Inline assignment for compact CLI usage.
    • --flag value
      Classic POSIX-style separation for readability in interactive usage.
  • ๐Ÿ”„ Typed parsing with FromStr
    Automatically converts string inputs into Rust types using the FromStr trait, ensuring type safety and reducing manual parsing code.

  • โš ๏ธ Automatic error formatting
    Parsing errors are automatically formatted in a clear and consistent way, improving end-user feedback.

  • ๐Ÿ“Œ Optional and required arguments
    Explicit support for required and optional parameters, removing the need for manual validation logic.

  • ๐Ÿ“š Multi-value collection
    Support for multiple values for the same flag (e.g. --file a b c), collected into typed containers.

  • ๐Ÿ“ฅ Positional argument passthrough
    Positional arguments can be captured or forwarded directly to subprocesses or higher-level handlers.

  • ๐Ÿ”’ Strict validation modes
    Enables strict parsing mode to reject unknown or malformed arguments, ideal for robust tools and system utilities.

  • ๐Ÿงต Thread-safe shared settings (RwLock)
    Safe shared state across threads using RwLock, useful for concurrent CLI applications or embedded runtimes.

  • โšก Custom actions/callbacks
    Allows execution of custom callbacks during parsing for dynamic or context-aware behavior.

  • ๐Ÿชถ Minimal and dependency-light design
    Keeps the core lightweight with minimal dependencies, focusing on portability and predictable behavior.

๐Ÿ“ฆ Installation

Add the crate to your Cargo.toml:

[dependencies]
flexiargs = "1.0"

๐ŸŒ Public API

The crate intentionally exposes a very small API surface:

pub use messages::{invalid_arg, missing_arg};
pub use flexiargs::{Arg, parse_into_vars};

๐Ÿšช Main Entry Points

Item Description
Arg Defines parsing rules
parse_into_vars Executes parsing
invalid_arg Standardized invalid argument error
missing_arg Standardized missing parameter error

๐Ÿš€ Quick Example

use flexiargs::{Arg, parse_into_vars};
use std::collections::VecDeque;

let mut sync_mode = false;
let mut packages = Vec::new();
let mut cache_dir = String::new();
let mut config_file: Option<String> = None;
let mut use_overlay = true;

let mut rules = [
    Arg::bool(Some("-S"), "--sync", &mut sync_mode),
    Arg::collect_list(None, "--pkgs", "packages", &mut packages),
    Arg::value(None, "--cache-dir", "path", &mut cache_dir),
    Arg::option(Some("-c"), "--config", "file", &mut config_file),
    Arg::set(None, "--disable-overlay", false, &mut use_overlay),
];

let args = VecDeque::from(vec![
     "-S".to_string(),
    "wget".to_string(),
    "curl".to_string(),
    "--cache-dir=/tmp".to_string(),
    "--disable-overlay".to_string()
]);

parse_into_vars("aports", &mut rules, args).ok();
drop(rules);


println!("Sync: {}", sync_mode);
println!("Packages: {:?}", packages);
println!("Cache dir: {}", cache_dir);
println!("Overlay enabled: {}", use_overlay);

๐Ÿง  Core Concepts

๐Ÿ“ Parsing Rules

Every CLI behavior is defined using an Arg.

Each rule describes:

  • ๐Ÿท๏ธ Accepted flags;
  • โš™๏ธ Parsing behavior;
  • ๐ŸŽฏ Target variable;
  • โœ… Validation requirements;

Example:

Arg::bool(Some("-v"), "--verbose", &mut verbose)

๐Ÿงฑ Supported Rule Types

flexiargs is built around a small set of explicit rule types that define how command-line input is interpreted, validated, and transformed. Instead of relying on implicit behavior or hidden conventions, each rule type has a clear and predictable responsibility, allowing you to compose CLI behavior in a controlled and deterministic way.

๐Ÿšฉ Boolean Flags

Sets a boolean to true when matched.

let mut verbose = false;

Arg::bool(Some("-v"), "--verbose", &mut verbose);

โœ… Supports

  • -v
  • --verbose

๐Ÿ”ข Typed Values

Parses values using FromStr.

let mut port: u16 = 0;

Arg::value(
    Some("-p"),
    "--port",
    "port",
    &mut port
);

โœ… Supports

  • --port 8080
  • --port=8080
  • -p 8080

โ“ Optional Values

Stores values in Option<String>.

let mut config: Option<String> = None;

Arg::option(
    Some("-c"),
    "--config",
    "file",
    &mut config
);

๐Ÿ”ง Fixed State Assignment

Assigns a predefined value when matched.

let mut overlay = true;

Arg::set(
    None,
    "--disable-overlay",
    false,
    &mut overlay
);

๐Ÿ“š Multi-Value Collection

Collects sequential positional values until another flag appears.

let mut packages = Vec::new();

Arg::collect_list(
    None,
    "--pkgs",
    "packages",
    &mut packages
);

๐Ÿงช Example

--pkgs wget curl git

๐Ÿ“ค Result

["wget", "curl", "git"]

โšก Custom Actions

Executes arbitrary logic.

Arg::action(
    Some("-V"),
    "--version",
    || {
        println!("myapp 1.0");
    }
);

๐Ÿ’ก Useful for

  • ๐Ÿ“„ Version output
  • ๐Ÿ› ๏ธ Custom handlers
  • ๐Ÿšช Early exits
  • ๐Ÿ”„ Dynamic state manipulation

โ— Required Arguments

Arguments can be marked as essential:

Arg::value(
    None,
    "--root",
    "path",
    &mut root
).essential();

If no essential rule is matched:

myapp: setup: no essential parameter specified

๐Ÿงต Thread-Safe Global State

flexiargs includes built-in support for shared application state using RwLock.

๐Ÿšฉ Shared Boolean Flags

use std::sync::RwLock;

static DEBUG: RwLock<bool> = RwLock::new(false);

Arg::rw_bool(
    Some("-d"),
    "--debug",
    &DEBUG
);

๐Ÿ”ข Shared Typed Values

use std::sync::RwLock;

static PORT: RwLock<u16> = RwLock::new(8080);

Arg::rw_value(
    None,
    "--port",
    "port",
    &PORT
);

๐Ÿ”ง Shared Fixed Assignment

Arg::rw_set(
    None,
    "--production",
    true,
    &MODE
);

๐Ÿ” Parsing

Parsing in flexiargs is explicit, deterministic, and fully rule-driven. Each step of the parsing process is defined by clear rules that transform raw command-line input into structured, validated, and typed data. This makes behavior predictable, easier to debug, and consistent across different CLI designs.

๐Ÿ“ฅ Basic Parsing

parse_into_vars(
    "server",
    &mut rules,
    args
).ok()?;

๐Ÿ“ฆ ParseResult

The parser returns a ParseResult.

This provides:

  • โœ… Parsing success/failure;
  • ๐Ÿ“ฆ Unmatched arguments;
  • ๐Ÿ“ Positional handling;
  • ๐Ÿ”’ Strict validation helpers;

โœ… .ok()

Extracts the parsing result.

parse_into_vars("app", &mut rules, args)
    .ok()?;

๐Ÿ”’ .strict()

Rejects any unmatched arguments.

parse_into_vars("app", &mut rules, args)
    .strict()
    .ok()?;

๐Ÿฅ‡ .strict_first()

Ensures the first argument matches a rule.

.strict_first()

๐Ÿ“ .strict_level(n)

Rejects unmatched arguments up to a given depth.

.strict_level(2)

๐Ÿชถ .passthrough()

Suppresses parsing errors.

Useful for optional parsing stages.

.passthrough()

๐Ÿ“Œ .require_args()

Fails if no arguments were supplied.

.require_args()?

๐Ÿ“ฆ .collect_rest()

Collects unmatched positional arguments.

let mut remaining = Vec::new();

parse_into_vars("app", &mut rules, args)
    .collect_rest(&mut remaining)?;

๐Ÿ“ Positional Arguments

The parser supports -- to stop option parsing.

๐Ÿงช Example

myapp --verbose -- file1 file2

Everything after -- becomes positional data.

โš ๏ธ Error Messages

flexiargs provides standardized and human-readable errors automatically.

โŒ Invalid arguments

myapp: invalid argument '--unknown'
Use 'myapp --help' to see available options.

โŒ Missing values

myapp: setup: --port requires a <port>.
Usage: myapp setup --port <port>

๐ŸŽฏ Argument Matching

Rules in flexiargs define how input tokens are interpreted and matched against declared CLI arguments. This matching system is flexible but explicit, allowing multiple naming styles and aliasing strategies while keeping behavior predictable and rule-based. Rules support:

  • ๐Ÿ”ค Short flags;
  • ๐Ÿท๏ธ Long flags;
  • ๐Ÿ”€ Aliases via |;
  • ๐Ÿงท Inline assignment;

๐Ÿงช Example

Arg::bool(
    Some("-v"),
    "--verbose|--debug",
    &mut verbose
);

โœ… Support

  • -v
  • --verbose
  • --debug

Argument matching in flexiargs is designed to be both flexible and explicit. Instead of enforcing a single naming convention, it allows multiple identifiers and aliases per argument while keeping resolution deterministic and rule-based.

๐Ÿค Contributing

Contributions, improvements, and issue reports are welcome.

๐Ÿšง Possible Future Extensions

  • ๐Ÿค– Auto-help generation
  • ๐ŸŒŽ Environment variable integration
  • ๐Ÿš Shell completion generation

๐Ÿ“œ MIT License

This repository has scripts created to be free software.
Therefore, they can be distributed and/or modified within the terms of the MIT License.

See the MIT License file for details.

๐Ÿ“ฌ Contact & Support