gdb: Convert language la_language_arch_info field to a method
This commit changes the language_data::la_language_arch_info function pointer member variable into a member function of language_defn. There should be no user visible changes after this commit. gdb/ChangeLog: * ada-lang.c (ada_language_arch_info): Delete function, move implementation to... (ada_language::language_arch_info): ...here, a new member function. (ada_language_data): Delete la_language_arch_info. * c-lang.c (c_language_data): Likewise. (c_language::language_arch_info): New member function. (cplus_language_arch_info): Delete function, move implementation to... (cplus_language::language_arch_info): ...here, a new member function. (cplus_language_data): Delete la_language_arch_info. (asm_language_data): Likewise. (asm_language::language_arch_info): New member function. (minimal_language_data): Delete la_language_arch_info. (minimal_language::language_arch_info): New member function. * d-lang.c (d_language_arch_info): Delete function, move implementation to... (d_language::language_arch_info): ...here, a new member function. (d_language_data): Delete la_language_arch_info. * f-lang.c (f_language_arch_info): Delete function, move implementation to... (f_language::language_arch_info): ...here, a new member function. (f_language_data): Delete la_language_arch_info. * go-lang.c (go_language_arch_info): Delete function, move implementation to... (go_language::language_arch_info): ...here, a new member function. (go_language_data): Delete la_language_arch_info. * language.c (unknown_language_data): Likewise. (unknown_language::language_arch_info): New member function. (auto_language_data): Delete la_language_arch_info. (auto_language::language_arch_info): New member function. (language_gdbarch_post_init): Update call to la_language_arch_info. * language.h (language_data): Delete la_language_arch_info function pointer. (language_defn::language_arch_info): New function. * m2-lang.c (m2_language_arch_info): Delete function, move implementation to... (m2_language::language_arch_info): ...here, a new member function. (m2_language_data): Delete la_language_arch_info. * objc-lang.c (objc_language_arch_info): Delete function, move implementation to... (objc_language::language_arch_info): ...here, a new member function. (objc_language_data): Delete la_language_arch_info. * opencl-lang.c (opencl_language_arch_info): Delete function, move implementation to... (opencl_language::language_arch_info): ...here, a new member function. (opencl_language_data): Delete la_language_arch_info. * p-lang.c (pascal_language_arch_info): Delete function, move implementation to... (pascal_language::language_arch_info): ...here, a new member function. (pascal_language_data): Delete la_language_arch_info. * rust-lang.c (rust_language_arch_info): Delete function, move implementation to... (rust_language::language_arch_info): ...here, a new member function. (rust_language_data): Delete la_language_arch_info.
This commit is contained in:
parent
48448202d7
commit
1fb314aaa3
13 changed files with 538 additions and 449 deletions
132
gdb/d-lang.c
132
gdb/d-lang.c
|
@ -133,73 +133,6 @@ enum d_primitive_types {
|
|||
nr_d_primitive_types
|
||||
};
|
||||
|
||||
/* Implements the la_language_arch_info language_defn routine
|
||||
for language D. */
|
||||
|
||||
static void
|
||||
d_language_arch_info (struct gdbarch *gdbarch,
|
||||
struct language_arch_info *lai)
|
||||
{
|
||||
const struct builtin_d_type *builtin = builtin_d_type (gdbarch);
|
||||
|
||||
lai->string_char_type = builtin->builtin_char;
|
||||
lai->primitive_type_vector
|
||||
= GDBARCH_OBSTACK_CALLOC (gdbarch, nr_d_primitive_types + 1,
|
||||
struct type *);
|
||||
|
||||
lai->primitive_type_vector [d_primitive_type_void]
|
||||
= builtin->builtin_void;
|
||||
lai->primitive_type_vector [d_primitive_type_bool]
|
||||
= builtin->builtin_bool;
|
||||
lai->primitive_type_vector [d_primitive_type_byte]
|
||||
= builtin->builtin_byte;
|
||||
lai->primitive_type_vector [d_primitive_type_ubyte]
|
||||
= builtin->builtin_ubyte;
|
||||
lai->primitive_type_vector [d_primitive_type_short]
|
||||
= builtin->builtin_short;
|
||||
lai->primitive_type_vector [d_primitive_type_ushort]
|
||||
= builtin->builtin_ushort;
|
||||
lai->primitive_type_vector [d_primitive_type_int]
|
||||
= builtin->builtin_int;
|
||||
lai->primitive_type_vector [d_primitive_type_uint]
|
||||
= builtin->builtin_uint;
|
||||
lai->primitive_type_vector [d_primitive_type_long]
|
||||
= builtin->builtin_long;
|
||||
lai->primitive_type_vector [d_primitive_type_ulong]
|
||||
= builtin->builtin_ulong;
|
||||
lai->primitive_type_vector [d_primitive_type_cent]
|
||||
= builtin->builtin_cent;
|
||||
lai->primitive_type_vector [d_primitive_type_ucent]
|
||||
= builtin->builtin_ucent;
|
||||
lai->primitive_type_vector [d_primitive_type_float]
|
||||
= builtin->builtin_float;
|
||||
lai->primitive_type_vector [d_primitive_type_double]
|
||||
= builtin->builtin_double;
|
||||
lai->primitive_type_vector [d_primitive_type_real]
|
||||
= builtin->builtin_real;
|
||||
lai->primitive_type_vector [d_primitive_type_ifloat]
|
||||
= builtin->builtin_ifloat;
|
||||
lai->primitive_type_vector [d_primitive_type_idouble]
|
||||
= builtin->builtin_idouble;
|
||||
lai->primitive_type_vector [d_primitive_type_ireal]
|
||||
= builtin->builtin_ireal;
|
||||
lai->primitive_type_vector [d_primitive_type_cfloat]
|
||||
= builtin->builtin_cfloat;
|
||||
lai->primitive_type_vector [d_primitive_type_cdouble]
|
||||
= builtin->builtin_cdouble;
|
||||
lai->primitive_type_vector [d_primitive_type_creal]
|
||||
= builtin->builtin_creal;
|
||||
lai->primitive_type_vector [d_primitive_type_char]
|
||||
= builtin->builtin_char;
|
||||
lai->primitive_type_vector [d_primitive_type_wchar]
|
||||
= builtin->builtin_wchar;
|
||||
lai->primitive_type_vector [d_primitive_type_dchar]
|
||||
= builtin->builtin_dchar;
|
||||
|
||||
lai->bool_type_symbol = "bool";
|
||||
lai->bool_type_default = builtin->builtin_bool;
|
||||
}
|
||||
|
||||
static const char *d_extensions[] =
|
||||
{
|
||||
".d", NULL
|
||||
|
@ -242,7 +175,6 @@ extern const struct language_data d_language_data =
|
|||
0, /* String lower bound. */
|
||||
default_word_break_characters,
|
||||
default_collect_symbol_completion_matches,
|
||||
d_language_arch_info,
|
||||
c_watch_location_expression,
|
||||
NULL, /* la_get_symbol_name_matcher */
|
||||
iterate_over_symbols,
|
||||
|
@ -262,6 +194,70 @@ public:
|
|||
d_language ()
|
||||
: language_defn (language_d, d_language_data)
|
||||
{ /* Nothing. */ }
|
||||
|
||||
/* See language.h. */
|
||||
void language_arch_info (struct gdbarch *gdbarch,
|
||||
struct language_arch_info *lai) const override
|
||||
{
|
||||
const struct builtin_d_type *builtin = builtin_d_type (gdbarch);
|
||||
|
||||
lai->string_char_type = builtin->builtin_char;
|
||||
lai->primitive_type_vector
|
||||
= GDBARCH_OBSTACK_CALLOC (gdbarch, nr_d_primitive_types + 1,
|
||||
struct type *);
|
||||
|
||||
lai->primitive_type_vector [d_primitive_type_void]
|
||||
= builtin->builtin_void;
|
||||
lai->primitive_type_vector [d_primitive_type_bool]
|
||||
= builtin->builtin_bool;
|
||||
lai->primitive_type_vector [d_primitive_type_byte]
|
||||
= builtin->builtin_byte;
|
||||
lai->primitive_type_vector [d_primitive_type_ubyte]
|
||||
= builtin->builtin_ubyte;
|
||||
lai->primitive_type_vector [d_primitive_type_short]
|
||||
= builtin->builtin_short;
|
||||
lai->primitive_type_vector [d_primitive_type_ushort]
|
||||
= builtin->builtin_ushort;
|
||||
lai->primitive_type_vector [d_primitive_type_int]
|
||||
= builtin->builtin_int;
|
||||
lai->primitive_type_vector [d_primitive_type_uint]
|
||||
= builtin->builtin_uint;
|
||||
lai->primitive_type_vector [d_primitive_type_long]
|
||||
= builtin->builtin_long;
|
||||
lai->primitive_type_vector [d_primitive_type_ulong]
|
||||
= builtin->builtin_ulong;
|
||||
lai->primitive_type_vector [d_primitive_type_cent]
|
||||
= builtin->builtin_cent;
|
||||
lai->primitive_type_vector [d_primitive_type_ucent]
|
||||
= builtin->builtin_ucent;
|
||||
lai->primitive_type_vector [d_primitive_type_float]
|
||||
= builtin->builtin_float;
|
||||
lai->primitive_type_vector [d_primitive_type_double]
|
||||
= builtin->builtin_double;
|
||||
lai->primitive_type_vector [d_primitive_type_real]
|
||||
= builtin->builtin_real;
|
||||
lai->primitive_type_vector [d_primitive_type_ifloat]
|
||||
= builtin->builtin_ifloat;
|
||||
lai->primitive_type_vector [d_primitive_type_idouble]
|
||||
= builtin->builtin_idouble;
|
||||
lai->primitive_type_vector [d_primitive_type_ireal]
|
||||
= builtin->builtin_ireal;
|
||||
lai->primitive_type_vector [d_primitive_type_cfloat]
|
||||
= builtin->builtin_cfloat;
|
||||
lai->primitive_type_vector [d_primitive_type_cdouble]
|
||||
= builtin->builtin_cdouble;
|
||||
lai->primitive_type_vector [d_primitive_type_creal]
|
||||
= builtin->builtin_creal;
|
||||
lai->primitive_type_vector [d_primitive_type_char]
|
||||
= builtin->builtin_char;
|
||||
lai->primitive_type_vector [d_primitive_type_wchar]
|
||||
= builtin->builtin_wchar;
|
||||
lai->primitive_type_vector [d_primitive_type_dchar]
|
||||
= builtin->builtin_dchar;
|
||||
|
||||
lai->bool_type_symbol = "bool";
|
||||
lai->bool_type_default = builtin->builtin_bool;
|
||||
}
|
||||
};
|
||||
|
||||
/* Single instance of the D language class. */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue