diff options
author | Andrew Burgess <andrew.burgess@embecosm.com> | 2020-05-01 21:51:15 +0100 |
---|---|---|
committer | Andrew Burgess <andrew.burgess@embecosm.com> | 2020-06-02 13:53:10 +0100 |
commit | 1fb314aaa3142711e452e66c2dced781a4d1ef87 (patch) | |
tree | ce4f8ed92b2c79139a274e51c53d782a3682fb05 /gdb/language.c | |
parent | 48448202d7e607d7423c6186438099f442732a95 (diff) | |
download | gdb-1fb314aaa3142711e452e66c2dced781a4d1ef87.zip gdb-1fb314aaa3142711e452e66c2dced781a4d1ef87.tar.gz gdb-1fb314aaa3142711e452e66c2dced781a4d1ef87.tar.bz2 |
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.
Diffstat (limited to 'gdb/language.c')
-rw-r--r-- | gdb/language.c | 26 |
1 files changed, 19 insertions, 7 deletions
diff --git a/gdb/language.c b/gdb/language.c index da99806..bc714ba 100644 --- a/gdb/language.c +++ b/gdb/language.c @@ -837,7 +837,6 @@ extern const struct language_data unknown_language_data = 0, /* String lower bound */ default_word_break_characters, default_collect_symbol_completion_matches, - unknown_language_arch_info, /* la_language_arch_info. */ c_watch_location_expression, NULL, /* la_get_symbol_name_matcher */ iterate_over_symbols, @@ -857,6 +856,13 @@ public: unknown_language () : language_defn (language_unknown, unknown_language_data) { /* Nothing. */ } + + /* See language.h. */ + void language_arch_info (struct gdbarch *gdbarch, + struct language_arch_info *lai) const override + { + unknown_language_arch_info (gdbarch, lai); + } }; /* Single instance of the unknown language class. */ @@ -899,7 +905,6 @@ extern const struct language_data auto_language_data = 0, /* String lower bound */ default_word_break_characters, default_collect_symbol_completion_matches, - unknown_language_arch_info, /* la_language_arch_info. */ c_watch_location_expression, NULL, /* la_get_symbol_name_matcher */ iterate_over_symbols, @@ -919,6 +924,13 @@ public: auto_language () : language_defn (language_auto, auto_language_data) { /* Nothing. */ } + + /* See language.h. */ + void language_arch_info (struct gdbarch *gdbarch, + struct language_arch_info *lai) const override + { + unknown_language_arch_info (gdbarch, lai); + } }; /* Single instance of the fake "auto" language. */ @@ -944,11 +956,11 @@ language_gdbarch_post_init (struct gdbarch *gdbarch) l = GDBARCH_OBSTACK_ZALLOC (gdbarch, struct language_gdbarch); for (const auto &lang : language_defn::languages) - if (lang != NULL && lang->la_language_arch_info != NULL) - { - lang->la_language_arch_info (gdbarch, - l->arch_info + lang->la_language); - } + { + gdb_assert (lang != nullptr); + lang->language_arch_info (gdbarch, + l->arch_info + lang->la_language); + } return l; } |