//===--- NameLookupRequests.cpp - Name Lookup Requests --------------------===// // // This source file is part of the Swift.org open source project // // Copyright (c) 2014 - 2017 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 // //===----------------------------------------------------------------------===// #include "swift/AST/NameLookupRequests.h" #include "swift/Subsystems.h" #include "swift/AST/ASTContext.h" #include "swift/AST/Evaluator.h" #include "swift/AST/Decl.h" #include "swift/AST/Module.h" using namespace swift; namespace swift { // Implement the name lookup type zone. #define SWIFT_TYPEID_ZONE NameLookup #define SWIFT_TYPEID_HEADER "swift/AST/NameLookupTypeIDZone.def" #include "swift/Basic/ImplementTypeIDZone.h" #undef SWIFT_TYPEID_ZONE #undef SWIFT_TYPEID_HEADER } //----------------------------------------------------------------------------// // Referenced inherited decls computation. //----------------------------------------------------------------------------// TypeLoc &InheritedDeclsReferencedRequest::getTypeLoc( llvm::PointerUnion decl, unsigned index) const { // FIXME: Copy-pasted from InheritedTypeRequest. We need to consolidate here. if (auto typeDecl = decl.dyn_cast()) return typeDecl->getInherited()[index]; return decl.get()->getInherited()[index]; } SourceLoc InheritedDeclsReferencedRequest::getNearestLoc() const { const auto &storage = getStorage(); auto &typeLoc = getTypeLoc(std::get<0>(storage), std::get<1>(storage)); return typeLoc.getLoc(); } //----------------------------------------------------------------------------// // Superclass declaration computation. //----------------------------------------------------------------------------// Optional SuperclassDeclRequest::getCachedResult() const { auto nominalDecl = std::get<0>(getStorage()); if (auto *classDecl = dyn_cast(nominalDecl)) if (classDecl->LazySemanticInfo.SuperclassDecl.getInt()) return classDecl->LazySemanticInfo.SuperclassDecl.getPointer(); if (auto *protocolDecl = dyn_cast(nominalDecl)) if (protocolDecl->LazySemanticInfo.SuperclassDecl.getInt()) return protocolDecl->LazySemanticInfo.SuperclassDecl.getPointer(); return None; } void SuperclassDeclRequest::cacheResult(ClassDecl *value) const { auto nominalDecl = std::get<0>(getStorage()); if (auto *classDecl = dyn_cast(nominalDecl)) classDecl->LazySemanticInfo.SuperclassDecl.setPointerAndInt(value, true); if (auto *protocolDecl = dyn_cast(nominalDecl)) protocolDecl->LazySemanticInfo.SuperclassDecl.setPointerAndInt(value, true); } //----------------------------------------------------------------------------// // Extended nominal computation. //----------------------------------------------------------------------------// Optional ExtendedNominalRequest::getCachedResult() const { // Note: if we fail to compute any nominal declaration, it's considered // a cache miss. This allows us to recompute the extended nominal types // during extension binding. auto ext = std::get<0>(getStorage()); if (ext->ExtendedNominal) return ext->ExtendedNominal; return None; } void ExtendedNominalRequest::cacheResult(NominalTypeDecl *value) const { auto ext = std::get<0>(getStorage()); if (value) ext->ExtendedNominal = value; } //----------------------------------------------------------------------------// // Destructor computation. //----------------------------------------------------------------------------// Optional GetDestructorRequest::getCachedResult() const { auto *classDecl = std::get<0>(getStorage()); auto results = classDecl->lookupDirect(DeclBaseName::createDestructor()); if (results.empty()) return None; return cast(results.front()); } void GetDestructorRequest::cacheResult(DestructorDecl *value) const { auto *classDecl = std::get<0>(getStorage()); classDecl->addMember(value); } // Define request evaluation functions for each of the name lookup requests. static AbstractRequestFunction *nameLookupRequestFunctions[] = { #define SWIFT_REQUEST(Zone, Name) \ reinterpret_cast(&Name::evaluateRequest), #include "swift/AST/NameLookupTypeIDZone.def" #undef SWIFT_REQUEST }; void swift::registerNameLookupRequestFunctions(Evaluator &evaluator) { evaluator.registerRequestFunctions(Zone::NameLookup, nameLookupRequestFunctions); }