diff options
author | NAKAMURA Takumi <geek4civic@gmail.com> | 2025-01-09 17:16:04 +0900 |
---|---|---|
committer | NAKAMURA Takumi <geek4civic@gmail.com> | 2025-01-09 17:16:04 +0900 |
commit | 0aa930a41f2d1ebf1fa90ec42da8f96d15a4dcbb (patch) | |
tree | 6a77b463f700e090df586672c26b9fe765fd115b /llvm/lib/ObjCopy/MachO/MachOObject.cpp | |
parent | ec6892d1c979ce0b84c86918d5cdbb03037b409a (diff) | |
parent | 6d16b1c5c468a79ecf867293023c89ac518ecdda (diff) | |
download | llvm-users/chapuni/cov/single/nextcount-base.zip llvm-users/chapuni/cov/single/nextcount-base.tar.gz llvm-users/chapuni/cov/single/nextcount-base.tar.bz2 |
Merge branch 'users/chapuni/cov/single/pair' into users/chapuni/cov/single/nextcount-baseusers/chapuni/cov/single/nextcount-base
Diffstat (limited to 'llvm/lib/ObjCopy/MachO/MachOObject.cpp')
-rw-r--r-- | llvm/lib/ObjCopy/MachO/MachOObject.cpp | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/llvm/lib/ObjCopy/MachO/MachOObject.cpp b/llvm/lib/ObjCopy/MachO/MachOObject.cpp index d593d67..e0819d8 100644 --- a/llvm/lib/ObjCopy/MachO/MachOObject.cpp +++ b/llvm/lib/ObjCopy/MachO/MachOObject.cpp @@ -33,6 +33,19 @@ SymbolEntry *SymbolTable::getSymbolByIndex(uint32_t Index) { static_cast<const SymbolTable *>(this)->getSymbolByIndex(Index)); } +void SymbolTable::updateSymbols(function_ref<void(SymbolEntry &)> Callable) { + for (auto &Sym : Symbols) + Callable(*Sym); + + // Partition symbols: local < defined external < undefined external. + auto ExternalBegin = std::stable_partition( + std::begin(Symbols), std::end(Symbols), + [](const auto &Sym) { return Sym->isLocalSymbol(); }); + std::stable_partition(ExternalBegin, std::end(Symbols), [](const auto &Sym) { + return !Sym->isUndefinedSymbol(); + }); +} + void SymbolTable::removeSymbols( function_ref<bool(const std::unique_ptr<SymbolEntry> &)> ToRemove) { llvm::erase_if(Symbols, ToRemove); @@ -85,6 +98,10 @@ void Object::updateLoadCommandIndexes() { case MachO::LC_DYLD_EXPORTS_TRIE: ExportsTrieCommandIndex = Index; break; + case MachO::LC_ENCRYPTION_INFO: + case MachO::LC_ENCRYPTION_INFO_64: + EncryptionInfoCommandIndex = Index; + break; } } } |