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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
|
.\" This module is believed to contain source code proprietary to AT&T.
.\" Use and redistribution is subject to the Berkeley Software License
.\" Agreement and your Software Agreement with AT&T (Western Electric).
.\"
.\" @(#)tt12 8.1 (Berkeley) 6/8/93
.\" Copyright (C) Caldera International Inc. 2001-2002. All rights reserved.
.\"
.\" Redistribution and use in source and binary forms, with or without
.\" modification, are permitted provided that the following conditions are
.\" met:
.\"
.\" Redistributions of source code and documentation must retain the above
.\" copyright notice, this list of conditions and the following
.\" disclaimer.
.\"
.\" Redistributions in binary form must reproduce the above copyright
.\" notice, this list of conditions and the following disclaimer in the
.\" documentation and/or other materials provided with the distribution.
.\"
.\" All advertising materials mentioning features or use of this software
.\" must display the following acknowledgement:
.\"
.\" This product includes software developed or owned by Caldera
.\" International, Inc. Neither the name of Caldera International, Inc.
.\" nor the names of other contributors may be used to endorse or promote
.\" products derived from this software without specific prior written
.\" permission.
.\"
.\" USE OF THE SOFTWARE PROVIDED FOR UNDER THIS LICENSE BY CALDERA
.\" INTERNATIONAL, INC. AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
.\" WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
.\" DISCLAIMED. IN NO EVENT SHALL CALDERA INTERNATIONAL, INC. BE LIABLE
.\" FOR ANY DIRECT, INDIRECT INCIDENTAL, SPECIAL, EXEMPLARY, OR
.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
.\" BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
.\" WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
.\" OR OTHERWISE) RISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
.\" IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
.\"
.\" $FreeBSD$
.\"
.NH
Conditionals
.PP
Suppose we want the
.BD .SH
macro to leave two extra inches of space just before section 1,
but nowhere else.
The cleanest way to do that is to test inside the
.BD .SH
macro
whether
the section number is 1,
and add some space if it is.
The
.BD .if
command provides the conditional test
that we can add
just before the heading line is output:
.P1 4
^if \e\en(SH=1 ^sp 2i \e" first section only
.P2
.PP
The condition after the
.BD .if
can be any arithmetic or logical expression.
If the condition is logically true, or arithmetically greater than zero,
the rest of the line is treated as if
it were text _
here a command.
If the condition is false, or zero or negative,
the rest of the line is skipped.
.PP
It is possible to do more than one command if a condition is true.
Suppose several operations are to be done before section 1.
One possibility is to define a macro
.BD .S1
and invoke it
if we are about to do section 1
(as determined by an
.BD .if ).
.P1
^de S1
--- processing for section 1 ---
^^
^de SH
^^^
^if \e\en(SH=1 ^S1
^^^
^^
.P2
.PP
An alternate way is to use the
extended form of the
.BD .if ,
like this:
.P1
^if \e\en(SH=1 \e{--- processing
for section 1 ----\e}
.P2
The braces
.BD \e{
and
.BD \e}
must occur in the positions shown
or you will get unexpected extra lines in your output.
.UL troff
also provides
an `if-else' construction,
which we will not go into here.
.PP
A condition can be negated by preceding it with
.BD ! ;
we get the same effect as above (but less clearly) by using
.P1
^if !\e\en(SH>1 ^S1
.P2
.PP
There are a handful of
other conditions that can be tested with
.BD .if .
For example, is the current page even or odd?
.P1
^if o ^tl 'odd page title''- % -'
^if e ^tl '- % -''even page title'
.P2
gives facing pages different titles and page numbers on the
outside edge when used inside an appropriate new page macro.
.PP
Two other conditions
are
.BD t
and
.BD n ,
which tell you whether the formatter is
.UL troff
or
.UL nroff .
.P1
^if t troff stuff ...
^if n nroff stuff ...
.P2
.PP
Finally, string comparisons may be made in an
.BD .if :
.P1
^if 'string1'string2' stuff
.P2
does `stuff' if
.ul
string1
is the same as
.ul
string2.
The character separating the strings can be anything
reasonable that is
not contained in either string.
The strings themselves can reference strings with
.BD \e* ,
arguments with
.BD \e$ ,
and so on.
|