mirror of
https://github.com/zeek/zeek.git
synced 2025-10-02 06:38:20 +00:00
fixup! Disable Stmt hooks for the built-in debugger if not a debug build
This commit is contained in:
parent
3878353a7a
commit
54c26f768f
2 changed files with 10 additions and 14 deletions
19
src/Stmt.cc
19
src/Stmt.cc
|
@ -12,6 +12,7 @@
|
|||
#include "zeek/Frame.h"
|
||||
#include "zeek/IntrusivePtr.h"
|
||||
#include "zeek/Reporter.h"
|
||||
#include "zeek/RunState.h"
|
||||
#include "zeek/Scope.h"
|
||||
#include "zeek/Traverse.h"
|
||||
#include "zeek/Trigger.h"
|
||||
|
@ -147,9 +148,10 @@ const AssertStmt* Stmt::AsAssertStmt() const {
|
|||
}
|
||||
|
||||
bool Stmt::SetLocationInfo(const Location* start, const Location* end) {
|
||||
#if DEBUG
|
||||
if ( ! Obj::SetLocationInfo(start, end) )
|
||||
return false;
|
||||
// Skip the rest of this code if the debugger isn't active or if the initial set
|
||||
// failed.
|
||||
if ( bool res = Obj::SetLocationInfo(start, end); ! res || ! detail::g_policy_debug )
|
||||
return res;
|
||||
|
||||
// Update the Filemap of line number -> statement mapping for
|
||||
// breakpoints (Debug.h).
|
||||
|
@ -178,9 +180,6 @@ bool Stmt::SetLocationInfo(const Location* start, const Location* end) {
|
|||
}
|
||||
|
||||
return true;
|
||||
#else
|
||||
return Obj::SetLocationInfo(start, end);
|
||||
#endif
|
||||
}
|
||||
|
||||
bool Stmt::IsPure() const { return false; }
|
||||
|
@ -440,17 +439,13 @@ ValPtr IfStmt::DoExec(Frame* f, Val* v, StmtFlowType& flow) {
|
|||
|
||||
f->SetNextStmt(do_stmt);
|
||||
|
||||
#if DEBUG
|
||||
if ( ! pre_execute_stmt(do_stmt, f) ) { // ### Abort or something
|
||||
}
|
||||
#endif
|
||||
|
||||
auto result = do_stmt->Exec(f, flow);
|
||||
|
||||
#if DEBUG
|
||||
if ( ! post_execute_stmt(do_stmt, f, result.get(), &flow) ) { // ### Abort or something
|
||||
}
|
||||
#endif
|
||||
|
||||
return result;
|
||||
}
|
||||
|
@ -1417,17 +1412,13 @@ ValPtr StmtList::Exec(Frame* f, StmtFlowType& flow) {
|
|||
|
||||
f->SetNextStmt(stmt);
|
||||
|
||||
#if DEBUG
|
||||
if ( ! pre_execute_stmt(stmt, f) ) { // ### Abort or something
|
||||
}
|
||||
#endif
|
||||
|
||||
auto result = stmt->Exec(f, flow);
|
||||
|
||||
#if DEBUG
|
||||
if ( ! post_execute_stmt(stmt, f, result.get(), &flow) ) { // ### Abort or something
|
||||
}
|
||||
#endif
|
||||
|
||||
if ( flow != FLOW_NEXT || result || f->HasDelayed() )
|
||||
return result;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue