14#ifndef LLVM_CLANG_LEX_MODULEMAP_H 
   15#define LLVM_CLANG_LEX_MODULEMAP_H 
   22#include "llvm/ADT/ArrayRef.h" 
   23#include "llvm/ADT/DenseMap.h" 
   24#include "llvm/ADT/DenseSet.h" 
   25#include "llvm/ADT/PointerIntPair.h" 
   26#include "llvm/ADT/SmallVector.h" 
   27#include "llvm/ADT/StringMap.h" 
   28#include "llvm/ADT/StringRef.h" 
   29#include "llvm/ADT/StringSet.h" 
   30#include "llvm/ADT/TinyPtrVector.h" 
   31#include "llvm/ADT/Twine.h" 
   50  virtual void anchor();
 
 
   90  Module *SourceModule = 
nullptr;
 
   93  llvm::SpecificBumpPtrAllocator<Module> ModulesAlloc;
 
  100  llvm::StringMap<Module *> Modules;
 
  104  llvm::DenseMap<const IdentifierInfo *, Module *> CachedModuleLoads;
 
  110  unsigned NumCreatedModules = 0;
 
  114  llvm::StringMap<llvm::StringSet<>> PendingLinkAsModule;
 
  159    llvm::PointerIntPair<Module *, 3, ModuleHeaderRole> Storage;
 
  166      return A.Storage == B.Storage;
 
 
  169      return A.Storage != B.Storage;
 
 
  191    explicit operator bool()
 const {
 
  192      return Storage.getPointer() != 
nullptr;
 
 
 
  201  using HeadersMap = llvm::DenseMap<FileEntryRef, SmallVector<KnownHeader, 1>>;
 
  208  mutable llvm::DenseMap<off_t, llvm::TinyPtrVector<Module*>> LazyHeadersBySize;
 
  211  mutable llvm::DenseMap<time_t, llvm::TinyPtrVector<Module*>>
 
  212              LazyHeadersByModTime;
 
  220  llvm::DenseMap<const DirectoryEntry *, Module *> UmbrellaDirs;
 
  227  unsigned CurrentModuleScopeID = 0;
 
  229  llvm::DenseMap<Module *, unsigned> ModuleScopeIDs;
 
  234  struct InferredDirectory {
 
  236    LLVM_PREFERRED_TYPE(
bool)
 
  237    unsigned InferModules : 1;
 
  250    InferredDirectory() : InferModules(
false) {}
 
  255  llvm::DenseMap<const DirectoryEntry *, InferredDirectory> InferredDirectories;
 
  259  llvm::DenseMap<const Module *, FileID> InferredModuleAllowedBy;
 
  261  llvm::DenseMap<const Module *, AdditionalModMapsSet> AdditionalModMaps;
 
  265  llvm::DenseMap<const FileEntry *, bool> LoadedModuleMap;
 
  266  llvm::DenseMap<const FileEntry *, const modulemap::ModuleMapFile *>
 
  269  std::vector<std::unique_ptr<modulemap::ModuleMapFile>> ParsedModuleMaps;
 
  274  llvm::StringMap<
SmallVector<std::pair<
const modulemap::ModuleMapFile *,
 
  275                                        const modulemap::ModuleDecl *>,
 
  292  resolveExport(Module *Mod, 
const Module::UnresolvedExportDecl &
Unresolved,
 
  293                bool Complain) 
const;
 
  306  Module *resolveModuleId(
const ModuleId &Id, Module *Mod, 
bool Complain) 
const;
 
  315  void addUnresolvedHeader(Module *Mod,
 
  316                           Module::UnresolvedHeaderDirective Header,
 
  317                           bool &NeedsFramework);
 
  329  findHeader(Module *M, 
const Module::UnresolvedHeaderDirective &Header,
 
  330             SmallVectorImpl<char> &RelativePathName, 
bool &NeedsFramework);
 
  338  void resolveHeader(Module *M, 
const Module::UnresolvedHeaderDirective &Header,
 
  339                     bool &NeedsFramework);
 
  344  bool resolveAsBuiltinHeader(Module *M,
 
  345                              const Module::UnresolvedHeaderDirective &Header);
 
  352  HeadersMap::iterator findKnownHeader(FileEntryRef 
File);
 
  360  KnownHeader findHeaderInUmbrellaDirs(
 
  361      FileEntryRef 
File, SmallVectorImpl<DirectoryEntryRef> &IntermediateDirs);
 
  365  KnownHeader findOrCreateModuleForHeaderInUmbrellaDir(FileEntryRef 
File);
 
  369  bool isHeaderInUmbrellaDirs(FileEntryRef 
File) {
 
  371    return static_cast<bool>(findHeaderInUmbrellaDirs(
File, IntermediateDirs));
 
  374  Module *inferFrameworkModule(DirectoryEntryRef FrameworkDir, Attributes Attrs,
 
  389  ModuleMap(SourceManager &SourceMgr, DiagnosticsEngine &Diags,
 
  390            const LangOptions &LangOpts, 
const TargetInfo *Target,
 
  391            HeaderSearch &HeaderInfo);
 
  414    Callbacks.push_back(std::move(Callback));
 
 
  432                                  bool AllowExcluded = 
false);
 
  457                               std::optional<const FileEntry *> 
File) 
const;
 
  474                               bool RequestingModuleIsModuleInterface,
 
  485                                   const Module *RequestingModule) 
const;
 
  540                                  bool IsFramework, 
bool IsExplicit) {
 
 
  557                                                  Module *Parent = 
nullptr);
 
  608    assert(!ExistingModule->
Parent && 
"expected top-level module");
 
  609    assert(ModuleScopeIDs.count(ExistingModule) && 
"unknown module");
 
  610    return ModuleScopeIDs[ExistingModule] < CurrentModuleScopeID;
 
 
  615    auto It = InferredDirectories.find(Dir);
 
  616    return It != InferredDirectories.end() && It->getSecond().InferModules;
 
 
  657    auto I = AdditionalModMaps.find(M);
 
  658    if (I == AdditionalModMaps.end())
 
 
  698                             const Twine &NameAsWritten,
 
  699                             const Twine &PathRelativeToRootModuleDirectory);
 
  703                               const Twine &NameAsWritten,
 
  704                               const Twine &PathRelativeToRootModuleDirectory);
 
  739                            unsigned *Offset = 
