]> granicus.if.org Git - clang/commit
[VFS] Reapply #2: Reconstruct the VFS overlay tree for more accurate lookup
authorBruno Cardoso Lopes <bruno.cardoso@gmail.com>
Thu, 12 May 2016 19:13:07 +0000 (19:13 +0000)
committerBruno Cardoso Lopes <bruno.cardoso@gmail.com>
Thu, 12 May 2016 19:13:07 +0000 (19:13 +0000)
commitdfa97d29ffeeb84a150671286690bfe0fe20c6f9
tree630f8ccb758c7ad2f96b2764693378f9d3070721
parent17e4499741351547b3fadff316885fd53eeedf1b
[VFS] Reapply #2: Reconstruct the VFS overlay tree for more accurate lookup

Reapply r269100 and r269270, reverted due to
https://llvm.org/bugs/show_bug.cgi?id=27725. Isolate the testcase that
corresponds to the new feature side of this commit and skip it on
windows hosts until we find why it does not work on these platforms.

Original commit message:

The way we currently build the internal VFS overlay representation leads
to inefficient path search and might yield wrong answers when asked for
recursive or regular directory iteration.

Currently, when reading an YAML file, each YAML root entry is placed
inside a new root in the filesystem overlay. In the crash reproducer, a
simple "@import Foundation" currently maps to 43 roots, and when looking
up paths, we traverse a directory tree for each of these different
roots, until we find a match (or don't). This has two consequences:

- It's slow.
- Directory iteration gives incomplete results since it only return
results within one root - since contents of the same directory can be
declared inside different roots, the result isn't accurate.

This is in part fault of the way we currently write out the YAML file
when emitting the crash reproducer - we could generate only one root and
that would make it fast and correct again. However, we should not rely
on how the client writes the YAML, but provide a good internal
representation regardless.

Build a proper virtual directory tree out of the YAML representation,
allowing faster search and proper iteration. Besides the crash
reproducer, this potentially benefits other VFS clients.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@269327 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Basic/VirtualFileSystem.cpp
unittests/Basic/VirtualFileSystemTest.cpp