diff options
author | Rui Ueyama <ruiu@google.com> | 2015-05-26 16:20:40 +0000 |
---|---|---|
committer | Rui Ueyama <ruiu@google.com> | 2015-05-26 16:20:40 +0000 |
commit | 407e09769733d5f54b3e130fa11177789225a31e (patch) | |
tree | 6f530411dc21517fa2502112ed47d55e0b103045 /llvm | |
parent | d6ea91456a319ed05dd2b6936cb76165b87a7ce6 (diff) | |
download | bcm5719-llvm-407e09769733d5f54b3e130fa11177789225a31e.tar.gz bcm5719-llvm-407e09769733d5f54b3e130fa11177789225a31e.zip |
Object: Add Archive::getNumberOfSymbols().
Add a function that returns number of symbols in archive headers.
llvm-svn: 238213
Diffstat (limited to 'llvm')
-rw-r--r-- | llvm/include/llvm/Object/Archive.h | 1 | ||||
-rw-r--r-- | llvm/lib/Object/Archive.cpp | 27 |
2 files changed, 14 insertions, 14 deletions
diff --git a/llvm/include/llvm/Object/Archive.h b/llvm/include/llvm/Object/Archive.h index d40dc9db9f5..8da6919a465 100644 --- a/llvm/include/llvm/Object/Archive.h +++ b/llvm/include/llvm/Object/Archive.h @@ -207,6 +207,7 @@ public: bool hasSymbolTable() const; child_iterator getSymbolTableChild() const { return SymbolTable; } + uint32_t getNumberOfSymbols() const; private: child_iterator SymbolTable; diff --git a/llvm/lib/Object/Archive.cpp b/llvm/lib/Object/Archive.cpp index 7d43daaf0f4..fb91eed2909 100644 --- a/llvm/lib/Object/Archive.cpp +++ b/llvm/lib/Object/Archive.cpp @@ -487,22 +487,21 @@ Archive::symbol_iterator Archive::symbol_begin() const { 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 { |