//===-- ValueObjectConstResult.cpp ------------------------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #include "lldb/Core/ValueObjectConstResult.h" #include "lldb/Core/DataExtractor.h" #include "lldb/Core/Module.h" #include "lldb/Core/ValueObjectList.h" #include "lldb/Symbol/ClangASTType.h" #include "lldb/Symbol/ObjectFile.h" #include "lldb/Symbol/SymbolContext.h" #include "lldb/Symbol/Type.h" #include "lldb/Symbol/Variable.h" #include "lldb/Target/ExecutionContext.h" #include "lldb/Target/Process.h" #include "lldb/Target/Target.h" using namespace lldb; using namespace lldb_private; ValueObjectConstResult::ValueObjectConstResult ( ExecutionContextScope *exe_scope, ByteOrder byte_order, uint32_t addr_byte_size ) : ValueObject (exe_scope), m_clang_ast (NULL), m_type_name (), m_byte_size (0) { SetIsConstant (); SetValueIsValid(true); m_data.SetByteOrder(byte_order); m_data.SetAddressByteSize(addr_byte_size); m_pointers_point_to_load_addrs = true; } ValueObjectConstResult::ValueObjectConstResult ( ExecutionContextScope *exe_scope, clang::ASTContext *clang_ast, void *clang_type, const ConstString &name, const DataExtractor &data ) : ValueObject (exe_scope), m_clang_ast (clang_ast), m_type_name (), m_byte_size (0) { m_data = data; m_value.GetScalar() = (uintptr_t)m_data.GetDataStart(); m_value.SetValueType(Value::eValueTypeHostAddress); m_value.SetContext(Value::eContextTypeClangType, clang_type); m_name = name; SetIsConstant (); SetValueIsValid(true); m_pointers_point_to_load_addrs = true; } ValueObjectConstResult::ValueObjectConstResult ( ExecutionContextScope *exe_scope, clang::ASTContext *clang_ast, void *clang_type, const ConstString &name, const lldb::DataBufferSP &data_sp, lldb::ByteOrder data_byte_order, uint8_t data_addr_size ) : ValueObject (exe_scope), m_clang_ast (clang_ast), m_type_name (), m_byte_size (0) { m_data.SetByteOrder(data_byte_order); m_data.SetAddressByteSize(data_addr_size); m_data.SetData(data_sp); m_value.GetScalar() = (uintptr_t)data_sp->GetBytes(); m_value.SetValueType(Value::eValueTypeHostAddress); m_value.SetContext(Value::eContextTypeClangType, clang_type); m_name = name; SetIsConstant (); SetValueIsValid(true); m_pointers_point_to_load_addrs = true; } ValueObjectConstResult::ValueObjectConstResult ( ExecutionContextScope *exe_scope, clang::ASTContext *clang_ast, void *clang_type, const ConstString &name, lldb::addr_t address, AddressType address_type, uint8_t addr_byte_size ) : ValueObject (exe_scope), m_clang_ast (clang_ast), m_type_name (), m_byte_size (0) { m_value.GetScalar() = address; m_data.SetAddressByteSize(addr_byte_size); m_value.GetScalar().GetData (m_data, addr_byte_size); //m_value.SetValueType(Value::eValueTypeHostAddress); switch (address_type) { default: case eAddressTypeInvalid: m_value.SetValueType(Value::eValueTypeScalar); break; case eAddressTypeFile: m_value.SetValueType(Value::eValueTypeFileAddress); break; case eAddressTypeLoad: m_value.SetValueType(Value::eValueTypeLoadAddress); break; case eAddressTypeHost: m_value.SetValueType(Value::eValueTypeHostAddress); break; } m_value.SetContext(Value::eContextTypeClangType, clang_type); m_name = name; SetIsConstant (); SetValueIsValid(true); m_pointers_point_to_load_addrs = true; } ValueObjectConstResult::ValueObjectConstResult ( ExecutionContextScope *exe_scope, const Error& error) : ValueObject (exe_scope), m_clang_ast (NULL), m_type_name (), m_byte_size (0) { m_error = error; SetIsConstant (); m_pointers_point_to_load_addrs = true; } ValueObjectConstResult::~ValueObjectConstResult() { } lldb::clang_type_t ValueObjectConstResult::GetClangType() { return m_value.GetClangType(); } lldb::ValueType ValueObjectConstResult::GetValueType() const { return eValueTypeConstResult; } size_t ValueObjectConstResult::GetByteSize() { if (m_byte_size == 0) { uint64_t bit_width = ClangASTType::GetClangTypeBitWidth (GetClangAST(), GetClangType()); m_byte_size = (bit_width + 7 ) / 8; } return m_byte_size; } void ValueObjectConstResult::SetByteSize (size_t size) { m_byte_size = size; } uint32_t ValueObjectConstResult::CalculateNumChildren() { return ClangASTContext::GetNumChildren (GetClangAST (), GetClangType(), true); } clang::ASTContext * ValueObjectConstResult::GetClangAST () { return m_clang_ast; } ConstString ValueObjectConstResult::GetTypeName() { if (m_type_name.IsEmpty()) m_type_name = ClangASTType::GetClangTypeName (GetClangType()); return m_type_name; } bool ValueObjectConstResult::UpdateValue () { // Const value is always valid SetValueIsValid (true); return true; } bool ValueObjectConstResult::IsInScope () { // A const result value is always in scope since it serializes all // information needed to contain the constant value. return true; }