[llvm] r238213 - Object: Add Archive::getNumberOfSymbols().
Rui Ueyama
ruiu at google.com
Tue May 26 09:20:40 PDT 2015
Author: ruiu
Date: Tue May 26 11:20:40 2015
New Revision: 238213
URL: http://llvm.org/viewvc/llvm-project?rev=238213&view=rev
Log:
Object: Add Archive::getNumberOfSymbols().
Add a function that returns number of symbols in archive headers.
Modified:
llvm/trunk/include/llvm/Object/Archive.h
llvm/trunk/lib/Object/Archive.cpp
Modified: llvm/trunk/include/llvm/Object/Archive.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/Object/Archive.h?rev=238213&r1=238212&r2=238213&view=diff
==============================================================================
--- llvm/trunk/include/llvm/Object/Archive.h (original)
+++ llvm/trunk/include/llvm/Object/Archive.h Tue May 26 11:20:40 2015
@@ -207,6 +207,7 @@ public:
bool hasSymbolTable() const;
child_iterator getSymbolTableChild() const { return SymbolTable; }
+ uint32_t getNumberOfSymbols() const;
private:
child_iterator SymbolTable;
Modified: llvm/trunk/lib/Object/Archive.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Object/Archive.cpp?rev=238213&r1=238212&r2=238213&view=diff
==============================================================================
--- llvm/trunk/lib/Object/Archive.cpp (original)
+++ llvm/trunk/lib/Object/Archive.cpp Tue May 26 11:20:40 2015
@@ -487,22 +487,21 @@ Archive::symbol_iterator Archive::symbol
Archive::symbol_iterator Archive::symbol_end() const {
if (!hasSymbolTable())
return symbol_iterator(Symbol(this, 0, 0));
+ return symbol_iterator(Symbol(this, getNumberOfSymbols(), 0));
+}
+uint32_t Archive::getNumberOfSymbols() const {
const char *buf = SymbolTable->getBuffer().begin();
- uint32_t symbol_count = 0;
- if (kind() == K_GNU) {
- symbol_count = read32be(buf);
- } else if (kind() == K_MIPS64) {
- symbol_count = read64be(buf);
- } else if (kind() == K_BSD) {
- symbol_count = read32le(buf) / 8;
- } else {
- uint32_t member_count = 0;
- member_count = read32le(buf);
- buf += 4 + (member_count * 4); // Skip offsets.
- symbol_count = read32le(buf);
- }
- return symbol_iterator(Symbol(this, symbol_count, 0));
+ if (kind() == K_GNU)
+ return read32be(buf);
+ if (kind() == K_MIPS64)
+ return read64be(buf);
+ if (kind() == K_BSD)
+ return read32le(buf) / 8;
+ uint32_t member_count = 0;
+ member_count = read32le(buf);
+ buf += 4 + (member_count * 4); // Skip offsets.
+ return read32le(buf);
}
Archive::child_iterator Archive::findSym(StringRef name) const {
More information about the llvm-commits
mailing list