Skip to content

Commit

Permalink
fix!: Remove ColorAuto & ColorNever settings, fixes #2811
Browse files Browse the repository at this point in the history
  • Loading branch information
pksunkara committed Oct 11, 2021
1 parent 937d76a commit 8283a0b
Show file tree
Hide file tree
Showing 4 changed files with 12 additions and 60 deletions.
9 changes: 4 additions & 5 deletions src/build/app/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -985,7 +985,7 @@ impl<'help> App<'help> {
/// ```no_run
/// # use clap::{App, AppSettings};
/// App::new("myprog")
/// .unset_global_setting(AppSettings::ColorAuto)
/// .unset_global_setting(AppSettings::UnifiedHelpMessage)
/// # ;
/// ```
/// [global]: App::global_setting()
Expand Down Expand Up @@ -2650,13 +2650,12 @@ impl<'help> App<'help> {
pub(crate) fn get_color(&self) -> ColorChoice {
debug!("App::color: Color setting...");

if self.is_set(AppSettings::ColorNever) {
debug!("Never");
ColorChoice::Never
} else if self.is_set(AppSettings::ColorAlways) {
if cfg!(feature = "color") && self.is_set(AppSettings::ColorAlways) {
debug!("Always");
ColorChoice::Always
} else {
// Same behaviour as `ColorChoice::Never` when `color` feature
// is turned off
debug!("Auto");
ColorChoice::Auto
}
Expand Down
60 changes: 7 additions & 53 deletions src/build/app/settings.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,9 +26,8 @@ bitflags! {
const NO_POS_VALUES = 1 << 17;
const NEXT_LINE_HELP = 1 << 18;
const DERIVE_DISP_ORDER = 1 << 19;
#[cfg(feature = "color")]
const COLOR_ALWAYS = 1 << 21;
const COLOR_AUTO = 1 << 22;
const COLOR_NEVER = 1 << 23;
const DONT_DELIM_TRAIL = 1 << 24;
const ALLOW_NEG_NUMS = 1 << 25;
const DISABLE_HELP_SC = 1 << 27;
Expand Down Expand Up @@ -58,7 +57,7 @@ pub struct AppFlags(Flags);

impl Default for AppFlags {
fn default() -> Self {
AppFlags(Flags::COLOR_AUTO)
Self::empty()
}
}

Expand All @@ -79,12 +78,9 @@ impl_settings! { AppSettings, AppFlags,
=> Flags::ALLOW_NEG_NUMS,
AllowMissingPositional("allowmissingpositional")
=> Flags::ALLOW_MISSING_POS,
#[cfg(feature = "color")]
ColorAlways("coloralways")
=> Flags::COLOR_ALWAYS,
ColorAuto("colorauto")
=> Flags::COLOR_AUTO,
ColorNever("colornever")
=> Flags::COLOR_NEVER,
DontDelimitTrailingValues("dontdelimittrailingvalues")
=> Flags::DONT_DELIM_TRAIL,
DontCollapseArgsInUsage("dontcollapseargsinusage")
Expand Down Expand Up @@ -490,27 +486,9 @@ pub enum AppSettings {
/// ```
SubcommandPrecedenceOverArg,

/// Enables colored output only when the output is going to a terminal or TTY.
/// Enables colored output regardless of whether or not the output is going to a terminal or TTY.
///
/// **NOTE:** This is the default behavior of `clap`.
///
/// **NOTE:** Must be compiled with the `color` cargo feature.
///
/// # Platform Specific
///
/// This setting only applies to Unix, Linux, and OSX (i.e. non-Windows platforms).
///
/// # Examples
///
/// ```no_run
/// # use clap::{App, Arg, AppSettings};
/// App::new("myprog")
/// .setting(AppSettings::ColorAuto)
/// .get_matches();
/// ```
ColorAuto,

/// Enables colored output regardless of whether or not the output is going to a terminal/TTY.
/// By default, output is colored only when it is going to terminal or TTY.
///
/// **NOTE:** Must be compiled with the `color` cargo feature.
///
Expand All @@ -526,26 +504,9 @@ pub enum AppSettings {
/// .setting(AppSettings::ColorAlways)
/// .get_matches();
/// ```
#[cfg(feature = "color")]
ColorAlways,

/// Disables colored output no matter if the output is going to a terminal/TTY, or not.
///
/// **NOTE:** Must be compiled with the `color` cargo feature
///
/// # Platform Specific
///
/// This setting only applies to Unix, Linux, and OSX (i.e. non-Windows platforms)
///
/// # Examples
///
/// ```no_run
/// # use clap::{App, Arg, AppSettings};
/// App::new("myprog")
/// .setting(AppSettings::ColorNever)
/// .get_matches();
/// ```
ColorNever,

/// Disables the automatic collapsing of positional args into `[ARGS]` inside the usage string
///
/// # Examples
Expand Down Expand Up @@ -1085,18 +1046,11 @@ mod test {
"allownegativenumbers".parse::<AppSettings>().unwrap(),
AppSettings::AllowNegativeNumbers
);
assert_eq!(
"colorauto".parse::<AppSettings>().unwrap(),
AppSettings::ColorAuto
);
#[cfg(feature = "color")]
assert_eq!(
"coloralways".parse::<AppSettings>().unwrap(),
AppSettings::ColorAlways
);
assert_eq!(
"colornever".parse::<AppSettings>().unwrap(),
AppSettings::ColorNever
);
assert_eq!(
"disablehelpsubcommand".parse::<AppSettings>().unwrap(),
AppSettings::DisableHelpSubcommand
Expand Down
1 change: 0 additions & 1 deletion tests/help.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2254,7 +2254,6 @@ fn option_usage_order() {
#[test]
fn about_in_subcommands_list() {
let app = App::new("about-in-subcommands-list")
.setting(AppSettings::ColorNever)
.subcommand(
App::new("sub")
.long_about("long about sub")
Expand Down
2 changes: 1 addition & 1 deletion tests/macros.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ fn basic() {
(version: "0.1")
(about: "tests clap library")
(author: "Kevin K. <kbknapp@gmail.com>")
(@global_setting ColorNever)
(@global_setting UnifiedHelpMessage)
(@arg opt: -o --option +takes_value ... "tests options")
(@arg positional: index(1) "tests positionals")
(@arg flag: -f --flag ... +global "tests flags")
Expand Down

0 comments on commit 8283a0b

Please sign in to comment.