summaryrefslogtreecommitdiff
path: root/gcc_arm/testsuite/g++.old-deja/g++.jason/overload13.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++.jason/overload13.C
parent27176890c4a688ea7de44d3f55af32827016a9fd (diff)
add old compiler with ARM support
Diffstat (limited to 'gcc_arm/testsuite/g++.old-deja/g++.jason/overload13.C')
-rwxr-xr-xgcc_arm/testsuite/g++.old-deja/g++.jason/overload13.C27
1 files changed, 27 insertions, 0 deletions
diff --git a/gcc_arm/testsuite/g++.old-deja/g++.jason/overload13.C b/gcc_arm/testsuite/g++.old-deja/g++.jason/overload13.C
new file mode 100755
index 0000000..6b5ca0f
--- /dev/null
+++ b/gcc_arm/testsuite/g++.old-deja/g++.jason/overload13.C
@@ -0,0 +1,27 @@
+// Bug: g++ screws up derived->base conversions when calling a global function
+// in the presence of matching members in the base. Whew.
+
+struct xios {
+ virtual ~xios() { }
+};
+
+struct xistream: virtual public xios {
+ int j;
+ void operator>>(char&);
+};
+
+struct xfstreambase: virtual public xios { };
+
+struct xifstream: public xfstreambase, public xistream { };
+
+void operator>>(xistream& i, int j)
+{
+ i.j = 0;
+}
+
+int main() {
+ int i;
+ xifstream ifs;
+
+ ifs >> i;
+}