diff options
Diffstat (limited to 'contrib/llvm-project/lldb/source/Interpreter/OptionGroupUInt64.cpp')
-rw-r--r-- | contrib/llvm-project/lldb/source/Interpreter/OptionGroupUInt64.cpp | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/contrib/llvm-project/lldb/source/Interpreter/OptionGroupUInt64.cpp b/contrib/llvm-project/lldb/source/Interpreter/OptionGroupUInt64.cpp new file mode 100644 index 000000000000..486941a7555a --- /dev/null +++ b/contrib/llvm-project/lldb/source/Interpreter/OptionGroupUInt64.cpp @@ -0,0 +1,45 @@ +//===-- OptionGroupUInt64.cpp ---------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#include "lldb/Interpreter/OptionGroupUInt64.h" + +#include "lldb/Host/OptionParser.h" + +using namespace lldb; +using namespace lldb_private; + +OptionGroupUInt64::OptionGroupUInt64(uint32_t usage_mask, bool required, + const char *long_option, int short_option, + uint32_t completion_type, + lldb::CommandArgumentType argument_type, + const char *usage_text, + uint64_t default_value) + : 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.validator = nullptr; + m_option_definition.option_has_arg = OptionParser::eRequiredArgument; + m_option_definition.enum_values = {}; + m_option_definition.completion_type = completion_type; + m_option_definition.argument_type = argument_type; + m_option_definition.usage_text = usage_text; +} + +Status OptionGroupUInt64::SetOptionValue(uint32_t option_idx, + llvm::StringRef option_arg, + ExecutionContext *execution_context) { + Status error(m_value.SetValueFromString(option_arg)); + return error; +} + +void OptionGroupUInt64::OptionParsingStarting( + ExecutionContext *execution_context) { + m_value.Clear(); +} |