1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- //===- InterfaceFile.cpp --------------------------------------------------===//
- //
- // 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
- //
- //===----------------------------------------------------------------------===//
- //
- // Implements the Interface File.
- //
- //===----------------------------------------------------------------------===//
- #include "llvm/TextAPI/MachO/InterfaceFile.h"
- #include <iomanip>
- #include <sstream>
- using namespace llvm::MachO;
- namespace llvm {
- namespace MachO {
- namespace detail {
- template <typename C>
- typename C::iterator addEntry(C &Container, StringRef InstallName) {
- auto I = llvm::bsearch(Container, [=](const InterfaceFileRef &O) {
- return InstallName <= O.getInstallName();
- });
- if ((I != std::end(Container)) && !(InstallName < I->getInstallName()))
- return I;
- return Container.emplace(I, InstallName);
- }
- } // end namespace detail.
- void InterfaceFile::addAllowableClient(StringRef Name,
- ArchitectureSet Architectures) {
- auto Client = detail::addEntry(AllowableClients, Name);
- Client->addArchitectures(Architectures);
- }
- void InterfaceFile::addReexportedLibrary(StringRef InstallName,
- ArchitectureSet Architectures) {
- auto Lib = detail::addEntry(ReexportedLibraries, InstallName);
- Lib->addArchitectures(Architectures);
- }
- void InterfaceFile::addUUID(Architecture Arch, StringRef UUID) {
- auto I =
- llvm::bsearch(UUIDs, [=](const std::pair<Architecture, std::string> &O) {
- return Arch <= O.first;
- });
- if (I != UUIDs.end() && Arch == I->first) {
- I->second = UUID;
- return;
- }
- UUIDs.emplace(I, Arch, UUID);
- return;
- }
- void InterfaceFile::addUUID(Architecture Arch, uint8_t UUID[16]) {
- std::stringstream Stream;
- for (unsigned i = 0; i < 16; ++i) {
- if (i == 4 || i == 6 || i == 8 || i == 10)
- Stream << '-';
- Stream << std::setfill('0') << std::setw(2) << std::uppercase << std::hex
- << static_cast<int>(UUID[i]);
- }
- addUUID(Arch, Stream.str());
- }
- void InterfaceFile::addSymbol(SymbolKind Kind, StringRef Name,
- ArchitectureSet Archs, SymbolFlags Flags) {
- Name = copyString(Name);
- auto result = Symbols.try_emplace(SymbolsMapKey{Kind, Name}, nullptr);
- if (result.second)
- result.first->second = new (Allocator) Symbol{Kind, Name, Archs, Flags};
- else
- result.first->second->addArchitectures(Archs);
- }
- } // end namespace MachO.
- } // end namespace llvm.
|