summaryrefslogtreecommitdiff
path: root/gdb/breakpoint.c
diff options
context:
space:
mode:
Diffstat (limited to 'gdb/breakpoint.c')
-rw-r--r--gdb/breakpoint.c127
1 files changed, 88 insertions, 39 deletions
diff --git a/gdb/breakpoint.c b/gdb/breakpoint.c
index fd6a0ba12c4..60115c4a31c 100644
--- a/gdb/breakpoint.c
+++ b/gdb/breakpoint.c
@@ -1,22 +1,21 @@
/* Everything about breakpoints, for GDB.
- Copyright (C) 1986, 1987 Free Software Foundation, Inc.
+ Copyright (C) 1986, 1987, 1989 Free Software Foundation, Inc.
-GDB is distributed in the hope that it will be useful, but WITHOUT ANY
-WARRANTY. No author or distributor accepts responsibility to anyone
-for the consequences of using it or for whether it serves any
-particular purpose or works at all, unless he says so in writing.
-Refer to the GDB General Public License for full details.
+This file is part of GDB.
-Everyone is granted permission to copy, modify and redistribute GDB,
-but only under the conditions described in the GDB General Public
-License. A copy of this license is supposed to have been given to you
-along with GDB so you can know your rights and responsibilities. It
-should be in a file named COPYING. Among other things, the copyright
-notice and this notice must be preserved on all copies.
+GDB is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 1, or (at your option)
+any later version.
-In other words, go ahead and share GDB, but don't try to stop
-anyone else from sharing it farther. Help stamp out software hoarding!
-*/
+GDB is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with GDB; see the file COPYING. If not, write to
+the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
#include "defs.h"
#include "param.h"
@@ -107,6 +106,9 @@ struct command_line *breakpoint_commands;
static void delete_breakpoint ();
void clear_momentary_breakpoints ();
void breakpoint_auto_delete ();
+
+/* Flag indicating extra verbosity for xgdb. */
+extern int xgdb_verbose;
/* condition N EXP -- set break condition of breakpoint N to EXP. */
@@ -125,6 +127,9 @@ condition_command (arg, from_tty)
p = arg;
while (*p >= '0' && *p <= '9') p++;
+ if (p == arg)
+ /* There is no number here. (e.g. "cond a == b"). */
+ error_no_arg ("breakpoint number");
bnum = atoi (arg);
ALL_BREAKPOINTS (b)
@@ -376,6 +381,9 @@ breakpoint_stop_status (pc, frame_address)
int value_zero;
if (b->cond)
{
+ /* Need to select the frame, with all that implies
+ so that the conditions will have the right context. */
+ select_frame (get_current_frame (), 0);
value_zero
= catch_errors (breakpoint_cond_eval, b->cond,
"Error occurred in testing breakpoint condition.");
@@ -420,12 +428,12 @@ breakpoint_1 (bnum)
register struct breakpoint *b;
register struct command_line *l;
register struct symbol *sym;
- CORE_ADDR last_addr = -1;
+ CORE_ADDR last_addr = (CORE_ADDR)-1;
ALL_BREAKPOINTS (b)
if (bnum == -1 || bnum == b->number)
{
- printf ("#%-3d %c 0x%08x ", b->number,
+ printf_filtered ("#%-3d %c 0x%08x ", b->number,
"nyod"[(int) b->enable],
b->address);
last_addr = b->address;
@@ -433,32 +441,48 @@ breakpoint_1 (bnum)
{
sym = find_pc_function (b->address);
if (sym)
- printf (" in %s (%s line %d)", SYMBOL_NAME (sym),
- b->symtab->filename, b->line_number);
+ printf_filtered (" in %s (%s line %d)", SYMBOL_NAME (sym),
+ b->symtab->filename, b->line_number);
else
- printf ("%s line %d", b->symtab->filename, b->line_number);
+ printf_filtered ("%s line %d", b->symtab->filename, b->line_number);
+ }
+ else
+ {
+ char *name;
+ int addr;
+
+ if (find_pc_partial_function (b->address, &name, &addr))
+ {
+ if (b->address - addr)
+ printf_filtered ("<%s+%d>", name, b->address - addr);
+ else
+ printf_filtered ("<%s>", name);
+ }
}
- printf ("\n");
+
+ printf_filtered ("\n");
if (b->ignore_count)
- printf ("\tignore next %d hits\n", b->ignore_count);
+ printf_filtered ("\tignore next %d hits\n", b->ignore_count);
if (b->frame)
- printf ("\tstop only in stack frame at 0x%x\n", b->frame);
+ printf_filtered ("\tstop only in stack frame at 0x%x\n", b->frame);
if (b->cond)
{
- printf ("\tbreak only if ");
+ printf_filtered ("\tbreak only if ");
print_expression (b->cond, stdout);
- printf ("\n");
+ printf_filtered ("\n");
}
if (l = b->commands)
while (l)
{
- printf ("\t%s\n", l->line);
+ printf_filtered ("\t%s\n", l->line);
l = l->next;
}
}
- if (last_addr != -1)
+ /* Compare against (CORE_ADDR)-1 in case some compiler decides
+ that a comparison of an unsigned with -1 is always false. */
+ if (last_addr != (CORE_ADDR)-1)
set_next_address (last_addr);
}
@@ -471,9 +495,9 @@ breakpoints_info (bnum_exp)
if (bnum_exp)
bnum = parse_and_eval_address (bnum_exp);
else if (breakpoint_chain == 0)
- printf ("No breakpoints.\n");
+ printf_filtered ("No breakpoints.\n");
else
- printf ("Breakpoints:\n\
+ printf_filtered ("Breakpoints:\n\
Num Enb Address Where\n");
breakpoint_1 (bnum);
@@ -686,7 +710,13 @@ break_command_1 (arg, tempflag, from_tty)
error ("No default breakpoint address now.");
}
else
- if (default_breakpoint_valid)
+ /* Force almost all breakpoints to be in terms of the
+ current_source_symtab (which is decode_line_1's default). This
+ should produce the results we want almost all of the time while
+ leaving default_breakpoint_* alone. */
+ if (default_breakpoint_valid
+ && (!current_source_symtab
+ || (arg && (*arg == '+' || *arg == '-'))))
sals = decode_line_1 (&arg, 1, default_breakpoint_symtab,
default_breakpoint_line);
else
@@ -770,14 +800,15 @@ tbreak_command (arg, from_tty)
* because it uses the mechanisms of breakpoints.
*/
void
-until_break_command(arg, from_tty)
+until_break_command (arg, from_tty)
char *arg;
int from_tty;
{
struct symtabs_and_lines sals;
struct symtab_and_line sal;
- FRAME frame = get_current_frame ();
- FRAME prev_frame = get_prev_frame (frame);
+ FRAME prev_frame = get_prev_frame (selected_frame);
+
+ clear_proceed_status ();
/* Set a breakpoint where the user wants it and at return from
this function */
@@ -803,7 +834,7 @@ until_break_command(arg, from_tty)
if (sal.pc == 0)
error ("No line %d in file \"%s\".", sal.line, sal.symtab->filename);
- set_momentary_breakpoint (sal, 0);
+ set_momentary_breakpoint (sal, selected_frame);
/* Keep within the current frame */
@@ -940,6 +971,10 @@ delete_breakpoint (bpt)
free_command_lines (&bpt->commands);
if (bpt->cond)
free (bpt->cond);
+
+ if (xgdb_verbose && bpt->number >=0)
+ printf ("breakpoint #%d deleted\n", bpt->number);
+
free (bpt);
}
@@ -954,7 +989,9 @@ delete_command (arg, from_tty)
if (arg == 0)
{
- if (!from_tty || query ("Delete all breakpoints? "))
+ /* Ask user only if there are some breakpoints to delete. */
+ if (!from_tty
+ || breakpoint_chain && query ("Delete all breakpoints? "))
{
/* No arg; clear all breakpoints. */
while (breakpoint_chain)
@@ -1077,6 +1114,9 @@ enable_breakpoint (bpt)
{
bpt->enable = enabled;
+ if (xgdb_verbose && bpt->number >= 0)
+ printf ("breakpoint #%d enabled\n", bpt->number);
+
check_duplicates (bpt->address);
}
@@ -1084,7 +1124,12 @@ static void
enable_command (args)
char *args;
{
- map_breakpoint_numbers (args, enable_breakpoint);
+ struct breakpoint *bpt;
+ if (args == 0)
+ ALL_BREAKPOINTS (bpt)
+ enable_breakpoint (bpt);
+ else
+ map_breakpoint_numbers (args, enable_breakpoint);
}
static void
@@ -1093,6 +1138,9 @@ disable_breakpoint (bpt)
{
bpt->enable = disabled;
+ if (xgdb_verbose && bpt->number >= 0)
+ printf ("breakpoint #%d disabled\n", bpt->number);
+
check_duplicates (bpt->address);
}
@@ -1263,12 +1311,13 @@ This command may be abbreviated \"disable\".",
Arguments are breakpoint numbers with spaces in between.\n\
To delete all breakpoints, give no argument.\n\
\n\
-The \"display\" subcommand applies to auto-displays instead of breakpoints.",
+Also a prefix command for deletion of other GDB objects.\n\
+The \"unset\" command is also an alias for \"delete\".",
&deletelist, "delete ", 1, &cmdlist);
add_com_alias ("d", "delete", class_breakpoint, 1);
- add_com_alias ("unset", "delete", class_breakpoint, 1);
+ add_com_alias ("unset", "delete", class_alias, 1);
- add_abbrev_cmd ("breakpoints", class_breakpoint, delete_command,
+ add_cmd ("breakpoints", class_alias, delete_command,
"Delete some breakpoints or auto-display expressions.\n\
Arguments are breakpoint numbers with spaces in between.\n\
To delete all breakpoints, give no argument.\n\