================
@@ -0,0 +1,165 @@
+//===-- GoToTargetsRequestHandler.cpp 
-------------------------------------===//
+//
+// 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 "DAP.h"
+
+#include "JSONUtils.h"
+
+#include <lldb/API/SBBreakpointLocation.h>
+#include <lldb/API/SBListener.h>
+#include <lldb/API/SBStream.h>
+
+namespace lldb_dap {
+
+static llvm::SmallVector<lldb::SBLineEntry>
+GetLineValidEntry(DAP &dap, const lldb::SBFileSpec &file_spec, uint32_t line) {
+  // disable breakpoint listeners so they do not send events to the DAP client.
+  lldb::SBListener listener = dap.debugger.GetListener();
+  lldb::SBBroadcaster broadcaster = dap.target.GetBroadcaster();
+  constexpr auto event_mask = lldb::SBTarget::eBroadcastBitBreakpointChanged;
+  listener.StopListeningForEvents(broadcaster, event_mask);
----------------
clayborg wrote:

This will work for code in the current source file when the source file itself 
matchs the name of a compile unit, but it won't work for inline functions. The 
line table above could easily contain entryes for "/.../stl/vector:123" where 
this is the `vector` header file from the STL. There will be no top level 
compile unit for this. 

So we really should add the new API so that it can use the same source file 
searching code that the breakpoints use.

It is easy to add things to the public API by following the API rules and 
making sure people agree on the signature and function location. Typically for 
things that want to search for things in a `lldb::SBModule`, we can add a 
`lldb::SBModule` API, but we might also want to add an API at the 
`lldb::SBTarget` so that it can search all modules so we might want the 
following APIs:

```
/// Find all locations for a file and line in this lldb::SBModule
lldb::SBSymbolContextList lldb::SBModule::ResolveContexts(lldb::SBFileSpec 
&file_spec, uint32_t line);
/// Find all locations for a file and line in all lldb::SBModule in the 
lldb::SBTarget
lldb::SBSymbolContextList lldb::SBTarget::ResolveContexts(lldb::SBFileSpec 
&file_spec, uint32_t line);
```


https://github.com/llvm/llvm-project/pull/130503
_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to