Blame argp/argp-test.c

Packit Service 82fcde
/* Test program for argp argument parser
Packit Service 82fcde
   Copyright (C) 1997-2018 Free Software Foundation, Inc.
Packit Service 82fcde
   This file is part of the GNU C Library.
Packit Service 82fcde
   Written by Miles Bader <miles@gnu.ai.mit.edu>.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is free software; you can redistribute it and/or
Packit Service 82fcde
   modify it under the terms of the GNU Lesser General Public
Packit Service 82fcde
   License as published by the Free Software Foundation; either
Packit Service 82fcde
   version 2.1 of the License, or (at your option) any later version.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is distributed in the hope that it will be useful,
Packit Service 82fcde
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 82fcde
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 82fcde
   Lesser General Public License for more details.
Packit Service 82fcde
Packit Service 82fcde
   You should have received a copy of the GNU Lesser General Public
Packit Service 82fcde
   License along with the GNU C Library; if not, see
Packit Service 82fcde
   <http://www.gnu.org/licenses/>.  */
Packit Service 82fcde
Packit Service 82fcde
#ifdef HAVE_CONFIG_H
Packit Service 82fcde
#include <config.h>
Packit Service 82fcde
#endif
Packit Service 82fcde
Packit Service 82fcde
#include <stdlib.h>
Packit Service 82fcde
#include <time.h>
Packit Service 82fcde
#include <string.h>
Packit Service 82fcde
#include <argp.h>
Packit Service 82fcde
Packit Service 82fcde
const char *argp_program_version = "argp-test 1.0";
Packit Service 82fcde

