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
1430fdc8d8SChris Lattner // Other libraries and framework includes
1530fdc8d8SChris Lattner // Project includes
1630fdc8d8SChris Lattner #include "lldb/Core/Debugger.h"
176d56d2ceSJim Ingham #include "lldb/Core/Module.h"
186d56d2ceSJim Ingham #include "lldb/Core/StreamFile.h"
1930fdc8d8SChris Lattner #include "lldb/Core/Timer.h"
206d56d2ceSJim Ingham #include "lldb/Core/Value.h"
216d56d2ceSJim Ingham #include "lldb/Core/ValueObject.h"
226d56d2ceSJim Ingham #include "lldb/Core/ValueObjectVariable.h"
237fb56d0aSGreg Clayton #include "lldb/Host/Host.h"
246d56d2ceSJim Ingham #include "lldb/Interpreter/Args.h"
2530fdc8d8SChris Lattner #include "lldb/Interpreter/CommandInterpreter.h"
2630fdc8d8SChris Lattner #include "lldb/Interpreter/CommandReturnObject.h"
276d56d2ceSJim Ingham #include "lldb/Interpreter/Options.h"
282837b766SJim Ingham #include "lldb/Interpreter/OptionGroupValueObjectDisplay.h"
29715c2365SGreg Clayton #include "lldb/Interpreter/OptionGroupVariable.h"
306d56d2ceSJim Ingham #include "lldb/Symbol/ClangASTType.h"
316d56d2ceSJim Ingham #include "lldb/Symbol/ClangASTContext.h"
326d56d2ceSJim Ingham #include "lldb/Symbol/ObjectFile.h"
336d56d2ceSJim Ingham #include "lldb/Symbol/SymbolContext.h"
346d56d2ceSJim Ingham #include "lldb/Symbol/Type.h"
356d56d2ceSJim Ingham #include "lldb/Symbol/Variable.h"
366d56d2ceSJim Ingham #include "lldb/Symbol/VariableList.h"
3730fdc8d8SChris Lattner #include "lldb/Target/Process.h"
3830fdc8d8SChris Lattner #include "lldb/Target/StackFrame.h"
3930fdc8d8SChris Lattner #include "lldb/Target/Thread.h"
406d56d2ceSJim Ingham #include "lldb/Target/Target.h"
4130fdc8d8SChris Lattner 
4230fdc8d8SChris Lattner using namespace lldb;
4330fdc8d8SChris Lattner using namespace lldb_private;
4430fdc8d8SChris Lattner 
4530fdc8d8SChris Lattner #pragma mark CommandObjectFrameInfo
4630fdc8d8SChris Lattner 
4730fdc8d8SChris Lattner //-------------------------------------------------------------------------
4830fdc8d8SChris Lattner // CommandObjectFrameInfo
4930fdc8d8SChris Lattner //-------------------------------------------------------------------------
5030fdc8d8SChris Lattner 
5130fdc8d8SChris Lattner class CommandObjectFrameInfo : public CommandObject
5230fdc8d8SChris Lattner {
5330fdc8d8SChris Lattner public:
5430fdc8d8SChris Lattner 
55a7015092SGreg Clayton     CommandObjectFrameInfo (CommandInterpreter &interpreter) :
56a7015092SGreg Clayton         CommandObject (interpreter,
57a7015092SGreg Clayton                        "frame info",
58e3d26315SCaroline Tice                        "List information about the currently selected frame in the current thread.",
5930fdc8d8SChris Lattner                        "frame info",
6030fdc8d8SChris Lattner                        eFlagProcessMustBeLaunched | eFlagProcessMustBePaused)
6130fdc8d8SChris Lattner     {
6230fdc8d8SChris Lattner     }
6330fdc8d8SChris Lattner 
6430fdc8d8SChris Lattner     ~CommandObjectFrameInfo ()
6530fdc8d8SChris Lattner     {
6630fdc8d8SChris Lattner     }
6730fdc8d8SChris Lattner 
6830fdc8d8SChris Lattner     bool
69a7015092SGreg Clayton     Execute (Args& command,
7030fdc8d8SChris Lattner              CommandReturnObject &result)
7130fdc8d8SChris Lattner     {
728b82f087SGreg Clayton         ExecutionContext exe_ctx(m_interpreter.GetExecutionContext());
7330fdc8d8SChris Lattner         if (exe_ctx.frame)
7430fdc8d8SChris Lattner         {
750603aa9dSGreg Clayton             exe_ctx.frame->DumpUsingSettingsFormat (&result.GetOutputStream());
7630fdc8d8SChris Lattner             result.SetStatus (eReturnStatusSuccessFinishResult);
7730fdc8d8SChris Lattner         }
7830fdc8d8SChris Lattner         else
7930fdc8d8SChris Lattner         {
8030fdc8d8SChris Lattner             result.AppendError ("no current frame");
8130fdc8d8SChris Lattner             result.SetStatus (eReturnStatusFailed);
8230fdc8d8SChris Lattner         }
8330fdc8d8SChris Lattner         return result.Succeeded();
8430fdc8d8SChris Lattner     }
8530fdc8d8SChris Lattner };
8630fdc8d8SChris Lattner 
8730fdc8d8SChris Lattner #pragma mark CommandObjectFrameSelect
8830fdc8d8SChris Lattner 
8930fdc8d8SChris Lattner //-------------------------------------------------------------------------
9030fdc8d8SChris Lattner // CommandObjectFrameSelect
9130fdc8d8SChris Lattner //-------------------------------------------------------------------------
9230fdc8d8SChris Lattner 
9330fdc8d8SChris Lattner class CommandObjectFrameSelect : public CommandObject
9430fdc8d8SChris Lattner {
9530fdc8d8SChris Lattner public:
9630fdc8d8SChris Lattner 
97864174e1SGreg Clayton    class CommandOptions : public Options
98864174e1SGreg Clayton     {
99864174e1SGreg Clayton     public:
100864174e1SGreg Clayton 
101eb0103f2SGreg Clayton         CommandOptions (CommandInterpreter &interpreter) :
102f16066e8SJohnny Chen             Options(interpreter)
103864174e1SGreg Clayton         {
104f6b8b581SGreg Clayton             OptionParsingStarting ();
105864174e1SGreg Clayton         }
106864174e1SGreg Clayton 
107864174e1SGreg Clayton         virtual
108864174e1SGreg Clayton         ~CommandOptions ()
109864174e1SGreg Clayton         {
110864174e1SGreg Clayton         }
111864174e1SGreg Clayton 
112864174e1SGreg Clayton         virtual Error
113f6b8b581SGreg Clayton         SetOptionValue (uint32_t option_idx, const char *option_arg)
114864174e1SGreg Clayton         {
115864174e1SGreg Clayton             Error error;
116864174e1SGreg Clayton             bool success = false;
117864174e1SGreg Clayton             char short_option = (char) m_getopt_table[option_idx].val;
118864174e1SGreg Clayton             switch (short_option)
119864174e1SGreg Clayton             {
120864174e1SGreg Clayton             case 'r':
121864174e1SGreg Clayton                 relative_frame_offset = Args::StringToSInt32 (option_arg, INT32_MIN, 0, &success);
122864174e1SGreg Clayton                 if (!success)
123864174e1SGreg Clayton                     error.SetErrorStringWithFormat ("invalid frame offset argument '%s'.\n", option_arg);
124864174e1SGreg Clayton                 break;
125864174e1SGreg Clayton 
126864174e1SGreg Clayton             default:
1272c88643aSBenjamin Kramer                 error.SetErrorStringWithFormat ("Invalid short option character '%c'.\n", short_option);
128864174e1SGreg Clayton                 break;
129864174e1SGreg Clayton             }
130864174e1SGreg Clayton 
131864174e1SGreg Clayton             return error;
132864174e1SGreg Clayton         }
133864174e1SGreg Clayton 
134864174e1SGreg Clayton         void
135f6b8b581SGreg Clayton         OptionParsingStarting ()
136864174e1SGreg Clayton         {
137864174e1SGreg Clayton             relative_frame_offset = INT32_MIN;
138864174e1SGreg Clayton         }
139864174e1SGreg Clayton 
140e0d378b3SGreg Clayton         const OptionDefinition*
141864174e1SGreg Clayton         GetDefinitions ()
142864174e1SGreg Clayton         {
143864174e1SGreg Clayton             return g_option_table;
144864174e1SGreg Clayton         }
145864174e1SGreg Clayton 
146864174e1SGreg Clayton         // Options table: Required for subclasses of Options.
147864174e1SGreg Clayton 
148e0d378b3SGreg Clayton         static OptionDefinition g_option_table[];
149864174e1SGreg Clayton         int32_t relative_frame_offset;
150864174e1SGreg Clayton     };
151864174e1SGreg Clayton 
152a7015092SGreg Clayton     CommandObjectFrameSelect (CommandInterpreter &interpreter) :
153a7015092SGreg Clayton         CommandObject (interpreter,
154a7015092SGreg Clayton                        "frame select",
155e3d26315SCaroline Tice                        "Select a frame by index from within the current thread and make it the current frame.",
156405fe67fSCaroline Tice                        NULL,
157eb0103f2SGreg Clayton                        eFlagProcessMustBeLaunched | eFlagProcessMustBePaused),
158eb0103f2SGreg Clayton         m_options (interpreter)
15930fdc8d8SChris Lattner     {
160405fe67fSCaroline Tice         CommandArgumentEntry arg;
161405fe67fSCaroline Tice         CommandArgumentData index_arg;
162405fe67fSCaroline Tice 
163405fe67fSCaroline Tice         // Define the first (and only) variant of this arg.
164405fe67fSCaroline Tice         index_arg.arg_type = eArgTypeFrameIndex;
165864174e1SGreg Clayton         index_arg.arg_repetition = eArgRepeatOptional;
166405fe67fSCaroline Tice 
167405fe67fSCaroline Tice         // There is only one variant this argument could be; put it into the argument entry.
168405fe67fSCaroline Tice         arg.push_back (index_arg);
169405fe67fSCaroline Tice 
170405fe67fSCaroline Tice         // Push the data for the first argument into the m_arguments vector.
171405fe67fSCaroline Tice         m_arguments.push_back (arg);
17230fdc8d8SChris Lattner     }
17330fdc8d8SChris Lattner 
17430fdc8d8SChris Lattner     ~CommandObjectFrameSelect ()
17530fdc8d8SChris Lattner     {
17630fdc8d8SChris Lattner     }
17730fdc8d8SChris Lattner 
178864174e1SGreg Clayton     virtual
179864174e1SGreg Clayton     Options *
180864174e1SGreg Clayton     GetOptions ()
181864174e1SGreg Clayton     {
182864174e1SGreg Clayton         return &m_options;
183864174e1SGreg Clayton     }
184864174e1SGreg Clayton 
185864174e1SGreg Clayton 
18630fdc8d8SChris Lattner     bool
187a7015092SGreg Clayton     Execute (Args& command,
18830fdc8d8SChris Lattner              CommandReturnObject &result)
18930fdc8d8SChris Lattner     {
1908b82f087SGreg Clayton         ExecutionContext exe_ctx (m_interpreter.GetExecutionContext());
19130fdc8d8SChris Lattner         if (exe_ctx.thread)
19230fdc8d8SChris Lattner         {
193864174e1SGreg Clayton             const uint32_t num_frames = exe_ctx.thread->GetStackFrameCount();
194864174e1SGreg Clayton             uint32_t frame_idx = UINT32_MAX;
195864174e1SGreg Clayton             if (m_options.relative_frame_offset != INT32_MIN)
196864174e1SGreg Clayton             {
197864174e1SGreg Clayton                 // The one and only argument is a signed relative frame index
198864174e1SGreg Clayton                 frame_idx = exe_ctx.thread->GetSelectedFrameIndex ();
199864174e1SGreg Clayton                 if (frame_idx == UINT32_MAX)
200864174e1SGreg Clayton                     frame_idx = 0;
201864174e1SGreg Clayton 
202864174e1SGreg Clayton                 if (m_options.relative_frame_offset < 0)
203864174e1SGreg Clayton                 {
204864174e1SGreg Clayton                     if (frame_idx >= -m_options.relative_frame_offset)
205864174e1SGreg Clayton                         frame_idx += m_options.relative_frame_offset;
206864174e1SGreg Clayton                     else
207864174e1SGreg Clayton                         frame_idx = 0;
208864174e1SGreg Clayton                 }
209864174e1SGreg Clayton                 else if (m_options.relative_frame_offset > 0)
210864174e1SGreg Clayton                 {
211864174e1SGreg Clayton                     if (num_frames - frame_idx > m_options.relative_frame_offset)
212864174e1SGreg Clayton                         frame_idx += m_options.relative_frame_offset;
213864174e1SGreg Clayton                     else
214864174e1SGreg Clayton                         frame_idx = num_frames - 1;
215864174e1SGreg Clayton                 }
216864174e1SGreg Clayton             }
217864174e1SGreg Clayton             else
218864174e1SGreg Clayton             {
21930fdc8d8SChris Lattner                 if (command.GetArgumentCount() == 1)
22030fdc8d8SChris Lattner                 {
22130fdc8d8SChris Lattner                     const char *frame_idx_cstr = command.GetArgumentAtIndex(0);
222864174e1SGreg Clayton                     frame_idx = Args::StringToUInt32 (frame_idx_cstr, UINT32_MAX, 0);
223864174e1SGreg Clayton                 }
224864174e1SGreg Clayton                 else
225864174e1SGreg Clayton                 {
226864174e1SGreg Clayton                     result.AppendError ("invalid arguments.\n");
227eb0103f2SGreg Clayton                     m_options.GenerateOptionUsage (result.GetErrorStream(), this);
228864174e1SGreg Clayton                 }
229864174e1SGreg Clayton             }
23030fdc8d8SChris Lattner 
23130fdc8d8SChris Lattner             if (frame_idx < num_frames)
23230fdc8d8SChris Lattner             {
2332976d00aSJim Ingham                 exe_ctx.thread->SetSelectedFrameByIndex (frame_idx);
2342976d00aSJim Ingham                 exe_ctx.frame = exe_ctx.thread->GetSelectedFrame ().get();
23530fdc8d8SChris Lattner 
23630fdc8d8SChris Lattner                 if (exe_ctx.frame)
23730fdc8d8SChris Lattner                 {
238e40e4218SJim Ingham                     bool already_shown = false;
239e40e4218SJim Ingham                     SymbolContext frame_sc(exe_ctx.frame->GetSymbolContext(eSymbolContextLineEntry));
240daccaa9eSCaroline Tice                     if (m_interpreter.GetDebugger().GetUseExternalEditor() && frame_sc.line_entry.file && frame_sc.line_entry.line != 0)
241e40e4218SJim Ingham                     {
242e40e4218SJim Ingham                         already_shown = Host::OpenFileInExternalEditor (frame_sc.line_entry.file, frame_sc.line_entry.line);
243e40e4218SJim Ingham                     }
244e40e4218SJim Ingham 
2457260f620SGreg Clayton                     bool show_frame_info = true;
2467260f620SGreg Clayton                     bool show_source = !already_shown;
2477260f620SGreg Clayton                     uint32_t source_lines_before = 3;
2487260f620SGreg Clayton                     uint32_t source_lines_after = 3;
2497260f620SGreg Clayton                     if (exe_ctx.frame->GetStatus(result.GetOutputStream(),
2507260f620SGreg Clayton                                                  show_frame_info,
2517260f620SGreg Clayton                                                  show_source,
2527260f620SGreg Clayton                                                  source_lines_before,
2537260f620SGreg Clayton                                                  source_lines_after))
25430fdc8d8SChris Lattner                     {
25530fdc8d8SChris Lattner                         result.SetStatus (eReturnStatusSuccessFinishResult);
25630fdc8d8SChris Lattner                         return result.Succeeded();
25730fdc8d8SChris Lattner                     }
25830fdc8d8SChris Lattner                 }
25930fdc8d8SChris Lattner             }
26030fdc8d8SChris Lattner             result.AppendErrorWithFormat ("Frame index (%u) out of range.\n", frame_idx);
26130fdc8d8SChris Lattner         }
26230fdc8d8SChris Lattner         else
26330fdc8d8SChris Lattner         {
26430fdc8d8SChris Lattner             result.AppendError ("no current thread");
26530fdc8d8SChris Lattner         }
26630fdc8d8SChris Lattner         result.SetStatus (eReturnStatusFailed);
26730fdc8d8SChris Lattner         return false;
26830fdc8d8SChris Lattner     }
269864174e1SGreg Clayton protected:
270864174e1SGreg Clayton 
271864174e1SGreg Clayton     CommandOptions m_options;
272864174e1SGreg Clayton };
273864174e1SGreg Clayton 
274e0d378b3SGreg Clayton OptionDefinition
275864174e1SGreg Clayton CommandObjectFrameSelect::CommandOptions::g_option_table[] =
276864174e1SGreg Clayton {
277864174e1SGreg Clayton { LLDB_OPT_SET_1, false, "relative", 'r', required_argument, NULL, 0, eArgTypeOffset, "A relative frame index offset from the current frame index."},
278864174e1SGreg Clayton { 0, false, NULL, 0, 0, NULL, NULL, eArgTypeNone, NULL }
27930fdc8d8SChris Lattner };
28030fdc8d8SChris Lattner 
2816d56d2ceSJim Ingham #pragma mark CommandObjectFrameVariable
2826d56d2ceSJim Ingham //----------------------------------------------------------------------
2836d56d2ceSJim Ingham // List images with associated information
2846d56d2ceSJim Ingham //----------------------------------------------------------------------
2856d56d2ceSJim Ingham class CommandObjectFrameVariable : public CommandObject
2866d56d2ceSJim Ingham {
2876d56d2ceSJim Ingham public:
2886d56d2ceSJim Ingham 
2892837b766SJim Ingham     class OptionGroupFrameVariable : public OptionGroup
2906d56d2ceSJim Ingham     {
2916d56d2ceSJim Ingham     public:
2926d56d2ceSJim Ingham 
2932837b766SJim Ingham         OptionGroupFrameVariable ()
2946d56d2ceSJim Ingham         {
2956d56d2ceSJim Ingham         }
2966d56d2ceSJim Ingham 
2976d56d2ceSJim Ingham         virtual
2982837b766SJim Ingham         ~OptionGroupFrameVariable ()
2996d56d2ceSJim Ingham         {
3006d56d2ceSJim Ingham         }
3016d56d2ceSJim Ingham 
3022837b766SJim Ingham         virtual uint32_t
3032837b766SJim Ingham         GetNumDefinitions ();
3042837b766SJim Ingham 
3052837b766SJim Ingham         virtual const OptionDefinition*
3062837b766SJim Ingham         GetDefinitions ()
3072837b766SJim Ingham         {
3082837b766SJim Ingham             return g_option_table;
3092837b766SJim Ingham         }
3102837b766SJim Ingham 
3116d56d2ceSJim Ingham         virtual Error
3122837b766SJim Ingham         SetOptionValue (CommandInterpreter &interpreter,
3132837b766SJim Ingham                         uint32_t option_idx,
3142837b766SJim Ingham                         const char *option_arg)
3156d56d2ceSJim Ingham         {
3166d56d2ceSJim Ingham             Error error;
3172837b766SJim Ingham             char short_option = (char) g_option_table[option_idx].short_option;
3186d56d2ceSJim Ingham             switch (short_option)
3196d56d2ceSJim Ingham             {
3206d56d2ceSJim Ingham             case 'r':   use_regex    = true;  break;
3216d56d2ceSJim Ingham             case 'a':   show_args    = false; break;
3226d56d2ceSJim Ingham             case 'l':   show_locals  = false; break;
323a134cc1bSGreg Clayton             case 'g':   show_globals = true;  break;
324a134cc1bSGreg Clayton             case 'c':   show_decl    = true;  break;
32568ebae61SGreg Clayton             case 'f':   error = Args::StringToFormat(option_arg, format, NULL); break;
3266d56d2ceSJim Ingham             case 'G':
327a134cc1bSGreg Clayton                 globals.push_back(ConstString (option_arg));
3286d56d2ceSJim Ingham                 break;
3296d56d2ceSJim Ingham             case 's':
3306d56d2ceSJim Ingham                 show_scope = true;
3316d56d2ceSJim Ingham                 break;
3326d56d2ceSJim Ingham 
3336d56d2ceSJim Ingham             default:
3346d56d2ceSJim Ingham                 error.SetErrorStringWithFormat("Invalid short option character '%c'.\n", short_option);
3356d56d2ceSJim Ingham                 break;
3366d56d2ceSJim Ingham             }
3376d56d2ceSJim Ingham 
3386d56d2ceSJim Ingham             return error;
3396d56d2ceSJim Ingham         }
3406d56d2ceSJim Ingham 
3412837b766SJim Ingham         virtual void
3422837b766SJim Ingham         OptionParsingStarting (CommandInterpreter &interpreter)
3436d56d2ceSJim Ingham         {
3446d56d2ceSJim Ingham             show_args     = true;
345a134cc1bSGreg Clayton             show_decl     = false;
346ded470d3SGreg Clayton             format        = eFormatDefault;
3472837b766SJim Ingham             show_globals  = false;
3482837b766SJim Ingham             show_locals   = true;
3492837b766SJim Ingham             use_regex     = false;
3502837b766SJim Ingham             show_scope    = false;
3516d56d2ceSJim Ingham             globals.clear();
3526d56d2ceSJim Ingham         }
3536d56d2ceSJim Ingham 
3546d56d2ceSJim Ingham         // Options table: Required for subclasses of Options.
3556d56d2ceSJim Ingham 
356e0d378b3SGreg Clayton         static OptionDefinition g_option_table[];
3572837b766SJim Ingham 
3582837b766SJim Ingham         bool use_regex:1,
359a134cc1bSGreg Clayton              show_args:1,
360a134cc1bSGreg Clayton              show_locals:1,
361a134cc1bSGreg Clayton              show_globals:1,
362a134cc1bSGreg Clayton              show_scope:1,
3632837b766SJim Ingham              show_decl:1;
364ded470d3SGreg Clayton         lldb::Format format; // The format to use when dumping variables or children of variables
3656d56d2ceSJim Ingham         std::vector<ConstString> globals;
3666d56d2ceSJim Ingham         // Instance variables to hold the values for command options.
3676d56d2ceSJim Ingham     };
3686d56d2ceSJim Ingham 
369a7015092SGreg Clayton     CommandObjectFrameVariable (CommandInterpreter &interpreter) :
370a7015092SGreg Clayton         CommandObject (interpreter,
3716d56d2ceSJim Ingham                        "frame variable",
372ed8a705cSGreg Clayton                        "Show frame variables. All argument and local variables "
373ed8a705cSGreg Clayton                        "that are in scope will be shown when no arguments are given. "
374ed8a705cSGreg Clayton                        "If any arguments are specified, they can be names of "
375ed8a705cSGreg Clayton                        "argument, local, file static and file global variables. "
376ed8a705cSGreg Clayton                        "Children of aggregate variables can be specified such as "
377ed8a705cSGreg Clayton                        "'var->child.x'.",
378ff471a94SJim Ingham                        NULL,
379eb0103f2SGreg Clayton                        eFlagProcessMustBeLaunched | eFlagProcessMustBePaused),
3802837b766SJim Ingham         m_option_group (interpreter),
381715c2365SGreg Clayton         m_option_variable(true), // Include the frame specific options by passing "true"
3822837b766SJim Ingham         m_varobj_options()
3836d56d2ceSJim Ingham     {
384405fe67fSCaroline Tice         CommandArgumentEntry arg;
385405fe67fSCaroline Tice         CommandArgumentData var_name_arg;
386405fe67fSCaroline Tice 
387405fe67fSCaroline Tice         // Define the first (and only) variant of this arg.
388405fe67fSCaroline Tice         var_name_arg.arg_type = eArgTypeVarName;
389405fe67fSCaroline Tice         var_name_arg.arg_repetition = eArgRepeatStar;
390405fe67fSCaroline Tice 
391405fe67fSCaroline Tice         // There is only one variant this argument could be; put it into the argument entry.
392405fe67fSCaroline Tice         arg.push_back (var_name_arg);
393405fe67fSCaroline Tice 
394405fe67fSCaroline Tice         // Push the data for the first argument into the m_arguments vector.
395405fe67fSCaroline Tice         m_arguments.push_back (arg);
3962837b766SJim Ingham 
397715c2365SGreg Clayton         m_option_group.Append (&m_option_variable, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1);
3982837b766SJim Ingham         m_option_group.Append (&m_varobj_options, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1);
3992837b766SJim Ingham         m_option_group.Finalize();
4006d56d2ceSJim Ingham     }
4016d56d2ceSJim Ingham 
4026d56d2ceSJim Ingham     virtual
4036d56d2ceSJim Ingham     ~CommandObjectFrameVariable ()
4046d56d2ceSJim Ingham     {
4056d56d2ceSJim Ingham     }
4066d56d2ceSJim Ingham 
4076d56d2ceSJim Ingham     virtual
4086d56d2ceSJim Ingham     Options *
4096d56d2ceSJim Ingham     GetOptions ()
4106d56d2ceSJim Ingham     {
4112837b766SJim Ingham         return &m_option_group;
4126d56d2ceSJim Ingham     }
4136d56d2ceSJim Ingham 
4146d56d2ceSJim Ingham 
4156d56d2ceSJim Ingham     virtual bool
4166d56d2ceSJim Ingham     Execute
4176d56d2ceSJim Ingham     (
4186d56d2ceSJim Ingham         Args& command,
4196d56d2ceSJim Ingham         CommandReturnObject &result
4206d56d2ceSJim Ingham     )
4216d56d2ceSJim Ingham     {
4228b82f087SGreg Clayton         ExecutionContext exe_ctx(m_interpreter.GetExecutionContext());
4236d56d2ceSJim Ingham         if (exe_ctx.frame == NULL)
4246d56d2ceSJim Ingham         {
425340b2baaSGreg Clayton             result.AppendError ("you must be stopped in a valid stack frame to view frame variables.");
4266d56d2ceSJim Ingham             result.SetStatus (eReturnStatusFailed);
4276d56d2ceSJim Ingham             return false;
4286d56d2ceSJim Ingham         }
4296d56d2ceSJim Ingham         else
4306d56d2ceSJim Ingham         {
431a134cc1bSGreg Clayton             Stream &s = result.GetOutputStream();
4326d56d2ceSJim Ingham 
433a134cc1bSGreg Clayton             bool get_file_globals = true;
434a134cc1bSGreg Clayton             VariableList *variable_list = exe_ctx.frame->GetVariableList (get_file_globals);
435a134cc1bSGreg Clayton 
4366d56d2ceSJim Ingham             VariableSP var_sp;
4376d56d2ceSJim Ingham             ValueObjectSP valobj_sp;
43878a685aaSJim Ingham 
4396d56d2ceSJim Ingham             const char *name_cstr = NULL;
4406d56d2ceSJim Ingham             size_t idx;
4416d56d2ceSJim Ingham 
442f9fa6ee5SEnrico Granata             SummaryFormatSP summary_format_sp;
443f9fa6ee5SEnrico Granata             if (!m_option_variable.summary.empty())
4441490c6fdSEnrico Granata                 Debugger::Formatting::NamedSummaryFormats::Get(ConstString(m_option_variable.summary.c_str()), summary_format_sp);
445f9fa6ee5SEnrico Granata 
446*379447a7SEnrico Granata             ValueObject::DumpValueObjectOptions options;
447*379447a7SEnrico Granata 
448*379447a7SEnrico Granata             options.SetPointerDepth(m_varobj_options.ptr_depth)
449*379447a7SEnrico Granata                    .SetMaximumDepth(m_varobj_options.max_depth)
450*379447a7SEnrico Granata                    .SetShowTypes(m_varobj_options.show_types)
451*379447a7SEnrico Granata                    .SetShowLocation(m_varobj_options.show_location)
452*379447a7SEnrico Granata                    .SetUseObjectiveC(m_varobj_options.use_objc)
453*379447a7SEnrico Granata                    .SetUseDynamicType(m_varobj_options.use_dynamic)
454*379447a7SEnrico Granata                    .SetUseSyntheticValue((lldb::SyntheticValueType)m_varobj_options.use_synth)
455*379447a7SEnrico Granata                    .SetFlatOutput(m_varobj_options.flat_output)
456*379447a7SEnrico Granata                    .SetOmitSummaryDepth(m_varobj_options.no_summary_depth)
457*379447a7SEnrico Granata                    .SetIgnoreCap(m_varobj_options.ignore_cap);
458*379447a7SEnrico Granata 
459*379447a7SEnrico Granata             if (m_varobj_options.be_raw)
460*379447a7SEnrico Granata                 options.SetRawDisplay(true);
461*379447a7SEnrico Granata 
462715c2365SGreg Clayton             if (variable_list)
4639df87c17SGreg Clayton             {
4649df87c17SGreg Clayton                 if (command.GetArgumentCount() > 0)
4656d56d2ceSJim Ingham                 {
46646747022SGreg Clayton                     VariableList regex_var_list;
46746747022SGreg Clayton 
4686d56d2ceSJim Ingham                     // If we have any args to the variable command, we will make
4696d56d2ceSJim Ingham                     // variable objects from them...
4706d56d2ceSJim Ingham                     for (idx = 0; (name_cstr = command.GetArgumentAtIndex(idx)) != NULL; ++idx)
4716d56d2ceSJim Ingham                     {
472715c2365SGreg Clayton                         if (m_option_variable.use_regex)
47346747022SGreg Clayton                         {
47446747022SGreg Clayton                             const uint32_t regex_start_index = regex_var_list.GetSize();
47546747022SGreg Clayton                             RegularExpression regex (name_cstr);
47646747022SGreg Clayton                             if (regex.Compile(name_cstr))
47746747022SGreg Clayton                             {
47846747022SGreg Clayton                                 size_t num_matches = 0;
47978a685aaSJim Ingham                                 const size_t num_new_regex_vars = variable_list->AppendVariablesIfUnique(regex,
48078a685aaSJim Ingham                                                                                                          regex_var_list,
48178a685aaSJim Ingham                                                                                                          num_matches);
48246747022SGreg Clayton                                 if (num_new_regex_vars > 0)
48346747022SGreg Clayton                                 {
48446747022SGreg Clayton                                     for (uint32_t regex_idx = regex_start_index, end_index = regex_var_list.GetSize();
48546747022SGreg Clayton                                          regex_idx < end_index;
48646747022SGreg Clayton                                          ++regex_idx)
48746747022SGreg Clayton                                     {
48846747022SGreg Clayton                                         var_sp = regex_var_list.GetVariableAtIndex (regex_idx);
48946747022SGreg Clayton                                         if (var_sp)
49046747022SGreg Clayton                                         {
4912837b766SJim Ingham                                             valobj_sp = exe_ctx.frame->GetValueObjectForFrameVariable (var_sp, m_varobj_options.use_dynamic);
49246747022SGreg Clayton                                             if (valobj_sp)
49346747022SGreg Clayton                                             {
494715c2365SGreg Clayton                                                 if (m_option_variable.format != eFormatDefault)
495715c2365SGreg Clayton                                                     valobj_sp->SetFormat (m_option_variable.format);
496ded470d3SGreg Clayton 
497715c2365SGreg Clayton                                                 if (m_option_variable.show_decl && var_sp->GetDeclaration ().GetFile())
49846747022SGreg Clayton                                                 {
49945ba8543SGreg Clayton                                                     bool show_fullpaths = false;
50045ba8543SGreg Clayton                                                     bool show_module = true;
50145ba8543SGreg Clayton                                                     if (var_sp->DumpDeclaration(&s, show_fullpaths, show_module))
50246747022SGreg Clayton                                                         s.PutCString (": ");
50346747022SGreg Clayton                                                 }
504f9fa6ee5SEnrico Granata                                                 if (summary_format_sp)
505f9fa6ee5SEnrico Granata                                                     valobj_sp->SetCustomSummaryFormat(summary_format_sp);
50646747022SGreg Clayton                                                 ValueObject::DumpValueObject (result.GetOutputStream(),
50746747022SGreg Clayton                                                                               valobj_sp.get(),
508*379447a7SEnrico Granata                                                                               options);
50946747022SGreg Clayton                                             }
51046747022SGreg Clayton                                         }
51146747022SGreg Clayton                                     }
51246747022SGreg Clayton                                 }
51346747022SGreg Clayton                                 else if (num_matches == 0)
51446747022SGreg Clayton                                 {
51546747022SGreg Clayton                                     result.GetErrorStream().Printf ("error: no variables matched the regular expression '%s'.\n", name_cstr);
51646747022SGreg Clayton                                 }
51746747022SGreg Clayton                             }
51846747022SGreg Clayton                             else
51946747022SGreg Clayton                             {
52046747022SGreg Clayton                                 char regex_error[1024];
52146747022SGreg Clayton                                 if (regex.GetErrorAsCString(regex_error, sizeof(regex_error)))
52246747022SGreg Clayton                                     result.GetErrorStream().Printf ("error: %s\n", regex_error);
52346747022SGreg Clayton                                 else
52446747022SGreg Clayton                                     result.GetErrorStream().Printf ("error: unkown regex error when compiling '%s'\n", name_cstr);
52546747022SGreg Clayton                             }
52646747022SGreg Clayton                         }
52746747022SGreg Clayton                         else
52846747022SGreg Clayton                         {
52954979cddSGreg Clayton                             Error error;
53078a685aaSJim Ingham                             uint32_t expr_path_options = StackFrame::eExpressionPathOptionCheckPtrVsMember;
5312837b766SJim Ingham                             lldb::VariableSP var_sp;
5322837b766SJim Ingham                             valobj_sp = exe_ctx.frame->GetValueForVariableExpressionPath (name_cstr,
5332837b766SJim Ingham                                                                                           m_varobj_options.use_dynamic,
5342837b766SJim Ingham                                                                                           expr_path_options,
5352837b766SJim Ingham                                                                                           var_sp,
5362837b766SJim Ingham                                                                                           error);
5376d56d2ceSJim Ingham                             if (valobj_sp)
5386d56d2ceSJim Ingham                             {
539715c2365SGreg Clayton                                 if (m_option_variable.format != eFormatDefault)
540715c2365SGreg Clayton                                     valobj_sp->SetFormat (m_option_variable.format);
541715c2365SGreg Clayton                                 if (m_option_variable.show_decl && var_sp && var_sp->GetDeclaration ().GetFile())
542a134cc1bSGreg Clayton                                 {
543a134cc1bSGreg Clayton                                     var_sp->GetDeclaration ().DumpStopContext (&s, false);
544a134cc1bSGreg Clayton                                     s.PutCString (": ");
545a134cc1bSGreg Clayton                                 }
546f9fa6ee5SEnrico Granata                                 if (summary_format_sp)
547f9fa6ee5SEnrico Granata                                     valobj_sp->SetCustomSummaryFormat(summary_format_sp);
5481d3afba3SGreg Clayton                                 ValueObject::DumpValueObject (result.GetOutputStream(),
549a134cc1bSGreg Clayton                                                               valobj_sp.get(),
55083c5cd9dSGreg Clayton                                                               valobj_sp->GetParent() ? name_cstr : NULL,
551*379447a7SEnrico Granata                                                               options);
5526d56d2ceSJim Ingham                             }
5536d56d2ceSJim Ingham                             else
5546d56d2ceSJim Ingham                             {
55554979cddSGreg Clayton                                 const char *error_cstr = error.AsCString(NULL);
55654979cddSGreg Clayton                                 if (error_cstr)
55754979cddSGreg Clayton                                     result.GetErrorStream().Printf("error: %s\n", error_cstr);
55854979cddSGreg Clayton                                 else
55954979cddSGreg Clayton                                     result.GetErrorStream().Printf ("error: unable to find any variable expression path that matches '%s'\n", name_cstr);
5606d56d2ceSJim Ingham                             }
5616d56d2ceSJim Ingham                         }
5626d56d2ceSJim Ingham                     }
56346747022SGreg Clayton                 }
5646d56d2ceSJim Ingham                 else
5656d56d2ceSJim Ingham                 {
566a134cc1bSGreg Clayton                     const uint32_t num_variables = variable_list->GetSize();
5676d56d2ceSJim Ingham 
5686d56d2ceSJim Ingham                     if (num_variables > 0)
5696d56d2ceSJim Ingham                     {
5706d56d2ceSJim Ingham                         for (uint32_t i=0; i<num_variables; i++)
5716d56d2ceSJim Ingham                         {
5721a65ae11SGreg Clayton                             var_sp = variable_list->GetVariableAtIndex(i);
57378a685aaSJim Ingham 
5746d56d2ceSJim Ingham                             bool dump_variable = true;
5756d56d2ceSJim Ingham 
576a134cc1bSGreg Clayton                             switch (var_sp->GetScope())
5776d56d2ceSJim Ingham                             {
5786d56d2ceSJim Ingham                             case eValueTypeVariableGlobal:
579715c2365SGreg Clayton                                 dump_variable = m_option_variable.show_globals;
580715c2365SGreg Clayton                                 if (dump_variable && m_option_variable.show_scope)
581a134cc1bSGreg Clayton                                     s.PutCString("GLOBAL: ");
5826d56d2ceSJim Ingham                                 break;
5836d56d2ceSJim Ingham 
5846d56d2ceSJim Ingham                             case eValueTypeVariableStatic:
585715c2365SGreg Clayton                                 dump_variable = m_option_variable.show_globals;
586715c2365SGreg Clayton                                 if (dump_variable && m_option_variable.show_scope)
587a134cc1bSGreg Clayton                                     s.PutCString("STATIC: ");
5886d56d2ceSJim Ingham                                 break;
5896d56d2ceSJim Ingham 
5906d56d2ceSJim Ingham                             case eValueTypeVariableArgument:
591715c2365SGreg Clayton                                 dump_variable = m_option_variable.show_args;
592715c2365SGreg Clayton                                 if (dump_variable && m_option_variable.show_scope)
593a134cc1bSGreg Clayton                                     s.PutCString("   ARG: ");
5946d56d2ceSJim Ingham                                 break;
5956d56d2ceSJim Ingham 
5966d56d2ceSJim Ingham                             case eValueTypeVariableLocal:
597715c2365SGreg Clayton                                 dump_variable = m_option_variable.show_locals;
598715c2365SGreg Clayton                                 if (dump_variable && m_option_variable.show_scope)
599a134cc1bSGreg Clayton                                     s.PutCString(" LOCAL: ");
6006d56d2ceSJim Ingham                                 break;
6016d56d2ceSJim Ingham 
6026d56d2ceSJim Ingham                             default:
6036d56d2ceSJim Ingham                                 break;
6046d56d2ceSJim Ingham                             }
6056d56d2ceSJim Ingham 
6066d56d2ceSJim Ingham                             if (dump_variable)
607a134cc1bSGreg Clayton                             {
608a134cc1bSGreg Clayton 
609a134cc1bSGreg Clayton                                 // Use the variable object code to make sure we are
610a134cc1bSGreg Clayton                                 // using the same APIs as the the public API will be
611a134cc1bSGreg Clayton                                 // using...
6122837b766SJim Ingham                                 valobj_sp = exe_ctx.frame->GetValueObjectForFrameVariable (var_sp,
6132837b766SJim Ingham                                                                                            m_varobj_options.use_dynamic);
614a134cc1bSGreg Clayton                                 if (valobj_sp)
615a134cc1bSGreg Clayton                                 {
616715c2365SGreg Clayton                                     if (m_option_variable.format != eFormatDefault)
617715c2365SGreg Clayton                                         valobj_sp->SetFormat (m_option_variable.format);
618ded470d3SGreg Clayton 
6196f00abd5SGreg Clayton                                     // When dumping all variables, don't print any variables
6206f00abd5SGreg Clayton                                     // that are not in scope to avoid extra unneeded output
6216035b67dSJim Ingham                                     if (valobj_sp->IsInScope ())
6226f00abd5SGreg Clayton                                     {
623715c2365SGreg Clayton                                         if (m_option_variable.show_decl && var_sp->GetDeclaration ().GetFile())
624a134cc1bSGreg Clayton                                         {
625a134cc1bSGreg Clayton                                             var_sp->GetDeclaration ().DumpStopContext (&s, false);
626a134cc1bSGreg Clayton                                             s.PutCString (": ");
627a134cc1bSGreg Clayton                                         }
628f9fa6ee5SEnrico Granata                                         if (summary_format_sp)
629f9fa6ee5SEnrico Granata                                             valobj_sp->SetCustomSummaryFormat(summary_format_sp);
6301d3afba3SGreg Clayton                                         ValueObject::DumpValueObject (result.GetOutputStream(),
631a134cc1bSGreg Clayton                                                                       valobj_sp.get(),
632a134cc1bSGreg Clayton                                                                       name_cstr,
633*379447a7SEnrico Granata                                                                       options);
634a134cc1bSGreg Clayton                                     }
635a134cc1bSGreg Clayton                                 }
6366d56d2ceSJim Ingham                             }
6376d56d2ceSJim Ingham                         }
6386d56d2ceSJim Ingham                     }
6396f00abd5SGreg Clayton                 }
6406d56d2ceSJim Ingham                 result.SetStatus (eReturnStatusSuccessFinishResult);
6416d56d2ceSJim Ingham             }
6429df87c17SGreg Clayton         }
64361a80ba6SEnrico Granata 
64461a80ba6SEnrico Granata         if (m_interpreter.TruncationWarningNecessary())
64561a80ba6SEnrico Granata         {
64661a80ba6SEnrico Granata             result.GetOutputStream().Printf(m_interpreter.TruncationWarningText(),
64761a80ba6SEnrico Granata                                             m_cmd_name.c_str());
64861a80ba6SEnrico Granata             m_interpreter.TruncationWarningGiven();
64961a80ba6SEnrico Granata         }
65061a80ba6SEnrico Granata 
6516d56d2ceSJim Ingham         return result.Succeeded();
6526d56d2ceSJim Ingham     }
6536d56d2ceSJim Ingham protected:
6546d56d2ceSJim Ingham 
6552837b766SJim Ingham     OptionGroupOptions m_option_group;
656715c2365SGreg Clayton     OptionGroupVariable m_option_variable;
6572837b766SJim Ingham     OptionGroupValueObjectDisplay m_varobj_options;
6586d56d2ceSJim Ingham };
6596d56d2ceSJim Ingham 
6602837b766SJim Ingham 
66130fdc8d8SChris Lattner #pragma mark CommandObjectMultiwordFrame
66230fdc8d8SChris Lattner 
66330fdc8d8SChris Lattner //-------------------------------------------------------------------------
66430fdc8d8SChris Lattner // CommandObjectMultiwordFrame
66530fdc8d8SChris Lattner //-------------------------------------------------------------------------
66630fdc8d8SChris Lattner 
6676611103cSGreg Clayton CommandObjectMultiwordFrame::CommandObjectMultiwordFrame (CommandInterpreter &interpreter) :
668a7015092SGreg Clayton     CommandObjectMultiword (interpreter,
669a7015092SGreg Clayton                             "frame",
67030fdc8d8SChris Lattner                             "A set of commands for operating on the current thread's frames.",
67130fdc8d8SChris Lattner                             "frame <subcommand> [<subcommand-options>]")
67230fdc8d8SChris Lattner {
673a7015092SGreg Clayton     LoadSubCommand ("info",   CommandObjectSP (new CommandObjectFrameInfo (interpreter)));
674a7015092SGreg Clayton     LoadSubCommand ("select", CommandObjectSP (new CommandObjectFrameSelect (interpreter)));
675a7015092SGreg Clayton     LoadSubCommand ("variable", CommandObjectSP (new CommandObjectFrameVariable (interpreter)));
67630fdc8d8SChris Lattner }
67730fdc8d8SChris Lattner 
67830fdc8d8SChris Lattner CommandObjectMultiwordFrame::~CommandObjectMultiwordFrame ()
67930fdc8d8SChris Lattner {
68030fdc8d8SChris Lattner }
68130fdc8d8SChris Lattner 
682