gcc provides the -I-
option, for which -I
directories preceding the -I-
are searched for quoted includes (#include "foo.h"
), and -I
directories following the -I-
are searched for bracketed includes (#include <foo.h>
), as well as after the others for quoted includes.
-I-
has another very important effect. It removes the directory of the source file that the #include
is in from the default search path. Normally a quoted include always searches the directory of the source file, and searches it before any -I
or other directories. -I-
therefore allows you to specify exactly where to go for quoted include files in the order you want, by removing that default path that otherwise would take priority.
So it sounds like I answered my question, yes? No. When I use -I-
now, I get this nastygram:
cc1: note: obsolete option -I- used, please use -iquote instead
The problem is that -iquote
does not remove the current directory from the search path. It is still always searched first, no matter what I provide to -iquote
.
So the question is: how do I get the same effect as -I-
, without using -I-
, which has been deprecated and will eventually go away?
Elaboration:
Suppose files are laid out as follows:
srcdir/
configure
file1.c
file2.c
config.h
builddir/
Makefile
file1.o
file2.o
config.h
libpudding.a
For various reasons, we can't remove config.h
from srcdir
(it will impact the build process on other platforms). However, we want to include the config.h
from builddir
in preference to the zconf.h
in srcdir
.
This can be accomplished with GCC's -I-
flag, but it seems otherwise impossible.
Updated question:
Ok, it seems like the GNU CC developers deprecated -I-
, but did not provide an alternative way to achieve its functionality. So my updated question is: what is the most effective way to bring this to the attention of the developers so that there is a high probability that either -I-
is undeprecated (which I would find most preferable, since it is a quite elegant way to handle specifying the search, much more so and much less ugly than -iquotexxx), or that some way is provided to remove the current directory from a quoted include search path?
-I-
is the only option with that behavior. In the past, I've decided that the simplest option for my own projects is to rename or reorganize my header files rather than futz with search paths. Source: gcc.gnu.org/onlinedocs/gcc-4.7.1/gcc/… – Dietrich Epp-I-
to accomplish it. Is this the kind of change you're looking for? github.com/depp/zlib – Dietrich Epp