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"
224d93b8cdSEnrico Granata #include "lldb/DataFormatters/ValueObjectPrinter.h"
2330fdc8d8SChris Lattner #include "lldb/Expression/ClangExpressionVariable.h"
241a8d4093SSean Callanan #include "lldb/Expression/ClangUserExpression.h"
25ebb84b24SStephen Wilson #include "lldb/Expression/ClangFunction.h"
2630fdc8d8SChris Lattner #include "lldb/Expression/DWARFExpression.h"
2730fdc8d8SChris Lattner #include "lldb/Host/Host.h"
28ebf7707eSSean Callanan #include "lldb/Core/Debugger.h"
296611103cSGreg Clayton #include "lldb/Interpreter/CommandInterpreter.h"
3030fdc8d8SChris Lattner #include "lldb/Interpreter/CommandReturnObject.h"
316c68fb45SJim Ingham #include "lldb/Target/ObjCLanguageRuntime.h"
3230fdc8d8SChris Lattner #include "lldb/Symbol/ObjectFile.h"
3330fdc8d8SChris Lattner #include "lldb/Symbol/Variable.h"
3430fdc8d8SChris Lattner #include "lldb/Target/Process.h"
35b57e4a1bSJason Molenda #include "lldb/Target/StackFrame.h"
3630fdc8d8SChris Lattner #include "lldb/Target/Target.h"
377260f620SGreg Clayton #include "lldb/Target/Thread.h"
38ebf7707eSSean Callanan #include "llvm/ADT/StringRef.h"
3930fdc8d8SChris Lattner 
4030fdc8d8SChris Lattner using namespace lldb;
4130fdc8d8SChris Lattner using namespace lldb_private;
4230fdc8d8SChris Lattner 
431deb7962SGreg Clayton CommandObjectExpression::CommandOptions::CommandOptions () :
441deb7962SGreg Clayton     OptionGroup()
4530fdc8d8SChris Lattner {
4630fdc8d8SChris Lattner }
4730fdc8d8SChris Lattner 
4830fdc8d8SChris Lattner 
4930fdc8d8SChris Lattner CommandObjectExpression::CommandOptions::~CommandOptions ()
5030fdc8d8SChris Lattner {
5130fdc8d8SChris Lattner }
5230fdc8d8SChris Lattner 
534d93b8cdSEnrico Granata static OptionEnumValueElement g_description_verbosity_type[] =
544d93b8cdSEnrico Granata {
554d93b8cdSEnrico Granata     { eLanguageRuntimeDescriptionDisplayVerbosityCompact,      "compact",       "Only show the description string"},
564d93b8cdSEnrico Granata     { eLanguageRuntimeDescriptionDisplayVerbosityFull,         "full",          "Show the full output, including persistent variable's name and type"},
574d93b8cdSEnrico Granata     { 0, NULL, NULL }
584d93b8cdSEnrico Granata };
594d93b8cdSEnrico Granata 
601deb7962SGreg Clayton OptionDefinition
611deb7962SGreg Clayton CommandObjectExpression::CommandOptions::g_option_table[] =
621deb7962SGreg Clayton {
63e2607b50SVirgile Bello     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "all-threads",        'a', OptionParser::eRequiredArgument, NULL, 0, eArgTypeBoolean,    "Should we run all threads if the execution doesn't complete on one thread."},
64e2607b50SVirgile Bello     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "ignore-breakpoints", 'i', OptionParser::eRequiredArgument, NULL, 0, eArgTypeBoolean,    "Ignore breakpoint hits while running expressions"},
65e2607b50SVirgile Bello     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "timeout",            't', OptionParser::eRequiredArgument, NULL, 0, eArgTypeUnsignedInteger,  "Timeout value (in microseconds) for running the expression."},
66e2607b50SVirgile Bello     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "unwind-on-error",    'u', OptionParser::eRequiredArgument, NULL, 0, eArgTypeBoolean,    "Clean up program state if the expression causes a crash, or raises a signal.  Note, unlike gdb hitting a breakpoint is controlled by another option (-i)."},
6762afb9f6SGreg Clayton     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "debug",              'g', OptionParser::eNoArgument      , NULL, 0, eArgTypeNone,       "When specified, debug the JIT code by setting a breakpoint on the first instruction and forcing breakpoints to not be ignored (-i0) and no unwinding to happen on error (-u0)."},
684d93b8cdSEnrico Granata     { LLDB_OPT_SET_1, false, "description-verbosity", 'v', OptionParser::eOptionalArgument, g_description_verbosity_type, 0, eArgTypeDescriptionVerbosity,        "How verbose should the output of this expression be, if the object description is asked for."},
691deb7962SGreg Clayton };
701deb7962SGreg Clayton 
711deb7962SGreg Clayton 
721deb7962SGreg Clayton uint32_t
731deb7962SGreg Clayton CommandObjectExpression::CommandOptions::GetNumDefinitions ()
741deb7962SGreg Clayton {
751deb7962SGreg Clayton     return sizeof(g_option_table)/sizeof(OptionDefinition);
761deb7962SGreg Clayton }
771deb7962SGreg Clayton 
7830fdc8d8SChris Lattner Error
791deb7962SGreg Clayton CommandObjectExpression::CommandOptions::SetOptionValue (CommandInterpreter &interpreter,
801deb7962SGreg Clayton                                                          uint32_t option_idx,
811deb7962SGreg Clayton                                                          const char *option_arg)
8230fdc8d8SChris Lattner {
8330fdc8d8SChris Lattner     Error error;
8430fdc8d8SChris Lattner 
853bcdfc0eSGreg Clayton     const int short_option = g_option_table[option_idx].short_option;
8630fdc8d8SChris Lattner 
8730fdc8d8SChris Lattner     switch (short_option)
8830fdc8d8SChris Lattner     {
893f4c09c1SCaroline Tice       //case 'l':
903f4c09c1SCaroline Tice       //if (language.SetLanguageFromCString (option_arg) == false)
913f4c09c1SCaroline Tice       //{
9286edbf41SGreg Clayton       //    error.SetErrorStringWithFormat("invalid language option argument '%s'", option_arg);
933f4c09c1SCaroline Tice       //}
943f4c09c1SCaroline Tice       //break;
9530fdc8d8SChris Lattner 
9635e1bda6SJim Ingham     case 'a':
9735e1bda6SJim Ingham         {
9835e1bda6SJim Ingham             bool success;
9935e1bda6SJim Ingham             bool result;
10035e1bda6SJim Ingham             result = Args::StringToBoolean(option_arg, true, &success);
10135e1bda6SJim Ingham             if (!success)
10235e1bda6SJim Ingham                 error.SetErrorStringWithFormat("invalid all-threads value setting: \"%s\"", option_arg);
10335e1bda6SJim Ingham             else
10435e1bda6SJim Ingham                 try_all_threads = result;
10535e1bda6SJim Ingham         }
1066c68fb45SJim Ingham         break;
1076c68fb45SJim Ingham 
108184e9811SJim Ingham     case 'i':
109184e9811SJim Ingham         {
110184e9811SJim Ingham             bool success;
111184e9811SJim Ingham             bool tmp_value = Args::StringToBoolean(option_arg, true, &success);
112184e9811SJim Ingham             if (success)
113184e9811SJim Ingham                 ignore_breakpoints = tmp_value;
114184e9811SJim Ingham             else
115184e9811SJim Ingham                 error.SetErrorStringWithFormat("could not convert \"%s\" to a boolean value.", option_arg);
116184e9811SJim Ingham             break;
117184e9811SJim Ingham         }
11835e1bda6SJim Ingham     case 't':
11935e1bda6SJim Ingham         {
12035e1bda6SJim Ingham             bool success;
12135e1bda6SJim Ingham             uint32_t result;
12235e1bda6SJim Ingham             result = Args::StringToUInt32(option_arg, 0, 0, &success);
12335e1bda6SJim Ingham             if (success)
12435e1bda6SJim Ingham                 timeout = result;
12535e1bda6SJim Ingham             else
12635e1bda6SJim Ingham                 error.SetErrorStringWithFormat ("invalid timeout setting \"%s\"", option_arg);
12735e1bda6SJim Ingham         }
12835e1bda6SJim Ingham         break;
12935e1bda6SJim Ingham 
130399f1cafSJim Ingham     case 'u':
1313bfdaa2aSSean Callanan         {
132399f1cafSJim Ingham             bool success;
133184e9811SJim Ingham             bool tmp_value = Args::StringToBoolean(option_arg, true, &success);
134184e9811SJim Ingham             if (success)
135184e9811SJim Ingham                 unwind_on_error = tmp_value;
136184e9811SJim Ingham             else
13786edbf41SGreg Clayton                 error.SetErrorStringWithFormat("could not convert \"%s\" to a boolean value.", option_arg);
138399f1cafSJim Ingham             break;
1393bfdaa2aSSean Callanan         }
1404d93b8cdSEnrico Granata 
1414d93b8cdSEnrico Granata     case 'v':
1424d93b8cdSEnrico Granata         if (!option_arg)
1434d93b8cdSEnrico Granata         {
1444d93b8cdSEnrico Granata             m_verbosity = eLanguageRuntimeDescriptionDisplayVerbosityFull;
1454d93b8cdSEnrico Granata             break;
1464d93b8cdSEnrico Granata         }
1474d93b8cdSEnrico Granata         m_verbosity = (LanguageRuntimeDescriptionDisplayVerbosity) Args::StringToOptionEnum(option_arg, g_option_table[option_idx].enum_values, 0, error);
1484d93b8cdSEnrico Granata         if (!error.Success())
1494d93b8cdSEnrico Granata             error.SetErrorStringWithFormat ("unrecognized value for description-verbosity '%s'", option_arg);
1504d93b8cdSEnrico Granata         break;
1514d93b8cdSEnrico Granata 
15262afb9f6SGreg Clayton     case 'g':
15362afb9f6SGreg Clayton         debug = true;
15462afb9f6SGreg Clayton         unwind_on_error = false;
15562afb9f6SGreg Clayton         ignore_breakpoints = false;
15662afb9f6SGreg Clayton         break;
15762afb9f6SGreg Clayton 
15830fdc8d8SChris Lattner     default:
15986edbf41SGreg Clayton         error.SetErrorStringWithFormat("invalid short option character '%c'", short_option);
16030fdc8d8SChris Lattner         break;
16130fdc8d8SChris Lattner     }
16230fdc8d8SChris Lattner 
16330fdc8d8SChris Lattner     return error;
16430fdc8d8SChris Lattner }
16530fdc8d8SChris Lattner 
16630fdc8d8SChris Lattner void
1671deb7962SGreg Clayton CommandObjectExpression::CommandOptions::OptionParsingStarting (CommandInterpreter &interpreter)
16830fdc8d8SChris Lattner {
169184e9811SJim Ingham     Process *process = interpreter.GetExecutionContext().GetProcessPtr();
170184e9811SJim Ingham     if (process != NULL)
171184e9811SJim Ingham     {
172184e9811SJim Ingham         ignore_breakpoints = process->GetIgnoreBreakpointsInExpressions();
173184e9811SJim Ingham         unwind_on_error    = process->GetUnwindOnErrorInExpressions();
174184e9811SJim Ingham     }
175184e9811SJim Ingham     else
176184e9811SJim Ingham     {
177184e9811SJim Ingham         ignore_breakpoints = false;
178399f1cafSJim Ingham         unwind_on_error = true;
179184e9811SJim Ingham     }
180184e9811SJim Ingham 
18130fdc8d8SChris Lattner     show_summary = true;
18235e1bda6SJim Ingham     try_all_threads = true;
18335e1bda6SJim Ingham     timeout = 0;
18462afb9f6SGreg Clayton     debug = false;
1854d93b8cdSEnrico Granata     m_verbosity = eLanguageRuntimeDescriptionDisplayVerbosityCompact;
18630fdc8d8SChris Lattner }
18730fdc8d8SChris Lattner 
188e0d378b3SGreg Clayton const OptionDefinition*
18930fdc8d8SChris Lattner CommandObjectExpression::CommandOptions::GetDefinitions ()
19030fdc8d8SChris Lattner {
19130fdc8d8SChris Lattner     return g_option_table;
19230fdc8d8SChris Lattner }
19330fdc8d8SChris Lattner 
194a7015092SGreg Clayton CommandObjectExpression::CommandObjectExpression (CommandInterpreter &interpreter) :
1955a988416SJim Ingham     CommandObjectRaw (interpreter,
19630fdc8d8SChris Lattner                       "expression",
1975c48d5c5SJim Ingham                       "Evaluate a C/ObjC/C++ expression in the current program context, using user defined variables and variables currently in scope.",
1985a988416SJim Ingham                       NULL,
199f9fc609fSGreg Clayton                       eFlagProcessMustBePaused | eFlagTryTargetAPILock),
2001deb7962SGreg Clayton     m_option_group (interpreter),
2011deb7962SGreg Clayton     m_format_options (eFormatDefault),
2021deb7962SGreg Clayton     m_command_options (),
20330fdc8d8SChris Lattner     m_expr_line_count (0),
20430fdc8d8SChris Lattner     m_expr_lines ()
20530fdc8d8SChris Lattner {
20630fdc8d8SChris Lattner   SetHelpLong(
20735e1bda6SJim Ingham "Timeouts:\n\
20835e1bda6SJim Ingham     If the expression can be evaluated statically (without runnning code) then it will be.\n\
20935e1bda6SJim Ingham     Otherwise, by default the expression will run on the current thread with a short timeout:\n\
21035e1bda6SJim Ingham     currently .25 seconds.  If it doesn't return in that time, the evaluation will be interrupted\n\
21135e1bda6SJim Ingham     and resumed with all threads running.  You can use the -a option to disable retrying on all\n\
21235e1bda6SJim Ingham     threads.  You can use the -t option to set a shorter timeout.\n\
2135c48d5c5SJim Ingham \n\
2145c48d5c5SJim Ingham User defined variables:\n\
2155c48d5c5SJim Ingham     You can define your own variables for convenience or to be used in subsequent expressions.\n\
2165c48d5c5SJim Ingham     You define them the same way you would define variables in C.  If the first character of \n\
2175c48d5c5SJim Ingham     your user defined variable is a $, then the variable's value will be available in future\n\
2185c48d5c5SJim Ingham     expressions, otherwise it will just be available in the current expression.\n\
2195c48d5c5SJim Ingham \n\
22035e1bda6SJim Ingham Examples: \n\
22130fdc8d8SChris Lattner \n\
22230fdc8d8SChris Lattner    expr my_struct->a = my_array[3] \n\
22330fdc8d8SChris Lattner    expr -f bin -- (index * 8) + 5 \n\
2245c48d5c5SJim Ingham    expr unsigned int $foo = 5\n\
22530fdc8d8SChris Lattner    expr char c[] = \"foo\"; c[0]\n");
226405fe67fSCaroline Tice 
227405fe67fSCaroline Tice     CommandArgumentEntry arg;
228405fe67fSCaroline Tice     CommandArgumentData expression_arg;
229405fe67fSCaroline Tice 
230405fe67fSCaroline Tice     // Define the first (and only) variant of this arg.
231405fe67fSCaroline Tice     expression_arg.arg_type = eArgTypeExpression;
232405fe67fSCaroline Tice     expression_arg.arg_repetition = eArgRepeatPlain;
233405fe67fSCaroline Tice 
234405fe67fSCaroline Tice     // There is only one variant this argument could be; put it into the argument entry.
235405fe67fSCaroline Tice     arg.push_back (expression_arg);
236405fe67fSCaroline Tice 
237405fe67fSCaroline Tice     // Push the data for the first argument into the m_arguments vector.
238405fe67fSCaroline Tice     m_arguments.push_back (arg);
2391deb7962SGreg Clayton 
2405009f9d5SGreg Clayton     // Add the "--format" and "--gdb-format"
2415009f9d5SGreg Clayton     m_option_group.Append (&m_format_options, OptionGroupFormat::OPTION_GROUP_FORMAT | OptionGroupFormat::OPTION_GROUP_GDB_FMT, LLDB_OPT_SET_1);
2421deb7962SGreg Clayton     m_option_group.Append (&m_command_options);
243b576bba2SEnrico Granata     m_option_group.Append (&m_varobj_options, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1 | LLDB_OPT_SET_2);
2441deb7962SGreg Clayton     m_option_group.Finalize();
24530fdc8d8SChris Lattner }
24630fdc8d8SChris Lattner 
24730fdc8d8SChris Lattner CommandObjectExpression::~CommandObjectExpression ()
24830fdc8d8SChris Lattner {
24930fdc8d8SChris Lattner }
25030fdc8d8SChris Lattner 
25130fdc8d8SChris Lattner Options *
25230fdc8d8SChris Lattner CommandObjectExpression::GetOptions ()
25330fdc8d8SChris Lattner {
2541deb7962SGreg Clayton     return &m_option_group;
25530fdc8d8SChris Lattner }
25630fdc8d8SChris Lattner 
25730fdc8d8SChris Lattner size_t
25830fdc8d8SChris Lattner CommandObjectExpression::MultiLineExpressionCallback
25930fdc8d8SChris Lattner (
26030fdc8d8SChris Lattner     void *baton,
2616611103cSGreg Clayton     InputReader &reader,
26230fdc8d8SChris Lattner     lldb::InputReaderAction notification,
26330fdc8d8SChris Lattner     const char *bytes,
26430fdc8d8SChris Lattner     size_t bytes_len
26530fdc8d8SChris Lattner )
26630fdc8d8SChris Lattner {
26730fdc8d8SChris Lattner     CommandObjectExpression *cmd_object_expr = (CommandObjectExpression *) baton;
268d61c10bcSCaroline Tice     bool batch_mode = reader.GetDebugger().GetCommandInterpreter().GetBatchCommandMode();
26930fdc8d8SChris Lattner 
27030fdc8d8SChris Lattner     switch (notification)
27130fdc8d8SChris Lattner     {
27230fdc8d8SChris Lattner     case eInputReaderActivate:
273d61c10bcSCaroline Tice         if (!batch_mode)
27415356e7fSCaroline Tice         {
27507e66e3eSGreg Clayton             StreamSP async_strm_sp(reader.GetDebugger().GetAsyncOutputStream());
27607e66e3eSGreg Clayton             if (async_strm_sp)
27707e66e3eSGreg Clayton             {
27807e66e3eSGreg Clayton                 async_strm_sp->PutCString("Enter expressions, then terminate with an empty line to evaluate:\n");
27907e66e3eSGreg Clayton                 async_strm_sp->Flush();
28007e66e3eSGreg Clayton             }
28115356e7fSCaroline Tice         }
28230fdc8d8SChris Lattner         // Fall through
28330fdc8d8SChris Lattner     case eInputReaderReactivate:
28430fdc8d8SChris Lattner         break;
28530fdc8d8SChris Lattner 
28630fdc8d8SChris Lattner     case eInputReaderDeactivate:
28730fdc8d8SChris Lattner         break;
28830fdc8d8SChris Lattner 
289969ed3d1SCaroline Tice     case eInputReaderAsynchronousOutputWritten:
290969ed3d1SCaroline Tice         break;
291969ed3d1SCaroline Tice 
29230fdc8d8SChris Lattner     case eInputReaderGotToken:
29330fdc8d8SChris Lattner         ++cmd_object_expr->m_expr_line_count;
29430fdc8d8SChris Lattner         if (bytes && bytes_len)
29530fdc8d8SChris Lattner         {
29630fdc8d8SChris Lattner             cmd_object_expr->m_expr_lines.append (bytes, bytes_len + 1);
29730fdc8d8SChris Lattner         }
29830fdc8d8SChris Lattner 
29930fdc8d8SChris Lattner         if (bytes_len == 0)
3006611103cSGreg Clayton             reader.SetIsDone(true);
30130fdc8d8SChris Lattner         break;
30230fdc8d8SChris Lattner 
303efed6131SCaroline Tice     case eInputReaderInterrupt:
304efed6131SCaroline Tice         cmd_object_expr->m_expr_lines.clear();
305efed6131SCaroline Tice         reader.SetIsDone (true);
306d61c10bcSCaroline Tice         if (!batch_mode)
30715356e7fSCaroline Tice         {
30807e66e3eSGreg Clayton             StreamSP async_strm_sp (reader.GetDebugger().GetAsyncOutputStream());
30907e66e3eSGreg Clayton             if (async_strm_sp)
31007e66e3eSGreg Clayton             {
31107e66e3eSGreg Clayton                 async_strm_sp->PutCString("Expression evaluation cancelled.\n");
31207e66e3eSGreg Clayton                 async_strm_sp->Flush();
31307e66e3eSGreg Clayton             }
31415356e7fSCaroline Tice         }
315efed6131SCaroline Tice         break;
316efed6131SCaroline Tice 
317efed6131SCaroline Tice     case eInputReaderEndOfFile:
318efed6131SCaroline Tice         reader.SetIsDone (true);
319efed6131SCaroline Tice         break;
320efed6131SCaroline Tice 
32130fdc8d8SChris Lattner     case eInputReaderDone:
322efed6131SCaroline Tice 		if (cmd_object_expr->m_expr_lines.size() > 0)
32330fdc8d8SChris Lattner         {
3246e8dc334SCaroline Tice             StreamSP output_stream = reader.GetDebugger().GetAsyncOutputStream();
3256e8dc334SCaroline Tice             StreamSP error_stream = reader.GetDebugger().GetAsyncErrorStream();
32630fdc8d8SChris Lattner             cmd_object_expr->EvaluateExpression (cmd_object_expr->m_expr_lines.c_str(),
3276e8dc334SCaroline Tice                                                  output_stream.get(),
3286e8dc334SCaroline Tice                                                  error_stream.get());
3296e8dc334SCaroline Tice             output_stream->Flush();
3306e8dc334SCaroline Tice             error_stream->Flush();
33130fdc8d8SChris Lattner         }
33230fdc8d8SChris Lattner         break;
33330fdc8d8SChris Lattner     }
33430fdc8d8SChris Lattner 
33530fdc8d8SChris Lattner     return bytes_len;
33630fdc8d8SChris Lattner }
33730fdc8d8SChris Lattner 
33830fdc8d8SChris Lattner bool
3391d3afba3SGreg Clayton CommandObjectExpression::EvaluateExpression
3401d3afba3SGreg Clayton (
3411d3afba3SGreg Clayton     const char *expr,
3426e8dc334SCaroline Tice     Stream *output_stream,
3436e8dc334SCaroline Tice     Stream *error_stream,
3441d3afba3SGreg Clayton     CommandReturnObject *result
3451d3afba3SGreg Clayton )
34630fdc8d8SChris Lattner {
347ba7b8e2cSGreg Clayton     // Don't use m_exe_ctx as this might be called asynchronously
348ba7b8e2cSGreg Clayton     // after the command object DoExecute has finished when doing
349ba7b8e2cSGreg Clayton     // multi-line expression that use an input reader...
350ba7b8e2cSGreg Clayton     ExecutionContext exe_ctx (m_interpreter.GetExecutionContext());
351ba7b8e2cSGreg Clayton 
352ba7b8e2cSGreg Clayton     Target *target = exe_ctx.GetTargetPtr();
353c0a6e061SSean Callanan 
354c0a6e061SSean Callanan     if (!target)
355c0a6e061SSean Callanan         target = Host::GetDummyTarget(m_interpreter.GetDebugger()).get();
356c0a6e061SSean Callanan 
357c14ee32dSGreg Clayton     if (target)
3586961e878SSean Callanan     {
3598b2fe6dcSGreg Clayton         lldb::ValueObjectSP result_valobj_sp;
3608b2fe6dcSGreg Clayton 
361e0d378b3SGreg Clayton         ExecutionResults exe_results;
36292adcac9SSean Callanan 
36392adcac9SSean Callanan         bool keep_in_memory = true;
36492adcac9SSean Callanan 
36535e1bda6SJim Ingham         EvaluateExpressionOptions options;
366*6fbc48bcSJim Ingham         options.SetCoerceToId(m_varobj_options.use_objc);
367*6fbc48bcSJim Ingham         options.SetUnwindOnError(m_command_options.unwind_on_error);
368*6fbc48bcSJim Ingham         options.SetIgnoreBreakpoints (m_command_options.ignore_breakpoints);
369*6fbc48bcSJim Ingham         options.SetKeepInMemory(keep_in_memory);
370*6fbc48bcSJim Ingham         options.SetUseDynamic(m_varobj_options.use_dynamic);
371*6fbc48bcSJim Ingham         options.SetTryAllThreads(m_command_options.try_all_threads);
372*6fbc48bcSJim Ingham         options.SetDebug(m_command_options.debug);
37362afb9f6SGreg Clayton 
37462afb9f6SGreg Clayton         if (m_command_options.timeout > 0)
37562afb9f6SGreg Clayton             options.SetTimeoutUsec(m_command_options.timeout);
376d4439aa9SEnrico Granata 
377c14ee32dSGreg Clayton         exe_results = target->EvaluateExpression (expr,
378ba7b8e2cSGreg Clayton                                                   exe_ctx.GetFramePtr(),
3793372f581SEnrico Granata                                                   result_valobj_sp,
380d4439aa9SEnrico Granata                                                   options);
3818b2fe6dcSGreg Clayton 
3828b2fe6dcSGreg Clayton         if (result_valobj_sp)
3838b2fe6dcSGreg Clayton         {
384bf154daeSSean Callanan             Format format = m_format_options.GetFormat();
385bf154daeSSean Callanan 
386b71f3844SGreg Clayton             if (result_valobj_sp->GetError().Success())
38730fdc8d8SChris Lattner             {
388bf154daeSSean Callanan                 if (format != eFormatVoid)
389bf154daeSSean Callanan                 {
3901deb7962SGreg Clayton                     if (format != eFormatDefault)
3911deb7962SGreg Clayton                         result_valobj_sp->SetFormat (format);
39232c4085bSGreg Clayton 
3934d93b8cdSEnrico Granata                     DumpValueObjectOptions options(m_varobj_options.GetAsDumpOptions(m_command_options.m_verbosity,format));
394770eb05aSEnrico Granata 
3954d93b8cdSEnrico Granata                     result_valobj_sp->Dump(*output_stream,options);
3964d93b8cdSEnrico Granata 
397fcd43b71SJohnny Chen                     if (result)
398fcd43b71SJohnny Chen                         result->SetStatus (eReturnStatusSuccessFinishResult);
39930fdc8d8SChris Lattner                 }
400bf154daeSSean Callanan             }
40130fdc8d8SChris Lattner             else
40230fdc8d8SChris Lattner             {
403bccce813SSean Callanan                 if (result_valobj_sp->GetError().GetError() == ClangUserExpression::kNoResult)
404bccce813SSean Callanan                 {
405bcf897faSSean Callanan                     if (format != eFormatVoid && m_interpreter.GetDebugger().GetNotifyVoid())
406bf154daeSSean Callanan                     {
407bcf897faSSean Callanan                         error_stream->PutCString("(void)\n");
408bcf897faSSean Callanan                     }
409bccce813SSean Callanan 
410bccce813SSean Callanan                     if (result)
411bccce813SSean Callanan                         result->SetStatus (eReturnStatusSuccessFinishResult);
412bccce813SSean Callanan                 }
413bccce813SSean Callanan                 else
414bccce813SSean Callanan                 {
4155fd05903SGreg Clayton                     const char *error_cstr = result_valobj_sp->GetError().AsCString();
4165fd05903SGreg Clayton                     if (error_cstr && error_cstr[0])
4175fd05903SGreg Clayton                     {
418c7bece56SGreg Clayton                         const size_t error_cstr_len = strlen (error_cstr);
4195fd05903SGreg Clayton                         const bool ends_with_newline = error_cstr[error_cstr_len - 1] == '\n';
4205fd05903SGreg Clayton                         if (strstr(error_cstr, "error:") != error_cstr)
4215fd05903SGreg Clayton                             error_stream->PutCString ("error: ");
4225fd05903SGreg Clayton                         error_stream->Write(error_cstr, error_cstr_len);
4235fd05903SGreg Clayton                         if (!ends_with_newline)
4245fd05903SGreg Clayton                             error_stream->EOL();
4255fd05903SGreg Clayton                     }
4265fd05903SGreg Clayton                     else
4275fd05903SGreg Clayton                     {
4285fd05903SGreg Clayton                         error_stream->PutCString ("error: unknown error\n");
4295fd05903SGreg Clayton                     }
4305fd05903SGreg Clayton 
431fcd43b71SJohnny Chen                     if (result)
432b71f3844SGreg Clayton                         result->SetStatus (eReturnStatusFailed);
43330fdc8d8SChris Lattner                 }
4348b2fe6dcSGreg Clayton             }
4358b2fe6dcSGreg Clayton         }
436bccce813SSean Callanan     }
4378b2fe6dcSGreg Clayton     else
4388b2fe6dcSGreg Clayton     {
4396e8dc334SCaroline Tice         error_stream->Printf ("error: invalid execution context for expression\n");
4408b2fe6dcSGreg Clayton         return false;
4418b2fe6dcSGreg Clayton     }
44230fdc8d8SChris Lattner 
44316ad5faeSSean Callanan     return true;
44430fdc8d8SChris Lattner }
44530fdc8d8SChris Lattner 
44630fdc8d8SChris Lattner bool
4475a988416SJim Ingham CommandObjectExpression::DoExecute
44830fdc8d8SChris Lattner (
44930fdc8d8SChris Lattner     const char *command,
45030fdc8d8SChris Lattner     CommandReturnObject &result
45130fdc8d8SChris Lattner )
45230fdc8d8SChris Lattner {
4531deb7962SGreg Clayton     m_option_group.NotifyOptionParsingStarting();
45430fdc8d8SChris Lattner 
45530fdc8d8SChris Lattner     const char * expr = NULL;
45630fdc8d8SChris Lattner 
45730fdc8d8SChris Lattner     if (command[0] == '\0')
45830fdc8d8SChris Lattner     {
45930fdc8d8SChris Lattner         m_expr_lines.clear();
46030fdc8d8SChris Lattner         m_expr_line_count = 0;
46130fdc8d8SChris Lattner 
462a7015092SGreg Clayton         InputReaderSP reader_sp (new InputReader(m_interpreter.GetDebugger()));
46330fdc8d8SChris Lattner         if (reader_sp)
46430fdc8d8SChris Lattner         {
46530fdc8d8SChris Lattner             Error err (reader_sp->Initialize (CommandObjectExpression::MultiLineExpressionCallback,
46630fdc8d8SChris Lattner                                               this,                         // baton
46730fdc8d8SChris Lattner                                               eInputReaderGranularityLine,  // token size, to pass to callback function
46830fdc8d8SChris Lattner                                               NULL,                         // end token
46930fdc8d8SChris Lattner                                               NULL,                         // prompt
47030fdc8d8SChris Lattner                                               true));                       // echo input
47130fdc8d8SChris Lattner             if (err.Success())
47230fdc8d8SChris Lattner             {
473a7015092SGreg Clayton                 m_interpreter.GetDebugger().PushInputReader (reader_sp);
47430fdc8d8SChris Lattner                 result.SetStatus (eReturnStatusSuccessFinishNoResult);
47530fdc8d8SChris Lattner             }
47630fdc8d8SChris Lattner             else
47730fdc8d8SChris Lattner             {
47830fdc8d8SChris Lattner                 result.AppendError (err.AsCString());
47930fdc8d8SChris Lattner                 result.SetStatus (eReturnStatusFailed);
48030fdc8d8SChris Lattner             }
48130fdc8d8SChris Lattner         }
48230fdc8d8SChris Lattner         else
48330fdc8d8SChris Lattner         {
48430fdc8d8SChris Lattner             result.AppendError("out of memory");
48530fdc8d8SChris Lattner             result.SetStatus (eReturnStatusFailed);
48630fdc8d8SChris Lattner         }
48730fdc8d8SChris Lattner         return result.Succeeded();
48830fdc8d8SChris Lattner     }
48930fdc8d8SChris Lattner 
49030fdc8d8SChris Lattner     if (command[0] == '-')
49130fdc8d8SChris Lattner     {
49230fdc8d8SChris Lattner         // We have some options and these options MUST end with --.
49330fdc8d8SChris Lattner         const char *end_options = NULL;
49430fdc8d8SChris Lattner         const char *s = command;
49530fdc8d8SChris Lattner         while (s && s[0])
49630fdc8d8SChris Lattner         {
49730fdc8d8SChris Lattner             end_options = ::strstr (s, "--");
49830fdc8d8SChris Lattner             if (end_options)
49930fdc8d8SChris Lattner             {
50030fdc8d8SChris Lattner                 end_options += 2; // Get past the "--"
50130fdc8d8SChris Lattner                 if (::isspace (end_options[0]))
50230fdc8d8SChris Lattner                 {
50330fdc8d8SChris Lattner                     expr = end_options;
50430fdc8d8SChris Lattner                     while (::isspace (*expr))
50530fdc8d8SChris Lattner                         ++expr;
50630fdc8d8SChris Lattner                     break;
50730fdc8d8SChris Lattner                 }
50830fdc8d8SChris Lattner             }
50930fdc8d8SChris Lattner             s = end_options;
51030fdc8d8SChris Lattner         }
51130fdc8d8SChris Lattner 
51230fdc8d8SChris Lattner         if (end_options)
51330fdc8d8SChris Lattner         {
51430fdc8d8SChris Lattner             Args args (command, end_options - command);
515a7015092SGreg Clayton             if (!ParseOptions (args, result))
51630fdc8d8SChris Lattner                 return false;
517f6b8b581SGreg Clayton 
5181deb7962SGreg Clayton             Error error (m_option_group.NotifyOptionParsingFinished());
519f6b8b581SGreg Clayton             if (error.Fail())
520f6b8b581SGreg Clayton             {
521f6b8b581SGreg Clayton                 result.AppendError (error.AsCString());
522f6b8b581SGreg Clayton                 result.SetStatus (eReturnStatusFailed);
523f6b8b581SGreg Clayton                 return false;
524f6b8b581SGreg Clayton             }
52530fdc8d8SChris Lattner         }
52630fdc8d8SChris Lattner     }
52730fdc8d8SChris Lattner 
52830fdc8d8SChris Lattner     if (expr == NULL)
52930fdc8d8SChris Lattner         expr = command;
53030fdc8d8SChris Lattner 
5316e8dc334SCaroline Tice     if (EvaluateExpression (expr, &(result.GetOutputStream()), &(result.GetErrorStream()), &result))
532fcd43b71SJohnny Chen         return true;
533fcd43b71SJohnny Chen 
534fcd43b71SJohnny Chen     result.SetStatus (eReturnStatusFailed);
535fcd43b71SJohnny Chen     return false;
53630fdc8d8SChris Lattner }
53730fdc8d8SChris Lattner 
538