mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-03 12:11:33 +01:00
Print --version etc via estream
This commit is contained in:
parent
f5551672fb
commit
29cc88db7d
@ -1,3 +1,12 @@
|
|||||||
|
2010-05-30 Werner Koch <wk@g10code.com>
|
||||||
|
|
||||||
|
* init.c (writestring_via_estream): New.
|
||||||
|
(init_common_subsystems): Register with argparse.
|
||||||
|
|
||||||
|
* argparse.c (argparse_register_outfnc): New.
|
||||||
|
(writestrings, flushstrings): New. Use them instead of stdout or
|
||||||
|
stderr based functions.
|
||||||
|
|
||||||
2010-05-04 Werner Koch <wk@g10code.com>
|
2010-05-04 Werner Koch <wk@g10code.com>
|
||||||
|
|
||||||
* estream.c (_es_get_std_stream): Re-use registered standard fds.
|
* estream.c (_es_get_std_stream): Re-use registered standard fds.
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <stdarg.h>
|
||||||
|
|
||||||
#include "libjnlib-config.h"
|
#include "libjnlib-config.h"
|
||||||
#include "mischelp.h"
|
#include "mischelp.h"
|
||||||
@ -144,10 +145,62 @@ struct alias_def_s {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const char *(*strusage_handler)( int ) = NULL;
|
static const char *(*strusage_handler)( int ) = NULL;
|
||||||
|
static int (*custom_outfnc) (int, const char *);
|
||||||
|
|
||||||
static int set_opt_arg(ARGPARSE_ARGS *arg, unsigned flags, char *s);
|
static int set_opt_arg(ARGPARSE_ARGS *arg, unsigned flags, char *s);
|
||||||
static void show_help(ARGPARSE_OPTS *opts, unsigned flags);
|
static void show_help(ARGPARSE_OPTS *opts, unsigned flags);
|
||||||
static void show_version(void);
|
static void show_version(void);
|
||||||
|
static int writestrings (int is_error, const char *string, ...)
|
||||||
|
#if __GNUC__ >= 4
|
||||||
|
__attribute__ ((sentinel(0)))
|
||||||
|
#endif
|
||||||
|
;
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
argparse_register_outfnc (int (*fnc)(int, const char *))
|
||||||
|
{
|
||||||
|
custom_outfnc = fnc;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Write STRING and all following const char * arguments either to
|
||||||
|
stdout or, if IS_ERROR is set, to stderr. The list of strings must
|
||||||
|
be terminated by a NULL. */
|
||||||
|
static int
|
||||||
|
writestrings (int is_error, const char *string, ...)
|
||||||
|
{
|
||||||
|
va_list arg_ptr;
|
||||||
|
const char *s;
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
|
if (string)
|
||||||
|
{
|
||||||
|
s = string;
|
||||||
|
va_start (arg_ptr, string);
|
||||||
|
do
|
||||||
|
{
|
||||||
|
if (custom_outfnc)
|
||||||
|
custom_outfnc (is_error? 2:1, s);
|
||||||
|
else
|
||||||
|
fputs (s, is_error? stderr : stdout);
|
||||||
|
count += strlen (s);
|
||||||
|
}
|
||||||
|
while ((s = va_arg (arg_ptr, const char *)));
|
||||||
|
va_end (arg_ptr);
|
||||||
|
}
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
flushstrings (int is_error)
|
||||||
|
{
|
||||||
|
if (custom_outfnc)
|
||||||
|
custom_outfnc (is_error? 2:1, NULL);
|
||||||
|
else
|
||||||
|
fflush (is_error? stderr : stdout);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -630,7 +683,7 @@ arg_parse( ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts)
|
|||||||
}
|
}
|
||||||
else if ( i < 0 && !strcmp( "warranty", s+2))
|
else if ( i < 0 && !strcmp( "warranty", s+2))
|
||||||
{
|
{
|
||||||
puts ( strusage (16) );
|
writestrings (0, strusage (16), "\n", NULL);
|
||||||
exit (0);
|
exit (0);
|
||||||
}
|
}
|
||||||
else if ( i < 0 && !strcmp( "dump-options", s+2) )
|
else if ( i < 0 && !strcmp( "dump-options", s+2) )
|
||||||
@ -638,9 +691,10 @@ arg_parse( ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts)
|
|||||||
for (i=0; opts[i].short_opt; i++ )
|
for (i=0; opts[i].short_opt; i++ )
|
||||||
{
|
{
|
||||||
if ( opts[i].long_opt )
|
if ( opts[i].long_opt )
|
||||||
printf ("--%s\n", opts[i].long_opt);
|
writestrings (0, "--", opts[i].long_opt, "\n", NULL);
|
||||||
}
|
}
|
||||||
fputs ("--dump-options\n--help\n--version\n--warranty\n", stdout);
|
writestrings (0, "--dump-options\n--help\n--version\n--warranty\n",
|
||||||
|
NULL);
|
||||||
exit (0);
|
exit (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -875,11 +929,12 @@ static void
|
|||||||
show_help (ARGPARSE_OPTS *opts, unsigned int flags)
|
show_help (ARGPARSE_OPTS *opts, unsigned int flags)
|
||||||
{
|
{
|
||||||
const char *s;
|
const char *s;
|
||||||
|
char tmp[2];
|
||||||
|
|
||||||
show_version ();
|
show_version ();
|
||||||
putchar ('\n');
|
writestrings (0, "\n", NULL);
|
||||||
s = strusage(41);
|
s = strusage(41);
|
||||||
puts (s);
|
writestrings (0, s, "\n", NULL);
|
||||||
if ( opts[0].description )
|
if ( opts[0].description )
|
||||||
{
|
{
|
||||||
/* Auto format the option description. */
|
/* Auto format the option description. */
|
||||||
@ -897,7 +952,7 @@ show_help (ARGPARSE_OPTS *opts, unsigned int flags)
|
|||||||
/* Example: " -v, --verbose Viele Sachen ausgeben" */
|
/* Example: " -v, --verbose Viele Sachen ausgeben" */
|
||||||
indent += 10;
|
indent += 10;
|
||||||
if ( *opts[0].description != '@' )
|
if ( *opts[0].description != '@' )
|
||||||
puts ("Options:");
|
writestrings (0, "Options:", "\n", NULL);
|
||||||
for (i=0; opts[i].short_opt; i++ )
|
for (i=0; opts[i].short_opt; i++ )
|
||||||
{
|
{
|
||||||
s = _( opts[i].description );
|
s = _( opts[i].description );
|
||||||
@ -910,61 +965,76 @@ show_help (ARGPARSE_OPTS *opts, unsigned int flags)
|
|||||||
if ( *s == '\n' )
|
if ( *s == '\n' )
|
||||||
{
|
{
|
||||||
if( s[1] )
|
if( s[1] )
|
||||||
putchar('\n');
|
writestrings (0, "\n", NULL);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
putchar(*s);
|
{
|
||||||
}
|
tmp[0] = *s;
|
||||||
putchar('\n');
|
tmp[1] = 0;
|
||||||
|
writestrings (0, tmp, NULL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
writestrings (0, "\n", NULL);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
j = 3;
|
j = 3;
|
||||||
if ( opts[i].short_opt < 256 )
|
if ( opts[i].short_opt < 256 )
|
||||||
{
|
{
|
||||||
printf (" -%c", opts[i].short_opt);
|
tmp[0] = opts[i].short_opt;
|
||||||
|
tmp[1] = 0;
|
||||||
|
writestrings (0, " -", tmp, NULL );
|
||||||
if ( !opts[i].long_opt )
|
if ( !opts[i].long_opt )
|
||||||
{
|
{
|
||||||
if (s && *s == '|' )
|
if (s && *s == '|' )
|
||||||
{
|
{
|
||||||
putchar (' '); j++;
|
writestrings (0, " ", NULL); j++;
|
||||||
for (s++ ; *s && *s != '|'; s++, j++ )
|
for (s++ ; *s && *s != '|'; s++, j++ )
|
||||||
putchar (*s);
|
{
|
||||||
|
tmp[0] = *s;
|
||||||
|
tmp[1] = 0;
|
||||||
|
writestrings (0, tmp, NULL);
|
||||||
|
}
|
||||||
if ( *s )
|
if ( *s )
|
||||||
s++;
|
s++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
fputs(" ", stdout);
|
writestrings (0, " ", NULL);
|
||||||
if ( opts[i].long_opt )
|
if ( opts[i].long_opt )
|
||||||
{
|
{
|
||||||
j += printf ("%c --%s", opts[i].short_opt < 256?',':' ',
|
tmp[0] = opts[i].short_opt < 256?',':' ';
|
||||||
opts[i].long_opt );
|
tmp[1] = 0;
|
||||||
|
j += writestrings (0, tmp, " --", opts[i].long_opt, NULL);
|
||||||
if (s && *s == '|' )
|
if (s && *s == '|' )
|
||||||
{
|
{
|
||||||
if ( *++s != '=' )
|
if ( *++s != '=' )
|
||||||
{
|
{
|
||||||
putchar(' ');
|
writestrings (0, " ", NULL);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
for ( ; *s && *s != '|'; s++, j++ )
|
for ( ; *s && *s != '|'; s++, j++ )
|
||||||
putchar(*s);
|
{
|
||||||
|
tmp[0] = *s;
|
||||||
|
tmp[1] = 0;
|
||||||
|
writestrings (0, tmp, NULL);
|
||||||
|
}
|
||||||
if ( *s )
|
if ( *s )
|
||||||
s++;
|
s++;
|
||||||
}
|
}
|
||||||
fputs (" ", stdout);
|
writestrings (0, " ", NULL);
|
||||||
j += 3;
|
j += 3;
|
||||||
}
|
}
|
||||||
for (;j < indent; j++ )
|
for (;j < indent; j++ )
|
||||||
putchar(' ');
|
writestrings (0, " ", NULL);
|
||||||
if ( s )
|
if ( s )
|
||||||
{
|
{
|
||||||
if ( *s && j > indent )
|
if ( *s && j > indent )
|
||||||
{
|
{
|
||||||
putchar('\n');
|
writestrings (0, "\n", NULL);
|
||||||
for (j=0;j < indent; j++ )
|
for (j=0;j < indent; j++ )
|
||||||
putchar (' ');
|
writestrings (0, " ", NULL);
|
||||||
}
|
}
|
||||||
for (; *s; s++ )
|
for (; *s; s++ )
|
||||||
{
|
{
|
||||||
@ -972,44 +1042,58 @@ show_help (ARGPARSE_OPTS *opts, unsigned int flags)
|
|||||||
{
|
{
|
||||||
if ( s[1] )
|
if ( s[1] )
|
||||||
{
|
{
|
||||||
putchar ('\n');
|
writestrings (0, "\n", NULL);
|
||||||
for (j=0; j < indent; j++ )
|
for (j=0; j < indent; j++ )
|
||||||
putchar (' ');
|
writestrings (0, " ", NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
putchar (*s);
|
{
|
||||||
|
tmp[0] = *s;
|
||||||
|
tmp[1] = 0;
|
||||||
|
writestrings (0, tmp, NULL);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
putchar ('\n');
|
writestrings (0, "\n", NULL);
|
||||||
}
|
}
|
||||||
if ( (flags & ARGPARSE_FLAG_ONEDASH) )
|
if ( (flags & ARGPARSE_FLAG_ONEDASH) )
|
||||||
puts ("\n(A single dash may be used instead of the double ones)");
|
writestrings (0, "\n(A single dash may be used "
|
||||||
|
"instead of the double ones)\n", NULL);
|
||||||
}
|
}
|
||||||
if ( (s=strusage(19)) )
|
if ( (s=strusage(19)) )
|
||||||
{
|
{
|
||||||
/* bug reports to ... */
|
/* bug reports to ... */
|
||||||
char *s2;
|
char *s2;
|
||||||
|
|
||||||
putchar('\n');
|
writestrings (0, "\n", NULL);
|
||||||
s2 = strstr (s, "@EMAIL@");
|
s2 = strstr (s, "@EMAIL@");
|
||||||
if (s2)
|
if (s2)
|
||||||
{
|
{
|
||||||
if (s2-s)
|
if (s2-s)
|
||||||
fwrite (s, s2-s, 1, stdout);
|
{
|
||||||
|
const char *s3;
|
||||||
|
|
||||||
|
for (s3=s; s3 < s2; s3++)
|
||||||
|
{
|
||||||
|
tmp[0] = *s3;
|
||||||
|
tmp[1] = 0;
|
||||||
|
writestrings (0, tmp, NULL);
|
||||||
|
}
|
||||||
|
}
|
||||||
#ifdef PACKAGE_BUGREPORT
|
#ifdef PACKAGE_BUGREPORT
|
||||||
fputs (PACKAGE_BUGREPORT, stdout);
|
writestrings (0, PACKAGE_BUGREPORT, NULL);
|
||||||
#else
|
#else
|
||||||
fputs ("bug@example.org", stdout);
|
writestrings (0, "bug@example.org", NULL);
|
||||||
#endif
|
#endif
|
||||||
s2 += 7;
|
s2 += 7;
|
||||||
if (*s2)
|
if (*s2)
|
||||||
fputs (s2, stdout);
|
writestrings (0, s2, NULL);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
fputs(s, stdout);
|
writestrings (0, s, NULL);
|
||||||
}
|
}
|
||||||
fflush(stdout);
|
flushstrings (0);
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1020,31 +1104,31 @@ show_version ()
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* Version line. */
|
/* Version line. */
|
||||||
fputs (strusage (11), stdout);
|
writestrings (0, strusage (11), NULL);
|
||||||
if ((s=strusage (12)))
|
if ((s=strusage (12)))
|
||||||
printf (" (%s)", s );
|
writestrings (0, " (", s, ")", NULL);
|
||||||
printf (" %s\n", strusage (13) );
|
writestrings (0, " ", strusage (13), "\n", NULL);
|
||||||
/* Additional version lines. */
|
/* Additional version lines. */
|
||||||
for (i=20; i < 30; i++)
|
for (i=20; i < 30; i++)
|
||||||
if ((s=strusage (i)))
|
if ((s=strusage (i)))
|
||||||
printf ("%s\n", s );
|
writestrings (0, s, "\n", NULL);
|
||||||
/* Copyright string. */
|
/* Copyright string. */
|
||||||
if( (s=strusage (14)) )
|
if ((s=strusage (14)))
|
||||||
printf("%s\n", s );
|
writestrings (0, s, "\n", NULL);
|
||||||
/* Licence string. */
|
/* Licence string. */
|
||||||
if( (s=strusage (10)) )
|
if( (s=strusage (10)) )
|
||||||
printf("%s\n", s );
|
writestrings (0, s, "\n", NULL);
|
||||||
/* Copying conditions. */
|
/* Copying conditions. */
|
||||||
if ( (s=strusage(15)) )
|
if ( (s=strusage(15)) )
|
||||||
fputs (s, stdout);
|
writestrings (0, s, NULL);
|
||||||
/* Thanks. */
|
/* Thanks. */
|
||||||
if ((s=strusage(18)))
|
if ((s=strusage(18)))
|
||||||
fputs (s, stdout);
|
writestrings (0, s, NULL);
|
||||||
/* Additional program info. */
|
/* Additional program info. */
|
||||||
for (i=30; i < 40; i++ )
|
for (i=30; i < 40; i++ )
|
||||||
if ( (s=strusage (i)) )
|
if ( (s=strusage (i)) )
|
||||||
fputs (s, stdout);
|
writestrings (0, s, NULL);
|
||||||
fflush (stdout);
|
flushstrings (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1055,20 +1139,21 @@ usage (int level)
|
|||||||
|
|
||||||
if (!level)
|
if (!level)
|
||||||
{
|
{
|
||||||
fprintf(stderr,"%s %s; %s\n", strusage(11), strusage(13), strusage (14));
|
writestrings (1, strusage(11), " ", strusage(13), "; ",
|
||||||
fflush (stderr);
|
strusage (14), "\n", NULL);
|
||||||
|
flushstrings (1);
|
||||||
}
|
}
|
||||||
else if (level == 1)
|
else if (level == 1)
|
||||||
{
|
{
|
||||||
p = strusage (40);
|
p = strusage (40);
|
||||||
fputs (p, stderr);
|
writestrings (1, p, NULL);
|
||||||
if (*p && p[strlen(p)] != '\n')
|
if (*p && p[strlen(p)] != '\n')
|
||||||
putc ('\n', stderr);
|
writestrings (1, "\n", NULL);
|
||||||
exit (2);
|
exit (2);
|
||||||
}
|
}
|
||||||
else if (level == 2)
|
else if (level == 2)
|
||||||
{
|
{
|
||||||
puts (strusage(41));
|
writestrings (0, strusage(41), "\n", NULL);
|
||||||
exit (0);
|
exit (0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -179,5 +179,6 @@ int optfile_parse( FILE *fp, const char *filename, unsigned *lineno,
|
|||||||
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 *));
|
||||||
|
|
||||||
#endif /*LIBJNLIB_ARGPARSE_H*/
|
#endif /*LIBJNLIB_ARGPARSE_H*/
|
||||||
|
@ -49,6 +49,23 @@ sleep_on_exit (void)
|
|||||||
#endif /*HAVE_W32CE_SYSTEM*/
|
#endif /*HAVE_W32CE_SYSTEM*/
|
||||||
|
|
||||||
|
|
||||||
|
/* If STRING is not NULL write string to es_stdout or es_stderr. MODE
|
||||||
|
must be 1 or 2. If STRING is NULL flush the respective stream. */
|
||||||
|
static int
|
||||||
|
writestring_via_estream (int mode, const char *string)
|
||||||
|
{
|
||||||
|
if (mode == 1 || mode == 2)
|
||||||
|
{
|
||||||
|
if (string)
|
||||||
|
return es_fputs (string, mode == 1? es_stdout : es_stderr);
|
||||||
|
else
|
||||||
|
return es_fflush (mode == 1? es_stdout : es_stderr);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* This function is to be used early at program startup to make sure
|
/* This function is to be used early at program startup to make sure
|
||||||
that some subsystems are initialized. This is in particular
|
that some subsystems are initialized. This is in particular
|
||||||
important for W32 to initialize the sockets so that our socket
|
important for W32 to initialize the sockets so that our socket
|
||||||
@ -100,6 +117,10 @@ init_common_subsystems (int *argcp, char ***argvp)
|
|||||||
(void)argcp;
|
(void)argcp;
|
||||||
(void)argvp;
|
(void)argvp;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* --version et al shall use estream as well. */
|
||||||
|
argparse_register_outfnc (writestring_via_estream);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user