https://gcc.gnu.org/bugzilla/show_bug.cgi?id=122411

            Bug ID: 122411
           Summary: Empty path in COMPILER_PATH leads to -isystem
                    ./include
           Product: gcc
           Version: 15.2.1
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: preprocessor
          Assignee: unassigned at gcc dot gnu.org
          Reporter: p.e.c.melis at alumnus dot utwente.nl
  Target Milestone: ---

We had inadvertently set COMPILER_PATH to "<somepath>:" (i.e. with trailing
":") and this leads to `-isystem ./include` being added by cpp/gcc, but only
when directory `include` actually exists in the current directory.

paulm@l0420007 11:24:~$ ls -l include
total 0

paulm@l0420007 11:24:~$ COMPILER_PATH=/tmp: cpp -v
Using built-in specs.
COLLECT_GCC=cpp
Target: x86_64-pc-linux-gnu
Configured with: /build/gcc/src/gcc/configure
--enable-languages=ada,c,c++,d,fortran,go,lto,m2,objc,obj-c++,rust,cobol
--enable-bootstrap --prefix=/usr --libdir=/usr/lib --libexecdir=/usr/lib
--mandir=/usr/share/man --infodir=/usr/share/info
--with-bugurl=https://gitlab.archlinux.org/archlinux/packaging/packages/gcc/-/issues
--with-build-config=bootstrap-lto --with-linker-hash-style=gnu
--with-system-zlib --enable-__cxa_atexit --enable-cet=auto
--enable-checking=release --enable-clocale=gnu --enable-default-pie
--enable-default-ssp --enable-gnu-indirect-function --enable-gnu-unique-object
--enable-libstdcxx-backtrace --enable-link-serialization=1
--enable-linker-build-id --enable-lto --enable-multilib --enable-plugin
--enable-shared --enable-threads=posix --disable-libssp --disable-libstdcxx-pch
--disable-werror
Thread model: posix
Supported LTO compression algorithms: zlib zstd
gcc version 15.2.1 20250813 (GCC) 
COLLECT_GCC_OPTIONS='-E' '-v' '-mtune=generic' '-march=x86-64'
 /usr/lib/gcc/x86_64-pc-linux-gnu/15.2.1/cc1 -E -quiet -v -isystem ./include -
-mtune=generic -march=x86-64 -dumpbase -
ignoring nonexistent directory
"/usr/lib/gcc/x86_64-pc-linux-gnu/15.2.1/../../../../x86_64-pc-linux-gnu/include"
#include "..." search starts here:
#include <...> search starts here:
 ./include
 /usr/lib/gcc/x86_64-pc-linux-gnu/15.2.1/include
 /usr/local/include
 /usr/lib/gcc/x86_64-pc-linux-gnu/15.2.1/include-fixed
 /usr/include
End of search list.
^C

However, if ./include does not exist no warning of non-existance is given and
`-isystem ./include` is not added, which is thoroughly confusing:

paulm@l0420007 11:28:~$ rm -rf include/
paulm@l0420007 11:29:~$ COMPILER_PATH=/tmp: cpp -v
Using built-in specs.
COLLECT_GCC=cpp
Target: x86_64-pc-linux-gnu
Configured with: /build/gcc/src/gcc/configure
--enable-languages=ada,c,c++,d,fortran,go,lto,m2,objc,obj-c++,rust,cobol
--enable-bootstrap --prefix=/usr --libdir=/usr/lib --libexecdir=/usr/lib
--mandir=/usr/share/man --infodir=/usr/share/info
--with-bugurl=https://gitlab.archlinux.org/archlinux/packaging/packages/gcc/-/issues
--with-build-config=bootstrap-lto --with-linker-hash-style=gnu
--with-system-zlib --enable-__cxa_atexit --enable-cet=auto
--enable-checking=release --enable-clocale=gnu --enable-default-pie
--enable-default-ssp --enable-gnu-indirect-function --enable-gnu-unique-object
--enable-libstdcxx-backtrace --enable-link-serialization=1
--enable-linker-build-id --enable-lto --enable-multilib --enable-plugin
--enable-shared --enable-threads=posix --disable-libssp --disable-libstdcxx-pch
--disable-werror
Thread model: posix
Supported LTO compression algorithms: zlib zstd
gcc version 15.2.1 20250813 (GCC) 
COLLECT_GCC_OPTIONS='-E' '-v' '-mtune=generic' '-march=x86-64'
 /usr/lib/gcc/x86_64-pc-linux-gnu/15.2.1/cc1 -E -quiet -v - -mtune=generic
-march=x86-64 -dumpbase -
ignoring nonexistent directory
"/usr/lib/gcc/x86_64-pc-linux-gnu/15.2.1/../../../../x86_64-pc-linux-gnu/include"
#include "..." search starts here:
#include <...> search starts here:
 /usr/lib/gcc/x86_64-pc-linux-gnu/15.2.1/include
 /usr/local/include
 /usr/lib/gcc/x86_64-pc-linux-gnu/15.2.1/include-fixed
 /usr/include
End of search list.
^C

Clearly that empty entry should not be there from our side, but it lead to a
long search for why a build was breaking which had an `include` dir in the
build dir that was referenced `-I./include`. But this `-I` was getting ignored
as it was treated as a duplicate system include path and thus moved later in
the include path list.

The current behaviour is a bit buggy in my opinion:

- The documentation for COMPILER_PATH only mentions that it influences
"searching for subprograms", but says nothing of it influencing (system)
include directories.

- No warning is given that `./include` cannot be found when it doesn't exist,
even though that seems to be the default behaviour for other non-existent
directories that are searched (but not those from COMPILER_PATH). Together with
silently adding `-isystem ./include` when `include` exists is quite unexpected.

Reply via email to