From: hajo Date: Tue, 2 Oct 2007 14:08:50 +0000 (+0200) Subject: added: autoconf environment X-Git-Url: http://git.eversberg.eu/gitweb.cgi?p=lcr.git;a=commitdiff_plain;h=8bddb2d979c879c2081d7efe9a048362524dbd14 added: autoconf environment NOTE: --with-asterisk compiles, --use-misdn-socket not --- diff --git a/AUTHORS b/AUTHORS new file mode 100644 index 0000000..e866f72 --- /dev/null +++ b/AUTHORS @@ -0,0 +1,2 @@ +Andreas Eversberg +Joerg Habenicht diff --git a/ChangeLog b/ChangeLog new file mode 100644 index 0000000..e69de29 diff --git a/INSTALL b/INSTALL new file mode 100644 index 0000000..5458714 --- /dev/null +++ b/INSTALL @@ -0,0 +1,234 @@ +Installation Instructions +************************* + +Copyright (C) 1994, 1995, 1996, 1999, 2000, 2001, 2002, 2004, 2005, +2006 Free Software Foundation, Inc. + +This file is free documentation; the Free Software Foundation gives +unlimited permission to copy, distribute and modify it. + +Basic Installation +================== + +Briefly, the shell commands `./configure; make; make install' should +configure, build, and install this package. The following +more-detailed instructions are generic; see the `README' file for +instructions specific to this package. + + The `configure' shell script attempts to guess correct values for +various system-dependent variables used during compilation. It uses +those values to create a `Makefile' in each directory of the package. +It may also create one or more `.h' files containing system-dependent +definitions. Finally, it creates a shell script `config.status' that +you can run in the future to recreate the current configuration, and a +file `config.log' containing compiler output (useful mainly for +debugging `configure'). + + It can also use an optional file (typically called `config.cache' +and enabled with `--cache-file=config.cache' or simply `-C') that saves +the results of its tests to speed up reconfiguring. Caching is +disabled by default to prevent problems with accidental use of stale +cache files. + + If you need to do unusual things to compile the package, please try +to figure out how `configure' could check whether to do them, and mail +diffs or instructions to the address given in the `README' so they can +be considered for the next release. If you are using the cache, and at +some point `config.cache' contains results you don't want to keep, you +may remove or edit it. + + The file `configure.ac' (or `configure.in') is used to create +`configure' by a program called `autoconf'. You need `configure.ac' if +you want to change it or regenerate `configure' using a newer version +of `autoconf'. + +The simplest way to compile this package is: + + 1. `cd' to the directory containing the package's source code and type + `./configure' to configure the package for your system. + + Running `configure' might take a while. While running, it prints + some messages telling which features it is checking for. + + 2. Type `make' to compile the package. + + 3. Optionally, type `make check' to run any self-tests that come with + the package. + + 4. Type `make install' to install the programs and any data files and + documentation. + + 5. You can remove the program binaries and object files from the + source code directory by typing `make clean'. To also remove the + files that `configure' created (so you can compile the package for + a different kind of computer), type `make distclean'. There is + also a `make maintainer-clean' target, but that is intended mainly + for the package's developers. If you use it, you may have to get + all sorts of other programs in order to regenerate files that came + with the distribution. + +Compilers and Options +===================== + +Some systems require unusual options for compilation or linking that the +`configure' script does not know about. Run `./configure --help' for +details on some of the pertinent environment variables. + + You can give `configure' initial values for configuration parameters +by setting variables in the command line or in the environment. Here +is an example: + + ./configure CC=c99 CFLAGS=-g LIBS=-lposix + + *Note Defining Variables::, for more details. + +Compiling For Multiple Architectures +==================================== + +You can compile the package for more than one kind of computer at the +same time, by placing the object files for each architecture in their +own directory. To do this, you can use GNU `make'. `cd' to the +directory where you want the object files and executables to go and run +the `configure' script. `configure' automatically checks for the +source code in the directory that `configure' is in and in `..'. + + With a non-GNU `make', it is safer to compile the package for one +architecture at a time in the source code directory. After you have +installed the package for one architecture, use `make distclean' before +reconfiguring for another architecture. + +Installation Names +================== + +By default, `make install' installs the package's commands under +`/usr/local/bin', include files under `/usr/local/include', etc. You +can specify an installation prefix other than `/usr/local' by giving +`configure' the option `--prefix=PREFIX'. + + You can specify separate installation prefixes for +architecture-specific files and architecture-independent files. If you +pass the option `--exec-prefix=PREFIX' to `configure', the package uses +PREFIX as the prefix for installing programs and libraries. +Documentation and other data files still use the regular prefix. + + In addition, if you use an unusual directory layout you can give +options like `--bindir=DIR' to specify different values for particular +kinds of files. Run `configure --help' for a list of the directories +you can set and what kinds of files go in them. + + If the package supports it, you can cause programs to be installed +with an extra prefix or suffix on their names by giving `configure' the +option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'. + +Optional Features +================= + +Some packages pay attention to `--enable-FEATURE' options to +`configure', where FEATURE indicates an optional part of the package. +They may also pay attention to `--with-PACKAGE' options, where PACKAGE +is something like `gnu-as' or `x' (for the X Window System). The +`README' should mention any `--enable-' and `--with-' options that the +package recognizes. + + For packages that use the X Window System, `configure' can usually +find the X include and library files automatically, but if it doesn't, +you can use the `configure' options `--x-includes=DIR' and +`--x-libraries=DIR' to specify their locations. + +Specifying the System Type +========================== + +There may be some features `configure' cannot figure out automatically, +but needs to determine by the type of machine the package will run on. +Usually, assuming the package is built to be run on the _same_ +architectures, `configure' can figure that out, but if it prints a +message saying it cannot guess the machine type, give it the +`--build=TYPE' option. TYPE can either be a short name for the system +type, such as `sun4', or a canonical name which has the form: + + CPU-COMPANY-SYSTEM + +where SYSTEM can have one of these forms: + + OS KERNEL-OS + + See the file `config.sub' for the possible values of each field. If +`config.sub' isn't included in this package, then this package doesn't +need to know the machine type. + + If you are _building_ compiler tools for cross-compiling, you should +use the option `--target=TYPE' to select the type of system they will +produce code for. + + If you want to _use_ a cross compiler, that generates code for a +platform different from the build platform, you should specify the +"host" platform (i.e., that on which the generated programs will +eventually be run) with `--host=TYPE'. + +Sharing Defaults +================ + +If you want to set default values for `configure' scripts to share, you +can create a site shell script called `config.site' that gives default +values for variables like `CC', `cache_file', and `prefix'. +`configure' looks for `PREFIX/share/config.site' if it exists, then +`PREFIX/etc/config.site' if it exists. Or, you can set the +`CONFIG_SITE' environment variable to the location of the site script. +A warning: not all `configure' scripts look for a site script. + +Defining Variables +================== + +Variables not defined in a site shell script can be set in the +environment passed to `configure'. However, some packages may run +configure again during the build, and the customized values of these +variables may be lost. In order to avoid this problem, you should set +them in the `configure' command line, using `VAR=value'. For example: + + ./configure CC=/usr/local2/bin/gcc + +causes the specified `gcc' to be used as the C compiler (unless it is +overridden in the site shell script). + +Unfortunately, this technique does not work for `CONFIG_SHELL' due to +an Autoconf bug. Until the bug is fixed you can use this workaround: + + CONFIG_SHELL=/bin/bash /bin/bash ./configure CONFIG_SHELL=/bin/bash + +`configure' Invocation +====================== + +`configure' recognizes the following options to control how it operates. + +`--help' +`-h' + Print a summary of the options to `configure', and exit. + +`--version' +`-V' + Print the version of Autoconf used to generate the `configure' + script, and exit. + +`--cache-file=FILE' + Enable the cache: use and save the results of the tests in FILE, + traditionally `config.cache'. FILE defaults to `/dev/null' to + disable caching. + +`--config-cache' +`-C' + Alias for `--cache-file=config.cache'. + +`--quiet' +`--silent' +`-q' + Do not print messages saying which checks are being made. To + suppress all normal output, redirect it to `/dev/null' (any error + messages will still be shown). + +`--srcdir=DIR' + Look for the package's source code in directory DIR. Usually + `configure' can determine that directory automatically. + +`configure' also accepts some other, not widely useful, options. Run +`configure --help' for more details. + diff --git a/Makefile.am b/Makefile.am new file mode 100644 index 0000000..e5b97b2 --- /dev/null +++ b/Makefile.am @@ -0,0 +1,492 @@ +## Makefile.am -- Process this file with automake to produce Makefile.in + + +INSTALLATION_DEFINES = -DCONFIG_DATA="\"$(pkgsysconfdir)\"" -DSHARE_DATA="\"$(pkgdatadir)\"" -DLOG_DIR="\"$(pkglogdir)\"" -DPBX -DINSTALL_DATA="\"$(pkgdatadir)\"" +# FIXME: find a macro for the include path of linux +# or is /lib/modules/$(uname -r)/source/include sufficient? +# Do we take /usr/src/linux or /usr/src/linux-$(uname -r) +# if complied without modules? +# UPDATE: Not needed, compiles cleanly without. +INCLUDES = $(all_includes) $(INSTALLATION_DEFINES) + + +bin_PROGRAMS = lcradmin gentones genwave #lcrwatch +sbin_PROGRAMS = lcr genrc genextension + + +conditional_sources_common = \ + main.c \ + options.c \ + interface.c \ + extension.c \ + cause.c \ + alawulaw.c \ + tones.c \ + message.c \ + route.c \ + port.cpp \ + mISDN.cpp \ + dss1.cpp \ + vbox.cpp \ + endpoint.cpp \ + endpointapp.cpp \ + apppbx.cpp \ + crypt.cpp \ + action.cpp \ + action_vbox.cpp \ + action_efi.cpp \ + mail.c \ + join.cpp \ + joinpbx.cpp \ + joinremote.cpp \ + admin_server.c \ + trace.c + +# extension.c main.c tones.c \ +# admin_server.c message.c \ +# alawulaw.c interface.c options.c \ +# cause.c mail.c route.c \ +# action.cpp crypt.cpp port.cpp \ +# action_efi.cpp dss1.cpp rule.cpp \ +# action_vbox.cpp endpointapp.cpp ie.cpp \ +# apppbx.cpp endpoint.cpp vbox.cpp \ +# call.cpp mISDN.cpp vector.cpp \ +# admin.h dss1.h route.h \ +# admin_server.h endpointapp.h rule.h \ +# alawulaw.h endpoint.h interface.h save.h \ +# apppbx.h extension.h main.h \ +# call.h message.h options.h tones.h \ +# cause.h mISDN.h port.h vbox.h \ +# crypt.h q931.h vector.h + + + + +# wizzard is currently disabled. +# it can be compiled with "make wizzard.o" but nothing more +#wizzard_SOURCES = wizzard.c wizzard.h + +lcr_SOURCES = $(conditional_sources_common) +lcr_LDADD = $(all_libraries) -lisdnnet -lmISDN +if WITH_CRYPTO +# TODO: maybe we could add crypt.{h,cpp} here? +#lcr_LDADD += -lcrypto -ldl +lcr_LDADD += -lcrypto +INSTALLATION_DEFINES += -DCRYPTO +endif + +if ENABLE_SOCKET_MISDN +INSTALLATION_DEFINES += -DSOCKET_MISDN +endif + +if ENABLE_ASTERISK_CHANNEL_DRIVER +sbin_PROGRAMS += chan_lcr +chan_lcr_SOURCES = asterisk_client.c +endif + +lcradmin_SOURCES = admin_client.c cause.c +genextension_SOURCES = genext.c options.c extension.c +# genrc, gentones, genwave are made automaticaly +lcrwatch_SOURCES = watch.c +#gentones: gentones.c +#genwave:genwave.c +#genrc: genrc.c + + +# test rule, nothing important +#echo: +# -echo $(all_libraries) >&2 + + +# CAUTION: CRUDE CRUDE HACK !! +# This transforms all compiling and linking calls from gcc into g++ +# This should better be removed and all .c files renamed to .cpp +COMPILE=$(CXXCOMPILE) +LINK=$(CXXLINK) +# in the end, it should look like: +# g++ -c -Wall -g -DINSTALL_DATA=\"/usr/local/lcr\" -I/usr/src/linux/include -I../mISDNuser/include -DPBX -DCRYPTO -I/usr/local/ssl/include route.cpp -o route.o + + + +pkglogdir=$(localstatedir)/log/@PACKAGE@ +# install runtime config in $prefix/etc/pbx4linux/ (e.g. /etc/pbx4linux) +# and voice data in $prefix/share/pbx4linux/ (e.g. /usr/share/pbx4linux) +pkgsysconfdir=$(sysconfdir)/@PACKAGE@ +dist_pkgsysconf_DATA = $(config_default) + +# install all voice data files along with their directory structure +# into $prefix/share/pbx4linux +nobase_dist_pkgdata_DATA = $(vbox_english) $(vbox_german) \ + $(tones_american) $(tones_efi) $(tones_german) + + +config_default = \ + default/directory.list \ + default/interface.conf \ + default/options.conf \ + default/routing.conf + +tones_american = \ + tones_american/activated_loop.isdn \ + tones_american/busy_loop.isdn \ + tones_american/cause_01_loop.isdn \ + tones_american/cause_02_loop.isdn \ + tones_american/cause_03_loop.isdn \ + tones_american/cause_05_loop.isdn \ + tones_american/cause_06_loop.isdn \ + tones_american/cause_12_loop.isdn \ + tones_american/cause_13_loop.isdn \ + tones_american/cause_14_loop.isdn \ + tones_american/cause_15_loop.isdn \ + tones_american/cause_16_loop.isdn \ + tones_american/cause_1b_loop.isdn \ + tones_american/cause_1c_loop.isdn \ + tones_american/cause_1d_loop.isdn \ + tones_american/cause_1f_loop.isdn \ + tones_american/cause_22_loop.isdn \ + tones_american/cause_26_loop.isdn \ + tones_american/cause_29_loop.isdn \ + tones_american/cause_2a_loop.isdn \ + tones_american/cause_2f_loop.isdn \ + tones_american/cause_31_loop.isdn \ + tones_american/cause_32_loop.isdn \ + tones_american/cause_39_loop.isdn \ + tones_american/cause_3a_loop.isdn \ + tones_american/cause_3f_loop.isdn \ + tones_american/cause_41_loop.isdn \ + tones_american/cause_42_loop.isdn \ + tones_american/cause_45_loop.isdn \ + tones_american/cause_46_loop.isdn \ + tones_american/cause_55_loop.isdn \ + tones_american/cause_80_loop.isdn \ + tones_american/cause_81_loop.isdn \ + tones_american/cause_82_loop.isdn \ + tones_american/cause_83_loop.isdn \ + tones_american/cause_84_loop.isdn \ + tones_american/cause_85_loop.isdn \ + tones_american/cause_86_loop.isdn \ + tones_american/cause_87_loop.isdn \ + tones_american/crypt_off.isdn \ + tones_american/crypt_on.isdn \ + tones_american/deactivated_loop.isdn \ + tones_american/dialpbx.isdn \ + tones_american/dialpbx_loop.isdn \ + tones_american/error_loop.isdn \ + tones_american/hold_loop.isdn \ + tones_american/password_loop.isdn \ + tones_american/redial.isdn \ + tones_american/ringing_loop.isdn \ + tones_american/ringpbx_loop.isdn \ + tones_american/test_loop.isdn + +tones_efi = \ + tones_efi/die.isdn \ + tones_efi/number_00.isdn \ + tones_efi/number_01.isdn \ + tones_efi/number_02.isdn \ + tones_efi/number_03.isdn \ + tones_efi/number_04.isdn \ + tones_efi/number_05.isdn \ + tones_efi/number_06.isdn \ + tones_efi/number_07.isdn \ + tones_efi/number_08.isdn \ + tones_efi/number_09.isdn + +tones_german = \ + tones_german/activated_loop.isdn \ + tones_german/busy_loop.isdn \ + tones_german/cause_01_loop.isdn \ + tones_german/cause_02_loop.isdn \ + tones_german/cause_03_loop.isdn \ + tones_german/cause_05_loop.isdn \ + tones_german/cause_06_loop.isdn \ + tones_german/cause_12_loop.isdn \ + tones_german/cause_13_loop.isdn \ + tones_german/cause_14_loop.isdn \ + tones_german/cause_15_loop.isdn \ + tones_german/cause_16_loop.isdn \ + tones_german/cause_1b_loop.isdn \ + tones_german/cause_1c_loop.isdn \ + tones_german/cause_1d_loop.isdn \ + tones_german/cause_1f_loop.isdn \ + tones_german/cause_22_loop.isdn \ + tones_german/cause_26_loop.isdn \ + tones_german/cause_29_loop.isdn \ + tones_german/cause_2a_loop.isdn \ + tones_german/cause_2f_loop.isdn \ + tones_german/cause_31_loop.isdn \ + tones_german/cause_32_loop.isdn \ + tones_german/cause_39_loop.isdn \ + tones_german/cause_3a_loop.isdn \ + tones_german/cause_3f_loop.isdn \ + tones_german/cause_41_loop.isdn \ + tones_german/cause_42_loop.isdn \ + tones_german/cause_45_loop.isdn \ + tones_german/cause_46_loop.isdn \ + tones_german/cause_55_loop.isdn \ + tones_german/cause_80_loop.isdn \ + tones_german/cause_81_loop.isdn \ + tones_german/cause_82_loop.isdn \ + tones_german/cause_83_loop.isdn \ + tones_german/cause_84_loop.isdn \ + tones_german/cause_85_loop.isdn \ + tones_german/cause_86_loop.isdn \ + tones_german/cause_87_loop.isdn \ + tones_german/deactivated_loop.isdn \ + tones_german/dialpbx_loop.isdn \ + tones_german/dialtone_loop.isdn \ + tones_german/error_loop.isdn \ + tones_german/password_loop.isdn \ + tones_german/redial.isdn \ + tones_german/release_loop.isdn \ + tones_german/ringing.isdn \ + tones_german/ringing_loop.isdn \ + tones_german/ringpbx_loop.isdn \ + tones_german/test_loop.isdn + +vbox_english = \ + vbox_english/call_anonymous.isdn \ + vbox_english/call_from.isdn \ + vbox_english/day_01.isdn \ + vbox_english/day_02.isdn \ + vbox_english/day_03.isdn \ + vbox_english/day_04.isdn \ + vbox_english/day_05.isdn \ + vbox_english/day_06.isdn \ + vbox_english/day_07.isdn \ + vbox_english/day_08.isdn \ + vbox_english/day_09.isdn \ + vbox_english/day_10.isdn \ + vbox_english/day_11.isdn \ + vbox_english/day_12.isdn \ + vbox_english/day_13.isdn \ + vbox_english/day_14.isdn \ + vbox_english/day_15.isdn \ + vbox_english/day_16.isdn \ + vbox_english/day_17.isdn \ + vbox_english/day_18.isdn \ + vbox_english/day_19.isdn \ + vbox_english/day_20.isdn \ + vbox_english/day_21.isdn \ + vbox_english/day_22.isdn \ + vbox_english/day_23.isdn \ + vbox_english/day_24.isdn \ + vbox_english/day_25.isdn \ + vbox_english/day_26.isdn \ + vbox_english/day_27.isdn \ + vbox_english/day_28.isdn \ + vbox_english/day_29.isdn \ + vbox_english/day_30.isdn \ + vbox_english/day_31.isdn \ + vbox_english/delete_ask.isdn \ + vbox_english/delete_done.isdn \ + vbox_english/intro.isdn \ + vbox_english/menu.isdn \ + vbox_english/minute.isdn \ + vbox_english/minutes.isdn \ + vbox_english/month_01.isdn \ + vbox_english/month_02.isdn \ + vbox_english/month_03.isdn \ + vbox_english/month_04.isdn \ + vbox_english/month_05.isdn \ + vbox_english/month_06.isdn \ + vbox_english/month_07.isdn \ + vbox_english/month_08.isdn \ + vbox_english/month_09.isdn \ + vbox_english/month_10.isdn \ + vbox_english/month_11.isdn \ + vbox_english/month_12.isdn \ + vbox_english/nothing.isdn \ + vbox_english/number_00.isdn \ + vbox_english/number_01.isdn \ + vbox_english/number_02.isdn \ + vbox_english/number_03.isdn \ + vbox_english/number_04.isdn \ + vbox_english/number_05.isdn \ + vbox_english/number_06.isdn \ + vbox_english/number_07.isdn \ + vbox_english/number_08.isdn \ + vbox_english/number_09.isdn \ + vbox_english/number_10.isdn \ + vbox_english/number_11.isdn \ + vbox_english/number_12.isdn \ + vbox_english/number_13.isdn \ + vbox_english/number_14.isdn \ + vbox_english/number_15.isdn \ + vbox_english/number_16.isdn \ + vbox_english/number_17.isdn \ + vbox_english/number_18.isdn \ + vbox_english/number_19.isdn \ + vbox_english/number_20.isdn \ + vbox_english/number_21.isdn \ + vbox_english/number_22.isdn \ + vbox_english/number_23.isdn \ + vbox_english/number_24.isdn \ + vbox_english/number_25.isdn \ + vbox_english/number_26.isdn \ + vbox_english/number_27.isdn \ + vbox_english/number_28.isdn \ + vbox_english/number_29.isdn \ + vbox_english/number_30.isdn \ + vbox_english/number_31.isdn \ + vbox_english/number_32.isdn \ + vbox_english/number_33.isdn \ + vbox_english/number_34.isdn \ + vbox_english/number_35.isdn \ + vbox_english/number_36.isdn \ + vbox_english/number_37.isdn \ + vbox_english/number_38.isdn \ + vbox_english/number_39.isdn \ + vbox_english/number_40.isdn \ + vbox_english/number_41.isdn \ + vbox_english/number_42.isdn \ + vbox_english/number_43.isdn \ + vbox_english/number_44.isdn \ + vbox_english/number_45.isdn \ + vbox_english/number_46.isdn \ + vbox_english/number_47.isdn \ + vbox_english/number_48.isdn \ + vbox_english/number_49.isdn \ + vbox_english/number_50.isdn \ + vbox_english/number_51.isdn \ + vbox_english/number_52.isdn \ + vbox_english/number_53.isdn \ + vbox_english/number_54.isdn \ + vbox_english/number_55.isdn \ + vbox_english/number_56.isdn \ + vbox_english/number_57.isdn \ + vbox_english/number_58.isdn \ + vbox_english/number_59.isdn \ + vbox_english/oclock_am.isdn \ + vbox_english/oclock_pm.isdn \ + vbox_english/pause.isdn \ + vbox_english/play.isdn \ + vbox_english/record_ask.isdn \ + vbox_english/record_play.isdn \ + vbox_english/record_record.isdn \ + vbox_english/store_ask.isdn \ + vbox_english/store_done.isdn + +vbox_german = \ + vbox_german/call_anonymous.isdn \ + vbox_german/call_from.isdn \ + vbox_german/day_01.isdn \ + vbox_german/day_02.isdn \ + vbox_german/day_03.isdn \ + vbox_german/day_04.isdn \ + vbox_german/day_05.isdn \ + vbox_german/day_06.isdn \ + vbox_german/day_07.isdn \ + vbox_german/day_08.isdn \ + vbox_german/day_09.isdn \ + vbox_german/day_10.isdn \ + vbox_german/day_11.isdn \ + vbox_german/day_12.isdn \ + vbox_german/day_13.isdn \ + vbox_german/day_14.isdn \ + vbox_german/day_15.isdn \ + vbox_german/day_16.isdn \ + vbox_german/day_17.isdn \ + vbox_german/day_18.isdn \ + vbox_german/day_19.isdn \ + vbox_german/day_20.isdn \ + vbox_german/day_21.isdn \ + vbox_german/day_22.isdn \ + vbox_german/day_23.isdn \ + vbox_german/day_24.isdn \ + vbox_german/day_25.isdn \ + vbox_german/day_26.isdn \ + vbox_german/day_27.isdn \ + vbox_german/day_28.isdn \ + vbox_german/day_29.isdn \ + vbox_german/day_30.isdn \ + vbox_german/day_31.isdn \ + vbox_german/delete_ask.isdn \ + vbox_german/delete_done.isdn \ + vbox_german/intro.isdn \ + vbox_german/menu.isdn \ + vbox_german/minute.isdn \ + vbox_german/minutes.isdn \ + vbox_german/month_01.isdn \ + vbox_german/month_02.isdn \ + vbox_german/month_03.isdn \ + vbox_german/month_04.isdn \ + vbox_german/month_05.isdn \ + vbox_german/month_06.isdn \ + vbox_german/month_07.isdn \ + vbox_german/month_08.isdn \ + vbox_german/month_09.isdn \ + vbox_german/month_10.isdn \ + vbox_german/month_11.isdn \ + vbox_german/month_12.isdn \ + vbox_german/nothing.isdn \ + vbox_german/number_00.isdn \ + vbox_german/number_01.isdn \ + vbox_german/number_02.isdn \ + vbox_german/number_03.isdn \ + vbox_german/number_04.isdn \ + vbox_german/number_05.isdn \ + vbox_german/number_06.isdn \ + vbox_german/number_07.isdn \ + vbox_german/number_08.isdn \ + vbox_german/number_09.isdn \ + vbox_german/number_10.isdn \ + vbox_german/number_11.isdn \ + vbox_german/number_12.isdn \ + vbox_german/number_13.isdn \ + vbox_german/number_14.isdn \ + vbox_german/number_15.isdn \ + vbox_german/number_16.isdn \ + vbox_german/number_17.isdn \ + vbox_german/number_18.isdn \ + vbox_german/number_19.isdn \ + vbox_german/number_20.isdn \ + vbox_german/number_21.isdn \ + vbox_german/number_22.isdn \ + vbox_german/number_23.isdn \ + vbox_german/number_24.isdn \ + vbox_german/number_25.isdn \ + vbox_german/number_26.isdn \ + vbox_german/number_27.isdn \ + vbox_german/number_28.isdn \ + vbox_german/number_29.isdn \ + vbox_german/number_30.isdn \ + vbox_german/number_31.isdn \ + vbox_german/number_32.isdn \ + vbox_german/number_33.isdn \ + vbox_german/number_34.isdn \ + vbox_german/number_35.isdn \ + vbox_german/number_36.isdn \ + vbox_german/number_37.isdn \ + vbox_german/number_38.isdn \ + vbox_german/number_39.isdn \ + vbox_german/number_40.isdn \ + vbox_german/number_41.isdn \ + vbox_german/number_42.isdn \ + vbox_german/number_43.isdn \ + vbox_german/number_44.isdn \ + vbox_german/number_45.isdn \ + vbox_german/number_46.isdn \ + vbox_german/number_47.isdn \ + vbox_german/number_48.isdn \ + vbox_german/number_49.isdn \ + vbox_german/number_50.isdn \ + vbox_german/number_51.isdn \ + vbox_german/number_52.isdn \ + vbox_german/number_53.isdn \ + vbox_german/number_54.isdn \ + vbox_german/number_55.isdn \ + vbox_german/number_56.isdn \ + vbox_german/number_57.isdn \ + vbox_german/number_58.isdn \ + vbox_german/number_59.isdn \ + vbox_german/number_eine.isdn \ + vbox_german/number_ein.isdn \ + vbox_german/oclock.isdn \ + vbox_german/pause.isdn \ + vbox_german/play.isdn \ + vbox_german/record_ask.isdn \ + vbox_german/record_play.isdn \ + vbox_german/record_record.isdn \ + vbox_german/store_ask.isdn \ + vbox_german/store_done.isdn diff --git a/NEWS b/NEWS new file mode 100644 index 0000000..e69de29 diff --git a/acinclude.m4 b/acinclude.m4 new file mode 100644 index 0000000..816bd1f --- /dev/null +++ b/acinclude.m4 @@ -0,0 +1,797 @@ + + + +dnl ------------------------------------------------------------------------ +dnl create a small program to test the settings of mISDNuser package +dnl ------------------------------------------------------------------------ +# ported from the KDE project +AC_DEFUN([PBX_PRINT_MISDNUSER_PROGRAM], +[ +cat > conftest.$ac_ext < +#include +#ifdef __cplusplus +} +#endif + +int main() +{ + /* TODO: try to reference some function here */ + return 0; +} +EOF +]) + +dnl ------------------------------------------------------------------------ +dnl create a small program to test the settings of mISDN package +dnl ------------------------------------------------------------------------ +# ported from the KDE project +AC_DEFUN([PBX_PRINT_MISDNKERNEL_PROGRAM], +[ +cat > conftest.$ac_ext < +#include +#include +#ifdef __cplusplus +} +#endif + +#define MISDN_MAJOR_VERSION_TEST $misdn_kernel_major_version_demand +#define MISDN_MINOR_VERSION_TEST $misdn_kernel_minor_version_demand +#define MISDN_VERSION_TEST ((MISDN_MAJOR_VERSION_TEST<<16) | MISDN_MINOR_VERSION_TEST) +//#define MISDN_VERSION ((MISDN_MAJOR_VERSION<<16) | MISDN_MINOR_VERSION) + +#if (MISDN_VERSION < MISDN_VERSION_TEST) +# error mISDN version mismatch. Need at least $misdn_kernel_major_version_demand.$misdn_kernel_minor_version_demand +#endif + + +int main() +{ + static u16 sum1; + /* access some constants from misdn kernel headers */ + u16 v1 = CMX_TXDATA_ON; + u16 v2 = CMX_TXDATA_OFF; + u16 v3 = CMX_DELAY; + u16 v4 = CMX_TX_DATA; + u16 v5 = CMX_JITTER; + + /* extend here more variables or function call + * to access more header information */ + + + /* anti optimisation constuct */ + sum1 = v1 + v2 + v3 + v4 + v5; + + return 0; +} +EOF +]) + + + +dnl prints a program. +dnl $1 is the include file +dnl $2 is the prefix before include +dnl $3 is the suffix, e.g. some variable or class definitions +dnl $4 is the program body within main() +AC_DEFUN([PBX_PRINT_PROGRAM], +[AC_LANG_PROGRAM([$2 +$1 + +$3], +[$4]) +]) + + + +dnl ------------------------------------------------------------------------ +dnl if --enable-debug, it disables optimisation and enables debugging symbols +dnl if --disable-debug (default) other way around +dnl ------------------------------------------------------------------------ +AC_DEFUN([AC_CHECK_COMPILERS], +[# taken from KDE project + + # enable debugging options on demand + DEBUGGING= + AC_ARG_ENABLE([debug], + [AS_HELP_STRING([--enable-debug], + [enable debugging symbols, turns off compiler optimisations (default=disable)]) + ], + [use_debug_code="yes"], + [use_debug_code="no"] + ) + AM_CONDITIONAL(ENABLE_DEBUGGING, test "x$DEBUGGING" == "xyes" ) + AC_ARG_ENABLE(dummyoption, + AC_HELP_STRING([--disable-debug], + [disables debugging symbols, turns on compiler optimisations]), + [:], + [:] + ) + + dnl this prevents stupid AC_PROG_CC to add "-g" to the default CFLAGS + CFLAGS=" $CFLAGS" + AC_PROG_CC + AC_PROG_CPP + + if test "$GCC" = "yes" ; then + if test "$use_debug_code" != "no"; then + CFLAGS="-g -O0 $CFLAGS" + else + CFLAGS="-O2 $CFLAGS" + fi + fi + + if test -z "$LDFLAGS" && test "$use_debug_code" = "no" && test "$GCC" = "yes"; then + LDFLAGS="" + fi + + CXXFLAGS=" $CXXFLAGS" + AC_PROG_CXX + + if test "$GXX" = "yes" ; then + if test "$use_debug_code" != "no"; then + CXXFLAGS="-g -O0 $CXXFLAGS" + else + CXXFLAGS="-O2 $CXXFLAGS" + fi + fi + +]) + + +dnl ------------------------------------------------------------------------ +dnl Try to find the mISDN-user headers and libraries. +dnl $(MISDN_LDFLAGS) will be -Lmisdnliblocation (if needed) +dnl and $(MISDN_INCLUDES) will be -Imisdnhdrlocation (if needed) +dnl ------------------------------------------------------------------------ +dnl +AC_DEFUN([AC_PATH_MISDNUSER], +[ +dnl AC_REQUIRE([K_PATH_X]) +dnl AC_REQUIRE([KDE_USE_MISDN]) +dnl AC_REQUIRE([KDE_CHECK_LIB64]) + +dnl ------------------------------------------------------------------------ +dnl Add configure flag to enable linking to MT version of mISDN-user library. +dnl ------------------------------------------------------------------------ + +dnl AC_ARG_ENABLE( +dnl mt, +dnl AC_HELP_STRING([--disable-mt],[link to non-threaded mISDN-user (deprecated)]), +dnl pbx_use_misdn_mt=$enableval, +dnl [ +dnl if test $pbx_misdnver = 3; then +dnl pbx_use_misdn_mt=yes +dnl else +dnl pbx_use_misdn_mt=no +dnl fi +dnl ] +dnl ) + +dnl USING_MISDN_MT="" + +dnl ------------------------------------------------------------------------ +dnl If we not get --disable-misdn-mt then adjust some vars for the host. +dnl ------------------------------------------------------------------------ + +dnl KDE_MT_LDFLAGS= +dnl KDE_MT_LIBS= +dnl if test "x$pbx_use_misdn_mt" = "xyes"; then +dnl KDE_CHECK_THREADING +dnl if test "x$pbx_use_threading" = "xyes"; then +dnl CPPFLAGS="$USE_THREADS -DMISDN_THREAD_SUPPORT $CPPFLAGS" +dnl KDE_MT_LDFLAGS="$USE_THREADS" +dnl KDE_MT_LIBS="$LIBPTHREAD" +dnl else +dnl pbx_use_misdn_mt=no +dnl fi +dnl fi +dnl AC_SUBST(KDE_MT_LDFLAGS) +dnl AC_SUBST(KDE_MT_LIBS) + +dnl pbx_misdn_was_given=yes + +dnl ------------------------------------------------------------------------ +dnl If we haven't been told how to link to mISDN-user, we work it out for ourselves. +dnl ------------------------------------------------------------------------ +dnl if test -z "$LIBMISDN_GLOB"; then +dnl if test "x$pbx_use_misdn_emb" = "xyes"; then +dnl LIBMISDN_GLOB="libmisdne.*" +dnl else +dnl LIBMISDN_GLOB="libmisdn.*" +dnl fi +dnl fi + +dnl ------------------------------------------------------------ +dnl If we got --enable-embedded then adjust the mISDN-user library name. +dnl ------------------------------------------------------------ +dnl if test "x$pbx_use_misdn_emb" = "xyes"; then +dnl misdnlib="misdne" +dnl else + misdnlib="mISDN" +dnl fi + +dnl pbx_int_misdn="-l$misdnlib" + +dnl if test -z "$LIBQPE"; then +dnl ------------------------------------------------------------ +dnl If we got --enable-palmtop then add -lqpe to the link line +dnl ------------------------------------------------------------ +dnl if test "x$pbx_use_misdn_emb" = "xyes"; then +dnl if test "x$pbx_use_misdn_emb_palm" = "xyes"; then +dnl LIB_QPE="-lqpe" +dnl else +dnl LIB_QPE="" +dnl fi +dnl else +dnl LIB_QPE="" +dnl fi +dnl fi + +dnl ------------------------------------------------------------------------ +dnl If we got --enable-misdn-mt then adjust the mISDN-user library name for the host. +dnl ------------------------------------------------------------------------ + +dnl if test "x$pbx_use_misdn_mt" = "xyes"; then +dnl LIBMISDN="-l$misdnlib-mt" +dnl pbx_int_misdn="-l$misdnlib-mt" +dnl LIBMISDN_GLOB="lib$misdnlib-mt.*" +dnl USING_MISDN_MT="using -mt" +dnl else +dnl LIBMISDN="-l$misdnlib" +dnl fi + +dnl if test $pbx_misdnver != 1; then + +dnl AC_REQUIRE([AC_FIND_PNG]) +dnl AC_REQUIRE([AC_FIND_JPEG]) +dnl LIBMISDN="$LIBMISDN $LIBPNG $LIBJPEG" +dnl fi + +dnl if test $pbx_misdnver = 3; then +dnl AC_REQUIRE([KDE_CHECK_LIBDL]) +dnl LIBMISDN="$LIBMISDN $LIBDL" +dnl fi + +dnl probably there could be a whole installation of misdn +pbx_misdn_dirs="/usr/local/mISDNuser /usr/local/misdn /usr/lib/mISDNuser /usr/lib/misdn" + + +AC_MSG_CHECKING([for mISDN-user]) +LIBMISDN="-l$misdnlib -lisdnnet" + +dnl if test "x$pbx_use_misdn_emb" != "xyes" && test "x$pbx_use_misdn_mac" != "xyes"; then +dnl LIBMISDN="$LIBMISDN $X_PRE_LIBS -lXext -lX11 $LIBSM $LIBSOCKET" +dnl fi +ac_misdnuser_includes=NO ac_misdnuser_libraries=NO ac_misdnuser_bindir=NO +misdnuser_libraries="" +misdnuser_includes="" +AC_ARG_WITH(misdnuser-dir, + AC_HELP_STRING([--with-misdnuser-dir=DIR],[where the root of mISDN-user is installed]), + [ ac_misdnuser_includes="$withval"/include + ac_misdnuser_libraries="$withval"/lib + ac_misdnuser_bindir="$withval"/bin + ]) + +AC_ARG_WITH(misdnuser-includes, + AC_HELP_STRING([--with-misdnuser-includes=DIR],[where the mISDN-user includes are (default=$with-misdnuser-dir/include)]), + [ + ac_misdnuser_includes="$withval" + ]) + +pbx_misdn_libs_given=no + +AC_ARG_WITH(misdnuser-libraries, + AC_HELP_STRING([--with-misdnuser-libraries=DIR],[where the mISDN-user library is installed (default=$with-misdnuser-dir/lib)]), + [ ac_misdnuser_libraries="$withval" + pbx_misdn_libs_given=yes + ]) + +AC_CACHE_VAL(ac_cv_have_misdn, +[#try to guess mISDN-user locations + +misdn_incdirs="" +for dir in $pbx_misdn_dirs; do + misdn_incdirs="$misdn_incdirs $dir/include $dir" +done +misdn_incdirs="$MISDNINC $misdn_incdirs /usr/include/mISDNuser /usr/include/misdn /usr/include" +if test ! "$ac_misdnuser_includes" = "NO"; then + misdn_incdirs="$ac_misdnuser_includes $misdn_incdirs" +fi + +dnl if test "$pbx_misdnver" != "1"; then + pbx_misdn_header=mISDNlib.h +dnl -> und auch "isdn_net.h" +dnl else +dnl pbx_misdn_header=qglobal.h +dnl fi + +AC_FIND_FILE($pbx_misdn_header, $misdn_incdirs, misdn_incdir) +ac_misdnuser_includes="$misdn_incdir" + +misdn_libdirs="" +for dir in $pbx_misdn_dirs; do + misdn_libdirs="$misdn_libdirs $dir/lib $dir" +done +misdn_libdirs="$MISDNLIB $misdn_libdirs /usr/lib /usr/local/lib" +if test ! "$ac_misdnuser_libraries" = "NO"; then + misdn_libdir=$ac_misdnuser_libraries +else + misdn_libdirs="$ac_misdnuser_libraries $misdn_libdirs" + # if the mISDN-user was given, the chance is too big that libmisdn.* doesn't exist + misdn_libdir=NONE + for dir in $misdn_libdirs; do + try="ls -1 $dir/${LIBMISDN_GLOB}" + if test -n "`$try 2> /dev/null`"; then misdn_libdir=$dir; break; else echo "tried $dir" >&AC_FD_CC ; fi + done +fi +for a in $misdn_libdir/lib`echo ${pbx_int_misdn} | sed 's,^-l,,'`_incremental.*; do + if test -e "$a"; then + LIBMISDN="$LIBMISDN ${pbx_int_misdn}_incremental" + break + fi +done + +ac_misdnuser_libraries="$misdn_libdir" + +AC_LANG_SAVE +AC_LANG_CPLUSPLUS + +ac_cxxflags_safe="$CXXFLAGS" +ac_ldflags_safe="$LDFLAGS" +ac_libs_safe="$LIBS" + +CXXFLAGS="$CXXFLAGS -I$misdn_incdir $all_includes" +LDFLAGS="$LDFLAGS -L$misdn_libdir $all_libraries $USER_LDFLAGS" +LIBS="$LIBS $LIBMISDN" + +PBX_PRINT_MISDNUSER_PROGRAM + +if AC_TRY_EVAL(ac_link) && test -s conftest; then + rm -f conftest* +else + echo "configure: failed program was:" >&AC_FD_CC + cat conftest.$ac_ext >&AC_FD_CC + ac_misdnuser_libraries="NO" +fi +rm -f conftest* +CXXFLAGS="$ac_cxxflags_safe" +LDFLAGS="$ac_ldflags_safe" +LIBS="$ac_libs_safe" + +AC_LANG_RESTORE +if test "$ac_misdnuser_includes" = NO || test "$ac_misdnuser_libraries" = NO; then + ac_cv_have_misdn="have_misdn=no" + ac_misdnuser_notfound="" + missing_misdn_mt="" + if test "$ac_misdnuser_includes" = NO; then + if test "$ac_misdnuser_libraries" = NO; then + ac_misdnuser_notfound="(headers and libraries)"; + else + ac_misdnuser_notfound="(headers)"; + fi + else +dnl if test "x$pbx_use_misdn_mt" = "xyes"; then +dnl missing_misdn_mt="Make sure that you have compiled mISDN-user with thread support!" +dnl ac_misdnuser_notfound="(library $misdnlib-mt)"; +dnl else + ac_misdnuser_notfound="(library $misdnlib)"; +dnl fi + fi + + AC_MSG_ERROR([mISDN-user ($pbx_misdn_minversion) $ac_misdnuser_notfound not found. Please check your installation! +For more details about this problem, look at the end of config.log.$missing_misdn_mt]) +else + have_misdn="yes" +fi +]) + + +eval "$ac_cv_have_misdn" + +if test "$have_misdn" != yes; then + AC_MSG_RESULT([$have_misdn]); +else + ac_cv_have_misdn="have_misdn=yes \ + ac_misdnuser_includes=$ac_misdnuser_includes ac_misdnuser_libraries=$ac_misdnuser_libraries" + AC_MSG_RESULT([libraries $ac_misdnuser_libraries, headers $ac_misdnuser_includes $USING_MISDN_MT]) + + misdnuser_libraries="$ac_misdnuser_libraries" + misdnuser_includes="$ac_misdnuser_includes" +fi + +dnl if test ! "$pbx_misdn_libs_given" = "yes" && test ! "$pbx_misdnver" = 3; then +dnl KDE_CHECK_MISDN_DIRECT(misdnuser_libraries= ,[]) +dnl fi + +AC_SUBST(misdnuser_libraries) +AC_SUBST(misdnuser_includes) + +if test -z "$misdnuser_includes"; then + MISDN_INCLUDES="" +else + MISDN_INCLUDES="-I$misdnuser_includes" + all_includes="$MISDN_INCLUDES $all_includes" +fi + +if test -z "$misdnuser_libraries"; then + MISDN_LDFLAGS="" +else + MISDN_LDFLAGS="-L$misdnuser_libraries" + all_libraries="$MISDN_LDFLAGS $all_libraries" +fi +dnl test -z "$KDE_MT_LDFLAGS" || all_libraries="$all_libraries $KDE_MT_LDFLAGS" + +AC_SUBST(MISDN_INCLUDES) +AC_SUBST(MISDN_LDFLAGS) +dnl AC_PATH_MISDN_MOC_UIC + +dnl KDE_CHECK_MISDN_JPEG + +dnl if test "x$pbx_use_misdn_emb" != "xyes" && test "x$pbx_use_misdn_mac" != "xyes"; then +dnl LIB_MISDN="$pbx_int_misdn $LIBJPEG_MISDN "'$(LIBZ) $(LIBPNG) -lXext $(LIB_X11) $(LIBSM)' +dnl else +dnl LIB_MISDN="$pbx_int_misdn $LIBJPEG_MISDN "'$(LIBZ) $(LIBPNG)' +dnl fi +dnl test -z "$KDE_MT_LIBS" || LIB_MISDN="$LIB_MISDN $KDE_MT_LIBS" +dnl for a in $misdn_libdir/lib`echo ${pbx_int_misdn} | sed 's,^-l,,'`_incremental.*; do +dnl if test -e "$a"; then +dnl LIB_MISDN="$LIB_MISDN ${pbx_int_misdn}_incremental" +dnl break +dnl fi +dnl done + +AC_SUBST(LIB_MISDN) +dnl AC_SUBST(LIB_QPE) + +AC_SUBST(pbx_misdnver) + +]) + + + +dnl ------------------------------------------------------------------------ +dnl Try to find the mISDN-kernel headers. +dnl $(MISDNKERNEL_INCLUDES) will be -Imisdnkernelhdrlocation (if needed) +dnl ------------------------------------------------------------------------ +dnl +AC_DEFUN([AC_PATH_MISDNKERNEL], +[ + + misdnlib="mISDN" +misdn_kernel_major_version_demand=6 +misdn_kernel_minor_version_demand=0 +lcr_misdn_kernel_minversion=$misdn_kernel_major_version_demand.$misdn_kernel_minor_version_demand + +dnl ## TODO !! convert misdnuser variables to misdn kernel header variables + +dnl probably there could be a whole installation of misdn +kernel_ver=$(uname -r) +misdn_kernelheader_dirs="/lib/modules/$kernel_ver/source/include /usr/src/linux/include/" + + +AC_MSG_CHECKING([for mISDN-kernel]) +dnl LIBMISDN="-l$misdnlib -lisdnnet" +dnl +dnl if test "x$pbx_use_misdn_emb" != "xyes" && test "x$pbx_use_misdn_mac" != "xyes"; then +dnl LIBMISDN="$LIBMISDN $X_PRE_LIBS -lXext -lX11 $LIBSM $LIBSOCKET" +dnl fi +dnl ac_misdnkernel_includes=NO ac_misdnkernel_libraries=NO ac_misdnkernel_bindir=NO +ac_misdnkernel_includes=NO +dnl misdnkernel_libraries="" +misdnkernel_includes="" +dnl AC_ARG_WITH(misdnkernel-dir, +dnl AC_HELP_STRING([--with-misdnkernel-dir=DIR],[where the mISDN-headers are installed ]), +dnl [ ac_misdnkernel_includes="$withval"/include +dnl ac_misdnkernel_libraries="$withval"/lib +dnl ac_misdnkernel_bindir="$withval"/bin +dnl ]) + +AC_ARG_WITH(misdnkernel-includes, + AC_HELP_STRING([--with-misdnkernel-includes=DIR],[where the mISDN-kernel includes are. Used if enable-socket-misdn]), + [ + ac_misdnkernel_includes="$withval" + ]) + +dnl pbx_misdn_libs_given=no + +dnl AC_ARG_WITH(misdnkernel-libraries, +dnl AC_HELP_STRING([--with-misdnkernel-libraries=DIR],[where the mISDN-kernel library is installed.]), +dnl [ ac_misdnkernel_libraries="$withval" +dnl pbx_misdn_libs_given=yes +dnl ]) + +AC_CACHE_VAL(ac_cv_have_misdnkernel, +[#try to guess mISDN-user locations + +misdnkernel_incdirs="" +for dir in $misdn_kernelheader_dirs; do + misdnkernel_incdirs="$misdnkernel_incdirs $dir/include $dir" +done +misdnkernel_incdirs="$MISDNKERNELINC $misdnkernel_incdirs /usr/include/mISDNuser /usr/include/misdn /usr/include" +if test ! "$ac_misdnkernel_includes" = "NO"; then + misdnkernel_incdirs="$ac_misdnkernel_includes $misdnkernel_incdirs" +fi + + pbx_misdn_kernel_header=linux/mISDNif.h + +AC_FIND_FILE($pbx_misdn_kernel_header, $misdnkernel_incdirs, misdnkernel_incdir) +ac_misdnkernel_includes="$misdnkernel_incdir" + +dnl misdn_libdirs="" +dnl for dir in $misdn_kernelheader_dirs; do +dnl misdn_libdirs="$misdn_libdirs $dir/lib $dir" +dnl done +dnl misdn_libdirs="$MISDNLIB $misdn_libdirs /usr/lib /usr/local/lib" +dnl if test ! "$ac_misdnkernel_libraries" = "NO"; then +dnl misdn_libdir=$ac_misdnkernel_libraries +dnl else +dnl misdn_libdirs="$ac_misdnkernel_libraries $misdn_libdirs" +dnl # if the mISDN-user was given, the chance is too big that libmisdn.* doesn't exist +dnl misdn_libdir=NONE +dnl for dir in $misdn_libdirs; do +dnl try="ls -1 $dir/${LIBMISDN_GLOB}" +dnl if test -n "`$try 2> /dev/null`"; then misdn_libdir=$dir; break; else echo "tried $dir" >&AC_FD_CC ; fi +dnl done +dnl fi +dnl for a in $misdn_libdir/lib`echo ${pbx_int_misdn} | sed 's,^-l,,'`_incremental.*; do +dnl if test -e "$a"; then +dnl LIBMISDN="$LIBMISDN ${pbx_int_misdn}_incremental" +dnl break +dnl fi +dnl done +dnl +dnl ac_misdnkernel_libraries="$misdn_libdir" +dnl +AC_LANG_SAVE +AC_LANG_CPLUSPLUS + +ac_cxxflags_safe="$CXXFLAGS" +ac_ldflags_safe="$LDFLAGS" +ac_libs_safe="$LIBS" + +CXXFLAGS="$CXXFLAGS -I$misdnkernel_incdir $all_includes" +LDFLAGS="$LDFLAGS -L$misdn_libdir $all_libraries $USER_LDFLAGS" +LIBS="$LIBS $LIBMISDN" + +PBX_PRINT_MISDNKERNEL_PROGRAM + +if AC_TRY_EVAL(ac_compile) && test -s conftest.o; then + rm -f conftest* +else + echo "configure: failed program was:" >&AC_FD_CC + cat conftest.$ac_ext >&AC_FD_CC + ac_misdnkernel_includes="NO" +dnl ac_misdnkernel_libraries="NO" +fi +rm -f conftest* +CXXFLAGS="$ac_cxxflags_safe" +LDFLAGS="$ac_ldflags_safe" +LIBS="$ac_libs_safe" + +AC_LANG_RESTORE +dnl if test "$ac_misdnkernel_includes" = NO || test "$ac_misdnkernel_libraries" = NO; then +if test "$ac_misdnkernel_includes" = NO; then + ac_cv_have_misdnkernel="have_misdnkernel=no" + ac_misdnkernel_notfound="" + missing_misdn_mt="" +dnl if test "$ac_misdnkernel_includes" = NO; then +dnl if test "$ac_misdnkernel_libraries" = NO; then +dnl ac_misdnkernel_notfound="(headers and libraries)"; +dnl else + ac_misdnkernel_notfound="(headers)"; +dnl fi +dnl else +dnl ac_misdnkernel_notfound="(library $misdnlib)"; +dnl fi + + AC_MSG_ERROR([mISDN kernel header (version >= $lcr_misdn_kernel_minversion) not found. Please check your installation! +For more details about this problem, look at the end of config.log.$missing_misdn_mt]) +else + have_misdnkernel="yes" +fi +]) + +dnl check cache content +dnl TODO: maybe move this to beginning (before compilation test?) +eval "$ac_cv_have_misdnkernel" + +if test "$have_misdnkernel" != yes; then + AC_MSG_RESULT([$have_misdnkernel]); +else + ac_cv_have_misdnkernel="have_misdnkernel=yes \ + ac_misdnkernel_includes=$ac_misdnkernel_includes" +dnl ac_misdnkernel_libraries=$ac_misdnkernel_libraries" + AC_MSG_RESULT([headers $ac_misdnkernel_includes]) + +dnl misdnkernel_libraries="$ac_misdnkernel_libraries" + misdnkernel_includes="$ac_misdnkernel_includes" +fi + +dnl if test ! "$pbx_misdn_libs_given" = "yes" && test ! "$pbx_misdnver" = 3; then +dnl KDE_CHECK_MISDN_DIRECT(misdnkernel_libraries= ,[]) +dnl fi + +dnl AC_SUBST(misdnkernel_libraries) +AC_SUBST(misdnkernel_includes) + +if test -z "$misdnkernel_includes"; then + MISDNKERNEL_INCLUDES="" +else + MISDNKERNEL_INCLUDES="-I$misdnkernel_includes" + all_includes="$MISDNKERNEL_INCLUDES $all_includes" +fi + +dnl if test -z "$misdnkernel_libraries"; then +dnl MISDN_LDFLAGS="" +dnl else +dnl MISDN_LDFLAGS="-L$misdnkernel_libraries" +dnl all_libraries="$MISDN_LDFLAGS $all_libraries" +dnl fi +dnl test -z "$KDE_MT_LDFLAGS" || all_libraries="$all_libraries $KDE_MT_LDFLAGS" + +AC_SUBST(MISDNKERNEL_INCLUDES) +dnl AC_SUBST(MISDN_LDFLAGS) +dnl AC_PATH_MISDN_MOC_UIC + +dnl KDE_CHECK_MISDN_JPEG + +dnl if test "x$pbx_use_misdn_emb" != "xyes" && test "x$pbx_use_misdn_mac" != "xyes"; then +dnl LIB_MISDN="$pbx_int_misdn $LIBJPEG_MISDN "'$(LIBZ) $(LIBPNG) -lXext $(LIB_X11) $(LIBSM)' +dnl else +dnl LIB_MISDN="$pbx_int_misdn $LIBJPEG_MISDN "'$(LIBZ) $(LIBPNG)' +dnl fi +dnl test -z "$KDE_MT_LIBS" || LIB_MISDN="$LIB_MISDN $KDE_MT_LIBS" +dnl for a in $misdn_libdir/lib`echo ${pbx_int_misdn} | sed 's,^-l,,'`_incremental.*; do +dnl if test -e "$a"; then +dnl LIB_MISDN="$LIB_MISDN ${pbx_int_misdn}_incremental" +dnl break +dnl fi +dnl done + +dnl AC_SUBST(LIB_MISDN) +dnl AC_SUBST(LIB_QPE) + +AC_SUBST(pbx_misdnver) + +]) + + + +dnl ------------------------------------------------------------------------ +dnl Find a file (or one of more files in a list of dirs) +dnl ------------------------------------------------------------------------ +AC_DEFUN([AC_FIND_FILE], +[ +$3=NO +for i in $2; +do + for j in $1; + do + echo "configure: __oline__: $i/$j" >&AC_FD_CC + if test -r "$i/$j"; then + echo "taking that" >&AC_FD_CC + $3=$i + break 2 + fi + done +done +]) + + + +dnl ------------------------------------------------------------------------ +dnl Taken from http://autoconf-archive.cryp.to/ac_define_dir.html +dnl Copyright © 2006 Stepan Kasal +dnl Copyright © 2006 Andreas Schwab +dnl Copyright © 2006 Guido U. Draheim +dnl Copyright © 2006 Alexandre Oliva +dnl Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright notice and this notice are preserved. +dnl +dnl This macro sets VARNAME to the expansion of the DIR variable, taking care +dnl of fixing up ${prefix} and such. +dnl ------------------------------------------------------------------------ +AC_DEFUN([AC_DEFINE_DIR], [ + prefix_NONE= + exec_prefix_NONE= + test "x$prefix" = xNONE && prefix_NONE=yes && prefix=$ac_default_prefix + test "x$exec_prefix" = xNONE && exec_prefix_NONE=yes && exec_prefix=$prefix +dnl In Autoconf 2.60, ${datadir} refers to ${datarootdir}, which in turn +dnl refers to ${prefix}. Thus we have to use `eval' twice. + eval ac_define_dir="\"[$]$2\"" + eval ac_define_dir="\"$ac_define_dir\"" + AC_SUBST($1, "$ac_define_dir") + AC_DEFINE_UNQUOTED($1, "$ac_define_dir", [$3]) + test "$prefix_NONE" && prefix=NONE + test "$exec_prefix_NONE" && exec_prefix=NONE +]) + + +dnl ------------------------------------------------------------------------ +dnl taken from http://autoconf-archive.cryp.to/ax_ext_check_header.html +dnl Copyright © 2005 Duncan Simpson +dnl Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright notice and this notice are preserved. +dnl +dnl Checks locations of headers in various places +dnl Extended by Jörg Habenicht +dnl ------------------------------------------------------------------------ +AC_DEFUN([AX_EXT_HAVE_HEADER], +[AC_LANG_PUSH(C) + AC_CHECK_HEADER($1, [$3 got="yes"], [$4 got="no"], [$5]) + hdr=`echo $1 | $as_tr_sh` + for dir in $2 + do + if test "x${got}" = "xno"; then + ext_hashdr_cvdir=`echo $dir | $as_tr_sh` + AC_CACHE_CHECK([for $1 header with -I$dir], + [ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}], + [ext_have_hdr_save_cflags=${CFLAGS} + CFLAGS="${CFLAGS} -I${dir}" + AC_COMPILE_IFELSE( + [AC_LANG_PROGRAM([#include <$1>])], + [got="yes"; eval "ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}"="yes"], + [got="no"; eval "ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}"="no"]) + CFLAGS=$ext_have_hdr_save_cflags]) + if eval `echo 'test x${'ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}'}' = "xyes"`; then + CFLAGS="${CFLAGS} -I${dir}" + CPPFLAGS="${CPPFLAGS} -I${dir}" + got="yes"; + hdr=`echo $1 | $as_tr_cpp` + AC_DEFINE_UNQUOTED(HAVE_${hdr}, 1, + [Define this if you have the $1 header]) + fi; + fi; + done +AC_LANG_POP]) + + +dnl ------------------------------------------------------------------------ +dnl taken from http://autoconf-archive.cryp.to/ax_ext_check_header.html +dnl Copyright © 2005 Duncan Simpson +dnl Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright notice and this notice are preserved. +dnl +dnl Checks locations of headers in various places +dnl Extended by Jörg Habenicht +dnl ------------------------------------------------------------------------ +dnl $1 include file name +dnl $2 directory list +dnl $3 action yes +dnl $4 action no +dnl $5 include prefix +dnl $6 include suffix +dnl $7 main() body content +AC_DEFUN([PBX_EXT_HAVE_CXX_HEADER], +[AC_LANG_PUSH(C++) + AC_CHECK_HEADER($1, [$3 got="yes"], [$4 got="no"], [$5]) + hdr=`echo $1 | $as_tr_sh` + for dir in $2 ; do + if test "x${got}" = "xno"; then + ext_hashdr_cvdir=`echo $dir | $as_tr_sh` + AC_CACHE_CHECK([for $1 header with -I$dir], + [ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}], + [ext_have_hdr_save_cxxflags=${CXXFLAGS} + CXXFLAGS="${CXXFLAGS} -I${dir}" + AC_COMPILE_IFELSE( + [PBX_PRINT_PROGRAM([#include <$1>],[$5],[$6],[$7])], + [$3 got="yes"; eval "ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}"="yes"], + [$4 got="no"; eval "ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}"="no"]) + CXXFLAGS=$ext_have_hdr_save_cxxflags]) + if eval `echo 'test x${'ext_cv${ext_hashdr_cvdir}_hashdr_${hdr}'}' = "xyes"`; then + CXXFLAGS="${CXXFLAGS} -I${dir}" + CPPFLAGS="${CPPFLAGS} -I${dir}" + got="yes"; + hdr=`echo $1 | $as_tr_cpp` + AC_DEFINE_UNQUOTED(HAVE_${hdr}, 1, + [Define this if you have the $1 header]) + fi; + fi; + done +AC_LANG_POP]) + diff --git a/autogen.sh b/autogen.sh new file mode 100644 index 0000000..f087399 --- /dev/null +++ b/autogen.sh @@ -0,0 +1,15 @@ +#!/bin/sh + + +# call autoconf, autoheader and automake +echo autoheader.. +autoheader || exit $? +echo aclocal.. +aclocal || exit $? +echo autoconf.. +autoconf || exit $? +echo automake.. +automake || exit $? + +#./configure +#make distcheck diff --git a/configure.ac b/configure.ac new file mode 100644 index 0000000..7249ad5 --- /dev/null +++ b/configure.ac @@ -0,0 +1,165 @@ +## -*- autoconf -*- + +dnl This file is part of linux-call-router +dnl Copyright (C) 2007 Joerg Habenicht (j.habenicht@gmx.de) + +dnl This program is free software; you can redistribute it and/or +dnl modify it under the terms of the GNU General Public License as +dnl published by the Free Software Foundation; either +dnl version 2 of the License, or (at your option) any later version. + +dnl This program is distributed in the hope that it will be useful, +dnl but WITHOUT ANY WARRANTY; without even the implied warranty of +dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +dnl GNU General Public License for more details. + +dnl You should have received a copy of the GNU General Public License +dnl along with this library; see the file COPYING. If not, write to +dnl the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, +dnl Boston, MA 02110-1301, USA. + + + +dnl This keeps being the first instruction. +dnl Change the 2nd argument if the version increases +dnl 1st + 2nd argument is used for distribution package name +AC_INIT(lcr, 0.1.20071001, pbx4linux@koeln.ccc.de) +AC_PREREQ(2.61) +AC_CONFIG_SRCDIR([main.c]) +AC_CONFIG_HEADER([config.h]) + +# fix warnings from autoconf + automake +AC_GNU_SOURCE +AC_USE_SYSTEM_EXTENSIONS +AM_INIT_AUTOMAKE([dist-bzip2]) + + + +# Checks for programs. +dnl AC_CHECK_COMPILERS contains AC_PROG_CC AC_PROG_CPP and AC_PROG_CXX +AC_CHECK_COMPILERS +dnl AC_PROG_CXX +dnl AC_PROG_CC +AC_PROG_INSTALL +AC_PROG_MAKE_SET +dnl required, if per binary CFLAGS are used +dnl AM_PROG_CC_C_O + + +# site specific configs +dnl enable this to have all special options on one place +dnl AC_PRESERVE_HELP_ORDER + +# enable socket access to misdn kernel module on demand +dnl SOCKET_MISDN= +AC_ARG_ENABLE([socket_misdn], + [AS_HELP_STRING([--enable-socket-misdn], + [use socket connection to misdn kernel code (default=disable)]) + ], + [use_misdn_socket="yes"], + [use_misdn_socket="no"] + ) +AM_CONDITIONAL(ENABLE_SOCKET_MISDN, test "x$use_misdn_socket" == "xyes" ) + +# check for asterisk +AC_ARG_WITH([asterisk], + [AS_HELP_STRING([--with-asterisk], + [compile with built-in Asterisk channel driver @<:@default=no@:>@]) + ], + [with_asterisk_channel_driver="yes"], + [with_asterisk_channel_driver="no"]) +AM_CONDITIONAL(ENABLE_ASTERISK_CHANNEL_DRIVER, test "x$with_asterisk_channel_driver" == "xyes" ) + +# check for crypto +AC_ARG_WITH([crypto], + [AS_HELP_STRING([--with-crypto], + [compile with lib Crypto support @<:@default=check@:>@]) + ], + [], + [with_crypto=check]) +LIBCRYPTO= +AS_IF([test "x$with_crypto" != xno], + [AC_CHECK_HEADERS([openssl/rsa.h]) + AC_CHECK_LIB([crypto], [main], + [AC_SUBST([LIBCRYPTO], ["-lcrypto"]) + AC_DEFINE([HAVE_LIBCRYPTO], [1], + [Define if you have libcrypto]) + ], + [if test "x$with_crypto" != xcheck ; then + AC_MSG_FAILURE( + [--with-crypto was given, but test for lib Crypto failed]) + fi + ], + -lcrypto + ) + ] + ) +AM_CONDITIONAL(WITH_CRYPTO, test "x$LIBCRYPTO" == "x-lcrypto" ) + +# check for isdn_net.h +# check for mISDNlib.h +# --with-isdn_net-include=, default: env MISDNUSER= , $include/mISDNuser + +# self written test for mISDNuser lib +AC_PATH_MISDNUSER + +# self written test for mISDN kernel header +AC_PATH_MISDNKERNEL + + + + +# Checks for libraries. +dnl FIXME: Replace `main' with a function in `-ldl': +dnl AC_CHECK_LIB([dl], [main]) +dnl FIXME: Replace `main' with a function in `-lh323_linux_x86_r': +dnl AC_CHECK_LIB([h323_linux_x86_r], [main]) +dnl FIXME: Replace `main' with a function in `-lisdnnet': +dnl AC_CHECK_LIB([isdnnet], [main]) +# FIXME: Replace `main' with a function in `-lm': +AC_CHECK_LIB([m], [main]) +dnl FIXME: Replace `main' with a function in `-lmISDN': +dnl AC_CHECK_LIB([mISDN], [main]) +# FIXME: Replace `main' with a function in `-lncurses': +AC_CHECK_LIB([ncurses], [main]) +dnl FIXME: Replace `main' with a function in `-lpt_linux_x86_r': +dnl AC_CHECK_LIB([pt_linux_x86_r], [main]) +# FIXME: Replace `main' with a function in `-lpthread': +AC_CHECK_LIB([pthread], [main]) + +# Checks for header files. +AC_HEADER_DIRENT +AC_HEADER_STDC +AC_HEADER_SYS_WAIT +AC_CHECK_HEADERS([fcntl.h netinet/in.h stdlib.h string.h sys/file.h sys/ioctl.h sys/socket.h sys/time.h unistd.h ctype.h assert.h]) +AC_HEADER_ASSERT + +# Checks for typedefs, structures, and compiler characteristics. +AC_HEADER_STDBOOL +AC_C_CONST +AC_C_INLINE +AC_TYPE_PID_T +AC_HEADER_TIME +AC_STRUCT_TM + +# Checks for library functions. +AC_FUNC_FORK +AC_PROG_GCC_TRADITIONAL +AC_FUNC_LSTAT +AC_FUNC_LSTAT_FOLLOWS_SLASHED_SYMLINK +AC_FUNC_MALLOC +AC_FUNC_MEMCMP +AC_TYPE_SIGNAL +AC_FUNC_STRNLEN +AC_FUNC_STRTOD +AC_FUNC_VPRINTF +AC_CHECK_FUNCS([gettimeofday memmove memset mkdir socket strcasecmp strchr strerror strncasecmp strstr strtol strtoul]) + +AC_SUBST(misdnuser_libraries) +AC_SUBST(misdnuser_includes) +AC_SUBST(misdnkernel_includes) +AC_SUBST(all_includes) +AC_SUBST(all_libraries) + +AC_CONFIG_FILES([Makefile]) +AC_OUTPUT diff --git a/depcomp b/depcomp new file mode 100755 index 0000000..ca5ea4e --- /dev/null +++ b/depcomp @@ -0,0 +1,584 @@ +#! /bin/sh +# depcomp - compile a program generating dependencies as side-effects + +scriptversion=2006-10-15.18 + +# Copyright (C) 1999, 2000, 2003, 2004, 2005, 2006 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 +# the Free Software Foundation; either version 2, 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, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA +# 02110-1301, USA. + +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +# Originally written by Alexandre Oliva . + +case $1 in + '') + echo "$0: No command. Try \`$0 --help' for more information." 1>&2 + exit 1; + ;; + -h | --h*) + cat <<\EOF +Usage: depcomp [--help] [--version] PROGRAM [ARGS] + +Run PROGRAMS ARGS to compile a file, generating dependencies +as side-effects. + +Environment variables: + depmode Dependency tracking mode. + source Source file read by `PROGRAMS ARGS'. + object Object file output by `PROGRAMS ARGS'. + DEPDIR directory where to store dependencies. + depfile Dependency file to output. + tmpdepfile Temporary file to use when outputing dependencies. + libtool Whether libtool is used (yes/no). + +Report bugs to . +EOF + exit $? + ;; + -v | --v*) + echo "depcomp $scriptversion" + exit $? + ;; +esac + +if test -z "$depmode" || test -z "$source" || test -z "$object"; then + echo "depcomp: Variables source, object and depmode must be set" 1>&2 + exit 1 +fi + +# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. +depfile=${depfile-`echo "$object" | + sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} +tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} + +rm -f "$tmpdepfile" + +# Some modes work just like other modes, but use different flags. We +# parameterize here, but still list the modes in the big case below, +# to make depend.m4 easier to write. Note that we *cannot* use a case +# here, because this file can only contain one case statement. +if test "$depmode" = hp; then + # HP compiler uses -M and no extra arg. + gccflag=-M + depmode=gcc +fi + +if test "$depmode" = dashXmstdout; then + # This is just like dashmstdout with a different argument. + dashmflag=-xM + depmode=dashmstdout +fi + +case "$depmode" in +gcc3) +## gcc 3 implements dependency tracking that does exactly what +## we want. Yay! Note: for some reason libtool 1.4 doesn't like +## it if -MD -MP comes after the -MF stuff. Hmm. +## Unfortunately, FreeBSD c89 acceptance of flags depends upon +## the command line argument order; so add the flags where they +## appear in depend2.am. Note that the slowdown incurred here +## affects only configure: in makefiles, %FASTDEP% shortcuts this. + for arg + do + case $arg in + -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; + *) set fnord "$@" "$arg" ;; + esac + shift # fnord + shift # $arg + done + "$@" + stat=$? + if test $stat -eq 0; then : + else + rm -f "$tmpdepfile" + exit $stat + fi + mv "$tmpdepfile" "$depfile" + ;; + +gcc) +## There are various ways to get dependency output from gcc. Here's +## why we pick this rather obscure method: +## - Don't want to use -MD because we'd like the dependencies to end +## up in a subdir. Having to rename by hand is ugly. +## (We might end up doing this anyway to support other compilers.) +## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like +## -MM, not -M (despite what the docs say). +## - Using -M directly means running the compiler twice (even worse +## than renaming). + if test -z "$gccflag"; then + gccflag=-MD, + fi + "$@" -Wp,"$gccflag$tmpdepfile" + stat=$? + if test $stat -eq 0; then : + else + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + echo "$object : \\" > "$depfile" + alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz +## The second -e expression handles DOS-style file names with drive letters. + sed -e 's/^[^:]*: / /' \ + -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" +## This next piece of magic avoids the `deleted header file' problem. +## The problem is that when a header file which appears in a .P file +## is deleted, the dependency causes make to die (because there is +## typically no way to rebuild the header). We avoid this by adding +## dummy dependencies for each header file. Too bad gcc doesn't do +## this for us directly. + tr ' ' ' +' < "$tmpdepfile" | +## Some versions of gcc put a space before the `:'. On the theory +## that the space means something, we add a space to the output as +## well. +## Some versions of the HPUX 10.20 sed can't process this invocation +## correctly. Breaking it into two sed invocations is a workaround. + sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +hp) + # This case exists only to let depend.m4 do its work. It works by + # looking at the text of this script. This case will never be run, + # since it is checked for above. + exit 1 + ;; + +sgi) + if test "$libtool" = yes; then + "$@" "-Wp,-MDupdate,$tmpdepfile" + else + "$@" -MDupdate "$tmpdepfile" + fi + stat=$? + if test $stat -eq 0; then : + else + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + + if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files + echo "$object : \\" > "$depfile" + + # Clip off the initial element (the dependent). Don't try to be + # clever and replace this with sed code, as IRIX sed won't handle + # lines with more than a fixed number of characters (4096 in + # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; + # the IRIX cc adds comments like `#:fec' to the end of the + # dependency line. + tr ' ' ' +' < "$tmpdepfile" \ + | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \ + tr ' +' ' ' >> $depfile + echo >> $depfile + + # The second pass generates a dummy entry for each header file. + tr ' ' ' +' < "$tmpdepfile" \ + | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ + >> $depfile + else + # The sourcefile does not contain any dependencies, so just + # store a dummy comment line, to avoid errors with the Makefile + # "include basename.Plo" scheme. + echo "#dummy" > "$depfile" + fi + rm -f "$tmpdepfile" + ;; + +aix) + # The C for AIX Compiler uses -M and outputs the dependencies + # in a .u file. In older versions, this file always lives in the + # current directory. Also, the AIX compiler puts `$object:' at the + # start of each line; $object doesn't have directory information. + # Version 6 uses the directory in both cases. + stripped=`echo "$object" | sed 's/\(.*\)\..*$/\1/'` + tmpdepfile="$stripped.u" + if test "$libtool" = yes; then + "$@" -Wc,-M + else + "$@" -M + fi + stat=$? + + if test -f "$tmpdepfile"; then : + else + stripped=`echo "$stripped" | sed 's,^.*/,,'` + tmpdepfile="$stripped.u" + fi + + if test $stat -eq 0; then : + else + rm -f "$tmpdepfile" + exit $stat + fi + + if test -f "$tmpdepfile"; then + outname="$stripped.o" + # Each line is of the form `foo.o: dependent.h'. + # Do two passes, one to just change these to + # `$object: dependent.h' and one to simply `dependent.h:'. + sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile" + sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile" + else + # The sourcefile does not contain any dependencies, so just + # store a dummy comment line, to avoid errors with the Makefile + # "include basename.Plo" scheme. + echo "#dummy" > "$depfile" + fi + rm -f "$tmpdepfile" + ;; + +icc) + # Intel's C compiler understands `-MD -MF file'. However on + # icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c + # ICC 7.0 will fill foo.d with something like + # foo.o: sub/foo.c + # foo.o: sub/foo.h + # which is wrong. We want: + # sub/foo.o: sub/foo.c + # sub/foo.o: sub/foo.h + # sub/foo.c: + # sub/foo.h: + # ICC 7.1 will output + # foo.o: sub/foo.c sub/foo.h + # and will wrap long lines using \ : + # foo.o: sub/foo.c ... \ + # sub/foo.h ... \ + # ... + + "$@" -MD -MF "$tmpdepfile" + stat=$? + if test $stat -eq 0; then : + else + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + # Each line is of the form `foo.o: dependent.h', + # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. + # Do two passes, one to just change these to + # `$object: dependent.h' and one to simply `dependent.h:'. + sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" + # Some versions of the HPUX 10.20 sed can't process this invocation + # correctly. Breaking it into two sed invocations is a workaround. + sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" | + sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +hp2) + # The "hp" stanza above does not work with aCC (C++) and HP's ia64 + # compilers, which have integrated preprocessors. The correct option + # to use with these is +Maked; it writes dependencies to a file named + # 'foo.d', which lands next to the object file, wherever that + # happens to be. + # Much of this is similar to the tru64 case; see comments there. + dir=`echo "$object" | sed -e 's|/[^/]*$|/|'` + test "x$dir" = "x$object" && dir= + base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'` + if test "$libtool" = yes; then + tmpdepfile1=$dir$base.d + tmpdepfile2=$dir.libs/$base.d + "$@" -Wc,+Maked + else + tmpdepfile1=$dir$base.d + tmpdepfile2=$dir$base.d + "$@" +Maked + fi + stat=$? + if test $stat -eq 0; then : + else + rm -f "$tmpdepfile1" "$tmpdepfile2" + exit $stat + fi + + for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" + do + test -f "$tmpdepfile" && break + done + if test -f "$tmpdepfile"; then + sed -e "s,^.*\.[a-z]*:,$object:," "$tmpdepfile" > "$depfile" + # Add `dependent.h:' lines. + sed -ne '2,${; s/^ *//; s/ \\*$//; s/$/:/; p;}' "$tmpdepfile" >> "$depfile" + else + echo "#dummy" > "$depfile" + fi + rm -f "$tmpdepfile" "$tmpdepfile2" + ;; + +tru64) + # The Tru64 compiler uses -MD to generate dependencies as a side + # effect. `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'. + # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put + # dependencies in `foo.d' instead, so we check for that too. + # Subdirectories are respected. + dir=`echo "$object" | sed -e 's|/[^/]*$|/|'` + test "x$dir" = "x$object" && dir= + base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'` + + if test "$libtool" = yes; then + # With Tru64 cc, shared objects can also be used to make a + # static library. This mechanism is used in libtool 1.4 series to + # handle both shared and static libraries in a single compilation. + # With libtool 1.4, dependencies were output in $dir.libs/$base.lo.d. + # + # With libtool 1.5 this exception was removed, and libtool now + # generates 2 separate objects for the 2 libraries. These two + # compilations output dependencies in $dir.libs/$base.o.d and + # in $dir$base.o.d. We have to check for both files, because + # one of the two compilations can be disabled. We should prefer + # $dir$base.o.d over $dir.libs/$base.o.d because the latter is + # automatically cleaned when .libs/ is deleted, while ignoring + # the former would cause a distcleancheck panic. + tmpdepfile1=$dir.libs/$base.lo.d # libtool 1.4 + tmpdepfile2=$dir$base.o.d # libtool 1.5 + tmpdepfile3=$dir.libs/$base.o.d # libtool 1.5 + tmpdepfile4=$dir.libs/$base.d # Compaq CCC V6.2-504 + "$@" -Wc,-MD + else + tmpdepfile1=$dir$base.o.d + tmpdepfile2=$dir$base.d + tmpdepfile3=$dir$base.d + tmpdepfile4=$dir$base.d + "$@" -MD + fi + + stat=$? + if test $stat -eq 0; then : + else + rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4" + exit $stat + fi + + for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4" + do + test -f "$tmpdepfile" && break + done + if test -f "$tmpdepfile"; then + sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile" + # That's a tab and a space in the []. + sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile" + else + echo "#dummy" > "$depfile" + fi + rm -f "$tmpdepfile" + ;; + +#nosideeffect) + # This comment above is used by automake to tell side-effect + # dependency tracking mechanisms from slower ones. + +dashmstdout) + # Important note: in order to support this mode, a compiler *must* + # always write the preprocessed file to stdout, regardless of -o. + "$@" || exit $? + + # Remove the call to Libtool. + if test "$libtool" = yes; then + while test $1 != '--mode=compile'; do + shift + done + shift + fi + + # Remove `-o $object'. + IFS=" " + for arg + do + case $arg in + -o) + shift + ;; + $object) + shift + ;; + *) + set fnord "$@" "$arg" + shift # fnord + shift # $arg + ;; + esac + done + + test -z "$dashmflag" && dashmflag=-M + # Require at least two characters before searching for `:' + # in the target name. This is to cope with DOS-style filenames: + # a dependency such as `c:/foo/bar' could be seen as target `c' otherwise. + "$@" $dashmflag | + sed 's:^[ ]*[^: ][^:][^:]*\:[ ]*:'"$object"'\: :' > "$tmpdepfile" + rm -f "$depfile" + cat < "$tmpdepfile" > "$depfile" + tr ' ' ' +' < "$tmpdepfile" | \ +## Some versions of the HPUX 10.20 sed can't process this invocation +## correctly. Breaking it into two sed invocations is a workaround. + sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +dashXmstdout) + # This case only exists to satisfy depend.m4. It is never actually + # run, as this mode is specially recognized in the preamble. + exit 1 + ;; + +makedepend) + "$@" || exit $? + # Remove any Libtool call + if test "$libtool" = yes; then + while test $1 != '--mode=compile'; do + shift + done + shift + fi + # X makedepend + shift + cleared=no + for arg in "$@"; do + case $cleared in + no) + set ""; shift + cleared=yes ;; + esac + case "$arg" in + -D*|-I*) + set fnord "$@" "$arg"; shift ;; + # Strip any option that makedepend may not understand. Remove + # the object too, otherwise makedepend will parse it as a source file. + -*|$object) + ;; + *) + set fnord "$@" "$arg"; shift ;; + esac + done + obj_suffix="`echo $object | sed 's/^.*\././'`" + touch "$tmpdepfile" + ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" + rm -f "$depfile" + cat < "$tmpdepfile" > "$depfile" + sed '1,2d' "$tmpdepfile" | tr ' ' ' +' | \ +## Some versions of the HPUX 10.20 sed can't process this invocation +## correctly. Breaking it into two sed invocations is a workaround. + sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" "$tmpdepfile".bak + ;; + +cpp) + # Important note: in order to support this mode, a compiler *must* + # always write the preprocessed file to stdout. + "$@" || exit $? + + # Remove the call to Libtool. + if test "$libtool" = yes; then + while test $1 != '--mode=compile'; do + shift + done + shift + fi + + # Remove `-o $object'. + IFS=" " + for arg + do + case $arg in + -o) + shift + ;; + $object) + shift + ;; + *) + set fnord "$@" "$arg" + shift # fnord + shift # $arg + ;; + esac + done + + "$@" -E | + sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ + -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' | + sed '$ s: \\$::' > "$tmpdepfile" + rm -f "$depfile" + echo "$object : \\" > "$depfile" + cat < "$tmpdepfile" >> "$depfile" + sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +msvisualcpp) + # Important note: in order to support this mode, a compiler *must* + # always write the preprocessed file to stdout, regardless of -o, + # because we must use -o when running libtool. + "$@" || exit $? + IFS=" " + for arg + do + case "$arg" in + "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") + set fnord "$@" + shift + shift + ;; + *) + set fnord "$@" "$arg" + shift + shift + ;; + esac + done + "$@" -E | + sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::echo "`cygpath -u \\"\1\\"`":p' | sort | uniq > "$tmpdepfile" + rm -f "$depfile" + echo "$object : \\" > "$depfile" + . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s:: \1 \\:p' >> "$depfile" + echo " " >> "$depfile" + . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::\1\::p' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +none) + exec "$@" + ;; + +*) + echo "Unknown depmode $depmode" 1>&2 + exit 1 + ;; +esac + +exit 0 + +# Local Variables: +# mode: shell-script +# sh-indentation: 2 +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-end: "$" +# End: diff --git a/install-sh b/install-sh new file mode 100755 index 0000000..4fbbae7 --- /dev/null +++ b/install-sh @@ -0,0 +1,507 @@ +#!/bin/sh +# install - install a program, script, or datafile + +scriptversion=2006-10-14.15 + +# This originates from X11R5 (mit/util/scripts/install.sh), which was +# later released in X11R6 (xc/config/util/install.sh) with the +# following copyright and license. +# +# Copyright (C) 1994 X Consortium +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to +# deal in the Software without restriction, including without limitation the +# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or +# sell copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN +# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- +# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# +# Except as contained in this notice, the name of the X Consortium shall not +# be used in advertising or otherwise to promote the sale, use or other deal- +# ings in this Software without prior written authorization from the X Consor- +# tium. +# +# +# FSF changes to this file are in the public domain. +# +# Calling this script install-sh is preferred over install.sh, to prevent +# `make' implicit rules from creating a file called install from it +# when there is no Makefile. +# +# This script is compatible with the BSD install script, but was written +# from scratch. + +nl=' +' +IFS=" "" $nl" + +# set DOITPROG to echo to test this script + +# Don't use :- since 4.3BSD and earlier shells don't like it. +doit="${DOITPROG-}" +if test -z "$doit"; then + doit_exec=exec +else + doit_exec=$doit +fi + +# Put in absolute file names if you don't have them in your path; +# or use environment vars. + +mvprog="${MVPROG-mv}" +cpprog="${CPPROG-cp}" +chmodprog="${CHMODPROG-chmod}" +chownprog="${CHOWNPROG-chown}" +chgrpprog="${CHGRPPROG-chgrp}" +stripprog="${STRIPPROG-strip}" +rmprog="${RMPROG-rm}" +mkdirprog="${MKDIRPROG-mkdir}" + +posix_glob= +posix_mkdir= + +# Desired mode of installed file. +mode=0755 + +chmodcmd=$chmodprog +chowncmd= +chgrpcmd= +stripcmd= +rmcmd="$rmprog -f" +mvcmd="$mvprog" +src= +dst= +dir_arg= +dstarg= +no_target_directory= + +usage="Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE + or: $0 [OPTION]... SRCFILES... DIRECTORY + or: $0 [OPTION]... -t DIRECTORY SRCFILES... + or: $0 [OPTION]... -d DIRECTORIES... + +In the 1st form, copy SRCFILE to DSTFILE. +In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. +In the 4th, create DIRECTORIES. + +Options: +-c (ignored) +-d create directories instead of installing files. +-g GROUP $chgrpprog installed files to GROUP. +-m MODE $chmodprog installed files to MODE. +-o USER $chownprog installed files to USER. +-s $stripprog installed files. +-t DIRECTORY install into DIRECTORY. +-T report an error if DSTFILE is a directory. +--help display this help and exit. +--version display version info and exit. + +Environment variables override the default commands: + CHGRPPROG CHMODPROG CHOWNPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG +" + +while test $# -ne 0; do + case $1 in + -c) shift + continue;; + + -d) dir_arg=true + shift + continue;; + + -g) chgrpcmd="$chgrpprog $2" + shift + shift + continue;; + + --help) echo "$usage"; exit $?;; + + -m) mode=$2 + shift + shift + case $mode in + *' '* | *' '* | *' +'* | *'*'* | *'?'* | *'['*) + echo "$0: invalid mode: $mode" >&2 + exit 1;; + esac + continue;; + + -o) chowncmd="$chownprog $2" + shift + shift + continue;; + + -s) stripcmd=$stripprog + shift + continue;; + + -t) dstarg=$2 + shift + shift + continue;; + + -T) no_target_directory=true + shift + continue;; + + --version) echo "$0 $scriptversion"; exit $?;; + + --) shift + break;; + + -*) echo "$0: invalid option: $1" >&2 + exit 1;; + + *) break;; + esac +done + +if test $# -ne 0 && test -z "$dir_arg$dstarg"; then + # When -d is used, all remaining arguments are directories to create. + # When -t is used, the destination is already specified. + # Otherwise, the last argument is the destination. Remove it from $@. + for arg + do + if test -n "$dstarg"; then + # $@ is not empty: it contains at least $arg. + set fnord "$@" "$dstarg" + shift # fnord + fi + shift # arg + dstarg=$arg + done +fi + +if test $# -eq 0; then + if test -z "$dir_arg"; then + echo "$0: no input file specified." >&2 + exit 1 + fi + # It's OK to call `install-sh -d' without argument. + # This can happen when creating conditional directories. + exit 0 +fi + +if test -z "$dir_arg"; then + trap '(exit $?); exit' 1 2 13 15 + + # Set umask so as not to create temps with too-generous modes. + # However, 'strip' requires both read and write access to temps. + case $mode in + # Optimize common cases. + *644) cp_umask=133;; + *755) cp_umask=22;; + + *[0-7]) + if test -z "$stripcmd"; then + u_plus_rw= + else + u_plus_rw='% 200' + fi + cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;; + *) + if test -z "$stripcmd"; then + u_plus_rw= + else + u_plus_rw=,u+rw + fi + cp_umask=$mode$u_plus_rw;; + esac +fi + +for src +do + # Protect names starting with `-'. + case $src in + -*) src=./$src ;; + esac + + if test -n "$dir_arg"; then + dst=$src + dstdir=$dst + test -d "$dstdir" + dstdir_status=$? + else + + # Waiting for this to be detected by the "$cpprog $src $dsttmp" command + # might cause directories to be created, which would be especially bad + # if $src (and thus $dsttmp) contains '*'. + if test ! -f "$src" && test ! -d "$src"; then + echo "$0: $src does not exist." >&2 + exit 1 + fi + + if test -z "$dstarg"; then + echo "$0: no destination specified." >&2 + exit 1 + fi + + dst=$dstarg + # Protect names starting with `-'. + case $dst in + -*) dst=./$dst ;; + esac + + # If destination is a directory, append the input filename; won't work + # if double slashes aren't ignored. + if test -d "$dst"; then + if test -n "$no_target_directory"; then + echo "$0: $dstarg: Is a directory" >&2 + exit 1 + fi + dstdir=$dst + dst=$dstdir/`basename "$src"` + dstdir_status=0 + else + # Prefer dirname, but fall back on a substitute if dirname fails. + dstdir=` + (dirname "$dst") 2>/dev/null || + expr X"$dst" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$dst" : 'X\(//\)[^/]' \| \ + X"$dst" : 'X\(//\)$' \| \ + X"$dst" : 'X\(/\)' \| . 2>/dev/null || + echo X"$dst" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q' + ` + + test -d "$dstdir" + dstdir_status=$? + fi + fi + + obsolete_mkdir_used=false + + if test $dstdir_status != 0; then + case $posix_mkdir in + '') + # Create intermediate dirs using mode 755 as modified by the umask. + # This is like FreeBSD 'install' as of 1997-10-28. + umask=`umask` + case $stripcmd.$umask in + # Optimize common cases. + *[2367][2367]) mkdir_umask=$umask;; + .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;; + + *[0-7]) + mkdir_umask=`expr $umask + 22 \ + - $umask % 100 % 40 + $umask % 20 \ + - $umask % 10 % 4 + $umask % 2 + `;; + *) mkdir_umask=$umask,go-w;; + esac + + # With -d, create the new directory with the user-specified mode. + # Otherwise, rely on $mkdir_umask. + if test -n "$dir_arg"; then + mkdir_mode=-m$mode + else + mkdir_mode= + fi + + posix_mkdir=false + case $umask in + *[123567][0-7][0-7]) + # POSIX mkdir -p sets u+wx bits regardless of umask, which + # is incompatible with FreeBSD 'install' when (umask & 300) != 0. + ;; + *) + tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ + trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0 + + if (umask $mkdir_umask && + exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1 + then + if test -z "$dir_arg" || { + # Check for POSIX incompatibilities with -m. + # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or + # other-writeable bit of parent directory when it shouldn't. + # FreeBSD 6.1 mkdir -m -p sets mode of existing directory. + ls_ld_tmpdir=`ls -ld "$tmpdir"` + case $ls_ld_tmpdir in + d????-?r-*) different_mode=700;; + d????-?--*) different_mode=755;; + *) false;; + esac && + $mkdirprog -m$different_mode -p -- "$tmpdir" && { + ls_ld_tmpdir_1=`ls -ld "$tmpdir"` + test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1" + } + } + then posix_mkdir=: + fi + rmdir "$tmpdir/d" "$tmpdir" + else + # Remove any dirs left behind by ancient mkdir implementations. + rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null + fi + trap '' 0;; + esac;; + esac + + if + $posix_mkdir && ( + umask $mkdir_umask && + $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir" + ) + then : + else + + # The umask is ridiculous, or mkdir does not conform to POSIX, + # or it failed possibly due to a race condition. Create the + # directory the slow way, step by step, checking for races as we go. + + case $dstdir in + /*) prefix=/ ;; + -*) prefix=./ ;; + *) prefix= ;; + esac + + case $posix_glob in + '') + if (set -f) 2>/dev/null; then + posix_glob=true + else + posix_glob=false + fi ;; + esac + + oIFS=$IFS + IFS=/ + $posix_glob && set -f + set fnord $dstdir + shift + $posix_glob && set +f + IFS=$oIFS + + prefixes= + + for d + do + test -z "$d" && continue + + prefix=$prefix$d + if test -d "$prefix"; then + prefixes= + else + if $posix_mkdir; then + (umask=$mkdir_umask && + $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break + # Don't fail if two instances are running concurrently. + test -d "$prefix" || exit 1 + else + case $prefix in + *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;; + *) qprefix=$prefix;; + esac + prefixes="$prefixes '$qprefix'" + fi + fi + prefix=$prefix/ + done + + if test -n "$prefixes"; then + # Don't fail if two instances are running concurrently. + (umask $mkdir_umask && + eval "\$doit_exec \$mkdirprog $prefixes") || + test -d "$dstdir" || exit 1 + obsolete_mkdir_used=true + fi + fi + fi + + if test -n "$dir_arg"; then + { test -z "$chowncmd" || $doit $chowncmd "$dst"; } && + { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } && + { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false || + test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1 + else + + # Make a couple of temp file names in the proper directory. + dsttmp=$dstdir/_inst.$$_ + rmtmp=$dstdir/_rm.$$_ + + # Trap to clean up those temp files at exit. + trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 + + # Copy the file name to the temp name. + (umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") && + + # and set any options; do chmod last to preserve setuid bits. + # + # If any of these fail, we abort the whole thing. If we want to + # ignore errors from any of these, just make sure not to ignore + # errors from the above "$doit $cpprog $src $dsttmp" command. + # + { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } \ + && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } \ + && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } \ + && { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } && + + # Now rename the file to the real destination. + { $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null \ + || { + # The rename failed, perhaps because mv can't rename something else + # to itself, or perhaps because mv is so ancient that it does not + # support -f. + + # Now remove or move aside any old file at destination location. + # We try this two ways since rm can't unlink itself on some + # systems and the destination file might be busy for other + # reasons. In this case, the final cleanup might fail but the new + # file should still install successfully. + { + if test -f "$dst"; then + $doit $rmcmd -f "$dst" 2>/dev/null \ + || { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null \ + && { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; }; }\ + || { + echo "$0: cannot unlink or rename $dst" >&2 + (exit 1); exit 1 + } + else + : + fi + } && + + # Now rename the file to the real destination. + $doit $mvcmd "$dsttmp" "$dst" + } + } || exit 1 + + trap '' 0 + fi +done + +# Local variables: +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-end: "$" +# End: diff --git a/missing b/missing new file mode 100755 index 0000000..1c8ff70 --- /dev/null +++ b/missing @@ -0,0 +1,367 @@ +#! /bin/sh +# Common stub for a few missing GNU programs while installing. + +scriptversion=2006-05-10.23 + +# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003, 2004, 2005, 2006 +# Free Software Foundation, Inc. +# Originally by Fran,cois Pinard , 1996. + +# 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 2, 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, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA +# 02110-1301, USA. + +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +if test $# -eq 0; then + echo 1>&2 "Try \`$0 --help' for more information" + exit 1 +fi + +run=: +sed_output='s/.* --output[ =]\([^ ]*\).*/\1/p' +sed_minuso='s/.* -o \([^ ]*\).*/\1/p' + +# In the cases where this matters, `missing' is being run in the +# srcdir already. +if test -f configure.ac; then + configure_ac=configure.ac +else + configure_ac=configure.in +fi + +msg="missing on your system" + +case $1 in +--run) + # Try to run requested program, and just exit if it succeeds. + run= + shift + "$@" && exit 0 + # Exit code 63 means version mismatch. This often happens + # when the user try to use an ancient version of a tool on + # a file that requires a minimum version. In this case we + # we should proceed has if the program had been absent, or + # if --run hadn't been passed. + if test $? = 63; then + run=: + msg="probably too old" + fi + ;; + + -h|--h|--he|--hel|--help) + echo "\ +$0 [OPTION]... PROGRAM [ARGUMENT]... + +Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an +error status if there is no known handling for PROGRAM. + +Options: + -h, --help display this help and exit + -v, --version output version information and exit + --run try to run the given command, and emulate it if it fails + +Supported PROGRAM values: + aclocal touch file \`aclocal.m4' + autoconf touch file \`configure' + autoheader touch file \`config.h.in' + autom4te touch the output file, or create a stub one + automake touch all \`Makefile.in' files + bison create \`y.tab.[ch]', if possible, from existing .[ch] + flex create \`lex.yy.c', if possible, from existing .c + help2man touch the output file + lex create \`lex.yy.c', if possible, from existing .c + makeinfo touch the output file + tar try tar, gnutar, gtar, then tar without non-portable flags + yacc create \`y.tab.[ch]', if possible, from existing .[ch] + +Send bug reports to ." + exit $? + ;; + + -v|--v|--ve|--ver|--vers|--versi|--versio|--version) + echo "missing $scriptversion (GNU Automake)" + exit $? + ;; + + -*) + echo 1>&2 "$0: Unknown \`$1' option" + echo 1>&2 "Try \`$0 --help' for more information" + exit 1 + ;; + +esac + +# Now exit if we have it, but it failed. Also exit now if we +# don't have it and --version was passed (most likely to detect +# the program). +case $1 in + lex|yacc) + # Not GNU programs, they don't have --version. + ;; + + tar) + if test -n "$run"; then + echo 1>&2 "ERROR: \`tar' requires --run" + exit 1 + elif test "x$2" = "x--version" || test "x$2" = "x--help"; then + exit 1 + fi + ;; + + *) + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then + # We have it, but it failed. + exit 1 + elif test "x$2" = "x--version" || test "x$2" = "x--help"; then + # Could not run --version or --help. This is probably someone + # running `$TOOL --version' or `$TOOL --help' to check whether + # $TOOL exists and not knowing $TOOL uses missing. + exit 1 + fi + ;; +esac + +# If it does not exist, or fails to run (possibly an outdated version), +# try to emulate it. +case $1 in + aclocal*) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified \`acinclude.m4' or \`${configure_ac}'. You might want + to install the \`Automake' and \`Perl' packages. Grab them from + any GNU archive site." + touch aclocal.m4 + ;; + + autoconf) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified \`${configure_ac}'. You might want to install the + \`Autoconf' and \`GNU m4' packages. Grab them from any GNU + archive site." + touch configure + ;; + + autoheader) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified \`acconfig.h' or \`${configure_ac}'. You might want + to install the \`Autoconf' and \`GNU m4' packages. Grab them + from any GNU archive site." + files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}` + test -z "$files" && files="config.h" + touch_files= + for f in $files; do + case $f in + *:*) touch_files="$touch_files "`echo "$f" | + sed -e 's/^[^:]*://' -e 's/:.*//'`;; + *) touch_files="$touch_files $f.in";; + esac + done + touch $touch_files + ;; + + automake*) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'. + You might want to install the \`Automake' and \`Perl' packages. + Grab them from any GNU archive site." + find . -type f -name Makefile.am -print | + sed 's/\.am$/.in/' | + while read f; do touch "$f"; done + ;; + + autom4te) + echo 1>&2 "\ +WARNING: \`$1' is needed, but is $msg. + You might have modified some files without having the + proper tools for further handling them. + You can get \`$1' as part of \`Autoconf' from any GNU + archive site." + + file=`echo "$*" | sed -n "$sed_output"` + test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"` + if test -f "$file"; then + touch $file + else + test -z "$file" || exec >$file + echo "#! /bin/sh" + echo "# Created by GNU Automake missing as a replacement of" + echo "# $ $@" + echo "exit 0" + chmod +x $file + exit 1 + fi + ;; + + bison|yacc) + echo 1>&2 "\ +WARNING: \`$1' $msg. You should only need it if + you modified a \`.y' file. You may need the \`Bison' package + in order for those modifications to take effect. You can get + \`Bison' from any GNU archive site." + rm -f y.tab.c y.tab.h + if test $# -ne 1; then + eval LASTARG="\${$#}" + case $LASTARG in + *.y) + SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'` + if test -f "$SRCFILE"; then + cp "$SRCFILE" y.tab.c + fi + SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'` + if test -f "$SRCFILE"; then + cp "$SRCFILE" y.tab.h + fi + ;; + esac + fi + if test ! -f y.tab.h; then + echo >y.tab.h + fi + if test ! -f y.tab.c; then + echo 'main() { return 0; }' >y.tab.c + fi + ;; + + lex|flex) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified a \`.l' file. You may need the \`Flex' package + in order for those modifications to take effect. You can get + \`Flex' from any GNU archive site." + rm -f lex.yy.c + if test $# -ne 1; then + eval LASTARG="\${$#}" + case $LASTARG in + *.l) + SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'` + if test -f "$SRCFILE"; then + cp "$SRCFILE" lex.yy.c + fi + ;; + esac + fi + if test ! -f lex.yy.c; then + echo 'main() { return 0; }' >lex.yy.c + fi + ;; + + help2man) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified a dependency of a manual page. You may need the + \`Help2man' package in order for those modifications to take + effect. You can get \`Help2man' from any GNU archive site." + + file=`echo "$*" | sed -n "$sed_output"` + test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"` + if test -f "$file"; then + touch $file + else + test -z "$file" || exec >$file + echo ".ab help2man is required to generate this page" + exit 1 + fi + ;; + + makeinfo) + echo 1>&2 "\ +WARNING: \`$1' is $msg. You should only need it if + you modified a \`.texi' or \`.texinfo' file, or any other file + indirectly affecting the aspect of the manual. The spurious + call might also be the consequence of using a buggy \`make' (AIX, + DU, IRIX). You might want to install the \`Texinfo' package or + the \`GNU make' package. Grab either from any GNU archive site." + # The file to touch is that specified with -o ... + file=`echo "$*" | sed -n "$sed_output"` + test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"` + if test -z "$file"; then + # ... or it is the one specified with @setfilename ... + infile=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'` + file=`sed -n ' + /^@setfilename/{ + s/.* \([^ ]*\) *$/\1/ + p + q + }' $infile` + # ... or it is derived from the source name (dir/f.texi becomes f.info) + test -z "$file" && file=`echo "$infile" | sed 's,.*/,,;s,.[^.]*$,,'`.info + fi + # If the file does not exist, the user really needs makeinfo; + # let's fail without touching anything. + test -f $file || exit 1 + touch $file + ;; + + tar) + shift + + # We have already tried tar in the generic part. + # Look for gnutar/gtar before invocation to avoid ugly error + # messages. + if (gnutar --version > /dev/null 2>&1); then + gnutar "$@" && exit 0 + fi + if (gtar --version > /dev/null 2>&1); then + gtar "$@" && exit 0 + fi + firstarg="$1" + if shift; then + case $firstarg in + *o*) + firstarg=`echo "$firstarg" | sed s/o//` + tar "$firstarg" "$@" && exit 0 + ;; + esac + case $firstarg in + *h*) + firstarg=`echo "$firstarg" | sed s/h//` + tar "$firstarg" "$@" && exit 0 + ;; + esac + fi + + echo 1>&2 "\ +WARNING: I can't seem to be able to run \`tar' with the given arguments. + You may want to install GNU tar or Free paxutils, or check the + command line arguments." + exit 1 + ;; + + *) + echo 1>&2 "\ +WARNING: \`$1' is needed, and is $msg. + You might have modified some files without having the + proper tools for further handling them. Check the \`README' file, + it often tells you about the needed prerequisites for installing + this package. You may also peek at any GNU archive site, in case + some other package would contain this missing \`$1' program." + exit 1 + ;; +esac + +exit 0 + +# Local variables: +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-end: "$" +# End: