xref: /src/contrib/llvm-project/llvm/lib/TextAPI/SymbolSet.cpp (revision 0fca6ea1d4eea4c934cfff25ac9ee8ad6fe95583)
17fa27ce4SDimitry Andric //===- lib/TextAPI/SymbolSet.cpp - TAPI Symbol Set ------------*- C++-*----===//
27fa27ce4SDimitry Andric //
37fa27ce4SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
47fa27ce4SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
57fa27ce4SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
67fa27ce4SDimitry Andric //
77fa27ce4SDimitry Andric //===----------------------------------------------------------------------===//
87fa27ce4SDimitry Andric 
97fa27ce4SDimitry Andric #include "llvm/TextAPI/SymbolSet.h"
107fa27ce4SDimitry Andric 
117fa27ce4SDimitry Andric using namespace llvm;
127fa27ce4SDimitry Andric using namespace llvm::MachO;
137fa27ce4SDimitry Andric 
addGlobalImpl(EncodeKind Kind,StringRef Name,SymbolFlags Flags)14ac9a064cSDimitry Andric Symbol *SymbolSet::addGlobalImpl(EncodeKind Kind, StringRef Name,
157fa27ce4SDimitry Andric                                  SymbolFlags Flags) {
167fa27ce4SDimitry Andric   Name = copyString(Name);
177fa27ce4SDimitry Andric   auto Result = Symbols.try_emplace(SymbolsMapKey{Kind, Name}, nullptr);
187fa27ce4SDimitry Andric   if (Result.second)
197fa27ce4SDimitry Andric     Result.first->second =
207fa27ce4SDimitry Andric         new (Allocator) Symbol{Kind, Name, TargetList(), Flags};
217fa27ce4SDimitry Andric   return Result.first->second;
227fa27ce4SDimitry Andric }
237fa27ce4SDimitry Andric 
addGlobal(EncodeKind Kind,StringRef Name,SymbolFlags Flags,const Target & Targ)24ac9a064cSDimitry Andric Symbol *SymbolSet::addGlobal(EncodeKind Kind, StringRef Name, SymbolFlags Flags,
257fa27ce4SDimitry Andric                              const Target &Targ) {
267fa27ce4SDimitry Andric   auto *Sym = addGlobalImpl(Kind, Name, Flags);
277fa27ce4SDimitry Andric   Sym->addTarget(Targ);
287fa27ce4SDimitry Andric   return Sym;
297fa27ce4SDimitry Andric }
307fa27ce4SDimitry Andric 
findSymbol(EncodeKind Kind,StringRef Name,ObjCIFSymbolKind ObjCIF) const31ac9a064cSDimitry Andric const Symbol *SymbolSet::findSymbol(EncodeKind Kind, StringRef Name,
32ac9a064cSDimitry Andric                                     ObjCIFSymbolKind ObjCIF) const {
33ac9a064cSDimitry Andric   if (auto result = Symbols.lookup({Kind, Name}))
34ac9a064cSDimitry Andric     return result;
35ac9a064cSDimitry Andric   if ((ObjCIF == ObjCIFSymbolKind::None) || (ObjCIF > ObjCIFSymbolKind::EHType))
36ac9a064cSDimitry Andric     return nullptr;
37ac9a064cSDimitry Andric   assert(ObjCIF <= ObjCIFSymbolKind::EHType &&
38ac9a064cSDimitry Andric          "expected single ObjCIFSymbolKind enum value");
39ac9a064cSDimitry Andric   // Non-complete ObjC Interfaces are represented as global symbols.
40ac9a064cSDimitry Andric   if (ObjCIF == ObjCIFSymbolKind::Class)
41ac9a064cSDimitry Andric     return Symbols.lookup(
42ac9a064cSDimitry Andric         {EncodeKind::GlobalSymbol, (ObjC2ClassNamePrefix + Name).str()});
43ac9a064cSDimitry Andric   if (ObjCIF == ObjCIFSymbolKind::MetaClass)
44ac9a064cSDimitry Andric     return Symbols.lookup(
45ac9a064cSDimitry Andric         {EncodeKind::GlobalSymbol, (ObjC2MetaClassNamePrefix + Name).str()});
46ac9a064cSDimitry Andric   return Symbols.lookup(
47ac9a064cSDimitry Andric       {EncodeKind::GlobalSymbol, (ObjC2EHTypePrefix + Name).str()});
487fa27ce4SDimitry Andric }
49