llvm/flang/test/Evaluate/fold-merge.f90

! RUN: %python %S/test_folding.py %s %flang_fc1
! Tests folding of MERGE
module m
  type t
    integer n
  end type
  logical, parameter :: test_01 = all(merge([1,2,3],4,[.true.,.false.,.true.]) == [1,4,3])
  logical, parameter :: test_02 = all(merge([1,2,3],4,.true.) == [1,2,3])
  logical, parameter :: test_03 = all(merge([1,2,3],4,.false.) == [4,4,4])
  logical, parameter :: test_04 = all(merge(1,4,[.true.,.false.,.true.,.false.]) == [1,4,1,4])
  type(t), parameter :: dt00a = merge(t(1),t(2),.true.)
  logical, parameter :: test_05 = dt00a%n == 1
  type(t), parameter :: dt00b = merge(t(1),t(2),.false.)
  logical, parameter :: test_06 = dt00b%n == 2
  type(t), parameter :: dt01(*) = merge([t(1),t(2)],[t(3),t(4)],[.false.,.true.])
  logical, parameter :: test_07 = all(dt01%n == [3,2])
  type(t), parameter :: dt02(*) = merge(t(1),[t(3),t(4)],.true.)
  logical, parameter :: test_08 = all(dt02%n == [1,1])
  type(t), parameter :: dt03(*) = merge([t(1),t(2)],t(3),[.true.,.false.])
  logical, parameter :: test_09 = all(dt03%n == [1,3])
  logical, parameter :: test_10 = merge('ab','cd',.true.) == 'ab'
end