nullptr,
 
  749  llvm::iterator_range<module_iterator> 
modules()
 const {
 
 
  755    CachedModuleLoads[&II] = M;
 
 
  760    auto I = CachedModuleLoads.find(&II);
 
  761    if (I == CachedModuleLoads.end())
 
 
 
Defines the clang::IdentifierInfo, clang::IdentifierTable, and clang::Selector interfaces.
 
Defines the clang::LangOptions interface.
 
Defines the clang::Module class, which describes a module in the source code.
 
Defines the clang::SourceLocation class and associated facilities.
 
Concrete class used by the front-end to report problems and issues.
 
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).
 
A reference to a FileEntry that includes the name of the file as it was accessed by the FileManager's...
 
Cached information about one file (either on disk or in the virtual file system).
 
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.
 
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...
 
A mechanism to observe the actions of the module map loader as it reads module map files.
 
virtual void moduleMapFileRead(SourceLocation FileStart, FileEntryRef File, bool IsSystem)
Called when a module map file has been read.
 
virtual ~ModuleMapCallbacks()=default
 
virtual void moduleMapAddHeader(StringRef Filename)
Called when a header is added during module map parsing.
 
virtual void moduleMapAddUmbrellaHeader(FileEntryRef Header)
Called when an umbrella header is added during module map parsing.
 
Module * createShadowedModule(StringRef Name, bool IsFramework, Module *ShadowingModule)
Create a new top-level module that is shadowed by ShadowingModule.
 
bool resolveExports(Module *Mod, bool Complain)
Resolve all of the unresolved exports in the given module.
 
void addLinkAsDependency(Module *Mod)
Make module to use export_as as the link dependency name if enough information is available or add it...
 
friend class ModuleMapLoader
 
void dump()
Dump the contents of the module map, for debugging purposes.
 
std::pair< Module *, bool > findOrCreateModule(StringRef Name, Module *Parent, bool IsFramework, bool IsExplicit)
Find a new module or submodule, or create it if it does not already exist.
 
llvm::StringMap< Module * >::const_iterator module_iterator
 
void setUmbrellaDirAsWritten(Module *Mod, DirectoryEntryRef UmbrellaDir, const Twine &NameAsWritten, const Twine &PathRelativeToRootModuleDirectory)
Sets the umbrella directory of the given module to the given directory.
 
