diff options
Diffstat (limited to 'lldb/source/Expression')
-rw-r--r-- | lldb/source/Expression/ASTResultSynthesizer.cpp | 6 | ||||
-rw-r--r-- | lldb/source/Expression/ClangUserExpression.cpp | 14 |
2 files changed, 14 insertions, 6 deletions
diff --git a/lldb/source/Expression/ASTResultSynthesizer.cpp b/lldb/source/Expression/ASTResultSynthesizer.cpp index 707875631bb..bcabfe3badc 100644 --- a/lldb/source/Expression/ASTResultSynthesizer.cpp +++ b/lldb/source/Expression/ASTResultSynthesizer.cpp @@ -24,11 +24,13 @@ using namespace llvm; using namespace clang; using namespace lldb_private; -ASTResultSynthesizer::ASTResultSynthesizer(ASTConsumer *passthrough) : +ASTResultSynthesizer::ASTResultSynthesizer(ASTConsumer *passthrough, + TypeFromUser desired_type) : m_ast_context (NULL), m_passthrough (passthrough), m_passthrough_sema (NULL), - m_sema (NULL) + m_sema (NULL), + m_desired_type (desired_type) { if (!m_passthrough) return; diff --git a/lldb/source/Expression/ClangUserExpression.cpp b/lldb/source/Expression/ClangUserExpression.cpp index f3515289741..3e4827b9f0f 100644 --- a/lldb/source/Expression/ClangUserExpression.cpp +++ b/lldb/source/Expression/ClangUserExpression.cpp @@ -44,7 +44,8 @@ ClangUserExpression::ClangUserExpression (const char *expr, m_jit_addr(LLDB_INVALID_ADDRESS), m_cplusplus(false), m_objectivec(false), - m_needs_object_ptr(false) + m_needs_object_ptr(false), + m_desired_type(NULL, NULL) { } @@ -55,7 +56,8 @@ ClangUserExpression::~ClangUserExpression () clang::ASTConsumer * ClangUserExpression::ASTTransformer (clang::ASTConsumer *passthrough) { - return new ASTResultSynthesizer(passthrough); + return new ASTResultSynthesizer(passthrough, + m_desired_type); } void @@ -115,7 +117,9 @@ ApplyUnicharHack(std::string &expr) } bool -ClangUserExpression::Parse (Stream &error_stream, ExecutionContext &exe_ctx) +ClangUserExpression::Parse (Stream &error_stream, + ExecutionContext &exe_ctx, + TypeFromUser desired_type) { lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS)); @@ -194,6 +198,8 @@ ClangUserExpression::Parse (Stream &error_stream, ExecutionContext &exe_ctx) // Parse the expression // + m_desired_type = desired_type; + m_expr_decl_map.reset(new ClangExpressionDeclMap(&exe_ctx)); ClangExpressionParser parser(target_triple.GetCString(), *this); @@ -452,7 +458,7 @@ ClangUserExpression::Evaluate (ExecutionContext &exe_ctx, StreamString error_stream; - if (!user_expression.Parse (error_stream, exe_ctx)) + if (!user_expression.Parse (error_stream, exe_ctx, TypeFromUser(NULL, NULL))) { if (error_stream.GetString().empty()) error.SetErrorString ("expression failed to parse, unknown error"); |