| 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
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
 | '\" te
.\"  Copyright 1989 AT&T  Copyright (c) 1997, Sun Microsystems, Inc.  All Rights Reserved
.\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License").  You may not use this file except in compliance with the License.
.\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing.  See the License for the specific language governing permissions and limitations under the License.
.\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE.  If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
.TH NEWFORM 1 "Jul 21, 1997"
.SH NAME
newform \- change the format of a text file
.SH SYNOPSIS
.LP
.nf
\fBnewform\fR [\fB-s\fR] [\fB-i\fR\fItabspec\fR] [\fB-o\fR\fItabspec\fR] [\fB-b\fR\fIn\fR] [\fB-e\fR\fIn\fR] [\fB-p\fR\fIn\fR]
     [\fB-a\fR\fIn\fR] [\fB-f\fR] [\fB-c\fR\fIchar\fR] [\fB-l\fR\fIn\fR] [\fIfilename\fR]...
.fi
.SH DESCRIPTION
.sp
.LP
\fBnewform\fR reads lines from the named \fIfilename\fRs, or the standard input
if no input file is named, and reproduces the lines on the standard output.
Lines are reformatted in accordance with command line options in effect.
.sp
.LP
Except for \fB-s\fR, command line options may appear in any order, may be
repeated, and may be intermingled with the optional \fIfilename\fRs. Command
line options are processed in the order specified. This means that option
sequences like ``\fB-e\fR15 \fB-l\fR60'' will yield results different from
``\fB-l\fR60 \fB-e\fR15''. Options are applied to all \fIfilename\fRs on the
command line.
.SH OPTIONS
.sp
.LP
The following options are supported:
.sp
.ne 2
.na
\fB\fB-s\fR \fR
.ad
.RS 14n
Shears off leading characters on each line up to the first tab and places up to
8 of the sheared characters at the end of the line. If more than 8 characters
(not counting the first tab) are sheared, the eighth character is replaced by a
\fB*\fR and any characters to the right of it are discarded. The first tab is
always discarded.
.sp
An error message and program exit will occur if this option is used on a file
without a tab on each line. The characters sheared off are saved internally
until all other options specified are applied to that line. The characters are
then added at the end of the processed line.
.sp
For example, to convert a file with leading digits, one or more tabs, and text
on each line, to a file beginning with the text, all tabs after the first
expanded to spaces, padded with spaces out to column 72 (or truncated to column
72), and the leading digits placed starting at column 73, the command would be:
.sp
\fBnewform \|\fR\fB-s\fR\fB \|\fR\fB-i\fR\fB \|\fR\fB-l\fR\fB \|\fR\fB-a\fR\fB
\|\fR\fB-e\fR\fB \|\fIfilename\fR\fR
.RE
.sp
.ne 2
.na
\fB\fB-i\fR\fItabspec\fR \fR
.ad
.RS 14n
Input tab specification: expands tabs to spaces, according to the tab
specifications given. \fITabspec\fR recognizes all tab specification forms
described in \fBtabs\fR(1). In addition, \fItabspec\fR may be \fB-\fR, in which
\fBnewform\fR assumes that the tab specification is to be found in the first
line read from the standard input (see \fBfspec\fR(4)). If no \fItabspec\fR is
given, \fItabspec\fR defaults to \fB\(mi8\fR\&. A \fItabspec\fR of \fB\(mi0\fR
expects no tabs; if any are found, they are treated as \fB\(mi1\fR\&.
.RE
.sp
.ne 2
.na
\fB\fB-o\fR\fItabspec\fR \fR
.ad
.RS 14n
Output tab specification: replaces spaces by tabs, according to the tab
specifications given. The tab specifications are the same as for
\fB-i\fR\fItabspec\fR. If no \fItabspec\fR is given, \fItabspec\fR defaults to
\fB\(mi8\fR\&. A \fItabspec\fR of \fB\(mi0\fR means that no spaces will be
converted to tabs on output.
.RE
.sp
.ne 2
.na
\fB\fB-b\fR\fIn\fR \fR
.ad
.RS 14n
Truncate \fIn\fR characters from the beginning of the line when the line length
is greater than the effective line length (see \fB\(mil\fIn\fR\fR). Default is
to truncate the number of characters necessary to obtain the effective line
length. The default value is used when \fB-b\fR with no \fIn\fR is used. This
option can be used to delete the sequence numbers from a \fBCOBOL\fR program as
follows:
.sp
\fBnewform \|\fR\fB-l\fR\fB1 \|\fR\fB-b\fR\fB7 \|\fIfilename\fR\fR
.RE
.sp
.ne 2
.na
\fB\fB-e\fR\fIn\fR\fR
.ad
.RS 14n
Same as \fB-b\fR\fIn\fR except that characters are truncated from the end of
the line.
.RE
.sp
.ne 2
.na
\fB\fB-p\fR\fIn\fR\fR
.ad
.RS 14n
Prefix \fIn\fR characters (see \fB-c\fR\fIchar\fR) to the beginning of a line
when the line length is less than the effective line length. Default is to
prefix the number of characters necessary to obtain the effective line length.
.RE
.sp
.ne 2
.na
\fB\fB-a\fR\fIn\fR\fR
.ad
.RS 14n
Same as \fB-p\fR\fIn\fR except characters are appended to the end of a line.
.RE
.sp
.ne 2
.na
\fB\fB-f\fR\fR
.ad
.RS 14n
Write the tab specification format line on the standard output before any other
lines are output. The tab specification format line which is printed will
correspond to the format specified in the \fBlast\fR \fB-o\fR option. If no
\fB-o\fR option is specified, the line which is printed will contain the
default specification of \fB\(mi8\fR\&.
.RE
.sp
.ne 2
.na
\fB\fB-c\fR\fIchar\fR\fR
.ad
.RS 14n
Change the prefix/append character to \fIchar\fR. Default character for
\fIchar\fR is a space.
.RE
.sp
.ne 2
.na
\fB\fB-l\fR\fIn\fR\fR
.ad
.RS 14n
Set the effective line length to \fIn\fR characters. If \fIn\fR is not entered,
\fB-l\fR defaults to 72. The default line length without the \fB-l\fR option is
80 characters. Note:  Tabs and backspaces are considered to be one character
(use \fB-i\fR to expand tabs to spaces).
.sp
The \fB\(mil1\fR must be used to set the effective line length shorter than any
existing line in the file so that the \fB-b\fR option is activated.
.RE
.SH OPERANDS
.sp
.LP
The following operand is supported:
.sp
.ne 2
.na
\fB\fIfilename\fR \fR
.ad
.RS 13n
Input file
.RE
.SH EXIT STATUS
.sp
.LP
The following exit values are returned:
.sp
.ne 2
.na
\fB\fB0\fR \fR
.ad
.RS 6n
Successful operation.
.RE
.sp
.ne 2
.na
\fB\fB1\fR \fR
.ad
.RS 6n
Operation failed.
.RE
.SH SEE ALSO
.sp
.LP
\fBcsplit\fR(1), \fBtabs\fR(1), \fBfspec\fR(4), \fBattributes\fR(5)
.SH DIAGNOSTICS
.sp
.LP
All diagnostics are fatal.
.sp
.ne 2
.na
\fB\fBusage:\fR \fB \|.\|.\|.\fR \fR
.ad
.sp .6
.RS 4n
\fBnewform\fR was called with a bad option.
.RE
.sp
.ne 2
.na
\fB\fB"not \fR\fB-s\fR\fB format"\fR\fR
.ad
.sp .6
.RS 4n
There was no tab on one line.
.RE
.sp
.ne 2
.na
\fB\fB"can't open file"\fR\fR
.ad
.sp .6
.RS 4n
Self-explanatory.
.RE
.sp
.ne 2
.na
\fB\fB"internal line too long"\fR\fR
.ad
.sp .6
.RS 4n
A line exceeds 512 characters after being expanded in the internal work buffer.
.RE
.sp
.ne 2
.na
\fB\fB"tabspec in error" \fR\fR
.ad
.sp .6
.RS 4n
A tab specification is incorrectly formatted, or specified tab stops are not
ascending.
.RE
.sp
.ne 2
.na
\fB\fB"tabspec indirection illegal" \fR\fR
.ad
.sp .6
.RS 4n
A \fItabspec\fR read from a file (or standard input) may not contain a
\fItabspec\fR referencing another file (or standard input).
.RE
.SH NOTES
.sp
.LP
\fBnewform\fR normally only keeps track of physical characters; however, for
the \fB-i\fR and \fB-o\fR options, \fBnewform\fR will keep track of backspaces
in order to line up tabs in the appropriate logical columns.
.sp
.LP
\fBnewform\fR will not prompt the user if a \fItabspec\fR is to be read from
the standard input (by use of \fB\fR\fB-i\fR\fB-\fR or \fB\fR\fB-o\fR\fB-\fR).
.sp
.LP
If the \fB-f\fR option is used, and the last \fB-o\fR option specified was
\fB\fR\fB-o\fR\fB-\fR, and was preceded by either a \fB\fR\fB-o\fR\fB-\fR or a
\fB\fR\fB-i\fR\fB-\fR, the tab specification format line will be incorrect.
 |