Refactoring breakpoints to not use the `g_dap` reference. Instead, when a breakpoint is constructed it will be passed a DAP reference that it should use for its lifetime. This is part of a larger refactor to remove the global `g_dap` variable to allow us to create multiple DAP instances. --------- Co-authored-by: Pavel Labath <pavel@labath.sk>
36 lines
1.2 KiB
C++
36 lines
1.2 KiB
C++
//===-- ExceptionBreakpoint.cpp ---------------------------------*- C++ -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "ExceptionBreakpoint.h"
|
|
#include "BreakpointBase.h"
|
|
#include "DAP.h"
|
|
#include "lldb/API/SBTarget.h"
|
|
|
|
namespace lldb_dap {
|
|
|
|
void ExceptionBreakpoint::SetBreakpoint() {
|
|
if (bp.IsValid())
|
|
return;
|
|
bool catch_value = filter.find("_catch") != std::string::npos;
|
|
bool throw_value = filter.find("_throw") != std::string::npos;
|
|
bp = dap.target.BreakpointCreateForException(language, catch_value,
|
|
throw_value);
|
|
// See comments in BreakpointBase::GetBreakpointLabel() for details of why
|
|
// we add a label to our breakpoints.
|
|
bp.AddName(BreakpointBase::GetBreakpointLabel());
|
|
}
|
|
|
|
void ExceptionBreakpoint::ClearBreakpoint() {
|
|
if (!bp.IsValid())
|
|
return;
|
|
dap.target.BreakpointDelete(bp.GetID());
|
|
bp = lldb::SBBreakpoint();
|
|
}
|
|
|
|
} // namespace lldb_dap
|