diff options
author | Glenn L McGrath <bug1@ihug.co.nz> | 2003-06-07 17:38:33 +0000 |
---|---|---|
committer | Glenn L McGrath <bug1@ihug.co.nz> | 2003-06-07 17:38:33 +0000 |
commit | a721204ec502238198b5703cfea99fd97cbca266 (patch) | |
tree | 431ea4e9635339feefe6ff6a94b031c0c14a62e6 | |
parent | a9e4617494537a65ecc711003414a4f97eaad8cc (diff) |
Better error handling
-rw-r--r-- | coreutils/sha1sum.c | 25 |
1 files changed, 16 insertions, 9 deletions
diff --git a/coreutils/sha1sum.c b/coreutils/sha1sum.c index c6534b5cb..1c31e3c55 100644 --- a/coreutils/sha1sum.c +++ b/coreutils/sha1sum.c @@ -112,7 +112,7 @@ static void sha_hash(unsigned int *data, int *hash) hash[4] += e; } -static void sha1sum_stream(FILE *fd, unsigned int *hashval) +static char sha1sum_stream(FILE *fd, unsigned int *hashval) { RESERVE_CONFIG_BUFFER(buffer, 64); int length = 0; @@ -145,7 +145,7 @@ static void sha1sum_stream(FILE *fd, unsigned int *hashval) RELEASE_CONFIG_BUFFER(buffer); - return; + return(EXIT_SUCCESS); } static void print_hash(unsigned int *hash_value, unsigned char hash_length, unsigned char *filename) @@ -167,11 +167,12 @@ static void print_hash(unsigned int *hash_value, unsigned char hash_length, unsi /* This should become a common function used by sha1sum and md5sum, * it needs extra functionality first */ -extern int authenticate(int argc, char **argv, void (*hash_ptr)(FILE *stream, unsigned int *hashval), const unsigned char hash_length) +extern int authenticate(int argc, char **argv, char (*hash_ptr)(FILE *stream, unsigned int *hashval), const unsigned char hash_length) { unsigned int hash_value[hash_length]; unsigned char flags = 0; int opt; + int return_value; while ((opt = getopt(argc, argv, "sc:w")) != -1) { switch (opt) { @@ -193,31 +194,37 @@ extern int authenticate(int argc, char **argv, void (*hash_ptr)(FILE *stream, un argv[argc++] = "-"; } + return_value = EXIT_SUCCESS; while (optind < argc) { FILE *stream; unsigned char *file_ptr = argv[optind]; + optind++; + if ((file_ptr[0] == '-') && (file_ptr[1] == '\0')) { stream = stdin; } else { stream = bb_wfopen(file_ptr, "r"); if (stream == NULL) { - return(EXIT_FAILURE); + return_value = EXIT_FAILURE; + continue; } } - hash_ptr(stream, hash_value); - if (!flags & FLAG_SILENT) { + if (hash_ptr(stream, hash_value) == EXIT_FAILURE) { + return_value = EXIT_FAILURE; + } + else if (!flags & FLAG_SILENT) { print_hash(hash_value, hash_length, file_ptr); } if (fclose(stream) == EOF) { - bb_perror_msg_and_die("Couldnt close file %s", file_ptr); + bb_perror_msg("Couldnt close file %s", file_ptr); + return_value = EXIT_FAILURE; } - optind++; } - return(EXIT_SUCCESS); + return(return_value); } extern int sha1sum_main(int argc, char **argv) |