mirror of
https://github.com/coreutils/coreutils.git
synced 2025-01-07 16:43:22 +08:00
(FAIL_ONLY_ONE_WAY): New macro. Factor out some duplication.
(main): Use it. [case 'a']: Use strtoul rather than strtol to avoid compiler warnings.
This commit is contained in:
parent
6fee4452d3
commit
fd5bc32835
40
src/split.c
40
src/split.c
@ -191,7 +191,7 @@ cwrite (int new_file_flag, const char *bp, int bytes)
|
|||||||
if (output_desc < 0)
|
if (output_desc < 0)
|
||||||
error (EXIT_FAILURE, errno, "%s", outfile);
|
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);
|
error (EXIT_FAILURE, errno, "%s", outfile);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -358,6 +358,14 @@ line_bytes_split (int nchars)
|
|||||||
free (buf);
|
free (buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define FAIL_ONLY_ONE_WAY() \
|
||||||
|
do \
|
||||||
|
{ \
|
||||||
|
error (0, 0, _("cannot split in more than one way")); \
|
||||||
|
usage (EXIT_FAILURE); \
|
||||||
|
} \
|
||||||
|
while (0)
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc, char **argv)
|
main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
@ -401,21 +409,21 @@ main (int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 'a':
|
case 'a':
|
||||||
if (xstrtol (optarg, NULL, 10, &tmp_long, "") != LONGINT_OK
|
{
|
||||||
|| tmp_long < 0 || tmp_long > SIZE_MAX)
|
unsigned long tmp;
|
||||||
|
if (xstrtoul (optarg, NULL, 10, &tmp, "") != LONGINT_OK
|
||||||
|
|| SIZE_MAX < tmp)
|
||||||
{
|
{
|
||||||
error (0, 0, _("%s: invalid suffix length"), optarg);
|
error (0, 0, _("%s: invalid suffix length"), optarg);
|
||||||
usage (EXIT_FAILURE);
|
usage (EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
suffix_length = tmp_long;
|
suffix_length = tmp;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'b':
|
case 'b':
|
||||||
if (split_type != type_undef)
|
if (split_type != type_undef)
|
||||||
{
|
FAIL_ONLY_ONE_WAY ();
|
||||||
error (0, 0, _("cannot split in more than one way"));
|
|
||||||
usage (EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
split_type = type_bytes;
|
split_type = type_bytes;
|
||||||
if (xstrtol (optarg, NULL, 10, &tmp_long, "bkm") != LONGINT_OK
|
if (xstrtol (optarg, NULL, 10, &tmp_long, "bkm") != LONGINT_OK
|
||||||
|| tmp_long < 0 || tmp_long > INT_MAX)
|
|| tmp_long < 0 || tmp_long > INT_MAX)
|
||||||
@ -428,10 +436,7 @@ main (int argc, char **argv)
|
|||||||
|
|
||||||
case 'l':
|
case 'l':
|
||||||
if (split_type != type_undef)
|
if (split_type != type_undef)
|
||||||
{
|
FAIL_ONLY_ONE_WAY ();
|
||||||
error (0, 0, _("cannot split in more than one way"));
|
|
||||||
usage (EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
split_type = type_lines;
|
split_type = type_lines;
|
||||||
if (xstrtol (optarg, NULL, 10, &tmp_long, "") != LONGINT_OK
|
if (xstrtol (optarg, NULL, 10, &tmp_long, "") != LONGINT_OK
|
||||||
|| tmp_long < 0 || tmp_long > INT_MAX)
|
|| tmp_long < 0 || tmp_long > INT_MAX)
|
||||||
@ -444,11 +449,7 @@ main (int argc, char **argv)
|
|||||||
|
|
||||||
case 'C':
|
case 'C':
|
||||||
if (split_type != type_undef)
|
if (split_type != type_undef)
|
||||||
{
|
FAIL_ONLY_ONE_WAY ();
|
||||||
error (0, 0, _("cannot split in more than one way"));
|
|
||||||
usage (EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
|
|
||||||
split_type = type_byteslines;
|
split_type = type_byteslines;
|
||||||
if (xstrtol (optarg, NULL, 10, &tmp_long, "bkm") != LONGINT_OK
|
if (xstrtol (optarg, NULL, 10, &tmp_long, "bkm") != LONGINT_OK
|
||||||
|| tmp_long < 0 || tmp_long > INT_MAX)
|
|| tmp_long < 0 || tmp_long > INT_MAX)
|
||||||
@ -470,10 +471,7 @@ main (int argc, char **argv)
|
|||||||
case '8':
|
case '8':
|
||||||
case '9':
|
case '9':
|
||||||
if (split_type != type_undef && split_type != type_digits)
|
if (split_type != type_undef && split_type != type_digits)
|
||||||
{
|
FAIL_ONLY_ONE_WAY ();
|
||||||
error (0, 0, _("cannot split in more than one way"));
|
|
||||||
usage (EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
if (digits_optind != 0 && digits_optind != this_optind)
|
if (digits_optind != 0 && digits_optind != this_optind)
|
||||||
accum = 0; /* More than one number given; ignore other. */
|
accum = 0; /* More than one number given; ignore other. */
|
||||||
digits_optind = this_optind;
|
digits_optind = this_optind;
|
||||||
|
Loading…
Reference in New Issue
Block a user