! 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