LLDB mainline
Public Member Functions | Private Member Functions | Private Attributes | List of all members
lldb_private::CommandObjectDWIMPrint Class Reference

Implements dwim-print, a printing command that chooses the most direct, efficient, and resilient means of printing a given expression. More...

#include <CommandObjectDWIMPrint.h>

Inheritance diagram for lldb_private::CommandObjectDWIMPrint:
Inheritance graph
[legend]

Public Member Functions

 CommandObjectDWIMPrint (CommandInterpreter &interpreter)
 
 ~CommandObjectDWIMPrint () override=default
 
OptionsGetOptions () override
 
bool WantsCompletion () override
 
- Public Member Functions inherited from lldb_private::CommandObjectRaw
 CommandObjectRaw (CommandInterpreter &interpreter, llvm::StringRef name, llvm::StringRef help="", llvm::StringRef syntax="", uint32_t flags=0)
 
 ~CommandObjectRaw () 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
 

Private Member Functions

void DoExecute (llvm::StringRef command, CommandReturnObject &result) override
 

Private Attributes

OptionGroupOptions m_option_group
 
OptionGroupFormat m_format_options = lldb::eFormatDefault
 
OptionGroupValueObjectDisplay m_varobj_options
 
CommandObjectExpression::CommandOptions m_expr_options
 

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
 
- 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 inherited from lldb_private::CommandObjectRaw
virtual void DoExecute (llvm::StringRef 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 ()
 
TargetGetSelectedOrDummyTarget (bool prefer_dummy=false)
 
TargetGetSelectedTarget ()
 
TargetGetDummyTarget ()
 
ThreadGetDefaultThread ()
 
bool CheckRequirements (CommandReturnObject &result)
 Check the command to make sure anything required by this command is available.
 
void Cleanup ()
 
- 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

Implements dwim-print, a printing command that chooses the most direct, efficient, and resilient means of printing a given expression.

DWIM is an acronym for Do What I Mean. From Wikipedia, DWIM is described as:

‍attempt to anticipate what users intend to do, correcting trivial errors automatically rather than blindly executing users' explicit but potentially incorrect input

The dwim-print command serves as a single print command for users who don't yet know, or perfer not to know, the various lldb commands that can be used to print, and when to use them.

Definition at line 32 of file CommandObjectDWIMPrint.h.

Constructor & Destructor Documentation

◆ CommandObjectDWIMPrint()

CommandObjectDWIMPrint::CommandObjectDWIMPrint ( CommandInterpreter interpreter)

◆ ~CommandObjectDWIMPrint()

lldb_private::CommandObjectDWIMPrint::~CommandObjectDWIMPrint ( )
overridedefault

Member Function Documentation

◆ DoExecute()

void CommandObjectDWIMPrint::DoExecute ( llvm::StringRef  command,
CommandReturnObject result 
)
overrideprivatevirtual

Implements lldb_private::CommandObjectRaw.

Definition at line 53 of file CommandObjectDWIMPrint.cpp.

References lldb_private::CommandReturnObject::AppendErrorWithFormatv(), lldb_private::CommandReturnObject::AppendMessageWithFormatv(), lldb::eDWIMPrintVerbosityFull, lldb::eDWIMPrintVerbosityNone, lldb::eExpressionCompleted, lldb::eLanguageTypeObjC, lldb::eLanguageTypeSwift, lldb::eLanguageTypeUnknown, lldb_private::eLazyBoolCalculate, lldb_private::eLazyBoolYes, lldb::eReturnStatusSuccessFinishResult, lldb_private::Target::EvaluateExpression(), lldb_private::StackFrame::FindVariable(), lldb_private::OptionGroupValueObjectDisplay::GetAsDumpOptions(), lldb_private::ExecutionContext::GetBestExecutionContextScope(), lldb_private::CommandObject::GetDebugger(), lldb_private::CommandObject::GetDummyTarget(), lldb_private::Debugger::GetDWIMPrintVerbosity(), lldb_private::TargetProperties::GetEnableNotifyAboutFixIts(), lldb_private::CommandReturnObject::GetErrorStream(), lldb_private::CommandObjectExpression::CommandOptions::GetEvaluateExpressionOptions(), lldb_private::OptionGroupFormat::GetFormat(), lldb_private::ExecutionContext::GetFramePtr(), lldb_private::CommandReturnObject::GetOutputStream(), lldb_private::Target::GetPersistentExpressionStateForLanguage(), lldb_private::Target::GetPersistentVariable(), lldb_private::OptionsWithRaw::GetRawPart(), lldb_private::StreamString::GetString(), lldb_private::ExecutionContext::GetTargetPtr(), lldb_private::StackFrame::GuessLanguage(), lldb_private::UserExpression::kNoResult, lldb_private::CommandObjectExpression::CommandOptions::language, lldb_private::CommandObject::m_cmd_name, lldb_private::CommandObject::m_exe_ctx, m_expr_options, m_format_options, m_option_group, m_varobj_options, lldb_private::CommandObjectExpression::CommandOptions::m_verbosity, lldb_private::Options::NotifyOptionParsingStarting(), lldb_private::CommandObject::ParseOptionsAndNotify(), lldb_private::CommandReturnObject::SetError(), lldb_private::DumpValueObjectOptions::SetHideRootName(), lldb_private::CommandReturnObject::SetStatus(), lldb_private::EvaluateExpressionOptions::SetSuppressPersistentResult(), lldb_private::CommandObjectExpression::CommandOptions::ShouldSuppressResult(), lldb_private::CommandObjectExpression::CommandOptions::suppress_persistent_result, and lldb_private::OptionGroupValueObjectDisplay::use_objc.

◆ GetOptions()

Options * CommandObjectDWIMPrint::GetOptions ( )
overridevirtual

Reimplemented from lldb_private::CommandObject.

Definition at line 51 of file CommandObjectDWIMPrint.cpp.

References m_option_group.

◆ WantsCompletion()

bool lldb_private::CommandObjectDWIMPrint::WantsCompletion ( )
inlineoverridevirtual

Reimplemented from lldb_private::CommandObject.

Definition at line 40 of file CommandObjectDWIMPrint.h.

Member Data Documentation

◆ m_expr_options

CommandObjectExpression::CommandOptions lldb_private::CommandObjectDWIMPrint::m_expr_options
private

Definition at line 48 of file CommandObjectDWIMPrint.h.

Referenced by CommandObjectDWIMPrint(), and DoExecute().

◆ m_format_options

OptionGroupFormat lldb_private::CommandObjectDWIMPrint::m_format_options = lldb::eFormatDefault
private

Definition at line 46 of file CommandObjectDWIMPrint.h.

Referenced by CommandObjectDWIMPrint(), and DoExecute().

◆ m_option_group

OptionGroupOptions lldb_private::CommandObjectDWIMPrint::m_option_group
private

Definition at line 45 of file CommandObjectDWIMPrint.h.

Referenced by CommandObjectDWIMPrint(), DoExecute(), and GetOptions().

◆ m_varobj_options

OptionGroupValueObjectDisplay lldb_private::CommandObjectDWIMPrint::m_varobj_options
private

Definition at line 47 of file CommandObjectDWIMPrint.h.

Referenced by CommandObjectDWIMPrint(), and DoExecute().


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