summaryrefslogtreecommitdiffstats
path: root/contrib/llvm/tools/lldb/source/Target/ExecutionContext.cpp
diff options
context:
space:
mode:
authordim <dim@FreeBSD.org>2014-02-26 22:26:40 +0000
committerdim <dim@FreeBSD.org>2014-02-26 22:26:40 +0000
commit09b56e694e5d4e67943f0d9c4668282053726b9f (patch)
treec09cd2cd8b06020ff76cb9b8f704cb7490621bcd /contrib/llvm/tools/lldb/source/Target/ExecutionContext.cpp
parent7d9059111716cc2ad4ad6f2782a9a03edcd2a81f (diff)
parent6765240e8d836b50e2135e928456ed8923b220ad (diff)
downloadFreeBSD-src-09b56e694e5d4e67943f0d9c4668282053726b9f.zip
FreeBSD-src-09b56e694e5d4e67943f0d9c4668282053726b9f.tar.gz
Merge from head up to r262536.
Diffstat (limited to 'contrib/llvm/tools/lldb/source/Target/ExecutionContext.cpp')
-rw-r--r--contrib/llvm/tools/lldb/source/Target/ExecutionContext.cpp13
1 files changed, 8 insertions, 5 deletions
diff --git a/contrib/llvm/tools/lldb/source/Target/ExecutionContext.cpp b/contrib/llvm/tools/lldb/source/Target/ExecutionContext.cpp
index 7a8b601..db4025f 100644
--- a/contrib/llvm/tools/lldb/source/Target/ExecutionContext.cpp
+++ b/contrib/llvm/tools/lldb/source/Target/ExecutionContext.cpp
@@ -154,7 +154,7 @@ ExecutionContext::ExecutionContext (const ExecutionContextRef &exe_ctx_ref) :
{
}
-ExecutionContext::ExecutionContext (const ExecutionContextRef *exe_ctx_ref_ptr) :
+ExecutionContext::ExecutionContext (const ExecutionContextRef *exe_ctx_ref_ptr, bool thread_and_frame_only_if_stopped) :
m_target_sp (),
m_process_sp (),
m_thread_sp (),
@@ -164,8 +164,11 @@ ExecutionContext::ExecutionContext (const ExecutionContextRef *exe_ctx_ref_ptr)
{
m_target_sp = exe_ctx_ref_ptr->GetTargetSP();
m_process_sp = exe_ctx_ref_ptr->GetProcessSP();
- m_thread_sp = exe_ctx_ref_ptr->GetThreadSP();
- m_frame_sp = exe_ctx_ref_ptr->GetFrameSP();
+ if (!thread_and_frame_only_if_stopped || (m_process_sp && StateIsStoppedState(m_process_sp->GetState(), true)))
+ {
+ m_thread_sp = exe_ctx_ref_ptr->GetThreadSP();
+ m_frame_sp = exe_ctx_ref_ptr->GetFrameSP();
+ }
}
}
@@ -824,9 +827,9 @@ ExecutionContextRef::GetFrameSP () const
}
ExecutionContext
-ExecutionContextRef::Lock () const
+ExecutionContextRef::Lock (bool thread_and_frame_only_if_stopped) const
{
- return ExecutionContext(this);
+ return ExecutionContext(this, thread_and_frame_only_if_stopped);
}
OpenPOWER on IntegriCloud