From: Tom Tromey Date: Thu, 14 Mar 2024 18:16:43 +0000 (-0600) Subject: Move "components" and "associations" into ada_parse_state X-Git-Tag: gdb-15-branchpoint~525 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=68d7f5b02f2e2d1eba7dca8701d340674f64329d;p=thirdparty%2Fbinutils-gdb.git Move "components" and "associations" into ada_parse_state This patch moves the "components" and "associations" globals into ada_parse_state. --- diff --git a/gdb/ada-exp.y b/gdb/ada-exp.y index cb0618c2200..be726eccbe2 100644 --- a/gdb/ada-exp.y +++ b/gdb/ada-exp.y @@ -64,6 +64,8 @@ struct name_info { static struct parser_state *pstate = NULL; +using namespace expr; + /* Data that must be held for the duration of a parse. */ struct ada_parse_state @@ -81,6 +83,12 @@ struct ada_parse_state return result.get (); } + /* The components being constructed during this parse. */ + std::vector components; + + /* The associations being constructed during this parse. */ + std::vector associations; + private: /* We don't have a good way to manage non-POD data in Yacc, so store @@ -125,8 +133,6 @@ static struct type *type_for_char (struct parser_state *, ULONGEST); static struct type *type_system_address (struct parser_state *); -using namespace expr; - /* Handle Ada type resolution for OP. DEPROCEDURE_P and CONTEXT_TYPE are passed to the resolve method, if called. */ static operation_up @@ -335,16 +341,13 @@ ada_funcall (int nargs) pstate->push (std::move (funcall)); } -/* The components being constructed during this parse. */ -static std::vector components; - /* Create a new ada_component_up of the indicated type and arguments, and push it on the global 'components' vector. */ template void push_component (Arg... args) { - components.emplace_back (new T (std::forward (args)...)); + ada_parser->components.emplace_back (new T (std::forward (args)...)); } /* Examine the final element of the 'components' vector, and return it @@ -354,7 +357,7 @@ push_component (Arg... args) static ada_choices_component * choice_component () { - ada_component *last = components.back ().get (); + ada_component *last = ada_parser->components.back ().get (); return gdb::checked_static_cast (last); } @@ -363,8 +366,8 @@ choice_component () static ada_component_up pop_component () { - ada_component_up result = std::move (components.back ()); - components.pop_back (); + ada_component_up result = std::move (ada_parser->components.back ()); + ada_parser->components.pop_back (); return result; } @@ -379,16 +382,13 @@ pop_components (int n) return result; } -/* The associations being constructed during this parse. */ -static std::vector associations; - /* Create a new ada_association_up of the indicated type and arguments, and push it on the global 'associations' vector. */ template void push_association (Arg... args) { - associations.emplace_back (new T (std::forward (args)...)); + ada_parser->associations.emplace_back (new T (std::forward (args)...)); } /* Pop the most recent association from the global stack, and return @@ -396,8 +396,8 @@ push_association (Arg... args) static ada_association_up pop_association () { - ada_association_up result = std::move (associations.back ()); - associations.pop_back (); + ada_association_up result = std::move (ada_parser->associations.back ()); + ada_parser->associations.pop_back (); return result; } @@ -1256,8 +1256,6 @@ ada_parse (struct parser_state *par_state) lexer_init (yyin); /* (Re-)initialize lexer. */ obstack_free (&temp_parse_space, NULL); obstack_init (&temp_parse_space); - components.clear (); - associations.clear (); assignments.clear (); iterated_associations.clear ();