gdb
authorTom Tromey <tromey@redhat.com>
Mon, 15 Mar 2010 17:26:47 +0000 (17:26 +0000)
committerTom Tromey <tromey@redhat.com>
Mon, 15 Mar 2010 17:26:47 +0000 (17:26 +0000)
* c-exp.y (name_not_typename): Add 'operator' clause.
gdb/testsuite
* gdb.cp/userdef.exp: Add tests for explicit calls to operator==.
* gdb.cp/userdef.cc (operator==): New function.
(main): New locals mem1, mem2.

gdb/ChangeLog
gdb/c-exp.y
gdb/testsuite/ChangeLog
gdb/testsuite/gdb.cp/userdef.cc
gdb/testsuite/gdb.cp/userdef.exp

index 8ce03f4bef2cfa2b689e9444483f57ee0865450f..2b3c172ea95de830ebd634544b0eb47384984a2c 100644 (file)
@@ -1,3 +1,7 @@
+2010-03-15  Tom Tromey  <tromey@redhat.com>
+
+       * c-exp.y (name_not_typename): Add 'operator' clause.
+
 2010-03-15  Ralf Corsepius  <ralf.corsepius@rtems.org>
 
        * configure.ac: Exit if ${gdb_target_obs}" is not set.
index 1af76c9dc71a7d2ce7f55e88c82321689735f380..2577a99398e9ce1c49f8abd0a28489942cffb1f2 100644 (file)
@@ -1236,6 +1236,14 @@ name_not_typename :      NAME
    context where only a name could occur, this might be useful.
        |       NAME_OR_INT
  */
+       |       operator
+                       {
+                         $$.stoken = $1;
+                         $$.sym = lookup_symbol ($1.ptr,
+                                                 expression_context_block,
+                                                 VAR_DOMAIN,
+                                                 &$$.is_a_field_of_this);
+                       }
        ;
 
 %%
index 84c5eef9a2883538753d3ab38897ece2b510b4c5..b675f98c27797ab038a3555bdebd6b64d484e122 100644 (file)
@@ -1,3 +1,9 @@
+2010-03-15  Tom Tromey  <tromey@redhat.com>
+
+       * gdb.cp/userdef.exp: Add tests for explicit calls to operator==.
+       * gdb.cp/userdef.cc (operator==): New function.
+       (main): New locals mem1, mem2.
+
 2010-03-15  Jie Zhang  <jie@codesourcery.com>
 
        * lib/mi-support.exp (mi_gdb_target_load): Delete unused timeout var.
index 338c58a7c8bd467075d82d1b0e0341ccffe45fab..56a735fdc89f0fcf1c9c6c1a6a1ffc8177b1a95c 100644 (file)
@@ -311,6 +311,11 @@ public:
   int z;
 };
 
+bool operator== (const Member &m1, const Member &m2)
+{
+  return m1.z == m2.z;
+}
+
 class Container
 {
 public:
@@ -330,8 +335,12 @@ int main (void)
  A1 two(4,5);
  A1 three(0,0);
  Container c;
+ Member mem1, mem2;
  int val;
  
+ mem1.z = 5;
+ mem2.z = 7;
+
  marker1(); // marker1-returns-here
  cout << one; // marker1-returns-here
  cout << two;
index 5e47d9079e0e2edfc56b0384ea99e3ca21c1a098..33bb485484b9efa8462a12fae06602964dfa3801 100644 (file)
@@ -113,6 +113,7 @@ gdb_test "print one > two" "\\\$\[0-9\]* = 0\[\r\n\]"
 gdb_test "print one >= two" "\\\$\[0-9\]* = 0\[\r\n\]"
 
 gdb_test "print one == two" "\\\$\[0-9\]* = 0\[\r\n\]"
+gdb_test "print one.operator== (two)" "\\\$\[0-9\]* = 0\[\r\n\]"
 
 gdb_test "print one != two" "\\\$\[0-9\]* = 1\[\r\n\]"
 
@@ -155,5 +156,8 @@ gdb_test "print *c" "\\\$\[0-9\]* = \\(Member &\\) @$hex: {z = .*}"
 gdb_test "print &*c" "\\\$\[0-9\]* = \\(Member \\*\\) $hex"
 gdb_test "ptype &*c" "type = (struct|class) Member {(\[\r\n \]+public:)?\[\r\n \]+int z;\[\r\n\]+} &\\*"
 
+gdb_test "print operator== (mem1, mem2)" " = false"
+gdb_test "print operator== (mem1, mem1)" " = true"
+
 gdb_exit
 return 0