binutils-gdb/gdb/gdbsupport
Simon Marchi 610cfd618e Compare iterators, not values, in filtered_iterator::operator{==,!=}
The == and != operators on filtered_iterator are not doing the
right thing, they compare values pointed by the wrapped iterators
instead of comparing the iterators themselves.

As a result, operator== will return true if the two iterators point to
two equal values at different positions.  operator!= will fail
similarly.

Also, this causes it to deference past-the-end iterators when doing.
For example, in

  for (iter = ...; iter != end_iter; ++iter)

the != comparison dereferences end_iter.  I don't think this should
happen.

I don't think it's a problem today, given that we only use
filtered_iterator to wrap linked lists of threads and inferiors.
Dereferencing past-the-end iterators of these types is not fatal, it
just returns NULL, which is not a value we otherwise find in the lists.
But in other contexts, it could become problematic.

I have added a simple self test that fails without the fix applied.

gdb/ChangeLog:

	* filtered-iterator.h (filtered_iterator) <operator==,
	operator!=>: Compare wrapped iterators, not wrapped pointers.
	* Makefile.in (SUBDIR_UNITTESTS_SRCS): Add
	unittests/filtered_iterator-selftests.c.
	* unittests/filtered_iterator-selftests.c: New file.
2019-12-04 13:27:56 -05:00
..
agent.c Convert int to bool in agent.c 2019-10-31 13:28:14 -05:00
agent.h Convert int to bool in agent.c 2019-10-31 13:28:14 -05:00
alt-stack.h Introduce alternate_signal_stack RAII class 2019-11-26 14:02:57 -07:00
array-view.h
ax.def
block-signals.h Add RAII class for blocking gdb signals 2019-11-26 14:02:57 -07:00
break-common.h
btrace-common.c gdb: Remove whitespace in 'std::vector <...>' 2019-10-03 09:42:42 +01:00
btrace-common.h gdb: Remove whitespace in 'std::vector <...>' 2019-10-03 09:42:42 +01:00
buffer.c
buffer.h
byte-vector.h
cleanups.c
cleanups.h
common-debug.c
common-debug.h
common-defs.h Import the time_r gnulib module 2019-11-15 11:48:08 -08:00
common-exceptions.c
common-exceptions.h
common-gdbthread.h
common-inferior.c Fix type of startup_with_shell in gdbserver 2019-10-02 13:43:41 -06:00
common-inferior.h Fix type of startup_with_shell in gdbserver 2019-10-02 13:43:41 -06:00
common-regcache.c
common-regcache.h
common-types.h
common-utils.c
common-utils.h Use strerror_r in safe_strerror if available 2019-10-31 15:14:14 -05:00
common.m4 Set names of worker threads 2019-11-26 14:02:58 -07:00
create-version.sh
def-vector.h
default-init-alloc.h
enum-flags.h
environ.c
environ.h
errors.c
errors.h
fileio.c
fileio.h
filestuff.c
filestuff.h
filtered-iterator.h Compare iterators, not values, in filtered_iterator::operator{==,!=} 2019-12-04 13:27:56 -05:00
format.c Handle %I64d in format_pieces 2019-11-21 14:39:40 -07:00
format.h gdb: Support printf 'z' size modifier 2019-11-12 23:46:41 +00:00
forward-scope-exit.h
function-view.h
gdb_assert.h Add missing includes to gdb_assert.h and gdb_string_view.h 2019-10-02 13:33:09 -05:00
gdb_binary_search.h Replace bsearch with a std::lower_bound-based search 2019-10-29 14:06:26 -05:00
gdb_locale.h
gdb_optional.h
gdb_proc_service.h
gdb_ref_ptr.h
gdb_setjmp.h Allow not saving the signal state in SIGSETJMP 2019-10-16 16:13:43 -05:00
gdb_signals.h
gdb_splay_tree.h
gdb_string_view.h Add missing includes to gdb_assert.h and gdb_string_view.h 2019-10-02 13:33:09 -05:00
gdb_string_view.tcc
gdb_sys_time.h
gdb_tilde_expand.c
gdb_tilde_expand.h
gdb_unique_ptr.h
gdb_unlinker.h
gdb_vecs.c
gdb_vecs.h gdb_vecs.h: Avoid self move assign 2019-11-10 20:09:59 +00:00
gdb_wait.h
gdb-dlfcn.c
gdb-dlfcn.h
gdb-sigmask.h Add RAII class for blocking gdb signals 2019-11-26 14:02:57 -07:00
hash_enum.h
host-defs.h
job-control.c
job-control.h
netstuff.c
netstuff.h
new-op.c
next-iterator.h
observable.h
offset-type.h
parallel-for.h Demangle minsyms in parallel 2019-11-26 14:02:58 -07:00
pathstuff.c
pathstuff.h
poison.h
preprocessor.h
print-utils.c
print-utils.h Improve comments in print-utils.h. 2019-10-11 11:28:35 -07:00
ptid.c
ptid.h
refcounted-object.h
rsp-low.c
rsp-low.h
run-time-clock.c
run-time-clock.h
safe-iterator.h
safe-strerror.c Use gnulib's strerror_r on MinGW 2019-11-15 13:31:36 -08:00
scope-exit.h
scoped_fd.h
scoped_mmap.c
scoped_mmap.h
scoped_restore.h
selftest.c
selftest.h
signals-state-save-restore.c Add RAII class for blocking gdb signals 2019-11-26 14:02:57 -07:00
signals-state-save-restore.h
signals.c
symbol.h
tdesc.c
tdesc.h
thread-pool.c Set names of worker threads 2019-11-26 14:02:58 -07:00
thread-pool.h Implement a thread pool 2019-11-26 14:02:57 -07:00
traits.h
underlying.h
valid-expr.h
version.h
x86-xstate.h
xml-utils.c
xml-utils.h