Mercurial > hg > CbC > CbC_gcc
view gcc/testsuite/g++.dg/gomp/loop-4.C @ 145:1830386684a0
gcc-9.2.0
author | anatofuz |
---|---|
date | Thu, 13 Feb 2020 11:34:05 +0900 |
parents | |
children |
line wrap: on
line source
typedef __PTRDIFF_TYPE__ ptrdiff_t; template <typename T> class I { public: typedef ptrdiff_t difference_type; I (); ~I (); I (T *); I (const I &); T &operator * (); T *operator -> (); T &operator [] (const difference_type &) const; I &operator = (const I &); I &operator ++ (); I operator ++ (int); I &operator -- (); I operator -- (int); I &operator += (const difference_type &); I &operator -= (const difference_type &); I operator + (const difference_type &) const; I operator - (const difference_type &) const; template <typename S> friend bool operator == (I<S> &, I<S> &); template <typename S> friend bool operator == (const I<S> &, const I<S> &); template <typename S> friend bool operator < (I<S> &, I<S> &); template <typename S> friend bool operator < (const I<S> &, const I<S> &); template <typename S> friend bool operator <= (I<S> &, I<S> &); template <typename S> friend bool operator <= (const I<S> &, const I<S> &); template <typename S> friend bool operator > (I<S> &, I<S> &); template <typename S> friend bool operator > (const I<S> &, const I<S> &); template <typename S> friend bool operator >= (I<S> &, I<S> &); template <typename S> friend bool operator >= (const I<S> &, const I<S> &); template <typename S> friend typename I<S>::difference_type operator - (I<S> &, I<S> &); template <typename S> friend typename I<S>::difference_type operator - (const I<S> &, const I<S> &); template <typename S> friend I<S> operator + (typename I<S>::difference_type , const I<S> &); private: T *p; }; template <typename T> bool operator == (I<T> &, I<T> &); template <typename T> bool operator == (const I<T> &, const I<T> &); template <typename T> bool operator != (I<T> &, I<T> &); template <typename T> bool operator != (const I<T> &, const I<T> &); template <typename T> bool operator < (I<T> &, I<T> &); template <typename T> bool operator < (const I<T> &, const I<T> &); template <typename T> bool operator <= (I<T> &, I<T> &); template <typename T> bool operator <= (const I<T> &, const I<T> &); template <typename T> bool operator > (I<T> &, I<T> &); template <typename T> bool operator > (const I<T> &, const I<T> &); template <typename T> bool operator >= (I<T> &, I<T> &); template <typename T> bool operator >= (const I<T> &, const I<T> &); template <typename T> typename I<T>::difference_type operator - (I<T> &, I<T> &); template <typename T> typename I<T>::difference_type operator - (const I<T> &, const I<T> &); template <typename T> I<T> operator + (typename I<T>::difference_type, const I<T> &); ptrdiff_t foo (I<int> &); I<int> &bar (I<int> &); I<int> &baz (I<int> *); void f0 () { int i; const int j = 1; const int k = -1; const int m = 2; const int n = -7; int o = 1; int p = -1; #pragma omp for for (i = 0; i != 64; i += j) ; #pragma omp for for (i = 64; i != 0; i -= j) ; #pragma omp for for (i = 0; i != 64; i -= k) ; #pragma omp for for (i = 64; i != 0; i += k) ; #pragma omp for for (i = 0; i != 64; i += m) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = 64; i != 0; i -= m) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = 0; i != 64; i -= n) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = 64; i != 0; i += n) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = 0; i != 64; i += o) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = 64; i != 0; i -= o) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = 0; i != 64; i -= p) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = 64; i != 0; i += p) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; } void f1 (I<int> &x, I<int> &y, I<int> &u, I<int> &v) { I<int> i, j; const int k = 1; const int l = -1; const int m = 2; const int n = -7; int o = 1; int p = -1; #pragma omp for for (i = x; i != y; i++) ; #pragma omp for for (i = x; y != i; ++i) ; #pragma omp for for (i = x; i != y; i = i + 1) ; #pragma omp for for (i = x; i != y; i = 1 + i) ; #pragma omp for for (i = y; i != x; i--) ; #pragma omp for for (i = y; x != i; --i) ; #pragma omp for for (i = y; i != x; i = i - 1) ; #pragma omp for for (i = y; i != x; i = -1 + i) ; #pragma omp for for (i = x; i != y; i = i + k) ; #pragma omp for for (i = x; i != y; i = k + i) ; #pragma omp for for (i = y; i != x; i = i - k) ; #pragma omp for for (i = y; i != x; i = -k + i) ; #pragma omp for for (i = x; i != y; i = i - l) ; #pragma omp for for (i = x; i != y; i = -l + i) ; #pragma omp for for (i = y; i != x; i = i + l) ; #pragma omp for for (i = y; i != x; i = l + i) ; #pragma omp for for (i = x; i != y; i = i + 2) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = x; i != y; i = 7 + i) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = y; i != x; i = i - 2) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = y; i != x; i = -7 + i) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = x; i != y; i = i + m) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = x; i != y; i = m + i) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = y; i != x; i = i - m) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = y; i != x; i = -m + i) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = x; i != y; i = i - n) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = x; i != y; i = -n + i) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = y; i != x; i = i + n) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = y; i != x; i = n + i) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = x; i != y; i = i + o) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = x; i != y; i = o + i) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = y; i != x; i = i - o) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = y; i != x; i = -o + i) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = x; i != y; i = i - p) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = x; i != y; i = -p + i) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = y; i != x; i = i + p) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; #pragma omp for for (i = y; i != x; i = p + i) // { dg-error "increment is not constant 1 or -1 for '!=' condition" } ; }