From: "Darrick J. Wong" <darrick.wong@oracle.com>
To: Jan Tulak <jtulak@redhat.com>
Cc: linux-xfs@vger.kernel.org
Subject: Re: [PATCH 5/6] mkfs: move getnum within the file
Date: Mon, 14 Aug 2017 16:07:22 -0700 [thread overview]
Message-ID: <20170814230722.GI4796@magnolia> (raw)
In-Reply-To: <20170811123037.15962-6-jtulak@redhat.com>
On Fri, Aug 11, 2017 at 02:30:36PM +0200, Jan Tulak wrote:
> Move getnum, check_opt and illegal_option within the file. We have to do
> this to avoid dependency issues with the following patch. There is no
> other change in this patch, just cut&paste of these functions.
>
> Signed-off-by: Jan Tulak <jtulak@redhat.com>
> ---
> mkfs/xfs_mkfs.c | 236 ++++++++++++++++++++++++++++----------------------------
> 1 file changed, 118 insertions(+), 118 deletions(-)
>
> diff --git a/mkfs/xfs_mkfs.c b/mkfs/xfs_mkfs.c
> index e3f7d345..3e7ba5f0 100644
> --- a/mkfs/xfs_mkfs.c
> +++ b/mkfs/xfs_mkfs.c
> @@ -813,6 +813,124 @@ get_conf_raw_safe(const int opt, const int subopt)
> return str;
> }
>
> +static __attribute__((noreturn)) void
> +illegal_option(
How about declaring the functions at the top and leaving the definitions
where they are?
--D
> + const char *value,
> + struct opt_params *opts,
> + int index,
> + const char *reason)
> +{
> + fprintf(stderr,
> + _("Illegal value %s for -%c %s option. %s\n"),
> + value, opts->name, opts->subopts[index],
> + reason ? reason : "");
> + usage();
> +}
> +
> +/*
> + * Check for conflicts and option respecification.
> + */
> +static void
> +check_opt(
> + struct opt_params *opts,
> + int index,
> + bool str_seen)
> +{
> + struct subopt_param *sp = &opts->subopt_params[index];
> + int i;
> +
> + if (sp->index != index) {
> + fprintf(stderr,
> + ("Developer screwed up option parsing (%d/%d)! Please report!\n"),
> + sp->index, index);
> + reqval(opts->name, (char **)opts->subopts, index);
> + }
> +
> + /*
> + * Check for respecification of the option. This is more complex than it
> + * seems because some options are parsed twice - once as a string during
> + * input parsing, then later the string is passed to getnum for
> + * conversion into a number and bounds checking. Hence the two variables
> + * used to track the different uses based on the @str parameter passed
> + * to us.
> + */
> + if (!str_seen) {
> + if (sp->seen)
> + respec(opts->name, (char **)opts->subopts, index);
> + sp->seen = true;
> + } else {
> + if (sp->str_seen)
> + respec(opts->name, (char **)opts->subopts, index);
> + sp->str_seen = true;
> + }
> +
> + /* check for conflicts with the option */
> + for (i = 0; i < MAX_CONFLICTS; i++) {
> + int conflict_opt = sp->conflicts[i];
> +
> + if (conflict_opt == LAST_CONFLICT)
> + break;
> + if (opts->subopt_params[conflict_opt].seen ||
> + opts->subopt_params[conflict_opt].str_seen)
> + conflict(opts->name, (char **)opts->subopts,
> + conflict_opt, index);
> + }
> +}
> +
> +static long long
> +getnum(
> + const char *str,
> + struct opt_params *opts,
> + int index)
> +{
> + struct subopt_param *sp = &opts->subopt_params[index];
> + long long c;
> +
> + check_opt(opts, index, false);
> + set_conf_raw(opts->index, index, str);
> + /* empty strings might just return a default value */
> + if (!str || *str == '\0') {
> + if (sp->flagval == SUBOPT_NEEDS_VAL)
> + reqval(opts->name, (char **)opts->subopts, index);
> + return sp->flagval;
> + }
> +
> + if (sp->minval == 0 && sp->maxval == 0) {
> + fprintf(stderr,
> + _("Option -%c %s has undefined minval/maxval."
> + "Can't verify value range. This is a bug.\n"),
> + opts->name, opts->subopts[index]);
> + exit(1);
> + }
> +
> + /*
> + * Some values are pure numbers, others can have suffixes that define
> + * the units of the number. Those get passed to cvtnum(), otherwise we
> + * convert it ourselves to guarantee there is no trailing garbage in the
> + * number.
> + */
> + if (sp->convert)
> + c = cvtnum(blocksize, sectorsize, str);
> + else {
> + char *str_end;
> +
> + c = strtoll(str, &str_end, 0);
> + if (c == 0 && str_end == str)
> + illegal_option(str, opts, index, NULL);
> + if (*str_end != '\0')
> + illegal_option(str, opts, index, NULL);
> + }
> +
> + /* Validity check the result. */
> + if (c < sp->minval)
> + illegal_option(str, opts, index, _("value is too small"));
> + else if (c > sp->maxval)
> + illegal_option(str, opts, index, _("value is too large"));
> + if (sp->is_power_2 && !ispow2(c))
> + illegal_option(str, opts, index, _("value must be a power of 2"));
> + return c;
> +}
> +
> /*
> * Convert lsu to lsunit for 512 bytes blocks and check validity of the values.
> */
> @@ -1337,124 +1455,6 @@ sb_set_features(
>
> }
>
> -static __attribute__((noreturn)) void
> -illegal_option(
> - const char *value,
> - struct opt_params *opts,
> - int index,
> - const char *reason)
> -{
> - fprintf(stderr,
> - _("Illegal value %s for -%c %s option. %s\n"),
> - value, opts->name, opts->subopts[index],
> - reason ? reason : "");
> - usage();
> -}
> -
> -/*
> - * Check for conflicts and option respecification.
> - */
> -static void
> -check_opt(
> - struct opt_params *opts,
> - int index,
> - bool str_seen)
> -{
> - struct subopt_param *sp = &opts->subopt_params[index];
> - int i;
> -
> - if (sp->index != index) {
> - fprintf(stderr,
> - ("Developer screwed up option parsing (%d/%d)! Please report!\n"),
> - sp->index, index);
> - reqval(opts->name, (char **)opts->subopts, index);
> - }
> -
> - /*
> - * Check for respecification of the option. This is more complex than it
> - * seems because some options are parsed twice - once as a string during
> - * input parsing, then later the string is passed to getnum for
> - * conversion into a number and bounds checking. Hence the two variables
> - * used to track the different uses based on the @str parameter passed
> - * to us.
> - */
> - if (!str_seen) {
> - if (sp->seen)
> - respec(opts->name, (char **)opts->subopts, index);
> - sp->seen = true;
> - } else {
> - if (sp->str_seen)
> - respec(opts->name, (char **)opts->subopts, index);
> - sp->str_seen = true;
> - }
> -
> - /* check for conflicts with the option */
> - for (i = 0; i < MAX_CONFLICTS; i++) {
> - int conflict_opt = sp->conflicts[i];
> -
> - if (conflict_opt == LAST_CONFLICT)
> - break;
> - if (opts->subopt_params[conflict_opt].seen ||
> - opts->subopt_params[conflict_opt].str_seen)
> - conflict(opts->name, (char **)opts->subopts,
> - conflict_opt, index);
> - }
> -}
> -
> -static long long
> -getnum(
> - const char *str,
> - struct opt_params *opts,
> - int index)
> -{
> - struct subopt_param *sp = &opts->subopt_params[index];
> - long long c;
> -
> - check_opt(opts, index, false);
> - set_conf_raw(opts->index, index, str);
> - /* empty strings might just return a default value */
> - if (!str || *str == '\0') {
> - if (sp->flagval == SUBOPT_NEEDS_VAL)
> - reqval(opts->name, (char **)opts->subopts, index);
> - return sp->flagval;
> - }
> -
> - if (sp->minval == 0 && sp->maxval == 0) {
> - fprintf(stderr,
> - _("Option -%c %s has undefined minval/maxval."
> - "Can't verify value range. This is a bug.\n"),
> - opts->name, opts->subopts[index]);
> - exit(1);
> - }
> -
> - /*
> - * Some values are pure numbers, others can have suffixes that define
> - * the units of the number. Those get passed to cvtnum(), otherwise we
> - * convert it ourselves to guarantee there is no trailing garbage in the
> - * number.
> - */
> - if (sp->convert)
> - c = cvtnum(blocksize, sectorsize, str);
> - else {
> - char *str_end;
> -
> - c = strtoll(str, &str_end, 0);
> - if (c == 0 && str_end == str)
> - illegal_option(str, opts, index, NULL);
> - if (*str_end != '\0')
> - illegal_option(str, opts, index, NULL);
> - }
> -
> - /* Validity check the result. */
> - if (c < sp->minval)
> - illegal_option(str, opts, index, _("value is too small"));
> - else if (c > sp->maxval)
> - illegal_option(str, opts, index, _("value is too large"));
> - if (sp->is_power_2 && !ispow2(c))
> - illegal_option(str, opts, index, _("value must be a power of 2"));
> - return c;
> -}
> -
> /*
> * Option is a string - do all the option table work, and check there
> * is actually an option string. Otherwise we don't do anything with the string
> --
> 2.13.3
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-xfs" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2017-08-14 23:07 UTC|newest]
Thread overview: 37+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-08-11 12:30 [PATCH 0/6 v2] mkfs: save user input into opts table Jan Tulak
2017-08-11 12:30 ` [PATCH 1/6] mkfs: Save raw user input field to the opts struct Jan Tulak
2017-08-14 22:56 ` Darrick J. Wong
2017-08-15 9:47 ` Jan Tulak
2017-08-11 12:30 ` [PATCH 2/6] mkfs: rename defaultval to flagval in opts Jan Tulak
2017-08-14 22:56 ` Darrick J. Wong
2017-08-11 12:30 ` [PATCH 3/6] mkfs: remove intermediate getstr followed by getnum Jan Tulak
2017-08-14 22:58 ` Darrick J. Wong
2017-08-11 12:30 ` [PATCH 4/6] mkfs: merge tables for opts parsing into one table Jan Tulak
2017-08-14 23:06 ` Darrick J. Wong
2017-08-15 10:05 ` Jan Tulak
2017-08-11 12:30 ` [PATCH 5/6] mkfs: move getnum within the file Jan Tulak
2017-08-14 23:07 ` Darrick J. Wong [this message]
2017-08-15 10:14 ` Jan Tulak
2017-08-15 21:09 ` Eric Sandeen
2017-08-16 9:25 ` Jan Tulak
2017-08-11 12:30 ` [PATCH 6/6] mkfs: extend opt_params with a value field Jan Tulak
2017-08-14 23:15 ` Darrick J. Wong
2017-08-15 10:42 ` Jan Tulak
2017-08-15 15:08 ` [PATCH 1/6 v2] mkfs: Save raw user input field to the opts struct Jan Tulak
2017-08-15 15:08 ` [PATCH 3/6 v2] mkfs: remove intermediate getstr followed by getnum Jan Tulak
2017-08-15 23:20 ` Eric Sandeen
2017-08-17 11:36 ` Dave Chinner
2017-08-15 15:08 ` [PATCH 4/6 v2] mkfs: merge tables for opts parsing into one table Jan Tulak
2017-08-15 15:08 ` [PATCH 5/6 v2] mkfs: move getnum within the file Jan Tulak
2017-08-15 15:08 ` [PATCH 6/6 v2] mkfs: extend opt_params with a value field Jan Tulak
2017-08-16 21:13 ` Eric Sandeen
2017-08-16 21:38 ` Darrick J. Wong
2017-08-17 10:08 ` Jan Tulak
2017-08-17 11:03 ` Dave Chinner
2017-08-17 14:56 ` Jan Tulak
2017-08-17 22:59 ` Dave Chinner
2017-08-17 15:26 ` Eric Sandeen
2017-08-15 23:07 ` [PATCH 1/6 v2] mkfs: Save raw user input field to the opts struct Eric Sandeen
2017-08-16 9:11 ` Jan Tulak
2017-08-16 14:42 ` Eric Sandeen
2017-08-16 15:38 ` Jan Tulak
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20170814230722.GI4796@magnolia \
--to=darrick.wong@oracle.com \
--cc=jtulak@redhat.com \
--cc=linux-xfs@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox