130fdc8d8SChris Lattner //===-- CommandObjectExpression.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 
1093a64300SDaniel Malea #include "lldb/lldb-python.h"
1193a64300SDaniel Malea 
1230fdc8d8SChris Lattner #include "CommandObjectExpression.h"
1330fdc8d8SChris Lattner 
1430fdc8d8SChris Lattner // C Includes
1530fdc8d8SChris Lattner // C++ Includes
1630fdc8d8SChris Lattner // Other libraries and framework includes
1730fdc8d8SChris Lattner // Project includes
18ebf7707eSSean Callanan #include "lldb/Interpreter/Args.h"
1930fdc8d8SChris Lattner #include "lldb/Core/Value.h"
2030fdc8d8SChris Lattner #include "lldb/Core/InputReader.h"
216c68fb45SJim Ingham #include "lldb/Core/ValueObjectVariable.h"
2230fdc8d8SChris Lattner #include "lldb/Expression/ClangExpressionVariable.h"
231a8d4093SSean Callanan #include "lldb/Expression/ClangUserExpression.h"
24ebb84b24SStephen Wilson #include "lldb/Expression/ClangFunction.h"
2530fdc8d8SChris Lattner #include "lldb/Expression/DWARFExpression.h"
2630fdc8d8SChris Lattner #include "lldb/Host/Host.h"
27ebf7707eSSean Callanan #include "lldb/Core/Debugger.h"
286611103cSGreg Clayton #include "lldb/Interpreter/CommandInterpreter.h"
2930fdc8d8SChris Lattner #include "lldb/Interpreter/CommandReturnObject.h"
306c68fb45SJim Ingham #include "lldb/Target/ObjCLanguageRuntime.h"
3130fdc8d8SChris Lattner #include "lldb/Symbol/ObjectFile.h"
3230fdc8d8SChris Lattner #include "lldb/Symbol/Variable.h"
3330fdc8d8SChris Lattner #include "lldb/Target/Process.h"
3430fdc8d8SChris Lattner #include "lldb/Target/StackFrame.h"
3530fdc8d8SChris Lattner #include "lldb/Target/Target.h"
367260f620SGreg Clayton #include "lldb/Target/Thread.h"
37ebf7707eSSean Callanan #include "llvm/ADT/StringRef.h"
3830fdc8d8SChris Lattner 
3930fdc8d8SChris Lattner using namespace lldb;
4030fdc8d8SChris Lattner using namespace lldb_private;
4130fdc8d8SChris Lattner 
421deb7962SGreg Clayton CommandObjectExpression::CommandOptions::CommandOptions () :
431deb7962SGreg Clayton     OptionGroup()
4430fdc8d8SChris Lattner {
4530fdc8d8SChris Lattner }
4630fdc8d8SChris Lattner 
4730fdc8d8SChris Lattner 
4830fdc8d8SChris Lattner CommandObjectExpression::CommandOptions::~CommandOptions ()
4930fdc8d8SChris Lattner {
5030fdc8d8SChris Lattner }
5130fdc8d8SChris Lattner 
521deb7962SGreg Clayton OptionDefinition
531deb7962SGreg Clayton CommandObjectExpression::CommandOptions::g_option_table[] =
541deb7962SGreg Clayton {
5535e1bda6SJim Ingham     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "all-threads",        'a', required_argument, NULL, 0, eArgTypeBoolean,    "Should we run all threads if the execution doesn't complete on one thread."},
56184e9811SJim Ingham     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "ignore-breakpoints", 'i', required_argument, NULL, 0, eArgTypeBoolean,    "Ignore breakpoint hits while running expressions"},
5735e1bda6SJim Ingham     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "timeout",            't', required_argument, NULL, 0, eArgTypeUnsignedInteger,  "Timeout value for running the expression."},
581deb7962SGreg Clayton     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "unwind-on-error",    'u', required_argument, NULL, 0, eArgTypeBoolean,    "Clean up program state if the expression causes a crash, breakpoint hit or signal."},
591deb7962SGreg Clayton };
601deb7962SGreg Clayton 
611deb7962SGreg Clayton 
621deb7962SGreg Clayton uint32_t
631deb7962SGreg Clayton CommandObjectExpression::CommandOptions::GetNumDefinitions ()
641deb7962SGreg Clayton {
651deb7962SGreg Clayton     return sizeof(g_option_table)/sizeof(OptionDefinition);
661deb7962SGreg Clayton }
671deb7962SGreg Clayton 
6830fdc8d8SChris Lattner Error
691deb7962SGreg Clayton CommandObjectExpression::CommandOptions::SetOptionValue (CommandInterpreter &interpreter,
701deb7962SGreg Clayton                                                          uint32_t option_idx,
711deb7962SGreg Clayton                                                          const char *option_arg)
7230fdc8d8SChris Lattner {
7330fdc8d8SChris Lattner     Error error;
7430fdc8d8SChris Lattner 
753bcdfc0eSGreg Clayton     const int short_option = g_option_table[option_idx].short_option;
7630fdc8d8SChris Lattner 
7730fdc8d8SChris Lattner     switch (short_option)
7830fdc8d8SChris Lattner     {
793f4c09c1SCaroline Tice       //case 'l':
803f4c09c1SCaroline Tice       //if (language.SetLanguageFromCString (option_arg) == false)
813f4c09c1SCaroline Tice       //{
8286edbf41SGreg Clayton       //    error.SetErrorStringWithFormat("invalid language option argument '%s'", option_arg);
833f4c09c1SCaroline Tice       //}
843f4c09c1SCaroline Tice       //break;
8530fdc8d8SChris Lattner 
8635e1bda6SJim Ingham     case 'a':
8735e1bda6SJim Ingham         {
8835e1bda6SJim Ingham             bool success;
8935e1bda6SJim Ingham             bool result;
9035e1bda6SJim Ingham             result = Args::StringToBoolean(option_arg, true, &success);
9135e1bda6SJim Ingham             if (!success)
9235e1bda6SJim Ingham                 error.SetErrorStringWithFormat("invalid all-threads value setting: \"%s\"", option_arg);
9335e1bda6SJim Ingham             else
9435e1bda6SJim Ingham                 try_all_threads = result;
9535e1bda6SJim Ingham         }
966c68fb45SJim Ingham         break;
976c68fb45SJim Ingham 
98184e9811SJim Ingham     case 'i':
99184e9811SJim Ingham         {
100184e9811SJim Ingham             bool success;
101184e9811SJim Ingham             bool tmp_value = Args::StringToBoolean(option_arg, true, &success);
102184e9811SJim Ingham             if (success)
103184e9811SJim Ingham                 ignore_breakpoints = tmp_value;
104184e9811SJim Ingham             else
105184e9811SJim Ingham                 error.SetErrorStringWithFormat("could not convert \"%s\" to a boolean value.", option_arg);
106184e9811SJim Ingham             break;
107184e9811SJim Ingham         }
10835e1bda6SJim Ingham     case 't':
10935e1bda6SJim Ingham         {
11035e1bda6SJim Ingham             bool success;
11135e1bda6SJim Ingham             uint32_t result;
11235e1bda6SJim Ingham             result = Args::StringToUInt32(option_arg, 0, 0, &success);
11335e1bda6SJim Ingham             if (success)
11435e1bda6SJim Ingham                 timeout = result;
11535e1bda6SJim Ingham             else
11635e1bda6SJim Ingham                 error.SetErrorStringWithFormat ("invalid timeout setting \"%s\"", option_arg);
11735e1bda6SJim Ingham         }
11835e1bda6SJim Ingham         break;
11935e1bda6SJim Ingham 
120399f1cafSJim Ingham     case 'u':
1213bfdaa2aSSean Callanan         {
122399f1cafSJim Ingham             bool success;
123184e9811SJim Ingham             bool tmp_value = Args::StringToBoolean(option_arg, true, &success);
124184e9811SJim Ingham             if (success)
125184e9811SJim Ingham                 unwind_on_error = tmp_value;
126184e9811SJim Ingham             else
12786edbf41SGreg Clayton                 error.SetErrorStringWithFormat("could not convert \"%s\" to a boolean value.", option_arg);
128399f1cafSJim Ingham             break;
1293bfdaa2aSSean Callanan         }
13030fdc8d8SChris Lattner     default:
13186edbf41SGreg Clayton         error.SetErrorStringWithFormat("invalid short option character '%c'", short_option);
13230fdc8d8SChris Lattner         break;
13330fdc8d8SChris Lattner     }
13430fdc8d8SChris Lattner 
13530fdc8d8SChris Lattner     return error;
13630fdc8d8SChris Lattner }
13730fdc8d8SChris Lattner 
13830fdc8d8SChris Lattner void
1391deb7962SGreg Clayton CommandObjectExpression::CommandOptions::OptionParsingStarting (CommandInterpreter &interpreter)
14030fdc8d8SChris Lattner {
141184e9811SJim Ingham     Process *process = interpreter.GetExecutionContext().GetProcessPtr();
142184e9811SJim Ingham     if (process != NULL)
143184e9811SJim Ingham     {
144184e9811SJim Ingham         ignore_breakpoints = process->GetIgnoreBreakpointsInExpressions();
145184e9811SJim Ingham         unwind_on_error    = process->GetUnwindOnErrorInExpressions();
146184e9811SJim Ingham     }
147184e9811SJim Ingham     else
148184e9811SJim Ingham     {
149184e9811SJim Ingham         ignore_breakpoints = false;
150399f1cafSJim Ingham         unwind_on_error = true;
151184e9811SJim Ingham     }
152184e9811SJim Ingham 
15330fdc8d8SChris Lattner     show_summary = true;
15435e1bda6SJim Ingham     try_all_threads = true;
15535e1bda6SJim Ingham     timeout = 0;
15630fdc8d8SChris Lattner }
15730fdc8d8SChris Lattner 
158e0d378b3SGreg Clayton const OptionDefinition*
15930fdc8d8SChris Lattner CommandObjectExpression::CommandOptions::GetDefinitions ()
16030fdc8d8SChris Lattner {
16130fdc8d8SChris Lattner     return g_option_table;
16230fdc8d8SChris Lattner }
16330fdc8d8SChris Lattner 
164a7015092SGreg Clayton CommandObjectExpression::CommandObjectExpression (CommandInterpreter &interpreter) :
1655a988416SJim Ingham     CommandObjectRaw (interpreter,
16630fdc8d8SChris Lattner                       "expression",
1675c48d5c5SJim Ingham                       "Evaluate a C/ObjC/C++ expression in the current program context, using user defined variables and variables currently in scope.",
1685a988416SJim Ingham                       NULL,
169f9fc609fSGreg Clayton                       eFlagProcessMustBePaused | eFlagTryTargetAPILock),
1701deb7962SGreg Clayton     m_option_group (interpreter),
1711deb7962SGreg Clayton     m_format_options (eFormatDefault),
1721deb7962SGreg Clayton     m_command_options (),
17330fdc8d8SChris Lattner     m_expr_line_count (0),
17430fdc8d8SChris Lattner     m_expr_lines ()
17530fdc8d8SChris Lattner {
17630fdc8d8SChris Lattner   SetHelpLong(
17735e1bda6SJim Ingham "Timeouts:\n\
17835e1bda6SJim Ingham     If the expression can be evaluated statically (without runnning code) then it will be.\n\
17935e1bda6SJim Ingham     Otherwise, by default the expression will run on the current thread with a short timeout:\n\
18035e1bda6SJim Ingham     currently .25 seconds.  If it doesn't return in that time, the evaluation will be interrupted\n\
18135e1bda6SJim Ingham     and resumed with all threads running.  You can use the -a option to disable retrying on all\n\
18235e1bda6SJim Ingham     threads.  You can use the -t option to set a shorter timeout.\n\
1835c48d5c5SJim Ingham \n\
1845c48d5c5SJim Ingham User defined variables:\n\
1855c48d5c5SJim Ingham     You can define your own variables for convenience or to be used in subsequent expressions.\n\
1865c48d5c5SJim Ingham     You define them the same way you would define variables in C.  If the first character of \n\
1875c48d5c5SJim Ingham     your user defined variable is a $, then the variable's value will be available in future\n\
1885c48d5c5SJim Ingham     expressions, otherwise it will just be available in the current expression.\n\
1895c48d5c5SJim Ingham \n\
19035e1bda6SJim Ingham Examples: \n\
19130fdc8d8SChris Lattner \n\
19230fdc8d8SChris Lattner    expr my_struct->a = my_array[3] \n\
19330fdc8d8SChris Lattner    expr -f bin -- (index * 8) + 5 \n\
1945c48d5c5SJim Ingham    expr unsigned int $foo = 5\n\
19530fdc8d8SChris Lattner    expr char c[] = \"foo\"; c[0]\n");
196405fe67fSCaroline Tice 
197405fe67fSCaroline Tice     CommandArgumentEntry arg;
198405fe67fSCaroline Tice     CommandArgumentData expression_arg;
199405fe67fSCaroline Tice 
200405fe67fSCaroline Tice     // Define the first (and only) variant of this arg.
201405fe67fSCaroline Tice     expression_arg.arg_type = eArgTypeExpression;
202405fe67fSCaroline Tice     expression_arg.arg_repetition = eArgRepeatPlain;
203405fe67fSCaroline Tice 
204405fe67fSCaroline Tice     // There is only one variant this argument could be; put it into the argument entry.
205405fe67fSCaroline Tice     arg.push_back (expression_arg);
206405fe67fSCaroline Tice 
207405fe67fSCaroline Tice     // Push the data for the first argument into the m_arguments vector.
208405fe67fSCaroline Tice     m_arguments.push_back (arg);
2091deb7962SGreg Clayton 
2105009f9d5SGreg Clayton     // Add the "--format" and "--gdb-format"
2115009f9d5SGreg Clayton     m_option_group.Append (&m_format_options, OptionGroupFormat::OPTION_GROUP_FORMAT | OptionGroupFormat::OPTION_GROUP_GDB_FMT, LLDB_OPT_SET_1);
2121deb7962SGreg Clayton     m_option_group.Append (&m_command_options);
213b576bba2SEnrico Granata     m_option_group.Append (&m_varobj_options, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1 | LLDB_OPT_SET_2);
2141deb7962SGreg Clayton     m_option_group.Finalize();
21530fdc8d8SChris Lattner }
21630fdc8d8SChris Lattner 
21730fdc8d8SChris Lattner CommandObjectExpression::~CommandObjectExpression ()
21830fdc8d8SChris Lattner {
21930fdc8d8SChris Lattner }
22030fdc8d8SChris Lattner 
22130fdc8d8SChris Lattner Options *
22230fdc8d8SChris Lattner CommandObjectExpression::GetOptions ()
22330fdc8d8SChris Lattner {
2241deb7962SGreg Clayton     return &m_option_group;
22530fdc8d8SChris Lattner }
22630fdc8d8SChris Lattner 
22730fdc8d8SChris Lattner size_t
22830fdc8d8SChris Lattner CommandObjectExpression::MultiLineExpressionCallback
22930fdc8d8SChris Lattner (
23030fdc8d8SChris Lattner     void *baton,
2316611103cSGreg Clayton     InputReader &reader,
23230fdc8d8SChris Lattner     lldb::InputReaderAction notification,
23330fdc8d8SChris Lattner     const char *bytes,
23430fdc8d8SChris Lattner     size_t bytes_len
23530fdc8d8SChris Lattner )
23630fdc8d8SChris Lattner {
23730fdc8d8SChris Lattner     CommandObjectExpression *cmd_object_expr = (CommandObjectExpression *) baton;
238d61c10bcSCaroline Tice     bool batch_mode = reader.GetDebugger().GetCommandInterpreter().GetBatchCommandMode();
23930fdc8d8SChris Lattner 
24030fdc8d8SChris Lattner     switch (notification)
24130fdc8d8SChris Lattner     {
24230fdc8d8SChris Lattner     case eInputReaderActivate:
243d61c10bcSCaroline Tice         if (!batch_mode)
24415356e7fSCaroline Tice         {
24507e66e3eSGreg Clayton             StreamSP async_strm_sp(reader.GetDebugger().GetAsyncOutputStream());
24607e66e3eSGreg Clayton             if (async_strm_sp)
24707e66e3eSGreg Clayton             {
24807e66e3eSGreg Clayton                 async_strm_sp->PutCString("Enter expressions, then terminate with an empty line to evaluate:\n");
24907e66e3eSGreg Clayton                 async_strm_sp->Flush();
25007e66e3eSGreg Clayton             }
25115356e7fSCaroline Tice         }
25230fdc8d8SChris Lattner         // Fall through
25330fdc8d8SChris Lattner     case eInputReaderReactivate:
25430fdc8d8SChris Lattner         break;
25530fdc8d8SChris Lattner 
25630fdc8d8SChris Lattner     case eInputReaderDeactivate:
25730fdc8d8SChris Lattner         break;
25830fdc8d8SChris Lattner 
259969ed3d1SCaroline Tice     case eInputReaderAsynchronousOutputWritten:
260969ed3d1SCaroline Tice         break;
261969ed3d1SCaroline Tice 
26230fdc8d8SChris Lattner     case eInputReaderGotToken:
26330fdc8d8SChris Lattner         ++cmd_object_expr->m_expr_line_count;
26430fdc8d8SChris Lattner         if (bytes && bytes_len)
26530fdc8d8SChris Lattner         {
26630fdc8d8SChris Lattner             cmd_object_expr->m_expr_lines.append (bytes, bytes_len + 1);
26730fdc8d8SChris Lattner         }
26830fdc8d8SChris Lattner 
26930fdc8d8SChris Lattner         if (bytes_len == 0)
2706611103cSGreg Clayton             reader.SetIsDone(true);
27130fdc8d8SChris Lattner         break;
27230fdc8d8SChris Lattner 
273efed6131SCaroline Tice     case eInputReaderInterrupt:
274efed6131SCaroline Tice         cmd_object_expr->m_expr_lines.clear();
275efed6131SCaroline Tice         reader.SetIsDone (true);
276d61c10bcSCaroline Tice         if (!batch_mode)
27715356e7fSCaroline Tice         {
27807e66e3eSGreg Clayton             StreamSP async_strm_sp (reader.GetDebugger().GetAsyncOutputStream());
27907e66e3eSGreg Clayton             if (async_strm_sp)
28007e66e3eSGreg Clayton             {
28107e66e3eSGreg Clayton                 async_strm_sp->PutCString("Expression evaluation cancelled.\n");
28207e66e3eSGreg Clayton                 async_strm_sp->Flush();
28307e66e3eSGreg Clayton             }
28415356e7fSCaroline Tice         }
285efed6131SCaroline Tice         break;
286efed6131SCaroline Tice 
287efed6131SCaroline Tice     case eInputReaderEndOfFile:
288efed6131SCaroline Tice         reader.SetIsDone (true);
289efed6131SCaroline Tice         break;
290efed6131SCaroline Tice 
29130fdc8d8SChris Lattner     case eInputReaderDone:
292efed6131SCaroline Tice 		if (cmd_object_expr->m_expr_lines.size() > 0)
29330fdc8d8SChris Lattner         {
2946e8dc334SCaroline Tice             StreamSP output_stream = reader.GetDebugger().GetAsyncOutputStream();
2956e8dc334SCaroline Tice             StreamSP error_stream = reader.GetDebugger().GetAsyncErrorStream();
29630fdc8d8SChris Lattner             cmd_object_expr->EvaluateExpression (cmd_object_expr->m_expr_lines.c_str(),
2976e8dc334SCaroline Tice                                                  output_stream.get(),
2986e8dc334SCaroline Tice                                                  error_stream.get());
2996e8dc334SCaroline Tice             output_stream->Flush();
3006e8dc334SCaroline Tice             error_stream->Flush();
30130fdc8d8SChris Lattner         }
30230fdc8d8SChris Lattner         break;
30330fdc8d8SChris Lattner     }
30430fdc8d8SChris Lattner 
30530fdc8d8SChris Lattner     return bytes_len;
30630fdc8d8SChris Lattner }
30730fdc8d8SChris Lattner 
30830fdc8d8SChris Lattner bool
3091d3afba3SGreg Clayton CommandObjectExpression::EvaluateExpression
3101d3afba3SGreg Clayton (
3111d3afba3SGreg Clayton     const char *expr,
3126e8dc334SCaroline Tice     Stream *output_stream,
3136e8dc334SCaroline Tice     Stream *error_stream,
3141d3afba3SGreg Clayton     CommandReturnObject *result
3151d3afba3SGreg Clayton )
31630fdc8d8SChris Lattner {
317*ba7b8e2cSGreg Clayton     // Don't use m_exe_ctx as this might be called asynchronously
318*ba7b8e2cSGreg Clayton     // after the command object DoExecute has finished when doing
319*ba7b8e2cSGreg Clayton     // multi-line expression that use an input reader...
320*ba7b8e2cSGreg Clayton     ExecutionContext exe_ctx (m_interpreter.GetExecutionContext());
321*ba7b8e2cSGreg Clayton 
322*ba7b8e2cSGreg Clayton     Target *target = exe_ctx.GetTargetPtr();
323c0a6e061SSean Callanan 
324c0a6e061SSean Callanan     if (!target)
325c0a6e061SSean Callanan         target = Host::GetDummyTarget(m_interpreter.GetDebugger()).get();
326c0a6e061SSean Callanan 
327c14ee32dSGreg Clayton     if (target)
3286961e878SSean Callanan     {
3298b2fe6dcSGreg Clayton         lldb::ValueObjectSP result_valobj_sp;
3308b2fe6dcSGreg Clayton 
331e0d378b3SGreg Clayton         ExecutionResults exe_results;
33292adcac9SSean Callanan 
33392adcac9SSean Callanan         bool keep_in_memory = true;
33492adcac9SSean Callanan 
33535e1bda6SJim Ingham         EvaluateExpressionOptions options;
336b576bba2SEnrico Granata         options.SetCoerceToId(m_varobj_options.use_objc)
337d4439aa9SEnrico Granata         .SetUnwindOnError(m_command_options.unwind_on_error)
338184e9811SJim Ingham         .SetIgnoreBreakpoints (m_command_options.ignore_breakpoints)
339d4439aa9SEnrico Granata         .SetKeepInMemory(keep_in_memory)
340b576bba2SEnrico Granata         .SetUseDynamic(m_varobj_options.use_dynamic)
34135e1bda6SJim Ingham         .SetRunOthers(m_command_options.try_all_threads)
34235e1bda6SJim Ingham         .SetTimeoutUsec(m_command_options.timeout);
343d4439aa9SEnrico Granata 
344c14ee32dSGreg Clayton         exe_results = target->EvaluateExpression (expr,
345*ba7b8e2cSGreg Clayton                                                   exe_ctx.GetFramePtr(),
3463372f581SEnrico Granata                                                   result_valobj_sp,
347d4439aa9SEnrico Granata                                                   options);
3488b2fe6dcSGreg Clayton 
349184e9811SJim Ingham         if ((exe_results == eExecutionInterrupted && !m_command_options.unwind_on_error)
350184e9811SJim Ingham             ||(exe_results == eExecutionHitBreakpoint && !m_command_options.ignore_breakpoints))
3518b2fe6dcSGreg Clayton         {
3527260f620SGreg Clayton             uint32_t start_frame = 0;
3537260f620SGreg Clayton             uint32_t num_frames = 1;
3547260f620SGreg Clayton             uint32_t num_frames_with_source = 0;
355*ba7b8e2cSGreg Clayton             Thread *thread = exe_ctx.GetThreadPtr();
356c14ee32dSGreg Clayton             if (thread)
3577260f620SGreg Clayton             {
358c14ee32dSGreg Clayton                 thread->GetStatus (result->GetOutputStream(),
3597260f620SGreg Clayton                                    start_frame,
3607260f620SGreg Clayton                                    num_frames,
3617260f620SGreg Clayton                                    num_frames_with_source);
3627260f620SGreg Clayton             }
363c14ee32dSGreg Clayton             else
364c14ee32dSGreg Clayton             {
365*ba7b8e2cSGreg Clayton                 Process *process = exe_ctx.GetProcessPtr();
366c14ee32dSGreg Clayton                 if (process)
3677260f620SGreg Clayton                 {
3687260f620SGreg Clayton                     bool only_threads_with_stop_reason = true;
369c14ee32dSGreg Clayton                     process->GetThreadStatus (result->GetOutputStream(),
3707260f620SGreg Clayton                                               only_threads_with_stop_reason,
3717260f620SGreg Clayton                                               start_frame,
3727260f620SGreg Clayton                                               num_frames,
3737260f620SGreg Clayton                                               num_frames_with_source);
3747260f620SGreg Clayton                 }
3756961e878SSean Callanan             }
376c14ee32dSGreg Clayton         }
3776961e878SSean Callanan 
3788b2fe6dcSGreg Clayton         if (result_valobj_sp)
3798b2fe6dcSGreg Clayton         {
380bf154daeSSean Callanan             Format format = m_format_options.GetFormat();
381bf154daeSSean Callanan 
382b71f3844SGreg Clayton             if (result_valobj_sp->GetError().Success())
38330fdc8d8SChris Lattner             {
384bf154daeSSean Callanan                 if (format != eFormatVoid)
385bf154daeSSean Callanan                 {
3861deb7962SGreg Clayton                     if (format != eFormatDefault)
3871deb7962SGreg Clayton                         result_valobj_sp->SetFormat (format);
38832c4085bSGreg Clayton 
3890c489f58SEnrico Granata                     ValueObject::DumpValueObjectOptions options;
390b576bba2SEnrico Granata                     options.SetMaximumPointerDepth(m_varobj_options.ptr_depth)
391b576bba2SEnrico Granata                     .SetMaximumDepth(m_varobj_options.max_depth)
392b576bba2SEnrico Granata                     .SetShowTypes(m_varobj_options.show_types)
393b576bba2SEnrico Granata                     .SetShowLocation(m_varobj_options.show_location)
394b576bba2SEnrico Granata                     .SetUseObjectiveC(m_varobj_options.use_objc)
395b576bba2SEnrico Granata                     .SetUseDynamicType(m_varobj_options.use_dynamic)
396b576bba2SEnrico Granata                     .SetUseSyntheticValue(m_varobj_options.use_synth)
397b576bba2SEnrico Granata                     .SetFlatOutput(m_varobj_options.flat_output)
398b576bba2SEnrico Granata                     .SetOmitSummaryDepth(m_varobj_options.no_summary_depth)
399b576bba2SEnrico Granata                     .SetIgnoreCap(m_varobj_options.ignore_cap)
4000c489f58SEnrico Granata                     .SetFormat(format)
401770eb05aSEnrico Granata                     .SetSummary()
402b576bba2SEnrico Granata                     .SetShowSummary(!m_varobj_options.use_objc)
403b576bba2SEnrico Granata                     .SetHideRootType(m_varobj_options.use_objc);
40493d59665SEnrico Granata 
40593d59665SEnrico Granata                     if (m_varobj_options.be_raw)
40693d59665SEnrico Granata                         options.SetRawDisplay(true);
407770eb05aSEnrico Granata 
4086e8dc334SCaroline Tice                     ValueObject::DumpValueObject (*(output_stream),
4090184f019SGreg Clayton                                                   result_valobj_sp.get(),   // Variable object to dump
4100c489f58SEnrico Granata                                                   options);
411fcd43b71SJohnny Chen                     if (result)
412fcd43b71SJohnny Chen                         result->SetStatus (eReturnStatusSuccessFinishResult);
41330fdc8d8SChris Lattner                 }
414bf154daeSSean Callanan             }
41530fdc8d8SChris Lattner             else
41630fdc8d8SChris Lattner             {
417bccce813SSean Callanan                 if (result_valobj_sp->GetError().GetError() == ClangUserExpression::kNoResult)
418bccce813SSean Callanan                 {
419bcf897faSSean Callanan                     if (format != eFormatVoid && m_interpreter.GetDebugger().GetNotifyVoid())
420bf154daeSSean Callanan                     {
421bcf897faSSean Callanan                         error_stream->PutCString("(void)\n");
422bcf897faSSean Callanan                     }
423bccce813SSean Callanan 
424bccce813SSean Callanan                     if (result)
425bccce813SSean Callanan                         result->SetStatus (eReturnStatusSuccessFinishResult);
426bccce813SSean Callanan                 }
427bccce813SSean Callanan                 else
428bccce813SSean Callanan                 {
4295fd05903SGreg Clayton                     const char *error_cstr = result_valobj_sp->GetError().AsCString();
4305fd05903SGreg Clayton                     if (error_cstr && error_cstr[0])
4315fd05903SGreg Clayton                     {
432c7bece56SGreg Clayton                         const size_t error_cstr_len = strlen (error_cstr);
4335fd05903SGreg Clayton                         const bool ends_with_newline = error_cstr[error_cstr_len - 1] == '\n';
4345fd05903SGreg Clayton                         if (strstr(error_cstr, "error:") != error_cstr)
4355fd05903SGreg Clayton                             error_stream->PutCString ("error: ");
4365fd05903SGreg Clayton                         error_stream->Write(error_cstr, error_cstr_len);
4375fd05903SGreg Clayton                         if (!ends_with_newline)
4385fd05903SGreg Clayton                             error_stream->EOL();
4395fd05903SGreg Clayton                     }
4405fd05903SGreg Clayton                     else
4415fd05903SGreg Clayton                     {
4425fd05903SGreg Clayton                         error_stream->PutCString ("error: unknown error\n");
4435fd05903SGreg Clayton                     }
4445fd05903SGreg Clayton 
445fcd43b71SJohnny Chen                     if (result)
446b71f3844SGreg Clayton                         result->SetStatus (eReturnStatusFailed);
44730fdc8d8SChris Lattner                 }
4488b2fe6dcSGreg Clayton             }
4498b2fe6dcSGreg Clayton         }
450bccce813SSean Callanan     }
4518b2fe6dcSGreg Clayton     else
4528b2fe6dcSGreg Clayton     {
4536e8dc334SCaroline Tice         error_stream->Printf ("error: invalid execution context for expression\n");
4548b2fe6dcSGreg Clayton         return false;
4558b2fe6dcSGreg Clayton     }
45630fdc8d8SChris Lattner 
45716ad5faeSSean Callanan     return true;
45830fdc8d8SChris Lattner }
45930fdc8d8SChris Lattner 
46030fdc8d8SChris Lattner bool
4615a988416SJim Ingham CommandObjectExpression::DoExecute
46230fdc8d8SChris Lattner (
46330fdc8d8SChris Lattner     const char *command,
46430fdc8d8SChris Lattner     CommandReturnObject &result
46530fdc8d8SChris Lattner )
46630fdc8d8SChris Lattner {
4671deb7962SGreg Clayton     m_option_group.NotifyOptionParsingStarting();
46830fdc8d8SChris Lattner 
46930fdc8d8SChris Lattner     const char * expr = NULL;
47030fdc8d8SChris Lattner 
47130fdc8d8SChris Lattner     if (command[0] == '\0')
47230fdc8d8SChris Lattner     {
47330fdc8d8SChris Lattner         m_expr_lines.clear();
47430fdc8d8SChris Lattner         m_expr_line_count = 0;
47530fdc8d8SChris Lattner 
476a7015092SGreg Clayton         InputReaderSP reader_sp (new InputReader(m_interpreter.GetDebugger()));
47730fdc8d8SChris Lattner         if (reader_sp)
47830fdc8d8SChris Lattner         {
47930fdc8d8SChris Lattner             Error err (reader_sp->Initialize (CommandObjectExpression::MultiLineExpressionCallback,
48030fdc8d8SChris Lattner                                               this,                         // baton
48130fdc8d8SChris Lattner                                               eInputReaderGranularityLine,  // token size, to pass to callback function
48230fdc8d8SChris Lattner                                               NULL,                         // end token
48330fdc8d8SChris Lattner                                               NULL,                         // prompt
48430fdc8d8SChris Lattner                                               true));                       // echo input
48530fdc8d8SChris Lattner             if (err.Success())
48630fdc8d8SChris Lattner             {
487a7015092SGreg Clayton                 m_interpreter.GetDebugger().PushInputReader (reader_sp);
48830fdc8d8SChris Lattner                 result.SetStatus (eReturnStatusSuccessFinishNoResult);
48930fdc8d8SChris Lattner             }
49030fdc8d8SChris Lattner             else
49130fdc8d8SChris Lattner             {
49230fdc8d8SChris Lattner                 result.AppendError (err.AsCString());
49330fdc8d8SChris Lattner                 result.SetStatus (eReturnStatusFailed);
49430fdc8d8SChris Lattner             }
49530fdc8d8SChris Lattner         }
49630fdc8d8SChris Lattner         else
49730fdc8d8SChris Lattner         {
49830fdc8d8SChris Lattner             result.AppendError("out of memory");
49930fdc8d8SChris Lattner             result.SetStatus (eReturnStatusFailed);
50030fdc8d8SChris Lattner         }
50130fdc8d8SChris Lattner         return result.Succeeded();
50230fdc8d8SChris Lattner     }
50330fdc8d8SChris Lattner 
50430fdc8d8SChris Lattner     if (command[0] == '-')
50530fdc8d8SChris Lattner     {
50630fdc8d8SChris Lattner         // We have some options and these options MUST end with --.
50730fdc8d8SChris Lattner         const char *end_options = NULL;
50830fdc8d8SChris Lattner         const char *s = command;
50930fdc8d8SChris Lattner         while (s && s[0])
51030fdc8d8SChris Lattner         {
51130fdc8d8SChris Lattner             end_options = ::strstr (s, "--");
51230fdc8d8SChris Lattner             if (end_options)
51330fdc8d8SChris Lattner             {
51430fdc8d8SChris Lattner                 end_options += 2; // Get past the "--"
51530fdc8d8SChris Lattner                 if (::isspace (end_options[0]))
51630fdc8d8SChris Lattner                 {
51730fdc8d8SChris Lattner                     expr = end_options;
51830fdc8d8SChris Lattner                     while (::isspace (*expr))
51930fdc8d8SChris Lattner                         ++expr;
52030fdc8d8SChris Lattner                     break;
52130fdc8d8SChris Lattner                 }
52230fdc8d8SChris Lattner             }
52330fdc8d8SChris Lattner             s = end_options;
52430fdc8d8SChris Lattner         }
52530fdc8d8SChris Lattner 
52630fdc8d8SChris Lattner         if (end_options)
52730fdc8d8SChris Lattner         {
52830fdc8d8SChris Lattner             Args args (command, end_options - command);
529a7015092SGreg Clayton             if (!ParseOptions (args, result))
53030fdc8d8SChris Lattner                 return false;
531f6b8b581SGreg Clayton 
5321deb7962SGreg Clayton             Error error (m_option_group.NotifyOptionParsingFinished());
533f6b8b581SGreg Clayton             if (error.Fail())
534f6b8b581SGreg Clayton             {
535f6b8b581SGreg Clayton                 result.AppendError (error.AsCString());
536f6b8b581SGreg Clayton                 result.SetStatus (eReturnStatusFailed);
537f6b8b581SGreg Clayton                 return false;
538f6b8b581SGreg Clayton             }
53930fdc8d8SChris Lattner         }
54030fdc8d8SChris Lattner     }
54130fdc8d8SChris Lattner 
54230fdc8d8SChris Lattner     if (expr == NULL)
54330fdc8d8SChris Lattner         expr = command;
54430fdc8d8SChris Lattner 
5456e8dc334SCaroline Tice     if (EvaluateExpression (expr, &(result.GetOutputStream()), &(result.GetErrorStream()), &result))
546fcd43b71SJohnny Chen         return true;
547fcd43b71SJohnny Chen 
548fcd43b71SJohnny Chen     result.SetStatus (eReturnStatusFailed);
549fcd43b71SJohnny Chen     return false;
55030fdc8d8SChris Lattner }
55130fdc8d8SChris Lattner 
552