binutils-gdb/gdb/cli
Pedro Alves 95e95a6de2 Make breakpoint/location number parsing error output consistent
... and also make GDB catch a few more cases of invalid input.

This fixes the inconsistency in GDB's output (e.g., "bad" vs "Bad")
exposed by the new tests added in the previous commit.

Also, makes the "0-0" and "inverted range" cases be loud errors.

Also makes GDB reject negative breakpoint number in ranges.  We
already rejected negative number literals, but you could still subvert
that via convenience variables, like:

  (gdb) set $bp -1
  (gdb) disable $bp.1-2

The change to get_number_trailer fixes a bug exposed by the new tests.
The function did not handle parsing "-$num".  [This wasn't visible in
the gdb.multi/tids.exp (which has similar tests) because the TID range
parsing is implemented differently.]

gdb/ChangeLog:
2017-11-07  Pedro Alves  <palves@redhat.com>

	* breakpoint.c (extract_bp_kind): New enum.
	(extract_bp_num, extract_bp_or_bp_range): New functions, partially
	factored out from ...
	(extract_bp_number_and_location): ... here.
	* cli/cli-utils.c (get_number_trailer): Handle '-$variable'.

gdb/testsuite/ChangeLog:
2017-11-07  Pedro Alves  <palves@redhat.com>

	* gdb.base/ena-dis-br.exp (test_ena_dis_br): Adjust test.
	* gdb.cp/ena-dis-br-range.exp: Adjust tests.
	(disable_invalid, disable_inverted, disable_negative): New
	procedures.
	("bad numbers"): New set of tests.
2017-11-07 11:07:19 +00:00
..
cli-cmds.c Constify add_prefix_cmd 2017-10-11 16:21:02 -06:00
cli-cmds.h
cli-decode.c Constify add_prefix_cmd 2017-10-11 16:21:02 -06:00
cli-decode.h
cli-dump.c Constify add_prefix_cmd 2017-10-11 16:21:02 -06:00
cli-interp.c
cli-interp.h
cli-logging.c Constify add_prefix_cmd 2017-10-11 16:21:02 -06:00
cli-script.c Use console uiout when executing breakpoint commands 2017-10-31 21:34:24 -04:00
cli-script.h
cli-setshow.c
cli-setshow.h
cli-utils.c Make breakpoint/location number parsing error output consistent 2017-11-07 11:07:19 +00:00
cli-utils.h