diff options
author | Jim Kingdon <jkingdon@engr.sgi.com> | 1993-10-08 20:33:22 +0000 |
---|---|---|
committer | Jim Kingdon <jkingdon@engr.sgi.com> | 1993-10-08 20:33:22 +0000 |
commit | 443abae18cc0f7c2654a6d0ddda239a4c6c846a5 (patch) | |
tree | 76d1f9fd7a9bb44a320b34e230bc61c687ad3956 /gdb/c-exp.y | |
parent | 1aa6938eb37f89db944795a21aadb98af7e44399 (diff) | |
download | gdb-443abae18cc0f7c2654a6d0ddda239a4c6c846a5.zip gdb-443abae18cc0f7c2654a6d0ddda239a4c6c846a5.tar.gz gdb-443abae18cc0f7c2654a6d0ddda239a4c6c846a5.tar.bz2 |
* findvar.c, value.h (symbol_read_needs_frame): New function.
* c-exp.y, m2-exp.y: Call it instead of having our own switch on
the symbol's class.
* valops.c (value_of_variable): Use symbol_read_needs_frame to
decide whether we care about finding a frame.
Diffstat (limited to 'gdb/c-exp.y')
-rw-r--r-- | gdb/c-exp.y | 31 |
1 files changed, 2 insertions, 29 deletions
diff --git a/gdb/c-exp.y b/gdb/c-exp.y index 1ab991c..37a00d2 100644 --- a/gdb/c-exp.y +++ b/gdb/c-exp.y @@ -659,41 +659,14 @@ variable: name_not_typename if (sym) { - switch (SYMBOL_CLASS (sym)) + if (symbol_read_needs_frame (sym)) { - case LOC_REGISTER: - case LOC_ARG: - case LOC_REF_ARG: - case LOC_REGPARM: - case LOC_REGPARM_ADDR: - case LOC_LOCAL: - case LOC_LOCAL_ARG: - case LOC_BASEREG: - case LOC_BASEREG_ARG: if (innermost_block == 0 || contained_in (block_found, innermost_block)) innermost_block = block_found; - case LOC_UNDEF: - case LOC_CONST: - case LOC_STATIC: - case LOC_TYPEDEF: - case LOC_LABEL: - case LOC_BLOCK: - case LOC_CONST_BYTES: - case LOC_OPTIMIZED_OUT: - - /* In this case the expression can - be evaluated regardless of what - frame we are in, so there is no - need to check for the - innermost_block. These cases are - listed so that gcc -Wall will - report types that may not have - been considered. */ - - break; } + write_exp_elt_opcode (OP_VAR_VALUE); /* We want to use the selected frame, not another more inner frame which happens to |