aboutsummaryrefslogtreecommitdiff
path: root/include/lldb/Interpreter/OptionValueArray.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/lldb/Interpreter/OptionValueArray.h')
-rw-r--r--include/lldb/Interpreter/OptionValueArray.h238
1 files changed, 99 insertions, 139 deletions
diff --git a/include/lldb/Interpreter/OptionValueArray.h b/include/lldb/Interpreter/OptionValueArray.h
index 38b9e3c3ee97..1e568cac402d 100644
--- a/include/lldb/Interpreter/OptionValueArray.h
+++ b/include/lldb/Interpreter/OptionValueArray.h
@@ -20,156 +20,116 @@
namespace lldb_private {
-class OptionValueArray : public OptionValue
-{
+class OptionValueArray : public OptionValue {
public:
- OptionValueArray (uint32_t type_mask = UINT32_MAX, bool raw_value_dump = false) :
- m_type_mask (type_mask),
- m_values (),
- m_raw_value_dump(raw_value_dump)
- {
- }
-
- ~OptionValueArray() override
- {
- }
-
- //---------------------------------------------------------------------
- // Virtual subclass pure virtual overrides
- //---------------------------------------------------------------------
-
- OptionValue::Type
- GetType() const override
- {
- return eTypeArray;
+ OptionValueArray(uint32_t type_mask = UINT32_MAX, bool raw_value_dump = false)
+ : m_type_mask(type_mask), m_values(), m_raw_value_dump(raw_value_dump) {}
+
+ ~OptionValueArray() override {}
+
+ //---------------------------------------------------------------------
+ // Virtual subclass pure virtual overrides
+ //---------------------------------------------------------------------
+
+ OptionValue::Type GetType() const override { return eTypeArray; }
+
+ void DumpValue(const ExecutionContext *exe_ctx, Stream &strm,
+ uint32_t dump_mask) override;
+
+ Error
+ SetValueFromString(llvm::StringRef value,
+ VarSetOperationType op = eVarSetOperationAssign) override;
+ Error
+ SetValueFromString(const char *,
+ VarSetOperationType = eVarSetOperationAssign) = delete;
+
+ bool Clear() override {
+ m_values.clear();
+ m_value_was_set = false;
+ return true;
+ }
+
+ lldb::OptionValueSP DeepCopy() const override;
+
+ bool IsAggregateValue() const override { return true; }
+
+ lldb::OptionValueSP GetSubValue(const ExecutionContext *exe_ctx,
+ llvm::StringRef name, bool will_modify,
+ Error &error) const override;
+
+ //---------------------------------------------------------------------
+ // Subclass specific functions
+ //---------------------------------------------------------------------
+
+ size_t GetSize() const { return m_values.size(); }
+
+ lldb::OptionValueSP operator[](size_t idx) const {
+ lldb::OptionValueSP value_sp;
+ if (idx < m_values.size())
+ value_sp = m_values[idx];
+ return value_sp;
+ }
+
+ lldb::OptionValueSP GetValueAtIndex(size_t idx) const {
+ lldb::OptionValueSP value_sp;
+ if (idx < m_values.size())
+ value_sp = m_values[idx];
+ return value_sp;
+ }
+
+ bool AppendValue(const lldb::OptionValueSP &value_sp) {
+ // Make sure the value_sp object is allowed to contain
+ // values of the type passed in...
+ if (value_sp && (m_type_mask & value_sp->GetTypeAsMask())) {
+ m_values.push_back(value_sp);
+ return true;
}
-
- void
- DumpValue(const ExecutionContext *exe_ctx, Stream &strm, uint32_t dump_mask) override;
-
- Error
- SetValueFromString(llvm::StringRef value,
- VarSetOperationType op = eVarSetOperationAssign) override;
-
- bool
- Clear() override
- {
- m_values.clear();
- m_value_was_set = false;
- return true;
+ return false;
+ }
+
+ bool InsertValue(size_t idx, const lldb::OptionValueSP &value_sp) {
+ // Make sure the value_sp object is allowed to contain
+ // values of the type passed in...
+ if (value_sp && (m_type_mask & value_sp->GetTypeAsMask())) {
+ if (idx < m_values.size())
+ m_values.insert(m_values.begin() + idx, value_sp);
+ else
+ m_values.push_back(value_sp);
+ return true;
}
-
- lldb::OptionValueSP
- DeepCopy() const override;
-
- bool
- IsAggregateValue() const override
- {
+ return false;
+ }
+
+ bool ReplaceValue(size_t idx, const lldb::OptionValueSP &value_sp) {
+ // Make sure the value_sp object is allowed to contain
+ // values of the type passed in...
+ if (value_sp && (m_type_mask & value_sp->GetTypeAsMask())) {
+ if (idx < m_values.size()) {
+ m_values[idx] = value_sp;
return true;
+ }
}
-
- lldb::OptionValueSP
- GetSubValue(const ExecutionContext *exe_ctx,
- const char *name,
- bool will_modify,
- Error &error) const override;
-
- //---------------------------------------------------------------------
- // Subclass specific functions
- //---------------------------------------------------------------------
-
- size_t
- GetSize () const
- {
- return m_values.size();
- }
+ return false;
+ }
- lldb::OptionValueSP
- operator[](size_t idx) const
- {
- lldb::OptionValueSP value_sp;
- if (idx < m_values.size())
- value_sp = m_values[idx];
- return value_sp;
+ bool DeleteValue(size_t idx) {
+ if (idx < m_values.size()) {
+ m_values.erase(m_values.begin() + idx);
+ return true;
}
+ return false;
+ }
- lldb::OptionValueSP
- GetValueAtIndex (size_t idx) const
- {
- lldb::OptionValueSP value_sp;
- if (idx < m_values.size())
- value_sp = m_values[idx];
- return value_sp;
- }
-
- bool
- AppendValue (const lldb::OptionValueSP &value_sp)
- {
- // Make sure the value_sp object is allowed to contain
- // values of the type passed in...
- if (value_sp && (m_type_mask & value_sp->GetTypeAsMask()))
- {
- m_values.push_back(value_sp);
- return true;
- }
- return false;
- }
-
- bool
- InsertValue (size_t idx, const lldb::OptionValueSP &value_sp)
- {
- // Make sure the value_sp object is allowed to contain
- // values of the type passed in...
- if (value_sp && (m_type_mask & value_sp->GetTypeAsMask()))
- {
- if (idx < m_values.size())
- m_values.insert(m_values.begin() + idx, value_sp);
- else
- m_values.push_back(value_sp);
- return true;
- }
- return false;
- }
+ size_t GetArgs(Args &args) const;
- bool
- ReplaceValue (size_t idx, const lldb::OptionValueSP &value_sp)
- {
- // Make sure the value_sp object is allowed to contain
- // values of the type passed in...
- if (value_sp && (m_type_mask & value_sp->GetTypeAsMask()))
- {
- if (idx < m_values.size())
- {
- m_values[idx] = value_sp;
- return true;
- }
- }
- return false;
- }
+ Error SetArgs(const Args &args, VarSetOperationType op);
- bool
- DeleteValue (size_t idx)
- {
- if (idx < m_values.size())
- {
- m_values.erase (m_values.begin() + idx);
- return true;
- }
- return false;
- }
-
- size_t
- GetArgs (Args &args) const;
-
- Error
- SetArgs (const Args &args, VarSetOperationType op);
-
protected:
- typedef std::vector<lldb::OptionValueSP> collection;
-
- uint32_t m_type_mask;
- collection m_values;
- bool m_raw_value_dump;
+ typedef std::vector<lldb::OptionValueSP> collection;
+
+ uint32_t m_type_mask;
+ collection m_values;
+ bool m_raw_value_dump;
};
} // namespace lldb_private