lunar (1) splint.1.gz

Provided by: splint_3.1.2+dfsg-5_amd64 bug

NAME

       splint - A tool for statically checking C programs

SYNOPSIS

       splint [options]

DESCRIPTION

       splint  is  a  tool  for  statically  checking C programs for security vulnerabilities and
       common programming mistakes. With minimal effort, splint can be used as a better lint.  If
       additional  effort is invested adding annotations to programs, splint can perform stronger
       checks than can be done by any standard lint.  For full documentation, install the splint-
       doc-html Debian package.  This man page only covers a few of the available options.

OPTIONS

       -help Shows help

       Initialization

       These  flags  control  directories  and  files  used  by splint. They may be used from the
       command line or in an options file, but may not be used as control comments in the  source
       code. Except where noted. they have the same meaning preceded by - or +.

       -tmpdir directory
             Set directory for writing temp files. Default is /tmp/.

       -I directory
             Add directory to path searched for C include files. Note there is no space after the
             I, to be consistent with C preprocessor flags.

       -S directory
             Add directory to path search for .lcl specification files.

       -f file
             Load options file <file>. If this flag is used from the command  line,  the  default
             ~/.splintrc  file is not loaded. This flag may be used in an options file to load in
             another options file.

       -nof  Prevents the default options files (./.splintrc and ~/.splintrc) from being  loaded.
             (Setting -nof overrides +nof, causing the options files to be loaded normally.)

       -systemdirs directories
             Set  directories  for system files (default is "/usr/include"). Separate directories
             with colons (e.g., "/usr/include:/usr/local/lib"). Flag settings propagate to  files
             in  a system directory. If -systemdirerrors is set, no errors are reported for files
             in system directories.

       Pre-processor

       These flags are used to define or undefine  pre-processor  constants.   The  -I<directory>
       flag is also passed to the C pre-processor.

       -D initializer
             Passed to the C pre-processor.

       -U initializer
             Passed to the C pre-processor

       Libraries These flags control the creation and use of libraries.

       -dump file
             Save  state in <file> for loading. The default extension .lcd is added if <file> has
             no extension.

       -load file
             Load state from <file> (created by -dump). The default extension .lcd  is  added  if
             <file> has no extension. Only one library file may be loaded.

             By  default,  the standard library is loaded if the -load flag is not used to load a
             user library. If no user library is loaded, one of the following flags may  be  used
             to  select a different standard library. Precede the flag by + to load the described
             library (or prevent a library from being loaded using nolib). See  Apppendix  F  for
             information on the provided libraries.

       -nolib
             Do not load any library. This prevents the standard library from being loaded.

       -ansi-lib
             Use the ANSI standard library (selected by default).

       -strict-lib
             Use strict version of the ANSI standard library.

       -posix-lib
             Use the POSIX standard library.

       -posix-strict-lib
             Use the strict version of the POSIX standard library.

       -1-lib
             Use UNIX version of standard library.

       -1-strict-lib
             Use the strict version of the UNIX standard library.

       Output

       These  flags  control  what  additional  information is printed by splint. Setting +<flag>
       causes the described information to be printed; setting -<flag> prevents it.  By  default,
       all these flags are off.

       -usestderr
             Send error messages to standard error (instead of standard out).  This flag has been
             replaced by more precise flags for controlling the warning, status message and fatal
             error streams independently.  See the output of splint +usestderr

       -showsummary
             Show  a  summary  of all errors reported and suppressed. Counts of suppressed errors
             are not necessarily correct since turning a flag off may prevent some checking  from
             being  done  to  save  computation,  and  errors that are not reported may propagate
             differently from when they are reported.

       -showscan
             Show file names as they are processed.

       -showalluses
             Show list of uses of all external identifiers sorted by number of uses.

       -stats
             Display number of lines processed and checking time.

       -timedist
             Display distribution of where checking time is spent.

       -quiet
             Suppress herald and error count. (If quiet is not set, splint prints  out  a  herald
             with  version  information  before checking begins, and a line summarizing the total
             number of errors reported.)

       -whichlib
             Print out the standard library filename and creation information.

       -limit number
             At most <number> similar errors  are  reported  consecutively.  Further  errors  are
             suppressed, and a message showing the number of suppressed messages is printed.

       Expected Errors

       Normally,  splint  will expect to report no errors. The exit status will be success (0) if
       no errors are reported, and failure if any errors are reported. Flags can be used  to  set
       the  expected  number  of  reported  errors.   Because  of  the provided error suppression
       mechanisms, these options should probably not be used for final checking real programs but
       may be useful in developing programs using make.

       -expect <number>
             Exactly <number> code errors are expected. splint will exit with failure exit status
             unless <number> code errors are detected.

       -Message Format
             These flags control how messages are printed. They may be set at the  command  line,
             in  options files, or locally in syntactic comments. The linelen and limit flags may
             be preceded by + or - with the same meaning; for the other flags,  +  turns  on  the
             describe  printing  and  -  turns it off. The box to the left of each flag gives its
             default value.

       -showcolumn
             Show column number where error is found. Default: +

       -showfunc
             Show name of function (or macro) definition containing error. The function  name  is
             printed once before the first message detected in that function. Default: +

       -showallconjs
             Show all possible alternate types (see Section 8.2.2). Default: -

       -paren-file-format
             Use file(line) format in messages.

       -hints
             Provide  hints describing an error and how a message may be suppressed for the first
             error reported in each error class. Default: +

       -forcehints
             Provide hints for all errors reported, even if the hint has already  been  displayed
             for the same error class. Default: -

       -linelen number
             Set  length  of  maximum  message  line  to  <number>  characters. splint will split
             messages longer than <number> characters long into multiple lines. Default: 80

       Mode Selector Flags

       Mode selects flags set the mode checking flags to predefined values. They provide a  quick
       coarse-grain  way  of  controlling  what classes of errors are reported. Specific checking
       flags may be set after a mode flag to override the mode settings. Mode flags may  be  used
       locally,  however  the  mode settings will override specific command line flag settings. A
       warning is produced if a mode flag is used after a mode checking flag has been set.

       These are brief descriptions to give a general idea of what each mode  does.  To  see  the
       complete  flag  settings  in  each  mode, use splint -help modes. A mode flag has the same
       effect when used with either + or -.

       -weak Weak checking, intended for typical unannotated C code. No modifies checking,  macro
             checking,  rep  exposure, or clean interface checking is done. Return values of type
             int may be ignored. The types bool, int, char and user-defined enum  types  are  all
             equivalent. Old style declarations are unreported.

       -standard
             The  default  mode.  All checking done by weak, plus modifies checking, global alias
             checking, use all parameters, using released storage, ignored return values  or  any
             type,  macro checking, unreachable code, infinite loops, and fall-through cases. The
             types bool, int and char are distinct.  Old style declarations are reported.

       -checks
             Moderately strict checking. All checking done by standard,  plus  must  modification
             checking, rep exposure, return alias, memory management and complete interfaces.

       -strict
             Absurdly strict checking. All checking done by checks, plus modifications and global
             variables used in unspecified functions, strict standard library, and strict  typing
             of  C operators. A special reward will be presented to the first person to produce a
             real program that produces no errors with strict checking.

AUTHOR

       If you need to get in contact with the authors send  email  to  info@splint.org  or  visit
       <http://www.splint.org>.

                                                                                        splint(1)