# Copyright 2019-2025 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 . # Test 'info sources [-d | -b] [--] [REGEX]' standard_testfile .c info_sources_base.c if {[prepare_for_testing $testfile.exp $testfile \ [list $srcfile $srcfile2] debug]} { untested $testfile.exp return -1 } # Executes "info sources ARGS". # # EXPECT_SEEN_INFO_SOURCES 1 indicates that the source file info_sources.c # must be seen in the output. Similarly, EXPECT_SEEN_INFO_SOURCES_BASE # indicates that the source file info_sources_base.c must be seen in the # output. # # If TESTNAME is not the empty string then this is the test name, otherwise # uses "info sources ARGS" as the test name. proc test_info_sources {args expect_seen_info_sources \ expect_seen_info_sources_base \ {testname ""}} { global gdb_prompt srcfile srcfile2 set seen_info_sources 0 set seen_info_sources_base 0 set cmd [concat "info sources " $args] if { $testname eq "" } { set $testname $cmd } gdb_test_multiple $cmd $testname { -re "^\[^,\]*${srcfile}(, |\[\r\n\]+)" { incr seen_info_sources exp_continue } -re "^\[^,\]*${srcfile2}(, |\[\r\n\]+)" { incr seen_info_sources_base 1 exp_continue } -re ", " { exp_continue } -re "$gdb_prompt $" { if {$seen_info_sources == $expect_seen_info_sources \ && $seen_info_sources_base == $expect_seen_info_sources_base} { pass $gdb_test_name } else { fail $gdb_test_name } } } } if ![runto_main] { return -1 } # List both files with no regexp: with_test_prefix "in main" { test_info_sources "" 1 1 } gdb_test "break some_other_func" "" gdb_test "continue" # List both files with no regexp: test_info_sources "" 1 1 # Same but with option terminator: test_info_sources "--" 1 1 # List both files with regexp matching anywhere in the filenames: test_info_sources "info_sources" 1 1 if { ! [is_remote host] } { test_info_sources "gdb.base" 1 1 } # List both files with regexp matching the filename basenames, # using various parts of the -basename option: test_info_sources "-b info_sources" 1 1 test_info_sources "-basename info_sources" 1 1 test_info_sources "-b -- info_sources" 1 1 test_info_sources "-ba info_sources" 1 1 test_info_sources "-base -- info_sources" 1 1 test_info_sources "-basena info_sources" 1 1 test_info_sources "-basename -- info_sources" 1 1 # List only the file with basename matching regexp: test_info_sources "-b base" 0 1 # List the files with dirname matching regexp, # using various part of the -dirname option: if { ! [is_remote host] } { test_info_sources "-d base" 1 1 test_info_sources "-dirname base" 1 1 } # Test non matching regexp against the basename, with option # terminator: test_info_sources "-b -- -d" 0 0 # The following tests relies on using a regexp which will not match # either the directory name of the source files. Unlike the basename # test above we need to be more careful picking the regexp as the # source filename might contain any simple character patterns, and so # could unexpectedly match the regexp. # # Loop through all the characters a-z trying regexp '-C' (where 'C' is # each character), looking for a regexp which doesn't match the # directory name. set re "" for {set i [scan a %c]} {$i <= [scan z %c]} {incr i} { set tmp_re -[format %c $i] if {$re eq "" && ![regexp $tmp_re $srcdir/$subdir/]} { set re $tmp_re } } # If we found a suitable regexp then test non matching regexp against # the directory name, with option terminator: if { $re ne "" } { test_info_sources "-d -- $re" 0 0 \ "info sources -d -- " } else { unresolved \ "info sources -d -- (failed to find regexp)" }