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 llvm::json::Value ToJSON(const ExecutionContext *exe_ctx) const override;
50
51 llvm::StringRef GetName() const override { return m_name; }
52
53 virtual Status DumpPropertyValue(const ExecutionContext *exe_ctx,
54 Stream &strm, llvm::StringRef property_path,
55 uint32_t dump_mask, bool is_json = false);
56
57 virtual void DumpAllDescriptions(CommandInterpreter &interpreter,
58 Stream &strm) const;
59
60 void Apropos(llvm::StringRef keyword,
61 std::vector<const Property *> &matching_properties) const;
62
63 void Initialize(const PropertyCollectionDefinition &setting_definitions);
64
65 void SetExpectedPath(std::string path);
66
67 // Subclass specific functions
68
69 // Get the index of a property given its exact name in this property
70 // collection, "name" can't be a path to a property path that refers to a
71 // property within a property
72 virtual size_t GetPropertyIndex(llvm::StringRef name) const;
73
74 // Get a property by exact name exists in this property collection, name can
75 // not be a path to a property path that refers to a property within a
76 // property
77 virtual const Property *
78 GetProperty(llvm::StringRef name,
79 const ExecutionContext *exe_ctx = nullptr) const;
80
81 virtual const Property *
83 const ExecutionContext *exe_ctx = nullptr) const {
85 }
86
87 // Property can be a property path like
88 // "target.process.extra-startup-command"
89 virtual const Property *
91 llvm::StringRef property_path) const;
92
94 GetPropertyValueAtIndex(size_t idx, const ExecutionContext *exe_ctx) const;
95
97 llvm::StringRef key) const;
98
100 llvm::StringRef name,
101 Status &error) const override;
102
104 llvm::StringRef path, llvm::StringRef value) override;
105
106 bool
107 GetPropertyAtIndexAsArgs(size_t idx, Args &args,
108 const ExecutionContext *exe_ctx = nullptr) const;
109
110 bool SetPropertyAtIndexFromArgs(size_t idx, const Args &args,
111 const ExecutionContext *exe_ctx = nullptr);
112
114 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
115
117 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
118
120 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
121
123 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
124
126 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
127
129 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
130
132 size_t idx, const ExecutionContext *exe_ctx = nullptr) const;
133
134 void AppendProperty(llvm::StringRef name, llvm::StringRef desc,
135 bool is_global, const lldb::OptionValueSP &value_sp);
136
138 llvm::StringRef name);
139
140 void SetValueChangedCallback(size_t property_idx,
141 std::function<void()> callback);
142
143 template <typename T>
144 auto GetPropertyAtIndexAs(size_t idx,
145 const ExecutionContext *exe_ctx = nullptr) const {
146 if (const Property *property = GetPropertyAtIndex(idx, exe_ctx)) {
147 if (OptionValue *value = property->GetValue().get())
148 return value->GetValueAs<T>();
149 }
150 if constexpr (std::is_pointer_v<T>)
151 return T{nullptr};
152 else
153 return std::optional<T>{std::nullopt};
154 }
155
156 template <typename T>
157 bool SetPropertyAtIndex(size_t idx, T t,
158 const ExecutionContext *exe_ctx = nullptr) const {
159 if (const Property *property = GetPropertyAtIndex(idx, exe_ctx)) {
160 if (OptionValue *value = property->GetValue().get()) {
161 value->SetValueAs(t);
162 return true;
163 }
164 }
165 return false;
166 }
167
168protected:
170 assert(idx < m_properties.size() && "invalid property index");
171 return ((idx < m_properties.size()) ? &m_properties[idx] : nullptr);
172 }
173
174 const Property *ProtectedGetPropertyAtIndex(size_t idx) const {
175 assert(idx < m_properties.size() && "invalid property index");
176 return ((idx < m_properties.size()) ? &m_properties[idx] : nullptr);
177 }
178
179 bool VerifyPath();
180
181 std::string m_name;
182 std::vector<Property> m_properties;
183 llvm::StringMap<size_t> m_name_to_index;
184 std::string m_expected_path;
185};
186
187} // namespace lldb_private
188
189#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)
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