llvm/flang/test/Semantics/OpenMP/reduction14.f90

! RUN: %python %S/../test_errors.py %s %flang_fc1 -fopenmp
! OpenMP Version 4.5
! 2.15.3.6 Reduction Clause
program omp_reduction
  integer :: i
  real :: r
  character :: c
  complex :: z
  logical :: l

  ! * is allowed for integer, real, and complex
  ! but not for logical or character
  ! ERROR: The type of 'c' is incompatible with the reduction operator.
  ! ERROR: The type of 'l' is incompatible with the reduction operator.
  !$omp parallel reduction(*:i,r,c,z,l)
  !$omp end parallel

  ! + is allowed for integer, real, and complex
  ! but not for logical or character
  ! ERROR: The type of 'c' is incompatible with the reduction operator.
  ! ERROR: The type of 'l' is incompatible with the reduction operator.
  !$omp parallel reduction(+:i,r,c,z,l)
  !$omp end parallel

  ! - is deprecated for all types
  ! ERROR: The minus reduction operator is deprecated since OpenMP 5.2 and is not supported in the REDUCTION clause.
  !$omp parallel reduction(-:i,r,c,z,l)
  !$omp end parallel

  ! .and. is only supported for logical operations
  ! ERROR: The type of 'i' is incompatible with the reduction operator.
  ! ERROR: The type of 'r' is incompatible with the reduction operator.
  ! ERROR: The type of 'c' is incompatible with the reduction operator.
  ! ERROR: The type of 'z' is incompatible with the reduction operator.
  !$omp parallel reduction(.and.:i,r,c,z,l)
  !$omp end parallel

  ! .or. is only supported for logical operations
  ! ERROR: The type of 'i' is incompatible with the reduction operator.
  ! ERROR: The type of 'r' is incompatible with the reduction operator.
  ! ERROR: The type of 'c' is incompatible with the reduction operator.
  ! ERROR: The type of 'z' is incompatible with the reduction operator.
  !$omp parallel reduction(.or.:i,r,c,z,l)
  !$omp end parallel

  ! .eqv. is only supported for logical operations
  ! ERROR: The type of 'i' is incompatible with the reduction operator.
  ! ERROR: The type of 'r' is incompatible with the reduction operator.
  ! ERROR: The type of 'c' is incompatible with the reduction operator.
  ! ERROR: The type of 'z' is incompatible with the reduction operator.
  !$omp parallel reduction(.eqv.:i,r,c,z,l)
  !$omp end parallel

  ! .neqv. is only supported for logical operations
  ! ERROR: The type of 'i' is incompatible with the reduction operator.
  ! ERROR: The type of 'r' is incompatible with the reduction operator.
  ! ERROR: The type of 'c' is incompatible with the reduction operator.
  ! ERROR: The type of 'z' is incompatible with the reduction operator.
  !$omp parallel reduction(.neqv.:i,r,c,z,l)
  !$omp end parallel

  ! iand only supports integers
  ! ERROR: The type of 'r' is incompatible with the reduction operator.
  ! ERROR: The type of 'c' is incompatible with the reduction operator.
  ! ERROR: The type of 'z' is incompatible with the reduction operator.
  ! ERROR: The type of 'l' is incompatible with the reduction operator.
  !$omp parallel reduction(iand:i,r,c,z,l)
  !$omp end parallel

  ! ior only supports integers
  ! ERROR: The type of 'r' is incompatible with the reduction operator.
  ! ERROR: The type of 'c' is incompatible with the reduction operator.
  ! ERROR: The type of 'z' is incompatible with the reduction operator.
  ! ERROR: The type of 'l' is incompatible with the reduction operator.
  !$omp parallel reduction(ior:i,r,c,z,l)
  !$omp end parallel

  ! ieor only supports integers
  ! ERROR: The type of 'r' is incompatible with the reduction operator.
  ! ERROR: The type of 'c' is incompatible with the reduction operator.
  ! ERROR: The type of 'z' is incompatible with the reduction operator.
  ! ERROR: The type of 'l' is incompatible with the reduction operator.
  !$omp parallel reduction(ieor:i,r,c,z,l)
  !$omp end parallel

  ! max arguments may be integer, real, or character:
  ! ERROR: The type of 'z' is incompatible with the reduction operator.
  ! ERROR: The type of 'l' is incompatible with the reduction operator.
  !$omp parallel reduction(max:i,r,c,z,l)
  !$omp end parallel

  ! min arguments may be integer, real, or character:
  ! ERROR: The type of 'z' is incompatible with the reduction operator.
  ! ERROR: The type of 'l' is incompatible with the reduction operator.
  !$omp parallel reduction(min:i,r,c,z,l)
  !$omp end parallel
end program omp_reduction