summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>2003-09-23 12:09:33 +0000
committerJim Meyering <jim@meyering.net>2003-09-23 12:09:33 +0000
commit80aa0840d7337070947243902370609cc69cb2ee (patch)
tree80e92209f7f2b2d2c328d6ddd905b3e31fad5e2b /src
parent46369400c745f255663923b123853436bc94b105 (diff)
downloadcoreutils-80aa0840d7337070947243902370609cc69cb2ee.tar.xz
(compare_files): Save errno after input error, to report proper errno value.
Diffstat (limited to 'src')
-rw-r--r--src/comm.c21
1 files changed, 18 insertions, 3 deletions
diff --git a/src/comm.c b/src/comm.c
index 0b69e5c36..736a60d82 100644
--- a/src/comm.c
+++ b/src/comm.c
@@ -144,6 +144,9 @@ compare_files (char **infiles)
/* streams[i] holds the input stream for file i. */
FILE *streams[2];
+ /* errno values for each stream. */
+ int saved_errno[2];
+
int i, ret = 0;
/* Initialize the storage. */
@@ -159,6 +162,7 @@ compare_files (char **infiles)
}
thisline[i] = readlinebuffer (thisline[i], streams[i]);
+ saved_errno[i] = errno;
}
while (thisline[0] || thisline[1])
@@ -198,16 +202,27 @@ compare_files (char **infiles)
/* Step the file the line came from.
If the files match, step both files. */
if (order >= 0)
- thisline[1] = readlinebuffer (thisline[1], streams[1]);
+ {
+ thisline[1] = readlinebuffer (thisline[1], streams[1]);
+ saved_errno[1] = errno;
+ }
if (order <= 0)
- thisline[0] = readlinebuffer (thisline[0], streams[0]);
+ {
+ thisline[0] = readlinebuffer (thisline[0], streams[0]);
+ saved_errno[0] = errno;
+ }
}
/* Free all storage and close all input streams. */
for (i = 0; i < 2; i++)
{
free (lb1[i].buffer);
- if (ferror (streams[i]) || fclose (streams[i]) == EOF)
+ if (ferror (streams[i]))
+ {
+ error (0, saved_errno[i], "%s", infiles[i]);
+ ret = 1;
+ }
+ if (fclose (streams[i]) != 0)
{
error (0, errno, "%s", infiles[i]);
ret = 1;