summaryrefslogtreecommitdiffstats
path: root/lldb/source/Plugins/LanguageRuntime/Go/GoLanguageRuntime.cpp
diff options
context:
space:
mode:
authorEnrico Granata <egranata@apple.com>2016-05-05 01:47:44 +0000
committerEnrico Granata <egranata@apple.com>2016-05-05 01:47:44 +0000
commit5ee54086251b7380c2997ff090311cdb739c17ea (patch)
tree145e11ab704b7cf141508966d59fc0f2da31afe2 /lldb/source/Plugins/LanguageRuntime/Go/GoLanguageRuntime.cpp
parent8752be775c938cf528dd3471d69f6e36e8f6c100 (diff)
downloadbcm5719-llvm-5ee54086251b7380c2997ff090311cdb739c17ea.tar.gz
bcm5719-llvm-5ee54086251b7380c2997ff090311cdb739c17ea.zip
Allow LanguageRuntimes to return an error if they fail in the course of dynamic type discovery
This is not meant to report that a value doesn't have a dynamic type - it is only meant as a mechanism to propagate actual type discovery issues (e.g. malformed type metadata for languages that have such a notion) This information is used by ValueObjectDynamic to set its own m_error, which is a fairly sharp and heavyweight tool to begin with For the time being, this is an architectural improvement but a practical no-op as no existing runtimes are actually setting errors llvm-svn: 268591
Diffstat (limited to 'lldb/source/Plugins/LanguageRuntime/Go/GoLanguageRuntime.cpp')
-rw-r--r--lldb/source/Plugins/LanguageRuntime/Go/GoLanguageRuntime.cpp10
1 files changed, 7 insertions, 3 deletions
diff --git a/lldb/source/Plugins/LanguageRuntime/Go/GoLanguageRuntime.cpp b/lldb/source/Plugins/LanguageRuntime/Go/GoLanguageRuntime.cpp
index c752971e7a0..594b5cdeea7 100644
--- a/lldb/source/Plugins/LanguageRuntime/Go/GoLanguageRuntime.cpp
+++ b/lldb/source/Plugins/LanguageRuntime/Go/GoLanguageRuntime.cpp
@@ -140,11 +140,15 @@ GoLanguageRuntime::CouldHaveDynamicValue (ValueObject &in_value)
}
bool
-GoLanguageRuntime::GetDynamicTypeAndAddress(ValueObject &in_value, lldb::DynamicValueType use_dynamic,
- TypeAndOrName &class_type_or_name, Address &dynamic_address,
- Value::ValueType &value_type)
+GoLanguageRuntime::GetDynamicTypeAndAddress(ValueObject &in_value,
+ lldb::DynamicValueType use_dynamic,
+ TypeAndOrName &class_type_or_name,
+ Address &dynamic_address,
+ Value::ValueType &value_type,
+ Error &error)
{
value_type = Value::eValueTypeScalar;
+ error.Clear();
class_type_or_name.Clear();
if (CouldHaveDynamicValue (in_value))
{
OpenPOWER on IntegriCloud