1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
# $Id: evalcall 2413 2010-09-11 17:43:04Z bird $ -*-perl-*-
## @file
# $(evalcall var,argN...)
#
#
# Copyright (c) 2008-2010 knut st. osmundsen <bird-kBuild-spamx@anduin.net>
#
# This file is part of kBuild.
#
# kBuild is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
#
# kBuild is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with kBuild. If not, see <http://www.gnu.org/licenses/>
#
#
$description = "Tests the $(evalcall ) function";
$details = "A few simple tests, nothing spectacular.";
if ($is_kmk) {
# TEST #0 - check that the feature is present.
# --------------------------------------------
run_make_test('
FUNC = local .RETURN = $2 $1
ifneq ($(evalcall FUNC,a,b),b a)
$(error sub-test 0 failed: $(evalcall FUNC,a,b))
endif
.PHONY: all
all: ; @:
',
'',
'');
# TEST #1 - the real test.
# ------------------------
run_make_test('
FUNC = local .RETURN = $2 $1
ifneq ($(evalcall FUNC,a,b),b a)
$(error sub-test 0 failed)
endif
ADD = local .RETURN = $(expr $1 + $2)
ifneq ($(evalcall ADD,1,2),3)
$(error sub-test 1 failed)
endif
define POP
local words := $(words $($1))
local .RETURN := $(word $(words), $($1))
$1 := $(wordlist 1, $(expr $(words) - 1), $($1))
endef
stack-var = a b c d
ifneq ($(evalcall POP,stack-var),d)
$(error sub-test 2d failed)
endif
ifneq ($(evalcall POP,stack-var),c)
$(error sub-test 2c failed)
endif
ifneq ($(evalcall POP,stack-var),b)
$(error sub-test 2b failed)
endif
ifneq ($(evalcall POP,stack-var),a)
$(error sub-test 2a failed)
endif
# Negative tests:
.RETURN = $2 $1
FUNC =
ifneq ($(evalcall FUNC,a,b),)
$(error sub-test 10 failed)
endif
.RETURN =
FUNC = .RETURN = $2 $1
ifneq ($(evalcall FUNC,a,b),)
$(error sub-test 11 failed)
endif
# Test .ARGC:
FUNC = local .RETURN = $(.ARGC)
ifneq ($(evalcall FUNC,a,b),2)
$(error sub-test 20 failed)
endif
ifneq ($(evalcall FUNC),0)
$(error sub-test 21 failed)
endif
ifneq ($(evalcall FUNC,aasdfasdf),1)
$(error sub-test 22 failed)
endif
.PHONY: all
all: ; @:
',
'',
'');
}
# Indicate that we're done.
1;
|