mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-11-27 12:03:41 +08:00
1c6fbf42e5
The next patch will want to do language->print_type(type, ...), to print a type in a given language, avoiding a dependency on the current language. That doesn't work correctly currently, however, because most language implementations of language_defn::print_type call c_print_type without passing down the language. There are two overloads of c_print_type, one that takes a language, and one that does not. The one that does not uses the current language, defeating the point of calling language->print_type()... This commit removes the c_print_type overload that does not take a language, and adjusts the codebase throughout to always pass down a language. In most places, there's already an enum language handy. language_defn::print_type implementations naturally pass down this->la_language. In a couple spots, like in ada-typeprint.c and rust-lang.c there's no enum language handy, but the code is written for a specific language, so we just hardcode the language. In gnuv3_print_method_ptr, I wasn't sure whether we could hardcode C++ here, and we don't have an enum language handy, so I made it use the current language, just like today. Can always be improved later. Change-Id: Ib54fab4cf0fd307bfd55bf1dd5056830096a653b
64 lines
2.1 KiB
C
64 lines
2.1 KiB
C
/* Support for printing Go types for GDB, the GNU debugger.
|
|
|
|
Copyright (C) 2012-2022 Free Software Foundation, Inc.
|
|
|
|
This file is part of GDB.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
/* TODO:
|
|
- lots
|
|
- if the more complex types get Python pretty-printers, we'll
|
|
want a Python API for type printing
|
|
*/
|
|
|
|
#include "defs.h"
|
|
#include "gdbtypes.h"
|
|
#include "c-lang.h"
|
|
#include "go-lang.h"
|
|
|
|
/* Print a description of a type TYPE.
|
|
Output goes to STREAM (via stdio).
|
|
If VARSTRING is a non-empty string, print as an Ada variable/field
|
|
declaration.
|
|
SHOW+1 is the maximum number of levels of internal type structure
|
|
to show (this applies to record types, enumerated types, and
|
|
array types).
|
|
SHOW is the number of levels of internal type structure to show
|
|
when there is a type name for the SHOWth deepest level (0th is
|
|
outer level).
|
|
When SHOW<0, no inner structure is shown.
|
|
LEVEL indicates level of recursion (for nested definitions). */
|
|
|
|
void
|
|
go_language::print_type (struct type *type, const char *varstring,
|
|
struct ui_file *stream, int show, int level,
|
|
const struct type_print_options *flags) const
|
|
{
|
|
/* Borrowed from c-typeprint.c. */
|
|
if (show > 0)
|
|
type = check_typedef (type);
|
|
|
|
/* Print the type of "abc" as "string", not char[4]. */
|
|
if (type->code () == TYPE_CODE_ARRAY
|
|
&& TYPE_TARGET_TYPE (type)->code () == TYPE_CODE_CHAR)
|
|
{
|
|
gdb_puts ("string", stream);
|
|
return;
|
|
}
|
|
|
|
/* Punt the rest to C for now. */
|
|
c_print_type (type, varstring, stream, show, level, la_language, flags);
|
|
}
|