Add completion for operations
This patch adds the necessary support for field name completion for expressions using class operation. This patch takes an approach similar to what is done today. It might be good, in the future, to change completion to be a method on the base class, to enable context-sensitive completion in more areas. gdb/ChangeLog 2021-03-08 Tom Tromey <tom@tromey.com> * parser-defs.h (struct expr_completion_state) <expout_last_op>: New member. (struct parser_state) <mark_struct_expression>: New method. * parse.c (parser_state::mark_struct_expression): Update assert. (parser_state::mark_struct_expression): New method. (parser_state::mark_completion_tag): Update assert. (parse_expression_for_completion): Handle expout_last_op.
This commit is contained in:
parent
413403fc34
commit
4933522da0
3 changed files with 45 additions and 2 deletions
26
gdb/parse.c
26
gdb/parse.c
|
@ -507,10 +507,23 @@ parser_state::mark_struct_expression ()
|
|||
{
|
||||
gdb_assert (parse_completion
|
||||
&& (m_completion_state.expout_tag_completion_type
|
||||
== TYPE_CODE_UNDEF));
|
||||
== TYPE_CODE_UNDEF)
|
||||
&& m_completion_state.expout_last_op == nullptr);
|
||||
m_completion_state.expout_last_struct = expout_ptr;
|
||||
}
|
||||
|
||||
/* See parser-defs.h. */
|
||||
|
||||
void
|
||||
parser_state::mark_struct_expression (expr::structop_base_operation *op)
|
||||
{
|
||||
gdb_assert (parse_completion
|
||||
&& (m_completion_state.expout_tag_completion_type
|
||||
== TYPE_CODE_UNDEF)
|
||||
&& m_completion_state.expout_last_struct == -1);
|
||||
m_completion_state.expout_last_op = op;
|
||||
}
|
||||
|
||||
/* Indicate that the current parser invocation is completing a tag.
|
||||
TAG is the type code of the tag, and PTR and LENGTH represent the
|
||||
start of the tag name. */
|
||||
|
@ -523,7 +536,8 @@ parser_state::mark_completion_tag (enum type_code tag, const char *ptr,
|
|||
&& (m_completion_state.expout_tag_completion_type
|
||||
== TYPE_CODE_UNDEF)
|
||||
&& m_completion_state.expout_completion_name == NULL
|
||||
&& m_completion_state.expout_last_struct == -1);
|
||||
&& m_completion_state.expout_last_struct == -1
|
||||
&& m_completion_state.expout_last_op == nullptr);
|
||||
gdb_assert (tag == TYPE_CODE_UNION
|
||||
|| tag == TYPE_CODE_STRUCT
|
||||
|| tag == TYPE_CODE_ENUM);
|
||||
|
@ -1262,6 +1276,14 @@ parse_expression_for_completion (const char *string,
|
|||
return NULL;
|
||||
}
|
||||
|
||||
if (cstate.expout_last_op != nullptr)
|
||||
{
|
||||
expr::structop_base_operation *op = cstate.expout_last_op;
|
||||
const std::string &fld = op->get_string ();
|
||||
*name = make_unique_xstrdup (fld.c_str ());
|
||||
return value_type (op->evaluate_lhs (exp.get ()));
|
||||
}
|
||||
|
||||
if (cstate.expout_last_struct == -1)
|
||||
return NULL;
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue