1
0
mirror of git://git.gnupg.org/gnupg.git synced 2024-12-23 10:29:58 +01:00

common: Allow standalone build of argparse.c

* common/argparse.h: Remove types.h - not required.
* common/argparse.c: Change to allow standalone use.

Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
Werner Koch 2015-03-17 09:19:55 +01:00
parent e0398fb110
commit eb5f2c0af6
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B
2 changed files with 169 additions and 55 deletions

View File

@ -1,6 +1,6 @@
/* [argparse.c wk 17.06.97] Argument Parser for option handling /* [argparse.c wk 17.06.97] Argument Parser for option handling
* Copyright (C) 1998-2001, 2006-2008, 2012 Free Software Foundation, Inc. * Copyright (C) 1998-2001, 2006-2008, 2012 Free Software Foundation, Inc.
* Copyright (C) 1997-2001, 2006-2008, 2013 Werner Koch * Copyright (C) 1997-2001, 2006-2008, 2013-2015 Werner Koch
* *
* This file is part of JNLIB, which is a subsystem of GnuPG. * This file is part of JNLIB, which is a subsystem of GnuPG.
* *
@ -29,6 +29,11 @@
* if not, see <http://www.gnu.org/licenses/>. * if not, see <http://www.gnu.org/licenses/>.
*/ */
/* This file may be used as part of GnuPG or standalone. A GnuPG
build is detected by the presence of the macro GNUPG_MAJOR_VERSION.
Some feature are only availalbe in the GnuPG build mode.
*/
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include <config.h> #include <config.h>
#endif #endif
@ -41,20 +46,114 @@
#include <limits.h> #include <limits.h>
#include <errno.h> #include <errno.h>
#include "libjnlib-config.h" #ifdef GNUPG_MAJOR_VERSION
#include "mischelp.h" # include "libjnlib-config.h"
#include "stringhelp.h" # include "mischelp.h"
#include "logging.h" # include "stringhelp.h"
#ifdef JNLIB_NEED_UTF8CONV # include "logging.h"
#include "utf8conv.h" # ifdef JNLIB_NEED_UTF8CONV
#endif # include "utf8conv.h"
# endif
#endif /*GNUPG_MAJOR_VERSION*/
#include "argparse.h" #include "argparse.h"
/* GnuPG uses GPLv3+ but a standalone version of this defaults to
GPLv2+ because that is the license of this file. Change this if
you include it in a program which uses GPLv3. If you don't want to
set a a copyright string for your usage() you may also hardcode it
here. */
#ifndef GNUPG_MAJOR_VERSION
# define ARGPARSE_GPL_VERSION 2
# define ARGPARSE_CRIGHT_STR "Copyright (C) YEAR NAME"
#else /* Used by GnuPG */
# define ARGPARSE_GPL_VERSION 3
# define ARGPARSE_CRIGHT_STR "Copyright (C) 2015 Free Software Foundation, Inc."
#endif /*GNUPG_MAJOR_VERSION*/
/* Replacements for standalone builds. */
#ifndef GNUPG_MAJOR_VERSION
# ifndef _
# define _(a) (a)
# endif
# ifndef DIM
# define DIM(v) (sizeof(v)/sizeof((v)[0]))
# endif
# define jnlib_malloc(a) malloc ((a))
# define jnlib_realloc(a,b) realloc ((a), (b))
# define jnlib_strdup(a) strdup ((a))
# define jnlib_free(a) free ((a))
# define jnlib_log_error my_log_error
# define jnlib_log_bug my_log_bug
# define trim_spaces(a) my_trim_spaces ((a))
# define map_static_macro_string(a) (a)
#endif /*!GNUPG_MAJOR_VERSION*/
#define ARGPARSE_STR(v) #v
#define ARGPARSE_STR2(v) ARGPARSE_STR(v)
/* Replacements for standalone builds. */
#ifndef GNUPG_MAJOR_VERSION
static void
my_log_error (const char *fmt, ...)
{
va_list arg_ptr ;
va_start (arg_ptr, fmt);
fprintf (stderr, "%s: ", strusage (11));
vfprintf (stderr, fmt, arg_ptr);
va_end (arg_ptr);
}
static void
my_log_bug (const char *fmt, ...)
{
va_list arg_ptr ;
va_start (arg_ptr, fmt);
fprintf (stderr, "%s: Ohhhh jeeee: ", strusage (11));
vfprintf (stderr, fmt, arg_ptr);
va_end (arg_ptr);
abort ();
}
static char *
my_trim_spaces (char *str)
{
char *string, *p, *mark;
string = str;
/* Find first non space character. */
for (p=string; *p && isspace (*(unsigned char*)p) ; p++)
;
/* Move characters. */
for ((mark = NULL); (*string = *p); string++, p++)
if (isspace (*(unsigned char*)p))
{
if (!mark)
mark = string;
}
else
mark = NULL;
if (mark)
*mark = '\0' ; /* Remove trailing spaces. */
return str ;
}
#endif /*!GNUPG_MAJOR_VERSION*/
/********************************* /*********************************
* @Summary arg_parse * @Summary arg_parse
* #include <wk/lib.h> * #include "argparse.h"
* *
* typedef struct { * typedef struct {
* char *argc; pointer to argc (value subject to change) * char *argc; pointer to argc (value subject to change)
@ -1367,12 +1466,19 @@ strusage( int level )
switch ( level ) switch ( level )
{ {
case 10: p = ("License GPLv3+: GNU GPL version 3 or later "
"<http://gnu.org/licenses/gpl.html>"); case 10:
#if ARGPARSE_GPL_VERSION == 3
p = ("License GPLv3+: GNU GPL version 3 or later "
"<http://gnu.org/licenses/gpl.html>");
#else
p = ("License GPLv2+: GNU GPL version 2 or later "
"<http://gnu.org/licenses/>");
#endif
break; break;
case 11: p = "foo"; break; case 11: p = "foo"; break;
case 13: p = "0.0"; break; case 13: p = "0.0"; break;
case 14: p = "Copyright (C) 2015 Free Software Foundation, Inc."; break; case 14: p = ARGPARSE_CRIGHT_STR; break;
case 15: p = case 15: p =
"This is free software: you are free to change and redistribute it.\n" "This is free software: you are free to change and redistribute it.\n"
"There is NO WARRANTY, to the extent permitted by law.\n"; "There is NO WARRANTY, to the extent permitted by law.\n";
@ -1380,7 +1486,9 @@ strusage( int level )
case 16: p = case 16: p =
"This is free software; you can redistribute it and/or modify\n" "This is free software; you can redistribute it and/or modify\n"
"it under the terms of the GNU General Public License as published by\n" "it under the terms of the GNU General Public License as published by\n"
"the Free Software Foundation; either version 3 of the License, or\n" "the Free Software Foundation; either version "
ARGPARSE_STR2(ARGPARSE_GPL_VERSION)
" of the License, or\n"
"(at your option) any later version.\n\n" "(at your option) any later version.\n\n"
"It is distributed in the hope that it will be useful,\n" "It is distributed in the hope that it will be useful,\n"
"but WITHOUT ANY WARRANTY; without even the implied warranty of\n" "but WITHOUT ANY WARRANTY; without even the implied warranty of\n"
@ -1414,7 +1522,7 @@ static struct {
int myopt; int myopt;
int echo; int echo;
int a_long_one; int a_long_one;
}opt; } opt;
int int
main(int argc, char **argv) main(int argc, char **argv)
@ -1422,7 +1530,7 @@ main(int argc, char **argv)
ARGPARSE_OPTS opts[] = { ARGPARSE_OPTS opts[] = {
ARGPARSE_x('v', "verbose", NONE, 0, "Laut sein"), ARGPARSE_x('v', "verbose", NONE, 0, "Laut sein"),
ARGPARSE_s_n('e', "echo" , ("Zeile ausgeben, damit wir sehen, " ARGPARSE_s_n('e', "echo" , ("Zeile ausgeben, damit wir sehen, "
"was wir ein gegeben haben")), "was wir eingegeben haben")),
ARGPARSE_s_n('d', "debug", "Debug\nfalls mal etwas\nschief geht"), ARGPARSE_s_n('d', "debug", "Debug\nfalls mal etwas\nschief geht"),
ARGPARSE_s_s('o', "output", 0 ), ARGPARSE_s_s('o', "output", 0 ),
ARGPARSE_o_s('c', "cross-ref", "cross-reference erzeugen\n" ), ARGPARSE_o_s('c', "cross-ref", "cross-reference erzeugen\n" ),
@ -1430,43 +1538,50 @@ main(int argc, char **argv)
ARGPARSE_s_n('s', "street","|Straße|set the name of the street to Straße"), ARGPARSE_s_n('s', "street","|Straße|set the name of the street to Straße"),
ARGPARSE_o_i('m', "my-option", 0), ARGPARSE_o_i('m', "my-option", 0),
ARGPARSE_s_n(500, "a-long-option", 0 ), ARGPARSE_s_n(500, "a-long-option", 0 ),
ARGPARSE_end ARGPARSE_end()
}; };
ARGPARSE_ARGS pargs = { &argc, &argv, 2|4|32 }; ARGPARSE_ARGS pargs = { &argc, &argv, (ARGPARSE_FLAG_ALL
int i; | ARGPARSE_FLAG_MIXED
| ARGPARSE_FLAG_ONEDASH) };
int i;
while( arg_parse ( &pargs, opts) ) { while (arg_parse (&pargs, opts))
switch( pargs.r_opt ) { {
case -1 : printf( "arg='%s'\n", pargs.r.ret_str); break; switch (pargs.r_opt)
case 'v': opt.verbose++; break; {
case 'e': opt.echo++; break; case ARGPARSE_IS_ARG :
case 'd': opt.debug++; break; printf ("arg='%s'\n", pargs.r.ret_str);
case 'o': opt.outfile = pargs.r.ret_str; break; break;
case 'c': opt.crf = pargs.r_type? pargs.r.ret_str:"a.crf"; break; case 'v': opt.verbose++; break;
case 'm': opt.myopt = pargs.r_type? pargs.r.ret_int : 1; break; case 'e': opt.echo++; break;
case 500: opt.a_long_one++; break; case 'd': opt.debug++; break;
default : pargs.err = ARGPARSE_PRINT_WARNING; break; case 'o': opt.outfile = pargs.r.ret_str; break;
case 'c': opt.crf = pargs.r_type? pargs.r.ret_str:"a.crf"; break;
case 'm': opt.myopt = pargs.r_type? pargs.r.ret_int : 1; break;
case 500: opt.a_long_one++; break;
default : pargs.err = ARGPARSE_PRINT_WARNING; break;
} }
} }
for(i=0; i < argc; i++ ) for (i=0; i < argc; i++ )
printf("%3d -> (%s)\n", i, argv[i] ); printf ("%3d -> (%s)\n", i, argv[i] );
puts("Options:"); puts ("Options:");
if( opt.verbose ) if (opt.verbose)
printf(" verbose=%d\n", opt.verbose ); printf (" verbose=%d\n", opt.verbose );
if( opt.debug ) if (opt.debug)
printf(" debug=%d\n", opt.debug ); printf (" debug=%d\n", opt.debug );
if( opt.outfile ) if (opt.outfile)
printf(" outfile='%s'\n", opt.outfile ); printf (" outfile='%s'\n", opt.outfile );
if( opt.crf ) if (opt.crf)
printf(" crffile='%s'\n", opt.crf ); printf (" crffile='%s'\n", opt.crf );
if( opt.myopt ) if (opt.myopt)
printf(" myopt=%d\n", opt.myopt ); printf (" myopt=%d\n", opt.myopt );
if( opt.a_long_one ) if (opt.a_long_one)
printf(" a-long-one=%d\n", opt.a_long_one ); printf (" a-long-one=%d\n", opt.a_long_one );
if( opt.echo ) if (opt.echo)
printf(" echo=%d\n", opt.echo ); printf (" echo=%d\n", opt.echo );
return 0;
return 0;
} }
#endif #endif /*TEST*/
/**** bottom of file ****/ /**** bottom of file ****/

View File

@ -32,7 +32,6 @@
#define LIBJNLIB_ARGPARSE_H #define LIBJNLIB_ARGPARSE_H
#include <stdio.h> #include <stdio.h>
#include "types.h"
typedef struct typedef struct
{ {
@ -193,12 +192,12 @@ typedef struct
#define ARGPARSE_INVALID_ARG (-12) #define ARGPARSE_INVALID_ARG (-12)
int arg_parse( ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts); int arg_parse (ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts);
int optfile_parse( FILE *fp, const char *filename, unsigned *lineno, int optfile_parse (FILE *fp, const char *filename, unsigned *lineno,
ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts); ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts);
void usage( int level ); void usage (int level);
const char *strusage( int level ); const char *strusage (int level);
void set_strusage( const char *(*f)( int ) ); void set_strusage (const char *(*f)( int ));
void argparse_register_outfnc (int (*fnc)(int, const char *)); void argparse_register_outfnc (int (*fnc)(int, const char *));
#endif /*LIBJNLIB_ARGPARSE_H*/ #endif /*LIBJNLIB_ARGPARSE_H*/