3 # ccformat - convert C code to standard format
5 # @(#) ccformat.sh 1.3 11/5/89 14:39:29
7 # how to supress newlines in echo
20 FLAGS
="-st -di8 -npsl -bap -bad -bbb -nbc -i4 -d0 -nip -nfc1 -cd41 -c49"
22 trap 'rm -f .ind.$$ $TMPF; exit 1' 1 2 3 15
24 # parse command options
31 1) ERROR
="-b option requires backup argument"; break;;
35 1) ERROR
="-T option requires typename argument"; break;;
36 *) FLAGS
="$FLAGS -T$2"; shift;;
38 -*) ERROR
="invalid option: $1"; break;;
44 # check for invalid commands
47 echo "$0: $ERROR" 1>&2
48 echo "usage: $0 [-b backup] [-t] [-T typename] [file(s)]" 1>&2
54 0) indent
$TROFF $FLAGS;;
58 indent
$TROFF $FLAGS $i
63 test -z "$BCK" ||
cp $i $i"$BCK" ||
{ echo backup FAILED
; exit 1; }
64 { # some versions of indent return garbage exit status -- gack!
65 (indent
$FLAGS <$i 2>.ind.$$
>$TMPF ||
test ! -s .ind.$$
) >$TMPF &&
66 # try a device full check
68 # ignore interrupts while we overwrite the original file
69 trap '' 1 2 3 15; cp $TMPF $i
70 ) && echo replaced
; } ||
{ echo replacement FAILED
; exit 1; }
83 # convert C source text to standard format
87 # ccformat [-b backup] [-t] [-T typename] [file(s)]
89 # The \fIccformat\fR command adjusts the layout of C program text
90 # such that it approximates the Kernighan and Ritchie coding style.
92 # If no file names are specified, \fIccformat\fR reads
93 # from standard input and writes the result to standard output.
94 # This is convenient for source formatting from within a text
97 # Otherwise, the named files are overwritten with their
98 # formatted equivalent. The \fI-b\fR option (see below) provides
99 # a way to create backup copies of the original files.
101 # Alternatively, the command can be used as a preprocessor for
102 # pretty-printing with the \fInroff\fR or \fItroff\fR commands
103 # (see the -t option below). In this case, output is always written
104 # to standard output and no change is made to source files.
106 # The following options are recognized:
109 # Requests that a copy of the original files be saved. The backup
110 # file name is constructed by appending the specified \fIbackup\fR
111 # string to the original file name.
112 # This option is ignored when the \fI-t\fR
113 # option is specifid.
116 # Makes the program act as a preprocessor
117 # for pretty-printing with \fInroff\fR or \fItroff\fR.
118 # For example, in order to produce a pretty-printed
119 # version on the line printer, use
121 ccformat
-t file(s
) | nroff
-mindent |
col |
lp
124 # Adds \fItypename\fR to the list of type keywords.
125 # Names accumulate: -T can be specified more
126 # than once. You need to specify all the
127 # typenames that appear in your program that
128 # are defined by typedefs - nothing will be
129 # harmed if you miss a few, but the program
130 # won't be formatted as nicely as it should.
134 # The following program layout is produced:
137 # Comments starting in the first column are left untouched.
138 # These are often carefully laid out by the programmer.
140 # Comments that appear in-between statements are lined up with
141 # the surrounding program text, and are adjusted to accomodate
142 # as many words on a line as possible.
143 # However, a blank line in the middle of a comment is respected.
145 # Trailing comments after declarations begin at column 41
147 # Trailing comments after executable statements start at
148 # column 49 (6 tab stops).
151 # Statements are indented by multiples of four columns.
152 # There is only one statement per line. A control statement
153 # is always placed on a separate line.
156 # If an opening brace is preceded by a control statement (\fCif,
157 # else, do, for\fR or \fCswitch\fR), it is placed on the same line
158 # as the control statement.
160 # A closing brace is placed at the same level of indentation as the
161 # program text that precedes the corresponding opening brace.
162 # If a closing brace is followed by a control statement (\fCelse\fR
163 # or \fCwhile\fR), that control statement is placed on the same line
164 # as the closing brace.
166 # In practice, brace placement is as
167 # exemplified by the books on C by B.W. Kernighan and D.M. Ritchie.
170 # Blanks are placed around assignment and arithmetic operators.
171 # Commas in declarations or parameter lists are followed by one blank.
173 # In the following cases a
174 # blank line is inserted if it is not already present in the text:
175 # 1) in front of a block comment, 2) between local declarations and
176 # executable statements 3) after each function body.
179 # In the output, each variable declaration appears on
184 # /tmp/ccformat.* intermediate files
188 # Indent may complain in case of syntax errors. These show
189 # up as comments in the resulting program text.
191 # The programs seems to beave even when fed ANSI C or even C++
192 # code; this has not been tested thoroughly, however.
194 # Will produce useless files when fed with anything that is
195 # not C program text. This does not imply a judgment about
196 # C programs in general.
199 # Eindhoven University of Technology
200 # Department of Mathematics and Computer Science
201 # Den Dolech 2, P.O. Box 513, 5600 MB Eindhoven, The Netherlands
203 # Fri May 6 14:07:04 MET DST 1988
205 # ccformat.sh 1.3 11/5/89 14:39:29 (draft)