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