diff options
Diffstat (limited to 'lldb/source/Interpreter/OptionGroupBoolean.cpp')
-rw-r--r-- | lldb/source/Interpreter/OptionGroupBoolean.cpp | 23 |
1 files changed, 16 insertions, 7 deletions
diff --git a/lldb/source/Interpreter/OptionGroupBoolean.cpp b/lldb/source/Interpreter/OptionGroupBoolean.cpp index f5403cfb992..58ac0f1def8 100644 --- a/lldb/source/Interpreter/OptionGroupBoolean.cpp +++ b/lldb/source/Interpreter/OptionGroupBoolean.cpp @@ -21,20 +21,19 @@ OptionGroupBoolean::OptionGroupBoolean (uint32_t usage_mask, bool required, const char *long_option, char short_option, - uint32_t completion_type, - lldb::CommandArgumentType argument_type, const char *usage_text, - bool default_value) : + bool default_value, + bool no_argument_toggle_default) : m_value (default_value, default_value) { m_option_definition.usage_mask = usage_mask; m_option_definition.required = required; m_option_definition.long_option = long_option; m_option_definition.short_option = short_option; - m_option_definition.option_has_arg = required_argument; + m_option_definition.option_has_arg = no_argument_toggle_default ? no_argument : required_argument; m_option_definition.enum_values = NULL; - m_option_definition.completion_type = completion_type; - m_option_definition.argument_type = argument_type; + m_option_definition.completion_type = 0; + m_option_definition.argument_type = eArgTypeBoolean; m_option_definition.usage_text = usage_text; } @@ -47,7 +46,17 @@ OptionGroupBoolean::SetOptionValue (CommandInterpreter &interpreter, uint32_t option_idx, const char *option_arg) { - Error error (m_value.SetValueFromCString (option_arg)); + Error error; + if (m_option_definition.option_has_arg == no_argument) + { + // Not argument, toggle the default value and mark the option as having been set + m_value.SetCurrentValue (!m_value.GetDefaultValue()); + m_value.SetOptionWasSet (); + } + else + { + error = m_value.SetValueFromCString (option_arg); + } return error; } |