summaryrefslogtreecommitdiff
path: root/gcc_arm/testsuite/g++.old-deja/g++.brendan/overload2.C
diff options
context:
space:
mode:
authorcamthesaxman <camthesaxman@users.noreply.github.com>2020-01-29 18:17:43 -0600
committercamthesaxman <camthesaxman@users.noreply.github.com>2020-01-29 18:17:43 -0600
commitcdc6e2c50f96119bdc4c1205ff5901ca82ec8357 (patch)
tree3e9217eabcf444e166008411f445315606dded59 /gcc_arm/testsuite/g++.old-deja/g++.brendan/overload2.C
parent27176890c4a688ea7de44d3f55af32827016a9fd (diff)
add old compiler with ARM support
Diffstat (limited to 'gcc_arm/testsuite/g++.old-deja/g++.brendan/overload2.C')
-rwxr-xr-xgcc_arm/testsuite/g++.old-deja/g++.brendan/overload2.C43
1 files changed, 43 insertions, 0 deletions
diff --git a/gcc_arm/testsuite/g++.old-deja/g++.brendan/overload2.C b/gcc_arm/testsuite/g++.old-deja/g++.brendan/overload2.C
new file mode 100755
index 0000000..75068da
--- /dev/null
+++ b/gcc_arm/testsuite/g++.old-deja/g++.brendan/overload2.C
@@ -0,0 +1,43 @@
+// GROUPS passed overloading
+// Check that calls to the correct overloaded virtual
+// functions are generated even where the type of the formal
+// arguments for the overloadings are similar or related.
+
+extern "C" void printf (char *, ...);
+
+int proper_method_called = 0;
+
+struct base {
+ int member;
+ virtual void method (char)
+ {
+ }
+ virtual void method (char *)
+ {
+ }
+};
+
+struct derived : public base {
+ int member;
+ virtual void method (char)
+ {
+ }
+ virtual void method (char *)
+ {
+ proper_method_called++;
+ }
+};
+
+char *message;
+
+int main ()
+{
+ derived derived_object;
+
+ derived_object.method (message);
+
+ if (proper_method_called != 1)
+ printf ("FAIL\n");
+ else
+ printf ("PASS\n");
+}