130fdc8d8SChris Lattner //===-- CommandObjectFrame.cpp ----------------------------------*- C++ -*-===// 230fdc8d8SChris Lattner // 330fdc8d8SChris Lattner // The LLVM Compiler Infrastructure 430fdc8d8SChris Lattner // 530fdc8d8SChris Lattner // This file is distributed under the University of Illinois Open Source 630fdc8d8SChris Lattner // License. See LICENSE.TXT for details. 730fdc8d8SChris Lattner // 830fdc8d8SChris Lattner //===----------------------------------------------------------------------===// 930fdc8d8SChris Lattner 1030fdc8d8SChris Lattner #include "CommandObjectFrame.h" 1130fdc8d8SChris Lattner 1230fdc8d8SChris Lattner // C Includes 1330fdc8d8SChris Lattner // C++ Includes 14de6bd243SJohnny Chen #include <string> 1530fdc8d8SChris Lattner // Other libraries and framework includes 1630fdc8d8SChris Lattner // Project includes 175d043464SJohnny Chen #include "lldb/Breakpoint/WatchpointLocation.h" 180a976141SEnrico Granata #include "lldb/Core/DataVisualization.h" 1930fdc8d8SChris Lattner #include "lldb/Core/Debugger.h" 206d56d2ceSJim Ingham #include "lldb/Core/Module.h" 216d56d2ceSJim Ingham #include "lldb/Core/StreamFile.h" 22de6bd243SJohnny Chen #include "lldb/Core/StreamString.h" 2330fdc8d8SChris Lattner #include "lldb/Core/Timer.h" 246d56d2ceSJim Ingham #include "lldb/Core/Value.h" 256d56d2ceSJim Ingham #include "lldb/Core/ValueObject.h" 266d56d2ceSJim Ingham #include "lldb/Core/ValueObjectVariable.h" 277fb56d0aSGreg Clayton #include "lldb/Host/Host.h" 286d56d2ceSJim Ingham #include "lldb/Interpreter/Args.h" 2930fdc8d8SChris Lattner #include "lldb/Interpreter/CommandInterpreter.h" 3030fdc8d8SChris Lattner #include "lldb/Interpreter/CommandReturnObject.h" 316d56d2ceSJim Ingham #include "lldb/Interpreter/Options.h" 322837b766SJim Ingham #include "lldb/Interpreter/OptionGroupValueObjectDisplay.h" 33715c2365SGreg Clayton #include "lldb/Interpreter/OptionGroupVariable.h" 34b1d7529eSJohnny Chen #include "lldb/Interpreter/OptionGroupWatchpoint.h" 356d56d2ceSJim Ingham #include "lldb/Symbol/ClangASTType.h" 366d56d2ceSJim Ingham #include "lldb/Symbol/ClangASTContext.h" 376d56d2ceSJim Ingham #include "lldb/Symbol/ObjectFile.h" 386d56d2ceSJim Ingham #include "lldb/Symbol/SymbolContext.h" 396d56d2ceSJim Ingham #include "lldb/Symbol/Type.h" 406d56d2ceSJim Ingham #include "lldb/Symbol/Variable.h" 416d56d2ceSJim Ingham #include "lldb/Symbol/VariableList.h" 4230fdc8d8SChris Lattner #include "lldb/Target/Process.h" 4330fdc8d8SChris Lattner #include "lldb/Target/StackFrame.h" 4430fdc8d8SChris Lattner #include "lldb/Target/Thread.h" 456d56d2ceSJim Ingham #include "lldb/Target/Target.h" 4630fdc8d8SChris Lattner 4730fdc8d8SChris Lattner using namespace lldb; 4830fdc8d8SChris Lattner using namespace lldb_private; 4930fdc8d8SChris Lattner 5030fdc8d8SChris Lattner #pragma mark CommandObjectFrameInfo 5130fdc8d8SChris Lattner 5230fdc8d8SChris Lattner //------------------------------------------------------------------------- 5330fdc8d8SChris Lattner // CommandObjectFrameInfo 5430fdc8d8SChris Lattner //------------------------------------------------------------------------- 5530fdc8d8SChris Lattner 5630fdc8d8SChris Lattner class CommandObjectFrameInfo : public CommandObject 5730fdc8d8SChris Lattner { 5830fdc8d8SChris Lattner public: 5930fdc8d8SChris Lattner 60a7015092SGreg Clayton CommandObjectFrameInfo (CommandInterpreter &interpreter) : 61a7015092SGreg Clayton CommandObject (interpreter, 62a7015092SGreg Clayton "frame info", 63e3d26315SCaroline Tice "List information about the currently selected frame in the current thread.", 6430fdc8d8SChris Lattner "frame info", 6530fdc8d8SChris Lattner eFlagProcessMustBeLaunched | eFlagProcessMustBePaused) 6630fdc8d8SChris Lattner { 6730fdc8d8SChris Lattner } 6830fdc8d8SChris Lattner 6930fdc8d8SChris Lattner ~CommandObjectFrameInfo () 7030fdc8d8SChris Lattner { 7130fdc8d8SChris Lattner } 7230fdc8d8SChris Lattner 7330fdc8d8SChris Lattner bool 74a7015092SGreg Clayton Execute (Args& command, 7530fdc8d8SChris Lattner CommandReturnObject &result) 7630fdc8d8SChris Lattner { 778b82f087SGreg Clayton ExecutionContext exe_ctx(m_interpreter.GetExecutionContext()); 78c14ee32dSGreg Clayton StackFrame *frame = exe_ctx.GetFramePtr(); 79c14ee32dSGreg Clayton if (frame) 8030fdc8d8SChris Lattner { 81c14ee32dSGreg Clayton frame->DumpUsingSettingsFormat (&result.GetOutputStream()); 8230fdc8d8SChris Lattner result.SetStatus (eReturnStatusSuccessFinishResult); 8330fdc8d8SChris Lattner } 8430fdc8d8SChris Lattner else 8530fdc8d8SChris Lattner { 8630fdc8d8SChris Lattner result.AppendError ("no current frame"); 8730fdc8d8SChris Lattner result.SetStatus (eReturnStatusFailed); 8830fdc8d8SChris Lattner } 8930fdc8d8SChris Lattner return result.Succeeded(); 9030fdc8d8SChris Lattner } 9130fdc8d8SChris Lattner }; 9230fdc8d8SChris Lattner 9330fdc8d8SChris Lattner #pragma mark CommandObjectFrameSelect 9430fdc8d8SChris Lattner 9530fdc8d8SChris Lattner //------------------------------------------------------------------------- 9630fdc8d8SChris Lattner // CommandObjectFrameSelect 9730fdc8d8SChris Lattner //------------------------------------------------------------------------- 9830fdc8d8SChris Lattner 9930fdc8d8SChris Lattner class CommandObjectFrameSelect : public CommandObject 10030fdc8d8SChris Lattner { 10130fdc8d8SChris Lattner public: 10230fdc8d8SChris Lattner 103864174e1SGreg Clayton class CommandOptions : public Options 104864174e1SGreg Clayton { 105864174e1SGreg Clayton public: 106864174e1SGreg Clayton 107eb0103f2SGreg Clayton CommandOptions (CommandInterpreter &interpreter) : 108f16066e8SJohnny Chen Options(interpreter) 109864174e1SGreg Clayton { 110f6b8b581SGreg Clayton OptionParsingStarting (); 111864174e1SGreg Clayton } 112864174e1SGreg Clayton 113864174e1SGreg Clayton virtual 114864174e1SGreg Clayton ~CommandOptions () 115864174e1SGreg Clayton { 116864174e1SGreg Clayton } 117864174e1SGreg Clayton 118864174e1SGreg Clayton virtual Error 119f6b8b581SGreg Clayton SetOptionValue (uint32_t option_idx, const char *option_arg) 120864174e1SGreg Clayton { 121864174e1SGreg Clayton Error error; 122864174e1SGreg Clayton bool success = false; 123864174e1SGreg Clayton char short_option = (char) m_getopt_table[option_idx].val; 124864174e1SGreg Clayton switch (short_option) 125864174e1SGreg Clayton { 126864174e1SGreg Clayton case 'r': 127864174e1SGreg Clayton relative_frame_offset = Args::StringToSInt32 (option_arg, INT32_MIN, 0, &success); 128864174e1SGreg Clayton if (!success) 129864174e1SGreg Clayton error.SetErrorStringWithFormat ("invalid frame offset argument '%s'.\n", option_arg); 130864174e1SGreg Clayton break; 131864174e1SGreg Clayton 132864174e1SGreg Clayton default: 1332c88643aSBenjamin Kramer error.SetErrorStringWithFormat ("Invalid short option character '%c'.\n", short_option); 134864174e1SGreg Clayton break; 135864174e1SGreg Clayton } 136864174e1SGreg Clayton 137864174e1SGreg Clayton return error; 138864174e1SGreg Clayton } 139864174e1SGreg Clayton 140864174e1SGreg Clayton void 141f6b8b581SGreg Clayton OptionParsingStarting () 142864174e1SGreg Clayton { 143864174e1SGreg Clayton relative_frame_offset = INT32_MIN; 144864174e1SGreg Clayton } 145864174e1SGreg Clayton 146e0d378b3SGreg Clayton const OptionDefinition* 147864174e1SGreg Clayton GetDefinitions () 148864174e1SGreg Clayton { 149864174e1SGreg Clayton return g_option_table; 150864174e1SGreg Clayton } 151864174e1SGreg Clayton 152864174e1SGreg Clayton // Options table: Required for subclasses of Options. 153864174e1SGreg Clayton 154e0d378b3SGreg Clayton static OptionDefinition g_option_table[]; 155864174e1SGreg Clayton int32_t relative_frame_offset; 156864174e1SGreg Clayton }; 157864174e1SGreg Clayton 158a7015092SGreg Clayton CommandObjectFrameSelect (CommandInterpreter &interpreter) : 159a7015092SGreg Clayton CommandObject (interpreter, 160a7015092SGreg Clayton "frame select", 161e3d26315SCaroline Tice "Select a frame by index from within the current thread and make it the current frame.", 162405fe67fSCaroline Tice NULL, 163eb0103f2SGreg Clayton eFlagProcessMustBeLaunched | eFlagProcessMustBePaused), 164eb0103f2SGreg Clayton m_options (interpreter) 16530fdc8d8SChris Lattner { 166405fe67fSCaroline Tice CommandArgumentEntry arg; 167405fe67fSCaroline Tice CommandArgumentData index_arg; 168405fe67fSCaroline Tice 169405fe67fSCaroline Tice // Define the first (and only) variant of this arg. 170405fe67fSCaroline Tice index_arg.arg_type = eArgTypeFrameIndex; 171864174e1SGreg Clayton index_arg.arg_repetition = eArgRepeatOptional; 172405fe67fSCaroline Tice 173405fe67fSCaroline Tice // There is only one variant this argument could be; put it into the argument entry. 174405fe67fSCaroline Tice arg.push_back (index_arg); 175405fe67fSCaroline Tice 176405fe67fSCaroline Tice // Push the data for the first argument into the m_arguments vector. 177405fe67fSCaroline Tice m_arguments.push_back (arg); 17830fdc8d8SChris Lattner } 17930fdc8d8SChris Lattner 18030fdc8d8SChris Lattner ~CommandObjectFrameSelect () 18130fdc8d8SChris Lattner { 18230fdc8d8SChris Lattner } 18330fdc8d8SChris Lattner 184864174e1SGreg Clayton virtual 185864174e1SGreg Clayton Options * 186864174e1SGreg Clayton GetOptions () 187864174e1SGreg Clayton { 188864174e1SGreg Clayton return &m_options; 189864174e1SGreg Clayton } 190864174e1SGreg Clayton 191864174e1SGreg Clayton 19230fdc8d8SChris Lattner bool 193a7015092SGreg Clayton Execute (Args& command, 19430fdc8d8SChris Lattner CommandReturnObject &result) 19530fdc8d8SChris Lattner { 1968b82f087SGreg Clayton ExecutionContext exe_ctx (m_interpreter.GetExecutionContext()); 197c14ee32dSGreg Clayton Thread *thread = exe_ctx.GetThreadPtr(); 198c14ee32dSGreg Clayton if (thread) 19930fdc8d8SChris Lattner { 200c14ee32dSGreg Clayton const uint32_t num_frames = thread->GetStackFrameCount(); 201864174e1SGreg Clayton uint32_t frame_idx = UINT32_MAX; 202864174e1SGreg Clayton if (m_options.relative_frame_offset != INT32_MIN) 203864174e1SGreg Clayton { 204864174e1SGreg Clayton // The one and only argument is a signed relative frame index 205c14ee32dSGreg Clayton frame_idx = thread->GetSelectedFrameIndex (); 206864174e1SGreg Clayton if (frame_idx == UINT32_MAX) 207864174e1SGreg Clayton frame_idx = 0; 208864174e1SGreg Clayton 209864174e1SGreg Clayton if (m_options.relative_frame_offset < 0) 210864174e1SGreg Clayton { 211864174e1SGreg Clayton if (frame_idx >= -m_options.relative_frame_offset) 212864174e1SGreg Clayton frame_idx += m_options.relative_frame_offset; 213864174e1SGreg Clayton else 214213b4546SJim Ingham { 215213b4546SJim Ingham if (frame_idx == 0) 216213b4546SJim Ingham { 217213b4546SJim Ingham //If you are already at the bottom of the stack, then just warn and don't reset the frame. 218213b4546SJim Ingham result.AppendError("Already at the bottom of the stack"); 219213b4546SJim Ingham result.SetStatus(eReturnStatusFailed); 220213b4546SJim Ingham return false; 221213b4546SJim Ingham } 222213b4546SJim Ingham else 223864174e1SGreg Clayton frame_idx = 0; 224864174e1SGreg Clayton } 225213b4546SJim Ingham } 226864174e1SGreg Clayton else if (m_options.relative_frame_offset > 0) 227864174e1SGreg Clayton { 228864174e1SGreg Clayton if (num_frames - frame_idx > m_options.relative_frame_offset) 229864174e1SGreg Clayton frame_idx += m_options.relative_frame_offset; 230864174e1SGreg Clayton else 231213b4546SJim Ingham { 232213b4546SJim Ingham if (frame_idx == num_frames - 1) 233213b4546SJim Ingham { 234213b4546SJim Ingham //If we are already at the top of the stack, just warn and don't reset the frame. 235213b4546SJim Ingham result.AppendError("Already at the top of the stack"); 236213b4546SJim Ingham result.SetStatus(eReturnStatusFailed); 237213b4546SJim Ingham return false; 238213b4546SJim Ingham } 239213b4546SJim Ingham else 240864174e1SGreg Clayton frame_idx = num_frames - 1; 241864174e1SGreg Clayton } 242864174e1SGreg Clayton } 243213b4546SJim Ingham } 244864174e1SGreg Clayton else 245864174e1SGreg Clayton { 24630fdc8d8SChris Lattner if (command.GetArgumentCount() == 1) 24730fdc8d8SChris Lattner { 24830fdc8d8SChris Lattner const char *frame_idx_cstr = command.GetArgumentAtIndex(0); 249864174e1SGreg Clayton frame_idx = Args::StringToUInt32 (frame_idx_cstr, UINT32_MAX, 0); 250864174e1SGreg Clayton } 25182d4a2b9SJason Molenda if (command.GetArgumentCount() == 0) 25282d4a2b9SJason Molenda { 25382d4a2b9SJason Molenda frame_idx = thread->GetSelectedFrameIndex (); 25482d4a2b9SJason Molenda if (frame_idx == UINT32_MAX) 25582d4a2b9SJason Molenda frame_idx = 0; 25682d4a2b9SJason Molenda } 257864174e1SGreg Clayton else 258864174e1SGreg Clayton { 259864174e1SGreg Clayton result.AppendError ("invalid arguments.\n"); 260eb0103f2SGreg Clayton m_options.GenerateOptionUsage (result.GetErrorStream(), this); 261864174e1SGreg Clayton } 262864174e1SGreg Clayton } 26330fdc8d8SChris Lattner 26430fdc8d8SChris Lattner if (frame_idx < num_frames) 26530fdc8d8SChris Lattner { 266c14ee32dSGreg Clayton thread->SetSelectedFrameByIndex (frame_idx); 267c14ee32dSGreg Clayton exe_ctx.SetFrameSP(thread->GetSelectedFrame ()); 268c14ee32dSGreg Clayton StackFrame *frame = exe_ctx.GetFramePtr(); 269c14ee32dSGreg Clayton if (frame) 27030fdc8d8SChris Lattner { 271e40e4218SJim Ingham bool already_shown = false; 272c14ee32dSGreg Clayton SymbolContext frame_sc(frame->GetSymbolContext(eSymbolContextLineEntry)); 273daccaa9eSCaroline Tice if (m_interpreter.GetDebugger().GetUseExternalEditor() && frame_sc.line_entry.file && frame_sc.line_entry.line != 0) 274e40e4218SJim Ingham { 275e40e4218SJim Ingham already_shown = Host::OpenFileInExternalEditor (frame_sc.line_entry.file, frame_sc.line_entry.line); 276e40e4218SJim Ingham } 277e40e4218SJim Ingham 2787260f620SGreg Clayton bool show_frame_info = true; 2797260f620SGreg Clayton bool show_source = !already_shown; 2807260f620SGreg Clayton uint32_t source_lines_before = 3; 2817260f620SGreg Clayton uint32_t source_lines_after = 3; 282c14ee32dSGreg Clayton if (frame->GetStatus (result.GetOutputStream(), 2837260f620SGreg Clayton show_frame_info, 2847260f620SGreg Clayton show_source, 2857260f620SGreg Clayton source_lines_before, 2867260f620SGreg Clayton source_lines_after)) 28730fdc8d8SChris Lattner { 28830fdc8d8SChris Lattner result.SetStatus (eReturnStatusSuccessFinishResult); 28930fdc8d8SChris Lattner return result.Succeeded(); 29030fdc8d8SChris Lattner } 29130fdc8d8SChris Lattner } 29230fdc8d8SChris Lattner } 29330fdc8d8SChris Lattner result.AppendErrorWithFormat ("Frame index (%u) out of range.\n", frame_idx); 29430fdc8d8SChris Lattner } 29530fdc8d8SChris Lattner else 29630fdc8d8SChris Lattner { 29730fdc8d8SChris Lattner result.AppendError ("no current thread"); 29830fdc8d8SChris Lattner } 29930fdc8d8SChris Lattner result.SetStatus (eReturnStatusFailed); 30030fdc8d8SChris Lattner return false; 30130fdc8d8SChris Lattner } 302864174e1SGreg Clayton protected: 303864174e1SGreg Clayton 304864174e1SGreg Clayton CommandOptions m_options; 305864174e1SGreg Clayton }; 306864174e1SGreg Clayton 307e0d378b3SGreg Clayton OptionDefinition 308864174e1SGreg Clayton CommandObjectFrameSelect::CommandOptions::g_option_table[] = 309864174e1SGreg Clayton { 310864174e1SGreg Clayton { LLDB_OPT_SET_1, false, "relative", 'r', required_argument, NULL, 0, eArgTypeOffset, "A relative frame index offset from the current frame index."}, 311864174e1SGreg Clayton { 0, false, NULL, 0, 0, NULL, NULL, eArgTypeNone, NULL } 31230fdc8d8SChris Lattner }; 31330fdc8d8SChris Lattner 3146d56d2ceSJim Ingham #pragma mark CommandObjectFrameVariable 3156d56d2ceSJim Ingham //---------------------------------------------------------------------- 3166d56d2ceSJim Ingham // List images with associated information 3176d56d2ceSJim Ingham //---------------------------------------------------------------------- 3186d56d2ceSJim Ingham class CommandObjectFrameVariable : public CommandObject 3196d56d2ceSJim Ingham { 3206d56d2ceSJim Ingham public: 3216d56d2ceSJim Ingham 322a7015092SGreg Clayton CommandObjectFrameVariable (CommandInterpreter &interpreter) : 323a7015092SGreg Clayton CommandObject (interpreter, 3246d56d2ceSJim Ingham "frame variable", 325ed8a705cSGreg Clayton "Show frame variables. All argument and local variables " 326ed8a705cSGreg Clayton "that are in scope will be shown when no arguments are given. " 327ed8a705cSGreg Clayton "If any arguments are specified, they can be names of " 328ed8a705cSGreg Clayton "argument, local, file static and file global variables. " 329ed8a705cSGreg Clayton "Children of aggregate variables can be specified such as " 330b1d7529eSJohnny Chen "'var->child.x'. " 331b1d7529eSJohnny Chen "You can choose to watch a variable with the '-w' option. " 332b1d7529eSJohnny Chen "Note that hardware resources for watching are often limited.", 333ff471a94SJim Ingham NULL, 334eb0103f2SGreg Clayton eFlagProcessMustBeLaunched | eFlagProcessMustBePaused), 3352837b766SJim Ingham m_option_group (interpreter), 336715c2365SGreg Clayton m_option_variable(true), // Include the frame specific options by passing "true" 337b1d7529eSJohnny Chen m_option_watchpoint(), 3382837b766SJim Ingham m_varobj_options() 3396d56d2ceSJim Ingham { 340405fe67fSCaroline Tice CommandArgumentEntry arg; 341405fe67fSCaroline Tice CommandArgumentData var_name_arg; 342405fe67fSCaroline Tice 343405fe67fSCaroline Tice // Define the first (and only) variant of this arg. 344405fe67fSCaroline Tice var_name_arg.arg_type = eArgTypeVarName; 345405fe67fSCaroline Tice var_name_arg.arg_repetition = eArgRepeatStar; 346405fe67fSCaroline Tice 347405fe67fSCaroline Tice // There is only one variant this argument could be; put it into the argument entry. 348405fe67fSCaroline Tice arg.push_back (var_name_arg); 349405fe67fSCaroline Tice 350405fe67fSCaroline Tice // Push the data for the first argument into the m_arguments vector. 351405fe67fSCaroline Tice m_arguments.push_back (arg); 3522837b766SJim Ingham 353715c2365SGreg Clayton m_option_group.Append (&m_option_variable, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1); 354b1d7529eSJohnny Chen m_option_group.Append (&m_option_watchpoint, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1); 3552837b766SJim Ingham m_option_group.Append (&m_varobj_options, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1); 3562837b766SJim Ingham m_option_group.Finalize(); 3576d56d2ceSJim Ingham } 3586d56d2ceSJim Ingham 3596d56d2ceSJim Ingham virtual 3606d56d2ceSJim Ingham ~CommandObjectFrameVariable () 3616d56d2ceSJim Ingham { 3626d56d2ceSJim Ingham } 3636d56d2ceSJim Ingham 3646d56d2ceSJim Ingham virtual 3656d56d2ceSJim Ingham Options * 3666d56d2ceSJim Ingham GetOptions () 3676d56d2ceSJim Ingham { 3682837b766SJim Ingham return &m_option_group; 3696d56d2ceSJim Ingham } 3706d56d2ceSJim Ingham 3716d56d2ceSJim Ingham 3726d56d2ceSJim Ingham virtual bool 3736d56d2ceSJim Ingham Execute 3746d56d2ceSJim Ingham ( 3756d56d2ceSJim Ingham Args& command, 3766d56d2ceSJim Ingham CommandReturnObject &result 3776d56d2ceSJim Ingham ) 3786d56d2ceSJim Ingham { 3798b82f087SGreg Clayton ExecutionContext exe_ctx(m_interpreter.GetExecutionContext()); 380c14ee32dSGreg Clayton StackFrame *frame = exe_ctx.GetFramePtr(); 381c14ee32dSGreg Clayton if (frame == NULL) 3826d56d2ceSJim Ingham { 383340b2baaSGreg Clayton result.AppendError ("you must be stopped in a valid stack frame to view frame variables."); 3846d56d2ceSJim Ingham result.SetStatus (eReturnStatusFailed); 3856d56d2ceSJim Ingham return false; 3866d56d2ceSJim Ingham } 3871e49e5e7SJohnny Chen 388a134cc1bSGreg Clayton Stream &s = result.GetOutputStream(); 3896d56d2ceSJim Ingham 390a134cc1bSGreg Clayton bool get_file_globals = true; 391650543f9SJim Ingham 392650543f9SJim Ingham // Be careful about the stack frame, if any summary formatter runs code, it might clear the StackFrameList 393650543f9SJim Ingham // for the thread. So hold onto a shared pointer to the frame so it stays alive. 394650543f9SJim Ingham 395c14ee32dSGreg Clayton VariableList *variable_list = frame->GetVariableList (get_file_globals); 396a134cc1bSGreg Clayton 3976d56d2ceSJim Ingham VariableSP var_sp; 3986d56d2ceSJim Ingham ValueObjectSP valobj_sp; 39978a685aaSJim Ingham 4006d56d2ceSJim Ingham const char *name_cstr = NULL; 4016d56d2ceSJim Ingham size_t idx; 4026d56d2ceSJim Ingham 403f9fa6ee5SEnrico Granata SummaryFormatSP summary_format_sp; 404f9fa6ee5SEnrico Granata if (!m_option_variable.summary.empty()) 40578d0638bSEnrico Granata DataVisualization::NamedSummaryFormats::GetSummaryFormat(ConstString(m_option_variable.summary.c_str()), summary_format_sp); 406f9fa6ee5SEnrico Granata 407379447a7SEnrico Granata ValueObject::DumpValueObjectOptions options; 408379447a7SEnrico Granata 409379447a7SEnrico Granata options.SetPointerDepth(m_varobj_options.ptr_depth) 410379447a7SEnrico Granata .SetMaximumDepth(m_varobj_options.max_depth) 411379447a7SEnrico Granata .SetShowTypes(m_varobj_options.show_types) 412379447a7SEnrico Granata .SetShowLocation(m_varobj_options.show_location) 413379447a7SEnrico Granata .SetUseObjectiveC(m_varobj_options.use_objc) 414379447a7SEnrico Granata .SetUseDynamicType(m_varobj_options.use_dynamic) 415379447a7SEnrico Granata .SetUseSyntheticValue((lldb::SyntheticValueType)m_varobj_options.use_synth) 416379447a7SEnrico Granata .SetFlatOutput(m_varobj_options.flat_output) 417379447a7SEnrico Granata .SetOmitSummaryDepth(m_varobj_options.no_summary_depth) 418379447a7SEnrico Granata .SetIgnoreCap(m_varobj_options.ignore_cap); 419379447a7SEnrico Granata 420379447a7SEnrico Granata if (m_varobj_options.be_raw) 421379447a7SEnrico Granata options.SetRawDisplay(true); 422379447a7SEnrico Granata 423715c2365SGreg Clayton if (variable_list) 4249df87c17SGreg Clayton { 4253a9838c0SJohnny Chen // If watching a variable, there are certain restrictions to be followed. 4263a9838c0SJohnny Chen if (m_option_watchpoint.watch_variable) 4273a9838c0SJohnny Chen { 4283a9838c0SJohnny Chen if (command.GetArgumentCount() != 1) { 4293a9838c0SJohnny Chen result.GetErrorStream().Printf("error: specify exactly one variable when using the '-w' option\n"); 4303a9838c0SJohnny Chen result.SetStatus(eReturnStatusFailed); 4313a9838c0SJohnny Chen return false; 4323a9838c0SJohnny Chen } else if (m_option_variable.use_regex) { 4333a9838c0SJohnny Chen result.GetErrorStream().Printf("error: specify your variable name exactly (no regex) when using the '-w' option\n"); 4343a9838c0SJohnny Chen result.SetStatus(eReturnStatusFailed); 4353a9838c0SJohnny Chen return false; 4363a9838c0SJohnny Chen } 4373a9838c0SJohnny Chen 4383a9838c0SJohnny Chen // Things have checked out ok... 439*b62a3be1SJohnny Chen // m_option_watchpoint.watch_type specifies the type of watching. 4403a9838c0SJohnny Chen } 4419df87c17SGreg Clayton if (command.GetArgumentCount() > 0) 4426d56d2ceSJim Ingham { 44346747022SGreg Clayton VariableList regex_var_list; 44446747022SGreg Clayton 4456d56d2ceSJim Ingham // If we have any args to the variable command, we will make 4466d56d2ceSJim Ingham // variable objects from them... 4476d56d2ceSJim Ingham for (idx = 0; (name_cstr = command.GetArgumentAtIndex(idx)) != NULL; ++idx) 4486d56d2ceSJim Ingham { 449715c2365SGreg Clayton if (m_option_variable.use_regex) 45046747022SGreg Clayton { 45146747022SGreg Clayton const uint32_t regex_start_index = regex_var_list.GetSize(); 45246747022SGreg Clayton RegularExpression regex (name_cstr); 45346747022SGreg Clayton if (regex.Compile(name_cstr)) 45446747022SGreg Clayton { 45546747022SGreg Clayton size_t num_matches = 0; 45678a685aaSJim Ingham const size_t num_new_regex_vars = variable_list->AppendVariablesIfUnique(regex, 45778a685aaSJim Ingham regex_var_list, 45878a685aaSJim Ingham num_matches); 45946747022SGreg Clayton if (num_new_regex_vars > 0) 46046747022SGreg Clayton { 46146747022SGreg Clayton for (uint32_t regex_idx = regex_start_index, end_index = regex_var_list.GetSize(); 46246747022SGreg Clayton regex_idx < end_index; 46346747022SGreg Clayton ++regex_idx) 46446747022SGreg Clayton { 46546747022SGreg Clayton var_sp = regex_var_list.GetVariableAtIndex (regex_idx); 46646747022SGreg Clayton if (var_sp) 46746747022SGreg Clayton { 468c14ee32dSGreg Clayton valobj_sp = frame->GetValueObjectForFrameVariable (var_sp, m_varobj_options.use_dynamic); 46946747022SGreg Clayton if (valobj_sp) 47046747022SGreg Clayton { 471715c2365SGreg Clayton if (m_option_variable.format != eFormatDefault) 472715c2365SGreg Clayton valobj_sp->SetFormat (m_option_variable.format); 473ded470d3SGreg Clayton 474715c2365SGreg Clayton if (m_option_variable.show_decl && var_sp->GetDeclaration ().GetFile()) 47546747022SGreg Clayton { 47645ba8543SGreg Clayton bool show_fullpaths = false; 47745ba8543SGreg Clayton bool show_module = true; 47845ba8543SGreg Clayton if (var_sp->DumpDeclaration(&s, show_fullpaths, show_module)) 47946747022SGreg Clayton s.PutCString (": "); 48046747022SGreg Clayton } 481f9fa6ee5SEnrico Granata if (summary_format_sp) 482f9fa6ee5SEnrico Granata valobj_sp->SetCustomSummaryFormat(summary_format_sp); 48346747022SGreg Clayton ValueObject::DumpValueObject (result.GetOutputStream(), 48446747022SGreg Clayton valobj_sp.get(), 485379447a7SEnrico Granata options); 48646747022SGreg Clayton } 48746747022SGreg Clayton } 48846747022SGreg Clayton } 48946747022SGreg Clayton } 49046747022SGreg Clayton else if (num_matches == 0) 49146747022SGreg Clayton { 49246747022SGreg Clayton result.GetErrorStream().Printf ("error: no variables matched the regular expression '%s'.\n", name_cstr); 49346747022SGreg Clayton } 49446747022SGreg Clayton } 49546747022SGreg Clayton else 49646747022SGreg Clayton { 49746747022SGreg Clayton char regex_error[1024]; 49846747022SGreg Clayton if (regex.GetErrorAsCString(regex_error, sizeof(regex_error))) 49946747022SGreg Clayton result.GetErrorStream().Printf ("error: %s\n", regex_error); 50046747022SGreg Clayton else 50146747022SGreg Clayton result.GetErrorStream().Printf ("error: unkown regex error when compiling '%s'\n", name_cstr); 50246747022SGreg Clayton } 50346747022SGreg Clayton } 504887062aeSJohnny Chen else // No regex, either exact variable names or variable expressions. 50546747022SGreg Clayton { 50654979cddSGreg Clayton Error error; 50778a685aaSJim Ingham uint32_t expr_path_options = StackFrame::eExpressionPathOptionCheckPtrVsMember; 5082837b766SJim Ingham lldb::VariableSP var_sp; 509c14ee32dSGreg Clayton valobj_sp = frame->GetValueForVariableExpressionPath (name_cstr, 5102837b766SJim Ingham m_varobj_options.use_dynamic, 5112837b766SJim Ingham expr_path_options, 5122837b766SJim Ingham var_sp, 5132837b766SJim Ingham error); 5146d56d2ceSJim Ingham if (valobj_sp) 5156d56d2ceSJim Ingham { 516715c2365SGreg Clayton if (m_option_variable.format != eFormatDefault) 517715c2365SGreg Clayton valobj_sp->SetFormat (m_option_variable.format); 518715c2365SGreg Clayton if (m_option_variable.show_decl && var_sp && var_sp->GetDeclaration ().GetFile()) 519a134cc1bSGreg Clayton { 520a134cc1bSGreg Clayton var_sp->GetDeclaration ().DumpStopContext (&s, false); 521a134cc1bSGreg Clayton s.PutCString (": "); 522a134cc1bSGreg Clayton } 523f9fa6ee5SEnrico Granata if (summary_format_sp) 524f9fa6ee5SEnrico Granata valobj_sp->SetCustomSummaryFormat(summary_format_sp); 525887062aeSJohnny Chen 526887062aeSJohnny Chen Stream &output_stream = result.GetOutputStream(); 527887062aeSJohnny Chen ValueObject::DumpValueObject (output_stream, 528a134cc1bSGreg Clayton valobj_sp.get(), 52983c5cd9dSGreg Clayton valobj_sp->GetParent() ? name_cstr : NULL, 530379447a7SEnrico Granata options); 531887062aeSJohnny Chen // Process watchpoint if necessary. 532887062aeSJohnny Chen if (m_option_watchpoint.watch_variable) 533887062aeSJohnny Chen { 5342fd89a09SJohnny Chen AddressType addr_type; 535*b62a3be1SJohnny Chen lldb::addr_t addr = 0; 536887062aeSJohnny Chen size_t size = 0; 537*b62a3be1SJohnny Chen if (m_option_watchpoint.watch_size == 0) { 538*b62a3be1SJohnny Chen addr = valobj_sp->GetAddressOf(false, &addr_type); 5392fd89a09SJohnny Chen if (addr_type == eAddressTypeLoad) { 5402fd89a09SJohnny Chen // We're in business. 5412fd89a09SJohnny Chen // Find out the size of this variable. 5422fd89a09SJohnny Chen size = valobj_sp->GetByteSize(); 5432fd89a09SJohnny Chen } 544*b62a3be1SJohnny Chen } else { 545*b62a3be1SJohnny Chen // The '-xsize'/'-x' option means to treat the value object as 546*b62a3be1SJohnny Chen // a pointer and to watch the pointee with the specified size. 547*b62a3be1SJohnny Chen addr = valobj_sp->GetValueAsUnsigned(0); 548*b62a3be1SJohnny Chen size = m_option_watchpoint.watch_size; 549*b62a3be1SJohnny Chen } 550887062aeSJohnny Chen uint32_t watch_type = m_option_watchpoint.watch_type; 551c14ee32dSGreg Clayton WatchpointLocation *wp_loc = exe_ctx.GetTargetRef().CreateWatchpointLocation(addr, size, watch_type).get(); 552887062aeSJohnny Chen if (wp_loc) 553887062aeSJohnny Chen { 554de6bd243SJohnny Chen if (var_sp && var_sp->GetDeclaration().GetFile()) 555de6bd243SJohnny Chen { 556de6bd243SJohnny Chen StreamString ss; 55718d7b950SJohnny Chen // True to show fullpath for declaration file. 558de6bd243SJohnny Chen var_sp->GetDeclaration().DumpStopContext(&ss, true); 559de6bd243SJohnny Chen wp_loc->SetDeclInfo(ss.GetString()); 560de6bd243SJohnny Chen } 561de6bd243SJohnny Chen StreamString ss; 562887062aeSJohnny Chen output_stream.Printf("Watchpoint created: "); 563de6bd243SJohnny Chen wp_loc->GetDescription(&output_stream, lldb::eDescriptionLevelFull); 564887062aeSJohnny Chen output_stream.EOL(); 565887062aeSJohnny Chen result.SetStatus(eReturnStatusSuccessFinishResult); 566887062aeSJohnny Chen } 567887062aeSJohnny Chen else 568887062aeSJohnny Chen { 569887062aeSJohnny Chen result.AppendErrorWithFormat("Watchpoint creation failed.\n"); 570887062aeSJohnny Chen result.SetStatus(eReturnStatusFailed); 571887062aeSJohnny Chen } 572887062aeSJohnny Chen return (wp_loc != NULL); 573887062aeSJohnny Chen } 5746d56d2ceSJim Ingham } 5756d56d2ceSJim Ingham else 5766d56d2ceSJim Ingham { 57754979cddSGreg Clayton const char *error_cstr = error.AsCString(NULL); 57854979cddSGreg Clayton if (error_cstr) 57954979cddSGreg Clayton result.GetErrorStream().Printf("error: %s\n", error_cstr); 58054979cddSGreg Clayton else 58154979cddSGreg Clayton result.GetErrorStream().Printf ("error: unable to find any variable expression path that matches '%s'\n", name_cstr); 5826d56d2ceSJim Ingham } 5836d56d2ceSJim Ingham } 5846d56d2ceSJim Ingham } 58546747022SGreg Clayton } 586926d086eSJohnny Chen else // No command arg specified. Use variable_list, instead. 5876d56d2ceSJim Ingham { 588a134cc1bSGreg Clayton const uint32_t num_variables = variable_list->GetSize(); 5896d56d2ceSJim Ingham if (num_variables > 0) 5906d56d2ceSJim Ingham { 5916d56d2ceSJim Ingham for (uint32_t i=0; i<num_variables; i++) 5926d56d2ceSJim Ingham { 5931a65ae11SGreg Clayton var_sp = variable_list->GetVariableAtIndex(i); 5946d56d2ceSJim Ingham bool dump_variable = true; 595a134cc1bSGreg Clayton switch (var_sp->GetScope()) 5966d56d2ceSJim Ingham { 5976d56d2ceSJim Ingham case eValueTypeVariableGlobal: 598715c2365SGreg Clayton dump_variable = m_option_variable.show_globals; 599715c2365SGreg Clayton if (dump_variable && m_option_variable.show_scope) 600a134cc1bSGreg Clayton s.PutCString("GLOBAL: "); 6016d56d2ceSJim Ingham break; 6026d56d2ceSJim Ingham 6036d56d2ceSJim Ingham case eValueTypeVariableStatic: 604715c2365SGreg Clayton dump_variable = m_option_variable.show_globals; 605715c2365SGreg Clayton if (dump_variable && m_option_variable.show_scope) 606a134cc1bSGreg Clayton s.PutCString("STATIC: "); 6076d56d2ceSJim Ingham break; 6086d56d2ceSJim Ingham 6096d56d2ceSJim Ingham case eValueTypeVariableArgument: 610715c2365SGreg Clayton dump_variable = m_option_variable.show_args; 611715c2365SGreg Clayton if (dump_variable && m_option_variable.show_scope) 612a134cc1bSGreg Clayton s.PutCString(" ARG: "); 6136d56d2ceSJim Ingham break; 6146d56d2ceSJim Ingham 6156d56d2ceSJim Ingham case eValueTypeVariableLocal: 616715c2365SGreg Clayton dump_variable = m_option_variable.show_locals; 617715c2365SGreg Clayton if (dump_variable && m_option_variable.show_scope) 618a134cc1bSGreg Clayton s.PutCString(" LOCAL: "); 6196d56d2ceSJim Ingham break; 6206d56d2ceSJim Ingham 6216d56d2ceSJim Ingham default: 6226d56d2ceSJim Ingham break; 6236d56d2ceSJim Ingham } 6246d56d2ceSJim Ingham 6256d56d2ceSJim Ingham if (dump_variable) 626a134cc1bSGreg Clayton { 627a134cc1bSGreg Clayton // Use the variable object code to make sure we are 628a134cc1bSGreg Clayton // using the same APIs as the the public API will be 629a134cc1bSGreg Clayton // using... 630c14ee32dSGreg Clayton valobj_sp = frame->GetValueObjectForFrameVariable (var_sp, 6312837b766SJim Ingham m_varobj_options.use_dynamic); 632a134cc1bSGreg Clayton if (valobj_sp) 633a134cc1bSGreg Clayton { 634715c2365SGreg Clayton if (m_option_variable.format != eFormatDefault) 635715c2365SGreg Clayton valobj_sp->SetFormat (m_option_variable.format); 636ded470d3SGreg Clayton 6376f00abd5SGreg Clayton // When dumping all variables, don't print any variables 6386f00abd5SGreg Clayton // that are not in scope to avoid extra unneeded output 6396035b67dSJim Ingham if (valobj_sp->IsInScope ()) 6406f00abd5SGreg Clayton { 641715c2365SGreg Clayton if (m_option_variable.show_decl && var_sp->GetDeclaration ().GetFile()) 642a134cc1bSGreg Clayton { 643a134cc1bSGreg Clayton var_sp->GetDeclaration ().DumpStopContext (&s, false); 644a134cc1bSGreg Clayton s.PutCString (": "); 645a134cc1bSGreg Clayton } 646f9fa6ee5SEnrico Granata if (summary_format_sp) 647f9fa6ee5SEnrico Granata valobj_sp->SetCustomSummaryFormat(summary_format_sp); 6481d3afba3SGreg Clayton ValueObject::DumpValueObject (result.GetOutputStream(), 649a134cc1bSGreg Clayton valobj_sp.get(), 650a134cc1bSGreg Clayton name_cstr, 651379447a7SEnrico Granata options); 652a134cc1bSGreg Clayton } 653a134cc1bSGreg Clayton } 6546d56d2ceSJim Ingham } 6556d56d2ceSJim Ingham } 6566d56d2ceSJim Ingham } 6576f00abd5SGreg Clayton } 6586d56d2ceSJim Ingham result.SetStatus (eReturnStatusSuccessFinishResult); 6596d56d2ceSJim Ingham } 66061a80ba6SEnrico Granata 66161a80ba6SEnrico Granata if (m_interpreter.TruncationWarningNecessary()) 66261a80ba6SEnrico Granata { 66361a80ba6SEnrico Granata result.GetOutputStream().Printf(m_interpreter.TruncationWarningText(), 66461a80ba6SEnrico Granata m_cmd_name.c_str()); 66561a80ba6SEnrico Granata m_interpreter.TruncationWarningGiven(); 66661a80ba6SEnrico Granata } 66761a80ba6SEnrico Granata 6686d56d2ceSJim Ingham return result.Succeeded(); 6696d56d2ceSJim Ingham } 6706d56d2ceSJim Ingham protected: 6716d56d2ceSJim Ingham 6722837b766SJim Ingham OptionGroupOptions m_option_group; 673715c2365SGreg Clayton OptionGroupVariable m_option_variable; 674b1d7529eSJohnny Chen OptionGroupWatchpoint m_option_watchpoint; 6752837b766SJim Ingham OptionGroupValueObjectDisplay m_varobj_options; 6766d56d2ceSJim Ingham }; 6776d56d2ceSJim Ingham 6782837b766SJim Ingham 67930fdc8d8SChris Lattner #pragma mark CommandObjectMultiwordFrame 68030fdc8d8SChris Lattner 68130fdc8d8SChris Lattner //------------------------------------------------------------------------- 68230fdc8d8SChris Lattner // CommandObjectMultiwordFrame 68330fdc8d8SChris Lattner //------------------------------------------------------------------------- 68430fdc8d8SChris Lattner 6856611103cSGreg Clayton CommandObjectMultiwordFrame::CommandObjectMultiwordFrame (CommandInterpreter &interpreter) : 686a7015092SGreg Clayton CommandObjectMultiword (interpreter, 687a7015092SGreg Clayton "frame", 68830fdc8d8SChris Lattner "A set of commands for operating on the current thread's frames.", 68930fdc8d8SChris Lattner "frame <subcommand> [<subcommand-options>]") 69030fdc8d8SChris Lattner { 691a7015092SGreg Clayton LoadSubCommand ("info", CommandObjectSP (new CommandObjectFrameInfo (interpreter))); 692a7015092SGreg Clayton LoadSubCommand ("select", CommandObjectSP (new CommandObjectFrameSelect (interpreter))); 693a7015092SGreg Clayton LoadSubCommand ("variable", CommandObjectSP (new CommandObjectFrameVariable (interpreter))); 69430fdc8d8SChris Lattner } 69530fdc8d8SChris Lattner 69630fdc8d8SChris Lattner CommandObjectMultiwordFrame::~CommandObjectMultiwordFrame () 69730fdc8d8SChris Lattner { 69830fdc8d8SChris Lattner } 69930fdc8d8SChris Lattner 700