forked from Imagelibrary/binutils-gdb
Introduce expression::first_opcode
This adds a new helper method, expression::first_opcode, that extracts the outermost opcode of an expression. This simplifies some patches in the expression rewrite series. Note that this patch requires the earlier patch to avoid manual dissection of OP_TYPE operations. 2020-12-15 Tom Tromey <tom@tromey.com> * varobj.c (varobj_create): Use first_opcode. * value.c (init_if_undefined_command): Use first_opcode. * typeprint.c (whatis_exp): Use first_opcode. * tracepoint.c (validate_actionline): Use first_opcode. (encode_actions_1): Use first_opcode. * stack.c (return_command): Use first_opcode. * expression.h (struct expression) <first_opcode>: New method. * eval.c (parse_and_eval_type): Use first_opcode. * dtrace-probe.c (dtrace_process_dof_probe): Use first_opcode.
This commit is contained in:
@@ -3104,7 +3104,7 @@ parse_and_eval_type (const char *p, int length)
|
||||
tmp[length + 2] = '0';
|
||||
tmp[length + 3] = '\0';
|
||||
expression_up expr = parse_expression (tmp);
|
||||
if (expr->elts[0].opcode != UNOP_CAST)
|
||||
if (expr->first_opcode () != UNOP_CAST)
|
||||
error (_("Internal error in eval_type."));
|
||||
return expr->elts[1].type;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user