LLDB mainline
OptionValueProperties.h
Go to the documentation of this file.
1//===-- OptionValueProperties.h ---------------------------------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
9#ifndef LLDB_INTERPRETER_OPTIONVALUEPROPERTIES_H
10#define LLDB_INTERPRETER_OPTIONVALUEPROPERTIES_H
11
12#include <vector>
13
18
19namespace lldb_private {
20class Properties;
21
23 : public Cloneable<OptionValueProperties, OptionValue>,
24 public std::enable_shared_from_this<OptionValueProperties> {
25public:
27
28 OptionValueProperties(llvm::StringRef name);
29
30 ~OptionValueProperties() override = default;
31
32 Type GetType() const override { return eTypeProperties; }
33
34 void Clear() override;
35
37 CreateLocalCopy(const Properties &global_properties);
38
40 DeepCopy(const lldb::OptionValueSP &new_parent) const override;
41
42 Status
43 SetValueFromString(llvm::StringRef value,
45
46 void DumpValue(const ExecutionContext *exe_ctx, Stream &strm,
47 uint32_t dump_mask) override;
48
49 bool IsDefault() const override;
50
51 llvm::json::Value ToJSON(const ExecutionContext *exe_ctx) const override;
52
53 llvm::StringRef GetName() const override { return m_name; }
54
55 virtual Status DumpPropertyValue(const ExecutionContext *exe_ctx,
56 Stream &strm, llvm::StringRef property_path,
57 uint32_t dump_mask, bool is_json = false);
58
59 virtual void DumpAllDescriptions(CommandInterpreter &interpreter,
60 Stream &strm) const;
61
62 void Apropos(llvm::StringRef keyword,
63 std::vector<const Property *> &matching_properties) const;
64
65 void Initialize(const PropertyCollectionDefinition &setting_definitions);
66
67 void SetExpectedPath(std::string path);
68
69 // Subclass specific functions
70
71 // Get the index of a property given its exact name in this property
72 // collection, "name" can't be a path to a property path that refers to a
73 // property within a property
74 virtual size_t GetPropertyIndex(llvm::StringRef name) const;
75
76 // Get a property by exact name exists in this property collection, name can
77 // not be a path to a property path that refers to a property within a
78 // property
79 virtual const Property *
80 GetProperty(llvm::StringRef name,
81 const ExecutionContext *exe_ctx = nullptr) const;
82
83 virtual const Property *
85 const ExecutionContext *exe_ctx = nullptr) const {
87 }
88
89 // Property can be a property path like
90 // "target.process.extra-startup-command"
91 virtual const Property *
93 llvm::StringRef property_path) const;
94
96 GetPropertyValueAtIndex(size_t idx, const ExecutionContext *exe_ctx) const;
97
99 llvm::StringRef key) const;
100
102 llvm::StringRef name,
103 Status &error) const override;
104
106 llvm::StringRef path, llvm::StringRef value) override;
107
108 bool
109 GetPropertyAtIndexAsArgs(size_t idx, Args &args,
110 const ExecutionContext *exe_ctx = nullptr) const;
111
112 bool SetPropertyAtIndexFromArgs(size_t idx, const Args &args,
113 const ExecutionContext *exe_ctx = nullptr);
114
116 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
117
119 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
120
122 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
123
125 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
126
128 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
129
131 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
132
134 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
135
136 void AppendProperty(llvm::StringRef name, llvm::StringRef desc,
137 bool is_global, const lldb::OptionValueSP &value_sp);
138
140 llvm::StringRef name);
141
142 void SetValueChangedCallback(size_t property_idx,
143 std::function<void()> callback);
144
145 template <typename T>
146 auto GetPropertyAtIndexAs(size_t idx,
147 const ExecutionContext *exe_ctx = nullptr) const {
148 if (const Property *property = GetPropertyAtIndex(idx, exe_ctx)) {
149 if (OptionValue *value = property->GetValue().get())
150 return value->GetValueAs<T>();
151 }
152 if constexpr (std::is_pointer_v<T>)
153 return T{nullptr};
154 else
155 return std::optional<T>{std::nullopt};
156 }
157
158 template <typename T>
159 bool SetPropertyAtIndex(size_t idx, T t,
160 const ExecutionContext *exe_ctx = nullptr) const {
161 if (const Property *property = GetPropertyAtIndex(idx, exe_ctx)) {
162 if (OptionValue *value = property->GetValue().get()) {
163 value->SetValueAs(t);
164 return true;
165 }
166 }
167 return false;
168 }
169
170protected:
172 assert(idx < m_properties.size() && "invalid property index");
173 return ((idx < m_properties.size()) ? &m_properties[idx] : nullptr);
174 }
175
176 const Property *ProtectedGetPropertyAtIndex(size_t idx) const {
177 assert(idx < m_properties.size() && "invalid property index");
178 return ((idx < m_properties.size()) ? &m_properties[idx] : nullptr);
179 }
180
181 bool VerifyPath();
182
183 std::string m_name;
184 std::vector<Property> m_properties;
185 llvm::StringMap<size_t> m_name_to_index;
186 std::string m_expected_path;
187};
188
189} // namespace lldb_private
190
191#endif // LLDB_INTERPRETER_OPTIONVALUEPROPERTIES_H
static llvm::raw_ostream & error(Stream &strm)
A command line argument class.
Definition Args.h:33
A class that implements CRTP-based "virtual constructor" idiom.
Definition Cloneable.h:40
"lldb/Target/ExecutionContext.h" A class that contains an execution context.
void AppendProperty(llvm::StringRef name, llvm::StringRef desc, bool is_global, const lldb::OptionValueSP &value_sp)
Status SetSubValue(const ExecutionContext *exe_ctx, VarSetOperationType op, llvm::StringRef path, llvm::StringRef value) override
OptionValueFileSpec * GetPropertyAtIndexAsOptionValueFileSpec(size_t idx, const ExecutionContext *exe_ctx=nullptr) const
auto GetPropertyAtIndexAs(size_t idx, const ExecutionContext *exe_ctx=nullptr) const
void Apropos(llvm::StringRef keyword, std::vector< const Property * > &matching_properties) const
void Initialize(const PropertyCollectionDefinition &setting_definitions)
bool IsDefault() const override
Return true if the current value equals the default value.
lldb::OptionValueSP DeepCopy(const lldb::OptionValueSP &new_parent) const override
void DumpValue(const ExecutionContext *exe_ctx, Stream &strm, uint32_t dump_mask) override
virtual void DumpAllDescriptions(CommandInterpreter &interpreter, Stream &strm) const
OptionValueFileSpecList * GetPropertyAtIndexAsOptionValueFileSpecList(size_t idx, const ExecutionContext *exe_ctx=nullptr) const
Property * ProtectedGetPropertyAtIndex(size_t idx)
OptionValueString * GetPropertyAtIndexAsOptionValueString(size_t idx, const ExecutionContext *exe_ctx=nullptr) const
bool SetPropertyAtIndex(size_t idx, T t, const ExecutionContext *exe_ctx=nullptr) const
virtual Status DumpPropertyValue(const ExecutionContext *exe_ctx, Stream &strm, llvm::StringRef property_path, uint32_t dump_mask, bool is_json=false)
OptionValueDictionary * GetPropertyAtIndexAsOptionValueDictionary(size_t idx, const ExecutionContext *exe_ctx=nullptr) const
llvm::StringRef GetName() const override
static lldb::OptionValuePropertiesSP CreateLocalCopy(const Properties &global_properties)
lldb::OptionValueSP GetSubValue(const ExecutionContext *exe_ctx, llvm::StringRef name, Status &error) const override
llvm::json::Value ToJSON(const ExecutionContext *exe_ctx) const override
void SetValueChangedCallback(size_t property_idx, std::function< void()> callback)
const Property * ProtectedGetPropertyAtIndex(size_t idx) const
bool SetPropertyAtIndexFromArgs(size_t idx, const Args &args, const ExecutionContext *exe_ctx=nullptr)
Status SetValueFromString(llvm::StringRef value, VarSetOperationType op=eVarSetOperationAssign) override
virtual const Property * GetPropertyAtPath(const ExecutionContext *exe_ctx, llvm::StringRef property_path) const
virtual const Property * GetPropertyAtIndex(size_t idx, const ExecutionContext *exe_ctx=nullptr) const
virtual lldb::OptionValueSP GetValueForKey(const ExecutionContext *exe_ctx, llvm::StringRef key) const
lldb::OptionValuePropertiesSP GetSubProperty(const ExecutionContext *exe_ctx, llvm::StringRef name)
virtual lldb::OptionValueSP GetPropertyValueAtIndex(size_t idx, const ExecutionContext *exe_ctx) const
OptionValueUInt64 * GetPropertyAtIndexAsOptionValueUInt64(size_t idx, const ExecutionContext *exe_ctx=nullptr) const
OptionValuePathMappings * GetPropertyAtIndexAsOptionValuePathMappings(size_t idx, const ExecutionContext *exe_ctx=nullptr) const
OptionValueSInt64 * GetPropertyAtIndexAsOptionValueSInt64(size_t idx, const ExecutionContext *exe_ctx=nullptr) const
virtual const Property * GetProperty(llvm::StringRef name, const ExecutionContext *exe_ctx=nullptr) const
bool GetPropertyAtIndexAsArgs(size_t idx, Args &args, const ExecutionContext *exe_ctx=nullptr) const
virtual size_t GetPropertyIndex(llvm::StringRef name) const
~OptionValueProperties() override=default
An error handling class.
Definition Status.h:118
A stream class that can stream formatted output to a file.
Definition Stream.h:28
A class that represents a running process on the host machine.
VarSetOperationType
Settable state variable types.
std::shared_ptr< lldb_private::OptionValueProperties > OptionValuePropertiesSP
std::shared_ptr< lldb_private::OptionValue > OptionValueSP