Simplify return & fshut() logic

Get rid of the !!()-constructs and use ret where available (or introduce it).

In some cases, there would be an "abort" on the first fshut-error, but we want
to close all files and report all warnings and then quit, not just the warning
for the first file.
This commit is contained in:
FRIGN
2015-05-25 01:33:19 +02:00
committed by sin
parent e8a4f37884
commit d23cc72490
34 changed files with 142 additions and 72 deletions

View File

@@ -50,7 +50,7 @@ main(int argc, char *argv[])
FILE *in = stdin, *out = NULL;
size_t size = 1000, scale = 1, n;
long l;
int ch, plen, slen = 2, always = 0;
int ret = 0, ch, plen, slen = 2, always = 0;
char name[NAME_MAX + 1], *prefix = "x", *file = NULL, *tmp, *end;
ARGBEGIN {
@@ -124,6 +124,9 @@ main(int argc, char *argv[])
putc(ch, out);
}
return !!(fshut(in, "<infile>") + (out && fshut(out, "<outfile>")) +
fshut(stdin, "<stdin>") + fshut(stdout, "<stdout>"));
ret |= (in != stdin) && fshut(in, "<infile>");
ret |= out && (out != stdout) && fshut(out, "<outfile>");
ret |= fshut(stdin, "<stdin>") | fshut(stdout, "<stdout>");
return ret;
}