xref: /llvm-project/flang/test/Evaluate/fold-merge.f90 (revision 8926f0fe62a55fc0de7d6839700513328bc0e13f)
1! RUN: %python %S/test_folding.py %s %flang_fc1
2! Tests folding of MERGE
3module m
4  type t
5    integer n
6  end type
7  logical, parameter :: test_01 = all(merge([1,2,3],4,[.true.,.false.,.true.]) == [1,4,3])
8  logical, parameter :: test_02 = all(merge([1,2,3],4,.true.) == [1,2,3])
9  logical, parameter :: test_03 = all(merge([1,2,3],4,.false.) == [4,4,4])
10  logical, parameter :: test_04 = all(merge(1,4,[.true.,.false.,.true.,.false.]) == [1,4,1,4])
11  type(t), parameter :: dt00a = merge(t(1),t(2),.true.)
12  logical, parameter :: test_05 = dt00a%n == 1
13  type(t), parameter :: dt00b = merge(t(1),t(2),.false.)
14  logical, parameter :: test_06 = dt00b%n == 2
15  type(t), parameter :: dt01(*) = merge([t(1),t(2)],[t(3),t(4)],[.false.,.true.])
16  logical, parameter :: test_07 = all(dt01%n == [3,2])
17  type(t), parameter :: dt02(*) = merge(t(1),[t(3),t(4)],.true.)
18  logical, parameter :: test_08 = all(dt02%n == [1,1])
19  type(t), parameter :: dt03(*) = merge([t(1),t(2)],t(3),[.true.,.false.])
20  logical, parameter :: test_09 = all(dt03%n == [1,3])
21  logical, parameter :: test_10 = merge('ab','cd',.true.) == 'ab'
22end
23