* utils.c (fputs_demangled, fprint_symbol): Remove.

* utils.c (fprintf_symbol_filtered):  New function which combines
	the functionality of fputs_demangled and fprint_symbol.  Uses a
	caller provided language parameter to select the appropriate
	demangler, and caller provided args to pass to the demangler.
	* defs.h (fputs_demangled, fprint_symbol):  Remove prototypes.
	* defs.h (fprintf_symbol_filtered):  Add prototype.
	* c-typeprint.c (cp_type_print_method_args):  Replace calls to
	fputs_demangled with call to fprintf_symbol_filtered.
	* cp-valprint.c (demangle.h):  Include
	* cp-valprint.c (cp_print_value_fields):  Replace calls to
	fprint_symbol with calls to fprintf_symbol_filtered.
	* printcmd.c (print_frame_args):  Replace call to fprint_symbol
	with call to fprintf_symbol_filtered.
	* stack.c (print_frame_info, frame_info):  Add language variable
	to pass to fprintf_symbol_demangled and initialize it from the
	symbol's language.  Replace calls to fputs_demangled with calls
	to fprintf_symbol_filtered.
	* symtab.c (find_methods):  Replace call to fputs_demangled with
	call to fprintf_symbol_filtered.
	**** start-sanitize-chill ****
	* ch-valprint.c (demangle.h):  Include.
	* ch-valprint.c (chill_print_value_fields):  Replace call to
	fprint_symbol with call to new fprintf_symbol_filtered.
	**** end-sanitize-chill ****
This commit is contained in:
Fred Fish 1993-03-11 19:27:51 +00:00
parent 4a3df10afd
commit 5e81259d23
6 changed files with 45 additions and 20 deletions

View File

@ -1,20 +1,34 @@
Thu Mar 11 09:33:01 1993 Fred Fish (fnf@cygnus.com) Thu Mar 11 09:33:01 1993 Fred Fish (fnf@cygnus.com)
* utils.c (fputs_demangled): Complete rewrite to clean up and * utils.c (fputs_demangled, fprint_symbol): Remove.
add a language parameter that is used to select the demangling * utils.c (fprintf_symbol_filtered): New function which combines
algorithm. the functionality of fputs_demangled and fprint_symbol. Uses a
caller provided language parameter to select the appropriate
demangler, and caller provided args to pass to the demangler.
* defs.h (enum language): Move further up in file so enum can * defs.h (enum language): Move further up in file so enum can
be used in prototypes. be used in prototypes.
* defs.h (fputs_demangled): Update prototype to add lang arg. * defs.h (fputs_demangled, fprint_symbol): Remove prototypes.
* c-typeprint.c (cp_type_print_method_args): Add language arg * defs.h (fprintf_symbol_filtered): Add prototype.
to fputs_demangled calls, remove DMGL_PARAMS flag. * c-typeprint.c (cp_type_print_method_args): Replace calls to
fputs_demangled with call to fprintf_symbol_filtered.
* cp-valprint.c (demangle.h): Include
* cp-valprint.c (cp_print_value_fields): Replace calls to
fprint_symbol with calls to fprintf_symbol_filtered.
* printcmd.c (print_frame_args): Replace call to fprint_symbol
with call to fprintf_symbol_filtered.
* stack.c (print_frame_info): Remove obsolete code so we don't * stack.c (print_frame_info): Remove obsolete code so we don't
have to update fputs_demangled usage in it. have to update fputs_demangled usage in it.
* stack.c (print_frame_info, frame_info): Add language variable * stack.c (print_frame_info, frame_info): Add language variable
to pass to fputs_demangled and initialize it from the symbol's to pass to fprintf_symbol_demangled and initialize it from the
language. Call fputs_demangled with language arg. symbol's language. Replace calls to fputs_demangled with calls
* symtab.c (find_methods): Add language arg to fputs_demangled to fprintf_symbol_filtered.
call. * symtab.c (find_methods): Replace call to fputs_demangled with
call to fprintf_symbol_filtered.
**** start-sanitize-chill ****
* ch-valprint.c (demangle.h): Include.
* ch-valprint.c (chill_print_value_fields): Replace call to
fprint_symbol with call to new fprintf_symbol_filtered.
**** end-sanitize-chill ****
Wed Mar 10 17:37:11 1993 Fred Fish (fnf@cygnus.com) Wed Mar 10 17:37:11 1993 Fred Fish (fnf@cygnus.com)

View File

@ -151,8 +151,8 @@ cp_type_print_method_args (args, prefix, varstring, staticp, stream)
{ {
int i; int i;
fputs_demangled (prefix, stream, DMGL_ANSI, language_cplus); fprintf_symbol_filtered (stream, prefix, language_cplus, DMGL_ANSI);
fputs_demangled (varstring, stream, DMGL_ANSI, language_cplus); fprintf_symbol_filtered (stream, varstring, language_cplus, DMGL_ANSI);
fputs_filtered (" (", stream); fputs_filtered (" (", stream);
if (args && args[!staticp] && args[!staticp]->code != TYPE_CODE_VOID) if (args && args[!staticp] && args[!staticp]->code != TYPE_CODE_VOID)
{ {

View File

@ -25,6 +25,7 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
#include "expression.h" #include "expression.h"
#include "value.h" #include "value.h"
#include "language.h" #include "language.h"
#include "demangle.h"
static void static void
chill_print_value_fields PARAMS ((struct type *, char *, FILE *, int, int, chill_print_value_fields PARAMS ((struct type *, char *, FILE *, int, int,
@ -266,7 +267,8 @@ chill_print_value_fields (type, valaddr, stream, format, recurse, pretty,
{ {
wrap_here (n_spaces (2 + 2 * recurse)); wrap_here (n_spaces (2 + 2 * recurse));
} }
fprint_symbol (stream, TYPE_FIELD_NAME (type, i)); fprintf_symbol_filtered (stream, TYPE_FIELD_NAME (type, i),
language_chill, DMGL_NO_OPTS);
fputs_filtered (" = ", stream); fputs_filtered (" = ", stream);
if (TYPE_FIELD_PACKED (type, i)) if (TYPE_FIELD_PACKED (type, i))
{ {

View File

@ -25,6 +25,7 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
#include "value.h" #include "value.h"
#include "command.h" #include "command.h"
#include "gdbcmd.h" #include "gdbcmd.h"
#include "demangle.h"
int vtblprint; /* Controls printing of vtbl's */ int vtblprint; /* Controls printing of vtbl's */
int objectprint; /* Controls looking up an object's derived type int objectprint; /* Controls looking up an object's derived type
@ -259,14 +260,20 @@ cp_print_value_fields (type, valaddr, stream, format, recurse, pretty,
fputs_filtered ("\"( ptr \"", stream); fputs_filtered ("\"( ptr \"", stream);
else else
fputs_filtered ("\"( nodef \"", stream); fputs_filtered ("\"( nodef \"", stream);
fprint_symbol (stream, TYPE_FIELD_NAME (type, i)); fprintf_symbol_filtered (stream, TYPE_FIELD_NAME (type, i),
language_cplus,
DMGL_PARAMS | DMGL_ANSI);
fputs_filtered ("\" \"", stream); fputs_filtered ("\" \"", stream);
fprint_symbol (stream, TYPE_FIELD_NAME (type, i)); fprintf_symbol_filtered (stream, TYPE_FIELD_NAME (type, i),
language_cplus,
DMGL_PARAMS | DMGL_ANSI);
fputs_filtered ("\") \"", stream); fputs_filtered ("\") \"", stream);
} }
else else
{ {
fprint_symbol (stream, TYPE_FIELD_NAME (type, i)); fprintf_symbol_filtered (stream, TYPE_FIELD_NAME (type, i),
language_cplus,
DMGL_PARAMS | DMGL_ANSI);
fputs_filtered (" = ", stream); fputs_filtered (" = ", stream);
} }
if (TYPE_FIELD_PACKED (type, i)) if (TYPE_FIELD_PACKED (type, i))

View File

@ -201,7 +201,8 @@ print_frame_info (fi, level, source, args)
if (addressprint) if (addressprint)
if (fi->pc != sal.pc || !sal.symtab) if (fi->pc != sal.pc || !sal.symtab)
printf_filtered ("%s in ", local_hex_string(fi->pc)); printf_filtered ("%s in ", local_hex_string(fi->pc));
fputs_demangled (funname ? funname : "??", stdout, 0, funlang); fprintf_symbol_filtered (stdout, funname ? funname : "??", funlang,
DMGL_NO_OPTS);
wrap_here (" "); wrap_here (" ");
fputs_filtered (" (", stdout); fputs_filtered (" (", stdout);
if (args) if (args)
@ -413,7 +414,8 @@ frame_info (addr_exp, from_tty)
if (funname) if (funname)
{ {
printf_filtered (" in "); printf_filtered (" in ");
fputs_demangled (funname, stdout, DMGL_ANSI | DMGL_PARAMS, funlang); fprintf_symbol_filtered (stdout, funname, funlang,
DMGL_ANSI | DMGL_PARAMS);
} }
wrap_here (" "); wrap_here (" ");
if (sal.symtab) if (sal.symtab)

View File

@ -1389,8 +1389,8 @@ find_methods (t, name, sym_arr)
else else
{ {
fputs_filtered("(Cannot find method ", stdout); fputs_filtered("(Cannot find method ", stdout);
fputs_demangled(phys_name, stdout, DMGL_PARAMS, fprintf_symbol_filtered (stdout, phys_name,
language_cplus); language_cplus, DMGL_PARAMS);
fputs_filtered(" - possibly inlined.)\n", stdout); fputs_filtered(" - possibly inlined.)\n", stdout);
} }
} }