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 } 251*f56c0137SJason Molenda else if (command.GetArgumentCount() == 0) 25282d4a2b9SJason Molenda { 25382d4a2b9SJason Molenda frame_idx = thread->GetSelectedFrameIndex (); 25482d4a2b9SJason Molenda if (frame_idx == UINT32_MAX) 255*f56c0137SJason Molenda { 25682d4a2b9SJason Molenda frame_idx = 0; 25782d4a2b9SJason Molenda } 258*f56c0137SJason Molenda } 259864174e1SGreg Clayton else 260864174e1SGreg Clayton { 261864174e1SGreg Clayton result.AppendError ("invalid arguments.\n"); 262eb0103f2SGreg Clayton m_options.GenerateOptionUsage (result.GetErrorStream(), this); 263864174e1SGreg Clayton } 264864174e1SGreg Clayton } 26530fdc8d8SChris Lattner 26630fdc8d8SChris Lattner if (frame_idx < num_frames) 26730fdc8d8SChris Lattner { 268c14ee32dSGreg Clayton thread->SetSelectedFrameByIndex (frame_idx); 269c14ee32dSGreg Clayton exe_ctx.SetFrameSP(thread->GetSelectedFrame ()); 270c14ee32dSGreg Clayton StackFrame *frame = exe_ctx.GetFramePtr(); 271c14ee32dSGreg Clayton if (frame) 27230fdc8d8SChris Lattner { 273e40e4218SJim Ingham bool already_shown = false; 274c14ee32dSGreg Clayton SymbolContext frame_sc(frame->GetSymbolContext(eSymbolContextLineEntry)); 275daccaa9eSCaroline Tice if (m_interpreter.GetDebugger().GetUseExternalEditor() && frame_sc.line_entry.file && frame_sc.line_entry.line != 0) 276e40e4218SJim Ingham { 277e40e4218SJim Ingham already_shown = Host::OpenFileInExternalEditor (frame_sc.line_entry.file, frame_sc.line_entry.line); 278e40e4218SJim Ingham } 279e40e4218SJim Ingham 2807260f620SGreg Clayton bool show_frame_info = true; 2817260f620SGreg Clayton bool show_source = !already_shown; 2827260f620SGreg Clayton uint32_t source_lines_before = 3; 2837260f620SGreg Clayton uint32_t source_lines_after = 3; 284c14ee32dSGreg Clayton if (frame->GetStatus (result.GetOutputStream(), 2857260f620SGreg Clayton show_frame_info, 2867260f620SGreg Clayton show_source, 2877260f620SGreg Clayton source_lines_before, 2887260f620SGreg Clayton source_lines_after)) 28930fdc8d8SChris Lattner { 29030fdc8d8SChris Lattner result.SetStatus (eReturnStatusSuccessFinishResult); 29130fdc8d8SChris Lattner return result.Succeeded(); 29230fdc8d8SChris Lattner } 29330fdc8d8SChris Lattner } 29430fdc8d8SChris Lattner } 29530fdc8d8SChris Lattner result.AppendErrorWithFormat ("Frame index (%u) out of range.\n", frame_idx); 29630fdc8d8SChris Lattner } 29730fdc8d8SChris Lattner else 29830fdc8d8SChris Lattner { 29930fdc8d8SChris Lattner result.AppendError ("no current thread"); 30030fdc8d8SChris Lattner } 30130fdc8d8SChris Lattner result.SetStatus (eReturnStatusFailed); 30230fdc8d8SChris Lattner return false; 30330fdc8d8SChris Lattner } 304864174e1SGreg Clayton protected: 305864174e1SGreg Clayton 306864174e1SGreg Clayton CommandOptions m_options; 307864174e1SGreg Clayton }; 308864174e1SGreg Clayton 309e0d378b3SGreg Clayton OptionDefinition 310864174e1SGreg Clayton CommandObjectFrameSelect::CommandOptions::g_option_table[] = 311864174e1SGreg Clayton { 312864174e1SGreg Clayton { LLDB_OPT_SET_1, false, "relative", 'r', required_argument, NULL, 0, eArgTypeOffset, "A relative frame index offset from the current frame index."}, 313864174e1SGreg Clayton { 0, false, NULL, 0, 0, NULL, NULL, eArgTypeNone, NULL } 31430fdc8d8SChris Lattner }; 31530fdc8d8SChris Lattner 3166d56d2ceSJim Ingham #pragma mark CommandObjectFrameVariable 3176d56d2ceSJim Ingham //---------------------------------------------------------------------- 3186d56d2ceSJim Ingham // List images with associated information 3196d56d2ceSJim Ingham //---------------------------------------------------------------------- 3206d56d2ceSJim Ingham class CommandObjectFrameVariable : public CommandObject 3216d56d2ceSJim Ingham { 3226d56d2ceSJim Ingham public: 3236d56d2ceSJim Ingham 324a7015092SGreg Clayton CommandObjectFrameVariable (CommandInterpreter &interpreter) : 325a7015092SGreg Clayton CommandObject (interpreter, 3266d56d2ceSJim Ingham "frame variable", 327ed8a705cSGreg Clayton "Show frame variables. All argument and local variables " 328ed8a705cSGreg Clayton "that are in scope will be shown when no arguments are given. " 329ed8a705cSGreg Clayton "If any arguments are specified, they can be names of " 330ed8a705cSGreg Clayton "argument, local, file static and file global variables. " 331ed8a705cSGreg Clayton "Children of aggregate variables can be specified such as " 332b1d7529eSJohnny Chen "'var->child.x'. " 333b1d7529eSJohnny Chen "You can choose to watch a variable with the '-w' option. " 334b1d7529eSJohnny Chen "Note that hardware resources for watching are often limited.", 335ff471a94SJim Ingham NULL, 336eb0103f2SGreg Clayton eFlagProcessMustBeLaunched | eFlagProcessMustBePaused), 3372837b766SJim Ingham m_option_group (interpreter), 338715c2365SGreg Clayton m_option_variable(true), // Include the frame specific options by passing "true" 339b1d7529eSJohnny Chen m_option_watchpoint(), 3402837b766SJim Ingham m_varobj_options() 3416d56d2ceSJim Ingham { 342405fe67fSCaroline Tice CommandArgumentEntry arg; 343405fe67fSCaroline Tice CommandArgumentData var_name_arg; 344405fe67fSCaroline Tice 345405fe67fSCaroline Tice // Define the first (and only) variant of this arg. 346405fe67fSCaroline Tice var_name_arg.arg_type = eArgTypeVarName; 347405fe67fSCaroline Tice var_name_arg.arg_repetition = eArgRepeatStar; 348405fe67fSCaroline Tice 349405fe67fSCaroline Tice // There is only one variant this argument could be; put it into the argument entry. 350405fe67fSCaroline Tice arg.push_back (var_name_arg); 351405fe67fSCaroline Tice 352405fe67fSCaroline Tice // Push the data for the first argument into the m_arguments vector. 353405fe67fSCaroline Tice m_arguments.push_back (arg); 3542837b766SJim Ingham 355715c2365SGreg Clayton m_option_group.Append (&m_option_variable, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1); 356b1d7529eSJohnny Chen m_option_group.Append (&m_option_watchpoint, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1); 3572837b766SJim Ingham m_option_group.Append (&m_varobj_options, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1); 3582837b766SJim Ingham m_option_group.Finalize(); 3596d56d2ceSJim Ingham } 3606d56d2ceSJim Ingham 3616d56d2ceSJim Ingham virtual 3626d56d2ceSJim Ingham ~CommandObjectFrameVariable () 3636d56d2ceSJim Ingham { 3646d56d2ceSJim Ingham } 3656d56d2ceSJim Ingham 3666d56d2ceSJim Ingham virtual 3676d56d2ceSJim Ingham Options * 3686d56d2ceSJim Ingham GetOptions () 3696d56d2ceSJim Ingham { 3702837b766SJim Ingham return &m_option_group; 3716d56d2ceSJim Ingham } 3726d56d2ceSJim Ingham 3736d56d2ceSJim Ingham 3746d56d2ceSJim Ingham virtual bool 3756d56d2ceSJim Ingham Execute 3766d56d2ceSJim Ingham ( 3776d56d2ceSJim Ingham Args& command, 3786d56d2ceSJim Ingham CommandReturnObject &result 3796d56d2ceSJim Ingham ) 3806d56d2ceSJim Ingham { 3818b82f087SGreg Clayton ExecutionContext exe_ctx(m_interpreter.GetExecutionContext()); 382c14ee32dSGreg Clayton StackFrame *frame = exe_ctx.GetFramePtr(); 383c14ee32dSGreg Clayton if (frame == NULL) 3846d56d2ceSJim Ingham { 385340b2baaSGreg Clayton result.AppendError ("you must be stopped in a valid stack frame to view frame variables."); 3866d56d2ceSJim Ingham result.SetStatus (eReturnStatusFailed); 3876d56d2ceSJim Ingham return false; 3886d56d2ceSJim Ingham } 3891e49e5e7SJohnny Chen 390a134cc1bSGreg Clayton Stream &s = result.GetOutputStream(); 3916d56d2ceSJim Ingham 392a134cc1bSGreg Clayton bool get_file_globals = true; 393650543f9SJim Ingham 394650543f9SJim Ingham // Be careful about the stack frame, if any summary formatter runs code, it might clear the StackFrameList 395650543f9SJim Ingham // for the thread. So hold onto a shared pointer to the frame so it stays alive. 396650543f9SJim Ingham 397c14ee32dSGreg Clayton VariableList *variable_list = frame->GetVariableList (get_file_globals); 398a134cc1bSGreg Clayton 3996d56d2ceSJim Ingham VariableSP var_sp; 4006d56d2ceSJim Ingham ValueObjectSP valobj_sp; 40178a685aaSJim Ingham 4026d56d2ceSJim Ingham const char *name_cstr = NULL; 4036d56d2ceSJim Ingham size_t idx; 4046d56d2ceSJim Ingham 405f9fa6ee5SEnrico Granata SummaryFormatSP summary_format_sp; 406f9fa6ee5SEnrico Granata if (!m_option_variable.summary.empty()) 40778d0638bSEnrico Granata DataVisualization::NamedSummaryFormats::GetSummaryFormat(ConstString(m_option_variable.summary.c_str()), summary_format_sp); 408f9fa6ee5SEnrico Granata 409379447a7SEnrico Granata ValueObject::DumpValueObjectOptions options; 410379447a7SEnrico Granata 411379447a7SEnrico Granata options.SetPointerDepth(m_varobj_options.ptr_depth) 412379447a7SEnrico Granata .SetMaximumDepth(m_varobj_options.max_depth) 413379447a7SEnrico Granata .SetShowTypes(m_varobj_options.show_types) 414379447a7SEnrico Granata .SetShowLocation(m_varobj_options.show_location) 415379447a7SEnrico Granata .SetUseObjectiveC(m_varobj_options.use_objc) 416379447a7SEnrico Granata .SetUseDynamicType(m_varobj_options.use_dynamic) 417379447a7SEnrico Granata .SetUseSyntheticValue((lldb::SyntheticValueType)m_varobj_options.use_synth) 418379447a7SEnrico Granata .SetFlatOutput(m_varobj_options.flat_output) 419379447a7SEnrico Granata .SetOmitSummaryDepth(m_varobj_options.no_summary_depth) 420379447a7SEnrico Granata .SetIgnoreCap(m_varobj_options.ignore_cap); 421379447a7SEnrico Granata 422379447a7SEnrico Granata if (m_varobj_options.be_raw) 423379447a7SEnrico Granata options.SetRawDisplay(true); 424379447a7SEnrico Granata 425715c2365SGreg Clayton if (variable_list) 4269df87c17SGreg Clayton { 4273a9838c0SJohnny Chen // If watching a variable, there are certain restrictions to be followed. 4283a9838c0SJohnny Chen if (m_option_watchpoint.watch_variable) 4293a9838c0SJohnny Chen { 4303a9838c0SJohnny Chen if (command.GetArgumentCount() != 1) { 4313a9838c0SJohnny Chen result.GetErrorStream().Printf("error: specify exactly one variable when using the '-w' option\n"); 4323a9838c0SJohnny Chen result.SetStatus(eReturnStatusFailed); 4333a9838c0SJohnny Chen return false; 4343a9838c0SJohnny Chen } else if (m_option_variable.use_regex) { 4353a9838c0SJohnny Chen result.GetErrorStream().Printf("error: specify your variable name exactly (no regex) when using the '-w' option\n"); 4363a9838c0SJohnny Chen result.SetStatus(eReturnStatusFailed); 4373a9838c0SJohnny Chen return false; 4383a9838c0SJohnny Chen } 4393a9838c0SJohnny Chen 4403a9838c0SJohnny Chen // Things have checked out ok... 441b62a3be1SJohnny Chen // m_option_watchpoint.watch_type specifies the type of watching. 4423a9838c0SJohnny Chen } 4439df87c17SGreg Clayton if (command.GetArgumentCount() > 0) 4446d56d2ceSJim Ingham { 44546747022SGreg Clayton VariableList regex_var_list; 44646747022SGreg Clayton 4476d56d2ceSJim Ingham // If we have any args to the variable command, we will make 4486d56d2ceSJim Ingham // variable objects from them... 4496d56d2ceSJim Ingham for (idx = 0; (name_cstr = command.GetArgumentAtIndex(idx)) != NULL; ++idx) 4506d56d2ceSJim Ingham { 451715c2365SGreg Clayton if (m_option_variable.use_regex) 45246747022SGreg Clayton { 45346747022SGreg Clayton const uint32_t regex_start_index = regex_var_list.GetSize(); 45446747022SGreg Clayton RegularExpression regex (name_cstr); 45546747022SGreg Clayton if (regex.Compile(name_cstr)) 45646747022SGreg Clayton { 45746747022SGreg Clayton size_t num_matches = 0; 45878a685aaSJim Ingham const size_t num_new_regex_vars = variable_list->AppendVariablesIfUnique(regex, 45978a685aaSJim Ingham regex_var_list, 46078a685aaSJim Ingham num_matches); 46146747022SGreg Clayton if (num_new_regex_vars > 0) 46246747022SGreg Clayton { 46346747022SGreg Clayton for (uint32_t regex_idx = regex_start_index, end_index = regex_var_list.GetSize(); 46446747022SGreg Clayton regex_idx < end_index; 46546747022SGreg Clayton ++regex_idx) 46646747022SGreg Clayton { 46746747022SGreg Clayton var_sp = regex_var_list.GetVariableAtIndex (regex_idx); 46846747022SGreg Clayton if (var_sp) 46946747022SGreg Clayton { 470c14ee32dSGreg Clayton valobj_sp = frame->GetValueObjectForFrameVariable (var_sp, m_varobj_options.use_dynamic); 47146747022SGreg Clayton if (valobj_sp) 47246747022SGreg Clayton { 473715c2365SGreg Clayton if (m_option_variable.format != eFormatDefault) 474715c2365SGreg Clayton valobj_sp->SetFormat (m_option_variable.format); 475ded470d3SGreg Clayton 476715c2365SGreg Clayton if (m_option_variable.show_decl && var_sp->GetDeclaration ().GetFile()) 47746747022SGreg Clayton { 47845ba8543SGreg Clayton bool show_fullpaths = false; 47945ba8543SGreg Clayton bool show_module = true; 48045ba8543SGreg Clayton if (var_sp->DumpDeclaration(&s, show_fullpaths, show_module)) 48146747022SGreg Clayton s.PutCString (": "); 48246747022SGreg Clayton } 483f9fa6ee5SEnrico Granata if (summary_format_sp) 484f9fa6ee5SEnrico Granata valobj_sp->SetCustomSummaryFormat(summary_format_sp); 48546747022SGreg Clayton ValueObject::DumpValueObject (result.GetOutputStream(), 48646747022SGreg Clayton valobj_sp.get(), 487379447a7SEnrico Granata options); 48846747022SGreg Clayton } 48946747022SGreg Clayton } 49046747022SGreg Clayton } 49146747022SGreg Clayton } 49246747022SGreg Clayton else if (num_matches == 0) 49346747022SGreg Clayton { 49446747022SGreg Clayton result.GetErrorStream().Printf ("error: no variables matched the regular expression '%s'.\n", name_cstr); 49546747022SGreg Clayton } 49646747022SGreg Clayton } 49746747022SGreg Clayton else 49846747022SGreg Clayton { 49946747022SGreg Clayton char regex_error[1024]; 50046747022SGreg Clayton if (regex.GetErrorAsCString(regex_error, sizeof(regex_error))) 50146747022SGreg Clayton result.GetErrorStream().Printf ("error: %s\n", regex_error); 50246747022SGreg Clayton else 50346747022SGreg Clayton result.GetErrorStream().Printf ("error: unkown regex error when compiling '%s'\n", name_cstr); 50446747022SGreg Clayton } 50546747022SGreg Clayton } 506887062aeSJohnny Chen else // No regex, either exact variable names or variable expressions. 50746747022SGreg Clayton { 50854979cddSGreg Clayton Error error; 50978a685aaSJim Ingham uint32_t expr_path_options = StackFrame::eExpressionPathOptionCheckPtrVsMember; 5102837b766SJim Ingham lldb::VariableSP var_sp; 511c14ee32dSGreg Clayton valobj_sp = frame->GetValueForVariableExpressionPath (name_cstr, 5122837b766SJim Ingham m_varobj_options.use_dynamic, 5132837b766SJim Ingham expr_path_options, 5142837b766SJim Ingham var_sp, 5152837b766SJim Ingham error); 5166d56d2ceSJim Ingham if (valobj_sp) 5176d56d2ceSJim Ingham { 518715c2365SGreg Clayton if (m_option_variable.format != eFormatDefault) 519715c2365SGreg Clayton valobj_sp->SetFormat (m_option_variable.format); 520715c2365SGreg Clayton if (m_option_variable.show_decl && var_sp && var_sp->GetDeclaration ().GetFile()) 521a134cc1bSGreg Clayton { 522a134cc1bSGreg Clayton var_sp->GetDeclaration ().DumpStopContext (&s, false); 523a134cc1bSGreg Clayton s.PutCString (": "); 524a134cc1bSGreg Clayton } 525f9fa6ee5SEnrico Granata if (summary_format_sp) 526f9fa6ee5SEnrico Granata valobj_sp->SetCustomSummaryFormat(summary_format_sp); 527887062aeSJohnny Chen 528887062aeSJohnny Chen Stream &output_stream = result.GetOutputStream(); 529887062aeSJohnny Chen ValueObject::DumpValueObject (output_stream, 530a134cc1bSGreg Clayton valobj_sp.get(), 53183c5cd9dSGreg Clayton valobj_sp->GetParent() ? name_cstr : NULL, 532379447a7SEnrico Granata options); 533887062aeSJohnny Chen // Process watchpoint if necessary. 534887062aeSJohnny Chen if (m_option_watchpoint.watch_variable) 535887062aeSJohnny Chen { 5362fd89a09SJohnny Chen AddressType addr_type; 537b62a3be1SJohnny Chen lldb::addr_t addr = 0; 538887062aeSJohnny Chen size_t size = 0; 539b62a3be1SJohnny Chen if (m_option_watchpoint.watch_size == 0) { 540b62a3be1SJohnny Chen addr = valobj_sp->GetAddressOf(false, &addr_type); 5412fd89a09SJohnny Chen if (addr_type == eAddressTypeLoad) { 5422fd89a09SJohnny Chen // We're in business. 5432fd89a09SJohnny Chen // Find out the size of this variable. 5442fd89a09SJohnny Chen size = valobj_sp->GetByteSize(); 5452fd89a09SJohnny Chen } 546b62a3be1SJohnny Chen } else { 547b62a3be1SJohnny Chen // The '-xsize'/'-x' option means to treat the value object as 548b62a3be1SJohnny Chen // a pointer and to watch the pointee with the specified size. 549b62a3be1SJohnny Chen addr = valobj_sp->GetValueAsUnsigned(0); 550b62a3be1SJohnny Chen size = m_option_watchpoint.watch_size; 551b62a3be1SJohnny Chen } 552887062aeSJohnny Chen uint32_t watch_type = m_option_watchpoint.watch_type; 553c14ee32dSGreg Clayton WatchpointLocation *wp_loc = exe_ctx.GetTargetRef().CreateWatchpointLocation(addr, size, watch_type).get(); 554887062aeSJohnny Chen if (wp_loc) 555887062aeSJohnny Chen { 556de6bd243SJohnny Chen if (var_sp && var_sp->GetDeclaration().GetFile()) 557de6bd243SJohnny Chen { 558de6bd243SJohnny Chen StreamString ss; 55918d7b950SJohnny Chen // True to show fullpath for declaration file. 560de6bd243SJohnny Chen var_sp->GetDeclaration().DumpStopContext(&ss, true); 561de6bd243SJohnny Chen wp_loc->SetDeclInfo(ss.GetString()); 562de6bd243SJohnny Chen } 563de6bd243SJohnny Chen StreamString ss; 564887062aeSJohnny Chen output_stream.Printf("Watchpoint created: "); 565de6bd243SJohnny Chen wp_loc->GetDescription(&output_stream, lldb::eDescriptionLevelFull); 566887062aeSJohnny Chen output_stream.EOL(); 567887062aeSJohnny Chen result.SetStatus(eReturnStatusSuccessFinishResult); 568887062aeSJohnny Chen } 569887062aeSJohnny Chen else 570887062aeSJohnny Chen { 571887062aeSJohnny Chen result.AppendErrorWithFormat("Watchpoint creation failed.\n"); 572887062aeSJohnny Chen result.SetStatus(eReturnStatusFailed); 573887062aeSJohnny Chen } 574887062aeSJohnny Chen return (wp_loc != NULL); 575887062aeSJohnny Chen } 5766d56d2ceSJim Ingham } 5776d56d2ceSJim Ingham else 5786d56d2ceSJim Ingham { 57954979cddSGreg Clayton const char *error_cstr = error.AsCString(NULL); 58054979cddSGreg Clayton if (error_cstr) 58154979cddSGreg Clayton result.GetErrorStream().Printf("error: %s\n", error_cstr); 58254979cddSGreg Clayton else 58354979cddSGreg Clayton result.GetErrorStream().Printf ("error: unable to find any variable expression path that matches '%s'\n", name_cstr); 5846d56d2ceSJim Ingham } 5856d56d2ceSJim Ingham } 5866d56d2ceSJim Ingham } 58746747022SGreg Clayton } 588926d086eSJohnny Chen else // No command arg specified. Use variable_list, instead. 5896d56d2ceSJim Ingham { 590a134cc1bSGreg Clayton const uint32_t num_variables = variable_list->GetSize(); 5916d56d2ceSJim Ingham if (num_variables > 0) 5926d56d2ceSJim Ingham { 5936d56d2ceSJim Ingham for (uint32_t i=0; i<num_variables; i++) 5946d56d2ceSJim Ingham { 5951a65ae11SGreg Clayton var_sp = variable_list->GetVariableAtIndex(i); 5966d56d2ceSJim Ingham bool dump_variable = true; 597a134cc1bSGreg Clayton switch (var_sp->GetScope()) 5986d56d2ceSJim Ingham { 5996d56d2ceSJim Ingham case eValueTypeVariableGlobal: 600715c2365SGreg Clayton dump_variable = m_option_variable.show_globals; 601715c2365SGreg Clayton if (dump_variable && m_option_variable.show_scope) 602a134cc1bSGreg Clayton s.PutCString("GLOBAL: "); 6036d56d2ceSJim Ingham break; 6046d56d2ceSJim Ingham 6056d56d2ceSJim Ingham case eValueTypeVariableStatic: 606715c2365SGreg Clayton dump_variable = m_option_variable.show_globals; 607715c2365SGreg Clayton if (dump_variable && m_option_variable.show_scope) 608a134cc1bSGreg Clayton s.PutCString("STATIC: "); 6096d56d2ceSJim Ingham break; 6106d56d2ceSJim Ingham 6116d56d2ceSJim Ingham case eValueTypeVariableArgument: 612715c2365SGreg Clayton dump_variable = m_option_variable.show_args; 613715c2365SGreg Clayton if (dump_variable && m_option_variable.show_scope) 614a134cc1bSGreg Clayton s.PutCString(" ARG: "); 6156d56d2ceSJim Ingham break; 6166d56d2ceSJim Ingham 6176d56d2ceSJim Ingham case eValueTypeVariableLocal: 618715c2365SGreg Clayton dump_variable = m_option_variable.show_locals; 619715c2365SGreg Clayton if (dump_variable && m_option_variable.show_scope) 620a134cc1bSGreg Clayton s.PutCString(" LOCAL: "); 6216d56d2ceSJim Ingham break; 6226d56d2ceSJim Ingham 6236d56d2ceSJim Ingham default: 6246d56d2ceSJim Ingham break; 6256d56d2ceSJim Ingham } 6266d56d2ceSJim Ingham 6276d56d2ceSJim Ingham if (dump_variable) 628a134cc1bSGreg Clayton { 629a134cc1bSGreg Clayton // Use the variable object code to make sure we are 630a134cc1bSGreg Clayton // using the same APIs as the the public API will be 631a134cc1bSGreg Clayton // using... 632c14ee32dSGreg Clayton valobj_sp = frame->GetValueObjectForFrameVariable (var_sp, 6332837b766SJim Ingham m_varobj_options.use_dynamic); 634a134cc1bSGreg Clayton if (valobj_sp) 635a134cc1bSGreg Clayton { 636715c2365SGreg Clayton if (m_option_variable.format != eFormatDefault) 637715c2365SGreg Clayton valobj_sp->SetFormat (m_option_variable.format); 638ded470d3SGreg Clayton 6396f00abd5SGreg Clayton // When dumping all variables, don't print any variables 6406f00abd5SGreg Clayton // that are not in scope to avoid extra unneeded output 6416035b67dSJim Ingham if (valobj_sp->IsInScope ()) 6426f00abd5SGreg Clayton { 643715c2365SGreg Clayton if (m_option_variable.show_decl && var_sp->GetDeclaration ().GetFile()) 644a134cc1bSGreg Clayton { 645a134cc1bSGreg Clayton var_sp->GetDeclaration ().DumpStopContext (&s, false); 646a134cc1bSGreg Clayton s.PutCString (": "); 647a134cc1bSGreg Clayton } 648f9fa6ee5SEnrico Granata if (summary_format_sp) 649f9fa6ee5SEnrico Granata valobj_sp->SetCustomSummaryFormat(summary_format_sp); 6501d3afba3SGreg Clayton ValueObject::DumpValueObject (result.GetOutputStream(), 651a134cc1bSGreg Clayton valobj_sp.get(), 652a134cc1bSGreg Clayton name_cstr, 653379447a7SEnrico Granata options); 654a134cc1bSGreg Clayton } 655a134cc1bSGreg Clayton } 6566d56d2ceSJim Ingham } 6576d56d2ceSJim Ingham } 6586d56d2ceSJim Ingham } 6596f00abd5SGreg Clayton } 6606d56d2ceSJim Ingham result.SetStatus (eReturnStatusSuccessFinishResult); 6616d56d2ceSJim Ingham } 66261a80ba6SEnrico Granata 66361a80ba6SEnrico Granata if (m_interpreter.TruncationWarningNecessary()) 66461a80ba6SEnrico Granata { 66561a80ba6SEnrico Granata result.GetOutputStream().Printf(m_interpreter.TruncationWarningText(), 66661a80ba6SEnrico Granata m_cmd_name.c_str()); 66761a80ba6SEnrico Granata m_interpreter.TruncationWarningGiven(); 66861a80ba6SEnrico Granata } 66961a80ba6SEnrico Granata 6706d56d2ceSJim Ingham return result.Succeeded(); 6716d56d2ceSJim Ingham } 6726d56d2ceSJim Ingham protected: 6736d56d2ceSJim Ingham 6742837b766SJim Ingham OptionGroupOptions m_option_group; 675715c2365SGreg Clayton OptionGroupVariable m_option_variable; 676b1d7529eSJohnny Chen OptionGroupWatchpoint m_option_watchpoint; 6772837b766SJim Ingham OptionGroupValueObjectDisplay m_varobj_options; 6786d56d2ceSJim Ingham }; 6796d56d2ceSJim Ingham 6802837b766SJim Ingham 68130fdc8d8SChris Lattner #pragma mark CommandObjectMultiwordFrame 68230fdc8d8SChris Lattner 68330fdc8d8SChris Lattner //------------------------------------------------------------------------- 68430fdc8d8SChris Lattner // CommandObjectMultiwordFrame 68530fdc8d8SChris Lattner //------------------------------------------------------------------------- 68630fdc8d8SChris Lattner 6876611103cSGreg Clayton CommandObjectMultiwordFrame::CommandObjectMultiwordFrame (CommandInterpreter &interpreter) : 688a7015092SGreg Clayton CommandObjectMultiword (interpreter, 689a7015092SGreg Clayton "frame", 69030fdc8d8SChris Lattner "A set of commands for operating on the current thread's frames.", 69130fdc8d8SChris Lattner "frame <subcommand> [<subcommand-options>]") 69230fdc8d8SChris Lattner { 693a7015092SGreg Clayton LoadSubCommand ("info", CommandObjectSP (new CommandObjectFrameInfo (interpreter))); 694a7015092SGreg Clayton LoadSubCommand ("select", CommandObjectSP (new CommandObjectFrameSelect (interpreter))); 695a7015092SGreg Clayton LoadSubCommand ("variable", CommandObjectSP (new CommandObjectFrameVariable (interpreter))); 69630fdc8d8SChris Lattner } 69730fdc8d8SChris Lattner 69830fdc8d8SChris Lattner CommandObjectMultiwordFrame::~CommandObjectMultiwordFrame () 69930fdc8d8SChris Lattner { 70030fdc8d8SChris Lattner } 70130fdc8d8SChris Lattner 702