diff options
Diffstat (limited to 'lldb/source')
| -rw-r--r-- | lldb/source/Breakpoint/BreakpointOptions.cpp | 7 | ||||
| -rw-r--r-- | lldb/source/Expression/ASTResultSynthesizer.cpp | 6 | ||||
| -rw-r--r-- | lldb/source/Expression/ClangUserExpression.cpp | 14 | ||||
| -rw-r--r-- | lldb/source/Symbol/ClangASTContext.cpp | 6 |
4 files changed, 26 insertions, 7 deletions
diff --git a/lldb/source/Breakpoint/BreakpointOptions.cpp b/lldb/source/Breakpoint/BreakpointOptions.cpp index 713c2e90c50..975c8364053 100644 --- a/lldb/source/Breakpoint/BreakpointOptions.cpp +++ b/lldb/source/Breakpoint/BreakpointOptions.cpp @@ -18,6 +18,7 @@ #include "lldb/Core/Value.h" #include "lldb/Breakpoint/StoppointCallbackContext.h" #include "lldb/Target/Process.h" +#include "lldb/Target/Target.h" #include "lldb/Target/ThreadSpec.h" #include "lldb/Target/ThreadPlanTestCondition.h" @@ -193,8 +194,12 @@ BreakpointOptions::GetThreadPlanToTestCondition (ExecutionContext &exe_ctx, exe_ctx.process->SetDynamicCheckers(dynamic_checkers); } + + // Get the boolean type from the process's scratch AST context + ClangASTContext *ast_context = exe_ctx.target->GetScratchClangASTContext(); + TypeFromUser bool_type(ast_context->GetBuiltInType_bool(), ast_context->getASTContext()); - if (!m_condition_ap->Parse (error_stream, exe_ctx)) + if (!m_condition_ap->Parse (error_stream, exe_ctx, bool_type)) { // Errors mean we should stop. return NULL; 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"); diff --git a/lldb/source/Symbol/ClangASTContext.cpp b/lldb/source/Symbol/ClangASTContext.cpp index 1ab02b989f9..13302756339 100644 --- a/lldb/source/Symbol/ClangASTContext.cpp +++ b/lldb/source/Symbol/ClangASTContext.cpp @@ -671,6 +671,12 @@ ClangASTContext::GetBuiltInType_void(ASTContext *ast_context) } clang_type_t +ClangASTContext::GetBuiltInType_bool() +{ + return getASTContext()->BoolTy.getAsOpaquePtr(); +} + +clang_type_t ClangASTContext::GetBuiltInType_objc_id() { return getASTContext()->ObjCBuiltinIdTy.getAsOpaquePtr(); |

