CEXTRACT(1) CEXTRACT(1)
30 October 1992
NAME
cextract, CDOCNAME - C prototype/documentation extractor
SYNOPSIS
cextract [ -Q# ] [ +AaPpNnxZ ] [ -o ofile ] [ -Hstr -Yprog -B -b -V -v
] [[ -options ] filename... ] CDOCNAME [ -Q# ] [ +AaNnx ] [ -o outfile
] [ -Yprogram -B -b -V -v ] [[ -options ] filename... ]
DESCRIPTION
The cextract program is used to extract the function descriptions (aka
prototypes) from a list of C source files and send them out to the
standard output or a specified file. It may also be used to generate
basic documentation for a list of C source files.
The specific reason this program was written was to provide a method
of automatically generating header files, containing prototypes, for
all of the functions used throughout a multi-file project.
Along with the standard C preprocessing options, -D, -I, and -U, there
are options which allow more control of what form the output will
take.
To allow for conditional processing, cextract automatically predefines
the __CEXTRACT__ identifier. Preprocessor commands, such as "#if",
"#ifdef" and "#ifndef" may then be used to control what code is parsed
by cextract. If the CDOCNAME command is used, the program will also
define __CEXTDOC__.
The cextract program also supports the use of customization files. A
system configuration file will be read, and then any "NORMRC" file in
the user's home directory, and finally any "NORMRC" file in the
current directory. For a description of the format of the
customization file, see the cextrc(5) manual page.
COMMAND LINE OPTIONS
The cextract and CDOCNAME programs support both long and short command
line options. Also, a `+' sign before an option description means
that it can be either on or off, with a `+' prefix enabling that
option or a `-' prefix disabling it. The prefix of "no-" (or "no") is
also supported for disabling an option.
Most command line arguments may be used anywhere on the command line,
but a few must be used before any file parsing begins [such as the -N,
+Z and -x options], and one can only be the first argument on the
command line [the -Q flag].
+A, +sort-all
Sort the output, listing all functions in alphabetical order.
This option is not compatible with the +C flag, since functions
are sorted over the entire spectrum, not just for each file.
- 1 - Formatted: October 30, 2025
CEXTRACT(1) CEXTRACT(1)
30 October 1992
+a, +sort-by-files
Sort the output, listing functions alphabetically for each file.
Since this option sorts each file separately, it is compatible
with the +C flag, unlike the +A option. For cextract, the
default is to not do any sorting, while the CDOCNAME default is
to sort by files.
-b, -build-config
Automatically build a configuration file in the current directory
based on the current program settings.
-B, -system-build
Generate a system wide configuration file based on the current
program settings.
+C, +first-comments
Capture the first comment encountered in each file and include it
in the generated output. [default off]
+c, +comments, +yank-comments
Take the comment immediately preceding the function declaration
and send it as output along with the function prototype. [default
on]
-Dexpression, -define=expression
Define a macro, as per the C "#define" preprocessor statement.
+E, +externs
Place the string 'extern' before each function prototype.
[default on]
+F, +filename
Prepend the name of the file to the initial comment when it is
processed. This flag requires the +C option. [default off]
-f%##, -font-%-##
Specify what fonts are to be used when generating troff
documentation output. The font name is a one or two character
troff name which will be interpreted later by the troff
processor. Four fonts are used: `1' or `t' which is used only
for the title words "Function:" and "File:" [default value of
"C", Courier]; `2' or `c' which is used for comments [default
value of "CO", Courier Oblique]; `3' or `n' which is used for the
function name [default value of "B", Times Bold]; and `4' or `p'
for the parameter list [default value of "R", Times Roman]. Note
that the `%' character indicates the type being adjusted, and
"##" indicates the one or two character font name.
-Hstring, -header-string=string
During the normal extraction mode, enclose the output within the
sequence "#ifndef string", "#define string", ..., "#endif /*
- 2 - Formatted: October 30, 2025
CEXTRACT(1) CEXTRACT(1)
30 October 1992
string */". This method is used with many system header files
and prevents the header file from being parsed more than once.
If this option is not used, the output will be enclosed within a
"#ifndef __CEXTRACT__", "#endif /* __CEXTRACT__ */" sequence
instead.
-Idirectory, -include=directory
Add the indicated directory to the search path for include files
accessed via the "#include" preprocessor statement. This flag is
passed on to the C preprocessor.
+m, +multi-comments, +multiple-comments
If the -c flag is set, look for a "block" of multiple comments,
instead of a single comment. Comments with more than one newline
in between are considered separate. [default off]
-N, -roff-mode, -troff-mode
Enable documentation mode, sending output as -ms troff format.
-n, -doc-mode
Enable documentation mode, sending output as normal text. This
is the default mode of the CDOCNAME program.
-o outfile, -output-file outfile, -output-file=outfile
Send output to the specified file instead of the standard output.
The file name need not immediately follow the `-o' flag, but it
must be the first non-option argument. Warning: This will
overwrite any existing file of the same name.
+P, +dual-output
In extraction mode, generate both styles of C prototypes,
separated by using "#ifdef" and "#else" statements to test for
__STDC__. This option must precede any file arguments. [default
on]
+p, +ansi-code
Produce output in ANSI C prototype format; otherwise, produce
old-style declarations. This option must precede any file
arguments. [default off]
-qfile, -config-file=file
Read in the specified file and parse it for customization
commands.
-Q#, -read-config=#
An octal digit specifies which configuration files should be
read; 1 for the system configuration file, 2 for the $HOME/NORMRC
file and 4 for the "NORMRC" file in the current directory. Add
values to read multiple files. If no number is specified, a 0 is
assumed. This option must be the very first argument on the
command line. [default value of 7 reads all three files]
- 3 - Formatted: October 30, 2025
CEXTRACT(1) CEXTRACT(1)
30 October 1992
+r, +remove-names, +discard-names
Strip out the variable names when sending out the prototype
lists.
+S, +show-all, +show-anyway
If the -p flag is off, output the prototype list anyway, but
enclosed within comments. If the -P flag is set, comments and
commented prototypes should also be duplicated within the non-
ANSI portion of the output. [default on]
+s, +s:none|all|only, +statics, +statics: none|all|only
Indicate how static functions are to be treated. If "none" is
chosen, static functions will be ignored, if "only" then any
non-static functions will be ignored, and "any" indicates that
all functions will be included. If no selection is given, either
"any" (`+' flag), or "none" (`-' flag) will be used.
-T#, -tab-width=#
Specify the tab width used during documentation output. If no
value is given, or a value of zero is given, tabs are passed
though unformatted.
-Uname, -undefine=name
Undefine a macro. If "-Dname" was specified in a previous
argument, it is removed from the argument list; otherwise, this
option is passed on to the C preprocessor.
-V, -settings
Show the current settings of the various program options.
-v, -version-info
Display the version number of the program.
+W, +break-after-types, +break-types
When enabled, a newline will be inserted between the function
type and the function name in the function declarations.
+w#, +wrap-parameters=#
If the length of the parameter list for a function would cause it
to exceed a given number of columns [72 by default], a newline
will be inserted in place of a space character, so that the
function will not exceed that given length. The optional number
after the command will override a negation prefix if encountered.
-x, -extract-mode
Run cextract or CDOCNAME as a prototype extractor. This is the
default mode for cextract.
-Yprogram -cpp-program=program
Specify which program to use as the C preprocessor. This program
should resolve all of the C defines and preprocessor statements
- 4 - Formatted: October 30, 2025
CEXTRACT(1) CEXTRACT(1)
30 October 1992
while, hopefully, leaving comments intact.
+Z, -merge-output
Combine the ANSI and K&R C output of the cextract on one line, to
create a much more compact header file.
VMS
Configuration files are also supported under VMS. The default
configuration files for VMS systems are sys$library:cext.cnf,
sys$login:cext.cnf, and cext.cnf.
Since the VMS C compiler strips out comments, the documentation mode
and comment options are not very useful. Using the GNU C preprocessor
instead might be a possible solution.
COPYRIGHT
The code is freely distributable and there are no restrictions other
than the fact that it not be used for monetary gain and that copyright
notices must be kept intact.
Both cextract and CDOCNAME may be used to generate proprietary source
code or documentation, but its own source code may not be used as a
part of any proprietary programs.
The header files and documentation generated by cextract and CDOCNAME
are not subject to this COPYRIGHT notice because they are derived from
the source code which was read in by the program to create the output.
FILES
SYSCXTRC, $HOME/NORMRC, NORMRC
The list of configuration files, and the order in which they are
read in.
SEE ALSO
cc(1), cextrc(5)
AUTHORS
Adam Bryant
adb@cs.bu.edu
initial VMS port by John Carr
jrcarr@iup.bitnet
special thanks to comp.sources.reviewed reviewers, without whom this
program would be much less useful.
VMS
On VMS systems, only the longer command line options are available,
and the '/' character is used to specify command line options.
- 5 - Formatted: October 30, 2025
CEXTRACT(1) CEXTRACT(1)
30 October 1992
BUGS
1) As far as I know, there is no way to tell the normal VMS C compiler
not to strip out comments. This renders the comment extraction and
documentation mode portions rather useless to VMS sites. Getting the
GNU C preprocessor for such sites is recommended.
2) Cextract has problems with function pointers and structure
definitions within the parameter list, using typedefs for such
declarations is recommended.
3) Does not yet fully support C++ code.
4) It is dependent on the given C preprocessor, so will have any
limitations (such as maximum #defines) which the C preprocessor has.
If any other bugs are detected, please notify the author.
- 6 - Formatted: October 30, 2025