diff options
author | Jim Meyering <jim@meyering.net> | 2002-09-28 16:50:34 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2002-09-28 16:50:34 +0000 |
commit | fd5bc3283527d846d5107fc853afee8d5b6cdeb8 (patch) | |
tree | d001fe5d785b96e813a47f52b52707781186ca42 | |
parent | 6fee4452d3ea3dd5aa5d8aad5d4449221016e234 (diff) | |
download | coreutils-fd5bc3283527d846d5107fc853afee8d5b6cdeb8.tar.xz |
(FAIL_ONLY_ONE_WAY): New macro. Factor out some duplication.
(main): Use it.
[case 'a']: Use strtoul rather than strtol to avoid compiler warnings.
-rw-r--r-- | src/split.c | 48 |
1 files changed, 23 insertions, 25 deletions
diff --git a/src/split.c b/src/split.c index f47039529..fc9786766 100644 --- a/src/split.c +++ b/src/split.c @@ -191,7 +191,7 @@ cwrite (int new_file_flag, const char *bp, int bytes) if (output_desc < 0) error (EXIT_FAILURE, errno, "%s", outfile); } - if (full_write (output_desc, bp, bytes) != bytes) + if (full_write (output_desc, bp, bytes) != (size_t) bytes) error (EXIT_FAILURE, errno, "%s", outfile); } @@ -358,6 +358,14 @@ line_bytes_split (int nchars) free (buf); } +#define FAIL_ONLY_ONE_WAY() \ + do \ + { \ + error (0, 0, _("cannot split in more than one way")); \ + usage (EXIT_FAILURE); \ + } \ + while (0) + int main (int argc, char **argv) { @@ -401,21 +409,21 @@ main (int argc, char **argv) break; case 'a': - if (xstrtol (optarg, NULL, 10, &tmp_long, "") != LONGINT_OK - || tmp_long < 0 || tmp_long > SIZE_MAX) - { - error (0, 0, _("%s: invalid suffix length"), optarg); - usage (EXIT_FAILURE); - } - suffix_length = tmp_long; + { + unsigned long tmp; + if (xstrtoul (optarg, NULL, 10, &tmp, "") != LONGINT_OK + || SIZE_MAX < tmp) + { + error (0, 0, _("%s: invalid suffix length"), optarg); + usage (EXIT_FAILURE); + } + suffix_length = tmp; + } break; case 'b': if (split_type != type_undef) - { - error (0, 0, _("cannot split in more than one way")); - usage (EXIT_FAILURE); - } + FAIL_ONLY_ONE_WAY (); split_type = type_bytes; if (xstrtol (optarg, NULL, 10, &tmp_long, "bkm") != LONGINT_OK || tmp_long < 0 || tmp_long > INT_MAX) @@ -428,10 +436,7 @@ main (int argc, char **argv) case 'l': if (split_type != type_undef) - { - error (0, 0, _("cannot split in more than one way")); - usage (EXIT_FAILURE); - } + FAIL_ONLY_ONE_WAY (); split_type = type_lines; if (xstrtol (optarg, NULL, 10, &tmp_long, "") != LONGINT_OK || tmp_long < 0 || tmp_long > INT_MAX) @@ -444,11 +449,7 @@ main (int argc, char **argv) case 'C': if (split_type != type_undef) - { - error (0, 0, _("cannot split in more than one way")); - usage (EXIT_FAILURE); - } - + FAIL_ONLY_ONE_WAY (); split_type = type_byteslines; if (xstrtol (optarg, NULL, 10, &tmp_long, "bkm") != LONGINT_OK || tmp_long < 0 || tmp_long > INT_MAX) @@ -470,10 +471,7 @@ main (int argc, char **argv) case '8': case '9': if (split_type != type_undef && split_type != type_digits) - { - error (0, 0, _("cannot split in more than one way")); - usage (EXIT_FAILURE); - } + FAIL_ONLY_ONE_WAY (); if (digits_optind != 0 && digits_optind != this_optind) accum = 0; /* More than one number given; ignore other. */ digits_optind = this_optind; |