1 //===--- Linkage.h - Linkage enumeration and utilities ----------*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file defines the Linkage enumeration and various utility
13 //===----------------------------------------------------------------------===//
14 #ifndef LLVM_CLANG_BASIC_LINKAGE_H
15 #define LLVM_CLANG_BASIC_LINKAGE_H
19 /// \brief Describes the different kinds of linkage
20 /// (C++ [basic.link], C99 6.2.2) that an entity may have.
22 /// \brief No linkage, which means that the entity is unique and
23 /// can only be referred to from within its scope.
26 /// \brief Internal linkage, which indicates that the entity can
27 /// be referred to from within the translation unit (but not other
28 /// translation units).
31 /// \brief External linkage within a unique namespace. From the
32 /// langauge perspective, these entities have external
33 /// linkage. However, since they reside in an anonymous namespace,
34 /// their names are unique to this translation unit, which is
35 /// equivalent to having internal linkage from the code-generation
37 UniqueExternalLinkage,
39 /// \brief External linkage, which indicates that the entity can
40 /// be referred to from other translation units.
44 /// \brief A more specific kind of linkage. This is relevant to CodeGen and
51 GVA_TemplateInstantiation,
52 GVA_ExplicitTemplateInstantiation
55 /// \brief Determine whether the given linkage is semantically
57 inline bool isExternalLinkage(Linkage L) {
58 return L == UniqueExternalLinkage || L == ExternalLinkage;
61 /// \brief Compute the minimum linkage given two linages.
62 static inline Linkage minLinkage(Linkage L1, Linkage L2) {
63 return L1 < L2? L1 : L2;
66 } // end namespace clang
68 #endif // LLVM_CLANG_BASIC_LINKAGE_H