Remove make_cleanup_restore_current_language
This patch replaces make_cleanup_restore_current_language with an RAII class that saves the current language, and restores it when the object is destroyed. ChangeLog 2017-08-03 Tom Tromey <tom@tromey.com> * utils.h (make_cleanup_restore_current_language): Remove. * utils.c (do_restore_current_language) (make_cleanup_restore_current_language): Remove. * parse.c (parse_exp_in_context_1) (parse_expression_with_language): Use scoped_restore_current_language. * mi/mi-main.c (mi_cmd_execute): Use scoped_restore_current_language. * language.h (scoped_restore_current_language): New class.
This commit is contained in:
parent
b80cf83844
commit
e3ad2841b1
@ -1,3 +1,15 @@
|
|||||||
|
2017-08-03 Tom Tromey <tom@tromey.com>
|
||||||
|
|
||||||
|
* utils.h (make_cleanup_restore_current_language): Remove.
|
||||||
|
* utils.c (do_restore_current_language)
|
||||||
|
(make_cleanup_restore_current_language): Remove.
|
||||||
|
* parse.c (parse_exp_in_context_1)
|
||||||
|
(parse_expression_with_language): Use
|
||||||
|
scoped_restore_current_language.
|
||||||
|
* mi/mi-main.c (mi_cmd_execute): Use
|
||||||
|
scoped_restore_current_language.
|
||||||
|
* language.h (scoped_restore_current_language): New class.
|
||||||
|
|
||||||
2017-08-03 Tom Tromey <tom@tromey.com>
|
2017-08-03 Tom Tromey <tom@tromey.com>
|
||||||
|
|
||||||
* compile/compile.c (cleanup_unlink_file): Remove.
|
* compile/compile.c (cleanup_unlink_file): Remove.
|
||||||
|
@ -633,4 +633,30 @@ extern const struct language_defn opencl_language_defn;
|
|||||||
extern const struct language_defn pascal_language_defn;
|
extern const struct language_defn pascal_language_defn;
|
||||||
extern const struct language_defn rust_language_defn;
|
extern const struct language_defn rust_language_defn;
|
||||||
|
|
||||||
|
/* Save the current language and restore it upon destruction. */
|
||||||
|
|
||||||
|
class scoped_restore_current_language
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
explicit scoped_restore_current_language ()
|
||||||
|
: m_lang (current_language->la_language)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
~scoped_restore_current_language ()
|
||||||
|
{
|
||||||
|
set_language (m_lang);
|
||||||
|
}
|
||||||
|
|
||||||
|
scoped_restore_current_language (const scoped_restore_current_language &)
|
||||||
|
= delete;
|
||||||
|
scoped_restore_current_language &operator=
|
||||||
|
(const scoped_restore_current_language &) = delete;
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
enum language m_lang;
|
||||||
|
};
|
||||||
|
|
||||||
#endif /* defined (LANGUAGE_H) */
|
#endif /* defined (LANGUAGE_H) */
|
||||||
|
@ -2243,9 +2243,10 @@ mi_cmd_execute (struct mi_parse *parse)
|
|||||||
error (_("Invalid frame id: %d"), frame);
|
error (_("Invalid frame id: %d"), frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gdb::optional<scoped_restore_current_language> lang_saver;
|
||||||
if (parse->language != language_unknown)
|
if (parse->language != language_unknown)
|
||||||
{
|
{
|
||||||
make_cleanup_restore_current_language ();
|
lang_saver.emplace ();
|
||||||
set_language (parse->language);
|
set_language (parse->language);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
18
gdb/parse.c
18
gdb/parse.c
@ -50,6 +50,7 @@
|
|||||||
#include "objfiles.h"
|
#include "objfiles.h"
|
||||||
#include "user-regs.h"
|
#include "user-regs.h"
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
#include "common/gdb_optional.h"
|
||||||
|
|
||||||
/* Standard set of definitions for printing, dumping, prefixifying,
|
/* Standard set of definitions for printing, dumping, prefixifying,
|
||||||
* and evaluating expressions. */
|
* and evaluating expressions. */
|
||||||
@ -1136,7 +1137,7 @@ parse_exp_in_context_1 (const char **stringptr, CORE_ADDR pc,
|
|||||||
const struct block *block,
|
const struct block *block,
|
||||||
int comma, int void_context_p, int *out_subexp)
|
int comma, int void_context_p, int *out_subexp)
|
||||||
{
|
{
|
||||||
struct cleanup *old_chain, *inner_chain;
|
struct cleanup *old_chain;
|
||||||
const struct language_defn *lang = NULL;
|
const struct language_defn *lang = NULL;
|
||||||
struct parser_state ps;
|
struct parser_state ps;
|
||||||
int subexp;
|
int subexp;
|
||||||
@ -1214,7 +1215,8 @@ parse_exp_in_context_1 (const char **stringptr, CORE_ADDR pc,
|
|||||||
to the value matching SELECTED_FRAME as set by get_current_arch. */
|
to the value matching SELECTED_FRAME as set by get_current_arch. */
|
||||||
|
|
||||||
initialize_expout (&ps, 10, lang, get_current_arch ());
|
initialize_expout (&ps, 10, lang, get_current_arch ());
|
||||||
inner_chain = make_cleanup_restore_current_language ();
|
|
||||||
|
scoped_restore_current_language lang_saver;
|
||||||
set_language (lang->la_language);
|
set_language (lang->la_language);
|
||||||
|
|
||||||
TRY
|
TRY
|
||||||
@ -1250,7 +1252,6 @@ parse_exp_in_context_1 (const char **stringptr, CORE_ADDR pc,
|
|||||||
if (expressiondebug)
|
if (expressiondebug)
|
||||||
dump_prefix_expression (ps.expout, gdb_stdlog);
|
dump_prefix_expression (ps.expout, gdb_stdlog);
|
||||||
|
|
||||||
do_cleanups (inner_chain);
|
|
||||||
discard_cleanups (old_chain);
|
discard_cleanups (old_chain);
|
||||||
|
|
||||||
*stringptr = lexptr;
|
*stringptr = lexptr;
|
||||||
@ -1275,19 +1276,14 @@ parse_expression (const char *string)
|
|||||||
expression_up
|
expression_up
|
||||||
parse_expression_with_language (const char *string, enum language lang)
|
parse_expression_with_language (const char *string, enum language lang)
|
||||||
{
|
{
|
||||||
struct cleanup *old_chain = NULL;
|
gdb::optional<scoped_restore_current_language> lang_saver;
|
||||||
|
|
||||||
if (current_language->la_language != lang)
|
if (current_language->la_language != lang)
|
||||||
{
|
{
|
||||||
old_chain = make_cleanup_restore_current_language ();
|
lang_saver.emplace ();
|
||||||
set_language (lang);
|
set_language (lang);
|
||||||
}
|
}
|
||||||
|
|
||||||
expression_up expr = parse_expression (string);
|
return parse_expression (string);
|
||||||
|
|
||||||
if (old_chain != NULL)
|
|
||||||
do_cleanups (old_chain);
|
|
||||||
return expr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Parse STRING as an expression. If parsing ends in the middle of a
|
/* Parse STRING as an expression. If parsing ends in the middle of a
|
||||||
|
22
gdb/utils.c
22
gdb/utils.c
@ -286,28 +286,6 @@ make_cleanup_free_so (struct so_list *so)
|
|||||||
return make_cleanup (do_free_so, so);
|
return make_cleanup (do_free_so, so);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Helper for make_cleanup_restore_current_language. */
|
|
||||||
|
|
||||||
static void
|
|
||||||
do_restore_current_language (void *p)
|
|
||||||
{
|
|
||||||
enum language saved_lang = (enum language) (uintptr_t) p;
|
|
||||||
|
|
||||||
set_language (saved_lang);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Remember the current value of CURRENT_LANGUAGE and make it restored when
|
|
||||||
the cleanup is run. */
|
|
||||||
|
|
||||||
struct cleanup *
|
|
||||||
make_cleanup_restore_current_language (void)
|
|
||||||
{
|
|
||||||
enum language saved_lang = current_language->la_language;
|
|
||||||
|
|
||||||
return make_cleanup (do_restore_current_language,
|
|
||||||
(void *) (uintptr_t) saved_lang);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Helper function for make_cleanup_clear_parser_state. */
|
/* Helper function for make_cleanup_clear_parser_state. */
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -113,8 +113,6 @@ extern struct cleanup *make_cleanup_value_free (struct value *);
|
|||||||
struct so_list;
|
struct so_list;
|
||||||
extern struct cleanup *make_cleanup_free_so (struct so_list *so);
|
extern struct cleanup *make_cleanup_free_so (struct so_list *so);
|
||||||
|
|
||||||
extern struct cleanup *make_cleanup_restore_current_language (void);
|
|
||||||
|
|
||||||
/* A deleter for a hash table. */
|
/* A deleter for a hash table. */
|
||||||
struct htab_deleter
|
struct htab_deleter
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user