Merge branch 'cb/parse-magnitude'
Move machinery to parse human-readable scaled numbers like 1k, 4M, and 2G as an option parameter's value from pack-objects to parse-options API, to make it available to other codepaths. * cb/parse-magnitude: parse-options: move unsigned long option parsing out of pack-objects.c test-parse-options: update to handle negative intsmaint
						commit
						e12b51e4d6
					
				|  | @ -168,6 +168,12 @@ There are some macros to easily define options: | |||
| 	Introduce an option with integer argument. | ||||
| 	The integer is put into `int_var`. | ||||
|  | ||||
| `OPT_MAGNITUDE(short, long, &unsigned_long_var, description)`:: | ||||
| 	Introduce an option with a size argument. The argument must be a | ||||
| 	non-negative integer and may include a suffix of 'k', 'm' or 'g' to | ||||
| 	scale the provided value by 1024, 1024^2 or 1024^3 respectively. | ||||
| 	The scaled value is put into `unsigned_long_var`. | ||||
|  | ||||
| `OPT_DATE(short, long, &int_var, description)`:: | ||||
| 	Introduce an option with date argument, see `approxidate()`. | ||||
| 	The timestamp is put into `int_var`. | ||||
|  |  | |||
|  | @ -2588,23 +2588,6 @@ static int option_parse_unpack_unreachable(const struct option *opt, | |||
| 	return 0; | ||||
| } | ||||
|  | ||||
| static int option_parse_ulong(const struct option *opt, | ||||
| 			      const char *arg, int unset) | ||||
| { | ||||
| 	if (unset) | ||||
| 		die(_("option %s does not accept negative form"), | ||||
| 		    opt->long_name); | ||||
|  | ||||
| 	if (!git_parse_ulong(arg, opt->value)) | ||||
| 		die(_("unable to parse value '%s' for option %s"), | ||||
| 		    arg, opt->long_name); | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| #define OPT_ULONG(s, l, v, h) \ | ||||
| 	{ OPTION_CALLBACK, (s), (l), (v), "n", (h),	\ | ||||
| 	  PARSE_OPT_NONEG, option_parse_ulong } | ||||
|  | ||||
| int cmd_pack_objects(int argc, const char **argv, const char *prefix) | ||||
| { | ||||
| 	int use_internal_rev_list = 0; | ||||
|  | @ -2627,16 +2610,16 @@ int cmd_pack_objects(int argc, const char **argv, const char *prefix) | |||
| 		{ OPTION_CALLBACK, 0, "index-version", NULL, N_("version[,offset]"), | ||||
| 		  N_("write the pack index file in the specified idx format version"), | ||||
| 		  0, option_parse_index_version }, | ||||
| 		OPT_ULONG(0, "max-pack-size", &pack_size_limit, | ||||
| 			  N_("maximum size of each output pack file")), | ||||
| 		OPT_MAGNITUDE(0, "max-pack-size", &pack_size_limit, | ||||
| 			      N_("maximum size of each output pack file")), | ||||
| 		OPT_BOOL(0, "local", &local, | ||||
| 			 N_("ignore borrowed objects from alternate object store")), | ||||
| 		OPT_BOOL(0, "incremental", &incremental, | ||||
| 			 N_("ignore packed objects")), | ||||
| 		OPT_INTEGER(0, "window", &window, | ||||
| 			    N_("limit pack window by objects")), | ||||
| 		OPT_ULONG(0, "window-memory", &window_memory_limit, | ||||
| 			  N_("limit pack window by memory in addition to object limit")), | ||||
| 		OPT_MAGNITUDE(0, "window-memory", &window_memory_limit, | ||||
| 			      N_("limit pack window by memory in addition to object limit")), | ||||
| 		OPT_INTEGER(0, "depth", &depth, | ||||
| 			    N_("maximum length of delta chain allowed in the resulting pack")), | ||||
| 		OPT_BOOL(0, "reuse-delta", &reuse_delta, | ||||
|  |  | |||
|  | @ -180,6 +180,23 @@ static int get_value(struct parse_opt_ctx_t *p, | |||
| 			return opterror(opt, "expects a numerical value", flags); | ||||
| 		return 0; | ||||
|  | ||||
| 	case OPTION_MAGNITUDE: | ||||
| 		if (unset) { | ||||
| 			*(unsigned long *)opt->value = 0; | ||||
| 			return 0; | ||||
| 		} | ||||
| 		if (opt->flags & PARSE_OPT_OPTARG && !p->opt) { | ||||
| 			*(unsigned long *)opt->value = opt->defval; | ||||
| 			return 0; | ||||
| 		} | ||||
| 		if (get_arg(p, opt, flags, &arg)) | ||||
| 			return -1; | ||||
| 		if (!git_parse_ulong(arg, opt->value)) | ||||
| 			return opterror(opt, | ||||
| 				"expects a non-negative integer value with an optional k/m/g suffix", | ||||
| 				flags); | ||||
| 		return 0; | ||||
|  | ||||
| 	default: | ||||
| 		die("should not happen, someone must be hit on the forehead"); | ||||
| 	} | ||||
|  |  | |||
|  | @ -16,6 +16,7 @@ enum parse_opt_type { | |||
| 	/* options with arguments (usually) */ | ||||
| 	OPTION_STRING, | ||||
| 	OPTION_INTEGER, | ||||
| 	OPTION_MAGNITUDE, | ||||
| 	OPTION_CALLBACK, | ||||
| 	OPTION_LOWLEVEL_CALLBACK, | ||||
| 	OPTION_FILENAME | ||||
|  | @ -129,6 +130,8 @@ struct option { | |||
| #define OPT_CMDMODE(s, l, v, h, i) { OPTION_CMDMODE, (s), (l), (v), NULL, \ | ||||
| 				      (h), PARSE_OPT_NOARG|PARSE_OPT_NONEG, NULL, (i) } | ||||
| #define OPT_INTEGER(s, l, v, h)     { OPTION_INTEGER, (s), (l), (v), N_("n"), (h) } | ||||
| #define OPT_MAGNITUDE(s, l, v, h)   { OPTION_MAGNITUDE, (s), (l), (v), \ | ||||
| 				      N_("n"), (h), PARSE_OPT_NONEG } | ||||
| #define OPT_STRING(s, l, v, a, h)   { OPTION_STRING,  (s), (l), (v), (a), (h) } | ||||
| #define OPT_STRING_LIST(s, l, v, a, h) \ | ||||
| 				    { OPTION_CALLBACK, (s), (l), (v), (a), \ | ||||
|  |  | |||
|  | @ -19,6 +19,7 @@ usage: test-parse-options <options> | |||
|  | ||||
|     -i, --integer <n>     get a integer | ||||
|     -j <n>                get a integer, too | ||||
|     -m, --magnitude <n>   get a magnitude | ||||
|     --set23               set integer to 23 | ||||
|     -t <time>             get timestamp of <time> | ||||
|     -L, --length <str>    get length of <str> | ||||
|  | @ -58,6 +59,7 @@ mv expect expect.err | |||
| cat >expect.template <<EOF | ||||
| boolean: 0 | ||||
| integer: 0 | ||||
| magnitude: 0 | ||||
| timestamp: 0 | ||||
| string: (not set) | ||||
| abbrev: 7 | ||||
|  | @ -132,9 +134,32 @@ test_expect_success 'OPT_BOOL() no negation #2' 'check_unknown_i18n --no-no-fear | |||
|  | ||||
| test_expect_success 'OPT_BOOL() positivation' 'check boolean: 0 -D --doubt' | ||||
|  | ||||
| test_expect_success 'OPT_INT() negative' 'check integer: -2345 -i -2345' | ||||
|  | ||||
| test_expect_success 'OPT_MAGNITUDE() simple' ' | ||||
| 	check magnitude: 2345678 -m 2345678 | ||||
| ' | ||||
|  | ||||
| test_expect_success 'OPT_MAGNITUDE() kilo' ' | ||||
| 	check magnitude: 239616 -m 234k | ||||
| ' | ||||
|  | ||||
| test_expect_success 'OPT_MAGNITUDE() mega' ' | ||||
| 	check magnitude: 104857600 -m 100m | ||||
| ' | ||||
|  | ||||
| test_expect_success 'OPT_MAGNITUDE() giga' ' | ||||
| 	check magnitude: 1073741824 -m 1g | ||||
| ' | ||||
|  | ||||
| test_expect_success 'OPT_MAGNITUDE() 3giga' ' | ||||
| 	check magnitude: 3221225472 -m 3g | ||||
| ' | ||||
|  | ||||
| cat > expect << EOF | ||||
| boolean: 2 | ||||
| integer: 1729 | ||||
| magnitude: 16384 | ||||
| timestamp: 0 | ||||
| string: 123 | ||||
| abbrev: 7 | ||||
|  | @ -145,8 +170,8 @@ file: prefix/my.file | |||
| EOF | ||||
|  | ||||
| test_expect_success 'short options' ' | ||||
| 	test-parse-options -s123 -b -i 1729 -b -vv -n -F my.file \ | ||||
| 	> output 2> output.err && | ||||
| 	test-parse-options -s123 -b -i 1729 -m 16k -b -vv -n -F my.file \ | ||||
| 	>output 2>output.err && | ||||
| 	test_cmp expect output && | ||||
| 	test_must_be_empty output.err | ||||
| ' | ||||
|  | @ -154,6 +179,7 @@ test_expect_success 'short options' ' | |||
| cat > expect << EOF | ||||
| boolean: 2 | ||||
| integer: 1729 | ||||
| magnitude: 16384 | ||||
| timestamp: 0 | ||||
| string: 321 | ||||
| abbrev: 10 | ||||
|  | @ -164,9 +190,10 @@ file: prefix/fi.le | |||
| EOF | ||||
|  | ||||
| test_expect_success 'long options' ' | ||||
| 	test-parse-options --boolean --integer 1729 --boolean --string2=321 \ | ||||
| 		--verbose --verbose --no-dry-run --abbrev=10 --file fi.le\ | ||||
| 		--obsolete > output 2> output.err && | ||||
| 	test-parse-options --boolean --integer 1729 --magnitude 16k \ | ||||
| 		--boolean --string2=321 --verbose --verbose --no-dry-run \ | ||||
| 		--abbrev=10 --file fi.le --obsolete \ | ||||
| 		>output 2>output.err && | ||||
| 	test_must_be_empty output.err && | ||||
| 	test_cmp expect output | ||||
| ' | ||||
|  | @ -180,6 +207,7 @@ test_expect_success 'missing required value' ' | |||
| cat > expect << EOF | ||||
| boolean: 1 | ||||
| integer: 13 | ||||
| magnitude: 0 | ||||
| timestamp: 0 | ||||
| string: 123 | ||||
| abbrev: 7 | ||||
|  | @ -202,6 +230,7 @@ test_expect_success 'intermingled arguments' ' | |||
| cat > expect << EOF | ||||
| boolean: 0 | ||||
| integer: 2 | ||||
| magnitude: 0 | ||||
| timestamp: 0 | ||||
| string: (not set) | ||||
| abbrev: 7 | ||||
|  | @ -230,6 +259,7 @@ test_expect_success 'ambiguously abbreviated option' ' | |||
| cat > expect << EOF | ||||
| boolean: 0 | ||||
| integer: 0 | ||||
| magnitude: 0 | ||||
| timestamp: 0 | ||||
| string: 123 | ||||
| abbrev: 7 | ||||
|  | @ -268,6 +298,7 @@ test_expect_success 'detect possible typos' ' | |||
| cat > expect <<EOF | ||||
| boolean: 0 | ||||
| integer: 0 | ||||
| magnitude: 0 | ||||
| timestamp: 0 | ||||
| string: (not set) | ||||
| abbrev: 7 | ||||
|  | @ -287,6 +318,7 @@ test_expect_success 'keep some options as arguments' ' | |||
| cat > expect <<EOF | ||||
| boolean: 0 | ||||
| integer: 0 | ||||
| magnitude: 0 | ||||
| timestamp: 1 | ||||
| string: (not set) | ||||
| abbrev: 7 | ||||
|  | @ -308,6 +340,7 @@ cat > expect <<EOF | |||
| Callback: "four", 0 | ||||
| boolean: 5 | ||||
| integer: 4 | ||||
| magnitude: 0 | ||||
| timestamp: 0 | ||||
| string: (not set) | ||||
| abbrev: 7 | ||||
|  | @ -336,6 +369,7 @@ test_expect_success 'OPT_CALLBACK() and callback errors work' ' | |||
| cat > expect <<EOF | ||||
| boolean: 1 | ||||
| integer: 23 | ||||
| magnitude: 0 | ||||
| timestamp: 0 | ||||
| string: (not set) | ||||
| abbrev: 7 | ||||
|  | @ -360,6 +394,7 @@ test_expect_success 'OPT_NEGBIT() and OPT_SET_INT() work' ' | |||
| cat > expect <<EOF | ||||
| boolean: 6 | ||||
| integer: 0 | ||||
| magnitude: 0 | ||||
| timestamp: 0 | ||||
| string: (not set) | ||||
| abbrev: 7 | ||||
|  | @ -390,6 +425,7 @@ test_expect_success 'OPT_COUNTUP() with PARSE_OPT_NODASH works' ' | |||
| cat > expect <<EOF | ||||
| boolean: 0 | ||||
| integer: 12345 | ||||
| magnitude: 0 | ||||
| timestamp: 0 | ||||
| string: (not set) | ||||
| abbrev: 7 | ||||
|  | @ -408,6 +444,7 @@ test_expect_success 'OPT_NUMBER_CALLBACK() works' ' | |||
| cat >expect <<EOF | ||||
| boolean: 0 | ||||
| integer: 0 | ||||
| magnitude: 0 | ||||
| timestamp: 0 | ||||
| string: (not set) | ||||
| abbrev: 7 | ||||
|  |  | |||
|  | @ -4,6 +4,7 @@ | |||
|  | ||||
| static int boolean = 0; | ||||
| static int integer = 0; | ||||
| static unsigned long magnitude = 0; | ||||
| static unsigned long timestamp; | ||||
| static int abbrev = 7; | ||||
| static int verbose = 0, dry_run = 0, quiet = 0; | ||||
|  | @ -48,6 +49,7 @@ int main(int argc, char **argv) | |||
| 		OPT_GROUP(""), | ||||
| 		OPT_INTEGER('i', "integer", &integer, "get a integer"), | ||||
| 		OPT_INTEGER('j', NULL, &integer, "get a integer, too"), | ||||
| 		OPT_MAGNITUDE('m', "magnitude", &magnitude, "get a magnitude"), | ||||
| 		OPT_SET_INT(0, "set23", &integer, "set integer to 23", 23), | ||||
| 		OPT_DATE('t', NULL, ×tamp, "get timestamp of <time>"), | ||||
| 		OPT_CALLBACK('L', "length", &integer, "str", | ||||
|  | @ -82,7 +84,8 @@ int main(int argc, char **argv) | |||
| 	argc = parse_options(argc, (const char **)argv, prefix, options, usage, 0); | ||||
|  | ||||
| 	printf("boolean: %d\n", boolean); | ||||
| 	printf("integer: %u\n", integer); | ||||
| 	printf("integer: %d\n", integer); | ||||
| 	printf("magnitude: %lu\n", magnitude); | ||||
| 	printf("timestamp: %lu\n", timestamp); | ||||
| 	printf("string: %s\n", string ? string : "(not set)"); | ||||
| 	printf("abbrev: %d\n", abbrev); | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Junio C Hamano
						Junio C Hamano