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