]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
Automatically handle includes in testsuite/lib/
authorPedro Alves <pedro@palves.net>
Wed, 13 Aug 2025 00:21:10 +0000 (01:21 +0100)
committerPedro Alves <pedro@palves.net>
Fri, 22 Aug 2025 18:20:44 +0000 (19:20 +0100)
Instead of manually calling lappend_include_file in every testcase
that needs to include a file in testsuite/lib/, handle testsuite/lib/
includes automatically in gdb_compile.

As an example, gdb.base/backtrace.exp is adjusted to no longer
explicitly call lappend_include_file for testsuite/lib/attributes.h.

Tested on x86-64 GNU/Linux with both:

 $ make check RUNTESTFLAGS=" \
     --host_board=local-remote-host-native \
     --target_board=local-remote-host-native \
     HOST_DIR=/tmp/foo/" \
     TESTS="gdb.base/backtrace.exp"

and:

 $ make check TESTS="gdb.base/backtrace.exp"

and confirming that the testcase still compiles and passes cleanly.

Also ran full testsuite on x86-64 GNU/Linux in normal mode.

Approved-by: Kevin Buettner <kevinb@redhat.com>
Change-Id: I5ca77426ea4a753a995c3ad125618c02cd952576

gdb/testsuite/gdb.base/backtrace.exp
gdb/testsuite/lib/gdb.exp

index 35784b413cf5fafd915d4b50fcc1cf979f429285..3020666d7418ae6e7f632bf29aecc8c83668622d 100644 (file)
 
 standard_testfile
 
-set flags {}
-lappend flags debug
-lappend_include_file flags $srcdir/lib/attributes.h
-
-if { [prepare_for_testing "failed to prepare" $testfile $srcfile $flags] } {
+if { [prepare_for_testing "failed to prepare" $testfile $srcfile] } {
     return -1
 }
 
index 98691dfce255e7bd50e024278866fea2913ae842..0361f10b9a616db3799221ad8054db7ca5526391 100644 (file)
@@ -6311,6 +6311,9 @@ proc gdb_compile {source dest type options} {
        }
     }
 
+    # Automatically handle includes in testsuite/lib/.
+    auto_lappend_include_files options $source
+
     cond_wrap [expr $pie != -1 || $nopie != -1] \
        with_PIE_multilib_flags_filtered {
        set result [target_compile $source $dest $type $options]
@@ -11114,6 +11117,66 @@ proc lappend_include_file { flags file } {
     }
 }
 
+# Helper for auto_lappend_include_files that handles one source file,
+# and tracks the list of already-visited files.
+
+proc auto_lappend_include_files_1 {flags source {visited {}}} {
+    upvar $flags up_flags
+    upvar $visited up_visited
+    global srcdir
+
+    set ext [string tolower [file extension $source]]
+    if {$ext ni {".c" ".cpp" ".cc" ".h" ".s"}} {
+       return
+    }
+
+    if {[catch {open $source r} fh err]} {
+       error "Failed to open file '$source': $err"
+    }
+    set contents [read $fh]
+    close $fh
+
+    lappend up_visited $source
+
+    # Match lines like:
+    #  #include "gdb_foo.h"
+    set re "^\\s*#include\\s+\"(.*)\""
+
+    foreach line [split $contents "\n"] {
+       if {[regexp $re $line -> basename]} {
+           set lib_file "$srcdir/lib/$basename"
+
+           # If already processed, skip.
+           if {[lsearch -exact $up_visited $lib_file] != -1} {
+               continue
+           }
+
+           if {![file exists $lib_file]} {
+               continue
+           }
+
+           # Append to include list, and recurse into the included
+           # file.
+           lappend_include_file up_flags $lib_file
+           auto_lappend_include_files_1 up_flags $lib_file up_visited
+       }
+    }
+}
+
+# Automatically handle includes under gdb/testsuite/lib/.
+#
+# For each source file in SOURCES, look for #include directives
+# including files that live in testsuite/lib/.  For each such included
+# file, call lappend_include_file for it.
+
+proc auto_lappend_include_files {flags sources} {
+    upvar $flags up_flags
+    set visited {}
+    foreach src $sources {
+       auto_lappend_include_files_1 up_flags $src visited
+    }
+}
+
 # Return a list of supported host locales.
 
 gdb_caching_proc host_locales { } {