| ! 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 |