]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
2004-08-13 Michael Chastain <mec.gnu@mindspring.com>
authorMichael Chastain <mec@google.com>
Fri, 13 Aug 2004 10:24:52 +0000 (10:24 +0000)
committerMichael Chastain <mec@google.com>
Fri, 13 Aug 2004 10:24:52 +0000 (10:24 +0000)
* gdb.cp/inherit.exp: Use cp_test_ptype_class.

gdb/testsuite/ChangeLog
gdb/testsuite/gdb.cp/inherit.exp

index 89eb7b3b2fe3020fa0103a25e691f3444ff998e9..15822e79da6e2400c395d40f392d67efbd330ec0 100644 (file)
@@ -1,3 +1,7 @@
+2004-08-13  Michael Chastain  <mec.gnu@mindspring.com>
+
+       * gdb.cp/inherit.exp: Use cp_test_ptype_class.
+
 2004-08-13  Michael Chastain  <mec.gnu@mindspring.com>
 
        * gdb.cp/classes.exp: Remove unused declarations.  Just let
index db57054dab2d1b8058b9af5ccbb5c29bc527e321..9ae1c1e2f3aec2fb1694aaafd9a52dfc4a096839 100644 (file)
@@ -28,6 +28,8 @@ if $tracelevel then {
 
 if { [skip_cplus_tests] } { continue }
 
+load_lib "cp-support.exp"
+
 set testfile "inherit"
 set srcfile misc.cc
 set binfile ${objdir}/${subdir}/${testfile}
@@ -43,127 +45,44 @@ proc test_ptype_si { } {
     global ws
     global nl
 
-    # Print class A as a type.
-
-    set re_class       "((class|struct) A \{${ws}public:|struct A \{)"
-    set re_fields      "int a;${ws}int x;"
-    set re_synth_gcc_23        "A & operator=\\(A const ?&\\);${ws}A\\(A const ?&\\);${ws}A\\((void|)\\);"
-
-    set name "ptype A (FIXME)"
-    gdb_test_multiple "ptype A" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
-
-    # Print class A as an explicit class.
-
-    set name "ptype class A (FIXME)"
-    gdb_test_multiple "ptype class A" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
-
-    # Print type of an object of type A.
-
-    set name "ptype g_A (FIXME)"
-    gdb_test_multiple "ptype g_A" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
-
-    # Print class B as a type.
-
-    set re_class       "((class|struct) B : public A \{${ws}public:|struct B : public A \{)"
-    set re_fields      "int b;${ws}int x;"
-    set re_synth_gcc_23        "B & operator=\\(B const ?&\\);${ws}B\\(B const ?&\\);${ws}B\\((void|)\\);"
-
-    set name "ptype B"
-    gdb_test_multiple "ptype B" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
-
-    # Print class B as an explicit class.
-
-    set name "ptype class B"
-    gdb_test_multiple "ptype class B" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
-
-    # Print type of an object of type B.
+    # A simple class.
 
-    set name "ptype g_B"
-    gdb_test_multiple "ptype g_B" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
-
-    # Print class C as a type.
-
-    set re_class       "((class|struct) C : public A \{${ws}public:|struct C : public A \{)"
-    set re_fields      "int c;${ws}int x;"
-    set re_synth_gcc_23        "C & operator=\\(C const ?&\\);${ws}C\\(C const ?&\\);${ws}C\\((void|)\\);"
-
-    set name "ptype C"
-    gdb_test_multiple "ptype C" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
+    cp_test_ptype_class \
+       "ptype A" "ptype A (FIXME)" "class" "A" \
+       {
+           { field public "int a;" }
+           { field public "int x;" }
        }
-    }
+    cp_test_ptype_class "ptype class A" "ptype class A (FIXME)" "class" "A" ibid
+    cp_test_ptype_class "ptype g_A" "ptype g_A (FIXME)" "class" "A" ibid
 
-    # Print class C as an explicit class.
+    # A derived class.
 
-    set name "ptype class C"
-    gdb_test_multiple "ptype class C" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
+    cp_test_ptype_class \
+       "ptype B" "" "class" "B" \
+       {
+           { base         "public A" }
+           { field public "int b;" }
+           { field public "int x;" }
        }
-    }
+    cp_test_ptype_class "ptype class B" "" "class" "B" ibid
+    cp_test_ptype_class "ptype g_B" "" "class" "B" ibid
 
-    # Print type of an object of type g_C.
+    # Another derived class.
 
-    set name "ptype g_C"
-    gdb_test_multiple "ptype g_C" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
+    cp_test_ptype_class \
+       "ptype C" "" "class" "C" \
+       {
+           { base         "public A" }
+           { field public "int c;" }
+           { field public "int x;" }
        }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
+    cp_test_ptype_class "ptype class C" "" "class" "C" ibid
+    cp_test_ptype_class "ptype g_C" "" "class" "C" ibid
 
-    # Print a structure with no tag.
+    # A structure with no tag.
+    # TODO: move this mess into a separate file, and re-specify
+    # which results are PASS, KFAIL, XFAIL, and FAIL.
 
     set re_tag         "tagless_struct"
     set XX_tag         "\\._1"
@@ -225,433 +144,108 @@ proc test_ptype_si { } {
 # Multiple inheritance, print type definitions.
 
 proc test_ptype_mi { } {
-    global gdb_prompt
-    global ws
-    global nl
 
-    set re_class       "class D : public B, public C \{${ws}public:"
-    set re_fields      "int d;${ws}int x;"
-    set re_synth_gcc_23        "D & operator=\\(D const ?&\\);${ws}D\\(D const ?&\\);${ws}D\\((void|)\\);"
+    # A class with two bases.
 
-    # ptype D: type, class, object.
-
-    set name "ptype D"
-    gdb_test_multiple "ptype D" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
+    cp_test_ptype_class \
+       "ptype D" "" "class" "D" \
+       {
+           { base         "public B" }
+           { base         "public C" }
+           { field public "int d;" }
+           { field public "int x;" }
        }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
-
-    set name "ptype class D"
-    gdb_test_multiple "ptype class D" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
-
-    set name "ptype g_D"
-    gdb_test_multiple "ptype g_D" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
-
-    set re_class       "class E : public D \{${ws}public:"
-    set re_fields      "int e;${ws}int x;"
-    set re_synth_gcc_23        "E & operator=\\(E const ?&\\);${ws}E\\(E const ?&\\);${ws}E\\((void|)\\);"
-
-    # ptype E: type, class, object.
-
-    set name "ptype E"
-    gdb_test_multiple "ptype E" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
+    cp_test_ptype_class "ptype class D" "" "class" "D" ibid
+    cp_test_ptype_class "ptype g_D" "" "class" "D" ibid
 
-    set name "ptype class E"
-    gdb_test_multiple "ptype class E" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
+    # A class derived from the previous class.
 
-    set name "ptype g_E"
-    gdb_test_multiple "ptype g_E" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
+    cp_test_ptype_class \
+       "ptype E" "" "class" "E" \
+       {
+           { base         "public D" }
+           { field public "int e;" }
+           { field public "int x;" }
        }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
+    cp_test_ptype_class "ptype class E" "" "class" "E" ibid
+    cp_test_ptype_class "ptype g_E" "" "class" "E" ibid
 }
 
 # Single virtual inheritance, print type definitions.
 
 proc test_ptype_vi { } {
-    global gdb_prompt
-    global ws
-    global nl
-
-    # ptype vA: type, class, object.
 
-    set re_class       "((class|struct) vA \{${ws}public:|struct vA \{)"
-    set re_fields      "int va;${ws}int vx;"
-    set re_synth_gcc_23        "vA & operator=\\(vA const ?&\\);${ws}vA\\(vA const ?&\\);${ws}vA\\((void|)\\);"
+    # class vA
 
-    set name "ptype vA"
-    gdb_test_multiple "ptype vA" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
+    cp_test_ptype_class \
+       "ptype vA" "" "class" "vA" \
+       {
+           { field public "int va;" }
+           { field public "int vx;" }
        }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
+    cp_test_ptype_class "ptype class vA" "" "class" "vA" ibid
+    cp_test_ptype_class "ptype g_vA" "" "class" "vA" ibid
 
-    set name "ptype class vA"
-    gdb_test_multiple "ptype class vA" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-    }
+    # class vB
 
-    set name "ptype g_vA"
-    gdb_test_multiple "ptype g_vA" $name {
-       -re "type = $re_class${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
+    cp_test_ptype_class \
+       "ptype vB" "" "class" "vB" \
+       {
+           { base         "public virtual vA" }
+           { vbase        "vA" }
+           { field public "int vb;" }
+           { field public "int vx;" }
        }
-    }
-
-    # ptype vB: type, class, object.
+    cp_test_ptype_class "ptype class vB" "" "class" "vB" ibid
+    cp_test_ptype_class "ptype g_vB" "" "class" "vB" ibid
 
-    set re_class       "class vB : public virtual vA \{(${ws}private:|)"
-    set re_vbptr       "vA \\*(_vb.2vA|_vb.vA);${ws}"
-    set re_access      "public:"
-    set re_fields      "int vb;${ws}int vx;"
-    set re_synth_gcc_2 "vB & operator=\\(vB const ?&\\);${ws}vB\\(int, vB const ?&\\);${ws}vB\\(int\\);"
-    set re_synth_gcc_3 "(vB & operator=\\(vB const ?&\\);${ws}|)vB\\(vB const ?&\\);${ws}vB\\((void|)\\);"
+    # class vC
 
-    set name "ptype vB"
-    gdb_test_multiple "ptype vB" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name (aCC)"
+    cp_test_ptype_class \
+       "ptype vC" "" "class" "vC" \
+       {
+           { base         "public virtual vA" }
+           { vbase        "vA" }
+           { field public "int vc;" }
+           { field public "int vx;" }
        }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name (aCC)"
-       }
-    }
+    cp_test_ptype_class "ptype class vC" "" "class" "vC" ibid
+    cp_test_ptype_class "ptype g_vC" "" "class" "vC" ibid
 
