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), |
Sean Callanan | 1ddd9fe | 2010-11-30 00:27:43 +0000 | [diff] [blame] | 32 | m_register_info (NULL), |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 33 | m_index (0), |
| 34 | m_parser_vars(), |
| 35 | m_jit_vars (), |
| 36 | m_data_sp () |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 37 | { |
| 38 | } |
| 39 | |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 40 | void |
| 41 | ClangExpressionVariable::DisableDataVars() |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 42 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 43 | m_data_sp.reset(); |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 44 | } |
| 45 | |
Jim Ingham | 324067b | 2010-09-30 00:54:27 +0000 | [diff] [blame] | 46 | |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 47 | ClangExpressionVariable::ClangExpressionVariable(const ClangExpressionVariable &rhs) : |
| 48 | m_name(rhs.m_name), |
| 49 | m_user_type(rhs.m_user_type), |
Sean Callanan | 1e61a63 | 2010-11-30 22:01:58 +0000 | [diff] [blame] | 50 | m_store(rhs.m_store), |
| 51 | m_register_info(rhs.m_register_info), |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 52 | m_index(rhs.m_index) |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 53 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 54 | if (rhs.m_parser_vars.get()) |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 55 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 56 | // TODO: Sean, can m_parser_vars be a shared pointer??? We are copy |
| 57 | // constructing it here. That is ok if we need to, but do we really |
| 58 | // need to? |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 59 | m_parser_vars.reset(new struct ParserVars); |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 60 | *m_parser_vars.get() = *rhs.m_parser_vars.get(); |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 61 | } |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 62 | |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 63 | if (rhs.m_jit_vars.get()) |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 64 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 65 | // TODO: Sean, can m_jit_vars be a shared pointer??? We are copy |
| 66 | // constructing it here. That is ok if we need to, but do we really |
| 67 | // need to? |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 68 | m_jit_vars.reset(new struct JITVars); |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 69 | *m_jit_vars.get() = *rhs.m_jit_vars.get(); |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 70 | } |
| 71 | |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 72 | if (rhs.m_data_sp) |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 73 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 74 | // TODO: Sean, does m_data_sp need to be copy constructed? Or can it |
| 75 | // shared the data? |
| 76 | |
| 77 | m_data_sp.reset(new DataBufferHeap (rhs.m_data_sp->GetBytes(), |
| 78 | rhs.m_data_sp->GetByteSize())); |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 79 | } |
| 80 | } |
| 81 | |
| 82 | bool |
Jim Ingham | 324067b | 2010-09-30 00:54:27 +0000 | [diff] [blame] | 83 | ClangExpressionVariable::PointValueAtData(Value &value, ExecutionContext *exe_ctx) |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 84 | { |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 85 | if (m_data_sp.get() == NULL) |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 86 | return false; |
| 87 | |
Greg Clayton | 6916e35 | 2010-11-13 03:52:47 +0000 | [diff] [blame] | 88 | value.SetContext(Value::eContextTypeClangType, m_user_type.GetOpaqueQualType()); |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 89 | value.SetValueType(Value::eValueTypeHostAddress); |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 90 | value.GetScalar() = (uintptr_t)m_data_sp->GetBytes(); |
Jim Ingham | 324067b | 2010-09-30 00:54:27 +0000 | [diff] [blame] | 91 | clang::ASTContext *ast_context = m_user_type.GetASTContext(); |
| 92 | |
| 93 | if (exe_ctx) |
| 94 | value.ResolveValue (exe_ctx, ast_context); |
Sean Callanan | a622343 | 2010-08-20 01:02:30 +0000 | [diff] [blame] | 95 | |
| 96 | return true; |
Chris Lattner | 24943d2 | 2010-06-08 16:52:24 +0000 | [diff] [blame] | 97 | } |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 98 | |
| 99 | void |
| 100 | ClangExpressionVariable::EnableDataVars() |
| 101 | { |
| 102 | if (!m_data_sp.get()) |
| 103 | m_data_sp.reset(new DataBufferHeap); |
| 104 | } |
| 105 | |
| 106 | lldb::ValueObjectSP |
| 107 | ClangExpressionVariable::GetExpressionResult (ExecutionContext *exe_ctx) |
| 108 | { |
| 109 | lldb::ValueObjectSP result_sp; |
| 110 | if (m_data_sp) |
| 111 | { |
| 112 | Target * target = NULL; |
| 113 | Process *process = NULL; |
| 114 | if (exe_ctx) |
| 115 | { |
| 116 | target = exe_ctx->target; |
| 117 | process = exe_ctx->process; |
| 118 | } |
| 119 | |
| 120 | Value value; |
| 121 | if (PointValueAtData(value, exe_ctx)) |
| 122 | { |
| 123 | lldb::ByteOrder byte_order = lldb::eByteOrderHost; |
| 124 | uint32_t addr_byte_size = 4; |
| 125 | if (process) |
| 126 | { |
| 127 | byte_order = process->GetByteOrder(); |
| 128 | addr_byte_size = process->GetAddressByteSize(); |
| 129 | } |
| 130 | result_sp.reset (new ValueObjectConstResult (m_user_type.GetASTContext(), |
| 131 | m_user_type.GetOpaqueQualType(), |
Greg Clayton | 8de27c7 | 2010-10-15 22:48:33 +0000 | [diff] [blame] | 132 | m_name, |
Greg Clayton | 66ed2fb | 2010-10-05 00:00:42 +0000 | [diff] [blame] | 133 | m_data_sp,// TODO: sean can you get this to be valid? |
| 134 | byte_order, |
| 135 | addr_byte_size)); |
| 136 | } |
| 137 | } |
| 138 | return result_sp; |
| 139 | } |
| 140 | |