diff options
Diffstat (limited to 'lldb')
| -rw-r--r-- | lldb/include/lldb/API/SBValue.h | 38 | ||||
| -rw-r--r-- | lldb/source/API/SBValue.cpp | 1085 |
2 files changed, 424 insertions, 699 deletions
diff --git a/lldb/include/lldb/API/SBValue.h b/lldb/include/lldb/API/SBValue.h index 170e3bd5865..2b9a344b930 100644 --- a/lldb/include/lldb/API/SBValue.h +++ b/lldb/include/lldb/API/SBValue.h @@ -15,11 +15,14 @@ #include "lldb/API/SBType.h" class ValueImpl; +class ValueLocker; namespace lldb { class SBValue { +friend class ValueLocker; + public: SBValue (); @@ -414,6 +417,16 @@ public: lldb::SBWatchpoint WatchPointee (bool resolve_location, bool read, bool write, SBError &error); + //------------------------------------------------------------------ + /// Same as the protected version of GetSP that takes a locker, except that we make the + /// locker locally in the function. Since the Target API mutex is recursive, and the + /// StopLocker is a read lock, you can call this function even if you are already + /// holding the two above-mentioned locks. + /// + /// @return + /// A ValueObjectSP of the best kind (static, dynamic or synthetic) we + /// can cons up, in accordance with the SBValue's settings. + //------------------------------------------------------------------ lldb::ValueObjectSP GetSP () const; @@ -424,6 +437,28 @@ protected: friend class SBThread; friend class SBValueList; + //------------------------------------------------------------------ + /// Get the appropriate ValueObjectSP from this SBValue, consulting the + /// use_dynamic and use_synthetic options passed in to SetSP when the + /// SBValue's contents were set. Since this often requires examining memory, + /// and maybe even running code, it needs to acquire the Target API and Process StopLock. + /// Those are held in an opaque class ValueLocker which is currently local to SBValue.cpp. + /// So you don't have to get these yourself just default construct a ValueLocker, and pass it into this. + /// If we need to make a ValueLocker and use it in some other .cpp file, we'll have to move it to + /// ValueObject.h/cpp or somewhere else convenient. We haven't needed to so far. + /// + /// @param[in] value_locker + /// An object that will hold the Target API, and Process RunLocks, and + /// auto-destroy them when it goes out of scope. Currently this is only useful in + /// SBValue.cpp. + /// + /// @return + /// A ValueObjectSP of the best kind (static, dynamic or synthetic) we + /// can cons up, in accordance with the SBValue's settings. + //------------------------------------------------------------------ + lldb::ValueObjectSP + GetSP (ValueLocker &value_locker) const; + // these calls do the right thing WRT adjusting their settings according to the target's preferences void SetSP (const lldb::ValueObjectSP &sp); @@ -437,6 +472,9 @@ protected: void SetSP (const lldb::ValueObjectSP &sp, lldb::DynamicValueType use_dynamic, bool use_synthetic); + void + SetSP (const lldb::ValueObjectSP &sp, lldb::DynamicValueType use_dynamic, bool use_synthetic, const char *name); + private: typedef std::shared_ptr<ValueImpl> ValueImplSP; ValueImplSP m_opaque_sp; diff --git a/lldb/source/API/SBValue.cpp b/lldb/source/API/SBValue.cpp index d467d791f22..33608f3ebeb 100644 --- a/lldb/source/API/SBValue.cpp +++ b/lldb/source/API/SBValue.cpp @@ -59,19 +59,24 @@ public: { } - ValueImpl (lldb::ValueObjectSP opaque_sp, + ValueImpl (lldb::ValueObjectSP in_valobj_sp, lldb::DynamicValueType use_dynamic, - bool use_synthetic) : - m_opaque_sp(opaque_sp), + bool use_synthetic, + const char *name = NULL) : + m_valobj_sp(in_valobj_sp), m_use_dynamic(use_dynamic), - m_use_synthetic(use_synthetic) + m_use_synthetic(use_synthetic), + m_name (name) { + if (!m_name.IsEmpty() && m_valobj_sp) + m_valobj_sp->SetName(m_name); } ValueImpl (const ValueImpl& rhs) : - m_opaque_sp(rhs.m_opaque_sp), + m_valobj_sp(rhs.m_valobj_sp), m_use_dynamic(rhs.m_use_dynamic), - m_use_synthetic(rhs.m_use_synthetic) + m_use_synthetic(rhs.m_use_synthetic), + m_name (rhs.m_name) { } @@ -80,9 +85,10 @@ public: { if (this != &rhs) { - m_opaque_sp = rhs.m_opaque_sp; + m_valobj_sp = rhs.m_valobj_sp; m_use_dynamic = rhs.m_use_dynamic; m_use_synthetic = rhs.m_use_synthetic; + m_name = rhs.m_name; } return *this; } @@ -90,31 +96,51 @@ public: bool IsValid () { - return m_opaque_sp.get() != NULL; + return m_valobj_sp.get() != NULL; } lldb::ValueObjectSP GetRootSP () { - return m_opaque_sp; + return m_valobj_sp; } lldb::ValueObjectSP - GetSP () + GetSP (Process::StopLocker &stop_locker, Mutex::Locker &api_locker, Error &error) { - if (!m_opaque_sp) - return m_opaque_sp; - lldb::ValueObjectSP value_sp = m_opaque_sp; + Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); + if (!m_valobj_sp) + { + error.SetErrorString("invalid value object"); + return m_valobj_sp; + } + + lldb::ValueObjectSP value_sp = m_valobj_sp; - Mutex::Locker api_lock; Target *target = value_sp->GetTargetSP().get(); if (target) - api_lock.Lock(target->GetAPIMutex()); - + api_locker.Lock(target->GetAPIMutex()); + + ProcessSP process_sp(value_sp->GetProcessSP()); + if (process_sp && !stop_locker.TryLock (&process_sp->GetRunLock())) + { + // We don't allow people to play around with ValueObject if the process is running. + // If you want to look at values, pause the process, then look. + if (log) + log->Printf ("SBValue(%p)::GetSP() => error: process is running", value_sp.get()); + error.SetErrorString ("process must be stopped."); + return ValueObjectSP(); + } + if (value_sp->GetDynamicValue(m_use_dynamic)) value_sp = value_sp->GetDynamicValue(m_use_dynamic); if (value_sp->GetSyntheticValue(m_use_synthetic)) value_sp = value_sp->GetSyntheticValue(m_use_synthetic); + if (!value_sp) + error.SetErrorString("invalid value object"); + if (!m_name.IsEmpty()) + value_sp->SetName(m_name); + return value_sp; } @@ -141,11 +167,78 @@ public: { return m_use_synthetic; } + + // All the derived values that we would make from the m_valobj_sp will share + // the ExecutionContext with m_valobj_sp, so we don't need to do the calculations + // in GetSP to return the Target, Process, Thread or Frame. It is convenient to + // provide simple accessors for these, which I do here. + TargetSP + GetTargetSP () + { + if (m_valobj_sp) + return m_valobj_sp->GetTargetSP(); + else + return TargetSP(); + } + + ProcessSP + GetProcessSP () + { + if (m_valobj_sp) + return m_valobj_sp->GetProcessSP(); + else + return ProcessSP(); + } + + ThreadSP + GetThreadSP () + { + if (m_valobj_sp) + return m_valobj_sp->GetThreadSP(); + else + return ThreadSP(); + } + StackFrameSP + GetFrameSP () + { + if (m_valobj_sp) + return m_valobj_sp->GetFrameSP(); + else + return StackFrameSP(); + } + private: - lldb::ValueObjectSP m_opaque_sp; + lldb::ValueObjectSP m_valobj_sp; lldb::DynamicValueType m_use_dynamic; bool m_use_synthetic; + ConstString m_name; +}; + +class ValueLocker +{ +public: + ValueLocker () + { + } + + ValueObjectSP + GetLockedSP(ValueImpl &in_value) + { + return in_value.GetSP(m_stop_locker, m_api_locker, m_lock_error); + } + + Error & + GetError() + { + return m_lock_error; + } + +private: + Process::StopLocker m_stop_locker; + Mutex::Locker m_api_locker; + Error m_lock_error; + }; SBValue::SBValue () : @@ -197,11 +290,12 @@ SBValue::GetError() { SBError sb_error; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) sb_error.SetError(value_sp->GetError()); else - sb_error.SetErrorString("error: invalid value"); + sb_error.SetErrorStringWithFormat ("error: %s", locker.GetError().AsCString()); return sb_error; } @@ -209,7 +303,8 @@ SBValue::GetError() user_id_t SBValue::GetID() { - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) return value_sp->GetID(); return LLDB_INVALID_UID; @@ -218,9 +313,9 @@ SBValue::GetID() const char * SBValue::GetName() { - const char *name = NULL; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) name = value_sp->GetName().GetCString(); @@ -241,28 +336,11 @@ SBValue::GetTypeName () { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); const char *name = NULL; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - // For a dynamic type we might have to run code to determine the type we are going to report, - // and we might not have updated the type before we get asked this. So make sure to get the API lock. - - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetTypeName() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - name = value_sp->GetQualifiedTypeName().GetCString(); - } - } + name = value_sp->GetQualifiedTypeName().GetCString(); } if (log) @@ -282,28 +360,11 @@ SBValue::GetByteSize () Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); size_t result = 0; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - // For a dynamic type we might have to run code to determine the type we are going to report, - // and we might not have updated the type before we get asked this. So make sure to get the API lock. - - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetTypeName() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - result = value_sp->GetByteSize(); - } - } + result = value_sp->GetByteSize(); } if (log) @@ -317,15 +378,11 @@ SBValue::IsInScope () { bool result = false; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - result = value_sp->IsInScope (); - } + result = value_sp->IsInScope (); } Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); @@ -341,25 +398,11 @@ SBValue::GetValue () Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); const char *cstr = NULL; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetValue() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - cstr = value_sp->GetValueAsCString (); - } - } + cstr = value_sp->GetValueAsCString (); } if (log) { @@ -376,9 +419,11 @@ ValueType SBValue::GetValueType () { ValueType result = eValueTypeInvalid; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) result = value_sp->GetValueType(); + Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); if (log) { @@ -402,25 +447,11 @@ SBValue::GetObjectDescription () { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); const char *cstr = NULL; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetObjectDescription() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - cstr = value_sp->GetObjectDescription (); - } - } + cstr = value_sp->GetObjectDescription (); } if (log) { @@ -437,27 +468,13 @@ SBValue::GetType() { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); SBType sb_type; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); TypeImplSP type_sp; if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetType() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - type_sp.reset (new TypeImpl(ClangASTType (value_sp->GetClangAST(), value_sp->GetClangType()))); - sb_type.SetSP(type_sp); - } - } + type_sp.reset (new TypeImpl(ClangASTType (value_sp->GetClangAST(), value_sp->GetClangType()))); + sb_type.SetSP(type_sp); } if (log) { @@ -474,25 +491,11 @@ SBValue::GetValueDidChange () { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); bool result = false; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetValueDidChange() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - result = value_sp->GetValueDidChange (); - } - } + result = value_sp->GetValueDidChange (); } if (log) log->Printf ("SBValue(%p)::GetValueDidChange() => %i", value_sp.get(), result); @@ -506,25 +509,11 @@ SBValue::GetSummary () { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); const char *cstr = NULL; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetSummary() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - cstr = value_sp->GetSummaryAsCString(); - } - } + cstr = value_sp->GetSummaryAsCString(); } if (log) { @@ -542,25 +531,11 @@ SBValue::GetLocation () { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); const char *cstr = NULL; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetLocation() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - cstr = value_sp->GetLocationAsCString(); - } - } + cstr = value_sp->GetLocationAsCString(); } if (log) { @@ -584,27 +559,16 @@ bool SBValue::SetValueFromCString (const char *value_str, lldb::SBError& error) { bool success = false; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::SetValueFromCString() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - success = value_sp->SetValueFromCString (value_str,error.ref()); - } - } + success = value_sp->SetValueFromCString (value_str,error.ref()); } + else + error.SetErrorStringWithFormat ("Could not get value: %s", locker.GetError().AsCString()); + if (log) log->Printf ("SBValue(%p)::SetValueFromCString(\"%s\") => %i", value_sp.get(), value_str, success); @@ -615,30 +579,15 @@ lldb::SBTypeFormat SBValue::GetTypeFormat () { lldb::SBTypeFormat format; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) + if (value_sp->UpdateValueIfNeeded(true)) { - Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - if (log) - log->Printf ("SBValue(%p)::GetTypeFormat() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - if (value_sp->UpdateValueIfNeeded(true)) - { - lldb::TypeFormatImplSP format_sp = value_sp->GetValueFormat(); - if (format_sp) - format.SetSP(format_sp); - } - } + lldb::TypeFormatImplSP format_sp = value_sp->GetValueFormat(); + if (format_sp) + format.SetSP(format_sp); } } return format; @@ -649,30 +598,15 @@ lldb::SBTypeSummary SBValue::GetTypeSummary () { lldb::SBTypeSummary summary; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - if (log) - log->Printf ("SBValue(%p)::GetTypeSummary() => error: process is running", value_sp.get()); - } - else + if (value_sp->UpdateValueIfNeeded(true)) { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - if (value_sp->UpdateValueIfNeeded(true)) - { - lldb::TypeSummaryImplSP summary_sp = value_sp->GetSummaryFormat(); - if (summary_sp) - summary.SetSP(summary_sp); - } - } + lldb::TypeSummaryImplSP summary_sp = value_sp->GetSummaryFormat(); + if (summary_sp) + summary.SetSP(summary_sp); } } return summary; @@ -683,33 +617,18 @@ lldb::SBTypeFilter SBValue::GetTypeFilter () { lldb::SBTypeFilter filter; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - if (log) - log->Printf ("SBValue(%p)::GetTypeFilter() => error: process is running", value_sp.get()); - } - else + if (value_sp->UpdateValueIfNeeded(true)) { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) + lldb::SyntheticChildrenSP synthetic_sp = value_sp->GetSyntheticChildren(); + + if (synthetic_sp && !synthetic_sp->IsScripted()) { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - if (value_sp->UpdateValueIfNeeded(true)) - { - lldb::SyntheticChildrenSP synthetic_sp = value_sp->GetSyntheticChildren(); - - if (synthetic_sp && !synthetic_sp->IsScripted()) - { - TypeFilterImplSP filter_sp = std::static_pointer_cast<TypeFilterImpl>(synthetic_sp); - filter.SetSP(filter_sp); - } - } + TypeFilterImplSP filter_sp = std::static_pointer_cast<TypeFilterImpl>(synthetic_sp); + filter.SetSP(filter_sp); } } } @@ -721,33 +640,18 @@ lldb::SBTypeSynthetic SBValue::GetTypeSynthetic () { lldb::SBTypeSynthetic synthetic; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) + if (value_sp->UpdateValueIfNeeded(true)) { - Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - if (log) - log->Printf ("SBValue(%p)::GetTypeSynthetic() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) + lldb::SyntheticChildrenSP children_sp = value_sp->GetSyntheticChildren(); + + if (children_sp && children_sp->IsScripted()) { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - if (value_sp->UpdateValueIfNeeded(true)) - { - lldb::SyntheticChildrenSP children_sp = value_sp->GetSyntheticChildren(); - - if (children_sp && children_sp->IsScripted()) - { - ScriptedSyntheticChildrenSP synth_sp = std::static_pointer_cast<ScriptedSyntheticChildren>(children_sp); - synthetic.SetSP(synth_sp); - } - } + ScriptedSyntheticChildrenSP synth_sp = std::static_pointer_cast<ScriptedSyntheticChildren>(children_sp); + synthetic.SetSP(synth_sp); } } } @@ -759,33 +663,15 @@ lldb::SBValue SBValue::CreateChildAtOffset (const char *name, uint32_t offset, SBType type) { lldb::SBValue sb_value; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); lldb::ValueObjectSP new_value_sp; if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - if (log) - log->Printf ("SBValue(%p)::CreateChildAtOffset() => error: process is running", value_sp.get()); - } - else + TypeImplSP type_sp (type.GetSP()); + if (type.IsValid()) { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - TypeImplSP type_sp (type.GetSP()); - if (type.IsValid()) - { - sb_value.SetSP(value_sp->GetSyntheticChildAtOffset(offset, type_sp->GetClangASTType(), true),GetPreferDynamicValue(),GetPreferSyntheticValue()); - new_value_sp = sb_value.GetSP(); - if (new_value_sp) - new_value_sp->SetName(ConstString(name)); - } - } + sb_value.SetSP(value_sp->GetSyntheticChildAtOffset(offset, type_sp->GetClangASTType(), true),GetPreferDynamicValue(),GetPreferSyntheticValue(), name); } } Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); @@ -806,7 +692,8 @@ lldb::SBValue SBValue::Cast (SBType type) { lldb::SBValue sb_value; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); TypeImplSP type_sp (type.GetSP()); if (value_sp && type_sp) sb_value.SetSP(value_sp->Cast(type_sp->GetClangASTType()),GetPreferDynamicValue(),GetPreferSyntheticValue()); @@ -826,33 +713,24 @@ SBValue::CreateValueFromExpression (const char *name, const char *expression, SB { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); lldb::SBValue sb_value; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); lldb::ValueObjectSP new_value_sp; if (value_sp) { ExecutionContext exe_ctx (value_sp->GetExecutionContextRef()); - ProcessSP process_sp(exe_ctx.GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::CreateValueFromExpression() => error: process is running", value_sp.get()); - } - else + Target* target = exe_ctx.GetTargetPtr(); + if (target) { - Target* target = exe_ctx.GetTargetPtr(); - if (target) + options.ref().SetKeepInMemory(true); + target->EvaluateExpression (expression, + exe_ctx.GetFramePtr(), + new_value_sp, + options.ref()); + if (new_value_sp) { - options.ref().SetKeepInMemory(true); - target->EvaluateExpression (expression, - exe_ctx.GetFramePtr(), - new_value_sp, - options.ref()); - if (new_value_sp) - { - new_value_sp->SetName(ConstString(name)); - sb_value.SetSP(new_value_sp); - } + new_value_sp->SetName(ConstString(name)); + sb_value.SetSP(new_value_sp); } } } @@ -877,7 +755,8 @@ lldb::SBValue SBValue::CreateValueFromAddress(const char* name, lldb::addr_t address, SBType sb_type) { lldb::SBValue sb_value; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); lldb::ValueObjectSP new_value_sp; lldb::TypeImplSP type_impl_sp (sb_type.GetSP()); if (value_sp && type_impl_sp) @@ -925,7 +804,8 @@ SBValue::CreateValueFromData (const char* name, SBData data, SBType type) { lldb::SBValue sb_value; lldb::ValueObjectSP new_value_sp; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { ExecutionContext exe_ctx (value_sp->GetExecutionContextRef()); @@ -955,13 +835,13 @@ SBValue::GetChildAtIndex (uint32_t idx) { const bool can_create_synthetic = false; lldb::DynamicValueType use_dynamic = eNoDynamicValues; - lldb::ValueObjectSP value_sp(GetSP()); - if (value_sp) - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - use_dynamic = target_sp->GetPreferDynamicValue(); - } + TargetSP target_sp; + if (m_opaque_sp) + target_sp = m_opaque_sp->GetTargetSP(); + + if (target_sp) + use_dynamic = target_sp->GetPreferDynamicValue(); + return GetChildAtIndex (idx, use_dynamic, can_create_synthetic); } @@ -971,36 +851,21 @@ SBValue::GetChildAtIndex (uint32_t idx, lldb::DynamicValueType use_dynamic, bool lldb::ValueObjectSP child_sp; Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetChildAtIndex() => error: process is running", value_sp.get()); - } - else + const bool can_create = true; + child_sp = value_sp->GetChildAtIndex (idx, can_create); + if (can_create_synthetic && !child_sp) { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) + if (value_sp->IsPointerType()) { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - const bool can_create = true; - child_sp = value_sp->GetChildAtIndex (idx, can_create); - if (can_create_synthetic && !child_sp) - { - if (value_sp->IsPointerType()) - { - child_sp = value_sp->GetSyntheticArrayMemberFromPointer(idx, can_create); - } - else if (value_sp->IsArrayType()) - { - child_sp = value_sp->GetSyntheticArrayMemberFromArray(idx, can_create); - } - } - + child_sp = value_sp->GetSyntheticArrayMemberFromPointer(idx, can_create); + } + else if (value_sp->IsArrayType()) + { + child_sp = value_sp->GetSyntheticArrayMemberFromArray(idx, can_create); } } } @@ -1017,16 +882,11 @@ uint32_t SBValue::GetIndexOfChildWithName (const char *name) { uint32_t idx = UINT32_MAX; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - - idx = value_sp->GetIndexOfChildWithName (ConstString(name)); - } + idx = value_sp->GetIndexOfChildWithName (ConstString(name)); } Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); if (log) @@ -1042,19 +902,14 @@ SBValue::GetIndexOfChildWithName (const char *name) SBValue SBValue::GetChildMemberWithName (const char *name) { - lldb::ValueObjectSP value_sp(GetSP()); - if (value_sp) - { - lldb::DynamicValueType use_dynamic_value = eNoDynamicValues; - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - use_dynamic_value = target_sp->GetPreferDynamicValue(); - } - return GetChildMemberWithName (name, use_dynamic_value); - } - return SBValue(); + lldb::DynamicValueType use_dynamic_value = eNoDynamicValues; + TargetSP target_sp; + if (m_opaque_sp) + target_sp = m_opaque_sp->GetTargetSP(); + + if (target_sp) + use_dynamic_value = target_sp->GetPreferDynamicValue(); + return GetChildMemberWithName (name, use_dynamic_value); } SBValue @@ -1065,25 +920,11 @@ SBValue::GetChildMemberWithName (const char *name, lldb::DynamicValueType use_dy Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetChildMemberWithName() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - child_sp = value_sp->GetChildMemberWithName (str_name, true); - } - } + child_sp = value_sp->GetChildMemberWithName (str_name, true); } SBValue sb_value; @@ -1164,32 +1005,20 @@ SBValue::SetPreferSyntheticValue (bool use_synthetic) bool SBValue::IsDynamic() { - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - return value_sp->IsDynamic(); - } - } + return value_sp->IsDynamic(); return false; } bool SBValue::IsSynthetic () { - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - return value_sp->IsSynthetic(); - } - } + return value_sp->IsSynthetic(); return false; } @@ -1198,26 +1027,12 @@ SBValue::GetValueForExpressionPath(const char* expr_path) { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); lldb::ValueObjectSP child_sp; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetValueForExpressionPath() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - // using default values for all the fancy options, just do it if you can - child_sp = value_sp->GetValueForExpressionPath(expr_path); - } - } + // using default values for all the fancy options, just do it if you can + child_sp = value_sp->GetValueForExpressionPath(expr_path); } SBValue sb_value; @@ -1233,35 +1048,19 @@ int64_t SBValue::GetValueAsSigned(SBError& error, int64_t fail_value) { error.Clear(); - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - if (log) - log->Printf ("SBValue(%p)::GetValueAsSigned() => error: process is running", value_sp.get()); - error.SetErrorString("process is running"); - } + Scalar scalar; + if (value_sp->ResolveValue (scalar)) + return scalar.SLongLong (fail_value); else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - Scalar scalar; - if (value_sp->ResolveValue (scalar)) - return scalar.SLongLong(fail_value); - else - error.SetErrorString("could not get value"); - } - else - error.SetErrorString("could not get target"); - } + error.SetErrorString ("could not resolve value"); } - error.SetErrorString("invalid SBValue"); + else + error.SetErrorStringWithFormat ("could not get SBValue: %s", locker.GetError().AsCString()); + return fail_value; } @@ -1269,63 +1068,32 @@ uint64_t SBValue::GetValueAsUnsigned(SBError& error, uint64_t fail_value) { error.Clear(); - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - if (log) - log->Printf ("SBValue(%p)::GetValueAsUnsigned() => error: process is running", value_sp.get()); - error.SetErrorString("process is running"); - } + Scalar scalar; + if (value_sp->ResolveValue (scalar)) + return scalar.ULongLong(fail_value); else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - Scalar scalar; - if (value_sp->ResolveValue (scalar)) - return scalar.ULongLong(fail_value); - else - error.SetErrorString("could not get value"); - } - else - error.SetErrorString("could not get target"); - } + error.SetErrorString("could not resolve value"); } - error.SetErrorString("invalid SBValue"); + else + error.SetErrorStringWithFormat ("could not get SBValue: %s", locker.GetError().AsCString()); + return fail_value; } int64_t SBValue::GetValueAsSigned(int64_t fail_value) { - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - if (log) - log->Printf ("SBValue(%p)::GetValueAsSigned() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - Scalar scalar; - if (value_sp->ResolveValue (scalar)) - return scalar.SLongLong(fail_value); - } - } + Scalar scalar; + if (value_sp->ResolveValue (scalar)) + return scalar.SLongLong(fail_value); } return fail_value; } @@ -1333,28 +1101,13 @@ SBValue::GetValueAsSigned(int64_t fail_value) uint64_t SBValue::GetValueAsUnsigned(uint64_t fail_value) { - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - if (log) - log->Printf ("SBValue(%p)::GetValueAsUnsigned() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - Scalar scalar; - if (value_sp->ResolveValue (scalar)) - return scalar.ULongLong(fail_value); - } - } + Scalar scalar; + if (value_sp->ResolveValue (scalar)) + return scalar.ULongLong(fail_value); } return fail_value; } @@ -1364,7 +1117,8 @@ SBValue::MightHaveChildren () { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); bool has_children = false; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) has_children = value_sp->MightHaveChildren(); @@ -1379,27 +1133,10 @@ SBValue::GetNumChildren () uint32_t num_children = 0; Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) - { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetNumChildren() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - - num_children = value_sp->GetNumChildren(); - } - } - } + num_children = value_sp->GetNumChildren(); if (log) log->Printf ("SBValue(%p)::GetNumChildren () => %u", value_sp.get(), num_children); @@ -1412,17 +1149,12 @@ SBValue SBValue::Dereference () { SBValue sb_value; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - Error error; sb_value = value_sp->Dereference (error); - } } Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); if (log) @@ -1436,17 +1168,10 @@ SBValue::TypeIsPointerType () { bool is_ptr_type = false; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - - is_ptr_type = value_sp->IsPointerType(); - } - } + is_ptr_type = value_sp->IsPointerType(); Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); if (log) @@ -1459,17 +1184,10 @@ SBValue::TypeIsPointerType () void * SBValue::GetOpaqueType() { - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) - { - TargetSP target_sp(value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - - return value_sp->GetClangType(); - } - } + return value_sp->GetClangType(); return NULL; } @@ -1478,19 +1196,18 @@ SBValue::GetTarget() { SBTarget sb_target; TargetSP target_sp; - lldb::ValueObjectSP value_sp(GetSP()); - if (value_sp) + if (m_opaque_sp) { - target_sp = value_sp->GetTargetSP(); + target_sp = m_opaque_sp->GetTargetSP(); sb_target.SetSP (target_sp); } Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); if (log) { if (target_sp.get() == NULL) - log->Printf ("SBValue(%p)::GetTarget () => NULL", value_sp.get()); + log->Printf ("SBValue(%p)::GetTarget () => NULL", m_opaque_sp.get()); else - log->Printf ("SBValue(%p)::GetTarget () => %p", value_sp.get(), target_sp.get()); + log->Printf ("SBValue(%p)::GetTarget () => %p", m_opaque_sp.get(), target_sp.get()); } return sb_target; } @@ -1500,20 +1217,18 @@ SBValue::GetProcess() { SBProcess sb_process; ProcessSP process_sp; - lldb::ValueObjectSP value_sp(GetSP()); - if (value_sp) + if (m_opaque_sp) { - process_sp = value_sp->GetProcessSP(); - if (process_sp) - sb_process.SetSP (process_sp); + process_sp = m_opaque_sp->GetProcessSP(); + sb_process.SetSP (process_sp); } Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); if (log) { if (process_sp.get() == NULL) - log->Printf ("SBValue(%p)::GetProcess () => NULL", value_sp.get()); + log->Printf ("SBValue(%p)::GetProcess () => NULL", m_opaque_sp.get()); else - log->Printf ("SBValue(%p)::GetProcess () => %p", value_sp.get(), process_sp.get()); + log->Printf ("SBValue(%p)::GetProcess () => %p", m_opaque_sp.get(), process_sp.get()); } return sb_process; } @@ -1523,19 +1238,18 @@ SBValue::GetThread() { SBThread sb_thread; ThreadSP thread_sp; - lldb::ValueObjectSP value_sp(GetSP()); - if (value_sp) + if (m_opaque_sp) { - thread_sp = value_sp->GetThreadSP(); + thread_sp = m_opaque_sp->GetThreadSP(); sb_thread.SetThread(thread_sp); } Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); if (log) { if (thread_sp.get() == NULL) - log->Printf ("SBValue(%p)::GetThread () => NULL", value_sp.get()); + log->Printf ("SBValue(%p)::GetThread () => NULL", m_opaque_sp.get()); else - log->Printf ("SBValue(%p)::GetThread () => %p", value_sp.get(), thread_sp.get()); + log->Printf ("SBValue(%p)::GetThread () => %p", m_opaque_sp.get(), thread_sp.get()); } return sb_thread; } @@ -1545,30 +1259,36 @@ SBValue::GetFrame() { SBFrame sb_frame; StackFrameSP frame_sp; - lldb::ValueObjectSP value_sp(GetSP()); - if (value_sp) + if (m_opaque_sp) { - frame_sp = value_sp->GetFrameSP(); + frame_sp = m_opaque_sp->GetFrameSP(); sb_frame.SetFrameSP (frame_sp); } Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); if (log) { if (frame_sp.get() == NULL) - log->Printf ("SBValue(%p)::GetFrame () => NULL", value_sp.get()); + log->Printf ("SBValue(%p)::GetFrame () => NULL", m_opaque_sp.get()); else - log->Printf ("SBValue(%p)::GetFrame () => %p", value_sp.get(), frame_sp.get()); + log->Printf ("SBValue(%p)::GetFrame () => %p", m_opaque_sp.get(), frame_sp.get()); } return sb_frame; } lldb::ValueObjectSP -SBValue::GetSP () const +SBValue::GetSP (ValueLocker &locker) const { if (!m_opaque_sp || !m_opaque_sp->IsValid()) return ValueObjectSP(); - return m_opaque_sp->GetSP(); + return locker.GetLockedSP(*m_opaque_sp.get()); +} + +lldb::ValueObjectSP +SBValue::GetSP () const +{ + ValueLocker locker; + return GetSP(locker); } void @@ -1638,10 +1358,17 @@ SBValue::SetSP (const lldb::ValueObjectSP &sp, lldb::DynamicValueType use_dynami m_opaque_sp = ValueImplSP(new ValueImpl(sp,use_dynamic,use_synthetic)); } +void +SBValue::SetSP (const lldb::ValueObjectSP &sp, lldb::DynamicValueType use_dynamic, bool use_synthetic, const char *name) +{ + m_opaque_sp = ValueImplSP(new ValueImpl(sp,use_dynamic,use_synthetic, name)); +} + bool SBValue::GetExpressionPath (SBStream &description) { - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { value_sp->GetExpressionPath (description.ref(), false); @@ -1653,7 +1380,8 @@ SBValue::GetExpressionPath (SBStream &description) bool SBValue::GetExpressionPath (SBStream &description, bool qualify_cxx_base_classes) { - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { value_sp->GetExpressionPath (description.ref(), qualify_cxx_base_classes); @@ -1667,21 +1395,11 @@ SBValue::GetDescription (SBStream &description) { Stream &strm = description.ref(); - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - if (log) - log->Printf ("SBValue(%p)::GetDescription() => error: process is running", value_sp.get()); - } - else - { - ValueObject::DumpValueObject (strm, value_sp.get()); - } + ValueObject::DumpValueObject (strm, value_sp.get()); } else strm.PutCString ("No value"); @@ -1692,7 +1410,8 @@ SBValue::GetDescription (SBStream &description) lldb::Format SBValue::GetFormat () { - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) return value_sp->GetFormat(); return eFormatDefault; @@ -1701,7 +1420,8 @@ SBValue::GetFormat () void SBValue::SetFormat (lldb::Format format) { - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) value_sp->SetFormat(format); } @@ -1710,16 +1430,12 @@ lldb::SBValue SBValue::AddressOf() { SBValue sb_value; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - TargetSP target_sp (value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - Error error; - sb_value.SetSP(value_sp->AddressOf (error),GetPreferDynamicValue(), GetPreferSyntheticValue()); - } + Error error; + sb_value.SetSP(value_sp->AddressOf (error),GetPreferDynamicValue(), GetPreferSyntheticValue()); } Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); if (log) @@ -1732,13 +1448,13 @@ lldb::addr_t SBValue::GetLoadAddress() { lldb::addr_t value = LLDB_INVALID_ADDRESS; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { TargetSP target_sp (value_sp->GetTargetSP()); if (target_sp) { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); const bool scalar_is_load_address = true; AddressType addr_type; value = value_sp->GetAddressOf(scalar_is_load_address, &addr_type); @@ -1769,14 +1485,14 @@ lldb::SBAddress SBValue::GetAddress() { Address addr; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { TargetSP target_sp (value_sp->GetTargetSP()); if (target_sp) { lldb::addr_t value = LLDB_INVALID_ADDRESS; - Mutex::Locker api_locker (target_sp->GetAPIMutex()); const bool scalar_is_load_address = true; AddressType addr_type; value = value_sp->GetAddressOf(scalar_is_load_address, &addr_type); @@ -1809,27 +1525,17 @@ SBValue::GetPointeeData (uint32_t item_idx, { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); lldb::SBData sb_data; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) + TargetSP target_sp (value_sp->GetTargetSP()); + if (target_sp) { - if (log) - log->Printf ("SBValue(%p)::GetPointeeData() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp (value_sp->GetTargetSP()); - if (target_sp) - { - DataExtractorSP data_sp(new DataExtractor()); - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - value_sp->GetPointeeData(*data_sp, item_idx, item_count); - if (data_sp->GetByteSize() > 0) - *sb_data = data_sp; - } + DataExtractorSP data_sp(new DataExtractor()); + value_sp->GetPointeeData(*data_sp, item_idx, item_count); + if (data_sp->GetByteSize() > 0) + *sb_data = data_sp; } } if (log) @@ -1847,28 +1553,14 @@ SBValue::GetData () { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); lldb::SBData sb_data; - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - if (log) - log->Printf ("SBValue(%p)::GetData() => error: process is running", value_sp.get()); - } - else - { - TargetSP target_sp (value_sp->GetTargetSP()); - if (target_sp) - { - Mutex::Locker api_locker (target_sp->GetAPIMutex()); - DataExtractorSP data_sp(new DataExtractor()); - value_sp->GetData(*data_sp); - if (data_sp->GetByteSize() > 0) - *sb_data = data_sp; - } - } + DataExtractorSP data_sp(new DataExtractor()); + value_sp->GetData(*data_sp); + if (data_sp->GetByteSize() > 0) + *sb_data = data_sp; } if (log) log->Printf ("SBValue(%p)::GetData () => SBData(%p)", @@ -1882,50 +1574,38 @@ bool SBValue::SetData (lldb::SBData &data, SBError &error) { Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); bool ret = true; if (value_sp) { - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) + DataExtractor *data_extractor = data.get(); + + if (!data_extractor) { if (log) - log->Printf ("SBValue(%p)::SetData() => error: process is running", value_sp.get()); + log->Printf ("SBValue(%p)::SetData() => error: no data to set", value_sp.get()); - error.SetErrorString("Process is running"); + error.SetErrorString("No data to set"); ret = false; } else { - DataExtractor *data_extractor = data.get(); + Error set_error; + + value_sp->SetData(*data_extractor, set_error); - if (!data_extractor) + if (!set_error.Success()) { - if (log) - log->Printf ("SBValue(%p)::SetData() => error: no data to set", value_sp.get()); - - error.SetErrorString("No data to set"); + error.SetErrorStringWithFormat("Couldn't set data: %s", set_error.AsCString()); ret = false; } - else - { - Error set_error; - - value_sp->SetData(*data_extractor, set_error); - - if (!set_error.Success()) - { - error.SetErrorStringWithFormat("Couldn't set data: %s", set_error.AsCString()); - ret = false; - } - } } } else { - error.SetErrorString("Couldn't set data: invalid SBValue"); + error.SetErrorStringWithFormat ("Couldn't set data: could not get SBValue: %s", locker.GetError().AsCString()); ret = false; } @@ -1940,7 +1620,8 @@ SBValue::SetData (lldb::SBData &data, SBError &error) lldb::SBDeclaration SBValue::GetDeclaration () { - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); SBDeclaration decl_sb; if (value_sp) { @@ -1957,21 +1638,11 @@ SBValue::Watch (bool resolve_location, bool read, bool write, SBError &error) SBWatchpoint sb_watchpoint; // If the SBValue is not valid, there's no point in even trying to watch it. - lldb::ValueObjectSP value_sp(GetSP()); + ValueLocker locker; + lldb::ValueObjectSP value_sp(GetSP(locker)); TargetSP target_sp (GetTarget().GetSP()); if (value_sp && target_sp) { - // Can't watch this if the process is running - ProcessSP process_sp(value_sp->GetProcessSP()); - Process::StopLocker stop_locker; - if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) - { - Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); - if (log) - log->Printf ("SBValue(%p)::Watch() => error: process is running", value_sp.get()); - return sb_watchpoint; - } - // Read and Write cannot both be false. if (!read && !write) return sb_watchpoint; @@ -2014,6 +1685,22 @@ SBValue::Watch (bool resolve_location, bool read, bool write, SBError &error) } } } + else if (target_sp) + { + Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); + if (log) + log->Printf ("SBValue(%p)::Watch() => error getting SBValue: %s", value_sp.get(), locker.GetError().AsCString()); + + error.SetErrorStringWithFormat("could not get SBValue: %s", locker.GetError().AsCString()); + } + else + { + Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); + if (log) + log->Printf ("SBValue(%p)::Watch() => error getting SBValue: no target", value_sp.get()); + error.SetErrorString("could not set watchpoint, a target is required"); + } + return sb_watchpoint; } |

