diff options
author | Enrico Granata <egranata@apple.com> | 2016-05-05 01:47:44 +0000 |
---|---|---|
committer | Enrico Granata <egranata@apple.com> | 2016-05-05 01:47:44 +0000 |
commit | 5ee54086251b7380c2997ff090311cdb739c17ea (patch) | |
tree | 145e11ab704b7cf141508966d59fc0f2da31afe2 /lldb/source/Plugins/LanguageRuntime/Java | |
parent | 8752be775c938cf528dd3471d69f6e36e8f6c100 (diff) | |
download | bcm5719-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/Java')
-rw-r--r-- | lldb/source/Plugins/LanguageRuntime/Java/JavaLanguageRuntime.cpp | 10 | ||||
-rw-r--r-- | lldb/source/Plugins/LanguageRuntime/Java/JavaLanguageRuntime.h | 9 |
2 files changed, 13 insertions, 6 deletions
diff --git a/lldb/source/Plugins/LanguageRuntime/Java/JavaLanguageRuntime.cpp b/lldb/source/Plugins/LanguageRuntime/Java/JavaLanguageRuntime.cpp index 07312a8af0d..1ff5a4dbbe5 100644 --- a/lldb/source/Plugins/LanguageRuntime/Java/JavaLanguageRuntime.cpp +++ b/lldb/source/Plugins/LanguageRuntime/Java/JavaLanguageRuntime.cpp @@ -105,10 +105,14 @@ GetDynamicTypeId(ExecutionContext *exe_ctx, Target *target, ValueObject &in_valu } bool -JavaLanguageRuntime::GetDynamicTypeAndAddress(ValueObject &in_value, lldb::DynamicValueType use_dynamic, - TypeAndOrName &class_type_or_name, Address &dynamic_address, - Value::ValueType &value_type) +JavaLanguageRuntime::GetDynamicTypeAndAddress(ValueObject &in_value, + lldb::DynamicValueType use_dynamic, + TypeAndOrName &class_type_or_name, + Address &dynamic_address, + Value::ValueType &value_type, + Error &error) { + error.Clear(); class_type_or_name.Clear(); // null references don't have a dynamic type diff --git a/lldb/source/Plugins/LanguageRuntime/Java/JavaLanguageRuntime.h b/lldb/source/Plugins/LanguageRuntime/Java/JavaLanguageRuntime.h index 83ed35dbb59..e90ba37d2bb 100644 --- a/lldb/source/Plugins/LanguageRuntime/Java/JavaLanguageRuntime.h +++ b/lldb/source/Plugins/LanguageRuntime/Java/JavaLanguageRuntime.h @@ -74,9 +74,12 @@ public: CouldHaveDynamicValue(ValueObject &in_value) override; bool - GetDynamicTypeAndAddress(ValueObject &in_value, lldb::DynamicValueType use_dynamic, - TypeAndOrName &class_type_or_name, Address &address, - Value::ValueType &value_type) override; + GetDynamicTypeAndAddress(ValueObject &in_value, + lldb::DynamicValueType use_dynamic, + TypeAndOrName &class_type_or_name, + Address &address, + Value::ValueType &value_type, + Error &error) override; protected: JavaLanguageRuntime(Process *process); |