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"
22*4d93b8cdSEnrico 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"
3530fdc8d8SChris Lattner #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 
53*4d93b8cdSEnrico Granata static OptionEnumValueElement g_description_verbosity_type[] =
54*4d93b8cdSEnrico Granata {
55*4d93b8cdSEnrico Granata     { eLanguageRuntimeDescriptionDisplayVerbosityCompact,      "compact",       "Only show the description string"},
56*4d93b8cdSEnrico Granata     { eLanguageRuntimeDescriptionDisplayVerbosityFull,         "full",          "Show the full output, including persistent variable's name and type"},
57*4d93b8cdSEnrico Granata     { 0, NULL, NULL }
58*4d93b8cdSEnrico Granata };
59*4d93b8cdSEnrico 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)."},
67*4d93b8cdSEnrico 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."},
681deb7962SGreg Clayton };
691deb7962SGreg Clayton 
701deb7962SGreg Clayton 
711deb7962SGreg Clayton uint32_t
721deb7962SGreg Clayton CommandObjectExpression::CommandOptions::GetNumDefinitions ()
731deb7962SGreg Clayton {
741deb7962SGreg Clayton     return sizeof(g_option_table)/sizeof(OptionDefinition);
751deb7962SGreg Clayton }
761deb7962SGreg Clayton 
7730fdc8d8SChris Lattner Error
781deb7962SGreg Clayton CommandObjectExpression::CommandOptions::SetOptionValue (CommandInterpreter &interpreter,
791deb7962SGreg Clayton                                                          uint32_t option_idx,
801deb7962SGreg Clayton                                                          const char *option_arg)
8130fdc8d8SChris Lattner {
8230fdc8d8SChris Lattner     Error error;
8330fdc8d8SChris Lattner 
843bcdfc0eSGreg Clayton     const int short_option = g_option_table[option_idx].short_option;
8530fdc8d8SChris Lattner 
8630fdc8d8SChris Lattner     switch (short_option)
8730fdc8d8SChris Lattner     {
883f4c09c1SCaroline Tice       //case 'l':
893f4c09c1SCaroline Tice       //if (language.SetLanguageFromCString (option_arg) == false)
903f4c09c1SCaroline Tice       //{
9186edbf41SGreg Clayton       //    error.SetErrorStringWithFormat("invalid language option argument '%s'", option_arg);
923f4c09c1SCaroline Tice       //}
933f4c09c1SCaroline Tice       //break;
9430fdc8d8SChris Lattner 
9535e1bda6SJim Ingham     case 'a':
9635e1bda6SJim Ingham         {
9735e1bda6SJim Ingham             bool success;
9835e1bda6SJim Ingham             bool result;
9935e1bda6SJim Ingham             result = Args::StringToBoolean(option_arg, true, &success);
10035e1bda6SJim Ingham             if (!success)
10135e1bda6SJim Ingham                 error.SetErrorStringWithFormat("invalid all-threads value setting: \"%s\"", option_arg);
10235e1bda6SJim Ingham             else
10335e1bda6SJim Ingham                 try_all_threads = result;
10435e1bda6SJim Ingham         }
1056c68fb45SJim Ingham         break;
1066c68fb45SJim Ingham 
107184e9811SJim Ingham     case 'i':
108184e9811SJim Ingham         {
109184e9811SJim Ingham             bool success;
110184e9811SJim Ingham             bool tmp_value = Args::StringToBoolean(option_arg, true, &success);
111184e9811SJim Ingham             if (success)
112184e9811SJim Ingham                 ignore_breakpoints = tmp_value;
113184e9811SJim Ingham             else
114184e9811SJim Ingham                 error.SetErrorStringWithFormat("could not convert \"%s\" to a boolean value.", option_arg);
115184e9811SJim Ingham             break;
116184e9811SJim Ingham         }
11735e1bda6SJim Ingham     case 't':
11835e1bda6SJim Ingham         {
11935e1bda6SJim Ingham             bool success;
12035e1bda6SJim Ingham             uint32_t result;
12135e1bda6SJim Ingham             result = Args::StringToUInt32(option_arg, 0, 0, &success);
12235e1bda6SJim Ingham             if (success)
12335e1bda6SJim Ingham                 timeout = result;
12435e1bda6SJim Ingham             else
12535e1bda6SJim Ingham                 error.SetErrorStringWithFormat ("invalid timeout setting \"%s\"", option_arg);
12635e1bda6SJim Ingham         }
12735e1bda6SJim Ingham         break;
12835e1bda6SJim Ingham 
129399f1cafSJim Ingham     case 'u':
1303bfdaa2aSSean Callanan         {
131399f1cafSJim Ingham             bool success;
132184e9811SJim Ingham             bool tmp_value = Args::StringToBoolean(option_arg, true, &success);
133184e9811SJim Ingham             if (success)
134184e9811SJim Ingham                 unwind_on_error = tmp_value;
135184e9811SJim Ingham             else
13686edbf41SGreg Clayton                 error.SetErrorStringWithFormat("could not convert \"%s\" to a boolean value.", option_arg);
137399f1cafSJim Ingham             break;
1383bfdaa2aSSean Callanan         }
139*4d93b8cdSEnrico Granata 
140*4d93b8cdSEnrico Granata     case 'v':
141*4d93b8cdSEnrico Granata         if (!option_arg)
142*4d93b8cdSEnrico Granata         {
143*4d93b8cdSEnrico Granata             m_verbosity = eLanguageRuntimeDescriptionDisplayVerbosityFull;
144*4d93b8cdSEnrico Granata             break;
145*4d93b8cdSEnrico Granata         }
146*4d93b8cdSEnrico Granata         m_verbosity = (LanguageRuntimeDescriptionDisplayVerbosity) Args::StringToOptionEnum(option_arg, g_option_table[option_idx].enum_values, 0, error);
147*4d93b8cdSEnrico Granata         if (!error.Success())
148*4d93b8cdSEnrico Granata             error.SetErrorStringWithFormat ("unrecognized value for description-verbosity '%s'", option_arg);
149*4d93b8cdSEnrico Granata         break;
150*4d93b8cdSEnrico Granata 
15130fdc8d8SChris Lattner     default:
15286edbf41SGreg Clayton         error.SetErrorStringWithFormat("invalid short option character '%c'", short_option);
15330fdc8d8SChris Lattner         break;
15430fdc8d8SChris Lattner     }
15530fdc8d8SChris Lattner 
15630fdc8d8SChris Lattner     return error;
15730fdc8d8SChris Lattner }
15830fdc8d8SChris Lattner 
15930fdc8d8SChris Lattner void
1601deb7962SGreg Clayton CommandObjectExpression::CommandOptions::OptionParsingStarting (CommandInterpreter &interpreter)
16130fdc8d8SChris Lattner {
162184e9811SJim Ingham     Process *process = interpreter.GetExecutionContext().GetProcessPtr();
163184e9811SJim Ingham     if (process != NULL)
164184e9811SJim Ingham     {
165184e9811SJim Ingham         ignore_breakpoints = process->GetIgnoreBreakpointsInExpressions();
166184e9811SJim Ingham         unwind_on_error    = process->GetUnwindOnErrorInExpressions();
167184e9811SJim Ingham     }
168184e9811SJim Ingham     else
169184e9811SJim Ingham     {
170184e9811SJim Ingham         ignore_breakpoints = false;
171399f1cafSJim Ingham         unwind_on_error = true;
172184e9811SJim Ingham     }
173184e9811SJim Ingham 
17430fdc8d8SChris Lattner     show_summary = true;
17535e1bda6SJim Ingham     try_all_threads = true;
17635e1bda6SJim Ingham     timeout = 0;
177*4d93b8cdSEnrico Granata     m_verbosity = eLanguageRuntimeDescriptionDisplayVerbosityCompact;
17830fdc8d8SChris Lattner }
17930fdc8d8SChris Lattner 
180e0d378b3SGreg Clayton const OptionDefinition*
18130fdc8d8SChris Lattner CommandObjectExpression::CommandOptions::GetDefinitions ()
18230fdc8d8SChris Lattner {
18330fdc8d8SChris Lattner     return g_option_table;
18430fdc8d8SChris Lattner }
18530fdc8d8SChris Lattner 
186a7015092SGreg Clayton CommandObjectExpression::CommandObjectExpression (CommandInterpreter &interpreter) :
1875a988416SJim Ingham     CommandObjectRaw (interpreter,
18830fdc8d8SChris Lattner                       "expression",
1895c48d5c5SJim Ingham                       "Evaluate a C/ObjC/C++ expression in the current program context, using user defined variables and variables currently in scope.",
1905a988416SJim Ingham                       NULL,
191f9fc609fSGreg Clayton                       eFlagProcessMustBePaused | eFlagTryTargetAPILock),
1921deb7962SGreg Clayton     m_option_group (interpreter),
1931deb7962SGreg Clayton     m_format_options (eFormatDefault),
1941deb7962SGreg Clayton     m_command_options (),
19530fdc8d8SChris Lattner     m_expr_line_count (0),
19630fdc8d8SChris Lattner     m_expr_lines ()
19730fdc8d8SChris Lattner {
19830fdc8d8SChris Lattner   SetHelpLong(
19935e1bda6SJim Ingham "Timeouts:\n\
20035e1bda6SJim Ingham     If the expression can be evaluated statically (without runnning code) then it will be.\n\
20135e1bda6SJim Ingham     Otherwise, by default the expression will run on the current thread with a short timeout:\n\
20235e1bda6SJim Ingham     currently .25 seconds.  If it doesn't return in that time, the evaluation will be interrupted\n\
20335e1bda6SJim Ingham     and resumed with all threads running.  You can use the -a option to disable retrying on all\n\
20435e1bda6SJim Ingham     threads.  You can use the -t option to set a shorter timeout.\n\
2055c48d5c5SJim Ingham \n\
2065c48d5c5SJim Ingham User defined variables:\n\
2075c48d5c5SJim Ingham     You can define your own variables for convenience or to be used in subsequent expressions.\n\
2085c48d5c5SJim Ingham     You define them the same way you would define variables in C.  If the first character of \n\
2095c48d5c5SJim Ingham     your user defined variable is a $, then the variable's value will be available in future\n\
2105c48d5c5SJim Ingham     expressions, otherwise it will just be available in the current expression.\n\
2115c48d5c5SJim Ingham \n\
21235e1bda6SJim Ingham Examples: \n\
21330fdc8d8SChris Lattner \n\
21430fdc8d8SChris Lattner    expr my_struct->a = my_array[3] \n\
21530fdc8d8SChris Lattner    expr -f bin -- (index * 8) + 5 \n\
2165c48d5c5SJim Ingham    expr unsigned int $foo = 5\n\
21730fdc8d8SChris Lattner    expr char c[] = \"foo\"; c[0]\n");
218405fe67fSCaroline Tice 
219405fe67fSCaroline Tice     CommandArgumentEntry arg;
220405fe67fSCaroline Tice     CommandArgumentData expression_arg;
221405fe67fSCaroline Tice 
222405fe67fSCaroline Tice     // Define the first (and only) variant of this arg.
223405fe67fSCaroline Tice     expression_arg.arg_type = eArgTypeExpression;
224405fe67fSCaroline Tice     expression_arg.arg_repetition = eArgRepeatPlain;
225405fe67fSCaroline Tice 
226405fe67fSCaroline Tice     // There is only one variant this argument could be; put it into the argument entry.
227405fe67fSCaroline Tice     arg.push_back (expression_arg);
228405fe67fSCaroline Tice 
229405fe67fSCaroline Tice     // Push the data for the first argument into the m_arguments vector.
230405fe67fSCaroline Tice     m_arguments.push_back (arg);
2311deb7962SGreg Clayton 
2325009f9d5SGreg Clayton     // Add the "--format" and "--gdb-format"
2335009f9d5SGreg Clayton     m_option_group.Append (&m_format_options, OptionGroupFormat::OPTION_GROUP_FORMAT | OptionGroupFormat::OPTION_GROUP_GDB_FMT, LLDB_OPT_SET_1);
2341deb7962SGreg Clayton     m_option_group.Append (&m_command_options);
235b576bba2SEnrico Granata     m_option_group.Append (&m_varobj_options, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1 | LLDB_OPT_SET_2);
2361deb7962SGreg Clayton     m_option_group.Finalize();
23730fdc8d8SChris Lattner }
23830fdc8d8SChris Lattner 
23930fdc8d8SChris Lattner CommandObjectExpression::~CommandObjectExpression ()
24030fdc8d8SChris Lattner {
24130fdc8d8SChris Lattner }
24230fdc8d8SChris Lattner 
24330fdc8d8SChris Lattner Options *
24430fdc8d8SChris Lattner CommandObjectExpression::GetOptions ()
24530fdc8d8SChris Lattner {
2461deb7962SGreg Clayton     return &m_option_group;
24730fdc8d8SChris Lattner }
24830fdc8d8SChris Lattner 
24930fdc8d8SChris Lattner size_t
25030fdc8d8SChris Lattner CommandObjectExpression::MultiLineExpressionCallback
25130fdc8d8SChris Lattner (
25230fdc8d8SChris Lattner     void *baton,
2536611103cSGreg Clayton     InputReader &reader,
25430fdc8d8SChris Lattner     lldb::InputReaderAction notification,
25530fdc8d8SChris Lattner     const char *bytes,
25630fdc8d8SChris Lattner     size_t bytes_len
25730fdc8d8SChris Lattner )
25830fdc8d8SChris Lattner {
25930fdc8d8SChris Lattner     CommandObjectExpression *cmd_object_expr = (CommandObjectExpression *) baton;
260d61c10bcSCaroline Tice     bool batch_mode = reader.GetDebugger().GetCommandInterpreter().GetBatchCommandMode();
26130fdc8d8SChris Lattner 
26230fdc8d8SChris Lattner     switch (notification)
26330fdc8d8SChris Lattner     {
26430fdc8d8SChris Lattner     case eInputReaderActivate:
265d61c10bcSCaroline Tice         if (!batch_mode)
26615356e7fSCaroline Tice         {
26707e66e3eSGreg Clayton             StreamSP async_strm_sp(reader.GetDebugger().GetAsyncOutputStream());
26807e66e3eSGreg Clayton             if (async_strm_sp)
26907e66e3eSGreg Clayton             {
27007e66e3eSGreg Clayton                 async_strm_sp->PutCString("Enter expressions, then terminate with an empty line to evaluate:\n");
27107e66e3eSGreg Clayton                 async_strm_sp->Flush();
27207e66e3eSGreg Clayton             }
27315356e7fSCaroline Tice         }
27430fdc8d8SChris Lattner         // Fall through
27530fdc8d8SChris Lattner     case eInputReaderReactivate:
27630fdc8d8SChris Lattner         break;
27730fdc8d8SChris Lattner 
27830fdc8d8SChris Lattner     case eInputReaderDeactivate:
27930fdc8d8SChris Lattner         break;
28030fdc8d8SChris Lattner 
281969ed3d1SCaroline Tice     case eInputReaderAsynchronousOutputWritten:
282969ed3d1SCaroline Tice         break;
283969ed3d1SCaroline Tice 
28430fdc8d8SChris Lattner     case eInputReaderGotToken:
28530fdc8d8SChris Lattner         ++cmd_object_expr->m_expr_line_count;
28630fdc8d8SChris Lattner         if (bytes && bytes_len)
28730fdc8d8SChris Lattner         {
28830fdc8d8SChris Lattner             cmd_object_expr->m_expr_lines.append (bytes, bytes_len + 1);
28930fdc8d8SChris Lattner         }
29030fdc8d8SChris Lattner 
29130fdc8d8SChris Lattner         if (bytes_len == 0)
2926611103cSGreg Clayton             reader.SetIsDone(true);
29330fdc8d8SChris Lattner         break;
29430fdc8d8SChris Lattner 
295efed6131SCaroline Tice     case eInputReaderInterrupt:
296efed6131SCaroline Tice         cmd_object_expr->m_expr_lines.clear();
297efed6131SCaroline Tice         reader.SetIsDone (true);
298d61c10bcSCaroline Tice         if (!batch_mode)
29915356e7fSCaroline Tice         {
30007e66e3eSGreg Clayton             StreamSP async_strm_sp (reader.GetDebugger().GetAsyncOutputStream());
30107e66e3eSGreg Clayton             if (async_strm_sp)
30207e66e3eSGreg Clayton             {
30307e66e3eSGreg Clayton                 async_strm_sp->PutCString("Expression evaluation cancelled.\n");
30407e66e3eSGreg Clayton                 async_strm_sp->Flush();
30507e66e3eSGreg Clayton             }
30615356e7fSCaroline Tice         }
307efed6131SCaroline Tice         break;
308efed6131SCaroline Tice 
309efed6131SCaroline Tice     case eInputReaderEndOfFile:
310efed6131SCaroline Tice         reader.SetIsDone (true);
311efed6131SCaroline Tice         break;
312efed6131SCaroline Tice 
31330fdc8d8SChris Lattner     case eInputReaderDone:
314efed6131SCaroline Tice 		if (cmd_object_expr->m_expr_lines.size() > 0)
31530fdc8d8SChris Lattner         {
3166e8dc334SCaroline Tice             StreamSP output_stream = reader.GetDebugger().GetAsyncOutputStream();
3176e8dc334SCaroline Tice             StreamSP error_stream = reader.GetDebugger().GetAsyncErrorStream();
31830fdc8d8SChris Lattner             cmd_object_expr->EvaluateExpression (cmd_object_expr->m_expr_lines.c_str(),
3196e8dc334SCaroline Tice                                                  output_stream.get(),
3206e8dc334SCaroline Tice                                                  error_stream.get());
3216e8dc334SCaroline Tice             output_stream->Flush();
3226e8dc334SCaroline Tice             error_stream->Flush();
32330fdc8d8SChris Lattner         }
32430fdc8d8SChris Lattner         break;
32530fdc8d8SChris Lattner     }
32630fdc8d8SChris Lattner 
32730fdc8d8SChris Lattner     return bytes_len;
32830fdc8d8SChris Lattner }
32930fdc8d8SChris Lattner 
33030fdc8d8SChris Lattner bool
3311d3afba3SGreg Clayton CommandObjectExpression::EvaluateExpression
3321d3afba3SGreg Clayton (
3331d3afba3SGreg Clayton     const char *expr,
3346e8dc334SCaroline Tice     Stream *output_stream,
3356e8dc334SCaroline Tice     Stream *error_stream,
3361d3afba3SGreg Clayton     CommandReturnObject *result
3371d3afba3SGreg Clayton )
33830fdc8d8SChris Lattner {
339ba7b8e2cSGreg Clayton     // Don't use m_exe_ctx as this might be called asynchronously
340ba7b8e2cSGreg Clayton     // after the command object DoExecute has finished when doing
341ba7b8e2cSGreg Clayton     // multi-line expression that use an input reader...
342ba7b8e2cSGreg Clayton     ExecutionContext exe_ctx (m_interpreter.GetExecutionContext());
343ba7b8e2cSGreg Clayton 
344ba7b8e2cSGreg Clayton     Target *target = exe_ctx.GetTargetPtr();
345c0a6e061SSean Callanan 
346c0a6e061SSean Callanan     if (!target)
347c0a6e061SSean Callanan         target = Host::GetDummyTarget(m_interpreter.GetDebugger()).get();
348c0a6e061SSean Callanan 
349c14ee32dSGreg Clayton     if (target)
3506961e878SSean Callanan     {
3518b2fe6dcSGreg Clayton         lldb::ValueObjectSP result_valobj_sp;
3528b2fe6dcSGreg Clayton 
353e0d378b3SGreg Clayton         ExecutionResults exe_results;
35492adcac9SSean Callanan 
35592adcac9SSean Callanan         bool keep_in_memory = true;
35692adcac9SSean Callanan 
35735e1bda6SJim Ingham         EvaluateExpressionOptions options;
358b576bba2SEnrico Granata         options.SetCoerceToId(m_varobj_options.use_objc)
359d4439aa9SEnrico Granata         .SetUnwindOnError(m_command_options.unwind_on_error)
360184e9811SJim Ingham         .SetIgnoreBreakpoints (m_command_options.ignore_breakpoints)
361d4439aa9SEnrico Granata         .SetKeepInMemory(keep_in_memory)
362b576bba2SEnrico Granata         .SetUseDynamic(m_varobj_options.use_dynamic)
36335e1bda6SJim Ingham         .SetRunOthers(m_command_options.try_all_threads)
36435e1bda6SJim Ingham         .SetTimeoutUsec(m_command_options.timeout);
365d4439aa9SEnrico Granata 
366c14ee32dSGreg Clayton         exe_results = target->EvaluateExpression (expr,
367ba7b8e2cSGreg Clayton                                                   exe_ctx.GetFramePtr(),
3683372f581SEnrico Granata                                                   result_valobj_sp,
369d4439aa9SEnrico Granata                                                   options);
3708b2fe6dcSGreg Clayton 
3718b2fe6dcSGreg Clayton         if (result_valobj_sp)
3728b2fe6dcSGreg Clayton         {
373bf154daeSSean Callanan             Format format = m_format_options.GetFormat();
374bf154daeSSean Callanan 
375b71f3844SGreg Clayton             if (result_valobj_sp->GetError().Success())
37630fdc8d8SChris Lattner             {
377bf154daeSSean Callanan                 if (format != eFormatVoid)
378bf154daeSSean Callanan                 {
3791deb7962SGreg Clayton                     if (format != eFormatDefault)
3801deb7962SGreg Clayton                         result_valobj_sp->SetFormat (format);
38132c4085bSGreg Clayton 
382*4d93b8cdSEnrico Granata                     DumpValueObjectOptions options(m_varobj_options.GetAsDumpOptions(m_command_options.m_verbosity,format));
383770eb05aSEnrico Granata 
384*4d93b8cdSEnrico Granata                     result_valobj_sp->Dump(*output_stream,options);
385*4d93b8cdSEnrico Granata 
386fcd43b71SJohnny Chen                     if (result)
387fcd43b71SJohnny Chen                         result->SetStatus (eReturnStatusSuccessFinishResult);
38830fdc8d8SChris Lattner                 }
389bf154daeSSean Callanan             }
39030fdc8d8SChris Lattner             else
39130fdc8d8SChris Lattner             {
392bccce813SSean Callanan                 if (result_valobj_sp->GetError().GetError() == ClangUserExpression::kNoResult)
393bccce813SSean Callanan                 {
394bcf897faSSean Callanan                     if (format != eFormatVoid && m_interpreter.GetDebugger().GetNotifyVoid())
395bf154daeSSean Callanan                     {
396bcf897faSSean Callanan                         error_stream->PutCString("(void)\n");
397bcf897faSSean Callanan                     }
398bccce813SSean Callanan 
399bccce813SSean Callanan                     if (result)
400bccce813SSean Callanan                         result->SetStatus (eReturnStatusSuccessFinishResult);
401bccce813SSean Callanan                 }
402bccce813SSean Callanan                 else
403bccce813SSean Callanan                 {
4045fd05903SGreg Clayton                     const char *error_cstr = result_valobj_sp->GetError().AsCString();
4055fd05903SGreg Clayton                     if (error_cstr && error_cstr[0])
4065fd05903SGreg Clayton                     {
407c7bece56SGreg Clayton                         const size_t error_cstr_len = strlen (error_cstr);
4085fd05903SGreg Clayton                         const bool ends_with_newline = error_cstr[error_cstr_len - 1] == '\n';
4095fd05903SGreg Clayton                         if (strstr(error_cstr, "error:") != error_cstr)
4105fd05903SGreg Clayton                             error_stream->PutCString ("error: ");
4115fd05903SGreg Clayton                         error_stream->Write(error_cstr, error_cstr_len);
4125fd05903SGreg Clayton                         if (!ends_with_newline)
4135fd05903SGreg Clayton                             error_stream->EOL();
4145fd05903SGreg Clayton                     }
4155fd05903SGreg Clayton                     else
4165fd05903SGreg Clayton                     {
4175fd05903SGreg Clayton                         error_stream->PutCString ("error: unknown error\n");
4185fd05903SGreg Clayton                     }
4195fd05903SGreg Clayton 
420fcd43b71SJohnny Chen                     if (result)
421b71f3844SGreg Clayton                         result->SetStatus (eReturnStatusFailed);
42230fdc8d8SChris Lattner                 }
4238b2fe6dcSGreg Clayton             }
4248b2fe6dcSGreg Clayton         }
425bccce813SSean Callanan     }
4268b2fe6dcSGreg Clayton     else
4278b2fe6dcSGreg Clayton     {
4286e8dc334SCaroline Tice         error_stream->Printf ("error: invalid execution context for expression\n");
4298b2fe6dcSGreg Clayton         return false;
4308b2fe6dcSGreg Clayton     }
43130fdc8d8SChris Lattner 
43216ad5faeSSean Callanan     return true;
43330fdc8d8SChris Lattner }
43430fdc8d8SChris Lattner 
43530fdc8d8SChris Lattner bool
4365a988416SJim Ingham CommandObjectExpression::DoExecute
43730fdc8d8SChris Lattner (
43830fdc8d8SChris Lattner     const char *command,
43930fdc8d8SChris Lattner     CommandReturnObject &result
44030fdc8d8SChris Lattner )
44130fdc8d8SChris Lattner {
4421deb7962SGreg Clayton     m_option_group.NotifyOptionParsingStarting();
44330fdc8d8SChris Lattner 
44430fdc8d8SChris Lattner     const char * expr = NULL;
44530fdc8d8SChris Lattner 
44630fdc8d8SChris Lattner     if (command[0] == '\0')
44730fdc8d8SChris Lattner     {
44830fdc8d8SChris Lattner         m_expr_lines.clear();
44930fdc8d8SChris Lattner         m_expr_line_count = 0;
45030fdc8d8SChris Lattner 
451a7015092SGreg Clayton         InputReaderSP reader_sp (new InputReader(m_interpreter.GetDebugger()));
45230fdc8d8SChris Lattner         if (reader_sp)
45330fdc8d8SChris Lattner         {
45430fdc8d8SChris Lattner             Error err (reader_sp->Initialize (CommandObjectExpression::MultiLineExpressionCallback,
45530fdc8d8SChris Lattner                                               this,                         // baton
45630fdc8d8SChris Lattner                                               eInputReaderGranularityLine,  // token size, to pass to callback function
45730fdc8d8SChris Lattner                                               NULL,                         // end token
45830fdc8d8SChris Lattner                                               NULL,                         // prompt
45930fdc8d8SChris Lattner                                               true));                       // echo input
46030fdc8d8SChris Lattner             if (err.Success())
46130fdc8d8SChris Lattner             {
462a7015092SGreg Clayton                 m_interpreter.GetDebugger().PushInputReader (reader_sp);
46330fdc8d8SChris Lattner                 result.SetStatus (eReturnStatusSuccessFinishNoResult);
46430fdc8d8SChris Lattner             }
46530fdc8d8SChris Lattner             else
46630fdc8d8SChris Lattner             {
46730fdc8d8SChris Lattner                 result.AppendError (err.AsCString());
46830fdc8d8SChris Lattner                 result.SetStatus (eReturnStatusFailed);
46930fdc8d8SChris Lattner             }
47030fdc8d8SChris Lattner         }
47130fdc8d8SChris Lattner         else
47230fdc8d8SChris Lattner         {
47330fdc8d8SChris Lattner             result.AppendError("out of memory");
47430fdc8d8SChris Lattner             result.SetStatus (eReturnStatusFailed);
47530fdc8d8SChris Lattner         }
47630fdc8d8SChris Lattner         return result.Succeeded();
47730fdc8d8SChris Lattner     }
47830fdc8d8SChris Lattner 
47930fdc8d8SChris Lattner     if (command[0] == '-')
48030fdc8d8SChris Lattner     {
48130fdc8d8SChris Lattner         // We have some options and these options MUST end with --.
48230fdc8d8SChris Lattner         const char *end_options = NULL;
48330fdc8d8SChris Lattner         const char *s = command;
48430fdc8d8SChris Lattner         while (s && s[0])
48530fdc8d8SChris Lattner         {
48630fdc8d8SChris Lattner             end_options = ::strstr (s, "--");
48730fdc8d8SChris Lattner             if (end_options)
48830fdc8d8SChris Lattner             {
48930fdc8d8SChris Lattner                 end_options += 2; // Get past the "--"
49030fdc8d8SChris Lattner                 if (::isspace (end_options[0]))
49130fdc8d8SChris Lattner                 {
49230fdc8d8SChris Lattner                     expr = end_options;
49330fdc8d8SChris Lattner                     while (::isspace (*expr))
49430fdc8d8SChris Lattner                         ++expr;
49530fdc8d8SChris Lattner                     break;
49630fdc8d8SChris Lattner                 }
49730fdc8d8SChris Lattner             }
49830fdc8d8SChris Lattner             s = end_options;
49930fdc8d8SChris Lattner         }
50030fdc8d8SChris Lattner 
50130fdc8d8SChris Lattner         if (end_options)
50230fdc8d8SChris Lattner         {
50330fdc8d8SChris Lattner             Args args (command, end_options - command);
504a7015092SGreg Clayton             if (!ParseOptions (args, result))
50530fdc8d8SChris Lattner                 return false;
506f6b8b581SGreg Clayton 
5071deb7962SGreg Clayton             Error error (m_option_group.NotifyOptionParsingFinished());
508f6b8b581SGreg Clayton             if (error.Fail())
509f6b8b581SGreg Clayton             {
510f6b8b581SGreg Clayton                 result.AppendError (error.AsCString());
511f6b8b581SGreg Clayton                 result.SetStatus (eReturnStatusFailed);
512f6b8b581SGreg Clayton                 return false;
513f6b8b581SGreg Clayton             }
51430fdc8d8SChris Lattner         }
51530fdc8d8SChris Lattner     }
51630fdc8d8SChris Lattner 
51730fdc8d8SChris Lattner     if (expr == NULL)
51830fdc8d8SChris Lattner         expr = command;
51930fdc8d8SChris Lattner 
5206e8dc334SCaroline Tice     if (EvaluateExpression (expr, &(result.GetOutputStream()), &(result.GetErrorStream()), &result))
521fcd43b71SJohnny Chen         return true;
522fcd43b71SJohnny Chen 
523fcd43b71SJohnny Chen     result.SetStatus (eReturnStatusFailed);
524fcd43b71SJohnny Chen     return false;
52530fdc8d8SChris Lattner }
52630fdc8d8SChris Lattner 
527