Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
* [RFA/MI testsuite] gdb/701 test (varobj)
@ 2002-09-13 16:49 Keith Seitz
  2002-09-13 17:25 ` Fernando Nasser
  2002-09-13 17:37 ` Andrew Cagney
  0 siblings, 2 replies; 7+ messages in thread
From: Keith Seitz @ 2002-09-13 16:49 UTC (permalink / raw)
  To: gdb-patches

Hi,

The test below tickles a crashing bug in gdb's varobj code, as reported in 
gdb/701.

[I felt it was a lot easier to add a new test file than to try to 
integrate this into the existing tests -- too many line numbers to reorder 
if adding a line into var-cmd.c...]

Keith

ChangeLog
2002-09-13  Keith Seitz  <keiths@redhat.com>

	* gdb701.exp: New file for testing varobj target type bug.
	* gdb701.c: New file.

Patch
Index: testsuite/gdb.mi/gdb701.c
===================================================================
RCS file: testsuite/gdb.mi/gdb701.c
diff -N testsuite/gdb.mi/gdb701.c
*** testsuite/gdb.mi/gdb701.c	1 Jan 1970 00:00:00 -0000
--- testsuite/gdb.mi/gdb701.c	13 Sep 2002 23:47:55 -0000
***************
*** 0 ****
--- 1,15 ----
+ struct _foo
+ {
+   int x;
+   int y;
+   int z;
+ };
+ 
+ typedef struct _foo Foo;
+ 
+ int
+ main (int argc, char *argv[])
+ {
+   Foo *foo = 0;
+   exit (0);
+ }
Index: testsuite/gdb.mi/gdb701.exp
===================================================================
RCS file: testsuite/gdb.mi/gdb701.exp
diff -N testsuite/gdb.mi/gdb701.exp
*** testsuite/gdb.mi/gdb701.exp	1 Jan 1970 00:00:00 -0000
--- testsuite/gdb.mi/gdb701.exp	13 Sep 2002 23:47:55 -0000
***************
*** 0 ****
--- 1,67 ----
+ # Copyright 2002 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 2 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, 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
+ 
+ #
+ # test gdb/701
+ #
+ 
+ load_lib mi-support.exp
+ set MIFLAGS "-i=mi"
+ 
+ gdb_exit
+ if [mi_gdb_start] {
+     continue
+ }
+ 
+ set testfile gdb701
+ set srcfile "$testfile.c"
+ set binfile $objdir/$subdir/$testfile
+ if {[gdb_compile $srcdir/$subdir/$srcfile $binfile executable debug] != ""} {
+   gdb_suppress_entire_file "Testcase compile failed, so all test in this file will automatically fail."
+ }
+ 
+ # When varobj reports the types of objects, it often isn't really reporting
+ # the type as GDB knows it. For example, in this testcase, we have a
+ # structure which has been typedefed. A varobj of this type would really have
+ # a type of "TYPE_CODE_TYPEDEF". It's target type is "TYPE_CODE_STRUCT". Varobj
+ # should skip over the TYPEDEF type when figuring out the varobj's children.
+ # If it doesn't, Bad Things Happen(TM).
+ 
+ # Run to main
+ mi_run_to_main
+ 
+ # Step over "foo = 0"
+ mi_next "step over \"foo = 0\""
+ 
+ mi_gdb_test "-var-create fooPtr * foo" \
+   "(&\".*\"\r\n)*\\^done,name=\"fooPtr\",numchild=\"3\",type=\"Foo \\*\"" \
+   "create fooPtr"
+ 
+ mi_gdb_test "-var-list-children fooPtr" \
+   "(&\".*\"\r\n)*\\^done,numchild=\"3\",.*" \
+   "list children of fooPtr"
+ 
+ foreach i [list x y z] {
+   mi_gdb_test "-var-list-children fooPtr.$i" \
+     "(&\".*\"\r\n)*\\^done,numchild=\"0\"" \
+     "list children of fooPtr.$i"
+ }
+ 
+ mi_gdb_exit
+ return 0


