| Index: gdb/testsuite/gdb.base/list.exp | 
| diff --git a/gdb/testsuite/gdb.base/list.exp b/gdb/testsuite/gdb.base/list.exp | 
| index 6b5b207d4b36dd1fd13cc8f5fdf74c12b3a2d4b4..c3cdc6b81ff86fd2a8c36035317fcd6f27c92649 100644 | 
| --- a/gdb/testsuite/gdb.base/list.exp | 
| +++ b/gdb/testsuite/gdb.base/list.exp | 
| @@ -1,5 +1,4 @@ | 
| -# Copyright 1992, 1994-1999, 2002-2003, 2007-2012 Free Software | 
| -# Foundation, Inc. | 
| +# Copyright 1992-2013 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 | 
| @@ -17,57 +16,49 @@ | 
| # This file was written by Fred Fish. (fnf@cygnus.com) | 
|  | 
|  | 
| -set testfile "list" | 
| -set binfile ${objdir}/${subdir}/${testfile} | 
| +standard_testfile list0.c list1.c | 
|  | 
| # Need to download the header to the host. | 
| -remote_download host ${srcdir}/${subdir}/list0.h list0.h | 
| +gdb_remote_download host ${srcdir}/${subdir}/list0.h | 
|  | 
| - | 
| -if  { [gdb_compile "${srcdir}/${subdir}/list0.c" "${binfile}0.o" object {debug}] != "" } { | 
| -     untested list.exp | 
| -     return -1 | 
| -} | 
| - | 
| -if  { [gdb_compile "${srcdir}/${subdir}/list1.c" "${binfile}1.o" object {debug}] != "" } { | 
| -     untested list.exp | 
| -     return -1 | 
| +if {[prepare_for_testing $testfile.exp $testfile [list $srcfile $srcfile2] \ | 
| +	 {debug}]} { | 
| +    return -1 | 
| } | 
|  | 
| -if  { [gdb_compile "${binfile}0.o ${binfile}1.o" ${binfile} executable {debug}] != "" } { | 
| -     untested list.exp | 
| -     return -1 | 
| -} | 
| - | 
| - | 
| - | 
| # Create and source the file that provides information about the compiler | 
| # used to compile the test case. | 
| if [get_compiler_info] { | 
| -    return -1; | 
| +    return -1 | 
| } | 
|  | 
| +# The last line in the file. | 
| +set last_line [gdb_get_line_number "last line" "list0.c"] | 
| + | 
| +# Regex matching the last line in the file. | 
| +set last_line_re "${last_line}\[ \t\]+} /\\* last line \\*/" | 
| + | 
| # | 
| # Local utility proc just to set and verify listsize | 
| # Return 1 if success, 0 if fail. | 
| # | 
|  | 
| -set set_listsize_count 0; | 
| +set set_listsize_count 0 | 
|  | 
| proc set_listsize { arg } { | 
| global gdb_prompt | 
| -    global set_listsize_count; | 
| +    global set_listsize_count | 
|  | 
| -    incr set_listsize_count; | 
| -    if [gdb_test "set listsize $arg" ".*" "setting listsize to $arg #$set_listsize_count"] { | 
| -	return 0; | 
| +    incr set_listsize_count | 
| +    if [gdb_test_no_output "set listsize $arg" "setting listsize to $arg #$set_listsize_count"] { | 
| +	return 0 | 
| } | 
| -    if { $arg <= 0 } { | 
| -	set arg "unlimited"; | 
| +    if { $arg == 0 } { | 
| +	set arg "unlimited" | 
| } | 
|  | 
| if [gdb_test "show listsize" "Number of source lines.* is ${arg}.*" "show listsize $arg #$set_listsize_count"] { | 
| -	return 0; | 
| +	return 0 | 
| } | 
| return 1 | 
| } | 
| @@ -80,6 +71,7 @@ proc test_listsize {} { | 
| global gdb_prompt | 
| global hp_cc_compiler | 
| global hp_aCC_compiler | 
| +    global last_line_re | 
|  | 
| # Show default size | 
|  | 
| @@ -125,21 +117,15 @@ proc test_listsize {} { | 
| # Try a size larger than the entire file. | 
|  | 
| if [ set_listsize 100 ] then { | 
| -	gdb_test "list 1" "1\[ \t\]+#include \"list0.h\".*\r\n4\[23\]\[ \t\]+\}" "list line 1 with listsize 100" | 
| +	gdb_test "list 1" "1\[ \t\]+#include \"list0.h\".*\r\n${last_line_re}" "list line 1 with listsize 100" | 
|  | 
| -	gdb_test "list 10" "1\[ \t\]+#include \"list0.h\".*\r\n4\[23\]\[ \t\]+\}" "list line 10 with listsize 100" | 
| +	gdb_test "list 10" "1\[ \t\]+#include \"list0.h\".*\r\n${last_line_re}" "list line 10 with listsize 100" | 
| } | 
|  | 
| -    # Try listsize of 0 which suppresses printing. | 
| +    # Try listsize of 0 which is special, and means unlimited. | 
|  | 
| set_listsize 0 | 
| -    gdb_test "list 1" "" "listsize of 0 suppresses output" | 
| - | 
| -    # Try listsize of -1 which is special, and means unlimited. | 
| - | 
| -    set_listsize -1 | 
| -    setup_xfail "*-*-*" | 
| -    gdb_test "list 1" "1\[ \t\]+#include .*\r\n39\[ \t\]+\}" "list line 1 with unlimited listsize" | 
| +    gdb_test "list 1" "1\[ \t\]+#include .*\r\n${last_line_re}" "list line 1 with unlimited listsize" | 
| } | 
|  | 
| # | 
| @@ -198,7 +184,7 @@ proc test_list_filename_and_number {} { | 
| timeout { fail "list list1.c:12 (timeout)" ; gdb_suppress_tests } | 
| } | 
| pass "list filename:number ($testcnt tests)" | 
| -    gdb_stop_suppressing_tests; | 
| +    gdb_stop_suppressing_tests | 
| } | 
|  | 
| # | 
| @@ -225,6 +211,7 @@ proc test_list_function {} { | 
|  | 
| proc test_list_forward {} { | 
| global gdb_prompt | 
| +    global last_line_re | 
|  | 
| set testcnt 0 | 
|  | 
| @@ -251,13 +238,13 @@ proc test_list_forward {} { | 
|  | 
| send_gdb "list\n" | 
| gdb_expect { | 
| -	-re "35\[ \t\]+foo \\(.*\\);.*42\[ \t\]+.*\}\r\n$gdb_prompt $" { incr testcnt } | 
| +	-re "35\[ \t\]+foo \\(.*\\);.*${last_line_re}\r\n$gdb_prompt $" { incr testcnt } | 
| -re ".*$gdb_prompt $" { fail "list 35-42" ; gdb_suppress_tests } | 
| timeout { fail "list 35-42 (timeout)" ; gdb_suppress_tests } | 
| } | 
|  | 
| pass "successive list commands to page forward ($testcnt tests)" | 
| -    gdb_stop_suppressing_tests; | 
| +    gdb_stop_suppressing_tests | 
| } | 
|  | 
| # Test that repeating the list linenum command doesn't print the same | 
| @@ -267,6 +254,7 @@ proc test_list_forward {} { | 
|  | 
| proc test_repeat_list_command {} { | 
| global gdb_prompt | 
| +    global last_line_re | 
|  | 
| set testcnt 0 | 
|  | 
| @@ -293,13 +281,13 @@ proc test_repeat_list_command {} { | 
|  | 
| send_gdb "\n" | 
| gdb_expect { | 
| -	-re "35\[ \t\]+foo \\(.*\\);.*42\[ \t\]+.*\}\r\n$gdb_prompt $" { incr testcnt } | 
| +	-re "35\[ \t\]+foo \\(.*\\);.*${last_line_re}\r\n$gdb_prompt $" { incr testcnt } | 
| -re ".*$gdb_prompt $" { fail "list 35-42" ; gdb_suppress_tests } | 
| timeout { fail "list 35-42 (timeout)" ; gdb_suppress_tests } | 
| } | 
|  | 
| pass "repeat list commands to page forward using 'return' ($testcnt tests)" | 
| -    gdb_stop_suppressing_tests; | 
| +    gdb_stop_suppressing_tests | 
| } | 
|  | 
| proc test_list_backwards {} { | 
| @@ -336,7 +324,7 @@ proc test_list_backwards {} { | 
| } | 
|  | 
| pass "$testcnt successive \"list -\" commands to page backwards" | 
| -    gdb_stop_suppressing_tests; | 
| +    gdb_stop_suppressing_tests | 
| } | 
|  | 
| # | 
| @@ -345,6 +333,8 @@ proc test_list_backwards {} { | 
|  | 
| proc test_list_range {} { | 
| global gdb_prompt | 
| +    global last_line_re | 
| +    global last_line | 
|  | 
| gdb_test "list list0.c:2,list0.c:5" "2\[ \t\]+\r\n3\[ \t\]+int main \[)(\]+.*5\[ \t\]+int x;" "list range; filename:line1,filename:line2" | 
|  | 
| @@ -354,9 +344,12 @@ proc test_list_range {} { | 
|  | 
| #    gdb_test     "list -100,-40" 	"Line number -60 out of range; .*list0.c has 39 lines." "list range; both bounds negative" | 
|  | 
| -    gdb_test "list 30,45" "30\[ \t\]+foo \(.*\);.*43\[ \t\]+\}" "list range; upper bound past EOF" | 
| +    set past_end [expr ${last_line} + 10] | 
| +    set much_past_end [expr ${past_end} + 10] | 
| + | 
| +    gdb_test "list 30,${past_end}" "30\[ \t\]+foo \(.*\);.*${last_line_re}" "list range; upper bound past EOF" | 
|  | 
| -    gdb_test "list 45,100" "Line number 45 out of range; .*list0.c has 43 lines." "list range; both bounds past EOF" | 
| +    gdb_test "list ${past_end},${much_past_end}" "Line number ${past_end} out of range; .*list0.c has ${last_line} lines." "list range; both bounds past EOF" | 
|  | 
| gdb_test "list list0.c:2,list1.c:17" "Specified start and end are in different files." "list range, must be same files" | 
| } | 
| @@ -367,6 +360,7 @@ proc test_list_range {} { | 
|  | 
| proc test_list_filename_and_function {} { | 
| global gdb_prompt | 
| +    global last_line_re | 
|  | 
| set testcnt 0 | 
|  | 
| @@ -390,7 +384,7 @@ proc test_list_filename_and_function {} { | 
| setup_xfail "rs6000-*-aix*" | 
| send_gdb "list list0.c:unused\n" | 
| gdb_expect { | 
| -	-re "40\[ \t\]+unused.*43\[ \t\]+\}\r\n$gdb_prompt $" { | 
| +	-re "40\[ \t\]+unused.*${last_line_re}\r\n$gdb_prompt $" { | 
| incr testcnt | 
| } | 
| -re "37.*42\[ \t\]+\}\r\n$gdb_prompt $" { | 
|  |