From: Tom Tromey Date: Wed, 16 Jan 2019 14:09:55 +0000 (-0700) Subject: Simplify minsym iteration X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=604b1bfb46e62d561698397cb5499b487eb0db34;p=binutils-gdb.git Simplify minsym iteration This simplifies the minimal symbol iterator, by using minimal_symbol_count and just doing a somewhat ordinary array-like iteration. array_view is nearly usable, except that it is more convenient for this iterator to return pointers rather than references. gdb/ChangeLog 2019-01-16 Tom Tromey * objfiles.h (class objfile_msymbols) : Change argument type. Remove no-argument constructor. : Simplify. : Update. : Use minimal_symbol_count. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 4e562fc0090..7d1ed3fac1a 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,11 @@ +2019-01-16 Tom Tromey + + * objfiles.h (class objfile_msymbols) : Change argument + type. Remove no-argument constructor. + : Simplify. + : Update. + : Use minimal_symbol_count. + 2019-01-16 Tom Tromey * objfiles.h (struct objfile) : New method. diff --git a/gdb/objfiles.h b/gdb/objfiles.h index 5299a3c8e5e..2e0fad69c00 100644 --- a/gdb/objfiles.h +++ b/gdb/objfiles.h @@ -591,20 +591,11 @@ public: typedef std::forward_iterator_tag iterator_category; typedef int difference_type; - explicit iterator (struct objfile *objfile) - : m_msym (objfile->per_bfd->msymbols) + explicit iterator (struct minimal_symbol *msym) + : m_msym (msym) { - /* Make sure to properly handle the case where there are no - minsyms. */ - if (MSYMBOL_LINKAGE_NAME (m_msym) == nullptr) - m_msym = nullptr; } - iterator () - : m_msym (nullptr) - { - } - value_type operator* () const { return m_msym; @@ -622,12 +613,7 @@ public: self_type &operator++ () { - if (m_msym != nullptr) - { - ++m_msym; - if (MSYMBOL_LINKAGE_NAME (m_msym) == nullptr) - m_msym = nullptr; - } + ++m_msym; return *this; } @@ -637,12 +623,13 @@ public: iterator begin () const { - return iterator (m_objfile); + return iterator (m_objfile->per_bfd->msymbols); } iterator end () const { - return iterator (); + return iterator (m_objfile->per_bfd->msymbols + + m_objfile->per_bfd->minimal_symbol_count); } private: