]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - usr.bin/seq/seq.1
sysctl(9): Fix a few mandoc related issues
[FreeBSD/FreeBSD.git] / usr.bin / seq / seq.1
1 .\"     $NetBSD: seq.1,v 1.8 2013/04/07 17:37:45 jdf Exp $
2 .\"
3 .\" Copyright (c) 2005 The NetBSD Foundation, Inc.
4 .\" All rights reserved.
5 .\"
6 .\" This code is derived from software contributed to The NetBSD Foundation
7 .\" by Brian Ginsbach.
8 .\"
9 .\" Redistribution and use in source and binary forms, with or without
10 .\" modification, are permitted provided that the following conditions
11 .\" are met:
12 .\" 1. Redistributions of source code must retain the above copyright
13 .\"    notice, this list of conditions and the following disclaimer.
14 .\" 2. Redistributions in binary form must reproduce the above copyright
15 .\"    notice, this list of conditions and the following disclaimer in the
16 .\"    documentation and/or other materials provided with the distribution.
17 .\"
18 .\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
19 .\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
20 .\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21 .\" PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
22 .\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23 .\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24 .\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 .\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26 .\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27 .\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28 .\" POSSIBILITY OF SUCH DAMAGE.
29 .\"
30 .\" $FreeBSD$
31 .\"
32 .Dd June 20, 2020
33 .Dt SEQ 1
34 .Os
35 .Sh NAME
36 .Nm seq
37 .Nd print sequences of numbers
38 .Sh SYNOPSIS
39 .Nm
40 .Op Fl w
41 .Op Fl f Ar format
42 .Op Fl s Ar string
43 .Op Fl t Ar string
44 .Op Ar first Op Ar incr
45 .Ar last
46 .Sh DESCRIPTION
47 The
48 .Nm
49 utility prints a sequence of numbers, one per line
50 .Pq default ,
51 from
52 .Ar first
53 .Pq default 1 ,
54 to near
55 .Ar last
56 as possible, in increments of
57 .Ar incr
58 .Pq default 1 .
59 When
60 .Ar first
61 is larger than
62 .Ar last ,
63 the default
64 .Ar incr
65 is -1.
66 .Pp
67 All numbers are interpreted as floating point.
68 .Pp
69 Normally integer values are printed as decimal integers.
70 .Pp
71 The
72 .Nm
73 utility accepts the following options:
74 .Bl -tag -width Ar
75 .It Fl f Ar format , Fl -format Ar format
76 Use a
77 .Xr printf 3
78 style
79 .Ar format
80 to print each number.
81 Only the
82 .Cm A ,
83 .Cm a ,
84 .Cm E ,
85 .Cm e ,
86 .Cm F ,
87 .Cm f ,
88 .Cm G ,
89 .Cm g ,
90 and
91 .Cm %
92 conversion characters are valid, along with any optional
93 flags and an optional numeric minimum field width or precision.
94 The
95 .Ar format
96 can contain character escape sequences in backslash notation as
97 defined in
98 .St -ansiC .
99 The default is
100 .Cm %g .
101 .It Fl s Ar string , Fl -separator Ar string
102 Use
103 .Ar string
104 to separate numbers.
105 The
106 .Ar string
107 can contain character escape sequences in backslash notation as
108 defined in
109 .St -ansiC .
110 The default is
111 .Cm \en .
112 .It Fl t Ar string , Fl -terminator Ar string
113 Use
114 .Ar string
115 to terminate sequence of numbers.
116 The
117 .Ar string
118 can contain character escape sequences in backslash notation as
119 defined in
120 .St -ansiC .
121 This option is useful when the default separator
122 does not contain a
123 .Cm \en .
124 .It Fl w , Fl -fixed-width
125 Equalize the widths of all numbers by padding with zeros as necessary.
126 This option has no effect with the
127 .Fl f
128 option.
129 If any sequence numbers will be printed in exponential notation,
130 the default conversion is changed to
131 .Cm %e .
132 .El
133 .Sh EXIT STATUS
134 .Ex -std
135 .Sh EXAMPLES
136 Generate a sequence from 1 to 3 (included) with a default increment of 1:
137 .Bd -literal -offset indent
138 # seq 1 3
139 1
140 2
141 3
142 .Ed
143 .Pp
144 Generate a sequence from 3 to 1 (included) with a default increment of -1:
145 .Bd -literal -offset indent
146 # seq 3 1
147 3
148 2
149 1
150 .Ed
151 .Pp
152 Generate a sequence from 0 to 0.1 (included) with an increment of 0.05 and padding
153 with leading zeroes.
154 .Bd -literal -offset indent
155 # seq -w 0 .05 .1
156 0.00
157 0.05
158 0.10
159 .Ed
160 .Pp
161 Generate a sequence from 1 to 3 (included) with a default increment of 1,
162 a custom separator string and a custom terminator:
163 .Bd -literal -offset indent
164 # seq -s "-->" -t "[end of list]\\n" 1 3
165 1-->2-->3-->[end of list]
166 .Ed
167 .Pp
168 Generate a sequence from 1 to 2 (included) with an increment of 0.2 and
169 print the results with two digits after the decimal point (using a
170 .Xr printf 3
171 style format):
172 .Bd -literal -offset indent
173 # seq -f %.2f 1 0.2 2
174 1.00
175 1.20
176 1.40
177 1.60
178 1.80
179 2.00
180 .Ed
181 .Sh SEE ALSO
182 .Xr jot 1 ,
183 .Xr printf 1 ,
184 .Xr printf 3
185 .Sh HISTORY
186 The
187 .Nm
188 command first appeared in Version\~8
189 .At .
190 A
191 .Nm
192 command appeared in
193 .Nx 3.0 ,
194 and was ported to
195 .Fx 9.0 .
196 This command was based on the command of the same name in
197 Plan 9 from Bell Labs and the GNU core utilities.
198 The GNU
199 .Nm
200 command first appeared in the 1.13 shell utilities release.
201 .Sh BUGS
202 The
203 .Fl w
204 option does not handle the transition from pure floating point
205 to exponent representation very well.
206 The
207 .Nm
208 command is not bug for bug compatible with other implementations.