Packit Service 82fcde
struct argp_option sub_options[] =
Packit Service 82fcde
{
Packit Service 82fcde
  {"subopt1",       's',     0,  0, "Nested option 1"},
Packit Service 82fcde
  {"subopt2",       'S',     0,  0, "Nested option 2"},
Packit Service 82fcde
Packit Service 82fcde
  { 0, 0, 0, 0, "Some more nested options:", 10},
Packit Service 82fcde
  {"subopt3",       'p',     0,  0, "Nested option 3"},
Packit Service 82fcde
Packit Service 82fcde
  {"subopt4",       'q',     0,  0, "Nested option 4", 1},
Packit Service 82fcde
Packit Service 82fcde
  {0}
Packit Service 82fcde
};
Packit Service 82fcde
Packit Service 82fcde
static const char sub_args_doc[] = "STRING...\n-";
Packit Service 82fcde
static const char sub_doc[] = "\vThis is the doc string from the sub-arg-parser.";
Packit Service 82fcde
Packit Service 82fcde
static error_t
Packit Service 82fcde
sub_parse_opt (int key, char *arg, struct argp_state *state)
Packit Service 82fcde
{
Packit Service 82fcde
  switch (key)
Packit Service 82fcde
    {
Packit Service 82fcde
    case ARGP_KEY_NO_ARGS:
Packit Service 82fcde
      printf ("NO SUB ARGS\n");
Packit Service 82fcde
      break;
Packit Service 82fcde
    case ARGP_KEY_ARG:
Packit Service 82fcde
      printf ("SUB ARG: %s\n", arg);
Packit Service 82fcde
      break;
Packit Service 82fcde
Packit Service 82fcde
    case 's' : case 'S': case 'p': case 'q':
Packit Service 82fcde
      printf ("SUB KEY %c\n", key);
Packit Service 82fcde
      break;
Packit Service 82fcde
Packit Service 82fcde
    default:
Packit Service 82fcde
      return ARGP_ERR_UNKNOWN;
Packit Service 82fcde
    }
Packit Service 82fcde
  return 0;
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
static char *
Packit Service 82fcde
sub_help_filter (int key, const char *text, void *input)
Packit Service 82fcde
{
Packit Service 82fcde
  if (key == ARGP_KEY_HELP_EXTRA)
Packit Service 82fcde
    return strdup ("This is some extra text from the sub parser (note that it \
Packit Service 82fcde
is preceded by a blank line).");
Packit Service 82fcde
  else
Packit Service 82fcde
    return (char *)text;
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
static struct argp sub_argp = {
Packit Service 82fcde
  sub_options, sub_parse_opt, sub_args_doc, sub_doc, 0, sub_help_filter
Packit Service 82fcde
};
Packit Service 82fcde

Packit Service 82fcde
/* Structure used to communicate with the parsing functions.  */
Packit Service 82fcde
struct params
Packit Service 82fcde
{
Packit Service 82fcde
  unsigned foonly;		/* Value parsed for foonly.  */
Packit Service 82fcde
  unsigned foonly_default;	/* Default value for it.  */
Packit Service 82fcde
};
Packit Service 82fcde
Packit Service 82fcde
#define OPT_PGRP 1
Packit Service 82fcde
#define OPT_SESS 2
Packit Service 82fcde
Packit Service 82fcde
struct argp_option options[] =
Packit Service 82fcde
{
Packit Service 82fcde
  {"pid",       'p',     "PID", 0, "List the process PID"},
Packit Service 82fcde
  {"pgrp",      OPT_PGRP,"PGRP",0, "List processes in the process group PGRP"},
Packit Service 82fcde
  {"no-parent", 'P',	 0,     0, "Include processes without parents"},
Packit Service 82fcde
  {0,           'x',     0,     OPTION_ALIAS},
Packit Service 82fcde
  {"all-fields",'Q',     0,     0, "Don't elide unusable fields (normally"
Packit Service 82fcde
				   " if there's some reason ps can't"
Packit Service 82fcde
				   " print a field for any process, it's"
Packit Service 82fcde
				   " removed from the output entirely)" },
Packit Service 82fcde
  {"reverse",   'r',    0,      0, "Reverse the order of any sort"},
Packit Service 82fcde
  {"gratuitously-long-reverse-option", 0, 0, OPTION_ALIAS},
Packit Service 82fcde
  {"session",  OPT_SESS,"SID",  OPTION_ARG_OPTIONAL,
Packit Service 82fcde
				   "Add the processes from the session"
Packit Service 82fcde
				   " SID (which defaults to the sid of"
Packit Service 82fcde
				   " the current process)" },
Packit Service 82fcde
Packit Service 82fcde
  {0,0,0,0, "Here are some more options:"},
Packit Service 82fcde
  {"foonly", 'f', "ZOT", OPTION_ARG_OPTIONAL, "Glork a foonly"},
Packit Service 82fcde
  {"zaza", 'z', 0, 0, "Snit a zar"},
Packit Service 82fcde
Packit Service 82fcde
  {0}
Packit Service 82fcde
};
Packit Service 82fcde
Packit Service 82fcde
static const char args_doc[] = "STRING";
Packit Service 82fcde
static const char doc[] = "Test program for argp."
Packit Service 82fcde
 "\vThis doc string comes after the options."
Packit Service 82fcde
 "\nHey!  Some manual formatting!"
Packit Service 82fcde
 "\nThe current time is: %s";
Packit Service 82fcde
Packit Service 82fcde
static void
Packit Service 82fcde
popt (int key, char *arg)
Packit Service 82fcde
{
Packit Service 82fcde
  char buf[10];
Packit Service 82fcde
  if (isprint (key))
Packit Service 82fcde
    sprintf (buf, "%c", key);
Packit Service 82fcde
  else
Packit Service 82fcde
    sprintf (buf, "%d", key);
Packit Service 82fcde
  if (arg)
Packit Service 82fcde
    printf ("KEY %s: %s\n", buf, arg);
Packit Service 82fcde
  else
Packit Service 82fcde
    printf ("KEY %s\n", buf);
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
static error_t
Packit Service 82fcde
parse_opt (int key, char *arg, struct argp_state *state)
Packit Service 82fcde
{
Packit Service 82fcde
  struct params *params = state->input;
Packit Service 82fcde
Packit Service 82fcde
  switch (key)
Packit Service 82fcde
    {
Packit Service 82fcde
    case ARGP_KEY_NO_ARGS:
Packit Service 82fcde
      printf ("NO ARGS\n");
Packit Service 82fcde
      break;
Packit Service 82fcde
Packit Service 82fcde
    case ARGP_KEY_ARG:
Packit Service 82fcde
      if (state->arg_num > 0)
Packit Service 82fcde
	return ARGP_ERR_UNKNOWN; /* Leave it for the sub-arg parser.  */
Packit Service 82fcde
      printf ("ARG: %s\n", arg);
Packit Service 82fcde
      break;
Packit Service 82fcde
Packit Service 82fcde
    case 'f':
Packit Service 82fcde
      if (arg)
Packit Service 82fcde
	params->foonly = atoi (arg);
Packit Service 82fcde
      else
Packit Service 82fcde
	params->foonly = params->foonly_default;
Packit Service 82fcde
      popt (key, arg);
Packit Service 82fcde
      break;
Packit Service 82fcde
Packit Service 82fcde
    case 'p': case 'P': case OPT_PGRP: case 'x': case 'Q':
Packit Service 82fcde
    case 'r': case OPT_SESS: case 'z':
Packit Service 82fcde
      popt (key, arg);
Packit Service 82fcde
      break;
Packit Service 82fcde
Packit Service 82fcde
    default:
Packit Service 82fcde
      return ARGP_ERR_UNKNOWN;
Packit Service 82fcde
    }
Packit Service 82fcde
  return 0;
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
static char *
Packit Service 82fcde
help_filter (int key, const char *text, void *input)
Packit Service 82fcde
{
Packit Service 82fcde
  char *new_text;
Packit Service 82fcde
  struct params *params = input;
Packit Service 82fcde
Packit Service 82fcde
  if (key == ARGP_KEY_HELP_POST_DOC && text)
Packit Service 82fcde
    {
Packit Service 82fcde
      time_t now = time (0);
Packit Service 82fcde
      asprintf (&new_text, text, ctime (&now));
Packit Service 82fcde
    }
Packit Service 82fcde
  else if (key == 'f')
Packit Service 82fcde
    /* Show the default for the --foonly option.  */
Packit Service 82fcde
    asprintf (&new_text, "%s (ZOT defaults to %x)",
Packit Service 82fcde
	      text, params->foonly_default);
Packit Service 82fcde
  else
Packit Service 82fcde
    new_text = (char *)text;
Packit Service 82fcde
Packit Service 82fcde
  return new_text;
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
static struct argp_child argp_children[] = { { &sub_argp }, { 0 } };
Packit Service 82fcde
static struct argp argp = {
Packit Service 82fcde
  options, parse_opt, args_doc, doc, argp_children, help_filter
Packit Service 82fcde
};
Packit Service 82fcde

Packit Service 82fcde
int
Packit Service 82fcde
main (int argc, char **argv)
Packit Service 82fcde
{
Packit Service 82fcde
  struct params params;
Packit Service 82fcde
  params.foonly = 0;
Packit Service 82fcde
  params.foonly_default = random ();
Packit Service 82fcde
  argp_parse (&argp, argc, argv, 0, 0, &params);
Packit Service 82fcde
  printf ("After parsing: foonly = %x\n", params.foonly);
Packit Service 82fcde
  return 0;
Packit Service 82fcde
}