diff options
| author | Jim Ingham <jingham@apple.com> | 2012-04-20 21:16:56 +0000 |
|---|---|---|
| committer | Jim Ingham <jingham@apple.com> | 2012-04-20 21:16:56 +0000 |
| commit | 6d66ce67d75ec2dbc42d028084ab0801c1f4fcd6 (patch) | |
| tree | bb24a8c6ac14f96ff77622db1e6cd0015900f2d5 /lldb/source/Target/StopInfo.cpp | |
| parent | 1b42280917638c00f5e7012383627966b682ee30 (diff) | |
| download | bcm5719-llvm-6d66ce67d75ec2dbc42d028084ab0801c1f4fcd6.tar.gz bcm5719-llvm-6d66ce67d75ec2dbc42d028084ab0801c1f4fcd6.zip | |
Make sure the "synchronous breakpoint callbacks" get called before the thread plan logic gets invoked, and if they
ask to continue that should short-circuit the thread plans for that thread. Also add a bit more explanation for
how this machinery is supposed to work.
Also pass eExecutionPolicyOnlyWhenNeeded, not eExecutionPolicyAlways when evaluating the expression for breakpoint
conditions.
llvm-svn: 155236
Diffstat (limited to 'lldb/source/Target/StopInfo.cpp')
| -rw-r--r-- | lldb/source/Target/StopInfo.cpp | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/lldb/source/Target/StopInfo.cpp b/lldb/source/Target/StopInfo.cpp index d5ef53b46cb..113aa57aacb 100644 --- a/lldb/source/Target/StopInfo.cpp +++ b/lldb/source/Target/StopInfo.cpp @@ -134,7 +134,7 @@ public: } virtual bool - ShouldStop (Event *event_ptr) + ShouldStopSynchronous (Event *event_ptr) { if (!m_should_stop_is_valid) { @@ -160,6 +160,15 @@ public: return m_should_stop; } + bool + ShouldStop (Event *event_ptr) + { + // This just reports the work done by PerformAction or the synchronous stop. It should + // only ever get called after they have had a chance to run. + assert (m_should_stop_is_valid); + return m_should_stop; + } + virtual void PerformAction (Event *event_ptr) { @@ -216,7 +225,7 @@ public: const bool discard_on_error = true; Error error; result_code = ClangUserExpression::EvaluateWithError (exe_ctx, - eExecutionPolicyAlways, + eExecutionPolicyOnlyWhenNeeded, lldb::eLanguageTypeUnknown, ClangUserExpression::eResultTypeAny, discard_on_error, |

