return arg1;
}
+/* Helper function that implements the body of OP_VAR_ENTRY_VALUE. */
+
+static struct value *
+eval_op_var_entry_value (struct type *expect_type, struct expression *exp,
+ enum noside noside, symbol *sym)
+{
+ if (noside == EVAL_SKIP)
+ return eval_skip_value (exp);
+ if (noside == EVAL_AVOID_SIDE_EFFECTS)
+ return value_zero (SYMBOL_TYPE (sym), not_lval);
+
+ if (SYMBOL_COMPUTED_OPS (sym) == NULL
+ || SYMBOL_COMPUTED_OPS (sym)->read_variable_at_entry == NULL)
+ error (_("Symbol \"%s\" does not have any specific entry value"),
+ sym->print_name ());
+
+ struct frame_info *frame = get_selected_frame (NULL);
+ return SYMBOL_COMPUTED_OPS (sym)->read_variable_at_entry (sym, frame);
+}
+
struct value *
evaluate_subexp_standard (struct type *expect_type,
struct expression *exp, int *pos,
case OP_VAR_ENTRY_VALUE:
(*pos) += 2;
- if (noside == EVAL_SKIP)
- return eval_skip_value (exp);
{
struct symbol *sym = exp->elts[pc + 1].symbol;
- struct frame_info *frame;
-
- if (noside == EVAL_AVOID_SIDE_EFFECTS)
- return value_zero (SYMBOL_TYPE (sym), not_lval);
-
- if (SYMBOL_COMPUTED_OPS (sym) == NULL
- || SYMBOL_COMPUTED_OPS (sym)->read_variable_at_entry == NULL)
- error (_("Symbol \"%s\" does not have any specific entry value"),
- sym->print_name ());
- frame = get_selected_frame (NULL);
- return SYMBOL_COMPUTED_OPS (sym)->read_variable_at_entry (sym, frame);
+ return eval_op_var_entry_value (expect_type, exp, noside, sym);
}
case OP_FUNC_STATIC_VAR: