]> granicus.if.org Git - clang/commit
Fix -Wnonportable-include-path suppression for header maps with absolute paths.
authorVolodymyr Sapsai <vsapsai@apple.com>
Wed, 11 Sep 2019 20:39:04 +0000 (20:39 +0000)
committerVolodymyr Sapsai <vsapsai@apple.com>
Wed, 11 Sep 2019 20:39:04 +0000 (20:39 +0000)
commitf5d449a52774ee2e43614ab6cffd5408247a598b
tree28dc6f50c62c32c31a444d7f09f2748c226a9694
parent1c54e90089651f37705da4074d65947df2ab2cc2
Fix -Wnonportable-include-path suppression for header maps with absolute paths.

In `DirectoryLookup::LookupFile` parameter `HasBeenMapped` doesn't cover
the case when clang finds a file through a header map but doesn't remap
the lookup filename because the target path is an absolute path. As a
result, -Wnonportable-include-path suppression for header maps
introduced in r301592 wasn't triggered.

Change parameter `HasBeenMapped` to `IsInHeaderMap` and use parameter
`MappedName` to track the filename remapping. This way we can handle
both relative and absolute paths in header maps, and account for their
specific properties, like filename remapping being a property preserved
across lookups in multiple directories.

rdar://problem/39516483

Reviewers: dexonsmith, bruno

Reviewed By: dexonsmith

Subscribers: jkorous, cfe-commits, ributzka

Differential Revision: https://reviews.llvm.org/D58094

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@371655 91177308-0d34-0410-b5e6-96231b3b80d8
include/clang/Lex/DirectoryLookup.h
lib/Lex/HeaderSearch.cpp
test/Preprocessor/Inputs/nonportable-hmaps/foo.hmap.json
test/Preprocessor/Inputs/nonportable-hmaps/headers/foo/Bar.h [new file with mode: 0644]
test/Preprocessor/Inputs/nonportable-hmaps/headers/foo/Baz.h [new file with mode: 0644]
test/Preprocessor/nonportable-include-with-hmap.c