239 lines
		
	
	
	
		
			6.3 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
			
		
		
	
	
			239 lines
		
	
	
	
		
			6.3 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
| .\" (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands.
 | |
| .\" See the copyright notice in the ACK home directory, in the file "Copyright".
 | |
| .\"
 | |
| .\" $Id$
 | |
| .TH LINT 1 "$Revision$"
 | |
| .SH NAME
 | |
| lint \- a C program checker
 | |
| .SH SYNOPSIS
 | |
| .B lint
 | |
| [ \-abhuvx \-KR -ansi ] [file | libname | \-l\fIxxx\fP ] ...
 | |
| .br
 | |
| .B lint
 | |
| \-L\fIlibname\fP [ file | libname2 | \-l\fIxxx\fP ] ...
 | |
| .br
 | |
| .SH DESCRIPTION
 | |
| .I Lint
 | |
| does an extensive consistency and plausibility check on a set of C
 | |
| program files.
 | |
| When it detects a doubtful construction
 | |
| (which need not be an error) it gives a warning.
 | |
| .PP
 | |
| It does a full flow-of-control check, except that
 | |
| .BR goto s
 | |
| are not followed and that the fact that a function never returns
 | |
| is not propagated.
 | |
| If, however, no
 | |
| .BR goto s
 | |
| are used, each call of a non-returning function is followed by
 | |
| /*NOTREACHED*/ and each switch has a default clause (possibly consisting
 | |
| of /*NOTREACHED*/), the initialization state of all local variables will
 | |
| be checked correctly.
 | |
| .PP
 | |
| .I Lint
 | |
| checks the types of the arguments implied by the format in a call of
 | |
| .IR printf() ,
 | |
| .IR scanf()
 | |
| and family, if the format string is a direct argument in the call.
 | |
| Formats of user functions can be indicated using a FORMAT pseudo-comment; see
 | |
| below.
 | |
| .PP
 | |
| .I Libraries
 | |
| .PP
 | |
| The second command (using the
 | |
| .BR \-L -option)
 | |
| is used to maintain lint libraries; these are ASCII files
 | |
| that contain the output of the first pass.
 | |
| A library name ends in
 | |
| .BR .llb .
 | |
| A lint user library can be created and updated by using the
 | |
| .B \-L
 | |
| option.  The
 | |
| .I libname
 | |
| end in
 | |
| .BR .llb ,
 | |
| and can be passed to
 | |
| .I lint
 | |
| again as a normal argument.
 | |
| .PP
 | |
| Standard libraries are searched by default or by explicitly giving the
 | |
| .B \-l
 | |
| option; their format is identical to that of the user library files.
 | |
| Possibilities are
 | |
| .BR \-lm ,
 | |
| .B \-ltermcap
 | |
| and 
 | |
| .BR \-lcurses .
 | |
| .B \-lc
 | |
| is default; a single
 | |
| .B \-l
 | |
| tells
 | |
| .I lint
 | |
| not to use the standard C library.
 | |
| The standard libraries are searched for in the standard lint directory or
 | |
| in the directory given in the environment variable LINTLIB, if present.
 | |
| .PP
 | |
| .I Options
 | |
| .PP
 | |
| The
 | |
| .BR \-D ,
 | |
| .B \-U
 | |
| and
 | |
| .B \-I
 | |
| options are recognized as separate arguments and conform to those of
 | |
| .IR cc .
 | |
| The
 | |
| .B \-KR
 | |
| option tells
 | |
| .I lint
 | |
| to check strictly according to Kernighan & Ritchie; since
 | |
| .I lint
 | |
| is trying to be helpful rather than obnoxious, this is not the default.
 | |
| The
 | |
| .B \-ansi
 | |
| option tells lint to check according to ANSI C.
 | |
| .PP
 | |
| .I Lint
 | |
| understands the following additional options:
 | |
| .TP
 | |
| .B a
 | |
| Warn about conversions that may cause a loss of precision.
 | |
| .TP
 | |
| .B b
 | |
| Do not report not-reachable 
 | |
| .I break
 | |
| statements.
 | |
| This flag may be useful when
 | |
| .I lint
 | |
| is run on a generated source file.
 | |
| .TP
 | |
| .B h
 | |
| Apply several heuristics:
 | |
| signal "null effects", possible pointer alignment problems and odd
 | |
| constructs; report definitions of variables that have a scope wider than
 | |
| necessary: extern variables that are used in one file only, automatic
 | |
| variables that could be more local.
 | |
| .TP
 | |
| .B u
 | |
| Do not complain about unused and undefined functions and global variables.
 | |
| .TP
 | |
| .B v
 | |
| Do not warn about unused arguments of functions.
 | |
| .TP
 | |
| .B x
 | |
| Complain about unused external variables.
 | |
| .PP
 | |
| .I Pseudo-comments
 | |
| .PP
 | |
| The following pseudo-comments can be used to influence the behaviour of
 | |
| .IR lint:
 | |
| .TP
 | |
