On Tue, Feb 05, 2019 at 04:01:01PM -0800, Jeff Kirsher wrote:
> From: Nicholas Nunley <nicholas.d.nun...@intel.com>
> 
> Move option parsing code into find_option function.
> 
> No behavior changes.
> 
> Based on patch by Kan Liang <kan.li...@intel.com>
> 
> Signed-off-by: Nicholas Nunley <nicholas.d.nun...@intel.com>
> Signed-off-by: Jeff Kirsher <jeffrey.t.kirs...@intel.com>
> ---
>  ethtool.c | 49 +++++++++++++++++++++++++++++++------------------
>  1 file changed, 31 insertions(+), 18 deletions(-)
> 
> diff --git a/ethtool.c b/ethtool.c
> index 2f7e96b..8b7c224 100644
> --- a/ethtool.c
> +++ b/ethtool.c
> @@ -5265,6 +5265,29 @@ static int show_usage(struct cmd_context *ctx)
>       return 0;
>  }
>  
> +static int find_option(int argc, char **argp)
> +{
> +     const char *opt;
> +     size_t len;
> +     int k;
> +
> +     for (k = 0; args[k].opts; k++) {
> +             opt = args[k].opts;
> +             for (;;) {
> +                     len = strcspn(opt, "|");
> +                     if (strncmp(*argp, opt, len) == 0 &&
> +                         (*argp)[len] == 0)
> +                             return k;
> +
> +                     if (opt[len] == 0)
> +                             break;
> +                     opt += len + 1;
> +             }
> +     }
> +
> +     return -1;
> +}
> +
>  int main(int argc, char **argp)
>  {
>       int (*func)(struct cmd_context *);
> @@ -5284,24 +5307,14 @@ int main(int argc, char **argp)
>        */
>       if (argc == 0)
>               exit_bad_args();
> -     for (k = 0; args[k].opts; k++) {
> -             const char *opt;
> -             size_t len;
> -             opt = args[k].opts;
> -             for (;;) {
> -                     len = strcspn(opt, "|");
> -                     if (strncmp(*argp, opt, len) == 0 &&
> -                         (*argp)[len] == 0) {
> -                             argp++;
> -                             argc--;
> -                             func = args[k].func;
> -                             want_device = args[k].want_device;
> -                             goto opt_found;
> -                     }
> -                     if (opt[len] == 0)
> -                             break;
> -                     opt += len + 1;
> -             }
> +
> +     k = find_option(argc, argp);
> +     if (k >= 0) {
> +             argp++;
> +             argc--;
> +             func = args[k].func;
> +             want_device = args[k].want_device;
> +             goto opt_found;
>       }
>       if ((*argp)[0] == '-')
>               exit_bad_args();

After hiding the loop into find_option() helper, you can put the
following few lines into else branch and get rid of the goto.

Michal Kubecek

Reply via email to