clang 23.0.0git
HeaderSearch.h
Go to the documentation of this file.
1//===- HeaderSearch.h - Resolve Header File Locations -----------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file defines the HeaderSearch interface.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef LLVM_CLANG_LEX_HEADERSEARCH_H
14#define LLVM_CLANG_LEX_HEADERSEARCH_H
15
20#include "clang/Lex/HeaderMap.h"
21#include "clang/Lex/ModuleMap.h"
22#include "llvm/ADT/ArrayRef.h"
23#include "llvm/ADT/DenseMap.h"
24#include "llvm/ADT/SmallString.h"
25#include "llvm/ADT/StringMap.h"
26#include "llvm/ADT/StringRef.h"
27#include "llvm/ADT/StringSet.h"
28#include "llvm/Support/Allocator.h"
29#include <cassert>
30#include <cstddef>
31#include <memory>
32#include <string>
33#include <utility>
34#include <vector>
35
36namespace llvm {
37
38class Triple;
39
40} // namespace llvm
41
42namespace clang {
43
45class DirectoryEntry;
47class FileEntry;
48class FileManager;
49class HeaderSearch;
51class IdentifierInfo;
52class LangOptions;
53class Module;
54class Preprocessor;
55class TargetInfo;
56
57/// The preprocessor keeps track of this information for each
58/// file that is \#included.
60 // TODO: Whether the file was included is not a property of the file itself.
61 // It's a preprocessor state, move it there.
62 /// True if this file has been included (or imported) **locally**.
63 LLVM_PREFERRED_TYPE(bool)
65
66 // TODO: Whether the file was imported is not a property of the file itself.
67 // It's a preprocessor state, move it there.
68 /// True if this is a \#import'd file.
69 LLVM_PREFERRED_TYPE(bool)
70 unsigned isImport : 1;
71
72 /// True if this is a \#pragma once file.
73 LLVM_PREFERRED_TYPE(bool)
74 unsigned isPragmaOnce : 1;
75
76 /// Keep track of whether this is a system header, and if so,
77 /// whether it is C++ clean or not. This can be set by the include paths or
78 /// by \#pragma gcc system_header. This is an instance of
79 /// SrcMgr::CharacteristicKind.
80 LLVM_PREFERRED_TYPE(SrcMgr::CharacteristicKind)
81 unsigned DirInfo : 3;
82
83 /// Whether this header file info was supplied by an external source,
84 /// and has not changed since.
85 LLVM_PREFERRED_TYPE(bool)
86 unsigned External : 1;
87
88 /// Whether this header is part of and built with a module. i.e. it is listed
89 /// in a module map, and is not `excluded` or `textual`. (same meaning as
90 /// `ModuleMap::isModular()`).
91 LLVM_PREFERRED_TYPE(bool)
92 unsigned isModuleHeader : 1;
93
94 /// Whether this header is a `textual header` in a module. If a header is
95 /// textual in one module and normal in another module, this bit will not be
96 /// set, only `isModuleHeader`.
97 LLVM_PREFERRED_TYPE(bool)
99
100 /// Whether this header is part of the module that we are building, even if it
101 /// doesn't build with the module. i.e. this will include `excluded` and
102 /// `textual` headers as well as normal headers.
103 LLVM_PREFERRED_TYPE(bool)
105
106 /// Whether this structure is considered to already have been
107 /// "resolved", meaning that it was loaded from the external source.
108 LLVM_PREFERRED_TYPE(bool)
109 unsigned Resolved : 1;
110
111 /// Whether this file has been looked up as a header.
112 LLVM_PREFERRED_TYPE(bool)
113 unsigned IsValid : 1;
114
115 /// If this file has a \#ifndef XXX (or equivalent) guard that
116 /// protects the entire contents of the file, this is the identifier
117 /// for the macro that controls whether or not it has any effect.
118 ///
119 /// Note: Most clients should use getControllingMacro() to access
120 /// the controlling macro of this header, since
121 /// getControllingMacro() is able to load a controlling macro from
122 /// external storage.
124
130
131 /// Retrieve the controlling macro for this header file, if
132 /// any.
133 const IdentifierInfo *
135
136 /// Update the module membership bits based on the header role.
137 ///
138 /// isModuleHeader will potentially be set, but not cleared.
139 /// isTextualModuleHeader will be set or cleared based on the role update.
141};
142
143static_assert(sizeof(HeaderFileInfo) <= 16);
144
145/// An external source of header file information, which may supply
146/// information about header files already included.
148public:
150
151 /// Retrieve the header file information for the given file entry.
152 ///
153 /// \returns Header file information for the given file entry, with the
154 /// \c External bit set. If the file entry is not known, return a
155 /// default-constructed \c HeaderFileInfo.
157};
158
159/// This structure is used to record entries in our framework cache.
161 /// The directory entry which should be used for the cached framework.
163
164 /// Whether this framework has been "user-specified" to be treated as if it
165 /// were a system framework (even if it was found outside a system framework
166 /// directory).
168};
169
170namespace detail {
171template <bool Const, typename T>
172using Qualified = std::conditional_t<Const, const T, T>;
173
174/// Forward iterator over the search directories of \c HeaderSearch.
175template <bool IsConst>
177 : llvm::iterator_facade_base<SearchDirIteratorImpl<IsConst>,
178 std::forward_iterator_tag,
179 Qualified<IsConst, DirectoryLookup>> {
180 /// Const -> non-const iterator conversion.
181 template <typename Enable = std::enable_if<IsConst, bool>>
184
186
188
189 bool operator==(const SearchDirIteratorImpl &RHS) const {
190 return HS == RHS.HS && Idx == RHS.Idx;
191 }
192
194 assert(*this && "Invalid iterator.");
195 ++Idx;
196 return *this;
197 }
198
200 assert(*this && "Invalid iterator.");
201 return HS->SearchDirs[Idx];
202 }
203
204 /// Creates an invalid iterator.
205 SearchDirIteratorImpl(std::nullptr_t) : HS(nullptr), Idx(0) {}
206
207 /// Checks whether the iterator is valid.
208 explicit operator bool() const { return HS != nullptr; }
209
210private:
211 /// The parent \c HeaderSearch. This is \c nullptr for invalid iterator.
213
214 /// The index of the current element.
215 size_t Idx;
216
217 /// The constructor that creates a valid iterator.
219 : HS(&HS), Idx(Idx) {}
220
221 /// Only HeaderSearch is allowed to instantiate valid iterators.
222 friend HeaderSearch;
223
224 /// Enables const -> non-const conversion.
225 friend SearchDirIteratorImpl<!IsConst>;
226};
227} // namespace detail
228
231
232using ConstSearchDirRange = llvm::iterator_range<ConstSearchDirIterator>;
233using SearchDirRange = llvm::iterator_range<SearchDirIterator>;
234
235/// Encapsulates the information needed to find the file referenced
236/// by a \#include or \#include_next, (sub-)framework lookup, etc.
238 friend class DirectoryLookup;
239
240 friend ConstSearchDirIterator;
241 friend SearchDirIterator;
242
243 /// Header-search options used to initialize this header search.
244 const HeaderSearchOptions &HSOpts;
245
246 /// Mapping from SearchDir to HeaderSearchOptions::UserEntries indices.
247 llvm::DenseMap<unsigned, unsigned> SearchDirToHSEntry;
248
249 DiagnosticsEngine &Diags;
250 FileManager &FileMgr;
251
252 /// \#include search path information. Requests for \#include "x" search the
253 /// directory of the \#including file first, then each directory in SearchDirs
254 /// consecutively. Requests for <x> search the current dir first, then each
255 /// directory in SearchDirs, starting at AngledDirIdx, consecutively.
256 std::vector<DirectoryLookup> SearchDirs;
257 /// Whether the DirectoryLookup at the corresponding index in SearchDirs has
258 /// been successfully used to lookup a file.
259 std::vector<bool> SearchDirsUsage;
260 unsigned AngledDirIdx = 0;
261 unsigned SystemDirIdx = 0;
262
263 /// Maps HeaderMap keys to SearchDir indices. When HeaderMaps are used
264 /// heavily, SearchDirs can start with thousands of HeaderMaps, so this Index
265 /// lets us avoid scanning them all to find a match.
266 llvm::StringMap<unsigned, llvm::BumpPtrAllocator> SearchDirHeaderMapIndex;
267
268 /// The index of the first SearchDir that isn't a header map.
269 unsigned FirstNonHeaderMapSearchDirIdx = 0;
270
271 /// \#include prefixes for which the 'system header' property is
272 /// overridden.
273 ///
274 /// For a \#include "x" or \#include <x> directive, the last string in this
275 /// list which is a prefix of 'x' determines whether the file is treated as
276 /// a system header.
277 std::vector<std::pair<std::string, bool>> SystemHeaderPrefixes;
278
279 /// The context hash used in SpecificModuleCachePath (unless suppressed).
280 std::string ContextHash;
281
282 /// The specific module cache path containing ContextHash (unless suppressed).
283 std::string SpecificModuleCachePath;
284
285 /// The length of the normalized module cache path at the start of \c
286 /// SpecificModuleCachePath.
287 size_t NormalizedModuleCachePathLen = 0;
288
289 /// All of the preprocessor-specific data about files that are
290 /// included, indexed by the FileEntry's UID.
291 mutable std::vector<HeaderFileInfo> FileInfo;
292
293 /// Keeps track of each lookup performed by LookupFile.
294 struct LookupFileCacheInfo {
295 // The requesting module for the lookup we cached.
296 const Module *RequestingModule = nullptr;
297
298 /// Starting search directory iterator that the cached search was performed
299 /// from. If there is a hit and this value doesn't match the current query,
300 /// the cache has to be ignored.
301 ConstSearchDirIterator StartIt = nullptr;
302
303 /// The search directory iterator that satisfied the query.
304 ConstSearchDirIterator HitIt = nullptr;
305
306 /// This is non-null if the original filename was mapped to a framework
307 /// include via a headermap.
308 const char *MappedName = nullptr;
309
310 /// Default constructor -- Initialize all members with zero.
311 LookupFileCacheInfo() = default;
312
313 void reset(const Module *NewRequestingModule,
314 ConstSearchDirIterator NewStartIt) {
315 RequestingModule = NewRequestingModule;
316 StartIt = NewStartIt;
317 MappedName = nullptr;
318 }
319 };
320 llvm::StringMap<LookupFileCacheInfo, llvm::BumpPtrAllocator> LookupFileCache;
321
322 /// Collection mapping a framework or subframework
323 /// name like "Carbon" to the Carbon.framework directory.
324 llvm::StringMap<FrameworkCacheEntry, llvm::BumpPtrAllocator> FrameworkMap;
325
326 /// Maps include file names (including the quotes or
327 /// angle brackets) to other include file names. This is used to support the
328 /// include_alias pragma for Microsoft compatibility.
329 using IncludeAliasMap =
330 llvm::StringMap<std::string, llvm::BumpPtrAllocator>;
331 std::unique_ptr<IncludeAliasMap> IncludeAliases;
332
333 /// This is a mapping from FileEntry -> HeaderMap, uniquing headermaps.
334 std::vector<std::pair<FileEntryRef, std::unique_ptr<HeaderMap>>> HeaderMaps;
335
336 /// The mapping between modules and headers.
337 mutable ModuleMap ModMap;
338
339 struct ModuleMapDirectoryState {
340 OptionalFileEntryRef ModuleMapFile;
341 OptionalFileEntryRef PrivateModuleMapFile;
342 enum {
343 Parsed,
344 Loaded,
345 Invalid,
346 } Status;
347
348 /// Relative header path -> list of module names
349 llvm::StringMap<llvm::SmallVector<StringRef, 1>> HeaderToModules{};
350 /// Relative dir path -> module name
351 llvm::SmallVector<std::pair<std::string, StringRef>, 2>
352 UmbrellaDirModules{};
353 /// List of module names with umbrella header decls
354 llvm::SmallVector<StringRef, 2> UmbrellaHeaderModules{};
355 };
356
357 /// Describes whether a given directory has a module map in it.
358 llvm::DenseMap<const DirectoryEntry *, ModuleMapDirectoryState>
359 DirectoryModuleMap;
360
361 /// Set of module map files we've already loaded, and a flag indicating
362 /// whether they were valid or not.
363 llvm::DenseMap<const FileEntry *, bool> LoadedModuleMaps;
364
365 /// Set of module map files we've already parsed, and a flag indicating
366 /// whether they were valid or not.
367 llvm::DenseMap<const FileEntry *, bool> ParsedModuleMaps;
368
369 // A map of discovered headers with their associated include file name.
370 llvm::DenseMap<const FileEntry *, llvm::SmallString<64>> IncludeNames;
371
372 /// Uniqued set of framework names, which is used to track which
373 /// headers were included as framework headers.
374 llvm::StringSet<llvm::BumpPtrAllocator> FrameworkNames;
375
376 /// Entity used to resolve the identifier IDs of controlling
377 /// macros into IdentifierInfo pointers, and keep the identifire up to date,
378 /// as needed.
379 ExternalPreprocessorSource *ExternalLookup = nullptr;
380
381 /// Entity used to look up stored header file information.
382 ExternalHeaderFileInfoSource *ExternalSource = nullptr;
383
384 /// Scan all of the header maps at the beginning of SearchDirs and
385 /// map their keys to the SearchDir index of their header map.
386 void indexInitialHeaderMaps();
387
388 /// Build the module map index for a directory's module map.
389 ///
390 /// This fills a ModuleMapDirectoryState with index information from its
391 /// directory's module map.
392 void buildModuleMapIndex(DirectoryEntryRef Dir,
393 ModuleMapDirectoryState &MMState);
394
395 void processModuleMapForIndex(const modulemap::ModuleMapFile &MMF,
396 DirectoryEntryRef MMDir, StringRef PathPrefix,
397 ModuleMapDirectoryState &MMState);
398
399 void processExternModuleDeclForIndex(const modulemap::ExternModuleDecl &EMD,
400 DirectoryEntryRef MMDir,
401 StringRef PathPrefix,
402 ModuleMapDirectoryState &MMState);
403
404 void processModuleDeclForIndex(const modulemap::ModuleDecl &MD,
405 StringRef ModuleName, DirectoryEntryRef MMDir,
406 StringRef PathPrefix,
407 ModuleMapDirectoryState &MMState);
408
409 void addToModuleMapIndex(StringRef RelPath, StringRef ModuleName,
410 StringRef PathPrefix,
411 ModuleMapDirectoryState &MMState);
412
413 /// Check if a relative path would be covered by the module map index.
414 /// Returns the module names that would cover this path.
415 SmallVector<StringRef, 1>
416 findMatchingModulesInIndex(StringRef RelativePath,
417 const ModuleMapDirectoryState &MMState) const;
418
419public:
420 HeaderSearch(const HeaderSearchOptions &HSOpts, SourceManager &SourceMgr,
421 DiagnosticsEngine &Diags, const LangOptions &LangOpts,
422 const TargetInfo *Target);
423 HeaderSearch(const HeaderSearch &) = delete;
425
426 /// Retrieve the header-search options with which this header search
427 /// was initialized.
428 const HeaderSearchOptions &getHeaderSearchOpts() const { return HSOpts; }
429
430 FileManager &getFileMgr() const { return FileMgr; }
431
432 DiagnosticsEngine &getDiags() const { return Diags; }
433
434 /// Interface for setting the file search paths.
435 void SetSearchPaths(std::vector<DirectoryLookup> dirs, unsigned angledDirIdx,
436 unsigned systemDirIdx,
437 llvm::DenseMap<unsigned, unsigned> searchDirToHSEntry);
438
439 /// Add an additional search path.
440 void AddSearchPath(const DirectoryLookup &dir, bool isAngled);
441
442 /// Add an additional system search path.
444 SearchDirs.push_back(dir);
445 SearchDirsUsage.push_back(false);
446 }
447
448 /// Set the list of system header prefixes.
449 void SetSystemHeaderPrefixes(ArrayRef<std::pair<std::string, bool>> P) {
450 SystemHeaderPrefixes.assign(P.begin(), P.end());
451 }
452
453 /// Checks whether the map exists or not.
454 bool HasIncludeAliasMap() const { return (bool)IncludeAliases; }
455
456 /// Map the source include name to the dest include name.
457 ///
458 /// The Source should include the angle brackets or quotes, the dest
459 /// should not. This allows for distinction between <> and "" headers.
460 void AddIncludeAlias(StringRef Source, StringRef Dest) {
461 if (!IncludeAliases)
462 IncludeAliases.reset(new IncludeAliasMap);
463 (*IncludeAliases)[Source] = std::string(Dest);
464 }
465
466 /// Maps one header file name to a different header
467 /// file name, for use with the include_alias pragma. Note that the source
468 /// file name should include the angle brackets or quotes. Returns StringRef
469 /// as null if the header cannot be mapped.
470 StringRef MapHeaderToIncludeAlias(StringRef Source) {
471 assert(IncludeAliases && "Trying to map headers when there's no map");
472
473 // Do any filename replacements before anything else
474 IncludeAliasMap::const_iterator Iter = IncludeAliases->find(Source);
475 if (Iter != IncludeAliases->end())
476 return Iter->second;
477 return {};
478 }
479
480 /// Initialize the module cache path.
481 void initializeModuleCachePath(std::string ContextHash);
482
483 /// Retrieve the specific module cache path. This is the normalized module
484 /// cache path plus the context hash (unless suppressed).
485 StringRef getSpecificModuleCachePath() const {
486 return SpecificModuleCachePath;
487 }
488
489 /// Retrieve the context hash.
490 StringRef getContextHash() const { return ContextHash; }
491
492 /// Retrieve the normalized module cache path. This is the path as provided on
493 /// the command line, but absolute, without './' components, and with
494 /// preferred path separators. Note that this does not have the context hash.
496 return getSpecificModuleCachePath().substr(0, NormalizedModuleCachePathLen);
497 }
498
499 /// Forget everything we know about headers so far.
501 FileInfo.clear();
502 }
503
505 ExternalLookup = EPS;
506 }
507
509 return ExternalLookup;
510 }
511
512 /// Set the external source of header information.
514 ExternalSource = ES;
515 }
516
518 StringRef Filename, OptionalFileEntryRef FE, bool &DiagnosedShadowing,
519 SourceLocation IncludeLoc, ConstSearchDirIterator FromDir,
520 ArrayRef<std::pair<OptionalFileEntryRef, DirectoryEntryRef>> Includers,
521 bool isAngled, int IncluderLoopIndex, ConstSearchDirIterator MainLoopIt);
522
523 /// Set the target information for the header search, if not
524 /// already known.
525 void setTarget(const TargetInfo &Target);
526
527 /// Given a "foo" or <foo> reference, look up the indicated file,
528 /// return null on failure.
529 ///
530 /// \returns If successful, this returns 'UsedDir', the DirectoryLookup member
531 /// the file was found in, or null if not applicable.
532 ///
533 /// \param IncludeLoc Used for diagnostics if valid.
534 ///
535 /// \param isAngled indicates whether the file reference is a <> reference.
536 ///
537 /// \param CurDir If non-null, the file was found in the specified directory
538 /// search location. This is used to implement \#include_next.
539 ///
540 /// \param Includers Indicates where the \#including file(s) are, in case
541 /// relative searches are needed. In reverse order of inclusion.
542 ///
543 /// \param SearchPath If non-null, will be set to the search path relative
544 /// to which the file was found. If the include path is absolute, SearchPath
545 /// will be set to an empty string.
546 ///
547 /// \param RelativePath If non-null, will be set to the path relative to
548 /// SearchPath at which the file was found. This only differs from the
549 /// Filename for framework includes.
550 ///
551 /// \param SuggestedModule If non-null, and the file found is semantically
552 /// part of a known module, this will be set to the module that should
553 /// be imported instead of preprocessing/parsing the file found.
554 ///
555 /// \param IsMapped If non-null, and the search involved header maps, set to
556 /// true.
557 ///
558 /// \param IsFrameworkFound If non-null, will be set to true if a framework is
559 /// found in any of searched SearchDirs. Will be set to false if a framework
560 /// is found only through header maps. Doesn't guarantee the requested file is
561 /// found.
563 StringRef Filename, SourceLocation IncludeLoc, bool isAngled,
565 ArrayRef<std::pair<OptionalFileEntryRef, DirectoryEntryRef>> Includers,
566 SmallVectorImpl<char> *SearchPath, SmallVectorImpl<char> *RelativePath,
567 Module *RequestingModule, ModuleMap::KnownHeader *SuggestedModule,
568 bool *IsMapped, bool *IsFrameworkFound, bool SkipCache = false,
569 bool BuildSystemModule = false, bool OpenFile = true,
570 bool CacheFailures = true);
571
572 /// Look up a subframework for the specified \#include file.
573 ///
574 /// For example, if \#include'ing <HIToolbox/HIToolbox.h> from
575 /// within ".../Carbon.framework/Headers/Carbon.h", check to see if
576 /// HIToolbox is a subframework within Carbon.framework. If so, return
577 /// the FileEntry for the designated file, otherwise return null.
579 StringRef Filename, FileEntryRef ContextFileEnt,
580 SmallVectorImpl<char> *SearchPath, SmallVectorImpl<char> *RelativePath,
581 Module *RequestingModule, ModuleMap::KnownHeader *SuggestedModule);
582
583 /// Look up the specified framework name in our framework cache.
584 /// \returns The DirectoryEntry it is in if we know, null otherwise.
586 return FrameworkMap[FWName];
587 }
588
589 /// Mark the specified file as a target of a \#include,
590 /// \#include_next, or \#import directive.
591 ///
592 /// \return false if \#including the file will have no effect or true
593 /// if we should include it.
594 ///
595 /// \param M The module to which `File` belongs (this should usually be the
596 /// SuggestedModule returned by LookupFile/LookupSubframeworkHeader)
598 bool isImport, bool ModulesEnabled, Module *M,
599 bool &IsFirstIncludeOfFile);
600
601 /// Return whether the specified file is a normal header,
602 /// a system header, or a C++ friendly system header.
608
609 /// Mark the specified file as a "once only" file due to
610 /// \#pragma once.
614
615 /// Mark the specified file as a system header, e.g. due to
616 /// \#pragma GCC system_header.
620
621 /// Mark the specified file as part of a module.
623 bool isCompilingModuleHeader);
624
625 /// Mark the specified file as having a controlling macro.
626 ///
627 /// This is used by the multiple-include optimization to eliminate
628 /// no-op \#includes.
630 const IdentifierInfo *ControllingMacro) {
631 getFileInfo(File).LazyControllingMacro = ControllingMacro;
632 }
633
634 /// Determine whether this file is intended to be safe from
635 /// multiple inclusions, e.g., it has \#pragma once or a controlling
636 /// macro.
637 ///
638 /// This routine does not consider the effect of \#import
640
641 /// Determine whether the given file is known to have ever been \#imported.
644 return FI && FI->isImport;
645 }
646
647 /// Determine which HeaderSearchOptions::UserEntries have been successfully
648 /// used so far and mark their index with 'true' in the resulting bit vector.
649 /// Note: implicit module maps don't contribute to entry usage.
650 std::vector<bool> computeUserEntryUsage() const;
651
652 /// Collect which HeaderSearchOptions::VFSOverlayFiles have been meaningfully
653 /// used so far and mark their index with 'true' in the resulting bit vector.
654 ///
655 /// Note: this ignores VFSs that redirect non-affecting files such as unused
656 /// modulemaps.
657 std::vector<bool> collectVFSUsageAndClear() const;
658
659 /// This method returns a HeaderMap for the specified
660 /// FileEntry, uniquing them through the 'HeaderMaps' datastructure.
662
663 /// Get filenames for all registered header maps.
665
666 /// Retrieve the name of the cached module file that should be used
667 /// to load the given module.
668 ///
669 /// \param Module The module whose module file name will be returned.
670 ///
671 /// \returns The name of the module file that corresponds to this module,
672 /// or an empty string if this module does not correspond to any module file.
674
675 /// Retrieve the name of the prebuilt module file that should be used
676 /// to load a module with the given name.
677 ///
678 /// \param ModuleName The module whose module file name will be returned.
679 ///
680 /// \param FileMapOnly If true, then only look in the explicit module name
681 // to file name map and skip the directory search.
682 ///
683 /// \returns The name of the module file that corresponds to this module,
684 /// or an empty string if this module does not correspond to any module file.
685 ModuleFileName getPrebuiltModuleFileName(StringRef ModuleName,
686 bool FileMapOnly = false);
687
688 /// Retrieve the name of the prebuilt module file that should be used
689 /// to load the given module.
690 ///
691 /// \param Module The module whose module file name will be returned.
692 ///
693 /// \returns The name of the module file that corresponds to this module,
694 /// or an empty string if this module does not correspond to any module file.
696
697 /// Retrieve the name of the (to-be-)cached module file that should
698 /// be used to load a module with the given name.
699 ///
700 /// \param ModuleName The module whose module file name will be returned.
701 ///
702 /// \param ModuleMapPath A path that when combined with \c ModuleName
703 /// uniquely identifies this module. See Module::ModuleMap.
704 ///
705 /// \returns The name of the module file that corresponds to this module,
706 /// or an empty string if this module does not correspond to any module file.
707 ModuleFileName getCachedModuleFileName(StringRef ModuleName,
708 StringRef ModuleMapPath);
709
710 /// Lookup a module Search for a module with the given name.
711 ///
712 /// \param ModuleName The name of the module we're looking for.
713 ///
714 /// \param ImportLoc Location of the module include/import.
715 ///
716 /// \param AllowSearch Whether we are allowed to search in the various
717 /// search directories to produce a module definition. If not, this lookup
718 /// will only return an already-known module.
719 ///
720 /// \param AllowExtraModuleMapSearch Whether we allow to search modulemaps
721 /// in subdirectories.
722 ///
723 /// \returns The module with the given name.
724 Module *lookupModule(StringRef ModuleName,
725 SourceLocation ImportLoc = SourceLocation(),
726 bool AllowSearch = true,
727 bool AllowExtraModuleMapSearch = false);
728
729 /// Try to find a module map file in the given directory, returning
730 /// \c nullopt if none is found.
732 bool IsFramework);
733
734 /// Determine whether there is a module map that may map the header
735 /// with the given file name to a (sub)module.
736 /// Always returns false if modules are disabled.
737 ///
738 /// \param Filename The name of the file.
739 ///
740 /// \param Root The "root" directory, at which we should stop looking for
741 /// module maps.
742 ///
743 /// \param IsSystem Whether the directories we're looking at are system
744 /// header directories.
745 bool hasModuleMap(StringRef Filename, const DirectoryEntry *Root,
746 bool IsSystem);
747
748 /// Retrieve the module that corresponds to the given file, if any.
749 ///
750 /// \param File The header that we wish to map to a module.
751 /// \param AllowTextual Whether we want to find textual headers too.
753 bool AllowTextual = false,
754 bool AllowExcluded = false) const;
755
756 /// Retrieve all the modules corresponding to the given file.
757 ///
758 /// \ref findModuleForHeader should typically be used instead of this.
761
762 /// Like \ref findAllModulesForHeader, but do not attempt to infer module
763 /// ownership from umbrella headers if we've not already done so.
766
767 /// Read the contents of the given module map file.
768 ///
769 /// \param File The module map file.
770 /// \param IsSystem Whether this file is in a system header directory.
771 /// \param ImplicitlyDiscovered Whether this file was found by module map
772 /// search.
773 /// \param ID If the module map file is already mapped (perhaps as part of
774 /// processing a preprocessed module), the ID of the file.
775 /// \param Offset [inout] An offset within ID to start parsing. On exit,
776 /// filled by the end of the parsed contents (either EOF or the
777 /// location of an end-of-module-map pragma).
778 /// \param OriginalModuleMapFile The original path to the module map file,
779 /// used to resolve paths within the module (this is required when
780 /// building the module from preprocessed source).
781 /// \returns true if an error occurred, false otherwise.
782 bool parseAndLoadModuleMapFile(FileEntryRef File, bool IsSystem,
783 bool ImplicitlyDiscovered,
784 FileID ID = FileID(),
785 unsigned *Offset = nullptr,
786 StringRef OriginalModuleMapFile = StringRef());
787
788 /// Collect the set of all known, top-level modules.
789 ///
790 /// \param Modules Will be filled with the set of known, top-level modules.
792
793 /// Load all known, top-level system modules.
795
796private:
797 /// Lookup a module with the given module name and search-name.
798 ///
799 /// \param ModuleName The name of the module we're looking for.
800 ///
801 /// \param SearchName The "search-name" to derive filesystem paths from
802 /// when looking for the module map; this is usually equal to ModuleName,
803 /// but for compatibility with some buggy frameworks, additional attempts
804 /// may be made to find the module under a related-but-different search-name.
805 ///
806 /// \param ImportLoc Location of the module include/import.
807 ///
808 /// \param AllowExtraModuleMapSearch Whether we allow to search modulemaps
809 /// in subdirectories.
810 ///
811 /// \returns The module named ModuleName.
812 Module *lookupModule(StringRef ModuleName, StringRef SearchName,
813 SourceLocation ImportLoc,
814 bool AllowExtraModuleMapSearch = false);
815
816 /// Retrieve the name of the (to-be-)cached module file that should
817 /// be used to load a module with the given name.
818 ///
819 /// \param ModuleName The module whose module file name will be returned.
820 ///
821 /// \param ModuleMapPath A path that when combined with \c ModuleName
822 /// uniquely identifies this module. See Module::ModuleMap.
823 ///
824 /// \param NormalizedCachePath The normalized path to the module cache.
825 ///
826 /// \returns The name of the module file that corresponds to this module,
827 /// or an empty string if this module does not correspond to any module file.
828 ModuleFileName getCachedModuleFileNameImpl(StringRef ModuleName,
829 StringRef ModuleMapPath,
830 StringRef NormalizedCachePath);
831
832 /// Retrieve a module with the given name, which may be part of the
833 /// given framework.
834 ///
835 /// \param Name The name of the module to retrieve.
836 ///
837 /// \param Dir The framework directory (e.g., ModuleName.framework).
838 ///
839 /// \param IsSystem Whether the framework directory is part of the system
840 /// frameworks.
841 ///
842 /// \param ImplicitlyDiscovered Whether the framework was discovered by module
843 /// map search.
844 ///
845 /// \returns The module, if found; otherwise, null.
846 Module *loadFrameworkModule(StringRef Name, DirectoryEntryRef Dir,
847 bool IsSystem, bool ImplicitlyDiscovered);
848
849 /// Load all of the module maps within the immediate subdirectories
850 /// of the given search directory.
851 void loadSubdirectoryModuleMaps(DirectoryLookup &SearchDir);
852
853 /// Diagnose headers that are a symlink and not covered by a module map.
854 void diagnoseUncoveredSymlink(FileEntryRef File,
856 const DirectoryEntry *Root);
857
858 /// Find and suggest a usable module for the given file.
859 ///
860 /// \return \c true if the file can be used, \c false if we are not permitted to
861 /// find this file due to requirements from \p RequestingModule.
862 bool findUsableModuleForHeader(FileEntryRef File, const DirectoryEntry *Root,
863 Module *RequestingModule,
864 ModuleMap::KnownHeader *SuggestedModule,
865 bool IsSystemHeaderDir);
866
867 /// Find and suggest a usable module for the given file, which is part of
868 /// the specified framework.
869 ///
870 /// \return \c true if the file can be used, \c false if we are not permitted to
871 /// find this file due to requirements from \p RequestingModule.
872 bool findUsableModuleForFrameworkHeader(
873 FileEntryRef File, StringRef FrameworkName, Module *RequestingModule,
874 ModuleMap::KnownHeader *SuggestedModule, bool IsSystemFramework);
875
876 /// Look up the file with the specified name and determine its owning
877 /// module.
879 getFileAndSuggestModule(StringRef FileName, SourceLocation IncludeLoc,
880 const DirectoryEntry *Dir, bool IsSystemHeaderDir,
881 Module *RequestingModule,
882 ModuleMap::KnownHeader *SuggestedModule,
883 bool OpenFile = true, bool CacheFailures = true);
884
885 /// Cache the result of a successful lookup at the given include location
886 /// using the search path at \c HitIt.
887 void cacheLookupSuccess(LookupFileCacheInfo &CacheLookup,
889 SourceLocation IncludeLoc);
890
891 /// Note that a lookup at the given include location was successful using the
892 /// search path at index `HitIdx`.
893 void noteLookupUsage(unsigned HitIdx, SourceLocation IncludeLoc);
894
895public:
896 /// Retrieve the module map.
897 ModuleMap &getModuleMap() { return ModMap; }
898
899 /// Retrieve the module map.
900 const ModuleMap &getModuleMap() const { return ModMap; }
901
902 unsigned header_file_size() const { return FileInfo.size(); }
903
904 /// Return the HeaderFileInfo structure for the specified FileEntry, in
905 /// preparation for updating it in some way.
907
908 /// Return the HeaderFileInfo structure for the specified FileEntry, if it has
909 /// ever been filled in (either locally or externally).
911
912 /// Return the headerFileInfo structure for the specified FileEntry, if it has
913 /// ever been filled in locally.
915
916 SearchDirIterator search_dir_begin() { return {*this, 0}; }
917 SearchDirIterator search_dir_end() { return {*this, SearchDirs.size()}; }
921
922 ConstSearchDirIterator search_dir_begin() const { return quoted_dir_begin(); }
923 ConstSearchDirIterator search_dir_nth(size_t n) const {
924 assert(n < SearchDirs.size());
925 return {*this, n};
926 }
927 ConstSearchDirIterator search_dir_end() const { return system_dir_end(); }
931
932 unsigned search_dir_size() const { return SearchDirs.size(); }
933
934 ConstSearchDirIterator quoted_dir_begin() const { return {*this, 0}; }
935 ConstSearchDirIterator quoted_dir_end() const { return angled_dir_begin(); }
936
937 ConstSearchDirIterator angled_dir_begin() const {
938 return {*this, AngledDirIdx};
939 }
940 ConstSearchDirIterator angled_dir_end() const { return system_dir_begin(); }
941
942 ConstSearchDirIterator system_dir_begin() const {
943 return {*this, SystemDirIdx};
944 }
945 ConstSearchDirIterator system_dir_end() const {
946 return {*this, SearchDirs.size()};
947 }
948
949 /// Get the index of the given search directory.
950 unsigned searchDirIdx(const DirectoryLookup &DL) const;
951
952 /// Retrieve a uniqued framework name.
953 StringRef getUniqueFrameworkName(StringRef Framework);
954
955 /// Retrieve the include name for the header.
956 ///
957 /// \param File The entry for a given header.
958 /// \returns The name of how the file was included when the header's location
959 /// was resolved.
960 StringRef getIncludeNameForHeader(const FileEntry *File) const;
961
962 /// Suggest a path by which the specified file could be found, for use in
963 /// diagnostics to suggest a #include. Returned path will only contain forward
964 /// slashes as separators. MainFile is the absolute path of the file that we
965 /// are generating the diagnostics for. It will try to shorten the path using
966 /// MainFile location, if none of the include search directories were prefix
967 /// of File.
968 ///
969 /// \param IsAngled If non-null, filled in to indicate whether the suggested
970 /// path should be referenced as <Header.h> instead of "Header.h".
972 llvm::StringRef MainFile,
973 bool *IsAngled = nullptr) const;
974
975 /// Suggest a path by which the specified file could be found, for use in
976 /// diagnostics to suggest a #include. Returned path will only contain forward
977 /// slashes as separators. MainFile is the absolute path of the file that we
978 /// are generating the diagnostics for. It will try to shorten the path using
979 /// MainFile location, if none of the include search directories were prefix
980 /// of File.
981 ///
982 /// \param WorkingDir If non-empty, this will be prepended to search directory
983 /// paths that are relative.
984 std::string suggestPathToFileForDiagnostics(llvm::StringRef File,
985 llvm::StringRef WorkingDir,
986 llvm::StringRef MainFile,
987 bool *IsAngled = nullptr) const;
988
989 void PrintStats();
990
991 size_t getTotalMemory() const;
992
993private:
994 /// Describes what happened when we tried to load or parse a module map file.
995 enum ModuleMapResult {
996 /// The module map file had already been processed.
997 MMR_AlreadyProcessed,
998
999 /// The module map file was processed by this invocation.
1000 MMR_NewlyProcessed,
1001
1002 /// There is was directory with the given name.
1003 MMR_NoDirectory,
1004
1005 /// There was either no module map file or the module map file was
1006 /// invalid.
1007 MMR_InvalidModuleMap
1008 };
1009
1010 ModuleMapResult parseAndLoadModuleMapFileImpl(
1011 FileEntryRef File, bool IsSystem, bool ImplicitlyDiscovered,
1012 DirectoryEntryRef Dir, FileID ID = FileID(), unsigned *Offset = nullptr,
1013 bool DiagnosePrivMMap = false);
1014
1015 ModuleMapResult parseModuleMapFileImpl(FileEntryRef File, bool IsSystem,
1016 bool ImplicitlyDiscovered,
1017 DirectoryEntryRef Dir,
1018 FileID ID = FileID());
1019
1020 /// Try to load the module map file in the given directory.
1021 ///
1022 /// \param DirName The name of the directory where we will look for a module
1023 /// map file.
1024 /// \param IsSystem Whether this is a system header directory.
1025 /// \param IsFramework Whether this is a framework directory.
1026 ///
1027 /// \returns The result of attempting to load the module map file from the
1028 /// named directory.
1029 ModuleMapResult parseAndLoadModuleMapFile(StringRef DirName, bool IsSystem,
1030 bool ImplicitlyDiscovered,
1031 bool IsFramework);
1032
1033 /// Try to load the module map file in the given directory.
1034 ///
1035 /// \param Dir The directory where we will look for a module map file.
1036 /// \param IsSystem Whether this is a system header directory.
1037 /// \param IsFramework Whether this is a framework directory.
1038 ///
1039 /// \returns The result of attempting to load the module map file from the
1040 /// named directory.
1041 ModuleMapResult parseAndLoadModuleMapFile(DirectoryEntryRef Dir,
1042 bool IsSystem,
1043 bool ImplicitlyDiscovered,
1044 bool IsFramework);
1045
1046 ModuleMapResult parseModuleMapFile(StringRef DirName, bool IsSystem,
1047 bool ImplicitlyDiscovered,
1048 bool IsFramework);
1049 ModuleMapResult parseModuleMapFile(DirectoryEntryRef Dir, bool IsSystem,
1050 bool ImplicitlyDiscovered,
1051 bool IsFramework);
1052};
1053
1054/// Apply the header search options to get given HeaderSearch object.
1056 const HeaderSearchOptions &HSOpts,
1057 const LangOptions &Lang,
1058 const llvm::Triple &triple);
1059
1060void normalizeModuleCachePath(FileManager &FileMgr, StringRef Path,
1061 SmallVectorImpl<char> &NormalizedPath);
1062
1064 StringRef ModuleCachePath,
1065 bool DisableModuleHash,
1066 std::string ContextHash);
1067
1068} // namespace clang
1069
1070#endif // LLVM_CLANG_LEX_HEADERSEARCH_H
std::shared_ptr< TokenRole > Role
A token can have a special role that can carry extra information about the token's formatting.
Defines the clang::SourceLocation class and associated facilities.
Defines the SourceManager interface.
Concrete class used by the front-end to report problems and issues.
Definition Diagnostic.h:233
A reference to a DirectoryEntry that includes the name of the directory as it was accessed by the Fil...
Cached information about one directory (either on disk or in the virtual file system).
DirectoryLookup - This class represents one entry in the search list that specifies the search order ...
An external source of header file information, which may supply information about header files alread...
virtual HeaderFileInfo GetHeaderFileInfo(FileEntryRef FE)=0
Retrieve the header file information for the given file entry.
Abstract interface for external sources of preprocessor information.
A reference to a FileEntry that includes the name of the file as it was accessed by the FileManager's...
Definition FileEntry.h:57
Cached information about one file (either on disk or in the virtual file system).
Definition FileEntry.h:302
An opaque identifier used by SourceManager which refers to a source file (MemoryBuffer) along with it...
Implements support for file system lookup, file system caching, and directory search management.
Definition FileManager.h:53
This class represents an Apple concept known as a 'header map'.
Definition HeaderMap.h:84
HeaderSearchOptions - Helper class for storing options related to the initialization of the HeaderSea...
Encapsulates the information needed to find the file referenced by a #include or #include_next,...
StringRef getUniqueFrameworkName(StringRef Framework)
Retrieve a uniqued framework name.
void SetExternalSource(ExternalHeaderFileInfoSource *ES)
Set the external source of header information.
HeaderSearch & operator=(const HeaderSearch &)=delete
unsigned search_dir_size() const
std::vector< bool > collectVFSUsageAndClear() const
Collect which HeaderSearchOptions::VFSOverlayFiles have been meaningfully used so far and mark their ...
SrcMgr::CharacteristicKind getFileDirFlavor(FileEntryRef File)
Return whether the specified file is a normal header, a system header, or a C++ friendly system heade...
FileManager & getFileMgr() const
void AddSearchPath(const DirectoryLookup &dir, bool isAngled)
Add an additional search path.
void diagnoseHeaderShadowing(StringRef Filename, OptionalFileEntryRef FE, bool &DiagnosedShadowing, SourceLocation IncludeLoc, ConstSearchDirIterator FromDir, ArrayRef< std::pair< OptionalFileEntryRef, DirectoryEntryRef > > Includers, bool isAngled, int IncluderLoopIndex, ConstSearchDirIterator MainLoopIt)
ConstSearchDirIterator angled_dir_end() const
Module * lookupModule(StringRef ModuleName, SourceLocation ImportLoc=SourceLocation(), bool AllowSearch=true, bool AllowExtraModuleMapSearch=false)
Lookup a module Search for a module with the given name.
void SetFileControllingMacro(FileEntryRef File, const IdentifierInfo *ControllingMacro)
Mark the specified file as having a controlling macro.
DiagnosticsEngine & getDiags() const
void MarkFileIncludeOnce(FileEntryRef File)
Mark the specified file as a "once only" file due to #pragma once.
ConstSearchDirIterator system_dir_begin() const
HeaderSearch(const HeaderSearch &)=delete
friend class DirectoryLookup
bool hasModuleMap(StringRef Filename, const DirectoryEntry *Root, bool IsSystem)
Determine whether there is a module map that may map the header with the given file name to a (sub)mo...
std::string suggestPathToFileForDiagnostics(FileEntryRef File, llvm::StringRef MainFile, bool *IsAngled=nullptr) const
Suggest a path by which the specified file could be found, for use in diagnostics to suggest a includ...
const HeaderFileInfo * getExistingLocalFileInfo(FileEntryRef FE) const
Return the headerFileInfo structure for the specified FileEntry, if it has ever been filled in locall...
ConstSearchDirIterator search_dir_end() const
OptionalFileEntryRef LookupFile(StringRef Filename, SourceLocation IncludeLoc, bool isAngled, ConstSearchDirIterator FromDir, ConstSearchDirIterator *CurDir, ArrayRef< std::pair< OptionalFileEntryRef, DirectoryEntryRef > > Includers, SmallVectorImpl< char > *SearchPath, SmallVectorImpl< char > *RelativePath, Module *RequestingModule, ModuleMap::KnownHeader *SuggestedModule, bool *IsMapped, bool *IsFrameworkFound, bool SkipCache=false, bool BuildSystemModule=false, bool OpenFile=true, bool CacheFailures=true)
Given a "foo" or <foo> reference, look up the indicated file, return null on failure.
void getHeaderMapFileNames(SmallVectorImpl< std::string > &Names) const
Get filenames for all registered header maps.
void MarkFileSystemHeader(FileEntryRef File)
Mark the specified file as a system header, e.g.
StringRef getIncludeNameForHeader(const FileEntry *File) const
Retrieve the include name for the header.
ConstSearchDirIterator angled_dir_begin() const
void SetSystemHeaderPrefixes(ArrayRef< std::pair< std::string, bool > > P)
Set the list of system header prefixes.
ArrayRef< ModuleMap::KnownHeader > findAllModulesForHeader(FileEntryRef File) const
Retrieve all the modules corresponding to the given file.
ConstSearchDirRange search_dir_range() const
bool hasFileBeenImported(FileEntryRef File) const
Determine whether the given file is known to have ever been #imported.
ModuleFileName getPrebuiltModuleFileName(StringRef ModuleName, bool FileMapOnly=false)
Retrieve the name of the prebuilt module file that should be used to load a module with the given nam...
unsigned searchDirIdx(const DirectoryLookup &DL) const
Get the index of the given search directory.
bool isFileMultipleIncludeGuarded(FileEntryRef File) const
Determine whether this file is intended to be safe from multiple inclusions, e.g.,...
StringRef getNormalizedModuleCachePath() const
Retrieve the normalized module cache path.
ConstSearchDirIterator quoted_dir_begin() const
ExternalPreprocessorSource * getExternalLookup() const
ModuleFileName getPrebuiltImplicitModuleFileName(Module *Module)
Retrieve the name of the prebuilt module file that should be used to load the given module.
ConstSearchDirIterator search_dir_nth(size_t n) const
void loadTopLevelSystemModules()
Load all known, top-level system modules.
SearchDirIterator search_dir_end()
FrameworkCacheEntry & LookupFrameworkCache(StringRef FWName)
Look up the specified framework name in our framework cache.
std::vector< bool > computeUserEntryUsage() const
Determine which HeaderSearchOptions::UserEntries have been successfully used so far and mark their in...
ConstSearchDirIterator quoted_dir_end() const
ArrayRef< ModuleMap::KnownHeader > findResolvedModulesForHeader(FileEntryRef File) const
Like findAllModulesForHeader, but do not attempt to infer module ownership from umbrella headers if w...
ModuleFileName getCachedModuleFileName(Module *Module)
Retrieve the name of the cached module file that should be used to load the given module.
void SetSearchPaths(std::vector< DirectoryLookup > dirs, unsigned angledDirIdx, unsigned systemDirIdx, llvm::DenseMap< unsigned, unsigned > searchDirToHSEntry)
Interface for setting the file search paths.
const ModuleMap & getModuleMap() const
Retrieve the module map.
void setTarget(const TargetInfo &Target)
Set the target information for the header search, if not already known.
const HeaderMap * CreateHeaderMap(FileEntryRef FE)
This method returns a HeaderMap for the specified FileEntry, uniquing them through the 'HeaderMaps' d...
ModuleMap::KnownHeader findModuleForHeader(FileEntryRef File, bool AllowTextual=false, bool AllowExcluded=false) const
Retrieve the module that corresponds to the given file, if any.
const HeaderSearchOptions & getHeaderSearchOpts() const
Retrieve the header-search options with which this header search was initialized.
SearchDirRange search_dir_range()
void collectAllModules(SmallVectorImpl< Module * > &Modules)
Collect the set of all known, top-level modules.
void MarkFileModuleHeader(FileEntryRef FE, ModuleMap::ModuleHeaderRole Role, bool isCompilingModuleHeader)
Mark the specified file as part of a module.
const HeaderFileInfo * getExistingFileInfo(FileEntryRef FE) const
Return the HeaderFileInfo structure for the specified FileEntry, if it has ever been filled in (eithe...
OptionalFileEntryRef LookupSubframeworkHeader(StringRef Filename, FileEntryRef ContextFileEnt, SmallVectorImpl< char > *SearchPath, SmallVectorImpl< char > *RelativePath, Module *RequestingModule, ModuleMap::KnownHeader *SuggestedModule)
Look up a subframework for the specified #include file.
HeaderFileInfo & getFileInfo(FileEntryRef FE)
Return the HeaderFileInfo structure for the specified FileEntry, in preparation for updating it in so...
void SetExternalLookup(ExternalPreprocessorSource *EPS)
StringRef getSpecificModuleCachePath() const
Retrieve the specific module cache path.
OptionalFileEntryRef lookupModuleMapFile(DirectoryEntryRef Dir, bool IsFramework)
Try to find a module map file in the given directory, returning nullopt if none is found.
bool ShouldEnterIncludeFile(Preprocessor &PP, FileEntryRef File, bool isImport, bool ModulesEnabled, Module *M, bool &IsFirstIncludeOfFile)
Mark the specified file as a target of a #include, #include_next, or #import directive.
size_t getTotalMemory() const
ModuleMap & getModuleMap()
Retrieve the module map.
bool parseAndLoadModuleMapFile(FileEntryRef File, bool IsSystem, bool ImplicitlyDiscovered, FileID ID=FileID(), unsigned *Offset=nullptr, StringRef OriginalModuleMapFile=StringRef())
Read the contents of the given module map file.
bool HasIncludeAliasMap() const
Checks whether the map exists or not.
unsigned header_file_size() const
HeaderSearch(const HeaderSearchOptions &HSOpts, SourceManager &SourceMgr, DiagnosticsEngine &Diags, const LangOptions &LangOpts, const TargetInfo *Target)
ConstSearchDirIterator system_dir_end() const
void ClearFileInfo()
Forget everything we know about headers so far.
ConstSearchDirIterator search_dir_begin() const
void AddIncludeAlias(StringRef Source, StringRef Dest)
Map the source include name to the dest include name.
StringRef MapHeaderToIncludeAlias(StringRef Source)
Maps one header file name to a different header file name, for use with the include_alias pragma.
StringRef getContextHash() const
Retrieve the context hash.
SearchDirIterator search_dir_begin()
void AddSystemSearchPath(const DirectoryLookup &dir)
Add an additional system search path.
void initializeModuleCachePath(std::string ContextHash)
Initialize the module cache path.
One of these records is kept for each identifier that is lexed.
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
Identifies a module file to be loaded.
Definition Module.h:99
A header that is known to reside within a given module, whether it was included or excluded.
Definition ModuleMap.h:158
ModuleHeaderRole
Flags describing the role of a module header.
Definition ModuleMap.h:126
Describes a module or submodule.
Definition Module.h:237
Engages in a tight little dance with the lexer to efficiently preprocess tokens.
Encodes a location in the source.
Exposes information about the current target.
Definition TargetInfo.h:227
Public enums and private classes that are part of the SourceManager implementation.
CharacteristicKind
Indicates whether a file or directory holds normal user code, system code, or system code which is im...
std::conditional_t< Const, const T, T > Qualified
The JSON file list parser is used to communicate input to InstallAPI.
CustomizableOptional< FileEntryRef > OptionalFileEntryRef
Definition FileEntry.h:208
void ApplyHeaderSearchOptions(HeaderSearch &HS, const HeaderSearchOptions &HSOpts, const LangOptions &Lang, const llvm::Triple &triple)
Apply the header search options to get given HeaderSearch object.
detail::SearchDirIteratorImpl< true > ConstSearchDirIterator
nullptr
This class represents a compute construct, representing a 'Kind' of ‘parallel’, 'serial',...
detail::SearchDirIteratorImpl< false > SearchDirIterator
@ External
External linkage, which indicates that the entity can be referred to from other translation units.
Definition Linkage.h:58
llvm::iterator_range< ConstSearchDirIterator > ConstSearchDirRange
std::string createSpecificModuleCachePath(FileManager &FileMgr, StringRef ModuleCachePath, bool DisableModuleHash, std::string ContextHash)
void normalizeModuleCachePath(FileManager &FileMgr, StringRef Path, SmallVectorImpl< char > &NormalizedPath)
llvm::iterator_range< SearchDirIterator > SearchDirRange
CustomizableOptional< DirectoryEntryRef > OptionalDirectoryEntryRef
@ Other
Other implicit parameter.
Definition Decl.h:1763
Diagnostic wrappers for TextAPI types for error reporting.
Definition Dominators.h:30
#define false
Definition stdbool.h:26
This structure is used to record entries in our framework cache.
bool IsUserSpecifiedSystemFramework
Whether this framework has been "user-specified" to be treated as if it were a system framework (even...
OptionalDirectoryEntryRef Directory
The directory entry which should be used for the cached framework.
The preprocessor keeps track of this information for each file that is #included.
void mergeModuleMembership(ModuleMap::ModuleHeaderRole Role)
Update the module membership bits based on the header role.
LazyIdentifierInfoPtr LazyControllingMacro
If this file has a #ifndef XXX (or equivalent) guard that protects the entire contents of the file,...
unsigned DirInfo
Keep track of whether this is a system header, and if so, whether it is C++ clean or not.
unsigned isModuleHeader
Whether this header is part of and built with a module.
const IdentifierInfo * getControllingMacro(ExternalPreprocessorSource *External)
Retrieve the controlling macro for this header file, if any.
unsigned isTextualModuleHeader
Whether this header is a textual header in a module.
unsigned isPragmaOnce
True if this is a #pragma once file.
unsigned Resolved
Whether this structure is considered to already have been "resolved", meaning that it was loaded from...
unsigned isCompilingModuleHeader
Whether this header is part of the module that we are building, even if it doesn't build with the mod...
unsigned IsValid
Whether this file has been looked up as a header.
unsigned isImport
True if this is a #import'd file.
unsigned IsLocallyIncluded
True if this file has been included (or imported) locally.
unsigned External
Whether this header file info was supplied by an external source, and has not changed since.
Forward iterator over the search directories of HeaderSearch.
SearchDirIteratorImpl(std::nullptr_t)
Creates an invalid iterator.
Qualified< IsConst, DirectoryLookup > & operator*() const
bool operator==(const SearchDirIteratorImpl &RHS) const
SearchDirIteratorImpl(const SearchDirIteratorImpl< false > &Other)
Const -> non-const iterator conversion.
SearchDirIteratorImpl & operator++()
SearchDirIteratorImpl & operator=(const SearchDirIteratorImpl &)=default
SearchDirIteratorImpl(const SearchDirIteratorImpl &)=default