ltlfilt: Call set_program_name().
* src/bin/ltlfilt.cc (main): Call set_program_name(). * lib/progname.c, lib/progname.h: New files, from gnulib 1af55d85d9762a679b4302d5995f05ccd883e956. * lib/Makefile.am, m4/gnulib-cache.m4, m4/gnulib-comp.m4: Adjust.
This commit is contained in:
parent
93f6e21759
commit
8132f91867
6 changed files with 175 additions and 2 deletions
|
|
@ -21,7 +21,7 @@
|
||||||
# the same distribution terms as the rest of that program.
|
# the same distribution terms as the rest of that program.
|
||||||
#
|
#
|
||||||
# Generated by gnulib-tool.
|
# Generated by gnulib-tool.
|
||||||
# Reproduce by: gnulib-tool --import --dir=. --lib=libgnu --source-base=lib --m4-base=m4 --doc-base=doc --tests-base=tests --aux-dir=tools --no-conditional-dependencies --no-libtool --macro-prefix=gl --no-vc-files argp
|
# Reproduce by: gnulib-tool --import --dir=. --lib=libgnu --source-base=lib --m4-base=m4 --doc-base=doc --tests-base=tests --aux-dir=tools --no-conditional-dependencies --no-libtool --macro-prefix=gl --no-vc-files argp progname
|
||||||
|
|
||||||
AUTOMAKE_OPTIONS = 1.5 gnits
|
AUTOMAKE_OPTIONS = 1.5 gnits
|
||||||
|
|
||||||
|
|
@ -247,6 +247,12 @@ EXTRA_libgnu_a_SOURCES += mempcpy.c
|
||||||
|
|
||||||
## end gnulib module mempcpy
|
## end gnulib module mempcpy
|
||||||
|
|
||||||
|
## begin gnulib module progname
|
||||||
|
|
||||||
|
libgnu_a_SOURCES += progname.h progname.c
|
||||||
|
|
||||||
|
## end gnulib module progname
|
||||||
|
|
||||||
## begin gnulib module rawmemchr
|
## begin gnulib module rawmemchr
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
92
lib/progname.c
Normal file
92
lib/progname.c
Normal file
|
|
@ -0,0 +1,92 @@
|
||||||
|
/* Program name management.
|
||||||
|
Copyright (C) 2001-2003, 2005-2012 Free Software Foundation, Inc.
|
||||||
|
Written by Bruno Haible <bruno@clisp.org>, 2001.
|
||||||
|
|
||||||
|
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
|
||||||
|
the Free Software Foundation; either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
|
||||||
|
/* Specification. */
|
||||||
|
#undef ENABLE_RELOCATABLE /* avoid defining set_program_name as a macro */
|
||||||
|
#include "progname.h"
|
||||||
|
|
||||||
|
#include <errno.h> /* get program_invocation_name declaration */
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
|
||||||
|
/* String containing name the program is called with.
|
||||||
|
To be initialized by main(). */
|
||||||
|
const char *program_name = NULL;
|
||||||
|
|
||||||
|
/* Set program_name, based on argv[0].
|
||||||
|
argv0 must be a string allocated with indefinite extent, and must not be
|
||||||
|
modified after this call. */
|
||||||
|
void
|
||||||
|
set_program_name (const char *argv0)
|
||||||
|
{
|
||||||
|
/* libtool creates a temporary executable whose name is sometimes prefixed
|
||||||
|
with "lt-" (depends on the platform). It also makes argv[0] absolute.
|
||||||
|
But the name of the temporary executable is a detail that should not be
|
||||||
|
visible to the end user and to the test suite.
|
||||||
|
Remove this "<dirname>/.libs/" or "<dirname>/.libs/lt-" prefix here. */
|
||||||
|
const char *slash;
|
||||||
|
const char *base;
|
||||||
|
|
||||||
|
/* Sanity check. POSIX requires the invoking process to pass a non-NULL
|
||||||
|
argv[0]. */
|
||||||
|
if (argv0 == NULL)
|
||||||
|
{
|
||||||
|
/* It's a bug in the invoking program. Help diagnosing it. */
|
||||||
|
fputs ("A NULL argv[0] was passed through an exec system call.\n",
|
||||||
|
stderr);
|
||||||
|
abort ();
|
||||||
|
}
|
||||||
|
|
||||||
|
slash = strrchr (argv0, '/');
|
||||||
|
base = (slash != NULL ? slash + 1 : argv0);
|
||||||
|
if (base - argv0 >= 7 && strncmp (base - 7, "/.libs/", 7) == 0)
|
||||||
|
{
|
||||||
|
argv0 = base;
|
||||||
|
if (strncmp (base, "lt-", 3) == 0)
|
||||||
|
{
|
||||||
|
argv0 = base + 3;
|
||||||
|
/* On glibc systems, remove the "lt-" prefix from the variable
|
||||||
|
program_invocation_short_name. */
|
||||||
|
#if HAVE_DECL_PROGRAM_INVOCATION_SHORT_NAME
|
||||||
|
program_invocation_short_name = (char *) argv0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* But don't strip off a leading <dirname>/ in general, because when the user
|
||||||
|
runs
|
||||||
|
/some/hidden/place/bin/cp foo foo
|
||||||
|
he should get the error message
|
||||||
|
/some/hidden/place/bin/cp: `foo' and `foo' are the same file
|
||||||
|
not
|
||||||
|
cp: `foo' and `foo' are the same file
|
||||||
|
*/
|
||||||
|
|
||||||
|
program_name = argv0;
|
||||||
|
|
||||||
|
/* On glibc systems, the error() function comes from libc and uses the
|
||||||
|
variable program_invocation_name, not program_name. So set this variable
|
||||||
|
as well. */
|
||||||
|
#if HAVE_DECL_PROGRAM_INVOCATION_NAME
|
||||||
|
program_invocation_name = (char *) argv0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
62
lib/progname.h
Normal file
62
lib/progname.h
Normal file
|
|
@ -0,0 +1,62 @@
|
||||||
|
/* Program name management.
|
||||||
|
Copyright (C) 2001-2004, 2006, 2009-2012 Free Software Foundation, Inc.
|
||||||
|
Written by Bruno Haible <bruno@clisp.org>, 2001.
|
||||||
|
|
||||||
|
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
|
||||||
|
the Free Software Foundation; either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#ifndef _PROGNAME_H
|
||||||
|
#define _PROGNAME_H
|
||||||
|
|
||||||
|
/* Programs using this file should do the following in main():
|
||||||
|
set_program_name (argv[0]);
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* String containing name the program is called with. */
|
||||||
|
extern const char *program_name;
|
||||||
|
|
||||||
|
/* Set program_name, based on argv[0].
|
||||||
|
argv0 must be a string allocated with indefinite extent, and must not be
|
||||||
|
modified after this call. */
|
||||||
|
extern void set_program_name (const char *argv0);
|
||||||
|
|
||||||
|
#if ENABLE_RELOCATABLE
|
||||||
|
|
||||||
|
/* Set program_name, based on argv[0], and original installation prefix and
|
||||||
|
directory, for relocatability. */
|
||||||
|
extern void set_program_name_and_installdir (const char *argv0,
|
||||||
|
const char *orig_installprefix,
|
||||||
|
const char *orig_installdir);
|
||||||
|
#undef set_program_name
|
||||||
|
#define set_program_name(ARG0) \
|
||||||
|
set_program_name_and_installdir (ARG0, INSTALLPREFIX, INSTALLDIR)
|
||||||
|
|
||||||
|
/* Return the full pathname of the current executable, based on the earlier
|
||||||
|
call to set_program_name_and_installdir. Return NULL if unknown. */
|
||||||
|
extern char *get_full_program_name (void);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* _PROGNAME_H */
|
||||||
|
|
@ -27,12 +27,13 @@
|
||||||
|
|
||||||
|
|
||||||
# Specification in the form of a command-line invocation:
|
# Specification in the form of a command-line invocation:
|
||||||
# gnulib-tool --import --dir=. --lib=libgnu --source-base=lib --m4-base=m4 --doc-base=doc --tests-base=tests --aux-dir=tools --no-conditional-dependencies --no-libtool --macro-prefix=gl --no-vc-files argp
|
# gnulib-tool --import --dir=. --lib=libgnu --source-base=lib --m4-base=m4 --doc-base=doc --tests-base=tests --aux-dir=tools --no-conditional-dependencies --no-libtool --macro-prefix=gl --no-vc-files argp progname
|
||||||
|
|
||||||
# Specification in the form of a few gnulib-tool.m4 macro invocations:
|
# Specification in the form of a few gnulib-tool.m4 macro invocations:
|
||||||
gl_LOCAL_DIR([])
|
gl_LOCAL_DIR([])
|
||||||
gl_MODULES([
|
gl_MODULES([
|
||||||
argp
|
argp
|
||||||
|
progname
|
||||||
])
|
])
|
||||||
gl_AVOID([])
|
gl_AVOID([])
|
||||||
gl_SOURCE_BASE([lib])
|
gl_SOURCE_BASE([lib])
|
||||||
|
|
|
||||||
|
|
@ -59,6 +59,7 @@ AC_DEFUN([gl_EARLY],
|
||||||
# Code from module mempcpy:
|
# Code from module mempcpy:
|
||||||
# Code from module multiarch:
|
# Code from module multiarch:
|
||||||
# Code from module nocrash:
|
# Code from module nocrash:
|
||||||
|
# Code from module progname:
|
||||||
# Code from module rawmemchr:
|
# Code from module rawmemchr:
|
||||||
# Code from module size_max:
|
# Code from module size_max:
|
||||||
# Code from module sleep:
|
# Code from module sleep:
|
||||||
|
|
@ -166,6 +167,8 @@ AC_DEFUN([gl_INIT],
|
||||||
fi
|
fi
|
||||||
gl_STRING_MODULE_INDICATOR([mempcpy])
|
gl_STRING_MODULE_INDICATOR([mempcpy])
|
||||||
gl_MULTIARCH
|
gl_MULTIARCH
|
||||||
|
AC_CHECK_DECLS([program_invocation_name], [], [], [#include <errno.h>])
|
||||||
|
AC_CHECK_DECLS([program_invocation_short_name], [], [], [#include <errno.h>])
|
||||||
gl_FUNC_RAWMEMCHR
|
gl_FUNC_RAWMEMCHR
|
||||||
if test $HAVE_RAWMEMCHR = 0; then
|
if test $HAVE_RAWMEMCHR = 0; then
|
||||||
AC_LIBOBJ([rawmemchr])
|
AC_LIBOBJ([rawmemchr])
|
||||||
|
|
@ -417,6 +420,8 @@ AC_DEFUN([gl_FILE_LIST], [
|
||||||
lib/printf-args.h
|
lib/printf-args.h
|
||||||
lib/printf-parse.c
|
lib/printf-parse.c
|
||||||
lib/printf-parse.h
|
lib/printf-parse.h
|
||||||
|
lib/progname.c
|
||||||
|
lib/progname.h
|
||||||
lib/rawmemchr.c
|
lib/rawmemchr.c
|
||||||
lib/rawmemchr.valgrind
|
lib/rawmemchr.valgrind
|
||||||
lib/size_max.h
|
lib/size_max.h
|
||||||
|
|
|
||||||
|
|
@ -29,6 +29,8 @@
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <argp.h>
|
#include <argp.h>
|
||||||
|
#include "progname.h"
|
||||||
|
|
||||||
#include "misc/_config.h"
|
#include "misc/_config.h"
|
||||||
#include "misc/hash.hh"
|
#include "misc/hash.hh"
|
||||||
#include "ltlparse/public.hh"
|
#include "ltlparse/public.hh"
|
||||||
|
|
@ -549,6 +551,11 @@ run_jobs()
|
||||||
int
|
int
|
||||||
main(int argc, char** argv)
|
main(int argc, char** argv)
|
||||||
{
|
{
|
||||||
|
set_program_name(argv[0]);
|
||||||
|
// Simplify the program name, because argp() uses it to report errors
|
||||||
|
// and display help text.
|
||||||
|
argv[0] = const_cast<char*>(program_name);
|
||||||
|
|
||||||
const argp ap = { options, parse_opt, "[FILENAME...]",
|
const argp ap = { options, parse_opt, "[FILENAME...]",
|
||||||
argp_program_doc, 0, 0, 0 };
|
argp_program_doc, 0, 0, 0 };
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue