Improve vipw error report when editor fails
* src/vipw.c: After waitpid(), use errno only if waitpid returned -1. Debian#688260 * src/vipw.c: Likewise for system().
This commit is contained in:
parent
d409947e9a
commit
5e87ff0615
@ -1,3 +1,9 @@
|
|||||||
|
2013-08-25 Nicolas François <nicolas.francois@centraliens.net>
|
||||||
|
|
||||||
|
* src/vipw.c: After waitpid(), use errno only if waitpid returned
|
||||||
|
-1. Debian#688260
|
||||||
|
* src/vipw.c: Likewise for system().
|
||||||
|
|
||||||
2013-08-23 victory <victory.deb@gmail.com>
|
2013-08-23 victory <victory.deb@gmail.com>
|
||||||
|
|
||||||
* po/ja.po: Updated to 558t
|
* po/ja.po: Updated to 558t
|
||||||
|
29
src/vipw.c
29
src/vipw.c
@ -180,7 +180,10 @@ static void vipwexit (const char *msg, int syserr, int ret)
|
|||||||
if (0 != syserr) {
|
if (0 != syserr) {
|
||||||
fprintf (stderr, ": %s", strerror (err));
|
fprintf (stderr, ": %s", strerror (err));
|
||||||
}
|
}
|
||||||
|
if ( (NULL != msg)
|
||||||
|
|| (0 != syserr)) {
|
||||||
(void) fputs ("\n", stderr);
|
(void) fputs ("\n", stderr);
|
||||||
|
}
|
||||||
if (!quiet) {
|
if (!quiet) {
|
||||||
fprintf (stdout, _("%s: %s is unchanged\n"), Prog,
|
fprintf (stdout, _("%s: %s is unchanged\n"), Prog,
|
||||||
filename);
|
filename);
|
||||||
@ -297,14 +300,25 @@ vipwedit (const char *file, int (*file_lock) (void), int (*file_unlock) (void))
|
|||||||
/* use the system() call to invoke the editor so that it accepts
|
/* use the system() call to invoke the editor so that it accepts
|
||||||
command line args in the EDITOR and VISUAL environment vars */
|
command line args in the EDITOR and VISUAL environment vars */
|
||||||
char *buf;
|
char *buf;
|
||||||
|
int status;
|
||||||
|
|
||||||
buf = (char *) malloc (strlen (editor) + strlen (fileedit) + 2);
|
buf = (char *) malloc (strlen (editor) + strlen (fileedit) + 2);
|
||||||
snprintf (buf, strlen (editor) + strlen (fileedit) + 2,
|
snprintf (buf, strlen (editor) + strlen (fileedit) + 2,
|
||||||
"%s %s", editor, fileedit);
|
"%s %s", editor, fileedit);
|
||||||
if (system (buf) != 0) {
|
status = system (buf);
|
||||||
fprintf (stderr, "%s: %s: %s\n", Prog, editor,
|
if (-1 == status) {
|
||||||
|
fprintf (stderr, _("%s: %s: %s\n"), Prog, editor,
|
||||||
strerror (errno));
|
strerror (errno));
|
||||||
exit (1);
|
exit (1);
|
||||||
|
} else if ( WIFEXITED (status)
|
||||||
|
&& (WEXITSTATUS (status) != 0)) {
|
||||||
|
fprintf (stderr, _("%s: %s returned with status %d\n"),
|
||||||
|
Prog, editor, WEXITSTATUS (status));
|
||||||
|
exit (WEXITSTATUS (status));
|
||||||
|
} else if (WIFSIGNALED (status)) {
|
||||||
|
fprintf (stderr, _("%s: %s killed by signal %d\n"),
|
||||||
|
Prog, editor, WTERMSIG (status));
|
||||||
|
exit (1);
|
||||||
} else {
|
} else {
|
||||||
exit (0);
|
exit (0);
|
||||||
}
|
}
|
||||||
@ -323,10 +337,15 @@ vipwedit (const char *file, int (*file_lock) (void), int (*file_unlock) (void))
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( (-1 == pid)
|
if (-1 == pid) {
|
||||||
|| (WIFEXITED (status) == 0)
|
|
||||||
|| (WEXITSTATUS (status) != 0)) {
|
|
||||||
vipwexit (editor, 1, 1);
|
vipwexit (editor, 1, 1);
|
||||||
|
} else if ( WIFEXITED (status)
|
||||||
|
&& (WEXITSTATUS (status) != 0)) {
|
||||||
|
vipwexit (NULL, 0, WEXITSTATUS (status));
|
||||||
|
} else if (WIFSIGNALED (status)) {
|
||||||
|
fprintf (stderr, _("%s: %s killed by signal %d\n"),
|
||||||
|
Prog, editor, WTERMSIG(status));
|
||||||
|
vipwexit (NULL, 0, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (stat (fileedit, &st2) != 0) {
|
if (stat (fileedit, &st2) != 0) {
|
||||||
|
Loading…
Reference in New Issue
Block a user