aboutsummaryrefslogtreecommitdiff
path: root/source/Commands/CommandObjectDisassemble.h
diff options
context:
space:
mode:
Diffstat (limited to 'source/Commands/CommandObjectDisassemble.h')
-rw-r--r--source/Commands/CommandObjectDisassemble.h120
1 files changed, 53 insertions, 67 deletions
diff --git a/source/Commands/CommandObjectDisassemble.h b/source/Commands/CommandObjectDisassemble.h
index ef19b3cf316a..db89aa24d6a0 100644
--- a/source/Commands/CommandObjectDisassemble.h
+++ b/source/Commands/CommandObjectDisassemble.h
@@ -24,78 +24,64 @@ namespace lldb_private {
// CommandObjectDisassemble
//-------------------------------------------------------------------------
-class CommandObjectDisassemble : public CommandObjectParsed
-{
+class CommandObjectDisassemble : public CommandObjectParsed {
public:
- class CommandOptions : public Options
- {
- public:
- CommandOptions (CommandInterpreter &interpreter);
-
- ~CommandOptions() override;
-
- Error
- SetOptionValue(uint32_t option_idx, const char *option_arg) override;
-
- void
- OptionParsingStarting() override;
-
- const OptionDefinition*
- GetDefinitions() override;
-
- const char *
- GetPluginName ()
- {
- return (plugin_name.empty() ? nullptr : plugin_name.c_str());
- }
-
- const char *
- GetFlavorString ()
- {
- if (flavor_string.empty() || flavor_string == "default")
- return nullptr;
- return flavor_string.c_str();
- }
-
- Error
- OptionParsingFinished() override;
-
- bool show_mixed; // Show mixed source/assembly
- bool show_bytes;
- uint32_t num_lines_context;
- uint32_t num_instructions;
- bool raw;
- std::string func_name;
- bool current_function;
- lldb::addr_t start_addr;
- lldb::addr_t end_addr;
- bool at_pc;
- bool frame_line;
- std::string plugin_name;
- std::string flavor_string;
- ArchSpec arch;
- bool some_location_specified; // If no location was specified, we'll select "at_pc". This should be set
- // in SetOptionValue if anything the selects a location is set.
- lldb::addr_t symbol_containing_addr;
- static OptionDefinition g_option_table[];
- };
-
- CommandObjectDisassemble (CommandInterpreter &interpreter);
-
- ~CommandObjectDisassemble() override;
-
- Options *
- GetOptions() override
- {
- return &m_options;
+ class CommandOptions : public Options {
+ public:
+ CommandOptions();
+
+ ~CommandOptions() override;
+
+ Error SetOptionValue(uint32_t option_idx, llvm::StringRef option_arg,
+ ExecutionContext *execution_context) override;
+
+ void OptionParsingStarting(ExecutionContext *execution_context) override;
+
+ llvm::ArrayRef<OptionDefinition> GetDefinitions() override;
+
+ const char *GetPluginName() {
+ return (plugin_name.empty() ? nullptr : plugin_name.c_str());
+ }
+
+ const char *GetFlavorString() {
+ if (flavor_string.empty() || flavor_string == "default")
+ return nullptr;
+ return flavor_string.c_str();
}
+ Error OptionParsingFinished(ExecutionContext *execution_context) override;
+
+ bool show_mixed; // Show mixed source/assembly
+ bool show_bytes;
+ uint32_t num_lines_context;
+ uint32_t num_instructions;
+ bool raw;
+ std::string func_name;
+ bool current_function;
+ lldb::addr_t start_addr;
+ lldb::addr_t end_addr;
+ bool at_pc;
+ bool frame_line;
+ std::string plugin_name;
+ std::string flavor_string;
+ ArchSpec arch;
+ bool some_location_specified; // If no location was specified, we'll select
+ // "at_pc". This should be set
+ // in SetOptionValue if anything the selects a location is set.
+ lldb::addr_t symbol_containing_addr;
+ static OptionDefinition g_option_table[];
+ };
+
+ CommandObjectDisassemble(CommandInterpreter &interpreter);
+
+ ~CommandObjectDisassemble() override;
+
+ Options *GetOptions() override { return &m_options; }
+
protected:
- bool
- DoExecute(Args& command,
- CommandReturnObject &result) override;
+ bool DoExecute(Args &command, CommandReturnObject &result) override;
- CommandOptions m_options;
+ CommandOptions m_options;
};
} // namespace lldb_private