^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFA/MI testsuite] gdb/701 test (varobj)
  2002-09-13 16:49 [RFA/MI testsuite] gdb/701 test (varobj) Keith Seitz
@ 2002-09-13 17:25 ` Fernando Nasser
  2002-09-16 11:56   ` Keith Seitz
  2002-09-17 12:24   ` Keith Seitz
  2002-09-13 17:37 ` Andrew Cagney
  1 sibling, 2 replies; 7+ messages in thread
From: Fernando Nasser @ 2002-09-13 17:25 UTC (permalink / raw)
  To: Keith Seitz; +Cc: gdb-patches

[-- Attachment #1: Type: text/plain, Size: 307 bytes --]

As you are at it, canyou take a look at this old patch of mine that I've 
found lost in a branch....  Something should be broken without it!

Regards,
Fernando


-- 
Fernando Nasser
Red Hat Canada Ltd.                     E-Mail:  fnasser@redhat.com
2323 Yonge Street, Suite #300
Toronto, Ontario   M4P 2C9

[-- Attachment #2: MI.PATCH --]
[-- Type: text/plain, Size: 1475 bytes --]

Index: mi/ChangeLog
===================================================================
RCS file: /cvs/src/src/gdb/mi/ChangeLog,v
retrieving revision 1.69
diff -c -p -r1.69 ChangeLog
*** mi/ChangeLog	11 Sep 2002 21:49:04 -0000	1.69
--- mi/ChangeLog	14 Sep 2002 00:23:46 -0000
***************
*** 1,3 ****
--- 1,7 ----
+ 2001-01-27  Fernando Nasser  <fnasser@redhat.com>
+ 
+ 	* mi-cmd-var.c (varobj_update_one): Get a new handle if type changed.
+ 
  2002-09-11  Keith Seitz  <keiths@redhat.com>
  
  	* mi-main.c (mi_cmd_data_list_register_names): Use cleanups
Index: mi/mi-cmd-var.c
===================================================================
RCS file: /cvs/src/src/gdb/mi/mi-cmd-var.c,v
retrieving revision 1.12
diff -c -p -r1.12 mi-cmd-var.c
*** mi/mi-cmd-var.c	30 Jul 2002 13:45:15 -0000	1.12
--- mi/mi-cmd-var.c	14 Sep 2002 00:23:46 -0000
*************** varobj_update_one (struct varobj *var)
*** 458,463 ****
--- 458,464 ----
    struct varobj **changelist;
    struct varobj **cc;
    int nc;
+   char *varname = varobj_get_objname(var);
  
    nc = varobj_update (&var, &changelist);
  
*************** varobj_update_one (struct varobj *var)
*** 475,480 ****
--- 476,482 ----
      }
    else if (nc == -2)
      {
+       var = varobj_get_handle (varname);
        ui_out_field_string (uiout, "name", varobj_get_objname (var));
        ui_out_field_string (uiout, "in_scope", "true");
        ui_out_field_string (uiout, "new_type", varobj_get_type(var));

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFA/MI testsuite] gdb/701 test (varobj)
  2002-09-13 16:49 [RFA/MI testsuite] gdb/701 test (varobj) Keith Seitz
  2002-09-13 17:25 ` Fernando Nasser
@ 2002-09-13 17:37 ` Andrew Cagney
  2002-09-16 12:02   ` Keith Seitz
  1 sibling, 1 reply; 7+ messages in thread
From: Andrew Cagney @ 2002-09-13 17:37 UTC (permalink / raw)
  To: Keith Seitz; +Cc: gdb-patches

> Hi,
> 
> The test below tickles a crashing bug in gdb's varobj code, as reported in 
> gdb/701.
> 
> [I felt it was a lot easier to add a new test file than to try to 
> integrate this into the existing tests -- too many line numbers to reorder 
> if adding a line into var-cmd.c...]

Ok. Andrew


> ChangeLog
> 2002-09-13  Keith Seitz  <keiths@redhat.com>
> 
> 	* gdb701.exp: New file for testing varobj target type bug.
> 	* gdb701.c: New file.
> 
> Patch
> Index: testsuite/gdb.mi/gdb701.c
> ===================================================================
> RCS file: testsuite/gdb.mi/gdb701.c
> diff -N testsuite/gdb.mi/gdb701.c
> *** testsuite/gdb.mi/gdb701.c	1 Jan 1970 00:00:00 -0000
> --- testsuite/gdb.mi/gdb701.c	13 Sep 2002 23:47:55 -0000
> ***************
> *** 0 ****
> --- 1,15 ----
> + struct _foo
> + {
> +   int x;
> +   int y;
> +   int z;
> + };
> + 
> + typedef struct _foo Foo;
> + 
> + int
> + main (int argc, char *argv[])
> + {
> +   Foo *foo = 0;
> +   exit (0);
> + }
> Index: testsuite/gdb.mi/gdb701.exp
> ===================================================================
> RCS file: testsuite/gdb.mi/gdb701.exp
> diff -N testsuite/gdb.mi/gdb701.exp
> *** testsuite/gdb.mi/gdb701.exp	1 Jan 1970 00:00:00 -0000
> --- testsuite/gdb.mi/gdb701.exp	13 Sep 2002 23:47:55 -0000
> ***************
> *** 0 ****
> --- 1,67 ----
> + # Copyright 2002 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 2 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, 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
> + 
> + #
> + # test gdb/701
> + #
> + 
> + load_lib mi-support.exp
> + set MIFLAGS "-i=mi"
> + 
> + gdb_exit
> + if [mi_gdb_start] {
> +     continue
> + }
> + 
> + set testfile gdb701
> + set srcfile "$testfile.c"
> + set binfile $objdir/$subdir/$testfile
> + if {[gdb_compile $srcdir/$subdir/$srcfile $binfile executable debug] != ""} {
> +   gdb_suppress_entire_file "Testcase compile failed, so all test in this file will automatically fail."
> + }
> + 
> + # When varobj reports the types of objects, it often isn't really reporting
> + # the type as GDB knows it. For example, in this testcase, we have a
> + # structure which has been typedefed. A varobj of this type would really have
> + # a type of "TYPE_CODE_TYPEDEF". It's target type is "TYPE_CODE_STRUCT". Varobj
> + # should skip over the TYPEDEF type when figuring out the varobj's children.
> + # If it doesn't, Bad Things Happen(TM).
> + 
> + # Run to main
> + mi_run_to_main
> + 
> + # Step over "foo = 0"
> + mi_next "step over \"foo = 0\""
> + 
> + mi_gdb_test "-var-create fooPtr * foo" \
> +   "(&\".*\"\r\n)*\\^done,name=\"fooPtr\",numchild=\"3\",type=\"Foo \\*\"" \
> +   "create fooPtr"
> + 
> + mi_gdb_test "-var-list-children fooPtr" \
> +   "(&\".*\"\r\n)*\\^done,numchild=\"3\",.*" \
> +   "list children of fooPtr"
> + 
> + foreach i [list x y z] {
> +   mi_gdb_test "-var-list-children fooPtr.$i" \
> +     "(&\".*\"\r\n)*\\^done,numchild=\"0\"" \
> +     "list children of fooPtr.$i"
> + }
> + 
> + mi_gdb_exit
> + return 0
> 
> 



^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFA/MI testsuite] gdb/701 test (varobj)
  2002-09-13 17:25 ` Fernando Nasser
@ 2002-09-16 11:56   ` Keith Seitz
  2002-09-17 12:24   ` Keith Seitz
  1 sibling, 0 replies; 7+ messages in thread
From: Keith Seitz @ 2002-09-16 11:56 UTC (permalink / raw)
  To: Fernando Nasser; +Cc: gdb-patches

On Fri, 13 Sep 2002, Fernando Nasser wrote:

> As you are at it, canyou take a look at this old patch of mine that I've 
> found lost in a branch....  Something should be broken without it!

I can take a look at it. It seems to me that this looks plausible. I'll 
see if I can add some more test which check the type-changing stuff. As I 
recall, we've historically had some problems with this code. Having a 
testcase should clear things up.

Keith



^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFA/MI testsuite] gdb/701 test (varobj)
  2002-09-13 17:37 ` Andrew Cagney
@ 2002-09-16 12:02   ` Keith Seitz
  0 siblings, 0 replies; 7+ messages in thread
