1 /* Test program for argp argument parser
2 Copyright (C) 1997-2023 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
17 <https://www.gnu.org/licenses/>. */
28 const char *argp_program_version
= "argp-test 1.0";
30 struct argp_option sub_options
[] =
32 {"subopt1", 's', 0, 0, "Nested option 1"},
33 {"subopt2", 'S', 0, 0, "Nested option 2"},
35 { 0, 0, 0, 0, "Some more nested options:", 10},
36 {"subopt3", 'p', 0, 0, "Nested option 3"},
38 {"subopt4", 'q', 0, 0, "Nested option 4", 1},
43 static const char sub_args_doc
[] = "STRING...\n-";
44 static const char sub_doc
[] = "\vThis is the doc string from the sub-arg-parser.";
47 sub_parse_opt (int key
, char *arg
, struct argp_state
*state
)
51 case ARGP_KEY_NO_ARGS
:
52 printf ("NO SUB ARGS\n");
55 printf ("SUB ARG: %s\n", arg
);
58 case 's' : case 'S': case 'p': case 'q':
59 printf ("SUB KEY %c\n", key
);
63 return ARGP_ERR_UNKNOWN
;
69 sub_help_filter (int key
, const char *text
, void *input
)
71 if (key
== ARGP_KEY_HELP_EXTRA
)
72 return strdup ("This is some extra text from the sub parser (note that it \
73 is preceded by a blank line).");
78 static struct argp sub_argp
= {
79 sub_options
, sub_parse_opt
, sub_args_doc
, sub_doc
, 0, sub_help_filter
82 /* Structure used to communicate with the parsing functions. */
85 unsigned foonly
; /* Value parsed for foonly. */
86 unsigned foonly_default
; /* Default value for it. */
92 struct argp_option options
[] =
94 {"pid", 'p', "PID", 0, "List the process PID"},
95 {"pgrp", OPT_PGRP
,"PGRP",0, "List processes in the process group PGRP"},
96 {"no-parent", 'P', 0, 0, "Include processes without parents"},
97 {0, 'x', 0, OPTION_ALIAS
},
98 {"all-fields",'Q', 0, 0, "Don't elide unusable fields (normally"
99 " if there's some reason ps can't"
100 " print a field for any process, it's"
101 " removed from the output entirely)" },
102 {"reverse", 'r', 0, 0, "Reverse the order of any sort"},
103 {"gratuitously-long-reverse-option", 0, 0, OPTION_ALIAS
},
104 {"session", OPT_SESS
,"SID", OPTION_ARG_OPTIONAL
,
105 "Add the processes from the session"
106 " SID (which defaults to the sid of"
107 " the current process)" },
109 {0,0,0,0, "Here are some more options:"},
110 {"foonly", 'f', "ZOT", OPTION_ARG_OPTIONAL
, "Glork a foonly"},
111 {"zaza", 'z', 0, 0, "Snit a zar"},
116 static const char args_doc
[] = "STRING";
117 static const char doc
[] = "Test program for argp."
118 "\vThis doc string comes after the options."
119 "\nHey! Some manual formatting!"
120 "\nThe current time is: %s";
123 popt (int key
, char *arg
)
127 sprintf (buf
, "%c", key
);
129 sprintf (buf
, "%d", key
);
131 printf ("KEY %s: %s\n", buf
, arg
);
133 printf ("KEY %s\n", buf
);
137 parse_opt (int key
, char *arg
, struct argp_state
*state
)
139 struct params
*params
= state
->input
;
143 case ARGP_KEY_NO_ARGS
:
144 printf ("NO ARGS\n");
148 if (state
->arg_num
> 0)
149 return ARGP_ERR_UNKNOWN
; /* Leave it for the sub-arg parser. */
150 printf ("ARG: %s\n", arg
);
155 params
->foonly
= atoi (arg
);
157 params
->foonly
= params
->foonly_default
;
161 case 'p': case 'P': case OPT_PGRP
: case 'x': case 'Q':
162 case 'r': case OPT_SESS
: case 'z':
167 return ARGP_ERR_UNKNOWN
;
173 help_filter (int key
, const char *text
, void *input
)
176 struct params
*params
= input
;
178 if (key
== ARGP_KEY_HELP_POST_DOC
&& text
)
180 time_t now
= time (0);
181 asprintf (&new_text
, text
, ctime (&now
));
184 /* Show the default for the --foonly option. */
185 asprintf (&new_text
, "%s (ZOT defaults to %x)",
186 text
, params
->foonly_default
);
188 new_text
= (char *)text
;
193 static struct argp_child argp_children
[] = { { &sub_argp
}, { 0 } };
194 static struct argp argp
= {
195 options
, parse_opt
, args_doc
, doc
, argp_children
, help_filter
199 main (int argc
, char **argv
)
201 struct params params
;
203 params
.foonly_default
= random ();
204 argp_parse (&argp
, argc
, argv
, 0, 0, ¶ms
);
205 printf ("After parsing: foonly = %x\n", params
.foonly
);