-    set name "ptype class vB"
-    gdb_test_multiple "ptype class vB" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name (aCC)"
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name (aCC)"
-       }
-    }
-
-    set name "ptype g_vB"
-    gdb_test_multiple "ptype g_vB" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name (aCC)"
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name (aCC)"
-       }
-    }
-
-    # ptype vC: type, class, object.
-
-    set re_class       "class vC : public virtual vA \{(${ws}private:|)"
-    set re_vbptr       "vA \\*(_vb.2vA|_vb.vA);${ws}"
-    set re_access      "public:"
-    set re_fields      "int vc;${ws}int vx;"
-    set re_synth_gcc_2 "vC & operator=\\(vC const ?&\\);${ws}vC\\(int, vC const ?&\\);${ws}vC\\(int\\);"
-    set re_synth_gcc_3 "(vC & operator=\\(vC const ?&\\);${ws}|)vC\\(vC const ?&\\);${ws}vC\\((void|)\\);"
-
-    set name "ptype vC"
-    gdb_test_multiple "ptype vC" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name (aCC)"
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name (aCC)"
-       }
-    }
-
-    set name "ptype class vC"
-    gdb_test_multiple "ptype class vC" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name (aCC)"
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name (aCC)"
-       }
-    }
-
-    set name "ptype g_vC"
-    gdb_test_multiple "ptype g_vC" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name (aCC)"
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name (aCC)"
-       }
-    }
 }
 
 # Multiple virtual inheritance, print type definitions.
 
 proc test_ptype_mvi { } {
-    global gdb_prompt
-    global ws
-    global nl
-
-    # ptype vD: type, class, object.
-
-    set re_class       "class vD : public virtual vB, public virtual vC \{(${ws}private:|)"
-    set re_vbptr       "vC \\*(_vb.2vC|_vb.vC);${ws}vB \\*(_vb.2vB|_vb.vB);"
-    set re_access      "public:"
-    set re_fields      "int vd;${ws}int vx;"
-    set re_synth_gcc_2 "vD & operator=\\(vD const ?&\\);${ws}vD\\(int, vD const ?&\\);${ws}vD\\(int\\);"
-    set re_synth_gcc_3 "(vD & operator=\\(vD const ?&\\);${ws}|)vD\\(vD const ?&\\);${ws}vD\\((void|)\\);"
-
-    set name "ptype vD"
-    gdb_test_multiple "ptype vD" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name"
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name"
-       }
-    }
 
