mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
* spelling: accessor Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: accommodates Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: argument Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: associated Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: availability Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: available Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: belongs Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: bookkeeping Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: building Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: clazz Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: clonable Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: closure Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: concatenated Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: conformance Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: context Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: conversion Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: correspondence Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: declarations Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: declared Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: defining Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: delayed Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: dependency Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: deployed Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: descendants Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: diagnose Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: diagnostic Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: equitable Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: evaluation Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: exclusivity Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: existence Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: existential Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: explicit Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: expressed Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: for Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: foreign Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: function Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: identifier Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: implicit Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: indices Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: information Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: instance Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: interchangeable Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: interface Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: introduced Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: invalid Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: kind-in Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: least Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: library Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: location Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: namespace Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: necessary Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: nonexistent Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: not Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: number Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: obtains Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: occurs Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: opaque Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: overridden Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: parameter Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: precede Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: preceding Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: property Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: protocol Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: qualified Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: recognized Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: recursively Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: references Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: relaxing Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: represented Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: request Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: requirement Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: requirements Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: retrieve Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: returned Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: satisfied Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: satisfy Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: scanner Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: siblings Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: simplified Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: something Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: source Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: specializations Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: specially Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: statement Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: stripped Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: structure Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: substitution Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: the Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: transform Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: transformed Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: transitively Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: transparent Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: typecheck Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: unknown Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: unlabeled Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: unqualified Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: whether Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: with Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> * spelling: scanner Signed-off-by: Josh Soref <jsoref@users.noreply.github.com> Co-authored-by: Josh Soref <jsoref@users.noreply.github.com>
166 lines
5.3 KiB
C++
166 lines
5.3 KiB
C++
//===--- ImportCache.h - Caching the import graph ---------------*- C++ -*-===//
|
|
//
|
|
// This source file is part of the Swift.org open source project
|
|
//
|
|
// Copyright (c) 2014 - 2019 Apple Inc. and the Swift project authors
|
|
// Licensed under Apache License v2.0 with Runtime Library Exception
|
|
//
|
|
// See https://swift.org/LICENSE.txt for license information
|
|
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file defines interfaces for querying the module import graph in an
|
|
// efficient manner.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef SWIFT_AST_IMPORT_CACHE_H
|
|
#define SWIFT_AST_IMPORT_CACHE_H
|
|
|
|
#include "swift/AST/Module.h"
|
|
#include "llvm/ADT/DenseMap.h"
|
|
#include "llvm/ADT/FoldingSet.h"
|
|
|
|
namespace swift {
|
|
class DeclContext;
|
|
|
|
namespace namelookup {
|
|
|
|
/// An object describing a set of modules visible from a DeclContext.
|
|
///
|
|
/// This consists of two arrays of modules; the top-level imports and the
|
|
/// transitive imports.
|
|
///
|
|
/// The top-level imports contains all public imports of the parent module
|
|
/// of 'dc', together with any private imports in the source file containing
|
|
/// 'dc', if there is one.
|
|
///
|
|
/// The transitive imports contains all public imports reachable from the
|
|
/// set of top-level imports.
|
|
///
|
|
/// Both sets only contain unique elements. The top-level imports always
|
|
/// include the parent module of 'dc' explicitly.
|
|
///
|
|
/// The set of transitive imports does not contain any elements found in
|
|
/// the top-level imports.
|
|
///
|
|
/// The Swift standard library module is not included in either set unless
|
|
/// it was explicitly imported (or re-exported).
|
|
class ImportSet final :
|
|
public llvm::FoldingSetNode,
|
|
private llvm::TrailingObjects<ImportSet, ImportedModule> {
|
|
friend TrailingObjects;
|
|
friend class ImportCache;
|
|
|
|
unsigned HasHeaderImportModule : 1;
|
|
unsigned NumTopLevelImports : 31;
|
|
unsigned NumTransitiveImports;
|
|
|
|
ImportSet(bool hasHeaderImportModule,
|
|
ArrayRef<ImportedModule> topLevelImports,
|
|
ArrayRef<ImportedModule> transitiveImports);
|
|
|
|
ImportSet(const ImportSet &) = delete;
|
|
void operator=(const ImportSet &) = delete;
|
|
|
|
public:
|
|
void Profile(llvm::FoldingSetNodeID &ID) {
|
|
Profile(ID, getTopLevelImports());
|
|
}
|
|
static void Profile(
|
|
llvm::FoldingSetNodeID &ID,
|
|
ArrayRef<ImportedModule> topLevelImports);
|
|
|
|
size_t numTrailingObjects(OverloadToken<ImportedModule>) const {
|
|
return NumTopLevelImports + NumTransitiveImports;
|
|
}
|
|
|
|
/// This is a bit of a hack to make module name lookup work properly.
|
|
/// If our import set includes the ClangImporter's special header import
|
|
/// module, we have to check it first, before any other imported module.
|
|
bool hasHeaderImportModule() const {
|
|
return HasHeaderImportModule;
|
|
}
|
|
|
|
ArrayRef<ImportedModule> getTopLevelImports() const {
|
|
return {getTrailingObjects<ImportedModule>(),
|
|
NumTopLevelImports};
|
|
}
|
|
|
|
ArrayRef<ImportedModule> getTransitiveImports() const {
|
|
return {getTrailingObjects<ImportedModule>() +
|
|
NumTopLevelImports,
|
|
NumTransitiveImports};
|
|
}
|
|
|
|
ArrayRef<ImportedModule> getAllImports() const {
|
|
return {getTrailingObjects<ImportedModule>(),
|
|
NumTopLevelImports + NumTransitiveImports};
|
|
}
|
|
|
|
SWIFT_DEBUG_DUMP;
|
|
};
|
|
|
|
class alignas(ImportedModule) ImportCache {
|
|
ImportCache(const ImportCache &) = delete;
|
|
void operator=(const ImportCache &) = delete;
|
|
|
|
llvm::FoldingSet<ImportSet> ImportSets;
|
|
llvm::DenseMap<const DeclContext *, ImportSet *> ImportSetForDC;
|
|
llvm::DenseMap<std::tuple<const ModuleDecl *,
|
|
const DeclContext *>,
|
|
ArrayRef<ImportPath::Access>> VisibilityCache;
|
|
llvm::DenseMap<std::tuple<const ModuleDecl *,
|
|
const ModuleDecl *,
|
|
const DeclContext *>,
|
|
ArrayRef<ImportPath::Access>> ShadowCache;
|
|
|
|
ImportPath::Access EmptyAccessPath;
|
|
|
|
ArrayRef<ImportPath::Access> allocateArray(
|
|
ASTContext &ctx,
|
|
SmallVectorImpl<ImportPath::Access> &results);
|
|
|
|
ImportSet &getImportSet(ASTContext &ctx,
|
|
ArrayRef<ImportedModule> topLevelImports);
|
|
|
|
public:
|
|
ImportCache() {}
|
|
|
|
/// Returns an object descripting all modules transitively imported
|
|
/// from 'dc'.
|
|
ImportSet &getImportSet(const DeclContext *dc);
|
|
|
|
/// Returns all access paths into 'mod' that are visible from 'dc',
|
|
/// including transitively, via re-exports.
|
|
ArrayRef<ImportPath::Access>
|
|
getAllVisibleAccessPaths(const ModuleDecl *mod, const DeclContext *dc);
|
|
|
|
bool isImportedBy(const ModuleDecl *mod,
|
|
const DeclContext *dc) {
|
|
return !getAllVisibleAccessPaths(mod, dc).empty();
|
|
}
|
|
|
|
/// Returns all access paths in 'mod' that are visible from 'dc' if we
|
|
/// subtract imports of 'other'.
|
|
ArrayRef<ImportPath::Access>
|
|
getAllAccessPathsNotShadowedBy(const ModuleDecl *mod,
|
|
const ModuleDecl *other,
|
|
const DeclContext *dc);
|
|
|
|
/// This is a hack to cope with main file parsing and REPL parsing, where
|
|
/// we can add ImportDecls after import resolution.
|
|
void clear() {
|
|
ImportSetForDC.clear();
|
|
}
|
|
};
|
|
|
|
ArrayRef<ImportedModule> getAllImports(const DeclContext *dc);
|
|
|
|
} // namespace namelookup
|
|
|
|
} // namespace swift
|
|
|
|
#endif
|