From: Tom Tromey Date: Thu, 14 Mar 2024 18:13:30 +0000 (-0600) Subject: Move "int_storage" global into ada_parse_state X-Git-Tag: gdb-15-branchpoint~526 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=48497d85e3b839b65d3376fcb8d345680ba68926;p=thirdparty%2Fbinutils-gdb.git Move "int_storage" global into ada_parse_state This patch moves the "int_storage" global into ada_parse_state. --- diff --git a/gdb/ada-exp.y b/gdb/ada-exp.y index 80c1edc792b..cb0618c2200 100644 --- a/gdb/ada-exp.y +++ b/gdb/ada-exp.y @@ -75,8 +75,19 @@ struct ada_parse_state std::string find_completion_bounds (); + const gdb_mpz *push_integer (gdb_mpz &&val) + { + auto &result = m_int_storage.emplace_back (new gdb_mpz (std::move (val))); + return result.get (); + } + private: + /* We don't have a good way to manage non-POD data in Yacc, so store + values here. The storage here is only valid for the duration of + the parse. */ + std::vector> m_int_storage; + /* The original expression string. */ const char *m_original_expr; }; @@ -85,11 +96,6 @@ private: static ada_parse_state *ada_parser; -/* We don't have a good way to manage non-POD data in Yacc, so store - values here. The storage here is only valid for the duration of - the parse. */ -static std::vector> int_storage; - int yyparse (void); static int yylex (void); @@ -1252,7 +1258,6 @@ ada_parse (struct parser_state *par_state) obstack_init (&temp_parse_space); components.clear (); associations.clear (); - int_storage.clear (); assignments.clear (); iterated_associations.clear (); diff --git a/gdb/ada-lex.l b/gdb/ada-lex.l index e1abf9adc25..109b95ccc35 100644 --- a/gdb/ada-lex.l +++ b/gdb/ada-lex.l @@ -465,8 +465,7 @@ processInt (struct parser_state *par_state, const char *base0, return FLOAT; } - const gdb_mpz *value - = int_storage.emplace_back (new gdb_mpz (std::move (result))).get (); + const gdb_mpz *value = ada_parser->push_integer (std::move (result)); int int_bits = gdbarch_int_bit (par_state->gdbarch ()); int long_bits = gdbarch_long_bit (par_state->gdbarch ());