char *str;
{
int pid, exitstatus, waitval;
+ int (*sigint)(), (*sigquit)();
int i;
- if ((pid = fork()) < 0) return -1;
+ if ((pid = fork()) < 0) return -1; /* How do we distinguish this
+ from exit status -1?
+ */
if (pid == 0) {
for (i = 3; i <= 20; i++) close(i);
execl("/bin/sh", "sh", "-c", str, (char *) 0);
/* get here if execl fails ... */
_exit(127); /* see manual page */
}
+
+ sigint = signal( SIGINT, SIG_IGN );
+ sigquit = signal( SIGQUIT, SIG_IGN );
+
while ((waitval = wait(&exitstatus)) != pid) {
if (waitval == -1) break;
}
/* no child ??? or maybe interrupted ??? */
exitstatus = -1;
}
+
+ signal( SIGINT, sigint );
+ signal( SIGQUIT, sigquit );
+
return exitstatus;
}
return(-1);
while (*++cp != ':')
;
- for (++cp ; *cp ; cp++) {
+ while (*cp) {
+ cp++;
while (ISSPACE(*cp))
cp++;
if (strncmp(cp, id, CAPABLEN) == 0) {
return(-1);
while (*++cp != ':')
;
- for (++cp ; *cp ; cp++) {
+ while (*cp) {
+ cp++;
while (ISSPACE(*cp))
cp++;
if (strncmp(cp, id, CAPABLEN) == 0)
return(NULL);
while (*++cp != ':')
;
- for (++cp ; *cp ; cp++) {
+ while (*cp) {
+ cp++;
while (ISSPACE(*cp))
cp++;
if (strncmp(cp, id, CAPABLEN) == 0) {