From: Keith Seitz @ 2002-09-16 12:02 UTC (permalink / raw)
  To: gdb-patches

On Fri, 13 Sep 2002, Andrew Cagney wrote:

> Ok. Andrew

Committed. Thanks for the quick look. Patch to fix this coming.

Keith


^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFA/MI testsuite] gdb/701 test (varobj)
  2002-09-13 17:25 ` Fernando Nasser
  2002-09-16 11:56   ` Keith Seitz
@ 2002-09-17 12:24   ` Keith Seitz
  2002-09-18  7:46     ` Fernando Nasser
  1 sibling, 1 reply; 7+ messages in thread
From: Keith Seitz @ 2002-09-17 12:24 UTC (permalink / raw)
  To: Fernando Nasser; +Cc: gdb-patches

On Fri, 13 Sep 2002, Fernando Nasser wrote:

> As you are at it, canyou take a look at this old patch of mine that I've 
> found lost in a branch....  Something should be broken without it!

Ok, I've got a testcase for it... I'll be submitting it shortly.

I think your patch is now obsolete. At one time this was necessary
because when we call varobj_update, we've already gotten a pointer to our 
varobj (via varobj_get_handle). When varobj_update is called and the type 
changes, the original varobj is deleted, and a new one is created with the 
same name. I changed the API for varobj_update so that this new handle is 
propagated upward.

