https://github.com/llvmbot created 
https://github.com/llvm/llvm-project/pull/196084

Backport fa8724beccad53be2d39d065be5db11917f94bac

Requested by: @da-viper

>From 3f2ce8546cac8adefeddb97cb4ec6348742f52f2 Mon Sep 17 00:00:00 2001
From: Ebuka Ezike <[email protected]>
Date: Tue, 5 May 2026 20:20:54 +0100
Subject: [PATCH] [lldb-dap] Fix crash in source request handler (#195847)

Check optional argument source has a value before getting the source
reference.

(cherry picked from commit fa8724beccad53be2d39d065be5db11917f94bac)
---
 lldb/test/API/tools/lldb-dap/source/TestDAP_source.py | 6 ++++++
 lldb/tools/lldb-dap/Handler/SourceRequestHandler.cpp  | 5 +++--
 2 files changed, 9 insertions(+), 2 deletions(-)

diff --git a/lldb/test/API/tools/lldb-dap/source/TestDAP_source.py 
b/lldb/test/API/tools/lldb-dap/source/TestDAP_source.py
index edf0af0bba2ba..01c28fe7a568e 100644
--- a/lldb/test/API/tools/lldb-dap/source/TestDAP_source.py
+++ b/lldb/test/API/tools/lldb-dap/source/TestDAP_source.py
@@ -32,6 +32,12 @@ def test_source(self):
         response = self.dap_server.request_source(sourceReference=0)
         self.assertFalse(response["success"], "verify invalid sourceReference 
fails")
 
+        # Check only source reference in the arguments field.
+        response = self.dap_server.request_custom("source", 
{"sourceReference": 0})
+        self.assertFalse(response["success"], "expected failed response")
+        error_format = self.get_dict_value(response, ["body", "error", 
"format"])
+        self.assertIn("unknown source reference", error_format)
+
         (stackFrames, totalFrames) = 
self.get_stackFrames_and_totalFramesCount()
         frameCount = len(stackFrames)
         self.assertGreaterEqual(frameCount, 3, "verify we got up to main at 
least")
diff --git a/lldb/tools/lldb-dap/Handler/SourceRequestHandler.cpp 
b/lldb/tools/lldb-dap/Handler/SourceRequestHandler.cpp
index 755ad206abe26..b2074e54e6be2 100644
--- a/lldb/tools/lldb-dap/Handler/SourceRequestHandler.cpp
+++ b/lldb/tools/lldb-dap/Handler/SourceRequestHandler.cpp
@@ -31,13 +31,14 @@ llvm::Expected<protocol::SourceResponseBody>
 SourceRequestHandler::Run(const protocol::SourceArguments &args) const {
 
   uint32_t source_ref =
-      args.source->sourceReference.value_or(args.sourceReference);
+      args.source ? args.source->sourceReference.value_or(args.sourceReference)
+                  : args.sourceReference;
   const std::optional<lldb::addr_t> source_addr_opt =
       dap.GetSourceReferenceAddress(source_ref);
 
   if (!source_addr_opt)
     return llvm::make_error<DAPError>(
-        llvm::formatv("Unknown source reference {}", source_ref));
+        llvm::formatv("unknown source reference {}", source_ref));
 
   lldb::SBAddress address(*source_addr_opt, dap.target);
   if (!address.IsValid())

_______________________________________________
llvm-branch-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-branch-commits

Reply via email to