summaryrefslogtreecommitdiff
path: root/gdb/testsuite/gdb.ada/array_of_variable_length.exp
blob: ea171e6e062b860a90bc7c81e0cade97cd4321c7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# Copyright 2015-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/>.

load_lib "ada.exp"

if { [skip_ada_tests] } { return -1 }

standard_ada_testfile foo

foreach_with_prefix scenario {all minimal} {
    set flags [list debug additional_flags=-fgnat-encodings=$scenario]

    if {[gdb_compile_ada "${srcfile}" "${binfile}-${scenario}" executable $flags] != ""} {
	return -1
    }

    clean_restart ${testfile}-${scenario}

    set bp_location [gdb_get_line_number "BREAK" ${testdir}/foo.adb]
    runto "foo.adb:$bp_location"

    # Pck.A is an array that embeds elements with variable size so compilers will
    # emit DWARF attributes such as DW_AT_byte_stride to tell GDB how to fetch
    # individual elements.  Array stride is also a way to describe packed arrays:
    # make sure we do not consider Pck.A as a packed array.
    gdb_test "ptype pck.a" "array \\(1 \\.\\. 2\\) of pck\\.r_type"

    # Make sure this also works with a type from a fully evaluated value.  During
    # evaluation, dynamic types can be "resolved" so GDB internals could "forget"
    # that elements have variable size.  Fortunately, type resolution of array
    # elements happens only when processing individual elements (i.e. the resolved
    # array type is still associated to the dynamic element type), so the following
    # is supposed to work.
    gdb_test "print pck.a" \
	"= \\(\\(l => 0, s => \"\"\\), \\(l => 2, s => \"ab\"\\)\\)"
    gdb_test "ptype $"\
	"array \\(1 \\.\\. 2\\) of pck\\.r_type"
}