LLDB mainline
Classes | Public Member Functions | Static Public Member Functions | Protected Member Functions | Private Attributes | List of all members
CommandObjectScriptingObjectParsed Class Reference

This command implements a lldb parsed scripted command. More...

Inheritance diagram for CommandObjectScriptingObjectParsed:
Inheritance graph
[legend]

Classes

class  CommandOptions
 

Public Member Functions

 CommandObjectScriptingObjectParsed (CommandInterpreter &interpreter, std::string name, StructuredData::GenericSP cmd_obj_sp, ScriptedCommandSynchronicity synch)
 
 ~CommandObjectScriptingObjectParsed () override=default
 
Status GetOptionsError ()
 
Status GetArgsError ()
 
bool WantsCompletion () override
 
bool IsRemovable () const override
 
ScriptedCommandSynchronicity GetSynchronicity ()
 
std::optional< std::string > GetRepeatCommand (Args &args, uint32_t index) override
 Get the command that appropriate for a "repeat" of the current command.
 
llvm::StringRef GetHelp () override
 
llvm::StringRef GetHelpLong () override
 
OptionsGetOptions () override
 
- Public Member Functions inherited from lldb_private::CommandObjectParsed
 CommandObjectParsed (CommandInterpreter &interpreter, const char *name, const char *help=nullptr, const char *syntax=nullptr, uint32_t flags=0)
 
 ~CommandObjectParsed () override=default
 
void Execute (const char *args_string, CommandReturnObject &result) override
 
- Public Member Functions inherited from lldb_private::CommandObject
 CommandObject (CommandInterpreter &interpreter, llvm::StringRef name, llvm::StringRef help="", llvm::StringRef syntax="", uint32_t flags=0)
 
virtual ~CommandObject ()=default
 
CommandInterpreterGetCommandInterpreter ()
 
DebuggerGetDebugger ()
 
virtual llvm::StringRef GetHelp ()
 
virtual llvm::StringRef GetHelpLong ()
 
virtual llvm::StringRef GetSyntax ()
 
llvm::StringRef GetCommandName () const
 
virtual void SetHelp (llvm::StringRef str)
 
virtual void SetHelpLong (llvm::StringRef str)
 
void SetSyntax (llvm::StringRef str)
 
virtual bool IsRemovable () const
 
virtual bool IsMultiwordObject ()
 
bool IsUserCommand ()
 
void SetIsUserCommand (bool is_user)
 
virtual CommandObjectMultiwordGetAsMultiwordCommand ()
 
virtual bool IsAlias ()
 
virtual bool IsDashDashCommand ()
 
virtual lldb::CommandObjectSP GetSubcommandSP (llvm::StringRef sub_cmd, StringList *matches=nullptr)
 
virtual lldb::CommandObjectSP GetSubcommandSPExact (llvm::StringRef sub_cmd)
 
virtual CommandObjectGetSubcommandObject (llvm::StringRef sub_cmd, StringList *matches=nullptr)
 
void FormatLongHelpText (Stream &output_strm, llvm::StringRef long_help)
 
void GenerateHelpText (CommandReturnObject &result)
 
virtual void GenerateHelpText (Stream &result)
 
virtual bool LoadSubCommand (llvm::StringRef cmd_name, const lldb::CommandObjectSP &command_obj)
 
virtual llvm::Error LoadUserSubcommand (llvm::StringRef cmd_name, const lldb::CommandObjectSP &command_obj, bool can_replace)
 
virtual bool WantsRawCommandString ()=0
 
virtual bool WantsCompletion ()
 
virtual OptionsGetOptions ()
 
void AddSimpleArgumentList (lldb::CommandArgumentType arg_type, ArgumentRepetitionType repetition_type=eArgRepeatPlain)
 
void AddIDsArgumentData (IDType type)
 
int GetNumArgumentEntries ()
 
CommandArgumentEntryGetArgumentEntryAtIndex (int idx)
 
void GetFormattedCommandArguments (Stream &str, uint32_t opt_set_mask=LLDB_OPT_SET_ALL)
 
bool ParseOptions (Args &args, CommandReturnObject &result)
 
void SetCommandName (llvm::StringRef name)
 
virtual void HandleCompletion (CompletionRequest &request)
 This default version handles calling option argument completions and then calls HandleArgumentCompletion if the cursor is on an argument, not an option.
 
virtual void HandleArgumentCompletion (CompletionRequest &request, OptionElementVector &opt_element_vector)
 The default version handles argument definitions that have only one argument type, and use one of the argument types that have an entry in the CommonCompletions.
 
bool HelpTextContainsWord (llvm::StringRef search_word, bool search_short_help=true, bool search_long_help=true, bool search_syntax=true, bool search_options=true)
 
FlagsGetFlags ()
 The flags accessor.
 
const FlagsGetFlags () const
 The flags const accessor.
 
virtual std::optional< std::string > GetRepeatCommand (Args &current_command_args, uint32_t index)
 Get the command that appropriate for a "repeat" of the current command.
 
bool HasOverrideCallback () const
 
void SetOverrideCallback (lldb::CommandOverrideCallback callback, void *baton)
 
void SetOverrideCallback (lldb_private::CommandOverrideCallbackWithResult callback, void *baton)
 
bool InvokeOverrideCallback (const char **argv, CommandReturnObject &result)
 
virtual void Execute (const char *args_string, CommandReturnObject &result)=0
 

Static Public Member Functions

static CommandObjectSP Create (CommandInterpreter &interpreter, std::string name, StructuredData::GenericSP cmd_obj_sp, ScriptedCommandSynchronicity synch, CommandReturnObject &result)
 
- Static Public Member Functions inherited from lldb_private::CommandObject
static const char * GetArgumentTypeAsCString (const lldb::CommandArgumentType arg_type)
 
static const char * GetArgumentDescriptionAsCString (const lldb::CommandArgumentType arg_type)
 
static lldb::CommandArgumentType LookupArgumentName (llvm::StringRef arg_name)
 
static const ArgumentTableEntryFindArgumentDataByType (lldb::CommandArgumentType arg_type)
 
static void GetArgumentHelp (Stream &str, lldb::CommandArgumentType arg_type, CommandInterpreter &interpreter)
 
static const char * GetArgumentName (lldb::CommandArgumentType arg_type)
 
static bool IsPairType (ArgumentRepetitionType arg_repeat_type)
 
static std::optional< ArgumentRepetitionTypeArgRepetitionFromString (llvm::StringRef string)
 

Protected Member Functions

void DoExecute (Args &args, CommandReturnObject &result) override
 
- Protected Member Functions inherited from lldb_private::CommandObjectParsed
virtual void DoExecute (Args &command, CommandReturnObject &result)=0
 
bool WantsRawCommandString () override
 
- Protected Member Functions inherited from lldb_private::CommandObject
bool ParseOptionsAndNotify (Args &args, CommandReturnObject &result, OptionGroupOptions &group_options, ExecutionContext &exe_ctx)
 
virtual const char * GetInvalidTargetDescription ()
 
virtual const char * GetInvalidProcessDescription ()
 
virtual const char * GetInvalidThreadDescription ()
 
virtual const char * GetInvalidFrameDescription ()
 
virtual const char * GetInvalidRegContextDescription ()
 
TargetGetDummyTarget ()
 
TargetGetTarget ()
 
ThreadGetDefaultThread ()
 
bool CheckRequirements (CommandReturnObject &result)
 Check the command to make sure anything required by this command is available.
 
void Cleanup ()
 

Private Attributes

StructuredData::GenericSP m_cmd_obj_sp
 
ScriptedCommandSynchronicity m_synchro
 
CommandOptions m_options
 
Status m_options_error
 
Status m_args_error
 
bool m_fetched_help_short: 1
 
bool m_fetched_help_long: 1
 

Additional Inherited Members

- Public Types inherited from lldb_private::CommandObject
enum  IDType { eBreakpointArgs = 0 , eWatchpointArgs = 1 }
 
typedef llvm::StringRef() ArgumentHelpCallbackFunction()
 
typedef std::vector< CommandArgumentDataCommandArgumentEntry
 
typedef std::map< std::string, lldb::CommandObjectSPCommandMap
 
- Protected Attributes inherited from lldb_private::CommandObject
CommandInterpreterm_interpreter
 
ExecutionContext m_exe_ctx
 
std::unique_lock< std::recursive_mutex > m_api_locker
 
std::string m_cmd_name
 
std::string m_cmd_help_short
 
std::string m_cmd_help_long
 
std::string m_cmd_syntax
 
Flags m_flags
 
std::vector< CommandArgumentEntrym_arguments
 
lldb::CommandOverrideCallback m_deprecated_command_override_callback
 
lldb_private::CommandOverrideCallbackWithResult m_command_override_callback
 
void * m_command_override_baton
 
bool m_is_user_command = false
 

Detailed Description

This command implements a lldb parsed scripted command.

The command provides a definition of the options and arguments, and a option value setting callback, and then the command's execution function gets passed just the parsed arguments. Note, implementing a command in Python using these base interfaces is a bit of a pain, but it is much easier to export this low level interface, and then make it nicer on the Python side, than to try to do that in a script language neutral way. So I've also added a base class in Python that provides a table-driven way of defining the options and arguments, which automatically fills the option values, making them available as properties in Python.

Definition at line 1236 of file CommandObjectCommands.cpp.

Constructor & Destructor Documentation

◆ CommandObjectScriptingObjectParsed()

CommandObjectScriptingObjectParsed::CommandObjectScriptingObjectParsed ( CommandInterpreter interpreter,
std::string  name,
StructuredData::GenericSP  cmd_obj_sp,
ScriptedCommandSynchronicity  synch 
)
inline

