]> git.ipfire.org Git - thirdparty/gcc.git/commit - libcpp/files.cc
libcpp: Diagnose #include after failed __has_include [PR80753]
authorJakub Jelinek <jakub@redhat.com>
Thu, 15 Jun 2023 12:16:17 +0000 (14:16 +0200)
committerJakub Jelinek <jakub@redhat.com>
Thu, 15 Jun 2023 12:16:17 +0000 (14:16 +0200)
commit37f373e974ac0a272b0e2b24e27c08833ad43470
tree3b9ae31ae4c9830a7ccec2dcd33f8566f2568a58
parent73a0d3bf895b5c322676178a51ac0d68cf603953
libcpp: Diagnose #include after failed __has_include [PR80753]

As can be seen in the testcase, we don't diagnose #include/#include_next
of a non-existent header if __has_include/__has_include_next is done for
that header first.
The problem is that we normally error the first time some header is not
found, but in the _cpp_FFK_HAS_INCLUDE case obviously don't want to diagnose
it, just expand it to 0.  And libcpp caches both successful includes and
unsuccessful ones.

The following patch fixes that by remembering that we haven't diagnosed
error when using __has_include* on it, and diagnosing it when using the
cache entry in normal mode the first time.

I think _cpp_FFK_NORMAL is the only mode in which we normally diagnose
errors, for _cpp_FFK_PRE_INCLUDE that open_file_failed isn't reached
and for _cpp_FFK_FAKE neither.

2023-06-15  Jakub Jelinek  <jakub@redhat.com>

PR preprocessor/80753
libcpp/
* files.cc (struct _cpp_file): Add deferred_error bitfield.
(_cpp_find_file): When finding a file in cache with deferred_error
set in _cpp_FFK_NORMAL mode, call open_file_failed and clear the flag.
Set deferred_error in _cpp_FFK_HAS_INCLUDE mode if open_file_failed
hasn't been called.
gcc/testsuite/
* c-c++-common/missing-header-5.c: New test.
gcc/testsuite/c-c++-common/missing-header-5.c [new file with mode: 0644]
libcpp/files.cc