diff options
author | Juergen Ributzka <juergen@ributzka.de> | 2018-11-28 21:38:28 +0000 |
---|---|---|
committer | Juergen Ributzka <juergen@ributzka.de> | 2018-11-28 21:38:28 +0000 |
commit | dec0696345925e8eadc515031949d4cf4dba4e2e (patch) | |
tree | 505572176bdd2c9f0ea2d9573146f07e3fb53fbd /llvm/lib/TextAPI/MachO/InterfaceFile.cpp | |
parent | eb6759bbf9eaa43d457d84426f37a8ebd424b763 (diff) | |
download | bcm5719-llvm-dec0696345925e8eadc515031949d4cf4dba4e2e.tar.gz bcm5719-llvm-dec0696345925e8eadc515031949d4cf4dba4e2e.zip |
Revert "[TextAPI] TBD Reader/Writer"
Reverting to unbreak bots.
llvm-svn: 347809
Diffstat (limited to 'llvm/lib/TextAPI/MachO/InterfaceFile.cpp')
-rw-r--r-- | llvm/lib/TextAPI/MachO/InterfaceFile.cpp | 86 |
1 files changed, 0 insertions, 86 deletions
diff --git a/llvm/lib/TextAPI/MachO/InterfaceFile.cpp b/llvm/lib/TextAPI/MachO/InterfaceFile.cpp deleted file mode 100644 index e252356c9f3..00000000000 --- a/llvm/lib/TextAPI/MachO/InterfaceFile.cpp +++ /dev/null @@ -1,86 +0,0 @@ -//===- lib/TextAPI/InterfaceFile.cpp - Interface File -----------*- C++ -*-===// -// -// The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// -/// -/// \file -/// \brief 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 = - std::lower_bound(std::begin(Container), std::end(Container), InstallName, - [](const InterfaceFileRef &LHS, const StringRef &RHS) { - return LHS.getInstallName() < RHS; - }); - 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 = std::lower_bound(UUIDs.begin(), UUIDs.end(), Arch, - [](const std::pair<Architecture, std::string> &LHS, - Architecture RHS) { return LHS.first < RHS; }); - - 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. |