summaryrefslogtreecommitdiff
path: root/gcc_arm/testsuite/g++.old-deja/g++.jason/optimize.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/optimize.C
parent27176890c4a688ea7de44d3f55af32827016a9fd (diff)
add old compiler with ARM support
Diffstat (limited to 'gcc_arm/testsuite/g++.old-deja/g++.jason/optimize.C')
-rwxr-xr-xgcc_arm/testsuite/g++.old-deja/g++.jason/optimize.C42
1 files changed, 42 insertions, 0 deletions
diff --git a/gcc_arm/testsuite/g++.old-deja/g++.jason/optimize.C b/gcc_arm/testsuite/g++.old-deja/g++.jason/optimize.C
new file mode 100755
index 0000000..1f554e2
--- /dev/null
+++ b/gcc_arm/testsuite/g++.old-deja/g++.jason/optimize.C
@@ -0,0 +1,42 @@
+// Bug: g++ claims that control can fall off the end of these functions.
+// PRMS Id: 4943
+// Special g++ Options: -O -pedantic-errors
+// Build don't link:
+
+struct A {
+ A();
+ A(const A&);
+ A& operator= (const A&);
+ ~A();
+};
+
+int f ()
+{
+ A a[2];
+ return 1;
+} // gets bogus error - jump_optimize
+
+int g ()
+{
+ A a;
+ return 1;
+} // gets bogus error - jump_optimize
+
+struct B {
+ B();
+ B(const B&);
+ B& operator= (const B&);
+ ~B();
+};
+
+inline B::~B()
+{
+ int i = 2;
+ while (i--) ;
+}
+
+int h ()
+{
+ B b;
+ return 1;
+} // gets bogus error - jump_optimize