diff options
| author | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2020-01-06 03:28:28 +0100 | 
|---|---|---|
| committer | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2020-01-06 03:28:28 +0100 | 
| commit | d053eb8096a790d81b67c844d918341e797c2659 (patch) | |
| tree | 41493bdf9374493f0e19db9f0c4a6eb4b69d4328 /lib/common/comp_opt.c | |
| parent | 61da4d9d3249cc6001c64d371ef1bf82aeeab616 (diff) | |
Cleanup: use parse_size function to parse compressor options
The XZ option parser had a similar function to parse_size. This commit
removes the other implementation and extends parse_size with the one
missing feature, i.e. allowing a '%' suffix for a relative value.
Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
Diffstat (limited to 'lib/common/comp_opt.c')
| -rw-r--r-- | lib/common/comp_opt.c | 47 | 
1 files changed, 6 insertions, 41 deletions
| diff --git a/lib/common/comp_opt.c b/lib/common/comp_opt.c index f257036..66d562e 100644 --- a/lib/common/comp_opt.c +++ b/lib/common/comp_opt.c @@ -74,39 +74,6 @@ static int find_lzo_alg(sqfs_compressor_config_t *cfg, const char *name)  	return -1;  } -static int get_size_value(const char *value, sqfs_u32 *out, sqfs_u32 block_size) -{ -	int i; - -	for (i = 0; isdigit(value[i]) && i < 9; ++i) -		; - -	if (i < 1 || i > 9) -		return -1; - -	*out = atol(value); - -	switch (value[i]) { -	case '\0': -		break; -	case 'm': -	case 'M': -		*out <<= 20; -		break; -	case 'k': -	case 'K': -		*out <<= 10; -		break; -	case '%': -		*out = (*out * block_size) / 100; -		break; -	default: -		return -1; -	} - -	return 0; -} -  enum {  	OPT_WINDOW = 0,  	OPT_LEVEL, @@ -125,7 +92,7 @@ int compressor_cfg_init_options(sqfs_compressor_config_t *cfg,  				E_SQFS_COMPRESSOR id,  				size_t block_size, char *options)  { -	size_t num_flags = 0, min_level = 0, max_level = 0, level; +	size_t num_flags = 0, min_level = 0, max_level = 0, level, dict_size;  	const flag_t *flags = NULL;  	char *subopts, *value;  	int i, opt; @@ -234,10 +201,12 @@ int compressor_cfg_init_options(sqfs_compressor_config_t *cfg,  			if (value == NULL)  				goto fail_value; -			if (get_size_value(value, &cfg->opt.xz.dict_size, -					   cfg->block_size)) { -				goto fail_dict; +			if (parse_size("Parsing XZ dictionary size", +				       &dict_size, value, cfg->block_size)) { +				return -1;  			} + +			cfg->opt.xz.dict_size = dict_size;  			break;  		default:  			if (set_flag(cfg, value, flags, num_flags)) @@ -265,10 +234,6 @@ fail_value:  	fprintf(stderr, "Missing value for compressor option '%s'.\n",  		token[opt]);  	return -1; -fail_dict: -	fputs("Dictionary size must be a number with the optional " -	      "suffix 'm','k' or '%'.\n", stderr); -	return -1;  }  typedef void (*compressor_help_fun_t)(void); | 
