From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 12791 invoked by alias); 15 Jul 2004 17:40:20 -0000 Mailing-List: contact gdb-patches-help@sources.redhat.com; run by ezmlm Precedence: bulk List-Subscribe: List-Archive: List-Post: List-Help: , Sender: gdb-patches-owner@sources.redhat.com Received: (qmail 12784 invoked from network); 15 Jul 2004 17:40:19 -0000 Received: from unknown (HELO mx1.redhat.com) (66.187.233.31) by sourceware.org with SMTP; 15 Jul 2004 17:40:19 -0000 Received: from int-mx1.corp.redhat.com (int-mx1.corp.redhat.com [172.16.52.254]) by mx1.redhat.com (8.12.10/8.12.10) with ESMTP id i6FHeJe3028815 for ; Thu, 15 Jul 2004 13:40:19 -0400 Received: from localhost.redhat.com (to-dhcp51.toronto.redhat.com [172.16.14.151]) by int-mx1.corp.redhat.com (8.11.6/8.11.6) with ESMTP id i6FHeC019815; Thu, 15 Jul 2004 13:40:18 -0400 Received: from gnu.org (localhost [127.0.0.1]) by localhost.redhat.com (Postfix) with ESMTP id 653D12B9D; Thu, 15 Jul 2004 13:40:14 -0400 (EDT) Message-ID: <40F6C17E.1060502@gnu.org> Date: Thu, 15 Jul 2004 17:40:00 -0000 From: Andrew Cagney User-Agent: Mozilla/5.0 (X11; U; NetBSD macppc; en-GB; rv:1.4.1) Gecko/20040217 MIME-Version: 1.0 To: Michael Elizabeth Chastain Cc: gdb-patches@sources.redhat.com Subject: Re: [rfc] Revamp logical.exp References: <20040714203406.693624B104@berman.michael-chastain.com> In-Reply-To: <20040714203406.693624B104@berman.michael-chastain.com> Content-Type: multipart/mixed; boundary="------------090609060102050207000904" X-SW-Source: 2004-07/txt/msg00184.txt.bz2 This is a multi-part message in MIME format. --------------090609060102050207000904 Content-Type: text/plain; charset=us-ascii; format=flowed Content-Transfer-Encoding: 7bit Content-length: 398 > ac> gdb_test "print x=1,y=0,x == y" " = 0" "evaluate x = y; variables > >>> x=1,y=0; expecting 0" Done. > That would be cool. > > ac> If you want spaces, I'll need to tweak the tables. > > It's fine without pretty-spaces. Also done. > ac> My favorite, amd64 GNU/Linux. > > Okay, approved, or pre-approved if you want to tweak it some more. > > Michael C committed as attached, Andrew --------------090609060102050207000904 Content-Type: text/plain; name="diffs" Content-Transfer-Encoding: 7bit Content-Disposition: inline; filename="diffs" Content-length: 17984 2004-07-15 Andrew Cagney * gdb.base/logical.exp: Update copyright. (evaluate): New procedure. Use to re-implement tests using several tables. Index: testsuite/gdb.base/logical.exp =================================================================== RCS file: /cvs/src/src/gdb/testsuite/gdb.base/logical.exp,v retrieving revision 1.2 diff -p -u -r1.2 logical.exp --- testsuite/gdb.base/logical.exp 6 Mar 2001 08:21:50 -0000 1.2 +++ testsuite/gdb.base/logical.exp 15 Jul 2004 14:59:45 -0000 @@ -1,4 +1,6 @@ -# Copyright 1998, 1999 Free Software Foundation, Inc. +# This testcase is part of GDB, the GNU debugger. + +# Copyright 1998, 1999, 2004 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 @@ -14,21 +16,15 @@ # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -# Please email any bugs, comments, and/or additions to this file to: -# bug-gdb@prep.ai.mit.edu - # This file was written by Elena Zannoni (ezannoni@cygnus.com) -# This file is part of the gdb testsuite +# Tests for correctenss of logical operators, associativity and +# precedence with integer type variables -# -# tests for correctenss of logical operators, associativity and precedence -# with integer type variables -# if $tracelevel then { - strace $tracelevel - } + strace $tracelevel +} # # test running programs @@ -41,8 +37,8 @@ set srcfile ${testfile}.c set binfile ${objdir}/${subdir}/${testfile} if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug additional_flags=-w}] != "" } { - gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail." - } + gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail." +} if [get_compiler_info ${binfile}] { return -1; @@ -63,515 +59,74 @@ if ![runto_main] then { continue } -# -# test expressions with "int" types -# - -gdb_test "set variable x=0" "" "set variable x=0" -gdb_test "set variable y=0" "" "set variable y=0" -gdb_test "set variable z=0" "" "set variable z=0" - -send_gdb "print x\n" -gdb_expect { - -re ".*0.*$gdb_prompt $" { - pass "print value of x" - } - -re ".*$gdb_prompt $" { fail "print value of x" } - timeout { fail "(timeout) print value of x" } - } - - -send_gdb "print y\n" -gdb_expect { - -re ".*0.*$gdb_prompt $" { - pass "print value of y" - } - -re ".*$gdb_prompt $" { fail "print value of y" } - timeout { fail "(timeout) print value of y" } - } - -send_gdb "print z\n" -gdb_expect { - -re ".*0.*$gdb_prompt $" { - pass "print value of z" - } - -re ".*$gdb_prompt $" { fail "print value of z" } - timeout { fail "(timeout) print value of z" } - } - - -# truth tables for && , || , ! - -send_gdb "print x && y\n" -gdb_expect { - -re ".*$false.*$gdb_prompt $" { - pass "print value of xy" - } - -re ".*$gdb_prompt $" { fail "print value of x>y" } - timeout { fail "(timeout) print value of x>y" } - } - -gdb_test "set variable y=1" "" "set variable y=1" - -send_gdb "print x && y\n" -gdb_expect { - -re ".*$false.*$gdb_prompt $" { - pass "print value of xy" - } - -re ".*$gdb_prompt $" { fail "print value of x>y" } - timeout { fail "(timeout) print value of x>y" } - } - -gdb_test "set variable y=0" "" "set variable y=0" - -send_gdb "print x && y\n" -gdb_expect { - -re ".*$false.*$gdb_prompt $" { - pass "print value of x y || w == z\n" -gdb_expect { - -re ".*$true.*$gdb_prompt $" { - pass "print value of x > y || w == z" - } - -re ".*$gdb_prompt $" { fail "print value of x > y || w == z" } - timeout { fail "(timeout) print value of x > y || w == z " } - } - - -gdb_test "set variable x=1" "" "set variable x=1" -gdb_test "set variable y=2" "" "set variable y=2" -gdb_test "set variable w=1" "" "set variable w=1" -gdb_test "set variable z=3" "" "set variable z=3" - - -send_gdb "print x >= y && w != z\n" -gdb_expect { - -re ".*$false.*$gdb_prompt $" { - pass "print value of x >= y || w != z" - } - -re ".*$gdb_prompt $" { fail "print value of x >= y || w != z" } - timeout { fail "(timeout) print value of x >= y || w != z " } - } - - - -gdb_test "set variable x=2" "" "set variable x=2" -gdb_test "set variable y=2" "" "set variable y=2" -gdb_test "set variable w=2" "" "set variable w=2" -gdb_test "set variable z=3" "" "set variable z=3" - - -send_gdb "print ! x > y || w + z\n" -gdb_expect { - -re ".*$true.*$gdb_prompt $" { - pass "print value of x > y || w != z" - } - -re ".*$gdb_prompt $" { fail "print value of x > y || w != z" } - timeout { fail "(timeout) print value of x > y || w != z " } - } - - - - - - - - - +proc evaluate { vars ops } { + for {set vari 0} {$vari < [llength $vars]} {incr vari} { + set var [lindex $vars $vari] + for {set opi 0} {$opi < [llength $ops]} {incr opi} { + set op [lindex [lindex $ops $opi] 0] + set val [lindex [lindex $ops $opi] [expr $vari + 1]] + gdb_test "print $var, $op" " = $val" "evaluate $op; variables $var; expecting $val" + } + } +} +# Unary +evaluate { + {x = 0} {x = 1} +} { + { {x} 0 1 } + { {!x} 1 0 } + { {!!x} 0 1 } +} +# Binary (with unary) +evaluate { + {x = 0, y = 0} {x = 0, y = 1} {x = 1, y = 0} {x = 1, y = 1} +} { + { {x && y} 0 0 0 1 } + { {!x && y} 0 1 0 0 } + { {x && !y} 0 0 1 0 } + { {!x && !y} 1 0 0 0 } + + { {x || y} 0 1 1 1 } + { {!x || y} 1 1 0 1 } + { {x || !y} 1 0 1 1 } + { {!x || !y} 1 1 1 0 } + + { {x < y} 0 1 0 0 } + { {x <= y} 1 1 0 1 } + { {x == y} 1 0 0 1 } + { {x != y} 0 1 1 0 } + { {x >= y} 1 0 1 1 } + { {x > y} 0 0 1 0 } +} +# Full table of &&, || combinations, followed by random mix of unary ops +evaluate { + {x = 0, y = 0, z = 0} {x = 0, y = 0, z = 1} {x = 0, y = 1, z = 0} {x = 0, y = 1, z = 1} + {x = 1, y = 0, z = 0} {x = 1, y = 0, z = 1} {x = 1, y = 1, z = 0} {x = 1, y = 1, z = 1} +} { + { {x && y && z} 0 0 0 0 0 0 0 1 } + { {x || y && z} 0 0 0 1 1 1 1 1 } + { {x && y || z} 0 1 0 1 0 1 1 1 } + { {x || y || z} 0 1 1 1 1 1 1 1 } + + { {x || !y && z} 0 1 0 0 1 1 1 1 } + { {!x || y && z} 1 1 1 1 0 0 0 1 } + { {!x || y && !z} 1 1 1 1 0 0 1 0 } +} +# More complex operations +evaluate { + {x = 1, y = 2, w = 3, z = 3} + {x = 1, y = 2, w = 1, z = 3} + {x = 2, y = 2, w = 2, z = 3} +} { + { {x > y || w == z} 1 0 0 } + { {x >= y && w != z} 0 0 1 } + { {! x > y || w + z} 1 1 1 } +} --------------090609060102050207000904--