File: deheader.adoc

package info (click to toggle)
deheader 1.12-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 480 kB
  • sloc: python: 1,206; ansic: 334; makefile: 75; sh: 15
file content (158 lines) | stat: -rw-r--r-- 6,490 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
= deheader(1)
:doctype: manpage
:manmanual: Development Tools
:mansource: deheader

// spellcheck: add sourcefile sourcefiles sys builddir cmake gcc
// spellcheck: add ifdef endif Werror Wfatal-errors makefile CFLAGS
// spellcheck: add Targetless pre-release deheadered POSIX

== Name
deheader - report which includes in C or C++ compiles can be removed

== Synopsis
*deheader* [-h] [-m _command_] [-b _builddir_] [-i _pattern_] [-q] [-r] [-v] [-x _pattern_] [-V] [_file-or-dir_]

== Description

This tool takes a list of C or C++ sourcefiles and generates a report
on which #includes can be omitted from them; also, what standard
inclusions may be required for portability. The test, for each foo.c
or foo.cc or foo.cpp, is simply whether "rm foo.o; make foo.o" returns
a zero status (but the build command may be overridden).

Exception: Under cmake, foo.o is a phony target. Therefore, when a
"CMakeList.txt" is detected, "make clean" is done rather than "rm
foo.o".

Optionally, with the *-r* switch, the unneeded headers are removed
from the sourcefiles. Don't use this option unless you have your
sourcefiles safely under version control and can revert!

If a sourcefile argument is a directory, the report is generated on
all source files beneath it. Subdirectories beginning with a dot are
assumed to be repository directories for version-control systems and
ignored. If no arguments are given, the program runs as if the name of
the current directory had been passed to it.

Inclusions within the scope of #if/#ifdef/#else/#endif directives are
left alone, because trying to reason about potential combinations of
-D and U options would be too complicated and prone to weird
errors. One exception: headers protected only by S_SPLINT_S, the
conditional for blocking scanning by the static analysis tool
splint(1), are scanned normally.

The tool will also emit warnings about duplicate inclusions, and
inclusions required for portability but not present.

It is recommended that you arrange to compile with options that will
stop the compiler on warnings when using this tool; otherwise it will
report headers that only declare prototypes and return types (and thus
throw only warnings) as being not required. Under gcc the compiler
options to accomplish this are -Werror -Wfatal-errors. If your
makefile follows normal conventions, running with *-m "make
CFLAGS='-Werror -Wfatal-errors' %s"* may do the right thing; you can
check this by running with -v -v -v to see what compilation commands
are actually emitted.

On each test compile, the original sourcefile is moved to a name with
an .orig suffix and restored on interrupt or after processing with its
original timestamp, unless the *-r* option was given and headers
removed.

If the -b option is given, it tells the program that generated .o
files live in a file tree parallel to the source tree but rooted at
the specified argument. If the argument is a relative path, it is
interpreted relative to the directory in which *deheader* is run.

If the first test compilation from the top-level directory fails,
*deheader* descends into the subdirectory of the source file and retries
compiling inside there.

At verbosity level 0, only messages indicating removable headers are
issued. At verbosity 1, test compilations are timed and progress
indicated with a twirling-baton prompt. At verbosity level 2, you get
verbose progress messages on the analysis. At verbosity level 3, you
see the output from the make and compilation commands.

If the -q (--quiet) option flag was not set, the last line of the
output will be a statistical summary.

Running *deheader* will leave a lot of binaries in your directory that
were compiled in ways possibly not invoked by your normal build
process. Running "make clean" afterwards (or the equivalent under
whatever build system you are using) is strongly recommended.

== Options

*-h*::
Display some help and exit.

*-m* _command_::
Set the build command used for test compiles. Defaults to 'make %s'. A
%s in the build command is replaced with the make target. Targetless
builders such as meson can be supported with, e.g. "-m 'ninja -C
build'"

*-b* _builddir_::
Set the build directory for object files.

*-i* _pattern_::
Set a pattern for includes to be ignored. Takes a Python regular expression.

*-q*::
Suppress statistical summary.

*-r*::
Remove header inclusions from sourcefiles where they are not required.

*-v*::
Set verbosity.

*-x* _pattern_::
Exclude files with names matching the specified Python regexp.

*-V*::
Show version of program and exit.

== Return Values

Returns 1 if unneeded includes were found, 0 otherwise. Thus, you can
use it for pre-release sanity checking in Makefile.

== Bugs

Very rarely, test-compiling after running with *-r* may show that this
tool removed some headers that are actually required for your
build. This can happen because *deheader* doesn't know about all the
strange things your build system gets up to, and the problem of
analyzing your build to understand them would be
Turing-complete. Simply revert the altered files and continue.

Due to minor variations in system headers, it is possible your program
may not port correctly in older Unix variants after being
deheadered. This is normally not a problem with the portion of the API
specified by POSIX and ANSI C, but may be for headers that are not
standardized or only weakly standardized. The sockets API
(<sys/select.h+, +sys/sockets.h+, and friends such as +sys/types.h+
and +sys.stat.h+) is perhaps the most serious trouble spot. *deheader*
has an internal table of rules that heads off the most common problems
by suppressing deletion of headers that are required for portability,
but your mileage may vary.

The dependency scanner does not ignore the text of comments. This,
e.g, a reference to "log10" in a comment will produce a spurious
warning that +<math.h>+ is required for portability.

Sufficiently perverse C++ can silently invalidate the brute-force
algorithm this tool uses. Example: if an overloaded function has
different overloads from two different files, removing one may expose
the other, changing runtime semantics without a compile-time
warning. Similarly, removing a later file containing a template
specialization may lead to undefined behavior from a template defined
in an earlier file. Use this with caution near such features, and test
carefully.

== Author

Eric S. Raymond <esr@snark.thyrsus.com>; (home page at http://www.catb.org/~esr/).