files: distinguish between read error and write error when prepending
This fixes https://savannah.gnu.org/bugs/?57066. Bug existed in this form since version 2.4.3 -- in older versions it segfaulted.master
parent
50ed18be17
commit
5390f96900
10
src/files.c
10
src/files.c
|
@ -1703,6 +1703,7 @@ bool write_file(const char *name, FILE *stream, bool tmp,
|
||||||
if (method == PREPEND) {
|
if (method == PREPEND) {
|
||||||
FILE *source = fopen(realname, "rb");
|
FILE *source = fopen(realname, "rb");
|
||||||
FILE *target = NULL;
|
FILE *target = NULL;
|
||||||
|
int verdict;
|
||||||
|
|
||||||
if (source == NULL) {
|
if (source == NULL) {
|
||||||
statusline(ALERT, _("Error reading %s: %s"), realname,
|
statusline(ALERT, _("Error reading %s: %s"), realname,
|
||||||
|
@ -1718,7 +1719,14 @@ bool write_file(const char *name, FILE *stream, bool tmp,
|
||||||
goto cleanup_and_exit;
|
goto cleanup_and_exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (copy_file(source, target, TRUE) != 0) {
|
verdict = copy_file(source, target, TRUE);
|
||||||
|
|
||||||
|
if (verdict == -1) {
|
||||||
|
statusline(ALERT, _("Error reading %s: %s"), realname,
|
||||||
|
strerror(errno));
|
||||||
|
unlink(tempname);
|
||||||
|
goto cleanup_and_exit;
|
||||||
|
} else if (verdict == -2) {
|
||||||
statusline(ALERT, _("Error writing temp file: %s"),
|
statusline(ALERT, _("Error writing temp file: %s"),
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
unlink(tempname);
|
unlink(tempname);
|
||||||
|
|
Loading…
Reference in New Issue