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>
26 lines
828 B
C++
26 lines
828 B
C++
//===-- FunctionBreakpoint.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 "FunctionBreakpoint.h"
|
|
#include "DAP.h"
|
|
#include "JSONUtils.h"
|
|
|
|
namespace lldb_dap {
|
|
|
|
FunctionBreakpoint::FunctionBreakpoint(DAP &d, const llvm::json::Object &obj)
|
|
: Breakpoint(d, obj), functionName(std::string(GetString(obj, "name"))) {}
|
|
|
|
void FunctionBreakpoint::SetBreakpoint() {
|
|
if (functionName.empty())
|
|
return;
|
|
bp = dap.target.BreakpointCreateByName(functionName.c_str());
|
|
Breakpoint::SetBreakpoint();
|
|
}
|
|
|
|
} // namespace lldb_dap
|