summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul Eggert <eggert@cs.ucla.edu>2005-04-11 20:07:54 +0000
committerPaul Eggert <eggert@cs.ucla.edu>2005-04-11 20:07:54 +0000
commitaba88afdced70a8fea1de4f9871244ddf425b36c (patch)
tree150f296f5ee9ca6178db872bd49cbb7647d7a065
parentea778b6463b576bb12c851c8ee84b263a3bb64f9 (diff)
downloadcoreutils-aba88afdced70a8fea1de4f9871244ddf425b36c.tar.xz
Include stdio-safer.h.
(main): Use fopen_safer. Simplify the resulting code.
-rw-r--r--src/join.c13
1 files changed, 6 insertions, 7 deletions
diff --git a/src/join.c b/src/join.c
index 68156191a..682806a55 100644
--- a/src/join.c
+++ b/src/join.c
@@ -1,5 +1,5 @@
/* join - join lines of two files on a common field
- Copyright (C) 91, 1995-2004 Free Software Foundation, Inc.
+ Copyright (C) 91, 1995-2005 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -31,6 +31,7 @@
#include "memcasecmp.h"
#include "posixver.h"
#include "quote.h"
+#include "stdio-safer.h"
#include "xmemcoll.h"
#include "xstrtol.h"
@@ -852,22 +853,20 @@ main (int argc, char **argv)
usage (EXIT_FAILURE);
}
- fp1 = STREQ (names[0], "-") ? stdin : fopen (names[0], "r");
+ fp1 = STREQ (names[0], "-") ? stdin : fopen_safer (names[0], "r");
if (!fp1)
error (EXIT_FAILURE, errno, "%s", names[0]);
- fp2 = STREQ (names[1], "-") ? stdin : fopen (names[1], "r");
+ fp2 = STREQ (names[1], "-") ? stdin : fopen_safer (names[1], "r");
if (!fp2)
error (EXIT_FAILURE, errno, "%s", names[1]);
if (fp1 == fp2)
error (EXIT_FAILURE, errno, _("both files cannot be standard input"));
join (fp1, fp2);
- if (fp1 != stdin && fclose (fp1) == EOF)
+ if (fclose (fp1) != 0)
error (EXIT_FAILURE, errno, "%s", names[0]);
- if (fp2 != stdin && fclose (fp2) == EOF)
+ if (fclose (fp2) != 0)
error (EXIT_FAILURE, errno, "%s", names[1]);
- if ((fp1 == stdin || fp2 == stdin) && fclose (stdin) == EOF)
- error (EXIT_FAILURE, errno, "-");
exit (EXIT_SUCCESS);
}