-    set name "ptype class vD"
-    gdb_test_multiple "ptype class vD" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name"
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name"
-       }
-    }
+    # class vD
 
-    set name "ptype g_vD"
-    gdb_test_multiple "ptype g_vD" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name"
+    cp_test_ptype_class \
+       "ptype vD" "" "class" "vD" \
+       {
+           { base         "public virtual vB" }
+           { base         "public virtual vC" }
+           { vbase        "vC" }
+           { vbase        "vB" }
+           { field public "int vd;" }
+           { field public "int vx;" }
        }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name"
-       }
-    }
+    cp_test_ptype_class "ptype class vD" "" "class" "vD" ibid
+    cp_test_ptype_class "ptype g_vD" "" "class" "vD" ibid
 
-    # ptype vE: type, class, object.
+    # class vE
 
-    set re_class       "class vE : public virtual vD \{(${ws}private:|)"
-    set re_vbptr       "vD \\*(_vb.2vD|_vb.vD);"
-    set re_access      "public:"
-    set re_fields      "int ve;${ws}int vx;"
-    set re_synth_gcc_2 "vE & operator=\\(vE const ?&\\);${ws}vE\\(int, vE const ?&\\);${ws}vE\\(int\\);"
-    set re_synth_gcc_3 "(vE & operator=\\(vE const ?&\\);${ws}|)vE\\(vE const ?&\\);${ws}vE\\((void|)\\);"
-
-    set name "ptype vE"
-    gdb_test_multiple "ptype vE" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name"
+    cp_test_ptype_class \
+       "ptype vE" "" "class" "vE" \
+       {
+           { base         "public virtual vD" }
+           { vbase        "vD" }
+           { field public "int ve;" }
+           { field public "int vx;" }
        }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name"
-       }
-    }
-
-    set name "ptype class vE"
-    gdb_test_multiple "ptype class vE" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name"
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name"
-       }
-    }
+    cp_test_ptype_class "ptype class vE" "" "class" "vE" ibid
+    cp_test_ptype_class "ptype g_vE" "" "class" "vE" ibid
 
-    set name "ptype g_vE"
-    gdb_test_multiple "ptype g_vE" $name {
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gdwarf-2
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_vbptr${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_2$nl\}$nl$gdb_prompt $" {
-           # gcc 2.95.3 -gstabs+
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gdwarf-2
-           # gcc HEAD 2004-01-21 -gdwarf-2
-           pass "$name"
-       }
-       -re "type = $re_class${ws}$re_access${ws}$re_fields${ws}$re_synth_gcc_3$nl\}$nl$gdb_prompt $" {
-           # gcc 3.3.2 -gstabs+
-           # gcc HEAD 2004-01-21 -gstabs+
-           pass "$name"
-       }
-    }
 }
 
 # Single inheritance, print individual members.
@@ -816,20 +410,20 @@ proc test_print_anon_union {} {
        }
     }
 
-    set re_class       "((struct|class) class_with_anon_union \{${ws}public:|struct class_with_anon_union \{)"
-    set re_fields      "int one;${ws}"
-    set re_anon_union  "union \{${ws}int a;${ws}long int b;${ws}\};"
-    set re_synth_gcc_23        "class_with_anon_union & operator=\\(class_with_anon_union const ?&\\);${ws}class_with_anon_union\\(class_with_anon_union const ?&\\);${ws}class_with_anon_union\\((void|)\\);"
+    # The nested union prints as a multi-line field, but the class body
+    # scanner is inherently line-oriented.  This is ugly but it works.
 
-    set name "print type of anonymous union"
-    gdb_test_multiple "ptype g_anon_union" $name {
-       -re "type = $re_class${ws}$re_fields${ws}$re_anon_union$nl\}$nl$gdb_prompt $" {
-           pass $name
-       }
-       -re "type = $re_class${ws}$re_fields${ws}$re_anon_union${ws}$re_synth_gcc_23$nl\}$nl$gdb_prompt $" {
-           pass $name
+    cp_test_ptype_class \
+       "ptype g_anon_union" "print type of anonymous union" \
+       "class" "class_with_anon_union" \
+       {
+           { field public "int one;" }
+           { field public "union \{" }
+           { field public "int a;" }
+           { field public "long int b;" }
+           { field public "\};" }
        }
-    }
+
 }