1.\" Copyright (c) 1980, 1990, 1993 2.\" The Regents of the University of California. All rights reserved. 3.\" 4.\" Redistribution and use in source and binary forms, with or without 5.\" modification, are permitted provided that the following conditions 6.\" are met: 7.\" 1. Redistributions of source code must retain the above copyright 8.\" notice, this list of conditions and the following disclaimer. 9.\" 2. Redistributions in binary form must reproduce the above copyright 10.\" notice, this list of conditions and the following disclaimer in the 11.\" documentation and/or other materials provided with the distribution. 12.\" 3. All advertising materials mentioning features or use of this software 13.\" must display the following acknowledgement: 14.\" This product includes software developed by the University of 15.\" California, Berkeley and its contributors. 16.\" 4. Neither the name of the University nor the names of its contributors 17.\" may be used to endorse or promote products derived from this software 18.\" without specific prior written permission. 19.\" 20.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 21.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 24.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30.\" SUCH DAMAGE. 31.\" 32.\" @(#)vgrind.1 8.1 (Berkeley) 6/6/93 33.\" $FreeBSD$ 34.\" 35.Dd June 6, 1993 36.Dt VGRIND 1 37.Os BSD 4 38.Sh NAME 39.Nm vgrind 40.Nd grind nice listings of programs 41.Sh SYNOPSIS 42.Nm 43.Op Fl 44.Op Fl W 45.Op Fl d Ar file 46.Op Fl f 47.Op Fl h Ar header 48.Op Fl l Ns Ar language 49.Op Fl n 50.Op Fl p Ar postproc 51.Op Fl sn 52.Op Fl t 53.Op Fl x 54.Ar name Ar ... 55.Sh DESCRIPTION 56.Nm Vgrind 57formats the program sources which are arguments 58in a nice style using 59.Xr troff 1 60Comments are placed in italics, keywords in bold face, 61and the name of the current function is listed down the margin of each 62page as it is encountered. 63.Pp 64.Nm Vgrind 65runs in two basic modes, filter mode (see the 66.Fl f 67option) or regular mode. In filter mode 68.Nm 69acts as a filter in a manner similar to 70.Xr tbl 1 . 71The standard input is passed directly to the standard output except 72for lines bracketed by the 73.Em troff-like 74macros: 75.Bl -tag -width Ds 76.It \&.vS 77starts processing 78.It \&.vE 79ends processing 80.El 81.Pp 82These lines are formatted as described above. The output from this 83filter can be passed to 84.Xr troff 85for output. There need be no particular ordering with 86.Xr eqn 1 87or 88.Xr tbl 1 . 89.Pp 90In regular mode 91.Nm 92accepts input files, processes them, and passes them to the postprocessor 93for output, 94.Xr psroff 1 95by default. 96.Pp 97In both modes 98.Nm 99passes any lines beginning with a decimal point without conversion. 100.Pp 101The options are: 102.Bl -tag -width Ar 103.It Fl 104forces input to be taken from standard input (default if 105.Fl f 106is specified ) 107.It Fl W 108forces output to the (wide) Versatec printer rather than the (narrow) 109Varian 110.It Fl d Ar file 111specifies an alternate language definitions 112file (default is 113.Pa /usr/share/misc/vgrindefs ) 114.It Fl f 115forces filter mode 116.It Fl h Ar header 117specifies a particular header to put on every output page (default is 118the file name) 119.It Fl l 120specifies the language to use. Currently known are 121.Tn PASCAL 122.Pq Fl l Ns Ar p , 123.Tn MODEL 124.Pq Fl l Ns Ar m , 125C 126.Pf ( Fl l Ns Ar c 127or the default), 128.Tn C++ 129.Pq Fl l Ns Ar c++ , 130.Tn CSH 131.Pq Fl l Ns Ar csh , 132.Tn SHELL 133.Pq Fl l Ns Ar sh , 134.Tn RATFOR 135.Pq Fl l Ns Ar r , 136.Tn MODULA2 137.Pq Fl l Ns Ar mod2 , 138.Tn YACC 139.Pq Fl l Ns Ar yacc , 140.Tn LISP 141.Pq Fl l Ns Ar isp , 142.Tn ICON 143.Pq Fl l Ns Ar I , 144and 145.Tn PERL 146.Pq Fl l Ns Ar perl . 147.It Fl n 148forces no keyword bolding 149.It Fl p Ar postproc 150use 151.Ar postproc 152to post-process the output, 153.Xr psroff 1 154by default. 155.It Fl s 156specifies a point size to use on output (exactly the same as the argument 157of a .ps) 158.It Fl t 159similar to the same option in 160.Xr troff 161causing formatted text to go to the standard output 162.It Fl x 163outputs the index file in a ``pretty'' format. 164The index file itself is produced whenever 165.Nm 166is run with a file called 167.Pa index 168in the current directory. 169The index of function 170definitions can then be run off by giving 171.Nm 172the 173.Fl x 174option and the file 175.Pa index 176as argument. 177.El 178.Sh FILES 179.Bl -tag -width /usr/share/misc/vgrindefsxx -compact 180.It Pa index 181file where source for index is created 182.It Pa /usr/share/tmac/tmac.vgrind 183macro package 184.It Pa /usr/libexec/vfontedpr 185preprocessor 186.It Pa /usr/share/misc/vgrindefs 187language descriptions 188.El 189.Sh SEE ALSO 190.Xr getcap 3 , 191.Xr vgrindefs 5 192.Sh BUGS 193Vfontedpr assumes that a certain programming style is followed: 194.Pp 195For 196.Tn C 197\- function names can be preceded on a line only by spaces, tabs, or an 198asterisk. The parenthesized arguments must also be on the same line. 199.Pp 200For 201.Tn PASCAL 202\- function names need to appear on the same line as the keywords 203.Em function 204or 205.Em procedure . 206.Pp 207For 208.Tn MODEL 209\- function names need to appear on the same line as the keywords 210.Em is beginproc . 211.Pp 212If these conventions are not followed, the indexing and marginal function 213name comment mechanisms will fail. 214.Pp 215More generally, arbitrary formatting styles for programs mostly look bad. 216The use of spaces to align source code fails miserably; if you plan to 217.Nm 218your program you should use tabs. This is somewhat inevitable since the 219font used by 220.Nm 221is variable width. 222.Pp 223The mechanism of 224.Xr ctags 1 225in recognizing functions should be used here. 226.Pp 227Filter mode does not work in documents using the 228.Fl me 229or 230.Fl ms 231macros. 232(So what use is it anyway?) 233.Sh HISTORY 234The 235.Nm 236command appeared in 237.Bx 3.0 . 238