From 994de9dd7102d8514765062a56ac6646fbf29e83 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Martin=20v=2E=20L=C3=B6wis?= Date: Sun, 28 Feb 1999 09:07:01 +0000 Subject: [PATCH] New test cases. From-SVN: r25498 --- .../g++.old-deja/g++.martin/sts_conv.C | 24 ++++++++++ .../g++.old-deja/g++.martin/sts_iarr.C | 45 +++++++++++++++++++ .../g++.old-deja/g++.martin/sts_partial.C | 15 +++++++ .../g++.old-deja/g++.martin/sts_vectini.C | 41 +++++++++++++++++ 4 files changed, 125 insertions(+) create mode 100644 gcc/testsuite/g++.old-deja/g++.martin/sts_conv.C create mode 100644 gcc/testsuite/g++.old-deja/g++.martin/sts_iarr.C create mode 100644 gcc/testsuite/g++.old-deja/g++.martin/sts_partial.C create mode 100644 gcc/testsuite/g++.old-deja/g++.martin/sts_vectini.C diff --git a/gcc/testsuite/g++.old-deja/g++.martin/sts_conv.C b/gcc/testsuite/g++.old-deja/g++.martin/sts_conv.C new file mode 100644 index 00000000000..4a3a436fe79 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.martin/sts_conv.C @@ -0,0 +1,24 @@ +// ecgs-bugs 1999-02-22 14:21, Stefan Schwarzer +// sts@ica1.uni-stuttgart.de +// this code should compile quietly + +class CArray +{ +public: + operator double* (){ return a; } + // works if we comment this line: + operator double* () const { return const_cast(a); } +private: + double a[2]; +}; + +int main(){ + CArray a; + double *pa = a + 1; // gets bogus error - should convert + return 0; +} + + + + + diff --git a/gcc/testsuite/g++.old-deja/g++.martin/sts_iarr.C b/gcc/testsuite/g++.old-deja/g++.martin/sts_iarr.C new file mode 100644 index 00000000000..c05fb16034e --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.martin/sts_iarr.C @@ -0,0 +1,45 @@ +// egcs-bugs 999-02-22 14:26 Stefan Schwarzer +// sts@ica1.uni-stuttgart.de +// should compile and return 0 + +template +struct Outer{ + struct Inner{ + Inner(int n): sum(n){} + + typename Outer::Inner operator[](int n) const + { return Outer::Inner(sum + n); } + + int sum; + }; + + typename Outer::Inner operator[](int n) const + { return Outer::Inner(n); } +}; + + +// specializations for N==1 +template<> +struct Outer<1> { + struct Inner { + Inner(int n): sum(n){} + + int operator[](int n) const + { return sum+n; } + + int sum; + }; + + int operator[](int n) const + { return n; } +}; + + +int main() +{ + Outer<1> sum1; + //std::cout << sum1[1] << "\n"; + Outer<2> sum2; + //std::cout << sum2[1][1] << "\n"; + return sum1[1] + sum2[1][1] - 3; +} diff --git a/gcc/testsuite/g++.old-deja/g++.martin/sts_partial.C b/gcc/testsuite/g++.old-deja/g++.martin/sts_partial.C new file mode 100644 index 00000000000..c2dc9411b54 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.martin/sts_partial.C @@ -0,0 +1,15 @@ +// excess errors test - XFAIL +// ecgs-bugs 1999-02-22 14:26 Stefan Schwarzer +// sts@ica1.uni-stuttgart.de +// partial ordering problem in egcs <= 1.1.1 + +template +int f(T &){ return 1; } + +template +int f( T[] ){ return 0; } + +int main(){ + int d[] ={2}; + return f(d); +} diff --git a/gcc/testsuite/g++.old-deja/g++.martin/sts_vectini.C b/gcc/testsuite/g++.old-deja/g++.martin/sts_vectini.C new file mode 100644 index 00000000000..56f7a1c6a5e --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.martin/sts_vectini.C @@ -0,0 +1,41 @@ +// Special g++ Options: -O2 +// egcs-bugs 1999-02-22 14:24 Stefan Schwarzer +// sts@ica1.uni-stuttgart.de +// optimizer problem in egcs <= 1.1.1 + +struct XTVec{ + XTVec(){x[0]=x[1] =x[2] =0;} + XTVec(int ax,int y=0.,int z=0.){x[0]=ax;x[1]=y; x[2]=z; } + int& operator[](int); + + int x[3]; +}; + +inline +int & XTVec::operator[](int i){ + return x[i]; +} + +inline +XTVec& operator+=(XTVec& lhs, XTVec& rhs){ + lhs[0]+=rhs[0]; + lhs[1]+=rhs[1]; + lhs[2]+=rhs[2]; + return lhs; +} + +inline +XTVec operator+(XTVec& lhs, XTVec& rhs){ + XTVec result(lhs); + return result += rhs; +} + +int main() +{ + XTVec ur(4.,0.,1.); + XTVec ll(0.,2.,0.); + XTVec initsum(ur + ll); + + // sum of components should be 7 + return (initsum[0] + initsum[1] + initsum[2] - 7); +} -- 2.30.2