| /*\ ARGSUSED\ */
 | |
| Do not warn about arguments not used in the next function
 | |
| (see also the \-\fBv\fR option).
 | |
| .TP
 | |
| /*\ NOTREACHED\ */
 | |
| This tells
 | |
| .I lint
 | |
| that the flow of control "cannot reach" this comment.
 | |
| This is a way to tell
 | |
| .I lint
 | |
| that a statement never "returns".
 | |
| .TP
 | |
| /*\ LINTLIBRARY\ */
 | |
| The definitions following this pseudo-comment are assumed to be part of a
 | |
| library.
 | |
| It suppresses complaints about unused functions and variables
 | |
| and is used in the creation of lint libraries.
 | |
| It implies /*\ ARGSUSED\ */.
 | |
| .TP
 | |
| /*\ VARARGS\fIn\fR\ */
 | |
| The next function can be called with a variable number of
 | |
| arguments.
 | |
| Only check the types of the first \fIn\fR arguments.
 | |
| The \fIn\fR must follow the word VARARGS immediately.
 | |
| /*\ VARARGS0\ */ may be abbreviated to /*\ VARARGS\ */.
 | |
| .TP
 | |
| /*\ FORMAT\fIn\fR $ ... $\ */
 | |
| The \fIn\fP-th argument (counting from 0) of the  next function declaration
 | |
| corresponds to a
 | |
| .IR printf -like
 | |
| format string.  Details about the format are given between the $$; see below.
 | |
| A missing $$ repeats the latest format.
 | |
| The \fIn\fR must follow the word FORMAT immediately.
 | |
| /*\ FORMAT\fIn\fR $ ... $\ */ implies /*\ VARARGS\fIn+1\fP\ */; if the format
 | |
| is followed by more required arguments, a separate /*\ VARARGS\fIm\fP\ */
 | |
| must be given after the FORMAT pseudo-comment.
 | |
| .IP
 | |
| If the printf-like heading also has to conform to some varargs.h convention,
 | |
| error messages may result; these can be suppressed by appending the letter v
 | |
| to the word FORMAT\fIn\fR without intervening space.
 | |
| .PP
 | |
| .I Formats
 | |
| .PP
 | |
| The $$-part of the FORMAT pseudo-comment consists of a list of format
 | |
| specifications, each of the form
 | |
| .IR %T = type ,
 | |
| where
 | |
| .I T
 | |
| is an arbitrary (short) string and
 | |
| .I type
 | |
| is the expected type in "C normal form" (like in a cast, with no superfluous
 | |
| parentheses and without the use of typedefs). E.g., %ld=long indicates that
 | |
| the format string ld corresponds to a parameter of type long. For a shorter
 | |
| notation see the example below.
 | |
| .I Lint
 | |
| recognizes conversion specifications of the form %[N|*|][.[N|*]]T where N is
 | |
| a number, the * is itself and T is a string as defined above. For the above
 | |
| example this would include %ld, %5.2ld, %.*ld, etc.
 | |
| .PP
 | |
| Example: the FORMAT pseudo-comment for
 | |
| .I printf()
 | |
| is:
 | |
| .br
 | |
| /*\ FORMAT0 $
 | |
| .br
 | |
| 	%[dox] = int		%l[dox] = long		%[DOX] = long
 | |
| .br
 | |
| 	%u = unsigned int	%lu = unsigned long	%U = unsigned long
 | |
| .br
 | |
| 	%[feg] = double
 | |
| .br
 | |
| 	%c = int			%s = char *
 | |
| .br
 | |
| $\ */
 | |
| .PP
 | |
| .I Output
 | |
| .PP
 | |
| Some users feel it is a good idea to pipe the output of
 | |
| .I lint
 | |
| through the command
 | |
| .br
 | |
| 	sort \-t' ' +0d \-1 +2n \-3
 | |
| .br
 | |
| where the character between the apostrophes is a space.
 | |
| .SH "ENVIRONMENT VARIABLES"
 | |
| LINTFLAGS		additional flag arguments (e.g. LINTFLAGS=\-h)
 | |
| .br
 | |
| LINTLIB		directory in which the standard libraries are looked up
 | |
| .SH FILES
 | |
| .IP ???/lnt 24
 | |
| first pass
 | |
| .IP ???/lpass2/lpass2
 | |
| second pass
 | |
| .IP ???/llib/*.llb
 | |
| lint libraries
 | |
| .SH SEE ALSO
 | |
| cem(1)
 | |
| .br
 | |
| Frans Kunst,
 | |
| .I Lint, a C Program Checker
 | |
| .SH BUGS
 | |
| Conflicting options in the command line are not detected.
 | |
| .br
 | |
| After a label, all automatic variables are assumed initialized.
 | |
| .SH AUTHOR
 | |
| Frans Kunst, Vrije Universiteit, Amsterdam.
 | |
| .br
 | |
| Dick Grune, Vrije Universiteit, Amsterdam.
 | |
| .br
 |