//===- ASTImporterLookupTable.h - ASTImporter specific lookup--*- C++ -*---===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This file defines the ASTImporterLookupTable class which implements a // lookup procedure for the import mechanism. // //===----------------------------------------------------------------------===// #ifndef LLVM_CLANG_AST_ASTIMPORTERLOOKUPTABLE_H #define LLVM_CLANG_AST_ASTIMPORTERLOOKUPTABLE_H #include "clang/AST/DeclBase.h" // lookup_result #include "clang/AST/DeclarationName.h" #include "llvm/ADT/DenseMap.h" #include "llvm/ADT/SetVector.h" namespace clang { class NamedDecl; class DeclContext; // There are certain cases when normal C/C++ lookup (localUncachedLookup) // does not find AST nodes. E.g.: // Example 1: // template <class T> // struct X { // friend void foo(); // this is never found in the DC of the TU. // }; // Example 2: // // The fwd decl to Foo is not found in the lookupPtr of the DC of the // // translation unit decl. // // Here we could find the node by doing a traverse throught the list of // // the Decls in the DC, but that would not scale. // struct A { struct Foo *p; }; // This is a severe problem because the importer decides if it has to create a // new Decl or not based on the lookup results. // To overcome these cases we need an importer specific lookup table which // holds every node and we are not interested in any C/C++ specific visibility // considerations. Simply, we must know if there is an existing Decl in a // given DC. Once we found it then we can handle any visibility related tasks. class ASTImporterLookupTable { … }; } // namespace clang #endif // LLVM_CLANG_AST_ASTIMPORTERLOOKUPTABLE_H