From 0b57cec536236d46e3dba9bd041533462f33dbb7 Mon Sep 17 00:00:00 2001 From: Dimitry Andric Date: Fri, 20 Dec 2019 19:53:05 +0000 Subject: Move all sources from the llvm project into contrib/llvm-project. This uses the new layout of the upstream repository, which was recently migrated to GitHub, and converted into a "monorepo". That is, most of the earlier separate sub-projects with their own branches and tags were consolidated into one top-level directory, and are now branched and tagged together. Updating the vendor area to match this layout is next. --- .../llvm/lib/TextAPI/MachO/InterfaceFile.cpp | 81 ++++++++++++++++++++++ 1 file changed, 81 insertions(+) create mode 100644 contrib/llvm-project/llvm/lib/TextAPI/MachO/InterfaceFile.cpp (limited to 'contrib/llvm-project/llvm/lib/TextAPI/MachO/InterfaceFile.cpp') diff --git a/contrib/llvm-project/llvm/lib/TextAPI/MachO/InterfaceFile.cpp b/contrib/llvm-project/llvm/lib/TextAPI/MachO/InterfaceFile.cpp new file mode 100644 index 000000000000..54ba8cc31267 --- /dev/null +++ b/contrib/llvm-project/llvm/lib/TextAPI/MachO/InterfaceFile.cpp @@ -0,0 +1,81 @@ +//===- 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 +#include + +namespace llvm { +namespace MachO { +namespace detail { +template +typename C::iterator addEntry(C &Container, StringRef InstallName) { + auto I = partition_point(Container, [=](const InterfaceFileRef &O) { + return O.getInstallName() < InstallName; + }); + if (I != Container.end() && I->getInstallName() == InstallName) + 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 = partition_point(UUIDs, + [=](const std::pair &O) { + return O.first < Arch; + }); + + 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(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. -- cgit v1.2.3