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 
10*93a64300SDaniel Malea #include "lldb/lldb-python.h"
11*93a64300SDaniel 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."},
561deb7962SGreg Clayton     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "dynamic-value",      'd', required_argument, NULL, 0, eArgTypeBoolean,    "Upcast the value resulting from the expression to its dynamic type if available."},
5735e1bda6SJim Ingham     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "timeout",            't', required_argument, NULL, 0, eArgTypeUnsignedInteger,  "Timeout value for running the expression."},
581deb7962SGreg Clayton     { LLDB_OPT_SET_1 | LLDB_OPT_SET_2, false, "unwind-on-error",    'u', required_argument, NULL, 0, eArgTypeBoolean,    "Clean up program state if the expression causes a crash, breakpoint hit or signal."},
591deb7962SGreg Clayton     { LLDB_OPT_SET_2                 , false, "object-description", 'o', no_argument,       NULL, 0, eArgTypeNone,       "Print the object description of the value resulting from the expression."},
601deb7962SGreg Clayton };
611deb7962SGreg Clayton 
621deb7962SGreg Clayton 
631deb7962SGreg Clayton uint32_t
641deb7962SGreg Clayton CommandObjectExpression::CommandOptions::GetNumDefinitions ()
651deb7962SGreg Clayton {
661deb7962SGreg Clayton     return sizeof(g_option_table)/sizeof(OptionDefinition);
671deb7962SGreg Clayton }
681deb7962SGreg Clayton 
6930fdc8d8SChris Lattner Error
701deb7962SGreg Clayton CommandObjectExpression::CommandOptions::SetOptionValue (CommandInterpreter &interpreter,
711deb7962SGreg Clayton                                                          uint32_t option_idx,
721deb7962SGreg Clayton                                                          const char *option_arg)
7330fdc8d8SChris Lattner {
7430fdc8d8SChris Lattner     Error error;
7530fdc8d8SChris Lattner 
763bcdfc0eSGreg Clayton     const int short_option = g_option_table[option_idx].short_option;
7730fdc8d8SChris Lattner 
7830fdc8d8SChris Lattner     switch (short_option)
7930fdc8d8SChris Lattner     {
803f4c09c1SCaroline Tice       //case 'l':
813f4c09c1SCaroline Tice       //if (language.SetLanguageFromCString (option_arg) == false)
823f4c09c1SCaroline Tice       //{
8386edbf41SGreg Clayton       //    error.SetErrorStringWithFormat("invalid language option argument '%s'", option_arg);
843f4c09c1SCaroline Tice       //}
853f4c09c1SCaroline Tice       //break;
8630fdc8d8SChris Lattner 
8735e1bda6SJim Ingham     case 'a':
8835e1bda6SJim Ingham         {
8935e1bda6SJim Ingham             bool success;
9035e1bda6SJim Ingham             bool result;
9135e1bda6SJim Ingham             result = Args::StringToBoolean(option_arg, true, &success);
9235e1bda6SJim Ingham             if (!success)
9335e1bda6SJim Ingham                 error.SetErrorStringWithFormat("invalid all-threads value setting: \"%s\"", option_arg);
9435e1bda6SJim Ingham             else
9535e1bda6SJim Ingham                 try_all_threads = result;
9635e1bda6SJim Ingham         }
976c68fb45SJim Ingham         break;
986c68fb45SJim Ingham 
9978a685aaSJim Ingham     case 'd':
10078a685aaSJim Ingham         {
10178a685aaSJim Ingham             bool success;
10278a685aaSJim Ingham             bool result;
10378a685aaSJim Ingham             result = Args::StringToBoolean(option_arg, true, &success);
10478a685aaSJim Ingham             if (!success)
10586edbf41SGreg Clayton                 error.SetErrorStringWithFormat("invalid dynamic value setting: \"%s\"", option_arg);
10678a685aaSJim Ingham             else
10778a685aaSJim Ingham             {
10878a685aaSJim Ingham                 if (result)
10978a685aaSJim Ingham                     use_dynamic = eLazyBoolYes;
11078a685aaSJim Ingham                 else
11178a685aaSJim Ingham                     use_dynamic = eLazyBoolNo;
11278a685aaSJim Ingham             }
11378a685aaSJim Ingham         }
11478a685aaSJim Ingham         break;
11578a685aaSJim Ingham 
11635e1bda6SJim Ingham     case 'o':
11735e1bda6SJim Ingham         print_object = true;
11835e1bda6SJim Ingham         break;
11935e1bda6SJim Ingham 
12035e1bda6SJim Ingham     case 't':
12135e1bda6SJim Ingham         {
12235e1bda6SJim Ingham             bool success;
12335e1bda6SJim Ingham             uint32_t result;
12435e1bda6SJim Ingham             result = Args::StringToUInt32(option_arg, 0, 0, &success);
12535e1bda6SJim Ingham             if (success)
12635e1bda6SJim Ingham                 timeout = result;
12735e1bda6SJim Ingham             else
12835e1bda6SJim Ingham                 error.SetErrorStringWithFormat ("invalid timeout setting \"%s\"", option_arg);
12935e1bda6SJim Ingham         }
13035e1bda6SJim Ingham         break;
13135e1bda6SJim Ingham 
132399f1cafSJim Ingham     case 'u':
1333bfdaa2aSSean Callanan         {
134399f1cafSJim Ingham             bool success;
135399f1cafSJim Ingham             unwind_on_error = Args::StringToBoolean(option_arg, true, &success);
136399f1cafSJim Ingham             if (!success)
13786edbf41SGreg Clayton                 error.SetErrorStringWithFormat("could not convert \"%s\" to a boolean value.", option_arg);
138399f1cafSJim Ingham             break;
1393bfdaa2aSSean Callanan         }
14030fdc8d8SChris Lattner     default:
14186edbf41SGreg Clayton         error.SetErrorStringWithFormat("invalid short option character '%c'", short_option);
14230fdc8d8SChris Lattner         break;
14330fdc8d8SChris Lattner     }
14430fdc8d8SChris Lattner 
14530fdc8d8SChris Lattner     return error;
14630fdc8d8SChris Lattner }
14730fdc8d8SChris Lattner 
14830fdc8d8SChris Lattner void
1491deb7962SGreg Clayton CommandObjectExpression::CommandOptions::OptionParsingStarting (CommandInterpreter &interpreter)
15030fdc8d8SChris Lattner {
15178a685aaSJim Ingham     use_dynamic = eLazyBoolCalculate;
1521deb7962SGreg Clayton     print_object = false;
153399f1cafSJim Ingham     unwind_on_error = true;
15430fdc8d8SChris Lattner     show_types = true;
15530fdc8d8SChris Lattner     show_summary = true;
15635e1bda6SJim Ingham     try_all_threads = true;
15735e1bda6SJim Ingham     timeout = 0;
15830fdc8d8SChris Lattner }
15930fdc8d8SChris Lattner 
160e0d378b3SGreg Clayton const OptionDefinition*
16130fdc8d8SChris Lattner CommandObjectExpression::CommandOptions::GetDefinitions ()
16230fdc8d8SChris Lattner {
16330fdc8d8SChris Lattner     return g_option_table;
16430fdc8d8SChris Lattner }
16530fdc8d8SChris Lattner 
166a7015092SGreg Clayton CommandObjectExpression::CommandObjectExpression (CommandInterpreter &interpreter) :
1675a988416SJim Ingham     CommandObjectRaw (interpreter,
16830fdc8d8SChris Lattner                       "expression",
1695c48d5c5SJim Ingham                       "Evaluate a C/ObjC/C++ expression in the current program context, using user defined variables and variables currently in scope.",
1705a988416SJim Ingham                       NULL,
1715a988416SJim Ingham                       eFlagProcessMustBePaused),
1721deb7962SGreg Clayton     m_option_group (interpreter),
1731deb7962SGreg Clayton     m_format_options (eFormatDefault),
1741deb7962SGreg Clayton     m_command_options (),
17530fdc8d8SChris Lattner     m_expr_line_count (0),
17630fdc8d8SChris Lattner     m_expr_lines ()
17730fdc8d8SChris Lattner {
17830fdc8d8SChris Lattner   SetHelpLong(
17935e1bda6SJim Ingham "Timeouts:\n\
18035e1bda6SJim Ingham     If the expression can be evaluated statically (without runnning code) then it will be.\n\
18135e1bda6SJim Ingham     Otherwise, by default the expression will run on the current thread with a short timeout:\n\
18235e1bda6SJim Ingham     currently .25 seconds.  If it doesn't return in that time, the evaluation will be interrupted\n\
18335e1bda6SJim Ingham     and resumed with all threads running.  You can use the -a option to disable retrying on all\n\
18435e1bda6SJim Ingham     threads.  You can use the -t option to set a shorter timeout.\n\
1855c48d5c5SJim Ingham \n\
1865c48d5c5SJim Ingham User defined variables:\n\
1875c48d5c5SJim Ingham     You can define your own variables for convenience or to be used in subsequent expressions.\n\
1885c48d5c5SJim Ingham     You define them the same way you would define variables in C.  If the first character of \n\
1895c48d5c5SJim Ingham     your user defined variable is a $, then the variable's value will be available in future\n\
1905c48d5c5SJim Ingham     expressions, otherwise it will just be available in the current expression.\n\
1915c48d5c5SJim Ingham \n\
19235e1bda6SJim Ingham Examples: \n\
19330fdc8d8SChris Lattner \n\
19430fdc8d8SChris Lattner    expr my_struct->a = my_array[3] \n\
19530fdc8d8SChris Lattner    expr -f bin -- (index * 8) + 5 \n\
1965c48d5c5SJim Ingham    expr unsigned int $foo = 5\n\
19730fdc8d8SChris Lattner    expr char c[] = \"foo\"; c[0]\n");
198405fe67fSCaroline Tice 
199405fe67fSCaroline Tice     CommandArgumentEntry arg;
200405fe67fSCaroline Tice     CommandArgumentData expression_arg;
201405fe67fSCaroline Tice 
202405fe67fSCaroline Tice     // Define the first (and only) variant of this arg.
203405fe67fSCaroline Tice     expression_arg.arg_type = eArgTypeExpression;
204405fe67fSCaroline Tice     expression_arg.arg_repetition = eArgRepeatPlain;
205405fe67fSCaroline Tice 
206405fe67fSCaroline Tice     // There is only one variant this argument could be; put it into the argument entry.
207405fe67fSCaroline Tice     arg.push_back (expression_arg);
208405fe67fSCaroline Tice 
209405fe67fSCaroline Tice     // Push the data for the first argument into the m_arguments vector.
210405fe67fSCaroline Tice     m_arguments.push_back (arg);
2111deb7962SGreg Clayton 
2125009f9d5SGreg Clayton     // Add the "--format" and "--gdb-format"
2135009f9d5SGreg Clayton     m_option_group.Append (&m_format_options, OptionGroupFormat::OPTION_GROUP_FORMAT | OptionGroupFormat::OPTION_GROUP_GDB_FMT, LLDB_OPT_SET_1);
2141deb7962SGreg Clayton     m_option_group.Append (&m_command_options);
2151deb7962SGreg Clayton     m_option_group.Finalize();
21630fdc8d8SChris Lattner }
21730fdc8d8SChris Lattner 
21830fdc8d8SChris Lattner CommandObjectExpression::~CommandObjectExpression ()
21930fdc8d8SChris Lattner {
22030fdc8d8SChris Lattner }
22130fdc8d8SChris Lattner 
22230fdc8d8SChris Lattner Options *
22330fdc8d8SChris Lattner CommandObjectExpression::GetOptions ()
22430fdc8d8SChris Lattner {
2251deb7962SGreg Clayton     return &m_option_group;
22630fdc8d8SChris Lattner }
22730fdc8d8SChris Lattner 
22830fdc8d8SChris Lattner size_t
22930fdc8d8SChris Lattner CommandObjectExpression::MultiLineExpressionCallback
23030fdc8d8SChris Lattner (
23130fdc8d8SChris Lattner     void *baton,
2326611103cSGreg Clayton     InputReader &reader,
23330fdc8d8SChris Lattner     lldb::InputReaderAction notification,
23430fdc8d8SChris Lattner     const char *bytes,
23530fdc8d8SChris Lattner     size_t bytes_len
23630fdc8d8SChris Lattner )
23730fdc8d8SChris Lattner {
23830fdc8d8SChris Lattner     CommandObjectExpression *cmd_object_expr = (CommandObjectExpression *) baton;
239d61c10bcSCaroline Tice     bool batch_mode = reader.GetDebugger().GetCommandInterpreter().GetBatchCommandMode();
24030fdc8d8SChris Lattner 
24130fdc8d8SChris Lattner     switch (notification)
24230fdc8d8SChris Lattner     {
24330fdc8d8SChris Lattner     case eInputReaderActivate:
244d61c10bcSCaroline Tice         if (!batch_mode)
24515356e7fSCaroline Tice         {
24607e66e3eSGreg Clayton             StreamSP async_strm_sp(reader.GetDebugger().GetAsyncOutputStream());
24707e66e3eSGreg Clayton             if (async_strm_sp)
24807e66e3eSGreg Clayton             {
24907e66e3eSGreg Clayton                 async_strm_sp->PutCString("Enter expressions, then terminate with an empty line to evaluate:\n");
25007e66e3eSGreg Clayton                 async_strm_sp->Flush();
25107e66e3eSGreg Clayton             }
25215356e7fSCaroline Tice         }
25330fdc8d8SChris Lattner         // Fall through
25430fdc8d8SChris Lattner     case eInputReaderReactivate:
25530fdc8d8SChris Lattner         break;
25630fdc8d8SChris Lattner 
25730fdc8d8SChris Lattner     case eInputReaderDeactivate:
25830fdc8d8SChris Lattner         break;
25930fdc8d8SChris Lattner 
260969ed3d1SCaroline Tice     case eInputReaderAsynchronousOutputWritten:
261969ed3d1SCaroline Tice         break;
262969ed3d1SCaroline Tice 
26330fdc8d8SChris Lattner     case eInputReaderGotToken:
26430fdc8d8SChris Lattner         ++cmd_object_expr->m_expr_line_count;
26530fdc8d8SChris Lattner         if (bytes && bytes_len)
26630fdc8d8SChris Lattner         {
26730fdc8d8SChris Lattner             cmd_object_expr->m_expr_lines.append (bytes, bytes_len + 1);
26830fdc8d8SChris Lattner         }
26930fdc8d8SChris Lattner 
27030fdc8d8SChris Lattner         if (bytes_len == 0)
2716611103cSGreg Clayton             reader.SetIsDone(true);
27230fdc8d8SChris Lattner         break;
27330fdc8d8SChris Lattner 
274efed6131SCaroline Tice     case eInputReaderInterrupt:
275efed6131SCaroline Tice         cmd_object_expr->m_expr_lines.clear();
276efed6131SCaroline Tice         reader.SetIsDone (true);
277d61c10bcSCaroline Tice         if (!batch_mode)
27815356e7fSCaroline Tice         {
27907e66e3eSGreg Clayton             StreamSP async_strm_sp (reader.GetDebugger().GetAsyncOutputStream());
28007e66e3eSGreg Clayton             if (async_strm_sp)
28107e66e3eSGreg Clayton             {
28207e66e3eSGreg Clayton                 async_strm_sp->PutCString("Expression evaluation cancelled.\n");
28307e66e3eSGreg Clayton                 async_strm_sp->Flush();
28407e66e3eSGreg Clayton             }
28515356e7fSCaroline Tice         }
286efed6131SCaroline Tice         break;
287efed6131SCaroline Tice 
288efed6131SCaroline Tice     case eInputReaderEndOfFile:
289efed6131SCaroline Tice         reader.SetIsDone (true);
290efed6131SCaroline Tice         break;
291efed6131SCaroline Tice 
29230fdc8d8SChris Lattner     case eInputReaderDone:
293efed6131SCaroline Tice 		if (cmd_object_expr->m_expr_lines.size() > 0)
29430fdc8d8SChris Lattner         {
2956e8dc334SCaroline Tice             StreamSP output_stream = reader.GetDebugger().GetAsyncOutputStream();
2966e8dc334SCaroline Tice             StreamSP error_stream = reader.GetDebugger().GetAsyncErrorStream();
29730fdc8d8SChris Lattner             cmd_object_expr->EvaluateExpression (cmd_object_expr->m_expr_lines.c_str(),
2986e8dc334SCaroline Tice                                                  output_stream.get(),
2996e8dc334SCaroline Tice                                                  error_stream.get());
3006e8dc334SCaroline Tice             output_stream->Flush();
3016e8dc334SCaroline Tice             error_stream->Flush();
30230fdc8d8SChris Lattner         }
30330fdc8d8SChris Lattner         break;
30430fdc8d8SChris Lattner     }
30530fdc8d8SChris Lattner 
30630fdc8d8SChris Lattner     return bytes_len;
30730fdc8d8SChris Lattner }
30830fdc8d8SChris Lattner 
30930fdc8d8SChris Lattner bool
3101d3afba3SGreg Clayton CommandObjectExpression::EvaluateExpression
3111d3afba3SGreg Clayton (
3121d3afba3SGreg Clayton     const char *expr,
3136e8dc334SCaroline Tice     Stream *output_stream,
3146e8dc334SCaroline Tice     Stream *error_stream,
3151d3afba3SGreg Clayton     CommandReturnObject *result
3161d3afba3SGreg Clayton )
31730fdc8d8SChris Lattner {
318a73d2692SGreg Clayton     Target *target = m_interpreter.GetExecutionContext().GetTargetPtr();
319c0a6e061SSean Callanan 
320c0a6e061SSean Callanan     if (!target)
321c0a6e061SSean Callanan         target = Host::GetDummyTarget(m_interpreter.GetDebugger()).get();
322c0a6e061SSean Callanan 
323c14ee32dSGreg Clayton     if (target)
3246961e878SSean Callanan     {
3258b2fe6dcSGreg Clayton         lldb::ValueObjectSP result_valobj_sp;
3268b2fe6dcSGreg Clayton 
327e0d378b3SGreg Clayton         ExecutionResults exe_results;
32892adcac9SSean Callanan 
32992adcac9SSean Callanan         bool keep_in_memory = true;
3302837b766SJim Ingham         lldb::DynamicValueType use_dynamic;
33178a685aaSJim Ingham         // If use dynamic is not set, get it from the target:
3321deb7962SGreg Clayton         switch (m_command_options.use_dynamic)
33378a685aaSJim Ingham         {
33478a685aaSJim Ingham         case eLazyBoolCalculate:
335c14ee32dSGreg Clayton             use_dynamic = target->GetPreferDynamicValue();
33678a685aaSJim Ingham             break;
33778a685aaSJim Ingham         case eLazyBoolYes:
3382837b766SJim Ingham             use_dynamic = lldb::eDynamicCanRunTarget;
33978a685aaSJim Ingham             break;
34078a685aaSJim Ingham         case eLazyBoolNo:
3412837b766SJim Ingham             use_dynamic = lldb::eNoDynamicValues;
34278a685aaSJim Ingham             break;
34378a685aaSJim Ingham         }
34492adcac9SSean Callanan 
34535e1bda6SJim Ingham         EvaluateExpressionOptions options;
346d4439aa9SEnrico Granata         options.SetCoerceToId(m_command_options.print_object)
347d4439aa9SEnrico Granata         .SetUnwindOnError(m_command_options.unwind_on_error)
348d4439aa9SEnrico Granata         .SetKeepInMemory(keep_in_memory)
349d4439aa9SEnrico Granata         .SetUseDynamic(use_dynamic)
35035e1bda6SJim Ingham         .SetRunOthers(m_command_options.try_all_threads)
35135e1bda6SJim Ingham         .SetTimeoutUsec(m_command_options.timeout);
352d4439aa9SEnrico Granata 
353c14ee32dSGreg Clayton         exe_results = target->EvaluateExpression (expr,
354a73d2692SGreg Clayton                                                   m_interpreter.GetExecutionContext().GetFramePtr(),
3553372f581SEnrico Granata                                                   result_valobj_sp,
356d4439aa9SEnrico Granata                                                   options);
3578b2fe6dcSGreg Clayton 
3581deb7962SGreg Clayton         if (exe_results == eExecutionInterrupted && !m_command_options.unwind_on_error)
3598b2fe6dcSGreg Clayton         {
3607260f620SGreg Clayton             uint32_t start_frame = 0;
3617260f620SGreg Clayton             uint32_t num_frames = 1;
3627260f620SGreg Clayton             uint32_t num_frames_with_source = 0;
363a73d2692SGreg Clayton             Thread *thread = m_interpreter.GetExecutionContext().GetThreadPtr();
364c14ee32dSGreg Clayton             if (thread)
3657260f620SGreg Clayton             {
366c14ee32dSGreg Clayton                 thread->GetStatus (result->GetOutputStream(),
3677260f620SGreg Clayton                                    start_frame,
3687260f620SGreg Clayton                                    num_frames,
3697260f620SGreg Clayton                                    num_frames_with_source);
3707260f620SGreg Clayton             }
371c14ee32dSGreg Clayton             else
372c14ee32dSGreg Clayton             {
373a73d2692SGreg Clayton                 Process *process = m_interpreter.GetExecutionContext().GetProcessPtr();
374c14ee32dSGreg Clayton                 if (process)
3757260f620SGreg Clayton                 {
3767260f620SGreg Clayton                     bool only_threads_with_stop_reason = true;
377c14ee32dSGreg Clayton                     process->GetThreadStatus (result->GetOutputStream(),
3787260f620SGreg Clayton                                               only_threads_with_stop_reason,
3797260f620SGreg Clayton                                               start_frame,
3807260f620SGreg Clayton                                               num_frames,
3817260f620SGreg Clayton                                               num_frames_with_source);
3827260f620SGreg Clayton                 }
3836961e878SSean Callanan             }
384c14ee32dSGreg Clayton         }
3856961e878SSean Callanan 
3868b2fe6dcSGreg Clayton         if (result_valobj_sp)
3878b2fe6dcSGreg Clayton         {
388bf154daeSSean Callanan             Format format = m_format_options.GetFormat();
389bf154daeSSean Callanan 
390b71f3844SGreg Clayton             if (result_valobj_sp->GetError().Success())
39130fdc8d8SChris Lattner             {
392bf154daeSSean Callanan                 if (format != eFormatVoid)
393bf154daeSSean Callanan                 {
3941deb7962SGreg Clayton                     if (format != eFormatDefault)
3951deb7962SGreg Clayton                         result_valobj_sp->SetFormat (format);
39632c4085bSGreg Clayton 
3970c489f58SEnrico Granata                     ValueObject::DumpValueObjectOptions options;
3980c489f58SEnrico Granata                     options.SetMaximumPointerDepth(0)
3990c489f58SEnrico Granata                     .SetMaximumDepth(UINT32_MAX)
4000c489f58SEnrico Granata                     .SetShowLocation(false)
4010c489f58SEnrico Granata                     .SetShowTypes(m_command_options.show_types)
4020c489f58SEnrico Granata                     .SetUseObjectiveC(m_command_options.print_object)
4030c489f58SEnrico Granata                     .SetUseDynamicType(use_dynamic)
4040c489f58SEnrico Granata                     .SetScopeChecked(true)
4050c489f58SEnrico Granata                     .SetFlatOutput(false)
40686cc9829SEnrico Granata                     .SetUseSyntheticValue(true)
4070c489f58SEnrico Granata                     .SetIgnoreCap(false)
4080c489f58SEnrico Granata                     .SetFormat(format)
409770eb05aSEnrico Granata                     .SetSummary()
4102b2631c9SEnrico Granata                     .SetShowSummary(!m_command_options.print_object)
4112b2631c9SEnrico Granata                     .SetHideRootType(m_command_options.print_object);
412770eb05aSEnrico Granata 
4136e8dc334SCaroline Tice                     ValueObject::DumpValueObject (*(output_stream),
4140184f019SGreg Clayton                                                   result_valobj_sp.get(),   // Variable object to dump
4150c489f58SEnrico Granata                                                   options);
416fcd43b71SJohnny Chen                     if (result)
417fcd43b71SJohnny Chen                         result->SetStatus (eReturnStatusSuccessFinishResult);
41830fdc8d8SChris Lattner                 }
419bf154daeSSean Callanan             }
42030fdc8d8SChris Lattner             else
42130fdc8d8SChris Lattner             {
422bccce813SSean Callanan                 if (result_valobj_sp->GetError().GetError() == ClangUserExpression::kNoResult)
423bccce813SSean Callanan                 {
424bcf897faSSean Callanan                     if (format != eFormatVoid && m_interpreter.GetDebugger().GetNotifyVoid())
425bf154daeSSean Callanan                     {
426bcf897faSSean Callanan                         error_stream->PutCString("(void)\n");
427bcf897faSSean Callanan                     }
428bccce813SSean Callanan 
429bccce813SSean Callanan                     if (result)
430bccce813SSean Callanan                         result->SetStatus (eReturnStatusSuccessFinishResult);
431bccce813SSean Callanan                 }
432bccce813SSean Callanan                 else
433bccce813SSean Callanan                 {
4345fd05903SGreg Clayton                     const char *error_cstr = result_valobj_sp->GetError().AsCString();
4355fd05903SGreg Clayton                     if (error_cstr && error_cstr[0])
4365fd05903SGreg Clayton                     {
4375fd05903SGreg Clayton                         int error_cstr_len = strlen (error_cstr);
4385fd05903SGreg Clayton                         const bool ends_with_newline = error_cstr[error_cstr_len - 1] == '\n';
4395fd05903SGreg Clayton                         if (strstr(error_cstr, "error:") != error_cstr)
4405fd05903SGreg Clayton                             error_stream->PutCString ("error: ");
4415fd05903SGreg Clayton                         error_stream->Write(error_cstr, error_cstr_len);
4425fd05903SGreg Clayton                         if (!ends_with_newline)
4435fd05903SGreg Clayton                             error_stream->EOL();
4445fd05903SGreg Clayton                     }
4455fd05903SGreg Clayton                     else
4465fd05903SGreg Clayton                     {
4475fd05903SGreg Clayton                         error_stream->PutCString ("error: unknown error\n");
4485fd05903SGreg Clayton                     }
4495fd05903SGreg Clayton 
450fcd43b71SJohnny Chen                     if (result)
451b71f3844SGreg Clayton                         result->SetStatus (eReturnStatusFailed);
45230fdc8d8SChris Lattner                 }
4538b2fe6dcSGreg Clayton             }
4548b2fe6dcSGreg Clayton         }
455bccce813SSean Callanan     }
4568b2fe6dcSGreg Clayton     else
4578b2fe6dcSGreg Clayton     {
4586e8dc334SCaroline Tice         error_stream->Printf ("error: invalid execution context for expression\n");
4598b2fe6dcSGreg Clayton         return false;
4608b2fe6dcSGreg Clayton     }
46130fdc8d8SChris Lattner 
46216ad5faeSSean Callanan     return true;
46330fdc8d8SChris Lattner }
46430fdc8d8SChris Lattner 
46530fdc8d8SChris Lattner bool
4665a988416SJim Ingham CommandObjectExpression::DoExecute
46730fdc8d8SChris Lattner (
46830fdc8d8SChris Lattner     const char *command,
46930fdc8d8SChris Lattner     CommandReturnObject &result
47030fdc8d8SChris Lattner )
47130fdc8d8SChris Lattner {
4721deb7962SGreg Clayton     m_option_group.NotifyOptionParsingStarting();
47330fdc8d8SChris Lattner 
47430fdc8d8SChris Lattner     const char * expr = NULL;
47530fdc8d8SChris Lattner 
47630fdc8d8SChris Lattner     if (command[0] == '\0')
47730fdc8d8SChris Lattner     {
47830fdc8d8SChris Lattner         m_expr_lines.clear();
47930fdc8d8SChris Lattner         m_expr_line_count = 0;
48030fdc8d8SChris Lattner 
481a7015092SGreg Clayton         InputReaderSP reader_sp (new InputReader(m_interpreter.GetDebugger()));
48230fdc8d8SChris Lattner         if (reader_sp)
48330fdc8d8SChris Lattner         {
48430fdc8d8SChris Lattner             Error err (reader_sp->Initialize (CommandObjectExpression::MultiLineExpressionCallback,
48530fdc8d8SChris Lattner                                               this,                         // baton
48630fdc8d8SChris Lattner                                               eInputReaderGranularityLine,  // token size, to pass to callback function
48730fdc8d8SChris Lattner                                               NULL,                         // end token
48830fdc8d8SChris Lattner                                               NULL,                         // prompt
48930fdc8d8SChris Lattner                                               true));                       // echo input
49030fdc8d8SChris Lattner             if (err.Success())
49130fdc8d8SChris Lattner             {
492a7015092SGreg Clayton                 m_interpreter.GetDebugger().PushInputReader (reader_sp);
49330fdc8d8SChris Lattner                 result.SetStatus (eReturnStatusSuccessFinishNoResult);
49430fdc8d8SChris Lattner             }
49530fdc8d8SChris Lattner             else
49630fdc8d8SChris Lattner             {
49730fdc8d8SChris Lattner                 result.AppendError (err.AsCString());
49830fdc8d8SChris Lattner                 result.SetStatus (eReturnStatusFailed);
49930fdc8d8SChris Lattner             }
50030fdc8d8SChris Lattner         }
50130fdc8d8SChris Lattner         else
50230fdc8d8SChris Lattner         {
50330fdc8d8SChris Lattner             result.AppendError("out of memory");
50430fdc8d8SChris Lattner             result.SetStatus (eReturnStatusFailed);
50530fdc8d8SChris Lattner         }
50630fdc8d8SChris Lattner         return result.Succeeded();
50730fdc8d8SChris Lattner     }
50830fdc8d8SChris Lattner 
50930fdc8d8SChris Lattner     if (command[0] == '-')
51030fdc8d8SChris Lattner     {
51130fdc8d8SChris Lattner         // We have some options and these options MUST end with --.
51230fdc8d8SChris Lattner         const char *end_options = NULL;
51330fdc8d8SChris Lattner         const char *s = command;
51430fdc8d8SChris Lattner         while (s && s[0])
51530fdc8d8SChris Lattner         {
51630fdc8d8SChris Lattner             end_options = ::strstr (s, "--");
51730fdc8d8SChris Lattner             if (end_options)
51830fdc8d8SChris Lattner             {
51930fdc8d8SChris Lattner                 end_options += 2; // Get past the "--"
52030fdc8d8SChris Lattner                 if (::isspace (end_options[0]))
52130fdc8d8SChris Lattner                 {
52230fdc8d8SChris Lattner                     expr = end_options;
52330fdc8d8SChris Lattner                     while (::isspace (*expr))
52430fdc8d8SChris Lattner                         ++expr;
52530fdc8d8SChris Lattner                     break;
52630fdc8d8SChris Lattner                 }
52730fdc8d8SChris Lattner             }
52830fdc8d8SChris Lattner             s = end_options;
52930fdc8d8SChris Lattner         }
53030fdc8d8SChris Lattner 
53130fdc8d8SChris Lattner         if (end_options)
53230fdc8d8SChris Lattner         {
53330fdc8d8SChris Lattner             Args args (command, end_options - command);
534a7015092SGreg Clayton             if (!ParseOptions (args, result))
53530fdc8d8SChris Lattner                 return false;
536f6b8b581SGreg Clayton 
5371deb7962SGreg Clayton             Error error (m_option_group.NotifyOptionParsingFinished());
538f6b8b581SGreg Clayton             if (error.Fail())
539f6b8b581SGreg Clayton             {
540f6b8b581SGreg Clayton                 result.AppendError (error.AsCString());
541f6b8b581SGreg Clayton                 result.SetStatus (eReturnStatusFailed);
542f6b8b581SGreg Clayton                 return false;
543f6b8b581SGreg Clayton             }
54430fdc8d8SChris Lattner         }
54530fdc8d8SChris Lattner     }
54630fdc8d8SChris Lattner 
54730fdc8d8SChris Lattner     if (expr == NULL)
54830fdc8d8SChris Lattner         expr = command;
54930fdc8d8SChris Lattner 
5506e8dc334SCaroline Tice     if (EvaluateExpression (expr, &(result.GetOutputStream()), &(result.GetErrorStream()), &result))
551fcd43b71SJohnny Chen         return true;
552fcd43b71SJohnny Chen 
553fcd43b71SJohnny Chen     result.SetStatus (eReturnStatusFailed);
554fcd43b71SJohnny Chen     return false;
55530fdc8d8SChris Lattner }
55630fdc8d8SChris Lattner 
557