◆ ~CommandObjectScriptingObjectParsed()

CommandObjectScriptingObjectParsed::~CommandObjectScriptingObjectParsed ( )
overridedefault

Member Function Documentation

◆ Create()

static CommandObjectSP CommandObjectScriptingObjectParsed::Create ( CommandInterpreter interpreter,
std::string  name,
StructuredData::GenericSP  cmd_obj_sp,
ScriptedCommandSynchronicity  synch,
CommandReturnObject result 
)
inlinestatic

◆ DoExecute()

void CommandObjectScriptingObjectParsed::DoExecute ( Args args,
CommandReturnObject result 
)
inlineoverrideprotectedvirtual

◆ GetArgsError()

Status CommandObjectScriptingObjectParsed::GetArgsError ( )
inline

Definition at line 1840 of file CommandObjectCommands.cpp.

References m_args_error.

Referenced by Create().

◆ GetHelp()

llvm::StringRef CommandObjectScriptingObjectParsed::GetHelp ( )
inlineoverridevirtual

◆ GetHelpLong()

llvm::StringRef CommandObjectScriptingObjectParsed::GetHelpLong ( )
inlineoverridevirtual

◆ GetOptions()

Options * CommandObjectScriptingObjectParsed::GetOptions ( )
inlineoverridevirtual

◆ GetOptionsError()

Status CommandObjectScriptingObjectParsed::GetOptionsError ( )
inline

Definition at line 1839 of file CommandObjectCommands.cpp.

References m_options_error.

Referenced by Create().

◆ GetRepeatCommand()

std::optional< std::string > CommandObjectScriptingObjectParsed::GetRepeatCommand ( Args current_command_args,
uint32_t  index 
)
inlineoverridevirtual

Get the command that appropriate for a "repeat" of the current command.

Parameters
[in]current_command_argsThe command arguments.
[in]indexThis is for internal use - it is how the completion request is tracked in CommandObjectMultiword, and should otherwise be ignored.
Returns
std::nullopt if there is no special repeat command - it will use the current command line. Otherwise a std::string containing the command to be repeated. If the string is empty, the command won't be allow repeating.

Reimplemented from lldb_private::CommandObject.

Definition at line 1847 of file CommandObjectCommands.cpp.

References lldb_private::CommandObject::GetDebugger(), lldb_private::ScriptInterpreter::GetRepeatCommandForScriptedCommand(), lldb_private::Debugger::GetScriptInterpreter(), and m_cmd_obj_sp.

◆ GetSynchronicity()

ScriptedCommandSynchronicity CommandObjectScriptingObjectParsed::GetSynchronicity ( )
inline

Definition at line 1845 of file CommandObjectCommands.cpp.

References m_synchro.

◆ IsRemovable()

bool CommandObjectScriptingObjectParsed::IsRemovable ( ) const
inlineoverridevirtual

Reimplemented from lldb_private::CommandObject.

Definition at line 1843 of file CommandObjectCommands.cpp.

◆ WantsCompletion()

bool CommandObjectScriptingObjectParsed::WantsCompletion ( )
inlineoverridevirtual

Reimplemented from lldb_private::CommandObject.

Definition at line 1841 of file CommandObjectCommands.cpp.

Member Data Documentation

◆ m_args_error

Status CommandObjectScriptingObjectParsed::m_args_error
private

Definition at line 1924 of file CommandObjectCommands.cpp.

Referenced by CommandObjectScriptingObjectParsed(), and GetArgsError().

◆ m_cmd_obj_sp

StructuredData::GenericSP CommandObjectScriptingObjectParsed::m_cmd_obj_sp
private

Definition at line 1920 of file CommandObjectCommands.cpp.

Referenced by DoExecute(), GetHelp(), GetHelpLong(), and GetRepeatCommand().

◆ m_fetched_help_long

bool CommandObjectScriptingObjectParsed::m_fetched_help_long
private

Definition at line 1926 of file CommandObjectCommands.cpp.

Referenced by GetHelpLong().

◆ m_fetched_help_short

bool CommandObjectScriptingObjectParsed::m_fetched_help_short
private

Definition at line 1925 of file CommandObjectCommands.cpp.

Referenced by GetHelp().

◆ m_options

CommandOptions CommandObjectScriptingObjectParsed::m_options
private

Definition at line 1922 of file CommandObjectCommands.cpp.

Referenced by CommandObjectScriptingObjectParsed(), and GetOptions().

◆ m_options_error

Status CommandObjectScriptingObjectParsed::m_options_error
private

◆ m_synchro

ScriptedCommandSynchronicity CommandObjectScriptingObjectParsed::m_synchro
private

Definition at line 1921 of file CommandObjectCommands.cpp.

Referenced by DoExecute(), and GetSynchronicity().


The documentation for this class was generated from the following file: