From: Tom Tromey Date: Wed, 27 Mar 2024 16:34:46 +0000 (-0600) Subject: Make pascal_language::print_type handle varstring==nullptr X-Git-Tag: gdb-15-branchpoint~569 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=edada1692cc4558138756eea99532d83b7b894e0;p=thirdparty%2Fbinutils-gdb.git Make pascal_language::print_type handle varstring==nullptr PR gdb/31524 points out a crash when pascal_language::print_type is called with varstring==nullptr. This crash is a regression arising from the printf/pager rewrite -- that indirectly removed a NULL check from gdb's "puts". This patch instead fixes the problem by adding a check to print_type. Passing nullptr here seems to be expected in other places (e.g., there is a call to type_print like this in expprint.c), and other implementations of this method (or related helpers) explicitly check for NULL. I didn't write a test case for this because it seemed like overkill for a Pascal bug that only occurs with -i=mi. However, if you want one, let me know and I will do it. Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=31524 Approved-By: John Baldwin --- diff --git a/gdb/p-typeprint.c b/gdb/p-typeprint.c index 5c48c1400c4..ad98d9ef202 100644 --- a/gdb/p-typeprint.c +++ b/gdb/p-typeprint.c @@ -54,7 +54,8 @@ pascal_language::print_type (struct type *type, const char *varstring, type_print_varspec_prefix (type, stream, show, 0, flags); } /* first the name */ - gdb_puts (varstring, stream); + if (varstring != nullptr) + gdb_puts (varstring, stream); if ((varstring != NULL && *varstring != '\0') && !(code == TYPE_CODE_FUNC