projects
/
gnulib.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
* build-aux/depcomp, build-aux/install-sh, build-aux/mdate-sh,
[gnulib.git]
/
lib
/
long-options.c
diff --git
a/lib/long-options.c
b/lib/long-options.c
index
82372d6
..
33f1d46
100644
(file)
--- a/
lib/long-options.c
+++ b/
lib/long-options.c
@@
-1,5
+1,7
@@
/* Utility to accept --help and --version options as unobtrusively as possible.
/* Utility to accept --help and --version options as unobtrusively as possible.
- Copyright (C) 1993, 1994, 1998, 1999 Free Software Foundation, Inc.
+
+ Copyright (C) 1993, 1994, 1998, 1999, 2000, 2002, 2003, 2004, 2005 Free
+ Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@
-13,7
+15,7
@@
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software Foundation,
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software Foundation,
- Inc., 5
9 Temple Place - Suite 330, Boston, MA 02111-1307
, USA. */
+ Inc., 5
1 Franklin Street, Fifth Floor, Boston, MA 02110-1301
, USA. */
/* Written by Jim Meyering. */
/* Written by Jim Meyering. */
@@
-21,24
+23,21
@@
# include <config.h>
#endif
# include <config.h>
#endif
+/* Specification. */
+#include "long-options.h"
+
+#include <stdarg.h>
#include <stdio.h>
#include <stdio.h>
+#include <stdlib.h>
#include <getopt.h>
#include <getopt.h>
-#include "closeout.h"
-#include "long-options.h"
-#include "version-etc.h"
-#if ENABLE_NLS
-# include <libintl.h>
-# define _(Text) gettext (Text)
-#else
-# define _(Text) Text
-#endif
+#include "version-etc.h"
static struct option const long_options[] =
{
static struct option const long_options[] =
{
- {"help", no_argument,
0
, 'h'},
- {"version", no_argument,
0
, 'v'},
- {
0, 0, 0
, 0}
+ {"help", no_argument,
NULL
, 'h'},
+ {"version", no_argument,
NULL
, 'v'},
+ {
NULL, 0, NULL
, 0}
};
/* Process long options --help and --version, but only if argc == 2.
};
/* Process long options --help and --version, but only if argc == 2.
@@
-50,8
+49,8
@@
parse_long_options (int argc,
const char *command_name,
const char *package,
const char *version,
const char *command_name,
const char *package,
const char *version,
-
const char *authors
,
-
void (*usage_func)()
)
+
void (*usage_func) (int)
,
+
/* const char *author1, ...*/ ...
)
{
int c;
int saved_opterr;
{
int c;
int saved_opterr;
@@
-67,13
+66,15
@@
parse_long_options (int argc,
switch (c)
{
case 'h':
switch (c)
{
case 'h':
- (*usage_func) (
0
);
+ (*usage_func) (
EXIT_SUCCESS
);
case 'v':
case 'v':
- version_etc (stdout, command_name, package, version, authors);
- close_stdout (); /* FIXME: output failure exit status
- should be settable via an arg. */
- exit (0);
+ {
+ va_list authors;
+ va_start (authors, usage_func);
+ version_etc_va (stdout, command_name, package, version, authors);
+ exit (0);
+ }
default:
/* Don't process any other long-named options. */
default:
/* Don't process any other long-named options. */