# Copyright 2020-2021 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 .
# Ensure that 'layout asm' before starting the inferior puts us in the
# asm layout and displays the disassembly for main.
tuiterm_env
standard_testfile tui-layout.c
if {[build_executable "failed to prepare" ${testfile} ${srcfile}] == -1} {
return -1
}
Term::clean_restart 24 80 $testfile
if {![Term::prepare_for_tui]} {
unsupported "TUI not supported"
return
}
# This puts us into TUI mode, and should display the ASM window.
Term::command_no_prompt_prefix "layout asm"
Term::check_box_contents "check asm box contents" 0 0 80 15 ""
# Scroll the ASM window down using the down arrow key. In an ideal
# world we'd like to use PageDown here, but currently our terminal
# library doesn't support such advanced things.
set testname "scroll to end of assembler"
set down_count 0
while (1) {
# Grab the second line, this is about to become the first line.
set line [Term::get_line 2]
# Except, if the second line is blank then we are at the end of
# the available asm output. Pressing down again _shouldn't_
# change the output, however, if GDB is working, and we press down
# then the screen won't change, so the call to Term::wait_for
# below will just timeout. So for now we avoid testing the edge
# case.
if {[regexp -- "^\\| +\\|$" $line]} {
# Second line is blank, we're at the end of the assembler.
pass $testname
break
}
# Send the down key to GDB.
send_gdb "\033\[B"
incr down_count
set re_line [string_to_regexp $line]
# Ignore whitespace mismatches.
regsub -all {\s+} $re_line {\s+} re_line
if {[Term::wait_for $re_line] \
&& [regexp $re_line [Term::get_line 1]]} {
# We scrolled successfully.
} else {
fail "$testname (scroll failed)"
Term::dump_screen
break
}
if { $down_count > 250 } {
# Maybe we should accept this as a pass in case a target
# really does have loads of assembler to scroll through.
fail "$testname (too much assembler)"
Term::dump_screen
break
}
}