| # Copyright 2011-2022 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/>. | 
 |  | 
 | # This file is part of the gdb testsuite.  It contains tests for evaluating | 
 | # Fortran subarray expression. | 
 |  | 
 | if { [skip_fortran_tests] } { return -1 } | 
 |  | 
 | standard_testfile .f90 | 
 | load_lib "fortran.exp" | 
 |  | 
 | if { [prepare_for_testing "failed to prepare" ${testfile} ${srcfile} {debug f90}] } { | 
 |     return -1 | 
 | } | 
 |  | 
 | if ![fortran_runto_main] { | 
 |     perror "Couldn't run to main" | 
 |     return | 
 | } | 
 |  | 
 | # Depending on the compiler being used, the type names can be printed differently. | 
 | set int [fortran_int4] | 
 |  | 
 | gdb_breakpoint [gdb_get_line_number "break-static"] | 
 | gdb_continue_to_breakpoint "break-static" ".*break-static.*" | 
 |  | 
 | gdb_test "print foo(2,3,4)" \ | 
 |     " = 20" \ | 
 |     "print valid static array element" | 
 |  | 
 | gdb_test "print foo(0,0,0)" \ | 
 |     "no such vector element" \ | 
 |     "print an invalid array index (0,0,0)" | 
 |  | 
 | gdb_test "print foo(2,3,5)" \ | 
 |     "no such vector element" \ | 
 |     "print an invalid array index (2,3,5)" | 
 |  | 
 | gdb_test "print foo(2,4,4)" \ | 
 |     "no such vector element" \ | 
 |     "print an invalid array index (2,4,4)" | 
 |  | 
 | gdb_test "print foo(3,3,4)" \ | 
 |     "no such vector element" \ | 
 |     "print an invalid array index (3,3,4)" | 
 |  | 
 | gdb_test "print foo" \ | 
 |     { = \(\(\(10, 10\) \(10, 10\) \(10, 10\)\) \(\(10, 10\) \(10, 10\) \(10, 10\)\) \(\(10, 10\) \(10, 10\) \(10, 10\)\) \(\(10, 10\) \(10, 10\) \(10, 20\)\)\)} \ | 
 |     "print full contents of the array" | 
 |  | 
 | gdb_breakpoint [gdb_get_line_number "break-variable"] | 
 | gdb_continue_to_breakpoint "break-variable" ".*break-variable.*" | 
 |  | 
 | gdb_test "print varbound(4)" \ | 
 |     " = 2" \ | 
 |     "print valid variable bound array element" | 
 |  | 
 | gdb_test "ptype unbound" \ | 
 |     "type = $int \\(\\*\\)" \ | 
 |     "print type of unbound array" | 
 |  | 
 | gdb_test "print unbound(4)" \ | 
 |     " = 2" \ | 
 |     "print valid unbound array element" |