//===--- SerializedModuleLoader.h - Import Swift modules --------*- c++ -*-===// // // This source file is part of the Swift.org open source project // // Copyright (c) 2014 - 2015 Apple Inc. and the Swift project authors // Licensed under Apache License v2.0 with Runtime Library Exception // // See http://swift.org/LICENSE.txt for license information // See http://swift.org/CONTRIBUTORS.txt for the list of Swift project authors // //===----------------------------------------------------------------------===// #ifndef SWIFT_SERIALIZATION_MODULELOADER_H #define SWIFT_SERIALIZATION_MODULELOADER_H #include "swift/Basic/Dwarf.h" #include "swift/AST/ModuleLoader.h" #include "llvm/ADT/OwningPtr.h" #include "llvm/Support/MemoryBuffer.h" #include namespace swift { class ASTContext; class Module; class ModuleFile; /// \brief Imports serialized Swift modules into an ASTContext. class SerializedModuleLoader : public ModuleLoader { private: ASTContext &Ctx; std::map > MemoryBuffers; /// A { module, generation # } pair. using LoadedModulePair = std::pair, unsigned>; std::vector LoadedModuleFiles; explicit SerializedModuleLoader(ASTContext &ctx); public: /// \brief Create a new importer that can load serialized Swift modules /// into the given ASTContext. static SerializedModuleLoader *create(ASTContext &ctx) { return new SerializedModuleLoader(ctx); } ~SerializedModuleLoader(); SerializedModuleLoader(const SerializedModuleLoader &) = delete; SerializedModuleLoader(SerializedModuleLoader &&) = delete; SerializedModuleLoader &operator=(const SerializedModuleLoader &) = delete; SerializedModuleLoader &operator=(SerializedModuleLoader &&) = delete; /// \brief Import a module with the given module path. /// /// \param importLoc The location of the 'import' keyword. /// /// \param path A sequence of (identifier, location) pairs that denote /// the dotted module name to load, e.g., AppKit.NSWindow. /// /// \returns the module referenced, if it could be loaded. Otherwise, /// emits a diagnostic and returns a FailedImportModule object. virtual Module * loadModule(SourceLoc importLoc, Module::AccessPathTy path) override; /// \brief Register a memory buffer that contains the serialized /// module for the given access path. This API is intended to be /// used by LLDB to add swiftmodules discovered in the __apple_ast /// section of a Mach-O file to the search path. /// FIXME: make this an actual access *path* once submodules are designed. void registerMemoryBuffer(StringRef AccessPath, std::unique_ptr input) { MemoryBuffers[AccessPath].reset(input.release()); } virtual void loadExtensions(NominalTypeDecl *nominal, unsigned previousGeneration) override; virtual void loadDeclsConformingTo(KnownProtocolKind kind, unsigned previousGeneration) override; }; /// Describes whether a loaded module can be used. enum class ModuleStatus { /// The module is valid. Valid, /// The module file format is too new to be used by this version of the /// compiler. FormatTooNew, /// The module file depends on another module that can't be loaded. MissingDependency, /// The module file is malformed in some way. Malformed }; } // end namespace swift #endif