1999-12-24  Ulrich Drepper  <drepper@cygnus.com>

	* sysdeps/posix/system.c (__libc_system): Check whether command
	processor is available if LINE is NULL.  Don't return immediately
	if wait call returned with EINTR.
	Patches by Geoff Clare <gwc@unisoft.com> (PR libc/1497 and libc/1498).
This commit is contained in:
Ulrich Drepper 1999-12-24 08:27:33 +00:00
parent 293321753c
commit ce40141c6b
3 changed files with 30 additions and 10 deletions

View File

@ -1,3 +1,10 @@
1999-12-24 Ulrich Drepper <drepper@cygnus.com>
* sysdeps/posix/system.c (__libc_system): Check whether command
processor is available if LINE is NULL. Don't return immediately
if wait call returned with EINTR.
Patches by Geoff Clare <gwc@unisoft.com> (PR libc/1497 and libc/1498).
1999-12-23 Ulrich Drepper <drepper@cygnus.com>
* locale/programs/ld-monetary.c (monetary_finish): Add cast to

View File

@ -1583,7 +1583,7 @@ output_weight (struct obstack *pool, struct locale_collate_t *collate,
if (elem->weights[cnt].w[i] == NULL)
{
/* This entry was IGNORE. */
buf[len++] = '\3';
buf[len++] = IGNORE_CHAR;
}
else
len += utf8_encode (&buf[len],
@ -1839,6 +1839,9 @@ collate_output (struct localedef_t *locale, struct charmap_t *charmap,
assert (cnt == _NL_ITEM_INDEX (_NL_NUM_LC_COLLATE));
write_locale_data (output_path, "LC_COLLATE", 2 + cnt, iov);
obstack_free (&weightpool, NULL);
obstack_free (&extrapool, NULL);
}

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1991, 92, 94, 95, 96, 97 Free Software Foundation, Inc.
/* Copyright (C) 1991, 92, 94, 95, 96, 97, 99 Free Software Foundation, Inc.
This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or
@ -44,8 +44,9 @@ __libc_system (const char *line)
#endif
if (line == NULL)
/* This signals that we have a command processor available. */
return 1;
/* Check that we have a command processor available. It might
not be available after a chroot(), for example. */
return __libc_system ("exit 0");
sa.sa_handler = SIG_IGN;
sa.sa_flags = 0;
@ -113,23 +114,32 @@ __libc_system (const char *line)
status = -1;
else
/* Parent side. */
#ifdef NO_WAITPID
{
#ifdef NO_WAITPID
pid_t child;
do
{
child = __wait (&status);
if (child <= -1)
if (child <= -1 && errno != EINTR)
{
status = -1;
break;
}
} while (child != pid);
}
/* Note that pid cannot be <= -1 and therefore the loop continues
when __wait returned with EINTR. */
}
while (child != pid);
#else
if (__waitpid (pid, &status, 0) != pid)
status = -1;
int n;
do
n = __waitpid (pid, &status, 0);
while (n == -1 && errno == EINTR);
if (n != pid)
status = -1;
#endif
}
save = errno;
if ((__sigaction (SIGINT, &intr, (struct sigaction *) NULL) |