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."},
5635e1bda6SJim Ingham     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "timeout",            't', required_argument, NULL, 0, eArgTypeUnsignedInteger,  "Timeout value for running the expression."},
571deb7962SGreg 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."},
581deb7962SGreg Clayton };
591deb7962SGreg Clayton 
601deb7962SGreg Clayton 
611deb7962SGreg Clayton uint32_t
621deb7962SGreg Clayton CommandObjectExpression::CommandOptions::GetNumDefinitions ()
631deb7962SGreg Clayton {
641deb7962SGreg Clayton     return sizeof(g_option_table)/sizeof(OptionDefinition);
651deb7962SGreg Clayton }
661deb7962SGreg Clayton 
6730fdc8d8SChris Lattner Error
681deb7962SGreg Clayton CommandObjectExpression::CommandOptions::SetOptionValue (CommandInterpreter &interpreter,
691deb7962SGreg Clayton                                                          uint32_t option_idx,
701deb7962SGreg Clayton                                                          const char *option_arg)
7130fdc8d8SChris Lattner {
7230fdc8d8SChris Lattner     Error error;
7330fdc8d8SChris Lattner 
743bcdfc0eSGreg Clayton     const int short_option = g_option_table[option_idx].short_option;
7530fdc8d8SChris Lattner 
7630fdc8d8SChris Lattner     switch (short_option)
7730fdc8d8SChris Lattner     {
783f4c09c1SCaroline Tice       //case 'l':
793f4c09c1SCaroline Tice       //if (language.SetLanguageFromCString (option_arg) == false)
803f4c09c1SCaroline Tice       //{
8186edbf41SGreg Clayton       //    error.SetErrorStringWithFormat("invalid language option argument '%s'", option_arg);
823f4c09c1SCaroline Tice       //}
833f4c09c1SCaroline Tice       //break;
8430fdc8d8SChris Lattner 
8535e1bda6SJim Ingham     case 'a':
8635e1bda6SJim Ingham         {
8735e1bda6SJim Ingham             bool success;
8835e1bda6SJim Ingham             bool result;
8935e1bda6SJim Ingham             result = Args::StringToBoolean(option_arg, true, &success);
9035e1bda6SJim Ingham             if (!success)
9135e1bda6SJim Ingham                 error.SetErrorStringWithFormat("invalid all-threads value setting: \"%s\"", option_arg);
9235e1bda6SJim Ingham             else
9335e1bda6SJim Ingham                 try_all_threads = result;
9435e1bda6SJim Ingham         }
956c68fb45SJim Ingham         break;
966c68fb45SJim Ingham 
9735e1bda6SJim Ingham     case 't':
9835e1bda6SJim Ingham         {
9935e1bda6SJim Ingham             bool success;
10035e1bda6SJim Ingham             uint32_t result;
10135e1bda6SJim Ingham             result = Args::StringToUInt32(option_arg, 0, 0, &success);
10235e1bda6SJim Ingham             if (success)
10335e1bda6SJim Ingham                 timeout = result;
10435e1bda6SJim Ingham             else
10535e1bda6SJim Ingham                 error.SetErrorStringWithFormat ("invalid timeout setting \"%s\"", option_arg);
10635e1bda6SJim Ingham         }
10735e1bda6SJim Ingham         break;
10835e1bda6SJim Ingham 
109399f1cafSJim Ingham     case 'u':
1103bfdaa2aSSean Callanan         {
111399f1cafSJim Ingham             bool success;
112399f1cafSJim Ingham             unwind_on_error = Args::StringToBoolean(option_arg, true, &success);
113399f1cafSJim Ingham             if (!success)
11486edbf41SGreg Clayton                 error.SetErrorStringWithFormat("could not convert \"%s\" to a boolean value.", option_arg);
115399f1cafSJim Ingham             break;
1163bfdaa2aSSean Callanan         }
11730fdc8d8SChris Lattner     default:
11886edbf41SGreg Clayton         error.SetErrorStringWithFormat("invalid short option character '%c'", short_option);
11930fdc8d8SChris Lattner         break;
12030fdc8d8SChris Lattner     }
12130fdc8d8SChris Lattner 
12230fdc8d8SChris Lattner     return error;
12330fdc8d8SChris Lattner }
12430fdc8d8SChris Lattner 
12530fdc8d8SChris Lattner void
1261deb7962SGreg Clayton CommandObjectExpression::CommandOptions::OptionParsingStarting (CommandInterpreter &interpreter)
12730fdc8d8SChris Lattner {
128399f1cafSJim Ingham     unwind_on_error = true;
12930fdc8d8SChris Lattner     show_summary = true;
13035e1bda6SJim Ingham     try_all_threads = true;
13135e1bda6SJim Ingham     timeout = 0;
13230fdc8d8SChris Lattner }
13330fdc8d8SChris Lattner 
134e0d378b3SGreg Clayton const OptionDefinition*
13530fdc8d8SChris Lattner CommandObjectExpression::CommandOptions::GetDefinitions ()
13630fdc8d8SChris Lattner {
13730fdc8d8SChris Lattner     return g_option_table;
13830fdc8d8SChris Lattner }
13930fdc8d8SChris Lattner 
140a7015092SGreg Clayton CommandObjectExpression::CommandObjectExpression (CommandInterpreter &interpreter) :
1415a988416SJim Ingham     CommandObjectRaw (interpreter,
14230fdc8d8SChris Lattner                       "expression",
1435c48d5c5SJim Ingham                       "Evaluate a C/ObjC/C++ expression in the current program context, using user defined variables and variables currently in scope.",
1445a988416SJim Ingham                       NULL,
145f9fc609fSGreg Clayton                       eFlagProcessMustBePaused | eFlagTryTargetAPILock),
1461deb7962SGreg Clayton     m_option_group (interpreter),
1471deb7962SGreg Clayton     m_format_options (eFormatDefault),
1481deb7962SGreg Clayton     m_command_options (),
14930fdc8d8SChris Lattner     m_expr_line_count (0),
15030fdc8d8SChris Lattner     m_expr_lines ()
15130fdc8d8SChris Lattner {
15230fdc8d8SChris Lattner   SetHelpLong(
15335e1bda6SJim Ingham "Timeouts:\n\
15435e1bda6SJim Ingham     If the expression can be evaluated statically (without runnning code) then it will be.\n\
15535e1bda6SJim Ingham     Otherwise, by default the expression will run on the current thread with a short timeout:\n\
15635e1bda6SJim Ingham     currently .25 seconds.  If it doesn't return in that time, the evaluation will be interrupted\n\
15735e1bda6SJim Ingham     and resumed with all threads running.  You can use the -a option to disable retrying on all\n\
15835e1bda6SJim Ingham     threads.  You can use the -t option to set a shorter timeout.\n\
1595c48d5c5SJim Ingham \n\
1605c48d5c5SJim Ingham User defined variables:\n\
1615c48d5c5SJim Ingham     You can define your own variables for convenience or to be used in subsequent expressions.\n\
1625c48d5c5SJim Ingham     You define them the same way you would define variables in C.  If the first character of \n\
1635c48d5c5SJim Ingham     your user defined variable is a $, then the variable's value will be available in future\n\
1645c48d5c5SJim Ingham     expressions, otherwise it will just be available in the current expression.\n\
1655c48d5c5SJim Ingham \n\
16635e1bda6SJim Ingham Examples: \n\
16730fdc8d8SChris Lattner \n\
16830fdc8d8SChris Lattner    expr my_struct->a = my_array[3] \n\
16930fdc8d8SChris Lattner    expr -f bin -- (index * 8) + 5 \n\
1705c48d5c5SJim Ingham    expr unsigned int $foo = 5\n\
17130fdc8d8SChris Lattner    expr char c[] = \"foo\"; c[0]\n");
172405fe67fSCaroline Tice 
173405fe67fSCaroline Tice     CommandArgumentEntry arg;
174405fe67fSCaroline Tice     CommandArgumentData expression_arg;
175405fe67fSCaroline Tice 
176405fe67fSCaroline Tice     // Define the first (and only) variant of this arg.
177405fe67fSCaroline Tice     expression_arg.arg_type = eArgTypeExpression;
178405fe67fSCaroline Tice     expression_arg.arg_repetition = eArgRepeatPlain;
179405fe67fSCaroline Tice 
180405fe67fSCaroline Tice     // There is only one variant this argument could be; put it into the argument entry.
181405fe67fSCaroline Tice     arg.push_back (expression_arg);
182405fe67fSCaroline Tice 
183405fe67fSCaroline Tice     // Push the data for the first argument into the m_arguments vector.
184405fe67fSCaroline Tice     m_arguments.push_back (arg);
1851deb7962SGreg Clayton 
1865009f9d5SGreg Clayton     // Add the "--format" and "--gdb-format"
1875009f9d5SGreg Clayton     m_option_group.Append (&m_format_options, OptionGroupFormat::OPTION_GROUP_FORMAT | OptionGroupFormat::OPTION_GROUP_GDB_FMT, LLDB_OPT_SET_1);
1881deb7962SGreg Clayton     m_option_group.Append (&m_command_options);
189*b576bba2SEnrico Granata     m_option_group.Append (&m_varobj_options, LLDB_OPT_SET_ALL, LLDB_OPT_SET_1 | LLDB_OPT_SET_2);
1901deb7962SGreg Clayton     m_option_group.Finalize();
19130fdc8d8SChris Lattner }
19230fdc8d8SChris Lattner 
19330fdc8d8SChris Lattner CommandObjectExpression::~CommandObjectExpression ()
19430fdc8d8SChris Lattner {
19530fdc8d8SChris Lattner }
19630fdc8d8SChris Lattner 
19730fdc8d8SChris Lattner Options *
19830fdc8d8SChris Lattner CommandObjectExpression::GetOptions ()
19930fdc8d8SChris Lattner {
2001deb7962SGreg Clayton     return &m_option_group;
20130fdc8d8SChris Lattner }
20230fdc8d8SChris Lattner 
20330fdc8d8SChris Lattner size_t
20430fdc8d8SChris Lattner CommandObjectExpression::MultiLineExpressionCallback
20530fdc8d8SChris Lattner (
20630fdc8d8SChris Lattner     void *baton,
2076611103cSGreg Clayton     InputReader &reader,
20830fdc8d8SChris Lattner     lldb::InputReaderAction notification,
20930fdc8d8SChris Lattner     const char *bytes,
21030fdc8d8SChris Lattner     size_t bytes_len
21130fdc8d8SChris Lattner )
21230fdc8d8SChris Lattner {
21330fdc8d8SChris Lattner     CommandObjectExpression *cmd_object_expr = (CommandObjectExpression *) baton;
214d61c10bcSCaroline Tice     bool batch_mode = reader.GetDebugger().GetCommandInterpreter().GetBatchCommandMode();
21530fdc8d8SChris Lattner 
21630fdc8d8SChris Lattner     switch (notification)
21730fdc8d8SChris Lattner     {
21830fdc8d8SChris Lattner     case eInputReaderActivate:
219d61c10bcSCaroline Tice         if (!batch_mode)
22015356e7fSCaroline Tice         {
22107e66e3eSGreg Clayton             StreamSP async_strm_sp(reader.GetDebugger().GetAsyncOutputStream());
22207e66e3eSGreg Clayton             if (async_strm_sp)
22307e66e3eSGreg Clayton             {
22407e66e3eSGreg Clayton                 async_strm_sp->PutCString("Enter expressions, then terminate with an empty line to evaluate:\n");
22507e66e3eSGreg Clayton                 async_strm_sp->Flush();
22607e66e3eSGreg Clayton             }
22715356e7fSCaroline Tice         }
22830fdc8d8SChris Lattner         // Fall through
22930fdc8d8SChris Lattner     case eInputReaderReactivate:
23030fdc8d8SChris Lattner         break;
23130fdc8d8SChris Lattner 
23230fdc8d8SChris Lattner     case eInputReaderDeactivate:
23330fdc8d8SChris Lattner         break;
23430fdc8d8SChris Lattner 
235969ed3d1SCaroline Tice     case eInputReaderAsynchronousOutputWritten:
236969ed3d1SCaroline Tice         break;
237969ed3d1SCaroline Tice 
23830fdc8d8SChris Lattner     case eInputReaderGotToken:
23930fdc8d8SChris Lattner         ++cmd_object_expr->m_expr_line_count;
24030fdc8d8SChris Lattner         if (bytes && bytes_len)
24130fdc8d8SChris Lattner         {
24230fdc8d8SChris Lattner             cmd_object_expr->m_expr_lines.append (bytes, bytes_len + 1);
24330fdc8d8SChris Lattner         }
24430fdc8d8SChris Lattner 
24530fdc8d8SChris Lattner         if (bytes_len == 0)
2466611103cSGreg Clayton             reader.SetIsDone(true);
24730fdc8d8SChris Lattner         break;
24830fdc8d8SChris Lattner 
249efed6131SCaroline Tice     case eInputReaderInterrupt:
250efed6131SCaroline Tice         cmd_object_expr->m_expr_lines.clear();
251efed6131SCaroline Tice         reader.SetIsDone (true);
252d61c10bcSCaroline Tice         if (!batch_mode)
25315356e7fSCaroline Tice         {
25407e66e3eSGreg Clayton             StreamSP async_strm_sp (reader.GetDebugger().GetAsyncOutputStream());
25507e66e3eSGreg Clayton             if (async_strm_sp)
25607e66e3eSGreg Clayton             {
25707e66e3eSGreg Clayton                 async_strm_sp->PutCString("Expression evaluation cancelled.\n");
25807e66e3eSGreg Clayton                 async_strm_sp->Flush();
25907e66e3eSGreg Clayton             }
26015356e7fSCaroline Tice         }
261efed6131SCaroline Tice         break;
262efed6131SCaroline Tice 
263efed6131SCaroline Tice     case eInputReaderEndOfFile:
264efed6131SCaroline Tice         reader.SetIsDone (true);
265efed6131SCaroline Tice         break;
266efed6131SCaroline Tice 
26730fdc8d8SChris Lattner     case eInputReaderDone:
268efed6131SCaroline Tice 		if (cmd_object_expr->m_expr_lines.size() > 0)
26930fdc8d8SChris Lattner         {
2706e8dc334SCaroline Tice             StreamSP output_stream = reader.GetDebugger().GetAsyncOutputStream();
2716e8dc334SCaroline Tice             StreamSP error_stream = reader.GetDebugger().GetAsyncErrorStream();
27230fdc8d8SChris Lattner             cmd_object_expr->EvaluateExpression (cmd_object_expr->m_expr_lines.c_str(),
2736e8dc334SCaroline Tice                                                  output_stream.get(),
2746e8dc334SCaroline Tice                                                  error_stream.get());
2756e8dc334SCaroline Tice             output_stream->Flush();
2766e8dc334SCaroline Tice             error_stream->Flush();
27730fdc8d8SChris Lattner         }
27830fdc8d8SChris Lattner         break;
27930fdc8d8SChris Lattner     }
28030fdc8d8SChris Lattner 
28130fdc8d8SChris Lattner     return bytes_len;
28230fdc8d8SChris Lattner }
28330fdc8d8SChris Lattner 
28430fdc8d8SChris Lattner bool
2851d3afba3SGreg Clayton CommandObjectExpression::EvaluateExpression
2861d3afba3SGreg Clayton (
2871d3afba3SGreg Clayton     const char *expr,
2886e8dc334SCaroline Tice     Stream *output_stream,
2896e8dc334SCaroline Tice     Stream *error_stream,
2901d3afba3SGreg Clayton     CommandReturnObject *result
2911d3afba3SGreg Clayton )
29230fdc8d8SChris Lattner {
293f9fc609fSGreg Clayton     Target *target = m_exe_ctx.GetTargetPtr();
294c0a6e061SSean Callanan 
295c0a6e061SSean Callanan     if (!target)
296c0a6e061SSean Callanan         target = Host::GetDummyTarget(m_interpreter.GetDebugger()).get();
297c0a6e061SSean Callanan 
298c14ee32dSGreg Clayton     if (target)
2996961e878SSean Callanan     {
3008b2fe6dcSGreg Clayton         lldb::ValueObjectSP result_valobj_sp;
3018b2fe6dcSGreg Clayton 
302e0d378b3SGreg Clayton         ExecutionResults exe_results;
30392adcac9SSean Callanan 
30492adcac9SSean Callanan         bool keep_in_memory = true;
30592adcac9SSean Callanan 
30635e1bda6SJim Ingham         EvaluateExpressionOptions options;
307*b576bba2SEnrico Granata         options.SetCoerceToId(m_varobj_options.use_objc)
308d4439aa9SEnrico Granata         .SetUnwindOnError(m_command_options.unwind_on_error)
309d4439aa9SEnrico Granata         .SetKeepInMemory(keep_in_memory)
310*b576bba2SEnrico Granata         .SetUseDynamic(m_varobj_options.use_dynamic)
31135e1bda6SJim Ingham         .SetRunOthers(m_command_options.try_all_threads)
31235e1bda6SJim Ingham         .SetTimeoutUsec(m_command_options.timeout);
313d4439aa9SEnrico Granata 
314c14ee32dSGreg Clayton         exe_results = target->EvaluateExpression (expr,
315f9fc609fSGreg Clayton                                                   m_exe_ctx.GetFramePtr(),
3163372f581SEnrico Granata                                                   result_valobj_sp,
317d4439aa9SEnrico Granata                                                   options);
3188b2fe6dcSGreg Clayton 
3191deb7962SGreg Clayton         if (exe_results == eExecutionInterrupted && !m_command_options.unwind_on_error)
3208b2fe6dcSGreg Clayton         {
3217260f620SGreg Clayton             uint32_t start_frame = 0;
3227260f620SGreg Clayton             uint32_t num_frames = 1;
3237260f620SGreg Clayton             uint32_t num_frames_with_source = 0;
324f9fc609fSGreg Clayton             Thread *thread = m_exe_ctx.GetThreadPtr();
325c14ee32dSGreg Clayton             if (thread)
3267260f620SGreg Clayton             {
327c14ee32dSGreg Clayton                 thread->GetStatus (result->GetOutputStream(),
3287260f620SGreg Clayton                                    start_frame,
3297260f620SGreg Clayton                                    num_frames,
3307260f620SGreg Clayton                                    num_frames_with_source);
3317260f620SGreg Clayton             }
332c14ee32dSGreg Clayton             else
333c14ee32dSGreg Clayton             {
334f9fc609fSGreg Clayton                 Process *process = m_exe_ctx.GetProcessPtr();
335c14ee32dSGreg Clayton                 if (process)
3367260f620SGreg Clayton                 {
3377260f620SGreg Clayton                     bool only_threads_with_stop_reason = true;
338c14ee32dSGreg Clayton                     process->GetThreadStatus (result->GetOutputStream(),
3397260f620SGreg Clayton                                               only_threads_with_stop_reason,
3407260f620SGreg Clayton                                               start_frame,
3417260f620SGreg Clayton                                               num_frames,
3427260f620SGreg Clayton                                               num_frames_with_source);
3437260f620SGreg Clayton                 }
3446961e878SSean Callanan             }
345c14ee32dSGreg Clayton         }
3466961e878SSean Callanan 
3478b2fe6dcSGreg Clayton         if (result_valobj_sp)
3488b2fe6dcSGreg Clayton         {
349bf154daeSSean Callanan             Format format = m_format_options.GetFormat();
350bf154daeSSean Callanan 
351b71f3844SGreg Clayton             if (result_valobj_sp->GetError().Success())
35230fdc8d8SChris Lattner             {
353bf154daeSSean Callanan                 if (format != eFormatVoid)
354bf154daeSSean Callanan                 {
3551deb7962SGreg Clayton                     if (format != eFormatDefault)
3561deb7962SGreg Clayton                         result_valobj_sp->SetFormat (format);
35732c4085bSGreg Clayton 
3580c489f58SEnrico Granata                     ValueObject::DumpValueObjectOptions options;
359*b576bba2SEnrico Granata                     options.SetMaximumPointerDepth(m_varobj_options.ptr_depth)
360*b576bba2SEnrico Granata                     .SetMaximumDepth(m_varobj_options.max_depth)
361*b576bba2SEnrico Granata                     .SetShowTypes(m_varobj_options.show_types)
362*b576bba2SEnrico Granata                     .SetShowLocation(m_varobj_options.show_location)
363*b576bba2SEnrico Granata                     .SetUseObjectiveC(m_varobj_options.use_objc)
364*b576bba2SEnrico Granata                     .SetUseDynamicType(m_varobj_options.use_dynamic)
365*b576bba2SEnrico Granata                     .SetUseSyntheticValue(m_varobj_options.use_synth)
366*b576bba2SEnrico Granata                     .SetFlatOutput(m_varobj_options.flat_output)
367*b576bba2SEnrico Granata                     .SetOmitSummaryDepth(m_varobj_options.no_summary_depth)
368*b576bba2SEnrico Granata                     .SetIgnoreCap(m_varobj_options.ignore_cap)
3690c489f58SEnrico Granata                     .SetFormat(format)
370770eb05aSEnrico Granata                     .SetSummary()
371*b576bba2SEnrico Granata                     .SetShowSummary(!m_varobj_options.use_objc)
372*b576bba2SEnrico Granata                     .SetHideRootType(m_varobj_options.use_objc);
373770eb05aSEnrico Granata 
3746e8dc334SCaroline Tice                     ValueObject::DumpValueObject (*(output_stream),
3750184f019SGreg Clayton                                                   result_valobj_sp.get(),   // Variable object to dump
3760c489f58SEnrico Granata                                                   options);
377fcd43b71SJohnny Chen                     if (result)
378fcd43b71SJohnny Chen                         result->SetStatus (eReturnStatusSuccessFinishResult);
37930fdc8d8SChris Lattner                 }
380bf154daeSSean Callanan             }
38130fdc8d8SChris Lattner             else
38230fdc8d8SChris Lattner             {
383bccce813SSean Callanan                 if (result_valobj_sp->GetError().GetError() == ClangUserExpression::kNoResult)
384bccce813SSean Callanan                 {
385bcf897faSSean Callanan                     if (format != eFormatVoid && m_interpreter.GetDebugger().GetNotifyVoid())
386bf154daeSSean Callanan                     {
387bcf897faSSean Callanan                         error_stream->PutCString("(void)\n");
388bcf897faSSean Callanan                     }
389bccce813SSean Callanan 
390bccce813SSean Callanan                     if (result)
391bccce813SSean Callanan                         result->SetStatus (eReturnStatusSuccessFinishResult);
392bccce813SSean Callanan                 }
393bccce813SSean Callanan                 else
394bccce813SSean Callanan                 {
3955fd05903SGreg Clayton                     const char *error_cstr = result_valobj_sp->GetError().AsCString();
3965fd05903SGreg Clayton                     if (error_cstr && error_cstr[0])
3975fd05903SGreg Clayton                     {
3985fd05903SGreg Clayton                         int error_cstr_len = strlen (error_cstr);
3995fd05903SGreg Clayton                         const bool ends_with_newline = error_cstr[error_cstr_len - 1] == '\n';
4005fd05903SGreg Clayton                         if (strstr(error_cstr, "error:") != error_cstr)
4015fd05903SGreg Clayton                             error_stream->PutCString ("error: ");
4025fd05903SGreg Clayton                         error_stream->Write(error_cstr, error_cstr_len);
4035fd05903SGreg Clayton                         if (!ends_with_newline)
4045fd05903SGreg Clayton                             error_stream->EOL();
4055fd05903SGreg Clayton                     }
4065fd05903SGreg Clayton                     else
4075fd05903SGreg Clayton                     {
4085fd05903SGreg Clayton                         error_stream->PutCString ("error: unknown error\n");
4095fd05903SGreg Clayton                     }
4105fd05903SGreg Clayton 
411fcd43b71SJohnny Chen                     if (result)
412b71f3844SGreg Clayton                         result->SetStatus (eReturnStatusFailed);
41330fdc8d8SChris Lattner                 }
4148b2fe6dcSGreg Clayton             }
4158b2fe6dcSGreg Clayton         }
416bccce813SSean Callanan     }
4178b2fe6dcSGreg Clayton     else
4188b2fe6dcSGreg Clayton     {
4196e8dc334SCaroline Tice         error_stream->Printf ("error: invalid execution context for expression\n");
4208b2fe6dcSGreg Clayton         return false;
4218b2fe6dcSGreg Clayton     }
42230fdc8d8SChris Lattner 
42316ad5faeSSean Callanan     return true;
42430fdc8d8SChris Lattner }
42530fdc8d8SChris Lattner 
42630fdc8d8SChris Lattner bool
4275a988416SJim Ingham CommandObjectExpression::DoExecute
42830fdc8d8SChris Lattner (
42930fdc8d8SChris Lattner     const char *command,
43030fdc8d8SChris Lattner     CommandReturnObject &result
43130fdc8d8SChris Lattner )
43230fdc8d8SChris Lattner {
4331deb7962SGreg Clayton     m_option_group.NotifyOptionParsingStarting();
43430fdc8d8SChris Lattner 
43530fdc8d8SChris Lattner     const char * expr = NULL;
43630fdc8d8SChris Lattner 
43730fdc8d8SChris Lattner     if (command[0] == '\0')
43830fdc8d8SChris Lattner     {
43930fdc8d8SChris Lattner         m_expr_lines.clear();
44030fdc8d8SChris Lattner         m_expr_line_count = 0;
44130fdc8d8SChris Lattner 
442a7015092SGreg Clayton         InputReaderSP reader_sp (new InputReader(m_interpreter.GetDebugger()));
44330fdc8d8SChris Lattner         if (reader_sp)
44430fdc8d8SChris Lattner         {
44530fdc8d8SChris Lattner             Error err (reader_sp->Initialize (CommandObjectExpression::MultiLineExpressionCallback,
44630fdc8d8SChris Lattner                                               this,                         // baton
44730fdc8d8SChris Lattner                                               eInputReaderGranularityLine,  // token size, to pass to callback function
44830fdc8d8SChris Lattner                                               NULL,                         // end token
44930fdc8d8SChris Lattner                                               NULL,                         // prompt
45030fdc8d8SChris Lattner                                               true));                       // echo input
45130fdc8d8SChris Lattner             if (err.Success())
45230fdc8d8SChris Lattner             {
453a7015092SGreg Clayton                 m_interpreter.GetDebugger().PushInputReader (reader_sp);
45430fdc8d8SChris Lattner                 result.SetStatus (eReturnStatusSuccessFinishNoResult);
45530fdc8d8SChris Lattner             }
45630fdc8d8SChris Lattner             else
45730fdc8d8SChris Lattner             {
45830fdc8d8SChris Lattner                 result.AppendError (err.AsCString());
45930fdc8d8SChris Lattner                 result.SetStatus (eReturnStatusFailed);
46030fdc8d8SChris Lattner             }
46130fdc8d8SChris Lattner         }
46230fdc8d8SChris Lattner         else
46330fdc8d8SChris Lattner         {
46430fdc8d8SChris Lattner             result.AppendError("out of memory");
46530fdc8d8SChris Lattner             result.SetStatus (eReturnStatusFailed);
46630fdc8d8SChris Lattner         }
46730fdc8d8SChris Lattner         return result.Succeeded();
46830fdc8d8SChris Lattner     }
46930fdc8d8SChris Lattner 
47030fdc8d8SChris Lattner     if (command[0] == '-')
47130fdc8d8SChris Lattner     {
47230fdc8d8SChris Lattner         // We have some options and these options MUST end with --.
47330fdc8d8SChris Lattner         const char *end_options = NULL;
47430fdc8d8SChris Lattner         const char *s = command;
47530fdc8d8SChris Lattner         while (s && s[0])
47630fdc8d8SChris Lattner         {
47730fdc8d8SChris Lattner             end_options = ::strstr (s, "--");
47830fdc8d8SChris Lattner             if (end_options)
47930fdc8d8SChris Lattner             {
48030fdc8d8SChris Lattner                 end_options += 2; // Get past the "--"
48130fdc8d8SChris Lattner                 if (::isspace (end_options[0]))
48230fdc8d8SChris Lattner                 {
48330fdc8d8SChris Lattner                     expr = end_options;
48430fdc8d8SChris Lattner                     while (::isspace (*expr))
48530fdc8d8SChris Lattner                         ++expr;
48630fdc8d8SChris Lattner                     break;
48730fdc8d8SChris Lattner                 }
48830fdc8d8SChris Lattner             }
48930fdc8d8SChris Lattner             s = end_options;
49030fdc8d8SChris Lattner         }
49130fdc8d8SChris Lattner 
49230fdc8d8SChris Lattner         if (end_options)
49330fdc8d8SChris Lattner         {
49430fdc8d8SChris Lattner             Args args (command, end_options - command);
495a7015092SGreg Clayton             if (!ParseOptions (args, result))
49630fdc8d8SChris Lattner                 return false;
497f6b8b581SGreg Clayton 
4981deb7962SGreg Clayton             Error error (m_option_group.NotifyOptionParsingFinished());
499f6b8b581SGreg Clayton             if (error.Fail())
500f6b8b581SGreg Clayton             {
501f6b8b581SGreg Clayton                 result.AppendError (error.AsCString());
502f6b8b581SGreg Clayton                 result.SetStatus (eReturnStatusFailed);
503f6b8b581SGreg Clayton                 return false;
504f6b8b581SGreg Clayton             }
50530fdc8d8SChris Lattner         }
50630fdc8d8SChris Lattner     }
50730fdc8d8SChris Lattner 
50830fdc8d8SChris Lattner     if (expr == NULL)
50930fdc8d8SChris Lattner         expr = command;
51030fdc8d8SChris Lattner 
5116e8dc334SCaroline Tice     if (EvaluateExpression (expr, &(result.GetOutputStream()), &(result.GetErrorStream()), &result))
512fcd43b71SJohnny Chen         return true;
513fcd43b71SJohnny Chen 
514fcd43b71SJohnny Chen     result.SetStatus (eReturnStatusFailed);
515fcd43b71SJohnny Chen     return false;
51630fdc8d8SChris Lattner }
51730fdc8d8SChris Lattner 
518