aboutsummaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
authorFred Fish <fnf@specifix.com>2006-01-24 15:20:10 +0000
committerFred Fish <fnf@specifix.com>2006-01-24 15:20:10 +0000
commit59f92a09f11acb0641ef889f6b32f73a27bd432f (patch)
treef876ff332d30afbdd7ea5ea402cc5ff9a467b927 /gdb
parentfc6e32319797541d9df5ea3a776536f1466b4dd6 (diff)
downloadgdb-59f92a09f11acb0641ef889f6b32f73a27bd432f.zip
gdb-59f92a09f11acb0641ef889f6b32f73a27bd432f.tar.gz
gdb-59f92a09f11acb0641ef889f6b32f73a27bd432f.tar.bz2
Reviewed and approved by Jim Blandy and Daniel Jacobowitz
2006-01-24 Fred Fish <fnf@specifix.com> * parse.c (source.h): Include. (parse_exp_in_context): Use static source context if no other context found.
Diffstat (limited to 'gdb')
-rw-r--r--gdb/ChangeLog6
-rw-r--r--gdb/parse.c19
2 files changed, 23 insertions, 2 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 609b95e..af422b9 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,3 +1,9 @@
+2006-01-24 Fred Fish <fnf@specifix.com>
+
+ * parse.c (source.h): Include.
+ (parse_exp_in_context): Use static source context if no
+ other context found.
+
2006-01-23 Andrew Stubbs <andrew.stubbs@st.com>
* sh-tdep.c: Include reggroups.h.
diff --git a/gdb/parse.c b/gdb/parse.c
index 6bf07bf..e0b5b70 100644
--- a/gdb/parse.c
+++ b/gdb/parse.c
@@ -52,6 +52,7 @@
#include "doublest.h"
#include "gdb_assert.h"
#include "block.h"
+#include "source.h"
/* Standard set of definitions for printing, dumping, prefixifying,
* and evaluating expressions. */
@@ -1075,13 +1076,27 @@ parse_exp_in_context (char **stringptr, struct block *block, int comma,
old_chain = make_cleanup (free_funcalls, 0 /*ignore*/);
funcall_chain = 0;
+ /* If no context specified, try using the current frame, if any. */
+
+ if (!block)
+ block = get_selected_block (&expression_context_pc);
+
+ /* Fall back to using the current source static context, if any. */
+
+ if (!block)
+ {
+ struct symtab_and_line cursal = get_current_source_symtab_and_line ();
+ if (cursal.symtab)
+ block = BLOCKVECTOR_BLOCK (BLOCKVECTOR (cursal.symtab), STATIC_BLOCK);
+ }
+
+ /* Save the context, if specified by caller, or found above. */
+
if (block)
{
expression_context_block = block;
expression_context_pc = BLOCK_START (block);
}
- else
- expression_context_block = get_selected_block (&expression_context_pc);
expout_size = 10;
expout_ptr = 0;