From d901deee6e616af8518778876349fbbe128100e3 Mon Sep 17 00:00:00 2001 From: Rafael Espindola Date: Fri, 22 Sep 2017 18:40:14 +0000 Subject: Move code to a helper function. NFC. Part of a patch by Jake Ehrlich! llvm-svn: 314012 --- llvm/lib/Object/ArchiveWriter.cpp | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) (limited to 'llvm/lib/Object/ArchiveWriter.cpp') diff --git a/llvm/lib/Object/ArchiveWriter.cpp b/llvm/lib/Object/ArchiveWriter.cpp index 4586d4427fe..19a46c01c59 100644 --- a/llvm/lib/Object/ArchiveWriter.cpp +++ b/llvm/lib/Object/ArchiveWriter.cpp @@ -277,6 +277,18 @@ static sys::TimePoint now(bool Deterministic) { return sys::TimePoint(); } +static bool isArchiveSymbol(const object::BasicSymbolRef &S) { + uint32_t Symflags = S.getFlags(); + if (Symflags & object::SymbolRef::SF_FormatSpecific) + return false; + if (!(Symflags & object::SymbolRef::SF_Global)) + return false; + if (Symflags & object::SymbolRef::SF_Undefined && + !(Symflags & object::SymbolRef::SF_Indirect)) + return false; + return true; +} + // Returns the offset of the first reference to a member offset. static Expected writeSymbolTable(raw_fd_ostream &Out, object::Archive::Kind Kind, @@ -310,13 +322,7 @@ writeSymbolTable(raw_fd_ostream &Out, object::Archive::Kind Kind, } for (const object::BasicSymbolRef &S : Obj.symbols()) { - uint32_t Symflags = S.getFlags(); - if (Symflags & object::SymbolRef::SF_FormatSpecific) - continue; - if (!(Symflags & object::SymbolRef::SF_Global)) - continue; - if (Symflags & object::SymbolRef::SF_Undefined && - !(Symflags & object::SymbolRef::SF_Indirect)) + if (!isArchiveSymbol(S)) continue; unsigned NameOffset = NameOS.tell(); -- cgit v1.2.3