119625d8cSopenharmony_ci// Copyright ⓒ 2015-2016 Kevin B. Knapp and [`clap-rs` contributors](https://github.com/clap-rs/clap/graphs/contributors). 219625d8cSopenharmony_ci// Licensed under the MIT license 319625d8cSopenharmony_ci// (see LICENSE or <http://opensource.org/licenses/MIT>) All files in the project carrying such 419625d8cSopenharmony_ci// notice may not be copied, modified, or distributed except according to those terms. 519625d8cSopenharmony_ci 619625d8cSopenharmony_ci//! > **Command Line Argument Parser for Rust** 719625d8cSopenharmony_ci//! 819625d8cSopenharmony_ci//! Quick Links: 919625d8cSopenharmony_ci//! - Derive [tutorial][_derive::_tutorial] and [reference][_derive] 1019625d8cSopenharmony_ci//! - Builder [tutorial][_tutorial] and [reference](index.html) 1119625d8cSopenharmony_ci//! - [Cookbook][_cookbook] 1219625d8cSopenharmony_ci//! - [FAQ][_faq] 1319625d8cSopenharmony_ci//! - [Discussions](https://github.com/clap-rs/clap/discussions) 1419625d8cSopenharmony_ci//! 1519625d8cSopenharmony_ci//! ## Aspirations 1619625d8cSopenharmony_ci//! 1719625d8cSopenharmony_ci//! - Out of the box, users get a polished CLI experience 1819625d8cSopenharmony_ci//! - Including common argument behavior, help generation, suggested fixes for users, colored output, [shell completions](https://github.com/clap-rs/clap/tree/master/clap_complete), etc 1919625d8cSopenharmony_ci//! - Flexible enough to port your existing CLI interface 2019625d8cSopenharmony_ci//! - However, we won't necessarily streamline support for each use case 2119625d8cSopenharmony_ci//! - Reasonable parse performance 2219625d8cSopenharmony_ci//! - Resilient maintainership, including 2319625d8cSopenharmony_ci//! - Willing to break compatibility rather than batching up breaking changes in large releases 2419625d8cSopenharmony_ci//! - Leverage feature flags to keep to one active branch 2519625d8cSopenharmony_ci//! - Being under [WG-CLI](https://github.com/rust-cli/team/) to increase the bus factor 2619625d8cSopenharmony_ci//! - We follow semver and will wait about 6-9 months between major breaking changes 2719625d8cSopenharmony_ci//! - We will support the last two minor Rust releases (MSRV, currently 1.64.0) 2819625d8cSopenharmony_ci//! 2919625d8cSopenharmony_ci//! While these aspirations can be at odds with fast build times and low binary 3019625d8cSopenharmony_ci//! size, we will still strive to keep these reasonable for the flexibility you 3119625d8cSopenharmony_ci//! get. Check out the 3219625d8cSopenharmony_ci//! [argparse-benchmarks](https://github.com/rust-cli/argparse-benchmarks-rs) for 3319625d8cSopenharmony_ci//! CLI parsers optimized for other use cases. 3419625d8cSopenharmony_ci//! 3519625d8cSopenharmony_ci//! ## Example 3619625d8cSopenharmony_ci//! 3719625d8cSopenharmony_ci//! Run 3819625d8cSopenharmony_ci//! ```console 3919625d8cSopenharmony_ci//! $ cargo add clap --features derive 4019625d8cSopenharmony_ci//! ``` 4119625d8cSopenharmony_ci//! *(See also [feature flag reference][_features])* 4219625d8cSopenharmony_ci//! 4319625d8cSopenharmony_ci//! Then define your CLI in `main.rs`: 4419625d8cSopenharmony_ci#![cfg_attr(not(feature = "derive"), doc = " ```ignore")] 4519625d8cSopenharmony_ci#![cfg_attr(feature = "derive", doc = " ```no_run")] 4619625d8cSopenharmony_ci#![doc = include_str!("../examples/demo.rs")] 4719625d8cSopenharmony_ci//! ``` 4819625d8cSopenharmony_ci//! 4919625d8cSopenharmony_ci//! And try it out: 5019625d8cSopenharmony_ci#![doc = include_str!("../examples/demo.md")] 5119625d8cSopenharmony_ci//! 5219625d8cSopenharmony_ci//! See also the derive [tutorial][_derive::_tutorial] and [reference][_derive] 5319625d8cSopenharmony_ci//! 5419625d8cSopenharmony_ci//! ### Related Projects 5519625d8cSopenharmony_ci//! 5619625d8cSopenharmony_ci//! Augment clap: 5719625d8cSopenharmony_ci//! - [wild](https://crates.io/crates/wild) for supporting wildcards (`*`) on Windows like you do Linux 5819625d8cSopenharmony_ci//! - [argfile](https://crates.io/crates/argfile) for loading additional arguments from a file (aka response files) 5919625d8cSopenharmony_ci//! - [shadow-rs](https://crates.io/crates/shadow-rs) for generating `Command::long_version` 6019625d8cSopenharmony_ci//! - [clap_mangen](https://crates.io/crates/clap_mangen) for generating man page source (roff) 6119625d8cSopenharmony_ci//! - [clap_complete](https://crates.io/crates/clap_complete) for shell completion support 6219625d8cSopenharmony_ci//! 6319625d8cSopenharmony_ci//! CLI Helpers 6419625d8cSopenharmony_ci//! - [clap-verbosity-flag](https://crates.io/crates/clap-verbosity-flag) 6519625d8cSopenharmony_ci//! - [clap-cargo](https://crates.io/crates/clap-cargo) 6619625d8cSopenharmony_ci//! - [concolor-clap](https://crates.io/crates/concolor-clap) 6719625d8cSopenharmony_ci//! 6819625d8cSopenharmony_ci//! Testing 6919625d8cSopenharmony_ci//! - [`trycmd`](https://crates.io/crates/trycmd): Bulk snapshot testing 7019625d8cSopenharmony_ci//! - [`snapbox`](https://crates.io/crates/snapbox): Specialized snapshot testing 7119625d8cSopenharmony_ci//! - [`assert_cmd`](https://crates.io/crates/assert_cmd) and [`assert_fs`](https://crates.io/crates/assert_fs): Customized testing 7219625d8cSopenharmony_ci//! 7319625d8cSopenharmony_ci//! Documentation: 7419625d8cSopenharmony_ci//! - [Command-line Apps for Rust](https://rust-cli.github.io/book/index.html) book 7519625d8cSopenharmony_ci//! 7619625d8cSopenharmony_ci 7719625d8cSopenharmony_ci#![cfg_attr(docsrs, feature(doc_auto_cfg))] 7819625d8cSopenharmony_ci#![doc(html_logo_url = "https://raw.githubusercontent.com/clap-rs/clap/master/assets/clap.png")] 7919625d8cSopenharmony_ci#![warn( 8019625d8cSopenharmony_ci missing_docs, 8119625d8cSopenharmony_ci missing_debug_implementations, 8219625d8cSopenharmony_ci missing_copy_implementations, 8319625d8cSopenharmony_ci trivial_casts, 8419625d8cSopenharmony_ci unused_allocation, 8519625d8cSopenharmony_ci trivial_numeric_casts, 8619625d8cSopenharmony_ci clippy::single_char_pattern 8719625d8cSopenharmony_ci)] 8819625d8cSopenharmony_ci#![forbid(unsafe_code)] 8919625d8cSopenharmony_ci// HACK https://github.com/rust-lang/rust-clippy/issues/7290 9019625d8cSopenharmony_ci#![allow(clippy::single_component_path_imports)] 9119625d8cSopenharmony_ci#![allow(clippy::branches_sharing_code)] 9219625d8cSopenharmony_ci// Doesn't allow for debug statements, etc to be unique 9319625d8cSopenharmony_ci#![allow(clippy::if_same_then_else)] 9419625d8cSopenharmony_ci// Breaks up parallelism that clarifies intent 9519625d8cSopenharmony_ci#![allow(clippy::collapsible_else_if)] 9619625d8cSopenharmony_ci 9719625d8cSopenharmony_ci#[cfg(not(feature = "std"))] 9819625d8cSopenharmony_cicompile_error!("`std` feature is currently required to build `clap`"); 9919625d8cSopenharmony_ci 10019625d8cSopenharmony_cipub use crate::builder::ArgAction; 10119625d8cSopenharmony_cipub use crate::builder::Command; 10219625d8cSopenharmony_cipub use crate::builder::ValueHint; 10319625d8cSopenharmony_cipub use crate::builder::{Arg, ArgGroup}; 10419625d8cSopenharmony_cipub use crate::parser::ArgMatches; 10519625d8cSopenharmony_cipub use crate::util::color::ColorChoice; 10619625d8cSopenharmony_cipub use crate::util::Id; 10719625d8cSopenharmony_ci 10819625d8cSopenharmony_ci/// Command Line Argument Parser Error 10919625d8cSopenharmony_ci/// 11019625d8cSopenharmony_ci/// See [`Command::error`] to create an error. 11119625d8cSopenharmony_ci/// 11219625d8cSopenharmony_ci/// [`Command::error`]: crate::Command::error 11319625d8cSopenharmony_cipub type Error = crate::error::Error<crate::error::DefaultFormatter>; 11419625d8cSopenharmony_ci 11519625d8cSopenharmony_cipub use crate::derive::{Args, CommandFactory, FromArgMatches, Parser, Subcommand, ValueEnum}; 11619625d8cSopenharmony_ci 11719625d8cSopenharmony_ci#[cfg(feature = "derive")] 11819625d8cSopenharmony_ci#[doc(hidden)] 11919625d8cSopenharmony_cipub use clap_derive::{self, *}; 12019625d8cSopenharmony_ci 12119625d8cSopenharmony_ci#[cfg(feature = "unstable-doc")] 12219625d8cSopenharmony_cipub mod _cookbook; 12319625d8cSopenharmony_ci#[cfg(feature = "unstable-doc")] 12419625d8cSopenharmony_cipub mod _derive; 12519625d8cSopenharmony_ci#[cfg(feature = "unstable-doc")] 12619625d8cSopenharmony_cipub mod _faq; 12719625d8cSopenharmony_ci#[cfg(feature = "unstable-doc")] 12819625d8cSopenharmony_cipub mod _features; 12919625d8cSopenharmony_ci#[cfg(feature = "unstable-doc")] 13019625d8cSopenharmony_cipub mod _tutorial; 13119625d8cSopenharmony_ci 13219625d8cSopenharmony_ci#[doc(hidden)] 13319625d8cSopenharmony_cipub mod __macro_refs { 13419625d8cSopenharmony_ci #[cfg(any(feature = "derive", feature = "cargo"))] 13519625d8cSopenharmony_ci #[doc(hidden)] 13619625d8cSopenharmony_ci pub use once_cell; 13719625d8cSopenharmony_ci} 13819625d8cSopenharmony_ci 13919625d8cSopenharmony_ci#[macro_use] 14019625d8cSopenharmony_ci#[allow(missing_docs)] 14119625d8cSopenharmony_cimod macros; 14219625d8cSopenharmony_ci 14319625d8cSopenharmony_cimod derive; 14419625d8cSopenharmony_ci 14519625d8cSopenharmony_cipub mod builder; 14619625d8cSopenharmony_cipub mod error; 14719625d8cSopenharmony_cipub mod parser; 14819625d8cSopenharmony_ci 14919625d8cSopenharmony_cimod mkeymap; 15019625d8cSopenharmony_cimod output; 15119625d8cSopenharmony_cimod util; 15219625d8cSopenharmony_ci 15319625d8cSopenharmony_ciconst INTERNAL_ERROR_MSG: &str = "Fatal internal error. Please consider filing a bug \ 15419625d8cSopenharmony_ci report at https://github.com/clap-rs/clap/issues"; 155