aboutsummaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
authorTom Tromey <tromey@adacore.com>2023-07-27 14:27:05 -0600
committerTom Tromey <tromey@adacore.com>2023-08-01 13:14:47 -0600
commit13bd1a9175962980a3b0f1c0598698858c72fc04 (patch)
treefc16ba7ac0ddfdbb9cace50ce688824249ab0021 /gdb
parent4b6521cf69f45050f857edeb592bc46ea198041d (diff)
downloadgdb-13bd1a9175962980a3b0f1c0598698858c72fc04.zip
gdb-13bd1a9175962980a3b0f1c0598698858c72fc04.tar.gz
gdb-13bd1a9175962980a3b0f1c0598698858c72fc04.tar.bz2
Implement DAP "source" request
This implements the DAP "source" request. I renamed the "loadedSources" function from "sources" to "loaded_sources" to avoid any confusion. I also moved the loadedSources test to the new sources.exp. Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=30691
Diffstat (limited to 'gdb')
-rw-r--r--gdb/python/lib/gdb/dap/sources.py24
-rw-r--r--gdb/testsuite/gdb.dap/basic-dap.exp3
-rw-r--r--gdb/testsuite/gdb.dap/sources.c22
-rw-r--r--gdb/testsuite/gdb.dap/sources.exp52
4 files changed, 97 insertions, 4 deletions
diff --git a/gdb/python/lib/gdb/dap/sources.py b/gdb/python/lib/gdb/dap/sources.py
index 8063528..7fa1ae4 100644
--- a/gdb/python/lib/gdb/dap/sources.py
+++ b/gdb/python/lib/gdb/dap/sources.py
@@ -82,5 +82,27 @@ def _sources():
@request("loadedSources")
@capability("supportsLoadedSourcesRequest")
-def sources(**extra):
+def loaded_sources(**extra):
return send_gdb_with_response(_sources)
+
+
+# This helper is needed because we must only access the globals here
+# from the gdb thread.
+@in_gdb_thread
+def _get_source(source):
+ filename = decode_source(source)
+ with open(filename) as f:
+ content = f.read()
+ return {
+ "content": content,
+ }
+
+
+@request("source")
+def source(*, source=None, sourceReference: int, **extra):
+ # The 'sourceReference' parameter is required by the spec, but is
+ # for backward compatibility, which I take to mean that the
+ # 'source' is preferred.
+ if source is None:
+ source = {"sourceReference": sourceReference}
+ return send_gdb_with_response(lambda: _get_source(source))
diff --git a/gdb/testsuite/gdb.dap/basic-dap.exp b/gdb/testsuite/gdb.dap/basic-dap.exp
index c4a1698..7dfc759 100644
--- a/gdb/testsuite/gdb.dap/basic-dap.exp
+++ b/gdb/testsuite/gdb.dap/basic-dap.exp
@@ -207,7 +207,4 @@ set obj [dap_check_request_and_response "command repl" \
set response [lindex $obj 0]
gdb_assert {[dict get $response body result] == 23}
-set obj [dap_check_request_and_response sources loadedSources]
-gdb_assert {[string first basic-dap.c $obj] != -1}
-
dap_shutdown
diff --git a/gdb/testsuite/gdb.dap/sources.c b/gdb/testsuite/gdb.dap/sources.c
new file mode 100644
index 0000000..599d1bd
--- /dev/null
+++ b/gdb/testsuite/gdb.dap/sources.c
@@ -0,0 +1,22 @@
+/* Copyright 2023 Free Software Foundation, Inc.
+
+ This file is part of GDB.
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 3 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>. */
+
+int
+main ()
+{
+ /* Distinguishing comment. */
+}
diff --git a/gdb/testsuite/gdb.dap/sources.exp b/gdb/testsuite/gdb.dap/sources.exp
new file mode 100644
index 0000000..a12c208
--- /dev/null
+++ b/gdb/testsuite/gdb.dap/sources.exp
@@ -0,0 +1,52 @@
+# Copyright 2023 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+# Test 'sources' and 'loadedSources'.
+
+require allow_dap_tests
+
+load_lib dap-support.exp
+
+standard_testfile
+
+if {[build_executable ${testfile}.exp $testfile] == -1} {
+ return
+}
+
+if {[dap_launch $testfile stop_at_main 1] == ""} {
+ return
+}
+
+set obj [dap_check_request_and_response loadedSources loadedSources]
+set ref 0
+foreach src [dict get [lindex $obj 0] body sources] {
+ if {[file tail [dict get $src name]] == "sources.c"} {
+ set ref [dict get $src sourceReference]
+ }
+}
+
+if {$ref == 0} {
+ fail "sources.c in loadedSources"
+} else {
+ pass "sources.c in loadedSources"
+
+ set obj [dap_check_request_and_response "get source" source \
+ [format {o sourceReference [i %d]} $ref]]
+ set text [dict get [lindex $obj 0] body content]
+ gdb_assert {[string first "Distinguishing comment" $text] != -1}
+}
+
+
+dap_shutdown