diff options
author | Enrico Granata <egranata@apple.com> | 2012-03-19 22:58:49 +0000 |
---|---|---|
committer | Enrico Granata <egranata@apple.com> | 2012-03-19 22:58:49 +0000 |
commit | 86cc982974a5689047016981932a69a3987cf027 (patch) | |
tree | f21c71327240584482718bec5dda27d897ecfe6a /lldb/source/Interpreter/ScriptInterpreterPython.cpp | |
parent | f9be693369134de1307db75310e71476fb76a017 (diff) | |
download | bcm5719-llvm-86cc982974a5689047016981932a69a3987cf027.tar.gz bcm5719-llvm-86cc982974a5689047016981932a69a3987cf027.zip |
Massive enumeration name changes: a number of enums in ValueObject were not following the naming pattern
Changes to synthetic children:
- the update(self): function can now (optionally) return a value - if it returns boolean value True, ValueObjectSyntheticFilter will not clear its caches across stop-points
this should allow better performance for Python-based synthetic children when one can be sure that the child ValueObjects have not changed
- making a difference between a synthetic VO and a VO with a synthetic value: now a ValueObjectSyntheticFilter will not return itself as its own synthetic value, but will (correctly)
claim to itself be synthetic
- cleared up the internal synthetic children architecture to make a more consistent use of pointers and references instead of shared pointers when possible
- major cleanup of unnecessary #include, data and functions in ValueObjectSyntheticFilter itself
- removed the SyntheticValueType enum and replaced it with a plain boolean (to which it was equivalent in the first place)
Some clean ups to the summary generation code
Centralized the code that clears out user-visible strings and data in ValueObject
More efficient summaries for libc++ containers
llvm-svn: 153061
Diffstat (limited to 'lldb/source/Interpreter/ScriptInterpreterPython.cpp')
-rw-r--r-- | lldb/source/Interpreter/ScriptInterpreterPython.cpp | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/lldb/source/Interpreter/ScriptInterpreterPython.cpp b/lldb/source/Interpreter/ScriptInterpreterPython.cpp index 79b4449d356..81bbf3f11ac 100644 --- a/lldb/source/Interpreter/ScriptInterpreterPython.cpp +++ b/lldb/source/Interpreter/ScriptInterpreterPython.cpp @@ -91,7 +91,7 @@ extern "C" uint32_t LLDBSwigPython_CalculateNumChildren (void *impl extern "C" void* LLDBSwigPython_GetChildAtIndex (void *implementor, uint32_t idx); extern "C" int LLDBSwigPython_GetIndexOfChildWithName (void *implementor, const char* child_name); extern "C" void* LLDBSWIGPython_CastPyObjectToSBValue (void* data); -extern "C" void LLDBSwigPython_UpdateSynthProviderInstance (void* implementor); +extern "C" bool LLDBSwigPython_UpdateSynthProviderInstance (void* implementor); extern "C" bool LLDBSwigPythonCallCommand ( @@ -1654,26 +1654,28 @@ ScriptInterpreterPython::GetIndexOfChildWithName (const lldb::ScriptInterpreterO return ret_val; } -void +bool ScriptInterpreterPython::UpdateSynthProviderInstance (const lldb::ScriptInterpreterObjectSP& implementor_sp) { + bool ret_val = false; + if (!implementor_sp) - return; + return ret_val; void* implementor = implementor_sp->GetObject(); if (!implementor) - return; + return ret_val; if (!g_swig_update_provider) - return; + return ret_val; { Locker py_lock(this); - g_swig_update_provider (implementor); + ret_val = g_swig_update_provider (implementor); } - return; + return ret_val; } bool |