void diagnoseHeaderInclusion(Module *RequestingModule, bool RequestingModuleIsModuleInterface, SourceLocation FilenameLoc, StringRef Filename, FileEntryRef File)
Reports errors if a module must not include a specific file.
 
void addAdditionalModuleMapFile(const Module *M, FileEntryRef ModuleMap)
 
OptionalFileEntryRef getContainingModuleMapFile(const Module *Module) const
 
static Module::HeaderKind headerRoleToKind(ModuleHeaderRole Role)
Convert a header role to a kind.
 
Module * findModule(StringRef Name) const
Retrieve a module with the given name.
 
void finishModuleDeclarationScope()
Creates a new declaration scope for module names, allowing previously defined modules to shadow defin...
 
bool canInferFrameworkModule(const DirectoryEntry *Dir) const
Check whether a framework module can be inferred in the given directory.
 
bool mayShadowNewModule(Module *ExistingModule)
 
bool parseAndLoadModuleMapFile(FileEntryRef File, bool IsSystem, DirectoryEntryRef HomeDir, FileID ID=FileID(), unsigned *Offset=nullptr, SourceLocation ExternModuleLoc=SourceLocation())
Load the given module map file, and record any modules we encounter.
 
KnownHeader findModuleForHeader(FileEntryRef File, bool AllowTextual=false, bool AllowExcluded=false)
Retrieve the module that owns the given header file, if any.
 
Module * createHeaderUnit(SourceLocation Loc, StringRef Name, Module::Header H)
Create a C++20 header unit.
 
void addModuleMapCallbacks(std::unique_ptr< ModuleMapCallbacks > Callback)
Add a module map callback.
 
void setBuiltinIncludeDir(DirectoryEntryRef Dir)
Set the directory that contains Clang-supplied include files, such as our stdarg.h or tgmath....
 
static bool isModular(ModuleHeaderRole Role)
Check if the header with the given role is a modular one.
 
bool resolveConflicts(Module *Mod, bool Complain)
Resolve all of the unresolved conflicts in the given module.
 
bool isHeaderUnavailableInModule(FileEntryRef Header, const Module *RequestingModule) const
Determine whether the given header is unavailable as part of the specified module.
 
void resolveHeaderDirectives(const FileEntry *File) const
Resolve all lazy header directives for the specified file.
 
module_iterator module_begin() const
 
ArrayRef< KnownHeader > findResolvedModulesForHeader(FileEntryRef File) const
Like findAllModulesForHeader, but do not attempt to infer module ownership from umbrella headers if w...
 
OptionalFileEntryRef getModuleMapFileForUniquing(const Module *M) const
 
bool shouldImportRelativeToBuiltinIncludeDir(StringRef FileName, Module *Module) const
 
Module * createModuleForImplementationUnit(SourceLocation Loc, StringRef Name)
Create a new module for a C++ module implementation unit.
 
ModuleMap(SourceManager &SourceMgr, DiagnosticsEngine &Diags, const LangOptions &LangOpts, const TargetInfo *Target, HeaderSearch &HeaderInfo)
Construct a new module map.
 
std::optional< Module * > getCachedModuleLoad(const IdentifierInfo &II)
Return a cached module load.
 
std::error_code canonicalizeModuleMapPath(SmallVectorImpl< char > &Path)
Canonicalize Path in a manner suitable for a module map file.
 
FileID getModuleMapFileIDForUniquing(const Module *M) const
Get the module map file that (along with the module name) uniquely identifies this module.
 
void setInferredModuleAllowedBy(Module *M, FileID ModMapFID)
 
void setUmbrellaHeaderAsWritten(Module *Mod, FileEntryRef UmbrellaHeader, const Twine &NameAsWritten, const Twine &PathRelativeToRootModuleDirectory)
Sets the umbrella header of the given module to the given header.
 
llvm::DenseSet< FileEntryRef > AdditionalModMapsSet
 
Module * findOrCreateModuleFirst(StringRef Name, Module *Parent, bool IsFramework, bool IsExplicit)
Call ModuleMap::findOrCreateModule and throw away the information whether the module was found or cre...
 
Module * lookupModuleUnqualified(StringRef Name, Module *Context) const
Retrieve a module with the given name using lexical name lookup, starting at the given context.
 
bool isBuiltinHeader(FileEntryRef File)
Is this a compiler builtin header?
 
Module * createModule(StringRef Name, Module *Parent, bool IsFramework, bool IsExplicit)
Create new submodule, assuming it does not exist.
 
module_iterator module_end() const
 
AdditionalModMapsSet * getAdditionalModuleMapFiles(const Module *M)
Get any module map files other than getModuleMapFileForUniquing(M) that define submodules of a top-le...
 
bool isHeaderInUnavailableModule(FileEntryRef Header) const
Determine whether the given header is part of a module marked 'unavailable'.
 
FileID getContainingModuleMapFileID(const Module *Module) const
Retrieve the module map file containing the definition of the given module.
 
OptionalDirectoryEntryRef getBuiltinDir() const
Get the directory that contains Clang-supplied include files.
 
~ModuleMap()
Destroy the module map.
 
bool parseModuleMapFile(FileEntryRef File, bool IsSystem, DirectoryEntryRef Dir, FileID ID=FileID(), SourceLocation ExternModuleLoc=SourceLocation())
Parse a module map without creating clang::Module instances.
 
Module * createGlobalModuleFragmentForModuleUnit(SourceLocation Loc, Module *Parent=nullptr)
Create a global module fragment for a C++ module unit.
 
void setTarget(const TargetInfo &Target)
Set the target information.
 
Module * lookupModuleQualified(StringRef Name, Module *Context) const
Retrieve a module with the given name within the given context, using direct (qualified) name lookup.
 
void resolveLinkAsDependencies(Module *Mod)
Use PendingLinkAsModule information to mark top level link names that are going to be replaced by exp...
 
void cacheModuleLoad(const IdentifierInfo &II, Module *M)
Cache a module load. M might be nullptr.
 
ModuleHeaderRole
Flags describing the role of a module header.
 
@ PrivateHeader
This header is included but private.
 
@ ExcludedHeader
This header is explicitly excluded from the module.
 
@ NormalHeader
This header is normally included in the module.
 
@ TextualHeader
This header is part of the module (for layering purposes) but should be textually included.
 
Module * createModuleForInterfaceUnit(SourceLocation Loc, StringRef Name)
Create a new module for a C++ module interface unit.
 
void addHeader(Module *Mod, Module::Header Header, ModuleHeaderRole Role, bool Imported=false)
Adds this header to the given module.
 
Module * createPrivateModuleFragmentForInterfaceUnit(Module *Parent, SourceLocation Loc)
Create a global module fragment for a C++ module interface unit.
 
Module * findOrInferSubmodule(Module *Parent, StringRef Name)
 
ArrayRef< KnownHeader > findAllModulesForHeader(FileEntryRef File)
Retrieve all the modules that contain the given header file.
 
Module * createImplicitGlobalModuleFragmentForModuleUnit(SourceLocation Loc, Module *Parent)
 
Module * createModuleUnitWithKind(SourceLocation Loc, StringRef Name, Module::ModuleKind Kind)
Create a new C++ module with the specified kind, and reparent any pending global module fragment(s) t...
 
Module * findOrLoadModule(StringRef Name)
 
static ModuleHeaderRole headerKindToRole(Module::HeaderKind Kind)
Convert a header kind to a role. Requires Kind to not be HK_Excluded.
 
llvm::iterator_range< module_iterator > modules() const
 
bool resolveUses(Module *Mod, bool Complain)
Resolve all of the unresolved uses in the given module.
 
Describes a module or submodule.
 
Module * Parent
The parent of this module.
 
bool isAvailable() const
Determine whether this module is available for use within the current translation unit.
 
llvm::PointerIntPair< Module *, 1, bool > ExportDecl
Describes an exported module.
 
Module * getTopLevelModule()
Retrieve the top-level module for this (sub)module, which may be this module.
 
Encodes a location in the source.
 
This class handles loading and caching of source files into memory.
 
Exposes information about the current target.
 
The JSON file list parser is used to communicate input to InstallAPI.
 
CustomizableOptional< FileEntryRef > OptionalFileEntryRef
 
SmallVector< std::pair< std::string, SourceLocation >, 2 > ModuleId
Describes the name of a module.
 
nullptr
This class represents a compute construct, representing a 'Kind' of ‘parallel’, 'serial',...
 
@ Module
Module linkage, which indicates that the entity can be referred to from other translation units withi...
 
CustomizableOptional< DirectoryEntryRef > OptionalDirectoryEntryRef
 
The set of attributes that can be attached to a module.