• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Std
2 use std::ops::BitOr;
3 
4 // Third party
5 use bitflags::bitflags;
6 
7 #[allow(unused)]
8 use crate::Arg;
9 
10 #[derive(Debug, Clone, Copy, PartialEq, Eq)]
11 pub(crate) struct ArgFlags(Flags);
12 
13 impl Default for ArgFlags {
default() -> Self14     fn default() -> Self {
15         Self::empty()
16     }
17 }
18 
19 /// Various settings that apply to arguments and may be set, unset, and checked via getter/setter
20 /// methods [`Arg::setting`], [`Arg::unset_setting`], and [`Arg::is_set`]. This is what the
21 /// [`Arg`] methods which accept a `bool` use internally.
22 ///
23 /// [`Arg`]: crate::Arg
24 /// [`Arg::setting`]: crate::Arg::setting()
25 /// [`Arg::unset_setting`]: crate::Arg::unset_setting()
26 /// [`Arg::is_set`]: crate::Arg::is_set()
27 #[derive(Debug, PartialEq, Copy, Clone)]
28 #[non_exhaustive]
29 pub(crate) enum ArgSettings {
30     Required,
31     Global,
32     Hidden,
33     NextLineHelp,
34     HidePossibleValues,
35     AllowHyphenValues,
36     AllowNegativeNumbers,
37     RequireEquals,
38     Last,
39     TrailingVarArg,
40     HideDefaultValue,
41     IgnoreCase,
42     #[cfg(feature = "env")]
43     HideEnv,
44     #[cfg(feature = "env")]
45     HideEnvValues,
46     HiddenShortHelp,
47     HiddenLongHelp,
48     Exclusive,
49 }
50 
51 bitflags! {
52     struct Flags: u32 {
53         const REQUIRED         = 1;
54         const GLOBAL           = 1 << 3;
55         const HIDDEN           = 1 << 4;
56         const TRAILING_VARARG  = 1 << 5;
57         const ALLOW_NEG_NUMS   = 1 << 6;
58         const NEXT_LINE_HELP   = 1 << 7;
59         const DELIM_NOT_SET    = 1 << 10;
60         const HIDE_POS_VALS    = 1 << 11;
61         const ALLOW_TAC_VALS   = 1 << 12;
62         const REQUIRE_EQUALS   = 1 << 13;
63         const LAST             = 1 << 14;
64         const HIDE_DEFAULT_VAL = 1 << 15;
65         const CASE_INSENSITIVE = 1 << 16;
66         #[cfg(feature = "env")]
67         const HIDE_ENV_VALS    = 1 << 17;
68         const HIDDEN_SHORT_H   = 1 << 18;
69         const HIDDEN_LONG_H    = 1 << 19;
70         #[cfg(feature = "env")]
71         const HIDE_ENV         = 1 << 21;
72         const EXCLUSIVE        = 1 << 23;
73         const NO_OP            = 0;
74     }
75 }
76 
77 impl_settings! { ArgSettings, ArgFlags,
78     Required => Flags::REQUIRED,
79     Global => Flags::GLOBAL,
80     Hidden => Flags::HIDDEN,
81     NextLineHelp => Flags::NEXT_LINE_HELP,
82     HidePossibleValues => Flags::HIDE_POS_VALS,
83     AllowHyphenValues => Flags::ALLOW_TAC_VALS,
84     AllowNegativeNumbers => Flags::ALLOW_NEG_NUMS,
85     RequireEquals => Flags::REQUIRE_EQUALS,
86     Last => Flags::LAST,
87     TrailingVarArg => Flags::TRAILING_VARARG,
88     IgnoreCase => Flags::CASE_INSENSITIVE,
89     #[cfg(feature = "env")]
90     HideEnv => Flags::HIDE_ENV,
91     #[cfg(feature = "env")]
92     HideEnvValues => Flags::HIDE_ENV_VALS,
93     HideDefaultValue => Flags::HIDE_DEFAULT_VAL,
94     HiddenShortHelp => Flags::HIDDEN_SHORT_H,
95     HiddenLongHelp => Flags::HIDDEN_LONG_H,
96     Exclusive => Flags::EXCLUSIVE
97 }
98 
99 #[cfg(test)]
100 mod test {
101     use super::*;
102     use crate::Arg;
103 
104     #[test]
setting()105     fn setting() {
106         let m = Arg::new("setting").setting(ArgSettings::Required);
107         assert!(m.is_required_set());
108     }
109 
110     #[test]
unset_setting()111     fn unset_setting() {
112         let m = Arg::new("unset_setting").setting(ArgSettings::Required);
113         assert!(m.is_required_set());
114 
115         let m = m.unset_setting(ArgSettings::Required);
116         assert!(!m.is_required_set(), "{m:#?}");
117     }
118 
119     #[test]
setting_bitor()120     fn setting_bitor() {
121         let m = Arg::new("setting_bitor")
122             .setting(ArgSettings::Required | ArgSettings::Hidden | ArgSettings::Last);
123 
124         assert!(m.is_required_set());
125         assert!(m.is_hide_set());
126         assert!(m.is_last_set());
127     }
128 
129     #[test]
unset_setting_bitor()130     fn unset_setting_bitor() {
131         let m = Arg::new("unset_setting_bitor")
132             .setting(ArgSettings::Required)
133             .setting(ArgSettings::Hidden)
134             .setting(ArgSettings::Last);
135 
136         assert!(m.is_required_set());
137         assert!(m.is_hide_set());
138         assert!(m.is_last_set());
139 
140         let m = m.unset_setting(ArgSettings::Required | ArgSettings::Hidden | ArgSettings::Last);
141         assert!(!m.is_required_set(), "{m:#?}");
142         assert!(!m.is_hide_set(), "{m:#?}");
143         assert!(!m.is_last_set(), "{m:#?}");
144     }
145 }
146