Use registry in gdbarch
gdbarch implements its own registry-like approach. This patch changes it to instead use registry.h. It's a rather large patch but largely uninteresting -- it's mostly a straightforward conversion from the old approach to the new one. The main benefit of this change is that it introduces type safety to the gdbarch registry. It also removes a bunch of code. One possible drawback is that, previously, the gdbarch registry differentiated between pre- and post-initialization setup. This doesn't seem very important to me, though.
This commit is contained in:
parent
8b15404301
commit
cb275538db
41 changed files with 533 additions and 837 deletions
18
gdb/f-lang.c
18
gdb/f-lang.c
|
@ -1720,11 +1720,10 @@ f_language::get_symbol_name_matcher_inner
|
|||
|
||||
static f_language f_language_defn;
|
||||
|
||||
static void *
|
||||
static struct builtin_f_type *
|
||||
build_fortran_types (struct gdbarch *gdbarch)
|
||||
{
|
||||
struct builtin_f_type *builtin_f_type
|
||||
= GDBARCH_OBSTACK_ZALLOC (gdbarch, struct builtin_f_type);
|
||||
struct builtin_f_type *builtin_f_type = new struct builtin_f_type;
|
||||
|
||||
builtin_f_type->builtin_void
|
||||
= arch_type (gdbarch, TYPE_CODE_VOID, TARGET_CHAR_BIT, "void");
|
||||
|
@ -1794,12 +1793,19 @@ build_fortran_types (struct gdbarch *gdbarch)
|
|||
return builtin_f_type;
|
||||
}
|
||||
|
||||
static struct gdbarch_data *f_type_data;
|
||||
static const registry<gdbarch>::key<struct builtin_f_type> f_type_data;
|
||||
|
||||
const struct builtin_f_type *
|
||||
builtin_f_type (struct gdbarch *gdbarch)
|
||||
{
|
||||
return (const struct builtin_f_type *) gdbarch_data (gdbarch, f_type_data);
|
||||
struct builtin_f_type *result = f_type_data.get (gdbarch);
|
||||
if (result == nullptr)
|
||||
{
|
||||
result = build_fortran_types (gdbarch);
|
||||
f_type_data.set (gdbarch, result);
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
/* Command-list for the "set/show fortran" prefix command. */
|
||||
|
@ -1810,8 +1816,6 @@ void _initialize_f_language ();
|
|||
void
|
||||
_initialize_f_language ()
|
||||
{
|
||||
f_type_data = gdbarch_data_register_post_init (build_fortran_types);
|
||||
|
||||
add_setshow_prefix_cmd
|
||||
("fortran", no_class,
|
||||
_("Prefix command for changing Fortran-specific settings."),
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue