aboutsummaryrefslogtreecommitdiff
path: root/contrib/bmake/unit-tests/directive-else.mk
blob: cda6719072175a34d72f203e3904113c67579512 (plain) (blame)
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
# $NetBSD: directive-else.mk,v 1.9 2023/11/19 21:47:52 rillig Exp $
#
# Tests for the .else directive.
#
# Since 2020-11-13, an '.else' followed by extraneous text generates a parse
# error in -dL (lint) mode.
#
# Since 2020-12-15, an '.else' followed by extraneous text always generates
# a parse error.

.if 0
.  warning must not be reached
# expect+1: The .else directive does not take arguments
.else 123
# expect+1: ok
.  info ok
.endif

.if 1
# expect+1: ok
.  info ok
# expect+1: The .else directive does not take arguments
.else 123
.  warning must not be reached
.endif

# An .else without a corresponding .if is an error.
# expect+1: if-less else
.else

# Accidental extra .else directives are detected too.
.if 0
.  warning must not be reached
.else
# expect+1: ok
.  info ok
# expect+1: warning: extra else
.else
.  info After an extra .else, everything is skipped.
.endif

# An .else may have a comment.  This comment does not count as an argument,
# therefore no parse error.
.if 0
.else # comment
.endif

# An expression does count as an argument, even if it is empty.
.if 0
# expect+1: The .else directive does not take arguments
.else ${:U}
.endif

all:
	@:;