Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 1 | //===-- ClangExpressionVariable.cpp -----------------------------*- C++ -*-===// |
| 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | |
| 10 | #include "lldb/Expression/ClangExpressionVariable.h" |
| 11 | |
| 12 | // C Includes |
| 13 | // C++ Includes |
| 14 | // Other libraries and framework includes |
| 15 | // Project includes |
| 16 | #include "clang/AST/ASTContext.h" |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 17 | #include "lldb/Core/ConstString.h" |
| 18 | #include "lldb/Core/DataExtractor.h" |
| 19 | #include "lldb/Core/Stream.h" |
| 20 | #include "lldb/Core/Value.h" |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 21 | #include "lldb/Core/ValueObjectConstResult.h" |
Sean Callanan | e8a59a8 | 2010-09-13 21:34:21 +0000 | [diff] [blame] | 22 | #include "lldb/Target/ExecutionContext.h" |
| 23 | #include "lldb/Target/Process.h" |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 24 | |
| 25 | using namespace lldb_private; |
| 26 | using namespace clang; |
| 27 | |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 28 | ClangExpressionVariable::ClangExpressionVariable() : |
| 29 | m_name(), |
| 30 | m_user_type (TypeFromUser(NULL, NULL)), |
| 31 | m_store (NULL), |
| 32 | m_index (0), |
| 33 | m_parser_vars(), |
| 34 | m_jit_vars (), |
| 35 | m_data_sp () |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 36 | { |
| 37 | } |
| 38 | |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 39 | void |
| 40 | ClangExpressionVariable::DisableDataVars() |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 41 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 42 | m_data_sp.reset(); |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 43 | } |
| 44 | |
Jim Ingham | 324067b | 2010-09-30 00:54:27 +0000 | [diff] [blame] | 45 | |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 46 | ClangExpressionVariable::ClangExpressionVariable(const ClangExpressionVariable &rhs) : |
| 47 | m_name(rhs.m_name), |
| 48 | m_user_type(rhs.m_user_type), |
| 49 | m_store(rhs.m_store), |
| 50 | m_index(rhs.m_index) |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 51 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 52 | if (rhs.m_parser_vars.get()) |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 53 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 54 | // TODO: Sean, can m_parser_vars be a shared pointer??? We are copy |
| 55 | // constructing it here. That is ok if we need to, but do we really |
| 56 | // need to? |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 57 | m_parser_vars.reset(new struct ParserVars); |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 58 | *m_parser_vars.get() = *rhs.m_parser_vars.get(); |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 59 | } |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 60 | |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 61 | if (rhs.m_jit_vars.get()) |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 62 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 63 | // TODO: Sean, can m_jit_vars be a shared pointer??? We are copy |
| 64 | // constructing it here. That is ok if we need to, but do we really |
| 65 | // need to? |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 66 | m_jit_vars.reset(new struct JITVars); |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 67 | *m_jit_vars.get() = *rhs.m_jit_vars.get(); |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 68 | } |
| 69 | |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 70 | if (rhs.m_data_sp) |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 71 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 72 | // TODO: Sean, does m_data_sp need to be copy constructed? Or can it |
| 73 | // shared the data? |
| 74 | |
| 75 | m_data_sp.reset(new DataBufferHeap (rhs.m_data_sp->GetBytes(), |
| 76 | rhs.m_data_sp->GetByteSize())); |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 77 | } |
| 78 | } |
| 79 | |
| 80 | bool |
Jim Ingham | 324067b | 2010-09-30 00:54:27 +0000 | [diff] [blame] | 81 | ClangExpressionVariable::PointValueAtData(Value &value, ExecutionContext *exe_ctx) |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 82 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 83 | if (m_data_sp.get() == NULL) |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 84 | return false; |
| 85 | |
| 86 | value.SetContext(Value::eContextTypeOpaqueClangQualType, m_user_type.GetOpaqueQualType()); |
| 87 | value.SetValueType(Value::eValueTypeHostAddress); |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 88 | value.GetScalar() = (uintptr_t)m_data_sp->GetBytes(); |
Jim Ingham | 324067b | 2010-09-30 00:54:27 +0000 | [diff] [blame] | 89 | clang::ASTContext *ast_context = m_user_type.GetASTContext(); |
| 90 | |
| 91 | if (exe_ctx) |
| 92 | value.ResolveValue (exe_ctx, ast_context); |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 93 | |
| 94 | return true; |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 95 | } |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame^] | 96 | |
| 97 | void |
| 98 | ClangExpressionVariable::EnableDataVars() |
| 99 | { |
| 100 | if (!m_data_sp.get()) |
| 101 | m_data_sp.reset(new DataBufferHeap); |
| 102 | } |
| 103 | |
| 104 | lldb::ValueObjectSP |
| 105 | ClangExpressionVariable::GetExpressionResult (ExecutionContext *exe_ctx) |
| 106 | { |
| 107 | lldb::ValueObjectSP result_sp; |
| 108 | if (m_data_sp) |
| 109 | { |
| 110 | Target * target = NULL; |
| 111 | Process *process = NULL; |
| 112 | if (exe_ctx) |
| 113 | { |
| 114 | target = exe_ctx->target; |
| 115 | process = exe_ctx->process; |
| 116 | } |
| 117 | |
| 118 | Value value; |
| 119 | if (PointValueAtData(value, exe_ctx)) |
| 120 | { |
| 121 | lldb::ByteOrder byte_order = lldb::eByteOrderHost; |
| 122 | uint32_t addr_byte_size = 4; |
| 123 | if (process) |
| 124 | { |
| 125 | byte_order = process->GetByteOrder(); |
| 126 | addr_byte_size = process->GetAddressByteSize(); |
| 127 | } |
| 128 | result_sp.reset (new ValueObjectConstResult (m_user_type.GetASTContext(), |
| 129 | m_user_type.GetOpaqueQualType(), |
| 130 | ConstString (m_name.c_str()), |
| 131 | m_data_sp,// TODO: sean can you get this to be valid? |
| 132 | byte_order, |
| 133 | addr_byte_size)); |
| 134 | } |
| 135 | } |
| 136 | return result_sp; |
| 137 | } |
| 138 | |