Thus, when varobj_update returns, the handle is still valid (if 
different). This change was committed by me on 2001-08-17.

Keith


^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [RFA/MI testsuite] gdb/701 test (varobj)
  2002-09-17 12:24   ` Keith Seitz
@ 2002-09-18  7:46     ` Fernando Nasser
  0 siblings, 0 replies; 7+ messages in thread
From: Fernando Nasser @ 2002-09-18  7:46 UTC (permalink / raw)
  To: Keith Seitz; +Cc: gdb-patches

Thanks for checking this out Keith.

Regards,
Fernando

Keith Seitz wrote:
> On Fri, 13 Sep 2002, Fernando Nasser wrote:
> 
> 
>>As you are at it, canyou take a look at this old patch of mine that I've 
>>found lost in a branch....  Something should be broken without it!
> 
> 
> Ok, I've got a testcase for it... I'll be submitting it shortly.
> 
> I think your patch is now obsolete. At one time this was necessary
> because when we call varobj_update, we've already gotten a pointer to our 
> varobj (via varobj_get_handle). When varobj_update is called and the type 
> changes, the original varobj is deleted, and a new one is created with the 
> same name. I changed the API for varobj_update so that this new handle is 
> propagated upward.
> 
> Thus, when varobj_update returns, the handle is still valid (if 
> different). This change was committed by me on 2001-08-17.
> 
> Keith
> 


-- 
Fernando Nasser
Red Hat Canada Ltd.                     E-Mail:  fnasser@redhat.com
2323 Yonge Street, Suite #300
Toronto, Ontario   M4P 2C9


^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2002-09-18 14:46 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2002-09-13 16:49 [RFA/MI testsuite] gdb/701 test (varobj) Keith Seitz
2002-09-13 17:25 ` Fernando Nasser
2002-09-16 11:56   ` Keith Seitz
2002-09-17 12:24   ` Keith Seitz
2002-09-18  7:46     ` Fernando Nasser
2002-09-13 17:37 ` Andrew Cagney
2002-09-16 12:02   ` Keith Seitz

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox