Skip to content

Commit

Permalink
Update.
Browse files Browse the repository at this point in the history
2004-05-07  Dmitry V. Levin  <[email protected]>

	* argp/argp-help.c (__argp_error, __argp_failure): Check result
	of __asprintf call and don't use string if it failed.
	* stdio-common/psignal.c (psignal): Likewise.
	* locale/programs/localedef.c (more_help): Likewise.
	* resolv/res_hconf.c (arg_service_list, arg_trimdomain_list,
	arg_bool, parse_line): Check result of __asprintf calls and
	don't use string if they failed.
	* sunrpc/svc_simple.c (registerrpc, universal): Likewise.
	* elf/ldconfig.c (parse_conf_include): Check result of __asprintf
	call and exit if it failed.
  • Loading branch information
Ulrich Drepper committed Jun 1, 2004
1 parent 9ddfc05 commit 322861e
Show file tree
Hide file tree
Showing 6 changed files with 72 additions and 33 deletions.
13 changes: 13 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,16 @@
2004-05-07 Dmitry V. Levin <[email protected]>

* argp/argp-help.c (__argp_error, __argp_failure): Check result
of __asprintf call and don't use string if it failed.
* stdio-common/psignal.c (psignal): Likewise.
* locale/programs/localedef.c (more_help): Likewise.
* resolv/res_hconf.c (arg_service_list, arg_trimdomain_list,
arg_bool, parse_line): Check result of __asprintf calls and
don't use string if they failed.
* sunrpc/svc_simple.c (registerrpc, universal): Likewise.
* elf/ldconfig.c (parse_conf_include): Check result of __asprintf
call and exit if it failed.

2004-05-10 Jakub Jelinek <[email protected]>

* sysdeps/posix/sysconf.c (__sysconf) <cases _SC_REALTIME_SIGNALS,
Expand Down
4 changes: 3 additions & 1 deletion elf/ldconfig.c
Original file line number Diff line number Diff line change
Expand Up @@ -1034,7 +1034,9 @@ parse_conf_include (const char *config_file, unsigned int lineno,
char *copy = NULL;
if (pattern[0] != '/' && strchr (config_file, '/') != NULL)
{
asprintf (&copy, "%s/%s", dirname (strdupa (config_file)), pattern);
if (asprintf (&copy, "%s/%s", dirname (strdupa (config_file)),
pattern) < 0)
error (EXIT_FAILURE, 0, _("memory exhausted"));
pattern = copy;
}

Expand Down
7 changes: 4 additions & 3 deletions locale/programs/localedef.c
Original file line number Diff line number Diff line change
Expand Up @@ -364,14 +364,15 @@ more_help (int key, const char *text, void *input)
{
case ARGP_KEY_HELP_EXTRA:
/* We print some extra information. */
asprintf (&cp, gettext ("\
if (asprintf (&cp, gettext ("\
System's directory for character maps : %s\n\
repertoire maps: %s\n\
locale path : %s\n\
%s"),
CHARMAP_PATH, REPERTOIREMAP_PATH, LOCALE_PATH, gettext ("\
CHARMAP_PATH, REPERTOIREMAP_PATH, LOCALE_PATH, gettext ("\
For bug reporting instructions, please see:\n\
<http://www.gnu.org/software/libc/bugs.html>.\n"));
<http://www.gnu.org/software/libc/bugs.html>.\n")) < 0)
return NULL;
return cp;
default:
break;
Expand Down
47 changes: 28 additions & 19 deletions resolv/res_hconf.c
Original file line number Diff line number Diff line change
Expand Up @@ -145,8 +145,10 @@ arg_service_list (const char *fname, int line_num, const char *args,
{
char *buf;

__asprintf (&buf, _("%s: line %d: expected service, found `%s'\n"),
fname, line_num, start);
if (__asprintf (&buf,
_("%s: line %d: expected service, found `%s'\n"),
fname, line_num, start) < 0)
return 0;

#ifdef USE_IN_LIBIO
if (_IO_fwide (stderr, 0) > 0)
Expand All @@ -162,9 +164,10 @@ arg_service_list (const char *fname, int line_num, const char *args,
{
char *buf;

__asprintf (&buf,
_("%s: line %d: cannot specify more than %d services"),
fname, line_num, SERVICE_MAX);
if (__asprintf (&buf, _("\
%s: line %d: cannot specify more than %d services"),
fname, line_num, SERVICE_MAX) < 0)
return 0;

#ifdef USE_IN_LIBIO
if (_IO_fwide (stderr, 0) > 0)
Expand All @@ -189,9 +192,10 @@ arg_service_list (const char *fname, int line_num, const char *args,
{
char *buf;

__asprintf (&buf, _("\
if (__asprintf (&buf, _("\
%s: line %d: list delimiter not followed by keyword"),
fname, line_num);
fname, line_num) < 0)
return 0;

#ifdef USE_IN_LIBIO
if (_IO_fwide (stderr, 0) > 0)
Expand Down Expand Up @@ -229,9 +233,10 @@ arg_trimdomain_list (const char *fname, int line_num, const char *args,
{
char *buf;

__asprintf (&buf, _("\
if (__asprintf (&buf, _("\
%s: line %d: cannot specify more than %d trim domains"),
fname, line_num, TRIMDOMAINS_MAX);
fname, line_num, TRIMDOMAINS_MAX) < 0)
return 0;

#ifdef USE_IN_LIBIO
if (_IO_fwide (stderr, 0) > 0)
Expand All @@ -254,9 +259,10 @@ arg_trimdomain_list (const char *fname, int line_num, const char *args,
{
char *buf;

__asprintf (&buf, _("\
if (__asprintf (&buf, _("\
%s: line %d: list delimiter not followed by domain"),
fname, line_num);
fname, line_num) < 0)
return 0;

#ifdef USE_IN_LIBIO
if (_IO_fwide (stderr, 0) > 0)
Expand Down Expand Up @@ -316,9 +322,10 @@ arg_bool (const char *fname, int line_num, const char *args, unsigned flag)
{
char *buf;

__asprintf (&buf,
_("%s: line %d: expected `on' or `off', found `%s'\n"),
fname, line_num, args);
if (__asprintf (&buf,
_("%s: line %d: expected `on' or `off', found `%s'\n"),
fname, line_num, args) < 0)
return 0;

#ifdef USE_IN_LIBIO
if (_IO_fwide (stderr, 0) > 0)
Expand Down Expand Up @@ -364,8 +371,9 @@ parse_line (const char *fname, int line_num, const char *str)
{
char *buf;

__asprintf (&buf, _("%s: line %d: bad command `%s'\n"),
fname, line_num, start);
if (__asprintf (&buf, _("%s: line %d: bad command `%s'\n"),
fname, line_num, start) < 0)
return;

#ifdef USE_IN_LIBIO
if (_IO_fwide (stderr, 0) > 0)
Expand All @@ -392,9 +400,10 @@ parse_line (const char *fname, int line_num, const char *str)
{
char *buf;

__asprintf (&buf,
_("%s: line %d: ignoring trailing garbage `%s'\n"),
fname, line_num, str);
if (__asprintf (&buf,
_("%s: line %d: ignoring trailing garbage `%s'\n"),
fname, line_num, str) < 0)
break;

#ifdef USE_IN_LIBIO
if (_IO_fwide (stderr, 0) > 0)
Expand Down
8 changes: 7 additions & 1 deletion stdio-common/psignal.c
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,13 @@ psignal (int sig, const char *s)
{
char *buf;

(void) __asprintf (&buf, _("%s%sUnknown signal %d\n"), s, colon, sig);
if (__asprintf (&buf, _("%s%sUnknown signal %d\n"), s, colon, sig) < 0)
{
if (_IO_fwide (stderr, 0) > 0)
(void) __fwprintf (stderr, L"%s%s%s\n", s, colon, _("Unknown signal"));
else
(void) fprintf (stderr, "%s%s%s\n", s, colon, _("Unknown signal"));
}

if (_IO_fwide (stderr, 0) > 0)
(void) __fwprintf (stderr, L"%s", buf);
Expand Down
26 changes: 17 additions & 9 deletions sunrpc/svc_simple.c
Original file line number Diff line number Diff line change
Expand Up @@ -84,8 +84,9 @@ registerrpc (u_long prognum, u_long versnum, u_long procnum,
if (procnum == NULLPROC)
{

(void) __asprintf (&buf, _("can't reassign procedure number %ld\n"),
NULLPROC);
if (__asprintf (&buf, _("can't reassign procedure number %ld\n"),
NULLPROC) < 0)
buf = NULL;
goto err_out;
}
if (transp == 0)
Expand All @@ -101,8 +102,9 @@ registerrpc (u_long prognum, u_long versnum, u_long procnum,
if (!svc_register (transp, (u_long) prognum, (u_long) versnum,
universal, IPPROTO_UDP))
{
(void) __asprintf (&buf, _("couldn't register prog %ld vers %ld\n"),
prognum, versnum);
if (__asprintf (&buf, _("couldn't register prog %ld vers %ld\n"),
prognum, versnum) < 0)
buf = NULL;
goto err_out;
}
pl = (struct proglst_ *) malloc (sizeof (struct proglst_));
Expand All @@ -121,6 +123,8 @@ registerrpc (u_long prognum, u_long versnum, u_long procnum,
return 0;

err_out:
if (buf == NULL)
return -1;
#ifdef USE_IN_LIBIO
if (_IO_fwide (stderr, 0) > 0)
(void) __fwprintf (stderr, L"%s", buf);
Expand Down Expand Up @@ -171,16 +175,20 @@ universal (struct svc_req *rqstp, SVCXPRT *transp_l)
return;
if (!INTUSE(svc_sendreply) (transp_l, pl->p_outproc, outdata))
{
(void) __asprintf (&buf,
_("trouble replying to prog %d\n"),
pl->p_prognum);
exit (1);
if (__asprintf (&buf, _("trouble replying to prog %d\n"),
pl->p_prognum) < 0)
buf = NULL;
goto err_out2;
}
/* free the decoded arguments */
(void) svc_freeargs (transp_l, pl->p_inproc, xdrbuf);
return;
}
(void) __asprintf (&buf, _("never registered prog %d\n"), prog);
if (__asprintf (&buf, _("never registered prog %d\n"), prog) < 0)
buf = NULL;
err_out2:
if (buf == NULL)
exit (1);
#ifdef USE_IN_LIBIO
if (_IO_fwide (stderr, 0) > 0)
__fwprintf (stderr, L"%s", buf);
Expand Down

0 comments on commit 322861e

Please sign in to comment.