From a33b576e701771646981b01fb1ba9732e79e57fe Mon Sep 17 00:00:00 2001 From: Michael Jerris Date: Tue, 30 Mar 2010 05:59:43 +0000 Subject: [PATCH] copy mod_gsmopen from branch git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@17138 d0543943-73ff-0310-b7d9-9358b9ac24b2 --- src/mod/endpoints/mod_gsmopen/Makefile | 9 + src/mod/endpoints/mod_gsmopen/Makefile.am | 7 + src/mod/endpoints/mod_gsmopen/README | 35 + .../mod_gsmopen/Makefile | 6 + .../mod_gsmopen/gsmopen.h | 1 + .../mod_gsmopen/gsmopen_protocol.c | 1 + .../mod_gsmopen/mod_gsmopen.c | 1 + .../endpoints/mod_gsmopen/asterisk/Makefile | 81 + src/mod/endpoints/mod_gsmopen/asterisk/README | 96 + .../mod_gsmopen/asterisk/asound.conf | 2 + .../mod_gsmopen/asterisk/celliax.conf | 205 + .../endpoints/mod_gsmopen/asterisk/celliax.h | 909 + .../mod_gsmopen/asterisk/celliax_additional.c | 7027 ++++ .../mod_gsmopen/asterisk/celliax_libcsv.c | 356 + .../mod_gsmopen/asterisk/celliax_libcsv.h | 48 + .../mod_gsmopen/asterisk/celliax_spandsp.c | 1059 + .../mod_gsmopen/asterisk/celliax_spandsp.h | 1028 + .../mod_gsmopen/asterisk/chan_celliax.c | 3094 ++ .../endpoints/mod_gsmopen/asterisk/ciapalo | 8 + .../endpoints/mod_gsmopen/configs/asound.conf | 6 + .../mod_gsmopen/configs/gsmopen.conf.xml | 23 + .../configs/gsmopen.conf.xml.motorola | 110 + src/mod/endpoints/mod_gsmopen/filtra48down8.c | 71 + src/mod/endpoints/mod_gsmopen/filtra8up48.c | 81 + src/mod/endpoints/mod_gsmopen/gsmlib/README | 8 + .../gsmlib-1.10-patched-12ubuntu1/ABOUT-NLS | 226 + .../gsmlib-1.10-patched-12ubuntu1/AUTHORS | 0 .../gsmlib-1.10-patched-12ubuntu1/COPYING | 482 + .../gsmlib-1.10-patched-12ubuntu1/ChangeLog | 386 + .../gsmlib-1.10-patched-12ubuntu1/INSTALL | 198 + .../gsmlib-1.10-patched-12ubuntu1/Makefile.am | 24 + .../gsmlib-1.10-patched-12ubuntu1/Makefile.in | 423 + .../gsmlib/gsmlib-1.10-patched-12ubuntu1/NEWS | 11 + .../gsmlib-1.10-patched-12ubuntu1/README | 166 + .../gsmlib/gsmlib-1.10-patched-12ubuntu1/TODO | 289 + .../gsmlib-1.10-patched-12ubuntu1/acconfig.h | 33 + .../acinclude.m4 | 0 .../gsmlib-1.10-patched-12ubuntu1/aclocal.m4 | 9704 +++++ .../apps/Makefile.am | 36 + .../apps/Makefile.in | 442 + .../apps/gsmctl.cc | 635 + .../apps/gsmpb.cc | 507 + .../apps/gsmsendsms.cc | 257 + .../apps/gsmsmsd.cc | 719 + .../apps/gsmsmsstore.cc | 439 + .../gsmlib-1.10-patched-12ubuntu1/configure | 30623 ++++++++++++++++ .../configure.in | 131 + .../contrib/gsm-utils.cron.d | 3 + .../contrib/gsm-utils.default | 13 + .../contrib/gsm-utils.init | 72 + .../contrib/gsmsmsrequeue | 44 + .../contrib/gsmsmsspool | 34 + .../debian/changelog | 244 + .../debian/compat | 1 + .../debian/control | 52 + .../debian/copyright | 26 + .../debian/gsm-utils.cron.d | 3 + .../debian/gsm-utils.default | 13 + .../debian/gsm-utils.dirs | 11 + .../debian/gsm-utils.docs | 4 + .../debian/gsm-utils.init | 77 + .../debian/gsm-utils.postinst | 31 + .../debian/gsm-utils.postrm | 43 + .../debian/gsm-utils.undocumented | 2 + .../debian/gsmsiexfer.1 | 29 + .../debian/libgsmme-dev.docs | 2 + .../debian/rules | 137 + .../debian/watch | 2 + .../gsmlib-1.10-patched-12ubuntu1/doc/FAQ | 101 + .../doc/Makefile.am | 33 + .../doc/Makefile.in | 412 + .../doc/README.NLS | 72 + .../doc/README.developers | 138 + .../doc/gsmctl.man | 683 + .../doc/gsminfo.man | 56 + .../doc/gsmlib.lsm | 20 + .../doc/gsmpb.man | 245 + .../doc/gsmsendsms.man | 154 + .../doc/gsmsmsd.man | 269 + .../doc/gsmsmsstore.man | 185 + .../ext/Makefile.am | 40 + .../ext/Makefile.in | 480 + .../ext/README.sieme | 75 + .../ext/gsm_sie_me.cc | 258 + .../ext/gsm_sie_me.h | 99 + .../ext/gsmsiectl.cc | 698 + .../ext/gsmsiexfer.cc | 292 + .../gsmlib-1.10-patched-12ubuntu1/g41.patch | 29 + .../gsm_config.h.in | 344 + .../gsmlib-1.10.debmg/debian/gsm-utils.dirs | 11 + .../debian/gsm-utils.postinst | 28 + .../gsmlib-1.10.debmg/debian/gsm-utils.prerm | 7 + .../debian/gsm-utils.undocumented | 2 + .../gsmlib-1.10-patched-12ubuntu1/gsmlib.spec | 92 + .../gsmlib/Makefile.am | 38 + .../gsmlib/Makefile.in | 461 + .../gsmlib/gsm_at.cc | 428 + .../gsmlib/gsm_at.h | 104 + .../gsmlib/gsm_cb.cc | 176 + .../gsmlib/gsm_cb.h | 106 + .../gsmlib/gsm_error.cc | 424 + .../gsmlib/gsm_error.h | 209 + .../gsmlib/gsm_event.cc | 174 + .../gsmlib/gsm_event.h | 68 + .../gsmlib/gsm_map_key.h | 128 + .../gsmlib/gsm_me_ta.cc | 1254 + .../gsmlib/gsm_me_ta.h | 402 + .../gsmlib/gsm_nls.cc | 32 + .../gsmlib/gsm_nls.h | 71 + .../gsmlib/gsm_parser.cc | 381 + .../gsmlib/gsm_parser.h | 125 + .../gsmlib/gsm_phonebook.cc | 585 + .../gsmlib/gsm_phonebook.h | 195 + .../gsmlib/gsm_port.h | 58 + .../gsmlib/gsm_sms.cc | 863 + .../gsmlib/gsm_sms.h | 480 + .../gsmlib/gsm_sms_codec.cc | 702 + .../gsmlib/gsm_sms_codec.h | 329 + .../gsmlib/gsm_sms_store.cc | 489 + .../gsmlib/gsm_sms_store.h | 295 + .../gsmlib/gsm_sorted_phonebook.cc | 502 + .../gsmlib/gsm_sorted_phonebook.h | 159 + .../gsmlib/gsm_sorted_phonebook_base.cc | 115 + .../gsmlib/gsm_sorted_phonebook_base.h | 220 + .../gsmlib/gsm_sorted_sms_store.cc | 499 + .../gsmlib/gsm_sorted_sms_store.h | 217 + .../gsmlib/gsm_sysdep.h | 83 + .../gsmlib/gsm_unix_serial.cc | 455 + .../gsmlib/gsm_unix_serial.h | 62 + .../gsmlib/gsm_util.cc | 380 + .../gsmlib/gsm_util.h | 232 + .../gsmlib/gsm_win32_serial.cc | 507 + .../gsmlib/gsm_win32_serial.h | 60 + .../intl/ChangeLog | 1086 + .../intl/Makefile | 214 + .../intl/Makefile.in | 214 + .../intl/VERSION | 1 + .../intl/bindtextdom.c | 203 + .../intl/cat-compat.c | 262 + .../intl/dcgettext.c | 624 + .../intl/dgettext.c | 59 + .../intl/explodename.c | 188 + .../intl/finddomain.c | 216 + .../intl/gettext.c | 70 + .../intl/gettext.h | 105 + .../intl/gettextP.h | 89 + .../intl/hash-string.h | 59 + .../intl/intl-compat.c | 76 + .../intl/l10nflist.c | 411 + .../intl/libgettext.h | 182 + .../intl/linux-msg.sed | 100 + .../intl/loadinfo.h | 76 + .../intl/loadmsgcat.c | 222 + .../intl/localealias.c | 424 + .../intl/po2tbl.sed.in | 102 + .../intl/textdomain.c | 108 + .../intl/xopen-msg.sed | 104 + .../po/Makefile.in.in | 250 + .../po/POTFILES.in | 19 + .../po/cat-id-tbl.c | 0 .../gsmlib-1.10-patched-12ubuntu1/po/de.gmo | Bin 0 -> 34591 bytes .../gsmlib-1.10-patched-12ubuntu1/po/de.po | 1758 + .../po/gsmlib.pot | 1689 + .../po/stamp-cat-id | 1 + .../scripts/Makefile.am | 15 + .../scripts/Makefile.in | 259 + .../scripts/config.guess | 1516 + .../scripts/config.rpath | 513 + .../scripts/config.sub | 1622 + .../scripts/debugconfig.sh | 3 + .../scripts/depcomp | 423 + .../scripts/install-sh | 250 + .../scripts/ltconfig | 3115 ++ .../scripts/ltmain.sh | 6538 ++++ .../scripts/missing | 336 + .../scripts/mkinstalldirs | 40 + .../gsmlib-1.10-patched-12ubuntu1/stamp-h.in | 1 + .../tests/Makefile.am | 65 + .../tests/Makefile.in | 544 + .../tests/runparser.sh | 12 + .../tests/runsms.sh | 18 + .../tests/runspb.sh | 17 + .../tests/runspb2.sh | 17 + .../tests/runspbi.sh | 18 + .../tests/runssms.sh | 21 + .../tests/spb.pb | 11 + .../tests/spb2.pb | 11 + .../tests/spbi1.pb | 3 + .../tests/spbi2-orig.pb | 4 + .../tests/testcb.cc | 40 + .../tests/testgsmlib.cc | 178 + .../tests/testparser-output.txt | 22 + .../tests/testparser.cc | 200 + .../tests/testpb.cc | 52 + .../tests/testpb2.cc | 75 + .../tests/testsms-output.txt | 167 + .../tests/testsms.cc | 80 + .../tests/testsms2.cc | 89 + .../tests/testspb-output.txt | 47 + .../tests/testspb.cc | 81 + .../tests/testspb2-output.txt | 47 + .../tests/testspbi-output.txt | 8 + .../tests/testssms-output.txt | 157 + .../tests/testssms.cc | 68 + .../win32/COPYING | 5 + .../win32/Makefile.am | 17 + .../win32/Makefile.in | 259 + .../win32/README.win | 41 + .../win32/getopt.c | 185 + .../win32/getopt.h | 49 + .../win32/gsm_config.h | 171 + .../win32/gsmctl.vcproj | 250 + .../win32/gsmlib.sln | 92 + .../win32/gsmlib.vcproj | 332 + .../win32/gsmpb.vcproj | 250 + .../win32/gsmsendsms.vcproj | 250 + .../win32/gsmsmsd.vcproj | 250 + .../win32/gsmsmsstore.vcproj | 252 + .../win32/testgsmlib.vcproj | 221 + .../win32/testsms.vcproj | 222 + .../win32/testsms2.vcproj | 222 + .../mod_gsmopen/gsmlib/gsmlib-1.10.tar.gz | Bin 0 -> 474591 bytes .../gsmlib/gsmlib_1.10-12ubuntu1.diff.gz | Bin 0 -> 453447 bytes src/mod/endpoints/mod_gsmopen/gsmopen.h | 665 + .../mod_gsmopen/gsmopen_protocol.cpp | 3994 ++ .../mod_gsmopen/mod_gsmopen.2008.vcproj | 168 + src/mod/endpoints/mod_gsmopen/mod_gsmopen.cpp | 3421 ++ .../mod_gsmopen/Makefile | 6 + .../mod_gsmopen/gsmopen.h | 1 + .../mod_gsmopen/gsmopen_protocol.cpp | 1 + .../mod_gsmopen/mod_gsmopen.cpp | 1 + .../mod_gsmopen/Makefile | 6 + .../mod_gsmopen/gsmopen.h | 1 + .../mod_gsmopen/gsmopen_protocol.c | 1 + .../mod_gsmopen/mod_gsmopen.c | 1 + src/mod/endpoints/mod_gsmopen/pa_ringbuffer.c | 275 + src/mod/endpoints/mod_gsmopen/pa_ringbuffer.h | 192 + src/mod/endpoints/mod_gsmopen/pablio.c | 720 + src/mod/endpoints/mod_gsmopen/pablio.h | 120 + .../endpoints/mod_gsmopen/portaudio_devlist.c | 54 + .../mod_gsmopen/Makefile | 6 + .../mod_gsmopen/filtra48down8.c | 1 + .../mod_gsmopen/filtra8up48.c | 1 + .../mod_gsmopen/gsmopen.h | 1 + .../mod_gsmopen/gsmopen_protocol.cpp | 1 + .../mod_gsmopen/mod_gsmopen.cpp | 1 + .../mod_gsmopen/pa_ringbuffer.c | 1 + .../mod_gsmopen/pa_ringbuffer.h | 1 + .../mod_gsmopen/pablio.c | 1 + .../mod_gsmopen/pablio.h | 1 + .../mod_gsmopen/portaudio_devlist.c | 1 + .../mod_gsmopen/usb-cm-108-2.txt | 1 + .../mod_gsmopen/Makefile | 6 + .../mod_gsmopen/filtra48down8.c | 1 + .../mod_gsmopen/filtra8up48.c | 1 + .../mod_gsmopen/gsmopen.h | 1 + .../mod_gsmopen/gsmopen_protocol.c | 1 + .../mod_gsmopen/mod_gsmopen.c | 1 + .../mod_gsmopen/pa_ringbuffer.c | 1 + .../mod_gsmopen/pa_ringbuffer.h | 1 + .../mod_gsmopen/pablio.c | 1 + .../mod_gsmopen/pablio.h | 1 + .../mod_gsmopen/portaudio_devlist.c | 1 + .../mod_gsmopen/usb-cm-108-2.txt | 1 + src/mod/endpoints/mod_gsmopen/setmixers | 13 + src/mod/endpoints/mod_gsmopen/test.cc | 206 + .../endpoints/mod_gsmopen/usb-cm-108-2.txt | 62 + 267 files changed, 116342 insertions(+) create mode 100644 src/mod/endpoints/mod_gsmopen/Makefile create mode 100644 src/mod/endpoints/mod_gsmopen/Makefile.am create mode 100644 src/mod/endpoints/mod_gsmopen/README create mode 100644 src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/Makefile create mode 120000 src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/gsmopen.h create mode 120000 src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/gsmopen_protocol.c create mode 120000 src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/mod_gsmopen.c create mode 100644 src/mod/endpoints/mod_gsmopen/asterisk/Makefile create mode 100644 src/mod/endpoints/mod_gsmopen/asterisk/README create mode 100644 src/mod/endpoints/mod_gsmopen/asterisk/asound.conf create mode 100644 src/mod/endpoints/mod_gsmopen/asterisk/celliax.conf create mode 100644 src/mod/endpoints/mod_gsmopen/asterisk/celliax.h create mode 100644 src/mod/endpoints/mod_gsmopen/asterisk/celliax_additional.c create mode 100644 src/mod/endpoints/mod_gsmopen/asterisk/celliax_libcsv.c create mode 100644 src/mod/endpoints/mod_gsmopen/asterisk/celliax_libcsv.h create mode 100644 src/mod/endpoints/mod_gsmopen/asterisk/celliax_spandsp.c create mode 100644 src/mod/endpoints/mod_gsmopen/asterisk/celliax_spandsp.h create mode 100644 src/mod/endpoints/mod_gsmopen/asterisk/chan_celliax.c create mode 100755 src/mod/endpoints/mod_gsmopen/asterisk/ciapalo create mode 100644 src/mod/endpoints/mod_gsmopen/configs/asound.conf create mode 100644 src/mod/endpoints/mod_gsmopen/configs/gsmopen.conf.xml create mode 100644 src/mod/endpoints/mod_gsmopen/configs/gsmopen.conf.xml.motorola create mode 100644 src/mod/endpoints/mod_gsmopen/filtra48down8.c create mode 100644 src/mod/endpoints/mod_gsmopen/filtra8up48.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/README create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ABOUT-NLS create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/AUTHORS create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/COPYING create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ChangeLog create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/INSTALL create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/Makefile.am create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/Makefile.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/NEWS create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/README create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/TODO create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/acconfig.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/acinclude.m4 create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/aclocal.m4 create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/Makefile.am create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/Makefile.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmctl.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmpb.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsendsms.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsmsd.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsmsstore.cc create mode 100755 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/configure create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/configure.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.cron.d create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.default create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.init create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsmsmsrequeue create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsmsmsspool create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/changelog create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/compat create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/control create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/copyright create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.cron.d create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.default create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.dirs create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.docs create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.init create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.postinst create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.postrm create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.undocumented create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsmsiexfer.1 create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/libgsmme-dev.docs create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/rules create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/watch create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/FAQ create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/Makefile.am create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/Makefile.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/README.NLS create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/README.developers create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmctl.man create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsminfo.man create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmlib.lsm create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmpb.man create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsendsms.man create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsmsd.man create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsmsstore.man create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/Makefile.am create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/Makefile.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/README.sieme create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsm_sie_me.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsm_sie_me.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsmsiectl.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsmsiexfer.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/g41.patch create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsm_config.h.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.dirs create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.postinst create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.prerm create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.undocumented create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib.spec create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/Makefile.am create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/Makefile.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_at.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_at.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_cb.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_cb.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_error.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_error.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_event.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_event.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_map_key.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_me_ta.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_me_ta.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_nls.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_nls.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_parser.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_parser.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_phonebook.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_phonebook.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_port.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_codec.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_codec.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_store.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_store.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook_base.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook_base.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_sms_store.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_sms_store.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sysdep.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_unix_serial.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_unix_serial.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_util.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_util.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_win32_serial.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_win32_serial.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/ChangeLog create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/Makefile create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/Makefile.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/VERSION create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/bindtextdom.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/cat-compat.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/dcgettext.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/dgettext.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/explodename.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/finddomain.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettext.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettext.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettextP.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/hash-string.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/intl-compat.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/l10nflist.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/libgettext.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/linux-msg.sed create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/loadinfo.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/loadmsgcat.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/localealias.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/po2tbl.sed.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/textdomain.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/xopen-msg.sed create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/Makefile.in.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/POTFILES.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/cat-id-tbl.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/de.gmo create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/de.po create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/gsmlib.pot create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/stamp-cat-id create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/Makefile.am create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/Makefile.in create mode 100755 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/config.guess create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/config.rpath create mode 100755 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/config.sub create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/debugconfig.sh create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/depcomp create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/install-sh create mode 100755 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/ltconfig create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/ltmain.sh create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/missing create mode 100755 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/mkinstalldirs create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/stamp-h.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/Makefile.am create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/Makefile.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runparser.sh create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runsms.sh create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspb.sh create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspb2.sh create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspbi.sh create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runssms.sh create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spb.pb create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spb2.pb create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spbi1.pb create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spbi2-orig.pb create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testcb.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testgsmlib.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testparser-output.txt create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testparser.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testpb.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testpb2.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms-output.txt create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms2.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb-output.txt create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb2-output.txt create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspbi-output.txt create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testssms-output.txt create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testssms.cc create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/COPYING create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/Makefile.am create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/Makefile.in create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/README.win create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/getopt.c create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/getopt.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsm_config.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmctl.vcproj create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmlib.sln create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmlib.vcproj create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmpb.vcproj create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsendsms.vcproj create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsmsd.vcproj create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsmsstore.vcproj create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testgsmlib.vcproj create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testsms.vcproj create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testsms2.vcproj create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10.tar.gz create mode 100644 src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib_1.10-12ubuntu1.diff.gz create mode 100644 src/mod/endpoints/mod_gsmopen/gsmopen.h create mode 100644 src/mod/endpoints/mod_gsmopen/gsmopen_protocol.cpp create mode 100644 src/mod/endpoints/mod_gsmopen/mod_gsmopen.2008.vcproj create mode 100644 src/mod/endpoints/mod_gsmopen/mod_gsmopen.cpp create mode 100644 src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/Makefile create mode 120000 src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/gsmopen.h create mode 120000 src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/gsmopen_protocol.cpp create mode 120000 src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/mod_gsmopen.cpp create mode 100644 src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/Makefile create mode 120000 src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/gsmopen.h create mode 120000 src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/gsmopen_protocol.c create mode 120000 src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/mod_gsmopen.c create mode 100644 src/mod/endpoints/mod_gsmopen/pa_ringbuffer.c create mode 100644 src/mod/endpoints/mod_gsmopen/pa_ringbuffer.h create mode 100644 src/mod/endpoints/mod_gsmopen/pablio.c create mode 100644 src/mod/endpoints/mod_gsmopen/pablio.h create mode 100644 src/mod/endpoints/mod_gsmopen/portaudio_devlist.c create mode 100644 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/Makefile create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/filtra48down8.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/filtra8up48.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/gsmopen.h create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/gsmopen_protocol.cpp create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/mod_gsmopen.cpp create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pa_ringbuffer.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pa_ringbuffer.h create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pablio.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pablio.h create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/portaudio_devlist.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/usb-cm-108-2.txt create mode 100644 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/Makefile create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/filtra48down8.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/filtra8up48.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/gsmopen.h create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/gsmopen_protocol.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/mod_gsmopen.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pa_ringbuffer.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pa_ringbuffer.h create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pablio.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pablio.h create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/portaudio_devlist.c create mode 120000 src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/usb-cm-108-2.txt create mode 100755 src/mod/endpoints/mod_gsmopen/setmixers create mode 100644 src/mod/endpoints/mod_gsmopen/test.cc create mode 100644 src/mod/endpoints/mod_gsmopen/usb-cm-108-2.txt diff --git a/src/mod/endpoints/mod_gsmopen/Makefile b/src/mod/endpoints/mod_gsmopen/Makefile new file mode 100644 index 0000000000..9aff13615a --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/Makefile @@ -0,0 +1,9 @@ +MODNAME=mod_gsmopen +SVNDEF := -D'GSMOPEN_SVN_VERSION="$(shell svnversion -n .)"' +#LOCAL_CFLAGS += $(SVNDEF) -I/usr/src/gsmlib-1.10 +LOCAL_CFLAGS += $(SVNDEF) -I../../../../libs/spandsp/src -I../../../..//libs/tiff-3.8.2/libtiff +#LOCAL_LDFLAGS=-lasound -L/usr/src/gsmlib-1.10/gsmlib/.libs -lgsmme +LOCAL_LDFLAGS=-L../../../../libs/spandsp/src -lasound -lgsmme -lspandsp +LOCAL_OBJS=gsmopen_protocol.o +#OUR_OBJS += /usr/src/gsmlib-1.10/gsmlib/libgsmme.la +include ../../../../build/modmake.rules diff --git a/src/mod/endpoints/mod_gsmopen/Makefile.am b/src/mod/endpoints/mod_gsmopen/Makefile.am new file mode 100644 index 0000000000..bde175df8f --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/Makefile.am @@ -0,0 +1,7 @@ +include $(top_srcdir)/build/modmake.rulesam +MODNAME=mod_gsmopen +mod_LTLIBRARIES = mod_gsmopen.la +mod_gsmopen_la_SOURCES = mod_gsmopen.cpp gsmopen_protocol.cpp +mod_gsmopen_la_CFLAGS = $(AM_CFLAGS) -DGSMOPEN_SVN_VERSION=\"`cat $(switch_builddir)/.version`\" +mod_gsmopen_la_LIBADD = $(switch_builddir)/libfreeswitch.la +mod_gsmopen_la_LDFLAGS = -avoid-version -module -no-undefined -lasound -lgsmme -lspandsp diff --git a/src/mod/endpoints/mod_gsmopen/README b/src/mod/endpoints/mod_gsmopen/README new file mode 100644 index 0000000000..18659c1be4 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/README @@ -0,0 +1,35 @@ +GSMopen, GSM Endpoint and Trunk + +This is just a prototype. + +put this directory in freeswitch.trunk/src/mod/endpoints/ + +make clean; make; make install + +Is not getting its configuration from the configuration file, it's all hardcoded but it needs the configuration file. + +Copy gsmopen.conf.xml in /usr/local/freeswitch/conf/autoload_configs/ + +You must have the device on serial port /dev/ttyACM0 and the audio as second soundcard plughw:1 (if you do not have a first soundcard, just modprobe snd-dummy before to connect the usb thingy). + +Put the volumes (with alsamixer -c1 -Vall) as: speaker 80, autogain on, mic off, mic capt 0. + +Then, with alsamixer -c1 -Vcapture, be sure capture is active (eg, press the spacebar until the red CAPTURE appear). When it all working, adjust to your taste. + +It answer calls, make calls, receive sms, and send sms (with the CLI command "sendsms"). + +Copy ciapalo in /usr/local/bin/ (is the program automatically spawned when an SMS is received). + +Copy asound.conf in /etc/asound.conf, it will spare you cpu cycles when rate conversion is required (always). + +All documentation on compiling, using, configuring, +tricks and tweaks, possible problems at: + +http://wiki.freeswitch.org/wiki/GSMopen_GSM_Endpoint_and_Trunk + +Enjoy + +-giovanni + +< gmaruzz at gmail dot com > + diff --git a/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/Makefile b/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/Makefile new file mode 100644 index 0000000000..070f941a94 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/Makefile @@ -0,0 +1,6 @@ +MODNAME=mod_gsmopen +SVNDEF := -D'GSMOPEN_SVN_VERSION="$(shell svnversion -n .)"' +LOCAL_CFLAGS += $(SVNDEF) -Wno-error=address -DNO_GSMLIB -I../../../../../../libs/spandsp/src -I../../../../../..//libs/tiff-3.8.2/libtiff +LOCAL_LDFLAGS=-lasound -L../../../../../../libs/spandsp/src -lspandsp +LOCAL_OBJS=gsmopen_protocol.o +include ../../../../../../build/modmake.rules diff --git a/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/gsmopen.h b/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/gsmopen.h new file mode 120000 index 0000000000..663f1cbc4d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/gsmopen.h @@ -0,0 +1 @@ +../../gsmopen.h \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/gsmopen_protocol.c b/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/gsmopen_protocol.c new file mode 120000 index 0000000000..b03564bdd9 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/gsmopen_protocol.c @@ -0,0 +1 @@ +../../gsmopen_protocol.cpp \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/mod_gsmopen.c b/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/mod_gsmopen.c new file mode 120000 index 0000000000..a0686ea786 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/alsa_nogsmlib_nocplusplus/mod_gsmopen/mod_gsmopen.c @@ -0,0 +1 @@ +../../mod_gsmopen.cpp \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/Makefile b/src/mod/endpoints/mod_gsmopen/asterisk/Makefile new file mode 100644 index 0000000000..6aed86266e --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/Makefile @@ -0,0 +1,81 @@ +# +# Asterisk -- A telephony toolkit for Linux. +# +# Makefile for channel drivers +# +# Copyright (C) 1999-2005, Mark Spencer +# +# Mark Spencer +# +# Edited By Belgarath <> Aug 28 2004 +# Added bare bones ultrasparc-linux support. +# +# This program is free software, distributed under the terms of +# the GNU General Public License +# + +#ASTERISK INCLUDE FILES +#The directory that contains the Asterisk include files (eg: /usr/include or /usr/include/asterisk or /usr/src/asterisk/include or ...) +#AST_INCLUDE_DIR=/usr/src/off_dev/asterisk-1.2.rev137401/include +AST_INCLUDE_DIR=/usr/src/asterisk-1.4.27.1/include +#AST_INCLUDE_DIR=/usr/src/asterisk-1.6.0.10/include + +#ASTERISK VERSION +#Uncomment one of the following lines to match your Asterisk series +#CFLAGS+=-DASTERISK_VERSION_1_2 +CFLAGS+=-DASTERISK_VERSION_1_4 +#CFLAGS+=-DASTERISK_VERSION_1_6_0 + +CFLAGS+=-pipe -Wall -Wstrict-prototypes -Wmissing-prototypes -Wmissing-declarations +CFLAGS+=-g3 + + + +CFLAGS+=-I$(AST_INCLUDE_DIR) -I. +CFLAGS+=-D_REENTRANT -D_GNU_SOURCE +#CFLAGS+=-O6 +#CFLAGS+=-march=i586 +CFLAGS+=-fomit-frame-pointer +ifeq ($(shell uname -m),x86_64) +CFLAGS+=-fPIC +endif + +SVNDEF := -D'CELLIAX_SVN_VERSION="$(shell svnversion -n .)"' +CFLAGS += $(SVNDEF) + + +SOLINK=-shared -Xlinker -x +CHANNEL_LIBS=chan_celliax.so +CC=gcc + +OSARCH=$(shell uname -s) + +ifeq ($(findstring CYGWIN,$(OSARCH)),CYGWIN) +# definition of pthread_kill as a printf (or as a noop) is required for Asterisk (and celliax) to run on Cygwin +# without it, each time (often) pthread_kill is called (by any thread, with any signal, URG included), bad things happen +CC=gcc -D pthread_kill=cyg_no_pthreadkill +AST_DLL_DIR=/home/maruzz/devel/svn_asterisk_branches_12 +CYGSOLINK=-Wl,--out-implib=lib$@.a -Wl,--export-all-symbols cyg_no_pthread_kill.o +CYGSOLIB=-L/usr/lib/w32api -lrpcrt4 -L/lib/mingw -lwinmm -L$(AST_DLL_DIR) -lasterisk.dll -L$(AST_DLL_DIR)/res -lres_features.so +CHANNEL_LIBS=cyg_no_pthread_kill.o chan_celliax.so +endif + +all: $(CHANNEL_LIBS) + +clean: + rm -f *.so *.o *.so.a + + +#chan_celliax section begins + +#to debug threads and lock on 1.4 uncomment the following +#CFLAGS+=-include /usr/src/asterisk/include/asterisk/autoconfig.h + +cyg_no_pthread_kill.o: cyg_no_pthread_kill.c + $(CC) $(CFLAGS) -c -o cyg_no_pthread_kill.o cyg_no_pthread_kill.c +chan_celliax.o: chan_celliax.c + $(CC) $(CFLAGS) -c -o chan_celliax.o chan_celliax.c +chan_celliax.so: chan_celliax.o celliax_spandsp.o celliax_libcsv.o celliax_additional.o + $(CC) $(SOLINK) -o $@ ${CYGSOLINK} chan_celliax.o celliax_spandsp.o celliax_libcsv.o celliax_additional.o -lm -ldl -lasound ${CYGSOLIB} +#chan_celliax section ends + diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/README b/src/mod/endpoints/mod_gsmopen/asterisk/README new file mode 100644 index 0000000000..c5921ca6b3 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/README @@ -0,0 +1,96 @@ +************************************************************** +* CHAN_CELLIAX DRIVER FOR AN EXISTING ASTERISK INSTALLATION +* (works for Asterisk 1.2.xx 1.4.xx 1.6.0.xx series) +* (do NOT works for Asterisk 1.6.1.xx series) +************************************************************** +============================================================== +1) To build celliax you need the ALSA development libraries +============================================================== + +To build celliax on Linux you need to install ALSA-dev libs + +You can do it on Debian/Ubuntu with: +# apt-get install libasound2-dev + +You can do it on Fedora/CentOS with: +# yum --nogpgcheck -y install alsa-lib-devel + +=============================================================== +2) build chan_celliax +=============================================================== + +go into the celliax source directory, edit the Makefile, +insert the asterisk version (1.2.x or 1.4.x or 1.6.0.x, +NOT 1.6.1.x), the location of your asterisk sources, then + +# make clean +# make + +copy chan_celliax.so in the asterisk modules directory + +=============================================================== +2) configure chan_celliax and asterisk +=============================================================== + +edit and copy celliax.conf in the asterisk configuration +directory + +copy ciapalo (or your program that accepts text in stdini) in +the location defined in celliax.conf (sms_receiving_program) + +edit modules.conf and put noload in front of *BOTH* chan_oss.so +AND chan_alsa.so AND chan_console.so + +copy asound.conf in /etc/asound.conf + +if you enable debug in logger.conf and "set debug 100" on +Asterisk, you'll get *a lot* of info on celliax inner workings + +=============================================================== +3) Troubleshooting +=============================================================== +Check that you set the correct serial device in celliax.conf +You can check how the device is called on your platform with: +dmesg | grep ttyU +dmesg | grep ttyA + +Check that you set the correct audio device in celliax.conf +You can check how the device is called on your platform with: +aplay -l +it will give you the number to put on "plughw:N" in celliax.conf + +Check the volume for both play and capture, and that capture +is activated (press spacebar when alsamixer in capture mode) +alsamixer -c[soundcard_number] -Vplay +alsamixer -c[soundcard_number] -Vcapture +we found good results with capt(31) autogain(on) speaker(75) + +If you get double digits (bounces) on DTMFs, check if the capture +volume is too high + +The SMSs are managed in Unicode (UTF8) for international characters +compatibility. Check that your console and/or text editor displays +UTF8 characters + +If you have bad sound, it's a timing problem. Use a 1000HZ kernel, +or add a timing device (ztdummy or zaptel interfaces) +*************************************************************** +* END CHAN_CELLIAX DRIVER FOR AN EXISTING ASTERISK INSTALLATION +*************************************************************** + + + +chan_celliax adds to Asterisk the DIALPLAN application: + + CelliaxSendsms + +You can type at the Asterisk CLI 'show application [application]' +to obtain more specific info on usage. + + + +Enjoy! + +-giovanni + +< gmaruzz at gmail dot com > diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/asound.conf b/src/mod/endpoints/mod_gsmopen/asterisk/asound.conf new file mode 100644 index 0000000000..71d6119670 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/asound.conf @@ -0,0 +1,2 @@ +#defaults.pcm.rate_converter "speexrate" +defaults.pcm.rate_converter "linear" diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/celliax.conf b/src/mod/endpoints/mod_gsmopen/asterisk/celliax.conf new file mode 100644 index 0000000000..1b84c577d8 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/celliax.conf @@ -0,0 +1,205 @@ +;; +;; +; Celliax Asterisk Driver +; +; Configuration file +; lines beginning with semicolon (" are ignored (commented out) +; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +; +; The first interface (named line0) +[line0] +;;;;;;;;;;;;;;;;;;;;;;;;; +;;;;;;;;;;;;;;;;;;;;;;;;; +; general settings, valid on all platforms +; +; +; Default language +; +language=en +; +; Default context (is overridden with @context syntax) +; +context=default +; +; Default extension (in extensions.conf) where incoming calls land +; +extension=s +; +;;;;;;;;;;;;;;;;;;;;;;;;; +;;;;;;;;;;;;;;;;;;;;;;;;; +; Debugging settings, valid globally for all interfaces on all platforms +; +; the debug values are global for all the interfaces. +; +; default is no celliax debugging output, you **have** to activate debugging here to obtain debugging from celliax +; +; To see the debugging output you have to "set debug 100" from the Asterisk CLI or launch +; Asterisk with -ddddddddddd option, and have the logger.conf file activating debug info for console and messages +; +; You can activate each of the following separately, but you can't disactivate. Eg: debug_at=no does not subtract debug_at from debug_all +; debug_all activate all possible debugging info +; +;debug_all=yes +debug_at=yes +;debug_fbus2=yes +debug_serial=yes +debug_pbx=yes +debug_sound=yes +;debug_locks=yes +debug_call=yes +;debug_monitorlocks=yes +;debug_cvm=yes + +;;;;;;;;;;;;;;;;;;;;;;;;; +;;;;;;;;;;;;;;;;;;;;;;;;; +; This is the program that will receive in stdin the incoming SMSs +sms_receiving_program=/usr/local/asterisk/usr/sbin/ciapalo + +;;;;;;;;;;;;;;;;;;;;;;;;; +;;;;;;;;;;;;;;;;;;;;;;;;; +; serial settings, valid for all platforms +; +;control_device_protocol can be AT or FBUS2 or NO_SERIAL (with NO_SERIAL the speed and name of the port are ignored) +control_device_protocol=at + +;speed of the serial port +control_device_speed=115200 + +;name of the serial port device +control_device_name=/dev/ttyACM0 ; this is a Celliax Official Device, recognized as a modem by Linux +;control_device_name=/dev/ttyUSB0 ; this is an alternative form of a Celliax Official Device, recognized as a modem by Linux + +;watch the soundcard for noise (ring), because the serial port do not tell us about incoming calls (eg 3310nokia), NO_SERIAL protocol watch for acoustic ring in any case +need_acoustic_ring=0 + +;audio noise threshold beyond which we declare there is a ring (512 is default, put it to 1024 or 2048 if you have false positive), ignored if not watching for ring +dsp_silence_threshold=1024 + +;;;;;;;;;;;;;;;;;;;;;;;;; +;;;;;;;;;;;;;;;;;;;;;;;;; +; audio boost settings, valid for all platforms, to compensate for different soundcard/phone input/output signal levels +; tweak it if you get horrible (or not hearable) sound +; +;boost can be positive or negative (-40 to +40) in db +;experiment to find which values are best for your soundcard +playback_boost=0 ; +capture_boost=0 ; + +;;;;;;;;;;;;;;;;;;;;;;;;;;; +; which audio device to use +;;;;;;;;;;;;;;;;;;;;;;;;;;; + +;names of the sound devices in linux +;if you don't use skype on this interface (eg don't need to share the audio device with other applications while celliax is running), use the plughw:n devices (plughw:0 is the first, plughw:1 is the second soundcard, etc). They have the best latency +;if you use skype on this interface use the default:n devices (default:0 is the first, default:1 is the second soundcard, etc). They have worst latency, but you can share them + +alsa_capture_device_name=plughw:1 +alsa_playback_device_name=plughw:1 + +alsa_period_size=160 +alsa_periods_in_buffer=4 + +;;;;;;;;;;;;;;;;;;;;;;;;; +;;;;;;;;;;;;;;;;;;;;;;;;; +; at "modem" commands settings for this interface (if controldevice_protocol is not AT they are ignored) +; +;what the modem is expecting in the part of the dial command before the number to be dialed (eg: ATD) +;at_dial_pre_number=AT+CKPD="EEE +at_dial_pre_number=ATD +;what the modem is expecting in the part of the dial command after the number to be dialed. If you want it to wait for a semicolon (;), just comment out the followin line. Wait for semicolon is the default +;at_dial_post_number=S" +;what the modem will answer after succesful execution of the dial command +at_dial_expect=OK + +;command to hangup the current call +;at_hangup=AT+CKPD="EEE" +at_hangup=ATH +;what the modem will answer after succesful execution of the hangup command +at_hangup_expect=OK + +;command to answer an incoming call +at_answer=ATA +;what the modem will answer after succesful execution of the answer command +at_answer_expect=OK + +;pause right after serial port opening, before any command is sent, in usecs (1million usec= 1sec) +at_initial_pause=500000 +;custom commands to be sent after the initial pause and before the "built in" initialization commands, and what the modem is expected to send as reply +;the first empty string stop the preinit sending +at_preinit_1=atciapa ; nonsense entry, just to show the preinit +at_preinit_1_expect=OK +at_preinit_2= +at_preinit_2_expect= +at_preinit_3= +at_preinit_3_expect= +at_preinit_4= +at_preinit_4_expect= +at_preinit_5= +at_preinit_5_expect= +;pause right after the custom preinit commands, before any "built in" command is sent, in usecs (1million usec= 1sec) +at_after_preinit_pause=500000 +;custom commands to be sent after the "built in" initialization commands, and what the modem is expected to send as reply +;the first empty string stop the postinit sending +;at_postinit_1=atcucu ; nonsense entry, just to show the postinit +at_postinit_1=at+cmic=0,9 ; modem's microphone sensitivity (our spk) +at_postinit_1_expect=OK +at_postinit_2=AT+CKPD="EEE" ;send three "end" buttonpress, to have the phone in a sane state, ready to dialing with furter CKPDs ***THIS IS IMPORTANT, needed on c650*** +at_postinit_2_expect=OK +at_postinit_3=AT+CSSN=1,0 +at_postinit_3_expect=OK +at_postinit_4=at+sidet=0 ; no sidetone in modem, please +at_postinit_4_expect=OK +at_postinit_5=at+clvl=99 ; modem's speaker level, out mic +at_postinit_5_expect=OK + +;what command to query the battery status, and what the modem is expected to send as reply +at_query_battchg=AT+CBC +at_query_battchg_expect=OK +;what command to query the signal status, and what the modem is expected to send as reply +at_query_signal=AT+CSQ +at_query_signal_expect=OK + +;what command to send a DTMF +at_send_dtmf=AT+VTS + +;the modem will send us the following messages to signal that the visual indicators on the phone has changed because of events (without us to ask for them), loosely based on ETSI standard (see CIND/CIEV/CMER in ETSI). Variable by manufacturer and phone model +; no service +at_indicator_noservice_string=+CIEV: 2,0 +; no signal +at_indicator_nosignal_string=+CIEV: 5,0 +; low signal +at_indicator_lowsignal_string=+CIEV: 5,1 +; low battery +at_indicator_lowbattchg_string=+CIEV: 0,1 +; no battery battery +at_indicator_nobattchg_string=+CIEV: 0,0 +; call is up +at_indicator_callactive_string=+CIEV: 3,1 +; call is down +at_indicator_nocallactive_string=+CIEV: 3,0 +; call is no more in process +at_indicator_nocallsetup_string=+CIEV: 6,0 +; call incoming is in process +at_indicator_callsetupincoming_string=+CIEV: 6,1 +; call outgoing is in process +at_indicator_callsetupoutgoing_string=+CIEV: 6,2 +; remote party is ringing because of our call outgoing +at_indicator_callsetupremoteringing_string=+CIEV: 6,3 + +;call processing unsolicited messages, proprietary for each phone manufacturer +;the modem will send us the following mesage to signal that the line is idle (eg. after an outgoing call has failed, or after hangup) +at_call_idle=+MCST: 1 +;the modem will send us the following mesage to signal that there is an incoming voice call +at_call_incoming=+MCST: 2 +;the modem will send us the following mesage to signal that there is an active call (eg. the remote party has answered us, or we answered them) +;at_call_active=+MCST: 3 +at_call_active=+CSSI: 7 +;the modem will send us the following mesage to signal that our outgoing call has failed +at_call_failed=+MCST: 65 +;the modem will send us the following mesage to signal that our outgoing call is in the calling phase +;at_call_calling=+MCST: 64 +at_call_calling=+CSSI: 1 + diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/celliax.h b/src/mod/endpoints/mod_gsmopen/asterisk/celliax.h new file mode 100644 index 0000000000..ed8c2b122c --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/celliax.h @@ -0,0 +1,909 @@ +//indent -gnu -ts4 -br -brs -cdw -lp -ce -nbfda -npcs -nprs -npsl -nbbo -saf -sai -saw -cs -bbo -nhnl -nut -sob -l90 +#undef GIOVA48 +#define CELLIAX_ALSA +#ifndef _CELLIAX_H_ +#define _CELLIAX_H_ + +#ifndef CELLIAX_SVN_VERSION +#define CELLIAX_SVN_VERSION "????NO_REVISION???" +#endif + +#include /* needed here for conditional compilation on version.h */ + /* the following #defs are for LINUX */ +#ifndef __CYGWIN__ +#ifndef ASTERISK_VERSION_1_6_0 +#ifndef ASTERISK_VERSION_1_4 +#ifndef ASTERISK_VERSION_1_2 +#define ASTERISK_VERSION_1_4 +#if(ASTERISK_VERSION_NUM == 999999) +#undef ASTERISK_VERSION_1_4 +#elif(ASTERISK_VERSION_NUM < 10400) +#undef ASTERISK_VERSION_1_4 +#endif /* ASTERISK_VERSION_NUM == 999999 || ASTERISK_VERSION_NUM < 10400 */ +#endif /* ASTERISK_VERSION_1_2 */ +#endif /* ASTERISK_VERSION_1_4 */ +#endif /* ASTERISK_VERSION_1_6_0 */ +#ifdef ASTERISK_VERSION_1_2 +#undef ASTERISK_VERSION_1_4 +#endif /* ASTERISK_VERSION_1_2 */ +#ifdef ASTERISK_VERSION_1_6_0 +#define ASTERISK_VERSION_1_4 +#endif /* ASTERISK_VERSION_1_6_0 */ +#define CELLIAX_DIR +#undef CELLIAX_LIBCSV +#endif /* NOT __CYGWIN__ */ + /* the following #defs are for WINDOWS */ +#ifdef __CYGWIN__ +#undef ASTERISK_VERSION_1_4 +#undef ASTERISK_VERSION_1_6_0 +#define CELLIAX_DIR +#undef CELLIAX_LIBCSV +#endif /* __CYGWIN__ */ + +/* CELLIAX_CVM */ +#undef CELLIAX_CVM +/* CELLIAX_CVM */ + +#undef CELLIAX_FBUS2 +#define CELLIAX_DIR +#define CELLIAX_LIBCSV + +/* INCLUDES */ +#ifdef ASTERISK_VERSION_1_6_0 +#include /* some asterisk-devel package do not contains asterisk.h, but seems that is needed for the 1.6 series, at least from trunk */ +#endif /* ASTERISK_VERSION_1_6_0 */ +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#ifndef ASTERISK_VERSION_1_4 +#include +#include +#endif /* ASTERISK_VERSION_1_4 */ +#ifndef CELLIAX_ALSA +#include "pablio.h" +#endif /* CELLIAX_ALSA */ +//#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#ifdef ASTERISK_VERSION_1_6_0 +#include +#include +#endif /* ASTERISK_VERSION_1_6_0 */ +#ifdef ASTERISK_VERSION_1_4 +#include +#include +#include +#include +#endif /* ASTERISK_VERSION_1_4 */ +#ifdef ASTERISK_VERSION_1_2 +#include +#include +#endif /* ASTERISK_VERSION_1_2 */ +#ifdef HAVE_CONFIG_H +#include +#endif +#include "celliax_spandsp.h" +#ifdef CELLIAX_LIBCSV +#include "celliax_libcsv.h" +#endif /* CELLIAX_LIBCSV */ +#ifdef __CYGWIN__ +#include +#endif /* __CYGWIN__ */ +#ifndef AST_DIGIT_ANYDIG +#define AST_DIGIT_ANYDIG "0123456789*#" +#else +#warning Please review Celliax AST_DIGIT_ANYDIG +#endif +#ifndef _ASTERISK_H +#define AST_CONFIG_MAX_PATH 255 /* defined in asterisk.h, but some asterisk-devel package do not contains asterisk.h */ +extern char ast_config_AST_CONFIG_DIR[AST_CONFIG_MAX_PATH]; +int ast_register_atexit(void (*func) (void)); /* in asterisk.h, but some asterisk-devel package do not contains asterisk.h */ +void ast_unregister_atexit(void (*func) (void)); /* in asterisk.h, but some asterisk-devel package do not contains asterisk.h */ +#endif +#ifdef CELLIAX_ALSA +#define ALSA_PCM_NEW_HW_PARAMS_API +#define ALSA_PCM_NEW_SW_PARAMS_API +#include +#endif /* CELLIAX_ALSA */ + +/* DEFINITIONS */ +/* LUIGI RIZZO's magic */ +/* boost support. BOOST_SCALE * 10 ^(BOOST_MAX/20) must + * be representable in 16 bits to avoid overflows. + */ +#define BOOST_SCALE (1<<9) +#define BOOST_MAX 40 /* slightly less than 7 bits */ +/* call flow from the device */ +#define FBUS2_OUTGOING_ACK 999 +#define FBUS2_SECURITY_COMMAND_ON 444 +#define CALLFLOW_CALL_IDLE AST_STATE_DOWN +#define CALLFLOW_INCOMING_RING AST_STATE_RING +#define CALLFLOW_CALL_DIALING AST_STATE_DIALING +#define CALLFLOW_CALL_LINEBUSY AST_STATE_BUSY +#define CALLFLOW_CALL_ACTIVE 300 +#define CALLFLOW_INCOMING_HANGUP 100 +#define CALLFLOW_CALL_RELEASED 101 +#define CALLFLOW_CALL_NOCARRIER 102 +#define CALLFLOW_CALL_INFLUX 103 +#define CALLFLOW_CALL_INCOMING 104 +#define CALLFLOW_CALL_FAILED 105 +#define CALLFLOW_CALL_NOSERVICE 106 +#define CALLFLOW_CALL_OUTGOINGRESTRICTED 107 +#define CALLFLOW_CALL_SECURITYFAIL 108 +#define CALLFLOW_CALL_NOANSWER 109 +#define CALLFLOW_CALL_HANGUP_REQUESTED 110 + //fixme CALLFLOW_GOT_IMEI to be removed +#define CALLFLOW_GOT_IMEI 1009 + //fixme CALLFLOW_INCOMING_CALLID to be removed +#define CALLFLOW_INCOMING_CALLID 1019 +#define AT_OK 0 +#define AT_ERROR 1 +/* FBUS2 (old Nokia phones) undocumented proprietary protocol */ +#define FBUS2_ACK_BYTE 0x7f +#define FBUS2_CALL_CALLID 0x05 +#define FBUS2_CALL_HANGUP 0x04 +#define FBUS2_CALL_STATUS_OFF 0x01 +#define FBUS2_CALL_STATUS_ON 0x02 +#define FBUS2_COMMAND_BYTE_1 0x00 +#define FBUS2_COMMAND_BYTE_2 0x01 +#define FBUS2_DEVICE_PC 0x0c +#define FBUS2_DEVICE_PHONE 0x00 +#define FBUS2_IRDA_FRAME_ID 0x1c +#define FBUS2_IS_LAST_FRAME 0x01 +#define FBUS2_MAX_TRANSMIT_LENGTH 120 +#define FBUS2_NETWORK_STATUS_REGISTERED 0x71 +#define FBUS2_SECURIY_CALL_COMMAND_ANSWER 0x02 +#define FBUS2_SECURIY_CALL_COMMAND_CALL 0x01 +#define FBUS2_SECURIY_CALL_COMMAND_RELEASE 0x03 +#define FBUS2_SECURIY_CALL_COMMANDS 0x7c +#define FBUS2_SECURIY_EXTENDED_COMMAND_ON 0x01 +#define FBUS2_SECURIY_EXTENDED_COMMANDS 0x64 +#define FBUS2_SECURIY_IMEI_COMMAND_GET 0x00 +#define FBUS2_SECURIY_IMEI_COMMANDS 0x66 +#define FBUS2_SEQNUM_MAX 0x47 +#define FBUS2_SEQNUM_MIN 0x40 +#define FBUS2_SERIAL_FRAME_ID 0x1e +#define FBUS2_SMS_INCOMING 0x10 +#define FBUS2_TYPE_CALL 0x01 +#define FBUS2_TYPE_CALL_DIVERT 0x06 +#define FBUS2_TYPE_CALL_STATUS 0x0d +#define FBUS2_TYPE_NETWORK_STATUS 0x0a +#define FBUS2_TYPE_SECURITY 0x40 +#define FBUS2_TYPE_SMS 0x02 +#define FBUS2_TYPE_MODEL_ASK 0xd1 +#define FBUS2_TYPE_MODEL_ANSWER 0xd2 +//#define FBUS2_TYPE_MODEL_ANSWER 0xffffffd2 +#ifdef CELLIAX_CVM +#define CVM_BUSMAIL_SEQNUM_MAX 0x7 +#endif /* CELLIAX_CVM */ +/* debugging bitmask */ +#define DEBUG_SOUND 1 +#define DEBUG_SERIAL 2 +#define DEBUG_SKYPE 4 +#define DEBUG_AT 8 +#define DEBUG_FBUS2 16 +#define DEBUG_CALL 32 +#define DEBUG_LOCKS 64 +#define DEBUG_PBX 128 +#define DEBUG_MONITORLOCKS 256 +#ifndef CELLIAX_CVM +#define DEBUG_ALL DEBUG_SOUND|DEBUG_SERIAL|DEBUG_SKYPE|DEBUG_AT|DEBUG_FBUS2|DEBUG_CALL|DEBUG_PBX|DEBUG_LOCKS|DEBUG_MONITORLOCKS +#else +#define DEBUG_CVM 512 +#define DEBUG_ALL DEBUG_SOUND|DEBUG_SERIAL|DEBUG_SKYPE|DEBUG_AT|DEBUG_FBUS2|DEBUG_CALL|DEBUG_PBX|DEBUG_LOCKS|DEBUG_MONITORLOCKS|DEBUG_CVM +#endif /* CELLIAX_CVM */ +/* wrappers for ast_log */ +#define DEBUGA_SOUND(...) if (celliax_debug & DEBUG_SOUND) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_SOUND %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define DEBUGA_SERIAL(...) if (celliax_debug & DEBUG_SERIAL) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_SERIAL %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define DEBUGA_SKYPE(...) if (celliax_debug & DEBUG_SKYPE) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_SKYPE %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define DEBUGA_AT(...) if (celliax_debug & DEBUG_AT) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_AT %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define DEBUGA_FBUS2(...) if (celliax_debug & DEBUG_FBUS2) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_FBUS2 %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define DEBUGA_CALL(...) if (celliax_debug & DEBUG_CALL) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_CALL %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define DEBUGA_PBX(...) if (celliax_debug & DEBUG_PBX) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_PBX %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#ifdef CELLIAX_CVM +#define DEBUGA_CVM(...) if (celliax_debug & DEBUG_CVM) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_CVM %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#endif /* CELLIAX_CVM */ +#define ERRORA(...) ast_log(LOG_ERROR, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][ERROR %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define NOTICA(...) ast_log(LOG_NOTICE, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][NOTICE %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define WARNINGA(...) ast_log(LOG_WARNING, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][WARNING %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +/* macros for logging */ +#define CELLIAX_P_LOG p ? p->owner : NULL, (unsigned long)pthread_self(), __LINE__, p ? p->name ? p->name : "none" : "none", p ? p->owner ? p->owner->_state : -1 : -1, p ? p->interface_state : -1, p ? p->phone_callflow : -1 +#define CELLIAX_TMP_LOG tmp ? tmp->owner : NULL, (unsigned long)pthread_self(), __LINE__, tmp ? tmp->name ? tmp->name : "none" : "none", tmp ? tmp->owner ? tmp->owner->_state : -1 : -1, tmp ? tmp->interface_state : -1, tmp ? tmp->phone_callflow : -1 +/* logging wrappers for ast_mutex_lock and ast_mutex_unlock */ +#define LOKKA(x) if (celliax_debug & DEBUG_LOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_LOCKS %-5d][%-10s][%2d,%2d,%2d] going to lock %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->fbus2_outgoing_list_lock ? "FBUS2_OUTGOING_LIST_LOCK" : "?????"); if (ast_mutex_lock(x)) ast_log(LOG_ERROR, "ast_mutex_lock failed, BAD\n"); if (celliax_debug & DEBUG_LOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_LOCKS %-5d][%-10s][%2d,%2d,%2d] locked %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->fbus2_outgoing_list_lock ? "FBUS2_OUTGOING_LIST_LOCK" : "?????"); +#define UNLOCKA(x) if (celliax_debug & DEBUG_LOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_LOCKS %-5d][%-10s][%2d,%2d,%2d] going to unlock %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->fbus2_outgoing_list_lock ? "FBUS2_OUTGOING_LIST_LOCK" : "?????"); if (ast_mutex_unlock(x)) ast_log(LOG_ERROR, "ast_mutex_lock failed, BAD\n"); if (celliax_debug & DEBUG_LOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_LOCKS %-5d][%-10s][%2d,%2d,%2d] unlocked %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->fbus2_outgoing_list_lock ? "FBUS2_OUTGOING_LIST_LOCK" : "?????"); +#define CVM_LOKKA(x) if (celliax_debug & DEBUG_LOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_LOCKS %-5d][%-10s][%2d,%2d,%2d] going to lock %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->cvm_busmail_outgoing_list_lock ? "FBUS2_OUTGOING_LIST_LOCK" : "?????"); if (ast_mutex_lock(x)) ast_log(LOG_ERROR, "ast_mutex_lock failed, BAD\n"); if (celliax_debug & DEBUG_LOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_LOCKS %-5d][%-10s][%2d,%2d,%2d] locked %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->cvm_busmail_outgoing_list_lock ? "CVM_BUSMAIL_OUTGOING_LIST_LOCK" : "?????"); +#define CVM_UNLOCKA(x) if (celliax_debug & DEBUG_LOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_LOCKS %-5d][%-10s][%2d,%2d,%2d] going to unlock %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->cvm_busmail_outgoing_list_lock ? "FBUS2_OUTGOING_LIST_LOCK" : "?????"); if (ast_mutex_unlock(x)) ast_log(LOG_ERROR, "ast_mutex_lock failed, BAD\n"); if (celliax_debug & DEBUG_LOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_LOCKS %-5d][%-10s][%2d,%2d,%2d] unlocked %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->cvm_busmail_outgoing_list_lock ? "CVM_BUSMAIL_OUTGOING_LIST_LOCK" : "?????"); +#define PUSHA_UNLOCKA(x) pthread_cleanup_push(celliax_unlocka_log, (void *) x); +#define POPPA_UNLOCKA(x) pthread_cleanup_pop(0); +#define MONITORLOKKA(x) if (celliax_debug & DEBUG_MONITORLOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_MONITORLOCKS %-5d][%-10s][%2d,%2d,%2d] going to lock %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->fbus2_outgoing_list_lock ? "FBUS2_OUTGOING_LIST_LOCK" : "?????"); if (ast_mutex_lock(x)) ast_log(LOG_ERROR, "ast_mutex_lock failed, BAD\n"); if (celliax_debug & DEBUG_MONITORLOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_MONITORLOCKS %-5d][%-10s][%2d,%2d,%2d] locked %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->fbus2_outgoing_list_lock ? "FBUS2_OUTGOING_LIST_LOCK" : "?????"); +#define MONITORUNLOCKA(x) if (celliax_debug & DEBUG_MONITORLOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_MONITORLOCKS %-5d][%-10s][%2d,%2d,%2d] going to unlock %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->fbus2_outgoing_list_lock ? "FBUS2_OUTGOING_LIST_LOCK" : "?????"); if (ast_mutex_unlock(x)) ast_log(LOG_ERROR, "ast_mutex_lock failed, BAD\n"); if (celliax_debug & DEBUG_MONITORLOCKS) ast_log(LOG_DEBUG, "rev "CELLIAX_SVN_VERSION "[%p|%-7lx][DEBUG_MONITORLOCKS %-5d][%-10s][%2d,%2d,%2d] unlocked %p (%s)\n", CELLIAX_P_LOG, x, x == &celliax_monlock ? "MONLOCK" : x == &celliax_iflock ? "IFLOCK" : x == &celliax_usecnt_lock ? "USECNT_LOCK" : x == &p->controldev_lock ? "CONTROLDEV_LOCK" : x == &p->fbus2_outgoing_list_lock ? "FBUS2_OUTGOING_LIST_LOCK" : "?????"); +/* macros used for config file parsing */ +#define M_BOOL(tag, dst) M_F(tag, (dst) = ast_true(__val) ) +#define M_END(x) x; +#define M_F(tag, f) if (!strcasecmp((__s), tag)) { f; } else +#ifdef ASTERISK_VERSION_1_6_0 +#define M_START(var, val) const char *__s = var; const char *__val = val; +#else +#define M_START(var, val) char *__s = var; char *__val = val; +#endif /* ASTERISK_VERSION_1_6_0 */ +#define M_STR(tag, dst) M_F(tag, ast_copy_string(dst, __val, sizeof(dst))) +#define M_UINT(tag, dst) M_F(tag, (dst) = strtoul(__val, NULL, 0) ) +/* which protocol we use to control the phone through serial device */ +#ifdef CELLIAX_CVM +#define PROTOCOL_CVM_BUSMAIL 5 +#endif /* CELLIAX_CVM */ +#define PROTOCOL_ALSA_VOICEMODEM 4 +#define PROTOCOL_AT 2 +#define PROTOCOL_FBUS2 1 +#define PROTOCOL_NO_SERIAL 3 +#ifndef GIOVA48 +#define CELLIAX_FRAME_SIZE 160 +#else //GIOVA48 +#define CELLIAX_FRAME_SIZE 960 +#endif //GIOVA48 +#define AT_BUFSIZ 8192 +#define AT_MESG_MAX_LENGTH 2048 /* much more than 10 SMSs */ +#define AT_MESG_MAX_LINES 256 /* 256 lines, so it can contains the results of AT+CLAC, that gives all the AT commands the phone supports */ + +#ifdef CELLIAX_CVM +/* MAIL PRIMITIVES */ +/* CVM -> CELLIAX */ +#define API_PP_LOCKED_IND 0x8558 //PP locked with FP +#define API_PP_UNLOCKED_IND 0x8559 //PP out of service, unlocked from FP + +#define API_PP_SETUP_IND 0x8574 //Incoming call to PP + +#define API_PP_SETUP_IND_CALL_TYPE_OFFSET 0x0 +#define API_PP_SETUP_IND_RING_TYPE_OFFSET 0x1 + +#define API_PP_SETUP_IND_CALL_EXT 0x0 +#define API_PP_SETUP_IND_CALL_INT 0x1 + +#define API_PP_SETUP_IND_RING_INT_CALL 0x40 +#define API_PP_SETUP_IND_RING_PAGE_ALL 0x46 + +#define API_PP_SETUP_ACK_IND 0x857F //internal connection established with FPs, waiting for handsetnumber + +#define API_PP_CONNECT_IND 0x8576 //air-link established with FPs +#define API_PP_CONNECT_CFM 0x8578 //PP answered incoming call + +#define API_PP_ALERT_IND 0x8581 +#define API_PP_ALERT_ON_IND 0x857D +#define API_PP_ALERT_OFF_IND 0x857E + +#define API_PP_SIGNAL_ON_IND 0x2F9C +#define API_PP_SIGNAL_OFF_IND 0x2F9D + +#define API_PP_RELEASE_IND 0x857B +#define API_PP_RELEASE_CFM 0x857A +#define API_PP_REJECT_IND 0x8564 + +#define API_PP_ACCESS_RIGHTS_CFM 0x8568 +#define API_PP_ACCESS_RIGHTS_REJ 0x8569 + +#define API_PP_DELETE_SUBS_CFM 0x8561 +#define API_PP_REMOTE_DELETE_SUBS_CFM 0x2F9F + +#define API_PP_CLIP_IND 0x2F93 +#define API_PP_SW_STATUS_IND 0x2FC2 +#define API_PP_MESSAGE_WAITING_IND 0x2FA1 + +#define CVM_PP_PLUG_STATUS_IND 0x2F4F +#define CVM_PP_LINE_STATUS_IND 0x2F53 +#define CVM_PP_ON_KEY_IND 0x2F64 + +#define API_PP_READ_RSSI_CFM 0x2FC7 +#define API_PP_ALERT_BROADCAST_IND 0x2FA3 + +/* CELLIAX -> CVM */ +#define API_PP_LOCK_REQ 0x8554 //select FP to lock once +#define API_PP_SETUP_REQ 0x8571 //setup air-link PP<->FP + +#define API_PP_KEYPAD_REQ 0x858A //send string for dialing + +#define API_PP_CONNECT_REQ 0x8577 //answer incoming call + +#define API_PP_ALERT_REQ 0x2F8D //inform FP that alering is started + +#define API_PP_RELEASE_REQ 0x8579 //release connection +#define API_PP_RELEASE_RES 0x857C //confirm FP initiated release of connection +#define API_PP_REJECT_REQ 0x8565 //PP reject incoming call + +#define API_PP_ACCESS_RIGHTS_REQ 0x8566 //init registration to FP +#define API_PP_DELETE_SUBS_REQ 0x8560 //deregister from FP (locally only in PP) +#define API_PP_REMOTE_DELETE_SUBS_REQ 0x2F9E //remotly deregister from FP + +#define API_PP_STOP_PROTOCOL_REQ 0x2FC4 //stop protocol from running (even registration) + +#define API_PP_READ_RSSI_REQ 0x2FC6 //RSSI readout request +#define API_PP_READ_RSSI_CFM 0x2FC7 //RSSI readout result + +#define CVM_PP_AUDIO_OPEN_REQ 0x2F0E //Enable audio +#define CVM_PP_AUDIO_CLOSE_REQ 0x2F0F //Disable audio + +#define CVM_PP_AUDIO_SET_VOLUME_REQ 0x2F1D //set volume + +#define CVM_PP_AUDIO_UNMUTE_MIC_REQ 0x2F1A //unmute mic +#define CVM_PP_AUDIO_MUTE_MIC_REQ 0x2F19 //mute mic + +#define CVM_PP_AUDIO_HS_PLUG_IND 0x2F1C //mute mic + +#define CVM_PP_AUDIO_OPEN_ADPCM_OFF_REQ 0x2F68 //open audio even before making connection + +/* END OF MAIL PRIMITIVES */ + +enum CvmLockState { + CVM_UNKNOWN_LOCK_STATE = 0, + CVM_UNLOCKED_TO_FP, + CVM_LOCKED_TO_FP +}; + +enum CvmRegisterState { + CVM_UNKNOWN_REGISTER_STATE = 0, + CVM_UNREGISTERED_TO_FP, + CVM_REGISTERED_TO_FP +}; + +#define BUSMAIL_MAIL_MAX_PARAMS_LENGTH 128 +#define BUSMAIL_MAX_FRAME_LENGTH (BUSMAIL_MAIL_MAX_PARAMS_LENGTH + 9) + +#define BUSMAIL_OFFSET_SOF 0 +#define BUSMAIL_OFFSET_LEN_MSB 1 +#define BUSMAIL_OFFSET_LEN_LSB 2 +#define BUSMAIL_OFFSET_HEADER 3 +#define BUSMAIL_OFFSET_MAIL BUSMAIL_OFFSET_MAIL_PROGRAM_ID +#define BUSMAIL_OFFSET_MAIL_PROGRAM_ID 4 +#define BUSMAIL_OFFSET_MAIL_TASK_ID 5 +#define BUSMAIL_OFFSET_MAIL_PRIMITIVE_MSB 7 +#define BUSMAIL_OFFSET_MAIL_PRIMITIVE_LSB 6 +#define BUSMAIL_OFFSET_MAIL_PARAMS 8 + +#define BUSMAIL_MAIL_PRIMITIVE_MSB 1 +#define BUSMAIL_MAIL_PRIMITIVE_LSB 0 +#define BUSMAIL_LEN_MSB 0 +#define BUSMAIL_LEN_LSB 1 + +#define BUSMAIL_SOF 0x10 + +#define BUSMAIL_MAIL_PROGRAM_ID 0x0 +#define BUSMAIL_MAIL_USERTASK_TASK_ID 0x0f +#define BUSMAIL_MAIL_TBHANDLE_TASK_ID 0x0 +#define BUSMAIL_MAIL_TASK_ID BUSMAIL_MAIL_USERTASK_TASK_ID + +#define BUSMAIL_HEADER_IC_BIT_MASK 0x80 +#define BUSMAIL_HEADER_SU_BIT_MASK 0x40 +#define BUSMAIL_HEADER_PF_BIT_MASK 0x08 +#define BUSMAIL_HEADER_TXSEQ_MASK 0x70 +#define BUSMAIL_HEADER_RXSEQ_MASK 0x07 +#define BUSMAIL_HEADER_SUID_MASK 0x30 +#define BUSMAIL_HEADER_UNID_MASK BUSMAIL_HEADER_SUID_MASK + +#define BUSMAIL_HEADER_INFO_FRAME 0x0 +#define BUSMAIL_HEADER_CTRL_FRAME 0x80 +#define BUSMAIL_HEADER_CTRL_SU_FRAME 0x0 +#define BUSMAIL_HEADER_CTRL_UN_FRAME 0x40 + +#define BUSMAIL_HEADER_UNID_SABM 0x0 +#define BUSMAIL_HEADER_SUID_RR 0x0 +#define BUSMAIL_HEADER_SUID_REJ 0x10 +#define BUSMAIL_HEADER_SUID_RNR 0x20 + +#define BUSMAIL_HEADER_SABM_MASK (BUSMAIL_HEADER_IC_BIT_MASK | BUSMAIL_HEADER_SU_BIT_MASK | BUSMAIL_HEADER_UNID_MASK) +#define BUSMAIL_HEADER_SABM (BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_UN_FRAME | BUSMAIL_HEADER_UNID_SABM) + +#define BUSMAIL_HEADER_REJ_MASK (BUSMAIL_HEADER_IC_BIT_MASK | BUSMAIL_HEADER_SU_BIT_MASK | BUSMAIL_HEADER_SUID_MASK) +#define BUSMAIL_HEADER_REJ (BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_SU_FRAME | BUSMAIL_HEADER_SUID_REJ) + +#define BUSMAIL_HEADER_SU_FRAME_MASK (BUSMAIL_HEADER_IC_BIT_MASK | BUSMAIL_HEADER_SU_BIT_MASK) +#define BUSMAIL_HEADER_SU_FRAME (BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_SU_FRAME) + +/*! + * \brief structure holding raw data to be send throught serial + */ +struct cvm_busmail_msg { + int valid; + unsigned char busmail_msg_buffer[BUSMAIL_MAX_FRAME_LENGTH]; + unsigned int busmail_msg_len; + + unsigned int tv_sec; + unsigned int tv_usec; + + unsigned char txseqno; + int acknowledged; + int how_many_sent; + int sent; + + struct cvm_busmail_msg *next; + struct cvm_busmail_msg *previous; +}; + +/*! + * \brief structure holding busmail frame, for internal use + */ +struct cvm_busmail_frame { + unsigned char busmail_sof; + unsigned char busmail_len[2]; + unsigned char busmail_header; + unsigned char busmail_mail_program_id; + unsigned char busmail_mail_task_id; + unsigned char busmail_mail_primitive[2]; + unsigned char busmail_mail_params_buffer[BUSMAIL_MAIL_MAX_PARAMS_LENGTH]; + unsigned int busmail_mail_params_buffer_len; + unsigned char busmail_crc; +}; +#endif /* CELLIAX_CVM */ + +/* CELLIAX INTERNAL STRUCTS */ + +/*! + * \brief structure for the linked list of FBUS2 Nokia proprietary protocol messages + */ +struct fbus2_msg { + int msg; + int seqnum; + int len; + int acknowledged; + int how_many_sent; + int sent; + unsigned int tv_sec; + unsigned int tv_usec; + unsigned char buffer[FBUS2_MAX_TRANSMIT_LENGTH + 10]; + struct fbus2_msg *next; + struct fbus2_msg *previous; +}; + +/*! + * \brief structure for storing the results of AT commands, in an array of AT_MESG_MAX_LINES * AT_MESG_MAX_LENGTH chars + */ +struct s_result { + int elemcount; + char result[AT_MESG_MAX_LINES][AT_MESG_MAX_LENGTH]; +}; + +/*! + * \brief PVT structure for a celliax interface (channel), created by celliax_mkif + */ +struct celliax_pvt { + char *name; /*!< \brief 'name' of the interface (channel) */ + int interface_state; /*!< \brief 'state' of the interface (channel) */ + int phone_callflow; /*!< \brief 'callflow' of the phone interface (as opposed to skype interface) */ + struct ast_channel *owner; /*!< \brief channel we belong to, possibly NULL */ + struct celliax_pvt *next; /*!< \brief Next interface (channel) in list */ + int readpos; /*!< \brief read position above */ + struct ast_frame read_f; /*!< \brief returned by oss_read */ + char context[AST_MAX_EXTENSION]; /*!< \brief default Asterisk dialplan context for this interface */ + char language[MAX_LANGUAGE]; /*!< \brief default Asterisk dialplan language for this interface */ + char exten[AST_MAX_EXTENSION]; /*!< \brief default Asterisk dialplan extension for this interface */ + struct ast_dsp *dsp; /*!< \brief Used for in-band DTMF detection */ + int celliax_sound_rate; /*!< \brief rate of the sound device, in Hz, eg: 8000 */ + int celliax_sound_capt_fd; /*!< \brief file descriptor for sound capture dev */ + char controldevice_name[50]; /*!< \brief name of the serial device controlling the interface, possibly none */ + int controldevprotocol; /*!< \brief which protocol is used for serial control of this interface */ + char controldevprotocolname[50]; /*!< \brief name of the serial device controlling protocol, one of "at" "fbus2" "no_serial" "alsa_voicemodem" */ + int controldevfd; /*!< \brief serial controlling file descriptor for this interface */ + char callid_name[50]; + char callid_number[50]; + unsigned char rxm[255]; /*!< \brief read buffer for FBUS2 serial protocol controlling Nokia phones */ + unsigned char array[255]; /*!< \brief read buffer for FBUS2 serial protocol controlling Nokia phones */ + int arraycounter; /*!< \brief position in the 'array' read buffer for FBUS2 serial protocol controlling Nokia phones */ + int seqnumfbus; /*!< \brief sequential number of FBUS2 messages, hex, revolving */ + pthread_t controldev_thread; /*!< \brief serial control thread for this interface, running during the call */ + struct fbus2_msg *fbus2_outgoing_list; /*!< \brief list used to track FBUS2 traffic acknowledgement and resending */ + ast_mutex_t fbus2_outgoing_list_lock; + int dsp_silence_threshold; + int need_acoustic_ring; /*!< \brief bool, this interface get the incoming ring from soundcard, not serial */ + char oss_write_buf[CELLIAX_FRAME_SIZE * 2]; + int oss_write_dst; + char oss_read_buf[CELLIAX_FRAME_SIZE * 2 + AST_FRIENDLY_OFFSET]; /*!< in bytes */ + time_t celliax_serial_synced_timestamp; + time_t celliax_serial_sync_period; + time_t audio_play_reset_timestamp; + time_t audio_capture_reset_timestamp; + speed_t controldevice_speed; + struct s_result line_array; + struct timeval ringtime; + struct timeval call_incoming_time; + int at_result; + + char at_dial_pre_number[64]; + char at_dial_post_number[64]; + char at_dial_expect[64]; + unsigned int at_early_audio; + char at_hangup[64]; + char at_hangup_expect[64]; + char at_answer[64]; + char at_answer_expect[64]; + unsigned int at_initial_pause; + char at_preinit_1[64]; + char at_preinit_1_expect[64]; + char at_preinit_2[64]; + char at_preinit_2_expect[64]; + char at_preinit_3[64]; + char at_preinit_3_expect[64]; + char at_preinit_4[64]; + char at_preinit_4_expect[64]; + char at_preinit_5[64]; + char at_preinit_5_expect[64]; + unsigned int at_after_preinit_pause; + + char at_postinit_1[64]; + char at_postinit_1_expect[64]; + char at_postinit_2[64]; + char at_postinit_2_expect[64]; + char at_postinit_3[64]; + char at_postinit_3_expect[64]; + char at_postinit_4[64]; + char at_postinit_4_expect[64]; + char at_postinit_5[64]; + char at_postinit_5_expect[64]; + + char at_send_dtmf[64]; + + char at_query_battchg[64]; + char at_query_battchg_expect[64]; + char at_query_signal[64]; + char at_query_signal_expect[64]; + char at_call_idle[64]; + char at_call_incoming[64]; + char at_call_active[64]; + char at_call_failed[64]; + char at_call_calling[64]; + +#define CIEV_STRING_SIZE 64 + char at_indicator_noservice_string[64]; + char at_indicator_nosignal_string[64]; + char at_indicator_lowsignal_string[64]; + char at_indicator_lowbattchg_string[64]; + char at_indicator_nobattchg_string[64]; + char at_indicator_callactive_string[64]; + char at_indicator_nocallactive_string[64]; + char at_indicator_nocallsetup_string[64]; + char at_indicator_callsetupincoming_string[64]; + char at_indicator_callsetupoutgoing_string[64]; + char at_indicator_callsetupremoteringing_string[64]; + + int at_indicator_callp; + int at_indicator_callsetupp; + int at_indicator_roamp; + int at_indicator_battchgp; + int at_indicator_servicep; + int at_indicator_signalp; + + int at_has_clcc; + int at_has_ecam; + + double playback_boost; + double capture_boost; + int stripmsd; + int controldev_dead; + ast_mutex_t controldev_lock; + struct timeval fbus2_list_tv; + struct timezone fbus2_list_tz; + dtmf_rx_state_t dtmf_state; + int dtmf_inited; + pthread_t sync_thread; + pthread_t celliax_sound_monitor_thread; + pthread_t celliax_serial_monitor_thread; + int celliax_serial_monitoring; + int skype; /*!< \brief config flag, bool, Skype support on this interface (0 if false, -1 if true) */ + int phonebook_listing; + int phonebook_querying; + int phonebook_listing_received_calls; + + int phonebook_first_entry; + int phonebook_last_entry; + int phonebook_number_lenght; + int phonebook_text_lenght; + FILE *phonebook_writing_fp; + int celliax_dir_entry_extension_prefix; +#ifdef CELLIAX_CVM + char cvm_subsc_1_pin[20]; + char cvm_subsc_2_pin[20]; + int cvm_subsc_no; + int cvm_lock_state; + int cvm_register_state; + int cvm_volume_level; + int cvm_celliax_serial_delay; + unsigned char cvm_handset_no; + unsigned char cvm_fp_is_cvm; + unsigned char cvm_rssi; + + unsigned char busmail_rxseq_cvm_last; /*!< \brief sequential number of BUSMAIL messages, (0-7) */ + unsigned char busmail_txseq_celliax_last; /*!< \brief sequential number of BUSMAIL messages, (0-7) */ + + struct cvm_busmail_msg *cvm_busmail_outgoing_list; /*!< \brief list used to track CVM BUSMAIL traffic acknowledgement and resending */ + ast_mutex_t cvm_busmail_outgoing_list_lock; + + struct timeval cvm_busmail_list_tv; + struct timezone cvm_busmail_list_tz; +#endif /* CELLIAX_CVM */ +#ifdef CELLIAX_LIBCSV + int csv_separator_is_semicolon; + int csv_complete_name_pos; + int csv_email_pos; + int csv_home_phone_pos; + int csv_mobile_phone_pos; + int csv_business_phone_pos; + int csv_first_row_is_title; + int csv_fields; + int csv_rows; + char csv_complete_name[256]; + char csv_email[256]; + char csv_home_phone[256]; + char csv_mobile_phone[256]; + char csv_business_phone[256]; +#endif /* CELLIAX_LIBCSV */ + int audio_play_reset_period; + + char at_cmgw[16]; + + int isInputInterleaved; + int isOutputInterleaved; + int numInputChannels; + int numOutputChannels; + int framesPerCallback; +#ifndef CELLIAX_ALSA + PABLIO_Stream *stream; +#endif /* CELLIAX_ALSA */ + int audiopipe[2]; + int speexecho; + int speexpreprocess; + int portaudiocindex; /*!< \brief Index of the Portaudio capture audio device */ + int portaudiopindex; /*!< \brief Index of the Portaudio playback audio device */ + int control_to_send; + int unread_sms_msg_id; + int reading_sms_msg; + char sms_message[4800]; + int sms_cnmi_not_supported; + char sms_receiving_program[256]; + int celliax_dir_prefix; + int no_ucs2; +#ifdef CELLIAX_ALSA + snd_pcm_t *alsac; /*!< \brief handle of the ALSA capture audio device */ + snd_pcm_t *alsap; /*!< \brief handle of the ALSA playback audio device */ + char alsacname[50]; /*!< \brief name of the ALSA capture audio device */ + char alsapname[50]; /*!< \brief name of the ALSA playback audio device */ + int alsa_period_size; /*!< \brief ALSA period_size, in byte */ + int alsa_periods_in_buffer; /*!< \brief how many periods in ALSA buffer, to calculate buffer_size */ + unsigned long int alsa_buffer_size; /*!< \brief ALSA buffer_size, in byte */ + int alsawrite_filled; + int alsa_capture_is_mono; + int alsa_play_is_mono; + struct pollfd pfd; +#endif /* CELLIAX_ALSA */ + + struct timeval dtmf_timestamp; +}; + +/* LOCKS */ +/*! \brief Protect the celliax_usecnt */ +AST_MUTEX_DEFINE_STATIC(celliax_usecnt_lock); +/*! \brief Protect the monitoring thread, so only one process can kill or start it, and not + * when it's doing something critical. */ +AST_MUTEX_DEFINE_STATIC(celliax_monlock); +/*! \brief Protect the interfaces list */ +AST_MUTEX_DEFINE_STATIC(celliax_iflock); + +/* FUNCTIONS */ + +/* module helpers functions */ +int load_module(void); +int unload_module(void); +int usecount(void); +char *description(void); +char *key(void); + +/* chan_celliax internal functions */ +void celliax_unlocka_log(void *x); +#ifdef CELLIAX_FBUS2 +int celliax_serial_sync_FBUS2(struct celliax_pvt *p); +int celliax_serial_answer_FBUS2(struct celliax_pvt *p); +int celliax_serial_call_FBUS2(struct celliax_pvt *p, char *dstr); +int celliax_serial_hangup_FBUS2(struct celliax_pvt *p); +int celliax_serial_config_FBUS2(struct celliax_pvt *p); +int celliax_serial_read_FBUS2(struct celliax_pvt *p); +int celliax_serial_getstatus_FBUS2(struct celliax_pvt *p); +int celliax_serial_get_seqnum_FBUS2(struct celliax_pvt *p); +int celliax_serial_security_command_FBUS2(struct celliax_pvt *p); +int celliax_serial_send_FBUS2(struct celliax_pvt *p, int len, unsigned char *buffer2); +int celliax_serial_list_acknowledge_FBUS2(struct celliax_pvt *p, int seqnum); +int celliax_serial_send_if_time_FBUS2(struct celliax_pvt *p); +int celliax_serial_write_FBUS2(struct celliax_pvt *p, unsigned char *MsgBuffer, + int MsgLength, unsigned char MsgType); +int celliax_serial_send_ack_FBUS2(struct celliax_pvt *p, unsigned char MsgType, + unsigned char MsgSequence); +struct fbus2_msg *celliax_serial_list_init_FBUS2(struct celliax_pvt *p); +int celliax_serial_list_print_FBUS2(struct celliax_pvt *p, struct fbus2_msg *list); + +#endif /* CELLIAX_FBUS2 */ + +#ifdef CELLIAX_CVM +int celliax_serial_sync_CVM_BUSMAIL(struct celliax_pvt *p); +int celliax_serial_answer_CVM_BUSMAIL(struct celliax_pvt *p); +int celliax_serial_call_CVM_BUSMAIL(struct celliax_pvt *p, char *dstr); +int celliax_serial_hangup_CVM_BUSMAIL(struct celliax_pvt *p); +int celliax_serial_config_CVM_BUSMAIL(struct celliax_pvt *p); +int celliax_serial_read_CVM_BUSMAIL(struct celliax_pvt *p); +int celliax_serial_getstatus_CVM_BUSMAIL(struct celliax_pvt *p); +int celliax_serial_send_CVM_BUSMAIL(struct celliax_pvt *p, int len, + unsigned char *mesg_ptr); +int celliax_serial_list_acknowledge_CVM_BUSMAIL(struct celliax_pvt *p, + unsigned char TxSeqNo); +int celliax_serial_send_if_time_CVM_BUSMAIL(struct celliax_pvt *p); +int celliax_serial_write_CVM_BUSMAIL(struct celliax_pvt *p, + struct cvm_busmail_frame *busmail_frame); +int celliax_serial_send_ctrl_frame_CVM_BUSMAIL(struct celliax_pvt *p, + unsigned char FrameType); +int celliax_serial_send_info_frame_CVM_BUSMAIL(struct celliax_pvt *p, int FrameType, + unsigned char ParamsLen, + unsigned char *Params); +struct cvm_busmail_msg *celliax_serial_list_init_CVM_BUSMAIL(struct celliax_pvt *p); +int celliax_serial_list_print_CVM_BUSMAIL(struct celliax_pvt *p, + struct cvm_busmail_msg *list); +int celliax_serial_lists_free_CVM_BUSMAIL(struct celliax_pvt *p); + +#endif /* CELLIAX_CVM */ + +/* CHAN_CELLIAX.C */ +int celliax_queue_control(struct ast_channel *chan, int control); +struct celliax_pvt *celliax_console_find_desc(char *dev); +int celliax_serial_call(struct celliax_pvt *p, char *dstr); + +/* FUNCTIONS */ +/* PBX interface functions */ +struct ast_channel *celliax_request(const char *type, int format, void *data, int *cause); +int celliax_answer(struct ast_channel *c); +int celliax_hangup(struct ast_channel *c); +int celliax_call(struct ast_channel *c, char *idest, int timeout); +struct ast_frame *celliax_read(struct ast_channel *chan); +int celliax_write(struct ast_channel *c, struct ast_frame *f); +int celliax_fixup(struct ast_channel *oldchan, struct ast_channel *newchan); +#ifndef ASTERISK_VERSION_1_4 +int celliax_indicate(struct ast_channel *c, int cond); +#else +int celliax_indicate(struct ast_channel *c, int cond, const void *data, size_t datalen); +#endif +int celliax_devicestate(void *data); +#ifdef ASTERISK_VERSION_1_4 +int celliax_senddigit_begin(struct ast_channel *ast, char digit); +int celliax_senddigit_end(struct ast_channel *ast, char digit, unsigned int duration); +#else /* ASTERISK_VERSION_1_4 */ +int celliax_senddigit(struct ast_channel *ast, char digit); +#endif /* ASTERISK_VERSION_1_4 */ + +/* chan_celliax internal functions */ + +struct celliax_pvt *celliax_mkif(struct ast_config *cfg, char *ctg, + int is_first_category); +struct ast_channel *celliax_new(struct celliax_pvt *p, int state, char *context); +int celliax_restart_monitor(void); +void *celliax_do_monitor(void *data); +void *celliax_do_audio_monitor(void *data); +int celliax_sound_boost(struct ast_frame *f, double boost); +int celliax_sound_init(struct celliax_pvt *p); +int celliax_sound_shutdown(struct celliax_pvt *p); +struct ast_frame *celliax_sound_dsp_analize(struct celliax_pvt *p, struct ast_frame *f, + int dsp_silence_threshold); +int celliax_sound_dsp_set(struct celliax_pvt *p, int dsp_silence_threshold, + int silence_suppression); +struct ast_frame *celliax_sound_read(struct celliax_pvt *p); +int celliax_sound_write(struct celliax_pvt *p, struct ast_frame *f); +int celliax_sound_monitor(struct celliax_pvt *p); +void *celliax_do_controldev_thread(void *data); +int celliax_serial_init(struct celliax_pvt *p, speed_t controldevice_speed); +int celliax_serial_monitor(struct celliax_pvt *p); +int celliax_serial_read(struct celliax_pvt *p); +int celliax_serial_sync(struct celliax_pvt *p); +int celliax_serial_getstatus(struct celliax_pvt *p); +int celliax_serial_config(struct celliax_pvt *p); +int celliax_serial_hangup(struct celliax_pvt *p); +int celliax_serial_answer(struct celliax_pvt *p); + +#define celliax_serial_write_AT_expect(P, D, S) celliax_serial_write_AT_expect1(P, D, S, 1, 2) +#define celliax_serial_write_AT_expect_noexpcr(P, D, S) celliax_serial_write_AT_expect1(P, D, S, 0, 2) +#define celliax_serial_write_AT_expect_noexpcr_tout(P, D, S, T) celliax_serial_write_AT_expect1(P, D, S, 0, T) +// 20.5 sec timeout, used for querying the SIM and sending SMSs +#define celliax_serial_write_AT_expect_longtime(P, D, S) celliax_serial_write_AT_expect1(P, D, S, 1, 20) +#define celliax_serial_write_AT_expect_longtime_noexpcr(P, D, S) celliax_serial_write_AT_expect1(P, D, S, 0, 20) +int celliax_serial_write_AT(struct celliax_pvt *p, const char *data); +int celliax_serial_write_AT_nocr(struct celliax_pvt *p, const char *data); +int celliax_serial_write_AT_ack(struct celliax_pvt *p, const char *data); +int celliax_serial_write_AT_ack_nocr_longtime(struct celliax_pvt *p, const char *data); +int celliax_serial_write_AT_noack(struct celliax_pvt *p, const char *data); +int celliax_serial_write_AT_expect1(struct celliax_pvt *p, const char *data, + const char *expected_string, int expect_crlf, + int seconds); +int celliax_serial_AT_expect(struct celliax_pvt *p, const char *expected_string, + int expect_crlf, int seconds); +int celliax_serial_read_AT(struct celliax_pvt *p, int look_for_ack, int timeout_usec, + int timeout_sec, const char *expected_string, int expect_crlf); +int celliax_serial_answer_AT(struct celliax_pvt *p); +int celliax_serial_hangup_AT(struct celliax_pvt *p); +int celliax_serial_config_AT(struct celliax_pvt *p); +int celliax_serial_call_AT(struct celliax_pvt *p, char *dstr); +int celliax_serial_sync_AT(struct celliax_pvt *p); +int celliax_serial_getstatus_AT(struct celliax_pvt *p); + +#ifdef ASTERISK_VERSION_1_6_0 +void celliax_store_boost(const char *s, double *boost); +#else +void celliax_store_boost(char *s, double *boost); +#endif /* ASTERISK_VERSION_1_6_0 */ +int celliax_console_set_active(int fd, int argc, char *argv[]); +#ifndef ASTERISK_VERSION_1_6_0 +int celliax_console_hangup(int fd, int argc, char *argv[]); +#else /* ASTERISK_VERSION_1_6_0 */ +char *celliax_console_hangup(struct ast_cli_entry *e, int cmd, struct ast_cli_args *a); +#endif /* ASTERISK_VERSION_1_6_0 */ +int celliax_console_playback_boost(int fd, int argc, char *argv[]); +int celliax_console_capture_boost(int fd, int argc, char *argv[]); +int celliax_console_celliax(int fd, int argc, char *argv[]); +#ifdef CELLIAX_DIR +int celliax_console_celliax_dir_import(int fd, int argc, char *argv[]); +int celliax_console_celliax_dir_export(int fd, int argc, char *argv[]); +#endif /* CELLIAX_DIR */ +int celliax_console_dial(int fd, int argc, char *argv[]); +int celliax_console_sendsms(int fd, int argc, char *argv[]); +int celliax_portaudio_init(struct celliax_pvt *p); +int celliax_portaudio_shutdown(struct celliax_pvt *p); +struct ast_frame *celliax_portaudio_read(struct celliax_pvt *p); +int celliax_portaudio_write(struct celliax_pvt *p, struct ast_frame *f); +int celliax_portaudio_devlist(struct celliax_pvt *p); +#ifdef CELLIAX_DIR +int celliax_dir_exec(struct ast_channel *chan, void *data); +int celliax_dir_create_extensions(void); +int celliax_dir_play_mailbox_owner(struct ast_channel *chan, char *context, + char *dialcontext, char *ext, char *name); +struct ast_config *celliax_dir_realtime(char *context); +int celliax_dir_do(struct ast_channel *chan, struct ast_config *cfg, char *context, + char *dialcontext, char digit, int last); +#endif /* CELLIAX_DIR */ +#ifdef CELLIAX_LIBCSV +void celliax_cb1(char *s, size_t len, void *data); +void celliax_cb2(char c, void *data); +#endif /* CELLIAX_LIBCSV */ +int celliax_sendsms(struct ast_channel *c, void *data); +int celliax_console_echo(int fd, int argc, char *argv[]); +int celliax_console_at(int fd, int argc, char *argv[]); +#ifdef ASTERISK_VERSION_1_2 +int celliax_manager_sendsms(struct mansession *s, struct message *m); +#endif //ASTERISK_VERSION_1_2 +#ifdef ASTERISK_VERSION_1_4 +int celliax_manager_sendsms(struct mansession *s, const struct message *m); +#endif //ASTERISK_VERSION_1_4 +int utf_to_ucs2(struct celliax_pvt *p, char *utf_in, size_t inbytesleft, char *ucs2_out, + size_t outbytesleft); +int ucs2_to_utf8(struct celliax_pvt *p, char *ucs2_in, char *utf8_out, + size_t outbytesleft); +#endif /* _CELLIAX_H_ */ +#ifdef CELLIAX_ALSA +int console_alsa_period(int fd, int argc, char *argv[]); +#endif /* CELLIAX_ALSA */ +#ifdef CELLIAX_ALSA +int alsa_init(struct celliax_pvt *p); +int alsa_shutdown(struct celliax_pvt *p); +snd_pcm_t *alsa_open_dev(struct celliax_pvt *p, snd_pcm_stream_t stream); +struct ast_frame *alsa_read(struct celliax_pvt *p); +int alsa_write(struct celliax_pvt *p, struct ast_frame *f); +#endif /* CELLIAX_ALSA */ diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/celliax_additional.c b/src/mod/endpoints/mod_gsmopen/asterisk/celliax_additional.c new file mode 100644 index 0000000000..f72c8d8552 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/celliax_additional.c @@ -0,0 +1,7027 @@ +//indent -gnu -ts4 -br -brs -cdw -lp -ce -nbfda -npcs -nprs -npsl -nbbo -saf -sai -saw -cs -bbo -nhnl -nut -sob -l90 +#include "celliax.h" +#include "iconv.h" + +extern int celliax_debug; +extern char *celliax_console_active; +extern char celliax_type[]; +extern struct celliax_pvt *celliax_iflist; +extern int celliax_dir_entry_extension; + +#ifndef GIOVA48 +#define SAMPLES_PER_FRAME 160 +#else // GIOVA48 +#define SAMPLES_PER_FRAME 960 +#endif // GIOVA48 + +#ifdef CELLIAX_ALSA +/*! \brief ALSA pcm format, according to endianess */ +#if __BYTE_ORDER == __LITTLE_ENDIAN +snd_pcm_format_t celliax_format = SND_PCM_FORMAT_S16_LE; +#else +snd_pcm_format_t celliax_format = SND_PCM_FORMAT_S16_BE; +#endif + +/*! + * \brief Initialize the ALSA soundcard channels (capture AND playback) used by one interface (a multichannel soundcard can be used by multiple interfaces) + * \param p the celliax_pvt of the interface + * + * This function call alsa_open_dev to initialize the ALSA soundcard for each channel (capture AND playback) used by one interface (a multichannel soundcard can be used by multiple interfaces). Called by sound_init + * + * \return zero on success, -1 on error. + */ +int alsa_init(struct celliax_pvt *p) +{ + p->alsac = alsa_open_dev(p, SND_PCM_STREAM_CAPTURE); + if (!p->alsac) { + ERRORA("Failed opening ALSA capture device: %s\n", CELLIAX_P_LOG, p->alsacname); + if (alsa_shutdown(p)) { + ERRORA("alsa_shutdown failed\n", CELLIAX_P_LOG); + return -1; + } + return -1; + } + p->alsap = alsa_open_dev(p, SND_PCM_STREAM_PLAYBACK); + if (!p->alsap) { + ERRORA("Failed opening ALSA playback device: %s\n", CELLIAX_P_LOG, p->alsapname); + if (alsa_shutdown(p)) { + ERRORA("alsa_shutdown failed\n", CELLIAX_P_LOG); + return -1; + } + return -1; + } + + /* make valgrind very happy */ + snd_config_update_free_global(); + return 0; +} + +/*! + * \brief Shutdown the ALSA soundcard channels (input and output) used by one interface (a multichannel soundcard can be used by multiple interfaces) + * \param p the celliax_pvt of the interface + * + * This function shutdown the ALSA soundcard channels (input and output) used by one interface (a multichannel soundcard can be used by multiple interfaces). Called by sound_init + * + * \return zero on success, -1 on error. + */ + +int alsa_shutdown(struct celliax_pvt *p) +{ + + int err; + + if (p->alsap) { + err = snd_pcm_drop(p->alsap); + if (err < 0) { + ERRORA("device [%s], snd_pcm_drop failed with error '%s'\n", CELLIAX_P_LOG, + p->alsapname, snd_strerror(err)); + return -1; + } + err = snd_pcm_close(p->alsap); + if (err < 0) { + ERRORA("device [%s], snd_pcm_close failed with error '%s'\n", CELLIAX_P_LOG, + p->alsapname, snd_strerror(err)); + return -1; + } + } + if (p->alsac) { + err = snd_pcm_drop(p->alsac); + if (err < 0) { + ERRORA("device [%s], snd_pcm_drop failed with error '%s'\n", CELLIAX_P_LOG, + p->alsacname, snd_strerror(err)); + return -1; + } + err = snd_pcm_close(p->alsac); + if (err < 0) { + ERRORA("device [%s], snd_pcm_close failed with error '%s'\n", CELLIAX_P_LOG, + p->alsacname, snd_strerror(err)); + return -1; + } + } + + return 0; +} + +/*! + * \brief Setup and open the ALSA device (capture OR playback) + * \param p the celliax_pvt of the interface + * \param stream the ALSA capture/playback definition + * + * This function setup and open the ALSA device (capture OR playback). Called by alsa_init + * + * \return zero on success, -1 on error. + */ +snd_pcm_t *alsa_open_dev(struct celliax_pvt * p, snd_pcm_stream_t stream) +{ + + snd_pcm_t *handle = NULL; + snd_pcm_hw_params_t *params; + snd_pcm_sw_params_t *swparams; + snd_pcm_uframes_t buffer_size; + int err; + size_t n; + //snd_pcm_uframes_t xfer_align; + unsigned int rate; + snd_pcm_uframes_t start_threshold, stop_threshold; + snd_pcm_uframes_t period_size = 0; + snd_pcm_uframes_t chunk_size = 0; + int start_delay = 0; + int stop_delay = 0; + snd_pcm_state_t state; + snd_pcm_info_t *info; + + period_size = p->alsa_period_size; + + snd_pcm_hw_params_alloca(¶ms); + snd_pcm_sw_params_alloca(&swparams); + + if (stream == SND_PCM_STREAM_CAPTURE) { + err = snd_pcm_open(&handle, p->alsacname, stream, 0 | SND_PCM_NONBLOCK); + } else { + err = snd_pcm_open(&handle, p->alsapname, stream, 0 | SND_PCM_NONBLOCK); + } + if (err < 0) { + ERRORA + ("snd_pcm_open failed with error '%s' on device '%s', if you are using a plughw:n device please change it to be a default:n device (so to allow it to be shared with other concurrent programs), or maybe you are using an ALSA voicemodem and slmodemd" + " is running?\n", CELLIAX_P_LOG, snd_strerror(err), + stream == SND_PCM_STREAM_CAPTURE ? p->alsacname : p->alsapname); + return NULL; + } + + snd_pcm_info_alloca(&info); + + if ((err = snd_pcm_info(handle, info)) < 0) { + ERRORA("info error: %s", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + + err = snd_pcm_nonblock(handle, 1); + if (err < 0) { + ERRORA("nonblock setting error: %s", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + + err = snd_pcm_hw_params_any(handle, params); + if (err < 0) { + ERRORA("Broken configuration for this PCM, no configurations available: %s\n", + CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + + err = snd_pcm_hw_params_set_access(handle, params, SND_PCM_ACCESS_RW_INTERLEAVED); + if (err < 0) { + ERRORA("Access type not available: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + err = snd_pcm_hw_params_set_format(handle, params, celliax_format); + if (err < 0) { + ERRORA("Sample format non available: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + err = snd_pcm_hw_params_set_channels(handle, params, 1); + if (err < 0) { + DEBUGA_SOUND("Channels count set failed: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + } +#if 1 + unsigned int chan_num; + err = snd_pcm_hw_params_get_channels(params, &chan_num); + if (err < 0) { + ERRORA("Channels count non available: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + if (chan_num < 1 || chan_num > 2) { + ERRORA("Channels count MUST BE 1 or 2, it is: %d\n", CELLIAX_P_LOG, chan_num); + ERRORA("Channels count MUST BE 1 or 2, it is: %d on %s %s\n", CELLIAX_P_LOG, chan_num, + p->alsapname, p->alsacname); + return NULL; + } else { + if (chan_num == 1) { + if (stream == SND_PCM_STREAM_CAPTURE) + p->alsa_capture_is_mono = 1; + else + p->alsa_play_is_mono = 1; + } else { + if (stream == SND_PCM_STREAM_CAPTURE) + p->alsa_capture_is_mono = 0; + else + p->alsa_play_is_mono = 0; + } + } +#else + p->alsa_capture_is_mono = 1; + p->alsa_play_is_mono = 1; +#endif + +#if 0 + unsigned int buffer_time = 0; + unsigned int period_time = 0; + snd_pcm_uframes_t period_frames = 0; + snd_pcm_uframes_t buffer_frames = 0; + + if (buffer_time == 0 && buffer_frames == 0) { + err = snd_pcm_hw_params_get_buffer_time_max(params, &buffer_time, 0); + assert(err >= 0); + if (buffer_time > 500000) + buffer_time = 500000; + } + if (period_time == 0 && period_frames == 0) { + if (buffer_time > 0) + period_time = buffer_time / 4; + else + period_frames = buffer_frames / 4; + } + if (period_time > 0) + err = snd_pcm_hw_params_set_period_time_near(handle, params, &period_time, 0); + else + err = snd_pcm_hw_params_set_period_size_near(handle, params, &period_frames, 0); + assert(err >= 0); + if (buffer_time > 0) { + err = snd_pcm_hw_params_set_buffer_time_near(handle, params, &buffer_time, 0); + } else { + err = snd_pcm_hw_params_set_buffer_size_near(handle, params, &buffer_frames); + } +#endif + +#if 1 + rate = p->celliax_sound_rate; + err = snd_pcm_hw_params_set_rate_near(handle, params, &rate, 0); + if ((float) p->celliax_sound_rate * 1.05 < rate + || (float) p->celliax_sound_rate * 0.95 > rate) { + WARNINGA("Rate is not accurate (requested = %iHz, got = %iHz)\n", CELLIAX_P_LOG, + p->celliax_sound_rate, rate); + } + + if (err < 0) { + ERRORA("Error setting rate: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + p->celliax_sound_rate = rate; + + err = snd_pcm_hw_params_set_period_size_near(handle, params, &period_size, 0); + + if (err < 0) { + ERRORA("Error setting period_size: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + + p->alsa_period_size = period_size; + + p->alsa_buffer_size = p->alsa_period_size * p->alsa_periods_in_buffer; + + err = snd_pcm_hw_params_set_buffer_size_near(handle, params, &p->alsa_buffer_size); + + if (err < 0) { + ERRORA("Error setting buffer_size: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } +#endif + + err = snd_pcm_hw_params(handle, params); + if (err < 0) { + ERRORA("Unable to install hw params: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + + snd_pcm_hw_params_get_period_size(params, &chunk_size, 0); + snd_pcm_hw_params_get_buffer_size(params, &buffer_size); + if (chunk_size == buffer_size) { + ERRORA("Can't use period equal to buffer size (%lu == %lu)\n", CELLIAX_P_LOG, + chunk_size, buffer_size); + return NULL; + } + + snd_pcm_sw_params_current(handle, swparams); + +#if 0 + err = snd_pcm_sw_params_get_xfer_align(swparams, &xfer_align); + if (err < 0) { + ERRORA("Unable to obtain xfer align: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + } + NOTICA("xfer_align: %d\n", CELLIAX_P_LOG, xfer_align); + /* for some reason, on some platforms, xfer_align here is zero, that gives a floating point exception later. So, let's try to force it to 160, the frame size used by celliax */ + xfer_align = p->alsa_period_size; + NOTICA("xfer_align: %d\n", CELLIAX_P_LOG, xfer_align); + + err = snd_pcm_sw_params_set_xfer_align(handle, swparams, xfer_align); + if (err < 0) { + ERRORA("Error setting xfer_align: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + } + NOTICA("xfer_align: %d\n", CELLIAX_P_LOG, xfer_align); + + err = snd_pcm_sw_params_get_xfer_align(swparams, &xfer_align); + if (err < 0) { + ERRORA("Unable to obtain xfer align: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + } + NOTICA("xfer_align: %d\n", CELLIAX_P_LOG, xfer_align); +#endif + + /* + if (sleep_min) + xfer_align = 1; + err = snd_pcm_sw_params_set_sleep_min(handle, swparams, + 0); + + if (err < 0) { + ERRORA("Error setting slep_min: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + } + */ + n = chunk_size; + err = snd_pcm_sw_params_set_avail_min(handle, swparams, n); + if (err < 0) { + ERRORA("Error setting avail_min: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + } +#if 0 + /* round up to closest transfer boundary */ + if (xfer_align == 0) { //so to avoid floating point exception ???? + xfer_align = 160; + } + //original n = (buffer_size / xfer_align) * xfer_align; + n = (chunk_size / xfer_align) * xfer_align; +#endif + if (stream == SND_PCM_STREAM_CAPTURE) { + start_delay = 1; + } + if (start_delay <= 0) { + start_threshold = n + (double) rate *start_delay / 1000000; + } else { + start_threshold = (double) rate *start_delay / 1000000; + } + if (start_threshold < 1) + start_threshold = 1; + if (start_threshold > n) + start_threshold = n; + err = snd_pcm_sw_params_set_start_threshold(handle, swparams, start_threshold); + if (err < 0) { + ERRORA("Error setting start_threshold: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + } + + if (stop_delay <= 0) + stop_threshold = buffer_size + (double) rate *stop_delay / 1000000; + else + stop_threshold = (double) rate *stop_delay / 1000000; + + if (stream == SND_PCM_STREAM_CAPTURE) { + stop_threshold = -1; + } + + err = snd_pcm_sw_params_set_stop_threshold(handle, swparams, stop_threshold); + + if (err < 0) { + ERRORA("Error setting stop_threshold: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + } +#if 0 + err = snd_pcm_sw_params_set_xfer_align(handle, swparams, xfer_align); + + if (err < 0) { + ERRORA("Error setting xfer_align: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + } +#endif + + if (snd_pcm_sw_params(handle, swparams) < 0) { + ERRORA("Error installing software parameters: %s\n", CELLIAX_P_LOG, + snd_strerror(err)); + } + + err = snd_pcm_poll_descriptors_count(handle); + if (err <= 0) { + ERRORA("Unable to get a poll descriptors count, error is %s\n", CELLIAX_P_LOG, + snd_strerror(err)); + return NULL; + } + + if (err != 1) { //number of poll descriptors + DEBUGA_SOUND("Can't handle more than one device\n", CELLIAX_P_LOG); + return NULL; + } + + err = snd_pcm_poll_descriptors(handle, &p->pfd, err); + if (err != 1) { + ERRORA("snd_pcm_poll_descriptors failed, %s\n", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + DEBUGA_SOUND("Acquired fd %d from the poll descriptor\n", CELLIAX_P_LOG, p->pfd.fd); + + if (stream == SND_PCM_STREAM_CAPTURE) { + p->celliax_sound_capt_fd = p->pfd.fd; + } + + state = snd_pcm_state(handle); + + if (state != SND_PCM_STATE_RUNNING) { + if (state != SND_PCM_STATE_PREPARED) { + err = snd_pcm_prepare(handle); + if (err) { + ERRORA("snd_pcm_prepare failed, %s\n", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + DEBUGA_SOUND("prepared!\n", CELLIAX_P_LOG); + } + if (stream == SND_PCM_STREAM_CAPTURE) { + err = snd_pcm_start(handle); + if (err) { + ERRORA("snd_pcm_start failed, %s\n", CELLIAX_P_LOG, snd_strerror(err)); + return NULL; + } + DEBUGA_SOUND("started!\n", CELLIAX_P_LOG); + } + } + if (option_debug > 1) { + snd_output_t *output = NULL; + err = snd_output_stdio_attach(&output, stdout, 0); + if (err < 0) { + ERRORA("snd_output_stdio_attach failed: %s\n", CELLIAX_P_LOG, snd_strerror(err)); + } + snd_pcm_dump(handle, output); + } + if (option_debug > 1) + DEBUGA_SOUND("ALSA handle = %ld\n", CELLIAX_P_LOG, (long int) handle); + return handle; + +} + +/*! \brief Read audio frames from interface */ + +struct ast_frame *alsa_read(struct celliax_pvt *p) +{ + static struct ast_frame f; + static short __buf[CELLIAX_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2]; + static short __buf2[(CELLIAX_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2) * 2]; + short *buf; + short *buf2; + static int readpos = 0; + static int left = CELLIAX_FRAME_SIZE; + snd_pcm_state_t state; + int r = 0; + int off = 0; + int error = 0; + //time_t now_timestamp; + + //memset(&f, 0, sizeof(struct ast_frame)); //giova + + f.frametype = AST_FRAME_NULL; + f.subclass = 0; + f.samples = 0; + f.datalen = 0; + f.data = NULL; + f.offset = 0; + f.src = celliax_type; + f.mallocd = 0; + f.delivery.tv_sec = 0; + f.delivery.tv_usec = 0; + + state = snd_pcm_state(p->alsac); + if (state != SND_PCM_STATE_RUNNING) { + DEBUGA_SOUND("ALSA read state is not SND_PCM_STATE_RUNNING\n", CELLIAX_P_LOG); + + if (state != SND_PCM_STATE_PREPARED) { + error = snd_pcm_prepare(p->alsac); + if (error) { + ERRORA("snd_pcm_prepare failed, %s\n", CELLIAX_P_LOG, snd_strerror(error)); + return &f; + } + DEBUGA_SOUND("prepared!\n", CELLIAX_P_LOG); + } + usleep(1000); + error = snd_pcm_start(p->alsac); + if (error) { + ERRORA("snd_pcm_start failed, %s\n", CELLIAX_P_LOG, snd_strerror(error)); + return &f; + } + DEBUGA_SOUND("started!\n", CELLIAX_P_LOG); + usleep(1000); + } + + buf = __buf + AST_FRIENDLY_OFFSET / 2; + buf2 = __buf2 + ((AST_FRIENDLY_OFFSET / 2) * 2); + + if (p->alsa_capture_is_mono) { + r = snd_pcm_readi(p->alsac, buf + readpos, left); + } else { + r = snd_pcm_readi(p->alsac, buf2 + (readpos * 2), left); + + int a = 0; + int i = 0; + for (i = 0; i < (CELLIAX_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2) * 2;) { + __buf[a] = (__buf2[i] + __buf2[i + 1]) / 2; //comment out this line to use only left + //__buf[a] = __buf2[i]; // enable this line to use only left + a++; + i++; + i++; + } + } + + if (r == -EPIPE) { + ERRORA("XRUN read\n\n\n\n\n", CELLIAX_P_LOG); + return &f; + } else if (r == -ESTRPIPE) { + ERRORA("-ESTRPIPE\n", CELLIAX_P_LOG); + return &f; + + } else if (r == -EAGAIN) { + DEBUGA_SOUND("ALSA read -EAGAIN, the soundcard is not ready to be read by celliax\n", + CELLIAX_P_LOG); + while (r == -EAGAIN) { + usleep(1000); + + if (p->alsa_capture_is_mono) { + r = snd_pcm_readi(p->alsac, buf + readpos, left); + } else { + r = snd_pcm_readi(p->alsac, buf2 + (readpos * 2), left); + + int a = 0; + int i = 0; + for (i = 0; i < (CELLIAX_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2) * 2;) { + __buf[a] = (__buf2[i] + __buf2[i + 1]) / 2; + a++; + i++; + i++; + } + } + + } + } else if (r < 0) { + WARNINGA("ALSA Read error: %s\n", CELLIAX_P_LOG, snd_strerror(r)); + } else if (r >= 0) { + //DEBUGA_SOUND("read: r=%d, readpos=%d, left=%d, off=%d\n", CELLIAX_P_LOG, r, readpos, left, off); + off -= r; //what is the meaning of this? a leftover, probably + } + /* Update positions */ + readpos += r; + left -= r; + + if (readpos >= CELLIAX_FRAME_SIZE) { + /* A real frame */ + readpos = 0; + left = CELLIAX_FRAME_SIZE; + + f.frametype = AST_FRAME_VOICE; + f.subclass = AST_FORMAT_SLINEAR; + f.samples = CELLIAX_FRAME_SIZE; + f.datalen = CELLIAX_FRAME_SIZE * 2; + f.data = buf; + f.offset = AST_FRIENDLY_OFFSET; + f.src = celliax_type; + f.mallocd = 0; +#ifdef ALSA_MONITOR + alsa_monitor_read((char *) buf, CELLIAX_FRAME_SIZE * 2); +#endif + + } + return &f; +} + +/*! \brief Write audio frames to interface */ +int alsa_write(struct celliax_pvt *p, struct ast_frame *f) +{ + static char sizbuf[8000]; + static char sizbuf2[16000]; + static char silencebuf[8000]; + static int sizpos = 0; + int len = sizpos; + int pos; + int res = 0; + time_t now_timestamp; + /* size_t frames = 0; */ + snd_pcm_state_t state; + snd_pcm_sframes_t delayp1; + snd_pcm_sframes_t delayp2; + + /* We have to digest the frame in 160-byte portions */ + if (f->datalen > sizeof(sizbuf) - sizpos) { + ERRORA("Frame too large\n", CELLIAX_P_LOG); + res = -1; + } else { + memcpy(sizbuf + sizpos, f->data, f->datalen); + len += f->datalen; + pos = 0; +#ifdef ALSA_MONITOR + alsa_monitor_write(sizbuf, len); +#endif + state = snd_pcm_state(p->alsap); + if (state == SND_PCM_STATE_XRUN) { + int i; + + DEBUGA_SOUND + ("You've got an ALSA write XRUN in the past (celliax can't fill the soundcard buffer fast enough). If this happens often (not after silence or after a pause in the speech, that's OK), and appear to damage the sound quality, first check if you have some IRQ problem, maybe sharing the soundcard IRQ with a broken or heavy loaded ethernet or graphic card. Then consider to increase the alsa_periods_in_buffer (now is set to %d) for this interface in the config file\n", + CELLIAX_P_LOG, p->alsa_periods_in_buffer); + res = snd_pcm_prepare(p->alsap); + if (res) { + ERRORA("audio play prepare failed: %s\n", CELLIAX_P_LOG, snd_strerror(res)); + } else { + res = snd_pcm_format_set_silence(celliax_format, silencebuf, len / 2); + if (res < 0) { + DEBUGA_SOUND("Silence error %s\n", CELLIAX_P_LOG, snd_strerror(res)); + res = -1; + } + for (i = 0; i < (p->alsa_periods_in_buffer - 1); i++) { + res = snd_pcm_writei(p->alsap, silencebuf, len / 2); + if (res != len / 2) { + DEBUGA_SOUND("Write returned a different quantity: %d\n", CELLIAX_P_LOG, res); + res = -1; + } else if (res < 0) { + DEBUGA_SOUND("Write error %s\n", CELLIAX_P_LOG, snd_strerror(res)); + res = -1; + } + } + } + + } + + res = snd_pcm_delay(p->alsap, &delayp1); + if (res < 0) { + DEBUGA_SOUND("Error %d on snd_pcm_delay: \"%s\"\n", CELLIAX_P_LOG, res, + snd_strerror(res)); + res = snd_pcm_prepare(p->alsap); + if (res) { + DEBUGA_SOUND("snd_pcm_prepare failed: '%s'\n", CELLIAX_P_LOG, snd_strerror(res)); + } + res = snd_pcm_delay(p->alsap, &delayp1); + } + + delayp2 = snd_pcm_avail_update(p->alsap); + if (delayp2 < 0) { + DEBUGA_SOUND("Error %d on snd_pcm_avail_update: \"%s\"\n", CELLIAX_P_LOG, + (int) delayp2, snd_strerror(delayp2)); + + res = snd_pcm_prepare(p->alsap); + if (res) { + DEBUGA_SOUND("snd_pcm_prepare failed: '%s'\n", CELLIAX_P_LOG, snd_strerror(res)); + } + delayp2 = snd_pcm_avail_update(p->alsap); + } + + if ( /* delayp1 != 0 && delayp1 != 160 */ + delayp1 < 160 || delayp2 > p->alsa_buffer_size) { + + res = snd_pcm_prepare(p->alsap); + if (res) { + DEBUGA_SOUND + ("snd_pcm_prepare failed while trying to prevent an ALSA write XRUN: %s, delayp1=%d, delayp2=%d\n", + CELLIAX_P_LOG, snd_strerror(res), (int) delayp1, (int) delayp2); + } else { + + int i; + for (i = 0; i < (p->alsa_periods_in_buffer - 1); i++) { + res = snd_pcm_format_set_silence(celliax_format, silencebuf, len / 2); + if (res < 0) { + DEBUGA_SOUND("Silence error %s\n", CELLIAX_P_LOG, snd_strerror(res)); + res = -1; + } + res = snd_pcm_writei(p->alsap, silencebuf, len / 2); + if (res < 0) { + DEBUGA_SOUND("Write error %s\n", CELLIAX_P_LOG, snd_strerror(res)); + res = -1; + } else if (res != len / 2) { + DEBUGA_SOUND("Write returned a different quantity: %d\n", CELLIAX_P_LOG, res); + res = -1; + } + } + + DEBUGA_SOUND + ("PREVENTING an ALSA write XRUN (celliax can't fill the soundcard buffer fast enough). If this happens often (not after silence or after a pause in the speech, that's OK), and appear to damage the sound quality, first check if you have some IRQ problem, maybe sharing the soundcard IRQ with a broken or heavy loaded ethernet or graphic card. Then consider to increase the alsa_periods_in_buffer (now is set to %d) for this interface in the config file. delayp1=%d, delayp2=%d\n", + CELLIAX_P_LOG, p->alsa_periods_in_buffer, (int) delayp1, (int) delayp2); + } + + } + + memset(sizbuf2, 0, sizeof(sizbuf2)); + if (p->alsa_play_is_mono) { + res = snd_pcm_writei(p->alsap, sizbuf, len / 2); + } else { + int a = 0; + int i = 0; + for (i = 0; i < 8000;) { + sizbuf2[a] = sizbuf[i]; + a++; + i++; + sizbuf2[a] = sizbuf[i]; + a++; + i--; + sizbuf2[a] = sizbuf[i]; // comment out this line to use only left + a++; + i++; + sizbuf2[a] = sizbuf[i]; // comment out this line to use only left + a++; + i++; + } + res = snd_pcm_writei(p->alsap, sizbuf2, len); + } + if (res == -EPIPE) { + DEBUGA_SOUND + ("ALSA write EPIPE (XRUN) (celliax can't fill the soundcard buffer fast enough). If this happens often (not after silence or after a pause in the speech, that's OK), and appear to damage the sound quality, first check if you have some IRQ problem, maybe sharing the soundcard IRQ with a broken or heavy loaded ethernet or graphic card. Then consider to increase the alsa_periods_in_buffer (now is set to %d) for this interface in the config file. delayp1=%d, delayp2=%d\n", + CELLIAX_P_LOG, p->alsa_periods_in_buffer, (int) delayp1, (int) delayp2); + res = snd_pcm_prepare(p->alsap); + if (res) { + ERRORA("audio play prepare failed: %s\n", CELLIAX_P_LOG, snd_strerror(res)); + } else { + + if (p->alsa_play_is_mono) { + res = snd_pcm_writei(p->alsap, sizbuf, len / 2); + } else { + int a = 0; + int i = 0; + for (i = 0; i < 8000;) { + sizbuf2[a] = sizbuf[i]; + a++; + i++; + sizbuf2[a] = sizbuf[i]; + a++; + i--; + sizbuf2[a] = sizbuf[i]; + a++; + i++; + sizbuf2[a] = sizbuf[i]; + a++; + i++; + } + res = snd_pcm_writei(p->alsap, sizbuf2, len); + } + + } + + } else { + if (res == -ESTRPIPE) { + ERRORA("You've got some big problems\n", CELLIAX_P_LOG); + } else if (res == -EAGAIN) { + res = 0; + } else if (res < 0) { + ERRORA("Error %d on audio write: \"%s\"\n", CELLIAX_P_LOG, res, + snd_strerror(res)); + } + } + } + + if (p->audio_play_reset_period) { + time(&now_timestamp); + if ((now_timestamp - p->audio_play_reset_timestamp) > p->audio_play_reset_period) { + if (option_debug) + DEBUGA_SOUND("reset audio play\n", CELLIAX_P_LOG); + res = snd_pcm_wait(p->alsap, 1000); + if (res < 0) { + ERRORA("audio play wait failed: %s\n", CELLIAX_P_LOG, snd_strerror(res)); + } + res = snd_pcm_drop(p->alsap); + if (res) { + ERRORA("audio play drop failed: %s\n", CELLIAX_P_LOG, snd_strerror(res)); + } + res = snd_pcm_prepare(p->alsap); + if (res) { + ERRORA("audio play prepare failed: %s\n", CELLIAX_P_LOG, snd_strerror(res)); + } + res = snd_pcm_wait(p->alsap, 1000); + if (res < 0) { + ERRORA("audio play wait failed: %s\n", CELLIAX_P_LOG, snd_strerror(res)); + } + time(&p->audio_play_reset_timestamp); + } + } + res = 0; + if (res > 0) + res = 0; + return res; +} + + +/*! \brief Write audio frames to interface */ +#endif /* CELLIAX_ALSA */ + +#ifdef CELLIAX_PORTAUDIO +int celliax_portaudio_devlist(struct celliax_pvt *p) +{ + int i, numDevices; + const PaDeviceInfo *deviceInfo; + + numDevices = Pa_GetDeviceCount(); + if (numDevices < 0) { + return 0; + } + for (i = 0; i < numDevices; i++) { + deviceInfo = Pa_GetDeviceInfo(i); + NOTICA + ("Found PORTAUDIO device: id=%d\tname=%s\tmax input channels=%d\tmax output channels=%d\n", + CELLIAX_P_LOG, i, deviceInfo->name, deviceInfo->maxInputChannels, + deviceInfo->maxOutputChannels); + } + + return numDevices; +} + +int celliax_portaudio_init(struct celliax_pvt *p) +{ + PaError err; + int c; + PaStreamParameters inputParameters, outputParameters; + int numdevices; + const PaDeviceInfo *deviceInfo; + +#ifndef GIOVA48 + setenv("PA_ALSA_PLUGHW", "1", 1); +#endif // GIOVA48 + + err = Pa_Initialize(); + if (err != paNoError) + return err; + + numdevices = celliax_portaudio_devlist(p); + + if (p->portaudiocindex > (numdevices - 1)) { + ERRORA("Portaudio Capture id=%d is out of range: valid id are from 0 to %d\n", + CELLIAX_P_LOG, p->portaudiocindex, (numdevices - 1)); + return -1; + } + + if (p->portaudiopindex > (numdevices - 1)) { + ERRORA("Portaudio Playback id=%d is out of range: valid id are from 0 to %d\n", + CELLIAX_P_LOG, p->portaudiopindex, (numdevices - 1)); + return -1; + } + //inputParameters.device = 0; + if (p->portaudiocindex != -1) { + inputParameters.device = p->portaudiocindex; + } else { + inputParameters.device = Pa_GetDefaultInputDevice(); + } + deviceInfo = Pa_GetDeviceInfo(inputParameters.device); + NOTICA + ("Using INPUT PORTAUDIO device: id=%d\tname=%s\tmax input channels=%d\tmax output channels=%d\n", + CELLIAX_P_LOG, inputParameters.device, deviceInfo->name, + deviceInfo->maxInputChannels, deviceInfo->maxOutputChannels); + if (deviceInfo->maxInputChannels == 0) { + ERRORA + ("No INPUT channels on device: id=%d\tname=%s\tmax input channels=%d\tmax output channels=%d\n", + CELLIAX_P_LOG, inputParameters.device, deviceInfo->name, + deviceInfo->maxInputChannels, deviceInfo->maxOutputChannels); + return -1; + } + inputParameters.channelCount = 1; + inputParameters.sampleFormat = paInt16; + //inputParameters.suggestedLatency = Pa_GetDeviceInfo(inputParameters.device)->defaultHighInputLatency; + inputParameters.suggestedLatency = 0.1; + inputParameters.hostApiSpecificStreamInfo = NULL; + + //outputParameters.device = 3; + if (p->portaudiopindex != -1) { + outputParameters.device = p->portaudiopindex; + } else { + outputParameters.device = Pa_GetDefaultOutputDevice(); + } + deviceInfo = Pa_GetDeviceInfo(outputParameters.device); + NOTICA + ("Using OUTPUT PORTAUDIO device: id=%d\tname=%s\tmax input channels=%d\tmax output channels=%d\n", + CELLIAX_P_LOG, outputParameters.device, deviceInfo->name, + deviceInfo->maxInputChannels, deviceInfo->maxOutputChannels); + if (deviceInfo->maxOutputChannels == 0) { + ERRORA + ("No OUTPUT channels on device: id=%d\tname=%s\tmax input channels=%d\tmax output channels=%d\n", + CELLIAX_P_LOG, inputParameters.device, deviceInfo->name, + deviceInfo->maxInputChannels, deviceInfo->maxOutputChannels); + return -1; + } +#ifndef GIOVA48 + outputParameters.channelCount = 1; +#else // GIOVA48 + outputParameters.channelCount = 2; +#endif // GIOVA48 + outputParameters.sampleFormat = paInt16; + //outputParameters.suggestedLatency = Pa_GetDeviceInfo(outputParameters.device)->defaultHighOutputLatency; + outputParameters.suggestedLatency = 0.1; + outputParameters.hostApiSpecificStreamInfo = NULL; + +/* build the pipe that will be polled on by pbx */ + c = pipe(p->audiopipe); + if (c) { + ERRORA("Unable to create audio pipe\n", CELLIAX_P_LOG); + return -1; + } + fcntl(p->audiopipe[0], F_SETFL, O_NONBLOCK); + fcntl(p->audiopipe[1], F_SETFL, O_NONBLOCK); + + err = +#ifndef GIOVA48 + OpenAudioStream(&p->stream, &inputParameters, &outputParameters, 8000, + paDitherOff | paClipOff, SAMPLES_PER_FRAME, p->audiopipe[1], + &p->speexecho, &p->speexpreprocess, &p->owner); + +#else // GIOVA48 + OpenAudioStream(&p->stream, &inputParameters, &outputParameters, 48000, + paDitherOff | paClipOff, SAMPLES_PER_FRAME, p->audiopipe[1], + &p->speexecho, &p->speexpreprocess, &p->owner); + +#endif // GIOVA48 + if (err != paNoError) { + ERRORA("Unable to open audio stream: %s\n", CELLIAX_P_LOG, Pa_GetErrorText(err)); + return -1; + } + +/* the pipe is our audio fd for pbx to poll on */ + p->celliax_sound_capt_fd = p->audiopipe[0]; + + return 0; +} + +int celliax_portaudio_write(struct celliax_pvt *p, struct ast_frame *f) +{ + int samples; +#ifdef GIOVA48 + //short buf[CELLIAX_FRAME_SIZE * 2]; + short buf[3840]; + short *buf2; + + //ERRORA("1 f->datalen=: %d\n", CELLIAX_P_LOG, f->datalen); + + memset(buf, '\0', CELLIAX_FRAME_SIZE * 2); + + buf2 = f->data; + + int i = 0, a = 0; + + for (i = 0; i < f->datalen / sizeof(short); i++) { +//stereo, 2 chan 48 -> mono 8 + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + /* + */ + } + f->data = &buf; + f->datalen = f->datalen * 6; + //ERRORA("2 f->datalen=: %d\n", CELLIAX_P_LOG, f->datalen); + //f->datalen = f->datalen; +#endif // GIOVA48 + +#ifdef ASTERISK_VERSION_1_6_0_1 + samples = + WriteAudioStream(p->stream, (short *) f->data.ptr, + (int) (f->datalen / sizeof(short))); +#else + samples = + WriteAudioStream(p->stream, (short *) f->data, (int) (f->datalen / sizeof(short))); +#endif /* ASTERISK_VERSION_1_6_0_1 */ + + if (samples != (int) (f->datalen / sizeof(short))) + ERRORA("WriteAudioStream wrote: %d of %d\n", CELLIAX_P_LOG, samples, + (int) (f->datalen / sizeof(short))); + + return 0; +} + +struct ast_frame *celliax_portaudio_read(struct celliax_pvt *p) +{ + static struct ast_frame f; + static short __buf[CELLIAX_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2]; + short *buf; + static short __buf2[CELLIAX_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2]; + short *buf2; + int samples; + char c; + + memset(__buf, '\0', (CELLIAX_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2)); + + buf = __buf + AST_FRIENDLY_OFFSET / 2; + + memset(__buf2, '\0', (CELLIAX_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2)); + + buf2 = __buf2 + AST_FRIENDLY_OFFSET / 2; + + f.frametype = AST_FRAME_NULL; + f.subclass = 0; + f.samples = 0; + f.datalen = 0; + +#ifdef ASTERISK_VERSION_1_6_0_1 + f.data.ptr = NULL; +#else + f.data = NULL; +#endif /* ASTERISK_VERSION_1_6_0_1 */ + f.offset = 0; + f.src = celliax_type; + f.mallocd = 0; + f.delivery.tv_sec = 0; + f.delivery.tv_usec = 0; + + if ((samples = ReadAudioStream(p->stream, buf, SAMPLES_PER_FRAME)) == 0) { + //do nothing + } else { +#ifdef GIOVA48 + int i = 0, a = 0; + + samples = samples / 6; + for (i = 0; i < samples; i++) { + buf2[i] = buf[a]; + a = a + 6; //mono, 1 chan 48 -> 8 + } + buf = buf2; + + /* A real frame */ + f.frametype = AST_FRAME_VOICE; + f.subclass = AST_FORMAT_SLINEAR; + f.samples = CELLIAX_FRAME_SIZE / 6; + f.datalen = CELLIAX_FRAME_SIZE * 2 / 6; +#else // GIOVA48 + /* A real frame */ + f.frametype = AST_FRAME_VOICE; + f.subclass = AST_FORMAT_SLINEAR; + f.samples = CELLIAX_FRAME_SIZE; + f.datalen = CELLIAX_FRAME_SIZE * 2; +#endif // GIOVA48 + +#ifdef ASTERISK_VERSION_1_6_0_1 + f.data.ptr = buf; +#else + f.data = buf; +#endif /* ASTERISK_VERSION_1_6_0_1 */ + f.offset = AST_FRIENDLY_OFFSET; + f.src = celliax_type; + f.mallocd = 0; + } + + read(p->audiopipe[0], &c, 1); + + return &f; +} + +int celliax_portaudio_shutdown(struct celliax_pvt *p) +{ + PaError err; + + err = CloseAudioStream(p->stream); + + if (err != paNoError) + ERRORA("not able to CloseAudioStream\n", CELLIAX_P_LOG); + + Pa_Terminate(); + return 0; +} +#endif // CELLIAX_PORTAUDIO + +int celliax_serial_sync_AT(struct celliax_pvt *p) +{ + usleep(10000); /* 10msec */ + time(&p->celliax_serial_synced_timestamp); + return 0; +} + +int celliax_serial_getstatus_AT(struct celliax_pvt *p) +{ + int res; + + if (p->owner) { + if (p->owner->_state != AST_STATE_UP && p->owner->_state != AST_STATE_DOWN) { + DEBUGA_AT("No getstatus, we're neither UP nor DOWN\n", CELLIAX_P_LOG); + return 0; + } + } + + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + res = celliax_serial_write_AT_ack(p, "AT"); + if (res) { + ERRORA("AT was not acknowledged, continuing but maybe there is a problem\n", + CELLIAX_P_LOG); + } + usleep(1000); + + if (strlen(p->at_query_battchg)) { + res = + celliax_serial_write_AT_expect(p, p->at_query_battchg, p->at_query_battchg_expect); + if (res) { + WARNINGA("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_query_battchg, p->at_query_battchg_expect); + } + usleep(1000); + } + + if (strlen(p->at_query_signal)) { + res = + celliax_serial_write_AT_expect(p, p->at_query_signal, p->at_query_signal_expect); + if (res) { + WARNINGA("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_query_signal, p->at_query_signal_expect); + } + usleep(1000); + } + //FIXME all the following commands in config! + + if (p->sms_cnmi_not_supported) { + res = celliax_serial_write_AT_ack(p, "AT+MMGL=\"HEADER ONLY\""); + if (res) { + WARNINGA + ("%s does not get %s from the modem, maybe a long msg is incoming. If this cellmodem is not a Motorola, you are arriving here because your cellmodem do not supports CNMI kind of incoming SMS alert; please let it know to the developers of Celliax. If this cellmodem is a Motorola and this message keeps repeating, and you cannot correctly receive SMSs from this interface, please manually clean all messages from the cellmodem/SIM. Continuing.\n", + CELLIAX_P_LOG, "AT+MMGL=\"HEADER ONLY\"", "OK"); + } else { + usleep(1000); + if (p->unread_sms_msg_id) { + char at_command[256]; + + if (p->no_ucs2 == 0) { + res = celliax_serial_write_AT_ack(p, "AT+CSCS=\"UCS2\""); + if (res) { + ERRORA + ("AT+CSCS=\"UCS2\" (set TE messages to ucs2) do not got OK from the phone\n", + CELLIAX_P_LOG); + memset(p->sms_message, 0, sizeof(p->sms_message)); + } + } + + memset(at_command, 0, sizeof(at_command)); + sprintf(at_command, "AT+CMGR=%d", p->unread_sms_msg_id); + memset(p->sms_message, 0, sizeof(p->sms_message)); + + p->reading_sms_msg = 1; + res = celliax_serial_write_AT_ack(p, at_command); + p->reading_sms_msg = 0; + if (res) { + ERRORA + ("AT+CMGR (read SMS) do not got OK from the phone, message sent was:|||%s|||\n", + CELLIAX_P_LOG, at_command); + } + res = celliax_serial_write_AT_ack(p, "AT+CSCS=\"GSM\""); + if (res) { + ERRORA + ("AT+CSCS=\"GSM\" (set TE messages to GSM) do not got OK from the phone\n", + CELLIAX_P_LOG); + } + memset(at_command, 0, sizeof(at_command)); + sprintf(at_command, "AT+CMGD=%d", p->unread_sms_msg_id); /* delete the message */ + p->unread_sms_msg_id = 0; + res = celliax_serial_write_AT_ack(p, at_command); + if (res) { + ERRORA + ("AT+CMGD (Delete SMS) do not got OK from the phone, message sent was:|||%s|||\n", + CELLIAX_P_LOG, at_command); + } + + if (strlen(p->sms_message)) { + + manager_event(EVENT_FLAG_SYSTEM, "CELLIAXincomingsms", + "Interface: %s\r\nSMS_Message: %s\r\n", p->name, p->sms_message); + + if (strlen(p->sms_receiving_program)) { + int fd1[2]; + pid_t pid1; + char *arg1[] = { p->sms_receiving_program, (char *) NULL }; + int i; + + NOTICA("incoming SMS message:>>>%s<<<\n", CELLIAX_P_LOG, p->sms_message); + pipe(fd1); + pid1 = fork(); + + if (pid1 == 0) { //child + int err; + + dup2(fd1[0], 0); // Connect stdin to pipe output + close(fd1[1]); // close input pipe side + setsid(); //session id + err = execvp(arg1[0], arg1); //exec our program, with stdin connected to pipe output + if (err) { + ERRORA + ("'sms_receiving_program' is set in config file to '%s', and it gave us back this error: %d, (%s). SMS received was:---%s---\n", + CELLIAX_P_LOG, p->sms_receiving_program, err, strerror(errno), + p->sms_message); + } + close(fd1[0]); // close output pipe side + } //starting here continue the parent + close(fd1[0]); // close output pipe side + // write the msg on the pipe input + for (i = 0; i < strlen(p->sms_message); i++) { + write(fd1[1], &p->sms_message[i], 1); + } + close(fd1[1]); // close pipe input, let our program know we've finished + } else { + ERRORA + ("got SMS incoming message, but 'sms_receiving_program' is not set in config file. SMS received was:---%s---\n", + CELLIAX_P_LOG, p->sms_message); + } + } +#if 1 //is this one needed? maybe it can interrupt an incoming call that is just to announce itself + if (p->phone_callflow == CALLFLOW_CALL_IDLE + && p->interface_state == AST_STATE_DOWN && p->owner == NULL) { + /* we're not in a call, neither calling */ + res = celliax_serial_write_AT_ack(p, "AT+CKPD=\"EEE\""); + if (res) { + ERRORA + ("AT+CKPD=\"EEE\" (cellphone screen back to user) do not got OK from the phone\n", + CELLIAX_P_LOG); + } + } +#endif + } + } + } + + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + return 0; +} + +int celliax_serial_read_AT(struct celliax_pvt *p, int look_for_ack, int timeout_usec, + int timeout_sec, const char *expected_string, int expect_crlf) +{ + int select_err; + int res; + fd_set read_fds; + struct timeval timeout; + char tmp_answer[AT_BUFSIZ]; + char tmp_answer2[AT_BUFSIZ]; + char *tmp_answer_ptr; + char *last_line_ptr; + int i = 0; + int read_count = 0; + int la_counter = 0; + int at_ack = -1; + int la_read = 0; + + FD_ZERO(&read_fds); + FD_SET(p->controldevfd, &read_fds); + + //NOTICA (" INSIDE this celliax_serial_device %s \n", CELLIAX_P_LOG, p->controldevice_name); + tmp_answer_ptr = tmp_answer; + memset(tmp_answer, 0, sizeof(char) * AT_BUFSIZ); + + timeout.tv_sec = timeout_sec; + timeout.tv_usec = timeout_usec; + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + + while ((select_err = select(p->controldevfd + 1, &read_fds, NULL, NULL, &timeout)) > 0) { + timeout.tv_sec = timeout_sec; //reset the timeout, linux modify it + timeout.tv_usec = timeout_usec; //reset the timeout, linux modify it + read_count = + read(p->controldevfd, tmp_answer_ptr, AT_BUFSIZ - (tmp_answer_ptr - tmp_answer)); + + if (read_count == 0) { + ERRORA + ("read 0 bytes!!! Nenormalno! Marking this celliax_serial_device %s as dead, andif it is owned by a channel, hanging up. Maybe the phone is stuck, switched off, power down or battery exhausted\n", + CELLIAX_P_LOG, p->controldevice_name); + p->controldev_dead = 1; + close(p->controldevfd); + UNLOCKA(&p->controldev_lock); + if (p->owner) { + p->owner->hangupcause = AST_CAUSE_FAILURE; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + } + return -1; + } + + if (option_debug > 90) { + //DEBUGA_AT("1 read %d bytes, --|%s|--\n", CELLIAX_P_LOG, read_count, tmp_answer_ptr); + //DEBUGA_AT("2 read %d bytes, --|%s|--\n", CELLIAX_P_LOG, read_count, tmp_answer); + } + tmp_answer_ptr = tmp_answer_ptr + read_count; + + char *token_ptr; + + la_counter = 0; + memset(tmp_answer2, 0, sizeof(char) * AT_BUFSIZ); + strcpy(tmp_answer2, tmp_answer); + if ((token_ptr = strtok(tmp_answer2, "\n\r"))) { + last_line_ptr = token_ptr; + strncpy(p->line_array.result[la_counter], token_ptr, AT_MESG_MAX_LENGTH); + if (strlen(token_ptr) > AT_MESG_MAX_LENGTH) { + WARNINGA + ("AT mesg longer than buffer, original message was: |%s|, in buffer only: |%s|\n", + CELLIAX_P_LOG, token_ptr, p->line_array.result[la_counter]); + } + la_counter++; + while ((token_ptr = strtok(NULL, "\n\r"))) { + last_line_ptr = token_ptr; + strncpy(p->line_array.result[la_counter], token_ptr, AT_MESG_MAX_LENGTH); + if (strlen(token_ptr) > AT_MESG_MAX_LENGTH) { + WARNINGA + ("AT mesg longer than buffer, original message was: |%s|, in buffer only: |%s|\n", + CELLIAX_P_LOG, token_ptr, p->line_array.result[la_counter]); + } + la_counter++; + } + } else { + last_line_ptr = tmp_answer; + } + + if (expected_string && !expect_crlf) { + DEBUGA_AT + ("last_line_ptr=|%s|, expected_string=|%s|, expect_crlf=%d, memcmp(last_line_ptr, expected_string, strlen(expected_string)) = %d\n", + CELLIAX_P_LOG, last_line_ptr, expected_string, expect_crlf, memcmp(last_line_ptr, + expected_string, + strlen + (expected_string))); + } + + if (expected_string && !expect_crlf + && !memcmp(last_line_ptr, expected_string, strlen(expected_string)) + ) { + strncpy(p->line_array.result[la_counter], last_line_ptr, AT_MESG_MAX_LENGTH); + // match expected string -> accept it withtout CRLF + la_counter++; + + } + /* if the last line read was not a complete line, we'll read the rest in the future */ + else if (tmp_answer[strlen(tmp_answer) - 1] != '\r' + && tmp_answer[strlen(tmp_answer) - 1] != '\n') + la_counter--; + + /* let's list the complete lines read so far, without re-listing the lines that has yet been listed */ + if (option_debug > 1) { + for (i = la_read; i < la_counter; i++) + DEBUGA_AT("Read line %d: |%s|\n", CELLIAX_P_LOG, i, p->line_array.result[i]); + } + + /* let's interpret the complete lines read so far (WITHOUT looking for OK, ERROR, and EXPECTED_STRING), without re-interpreting the lines that has been yet interpreted, so we're sure we don't miss anything */ + for (i = la_read; i < la_counter; i++) { + + if ((strcmp(p->line_array.result[i], "RING") == 0)) { + /* with first RING we wait for callid */ + gettimeofday(&(p->ringtime), NULL); + /* give CALLID (+CLIP) a chance, wait for the next RING before answering */ + if (p->phone_callflow == CALLFLOW_INCOMING_RING) { + /* we're at the second ring, set the interface state, will be answered by celliax_do_monitor */ + DEBUGA_AT("|%s| got second RING\n", CELLIAX_P_LOG, p->line_array.result[i]); + p->interface_state = AST_STATE_RING; + } else { + /* we're at the first ring, so there is no CALLID yet thus clean the previous one + just in case we don't receive the caller identification in this new call */ + memset(p->callid_name, 0, sizeof(p->callid_name)); + memset(p->callid_number, 0, sizeof(p->callid_number)); + /* only send AT+CLCC? if the device previously reported its support */ + if (p->at_has_clcc != 0) { + /* we're at the first ring, try to get CALLID (with +CLCC) */ + DEBUGA_AT("|%s| got first RING, sending AT+CLCC?\n", CELLIAX_P_LOG, + p->line_array.result[i]); + res = celliax_serial_write_AT_noack(p, "AT+CLCC?"); + if (res) { + ERRORA("AT+CLCC? (call list) was not correctly sent to the phone\n", + CELLIAX_P_LOG); + } + } else { + DEBUGA_AT("|%s| got first RING, but not sending AT+CLCC? as this device " + "seems not to support\n", CELLIAX_P_LOG, p->line_array.result[i]); + } + } + p->phone_callflow = CALLFLOW_INCOMING_RING; + } + + if ((strncmp(p->line_array.result[i], "+CLCC", 5) == 0)) { + /* with clcc we wait for clip */ + memset(p->callid_name, 0, sizeof(p->callid_name)); + memset(p->callid_number, 0, sizeof(p->callid_number)); + int commacount = 0; + int a = 0; + int b = 0; + int c = 0; + + for (a = 0; a < strlen(p->line_array.result[i]); a++) { + + if (p->line_array.result[i][a] == ',') { + commacount++; + } + if (commacount == 5) { + if (p->line_array.result[i][a] != ',' && p->line_array.result[i][a] != '"') { + p->callid_number[b] = p->line_array.result[i][a]; + b++; + } + } + if (commacount == 7) { + if (p->line_array.result[i][a] != ',' && p->line_array.result[i][a] != '"') { + p->callid_name[c] = p->line_array.result[i][a]; + c++; + } + } + } + + p->phone_callflow = CALLFLOW_INCOMING_RING; + DEBUGA_AT("|%s| CLCC CALLID: name is %s, number is %s\n", CELLIAX_P_LOG, + p->line_array.result[i], + p->callid_name[0] ? p->callid_name : "not available", + p->callid_number[0] ? p->callid_number : "not available"); + } + + if ((strncmp(p->line_array.result[i], "+CLIP", 5) == 0)) { + /* with CLIP, we want to answer right away */ + memset(p->callid_name, 0, sizeof(p->callid_name)); + memset(p->callid_number, 0, sizeof(p->callid_number)); + + int commacount = 0; + int a = 0; + int b = 0; + int c = 0; + + for (a = 7; a < strlen(p->line_array.result[i]); a++) { + if (p->line_array.result[i][a] == ',') { + commacount++; + } + if (commacount == 0) { + if (p->line_array.result[i][a] != ',' && p->line_array.result[i][a] != '"') { + p->callid_number[b] = p->line_array.result[i][a]; + b++; + } + } + if (commacount == 4) { + if (p->line_array.result[i][a] != ',' && p->line_array.result[i][a] != '"') { + p->callid_name[c] = p->line_array.result[i][a]; + c++; + } + } + } + + if (p->interface_state != AST_STATE_RING) { + gettimeofday(&(p->call_incoming_time), NULL); + DEBUGA_AT("AST_STATE_RING call_incoming_time.tv_sec=%ld\n", + CELLIAX_P_LOG, p->call_incoming_time.tv_sec); + + } + + p->interface_state = AST_STATE_RING; + p->phone_callflow = CALLFLOW_INCOMING_RING; + DEBUGA_AT("|%s| CLIP INCOMING CALLID: name is %s, number is %s\n", CELLIAX_P_LOG, + p->line_array.result[i], + p->callid_name[0] != 1 ? p->callid_name : "not available", + p->callid_number[0] ? p->callid_number : "not available"); + } + + if ((strcmp(p->line_array.result[i], "BUSY") == 0)) { + p->phone_callflow = CALLFLOW_CALL_LINEBUSY; + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_LINEBUSY\n", CELLIAX_P_LOG, + p->line_array.result[i]); + if (p->interface_state != AST_STATE_DOWN && p->owner) { + ast_setstate(p->owner, AST_STATE_BUSY); + celliax_queue_control(p->owner, AST_CONTROL_BUSY); + } else { + ERRORA("Why BUSY now?\n", CELLIAX_P_LOG); + } + } + if ((strcmp(p->line_array.result[i], "NO ANSWER") == 0)) { + p->phone_callflow = CALLFLOW_CALL_NOANSWER; + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_NOANSWER\n", CELLIAX_P_LOG, + p->line_array.result[i]); + if (p->interface_state != AST_STATE_DOWN && p->owner) { + p->owner->hangupcause = AST_CAUSE_NO_ANSWER; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + } else { + ERRORA("Why NO ANSWER now?\n", CELLIAX_P_LOG); + } + } + if ((strcmp(p->line_array.result[i], "NO CARRIER") == 0)) { + if (p->phone_callflow != CALLFLOW_CALL_HANGUP_REQUESTED) { + p->phone_callflow = CALLFLOW_CALL_NOCARRIER; + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_NOCARRIER\n", CELLIAX_P_LOG, + p->line_array.result[i]); + p->control_to_send = 0; + usleep(20000); + if (p->interface_state != AST_STATE_DOWN && p->owner) { + p->owner->hangupcause = AST_CAUSE_FAILURE; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + } else { + ERRORA("Why NO CARRIER now?\n", CELLIAX_P_LOG); + } + } + } + + if ((strncmp(p->line_array.result[i], "+CBC:", 5) == 0)) { + int power_supply, battery_strenght, err; + + power_supply = battery_strenght = 0; + + err = + sscanf(&p->line_array.result[i][6], "%d,%d", &power_supply, &battery_strenght); + if (err < 2) { + DEBUGA_AT("|%s| is not formatted as: |+CBC: xx,yy| now trying |+CBC:xx,yy|\n", + CELLIAX_P_LOG, p->line_array.result[i]); + + err = + sscanf(&p->line_array.result[i][5], "%d,%d", &power_supply, + &battery_strenght); + DEBUGA_AT("|%s| +CBC: Powered by %s, battery strenght=%d\n", CELLIAX_P_LOG, + p->line_array.result[i], power_supply ? "power supply" : "battery", + battery_strenght); + + } + + if (err < 2) { + DEBUGA_AT("|%s| is not formatted as: |+CBC:xx,yy| giving up\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + else { + if (option_debug > 1) + DEBUGA_AT("|%s| +CBC: Powered by %s, battery strenght=%d\n", CELLIAX_P_LOG, + p->line_array.result[i], power_supply ? "power supply" : "battery", + battery_strenght); + if (!power_supply) { + if (battery_strenght < 10) { + ERRORA("|%s| BATTERY ALMOST EXHAUSTED\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } else if (battery_strenght < 20) { + WARNINGA("|%s| BATTERY LOW\n", CELLIAX_P_LOG, p->line_array.result[i]); + + } + + } + } + + } + + if ((strncmp(p->line_array.result[i], "+CSQ:", 5) == 0)) { + int signal_quality, ber, err; + + signal_quality = ber = 0; + + err = sscanf(&p->line_array.result[i][6], "%d,%d", &signal_quality, &ber); + if (option_debug > 1) + DEBUGA_AT("|%s| +CSQ: Signal Quality: %d, Error Rate=%d\n", CELLIAX_P_LOG, + p->line_array.result[i], signal_quality, ber); + if (err < 2) { + ERRORA("|%s| is not formatted as: |+CSQ: xx,yy|\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } else { + if (signal_quality < 11 || signal_quality == 99) { + WARNINGA + ("|%s| CELLPHONE GETS ALMOST NO SIGNAL, consider to move it or additional antenna\n", + CELLIAX_P_LOG, p->line_array.result[i]); + } else if (signal_quality < 15) { + WARNINGA("|%s| CELLPHONE GETS SIGNAL LOW\n", CELLIAX_P_LOG, + p->line_array.result[i]); + + } + + } + + } + if ((strncmp(p->line_array.result[i], "+CMGW:", 6) == 0)) { + int err; + + err = sscanf(&p->line_array.result[i][7], "%s", p->at_cmgw); + DEBUGA_AT("|%s| +CMGW: %s\n", CELLIAX_P_LOG, p->line_array.result[i], p->at_cmgw); + if (err < 1) { + ERRORA("|%s| is not formatted as: |+CMGW: xxxx|\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + } + + /* at_call_* are unsolicited messages sent by the modem to signal us about call processing activity and events */ + if ((strcmp(p->line_array.result[i], p->at_call_idle) == 0)) { + p->phone_callflow = CALLFLOW_CALL_IDLE; + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_IDLE\n", CELLIAX_P_LOG, p->line_array.result[i]); + if (p->interface_state != AST_STATE_DOWN && p->owner) { + DEBUGA_AT("just received a remote HANGUP\n", CELLIAX_P_LOG); + p->owner->hangupcause = AST_CAUSE_NORMAL; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + DEBUGA_AT("just sent AST_CONTROL_HANGUP\n", CELLIAX_P_LOG); + } + } + + if ((strcmp(p->line_array.result[i], p->at_call_incoming) == 0)) { + + //char list_command[64]; + + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_INCOMING\n", CELLIAX_P_LOG, + p->line_array.result[i]); + + if (p->phone_callflow != CALLFLOW_CALL_INCOMING + && p->phone_callflow != CALLFLOW_INCOMING_RING) { + //mark the time of CALLFLOW_CALL_INCOMING + gettimeofday(&(p->call_incoming_time), NULL); + p->phone_callflow = CALLFLOW_CALL_INCOMING; + DEBUGA_AT("CALLFLOW_CALL_INCOMING call_incoming_time.tv_sec=%ld\n", + CELLIAX_P_LOG, p->call_incoming_time.tv_sec); + + } + } + + if ((strcmp(p->line_array.result[i], p->at_call_active) == 0)) { + p->phone_callflow = CALLFLOW_CALL_ACTIVE; + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_ACTIVE\n", CELLIAX_P_LOG, + p->line_array.result[i]); + + if (p->owner && p->interface_state == CALLFLOW_CALL_DIALING) { + DEBUGA_PBX("just received a remote ANSWER\n", CELLIAX_P_LOG); + if (p->owner->_state != AST_STATE_UP) { + celliax_queue_control(p->owner, AST_CONTROL_RINGING); + DEBUGA_PBX("just sent AST_CONTROL_RINGING\n", CELLIAX_P_LOG); + DEBUGA_PBX("going to send AST_CONTROL_ANSWER\n", CELLIAX_P_LOG); + celliax_queue_control(p->owner, AST_CONTROL_ANSWER); + DEBUGA_PBX("just sent AST_CONTROL_ANSWER\n", CELLIAX_P_LOG); + } + } else { + } + p->interface_state = AST_STATE_UP; + DEBUGA_PBX("just interface_state UP\n", CELLIAX_P_LOG); + } + + if ((strcmp(p->line_array.result[i], p->at_call_calling) == 0)) { + p->phone_callflow = CALLFLOW_CALL_DIALING; + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_DIALING\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + if ((strcmp(p->line_array.result[i], p->at_call_failed) == 0)) { + p->phone_callflow = CALLFLOW_CALL_FAILED; + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_FAILED\n", CELLIAX_P_LOG, + p->line_array.result[i]); + if (p->interface_state != AST_STATE_DOWN && p->owner) { + p->owner->hangupcause = AST_CAUSE_FAILURE; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + } + } + + if ((strncmp(p->line_array.result[i], "+CSCA:", 6) == 0)) { //TODO SMS FIXME in config! + if (option_debug > 1) + DEBUGA_AT("|%s| +CSCA: Message Center Address!\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strncmp(p->line_array.result[i], "+CMGF:", 6) == 0)) { //TODO SMS FIXME in config! + if (option_debug > 1) + DEBUGA_AT("|%s| +CMGF: Message Format!\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strncmp(p->line_array.result[i], "+CMTI:", 6) == 0)) { //TODO SMS FIXME in config! + int err; + int pos; + + //FIXME all the following commands in config! + if (option_debug) + DEBUGA_AT("|%s| +CMTI: Incoming SMS!\n", CELLIAX_P_LOG, + p->line_array.result[i]); + + err = sscanf(&p->line_array.result[i][12], "%d", &pos); + if (err < 1) { + ERRORA("|%s| is not formatted as: |+CMTI: \"MT\",xx|\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } else { + DEBUGA_AT("|%s| +CMTI: Incoming SMS in position: %d!\n", CELLIAX_P_LOG, + p->line_array.result[i], pos); + p->unread_sms_msg_id = pos; + usleep(1000); + + if (p->unread_sms_msg_id) { + char at_command[256]; + + if (p->no_ucs2 == 0) { + res = celliax_serial_write_AT_ack(p, "AT+CSCS=\"UCS2\""); + if (res) { + ERRORA + ("AT+CSCS=\"UCS2\" (set TE messages to ucs2) do not got OK from the phone, continuing\n", + CELLIAX_P_LOG); + //memset(p->sms_message, 0, sizeof(p->sms_message)); + } + } + + memset(at_command, 0, sizeof(at_command)); + sprintf(at_command, "AT+CMGR=%d", p->unread_sms_msg_id); + memset(p->sms_message, 0, sizeof(p->sms_message)); + + p->reading_sms_msg = 1; + res = celliax_serial_write_AT_ack(p, at_command); + p->reading_sms_msg = 0; + if (res) { + ERRORA + ("AT+CMGR (read SMS) do not got OK from the phone, message sent was:|||%s|||\n", + CELLIAX_P_LOG, at_command); + } + res = celliax_serial_write_AT_ack(p, "AT+CSCS=\"GSM\""); + if (res) { + ERRORA + ("AT+CSCS=\"GSM\" (set TE messages to GSM) do not got OK from the phone\n", + CELLIAX_P_LOG); + } + memset(at_command, 0, sizeof(at_command)); + sprintf(at_command, "AT+CMGD=%d", p->unread_sms_msg_id); /* delete the message */ + p->unread_sms_msg_id = 0; + res = celliax_serial_write_AT_ack(p, at_command); + if (res) { + ERRORA + ("AT+CMGD (Delete SMS) do not got OK from the phone, message sent was:|||%s|||\n", + CELLIAX_P_LOG, at_command); + } + + if (strlen(p->sms_message)) { + manager_event(EVENT_FLAG_SYSTEM, "CELLIAXincomingsms", + "Interface: %s\r\nSMS_Message: %s\r\n", p->name, + p->sms_message); + if (strlen(p->sms_receiving_program)) { + int fd1[2]; + pid_t pid1; + char *arg1[] = { p->sms_receiving_program, (char *) NULL }; + int i; + + NOTICA("incoming SMS message:>>>%s<<<\n", CELLIAX_P_LOG, p->sms_message); + pipe(fd1); + pid1 = fork(); + + if (pid1 == 0) { //child + int err; + + dup2(fd1[0], 0); // Connect stdin to pipe output + close(fd1[1]); // close input pipe side + close(p->controldevfd); + setsid(); //session id + err = execvp(arg1[0], arg1); //exec our program, with stdin connected to pipe output + if (err) { + ERRORA + ("'sms_receiving_program' is set in config file to '%s', and it gave us back this error: %d, (%s). SMS received was:---%s---\n", + CELLIAX_P_LOG, p->sms_receiving_program, err, strerror(errno), + p->sms_message); + } + close(fd1[0]); // close output pipe side + } +//starting here continue the parent + close(fd1[0]); // close output pipe side + // write the msg on the pipe input + for (i = 0; i < strlen(p->sms_message); i++) { + write(fd1[1], &p->sms_message[i], 1); + } + close(fd1[1]); // close pipe input, let our program know we've finished + } else { + ERRORA + ("got SMS incoming message, but 'sms_receiving_program' is not set in config file. SMS received was:---%s---\n", + CELLIAX_P_LOG, p->sms_message); + } + } +#if 1 //is this one needed? maybe it can interrupt an incoming call that is just to announce itself + if (p->phone_callflow == CALLFLOW_CALL_IDLE + && p->interface_state == AST_STATE_DOWN && p->owner == NULL) { + /* we're not in a call, neither calling */ + res = celliax_serial_write_AT_ack(p, "AT+CKPD=\"EEE\""); + if (res) { + ERRORA + ("AT+CKPD=\"EEE\" (cellphone screen back to user) do not got OK from the phone\n", + CELLIAX_P_LOG); + } + } +#endif + } //unread_msg_id + + } //CMTI well formatted + + } //CMTI + + if ((strncmp(p->line_array.result[i], "+MMGL:", 6) == 0)) { //TODO MOTOROLA SMS FIXME in config! + int err = 0; + //int unread_msg_id=0; + + if (option_debug) + DEBUGA_AT("|%s| +MMGL: Listing Motorola SMSs!\n", CELLIAX_P_LOG, + p->line_array.result[i]); + + err = sscanf(&p->line_array.result[i][7], "%d", &p->unread_sms_msg_id); + if (err < 1) { + ERRORA("|%s| is not formatted as: |+MMGL: xx|\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + } + if ((strncmp(p->line_array.result[i], "+CMGL:", 6) == 0)) { //TODO SMS FIXME in config! + if (option_debug) + DEBUGA_AT("|%s| +CMGL: Listing SMSs!\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + if ((strncmp(p->line_array.result[i], "+MMGR:", 6) == 0)) { //TODO MOTOROLA SMS FIXME in config! + if (option_debug) + DEBUGA_AT("|%s| +MMGR: Reading Motorola SMS!\n", CELLIAX_P_LOG, + p->line_array.result[i]); + if (p->reading_sms_msg) + p->reading_sms_msg++; + } + if ((strncmp(p->line_array.result[i], "+CMGR: \"STO U", 13) == 0)) { //TODO SMS FIXME in config! + if (option_debug) + DEBUGA_AT("|%s| +CMGR: Reading stored UNSENT SMS!\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } else if ((strncmp(p->line_array.result[i], "+CMGR: \"STO S", 13) == 0)) { //TODO SMS FIXME in config! + if (option_debug) + DEBUGA_AT("|%s| +CMGR: Reading stored SENT SMS!\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } else if ((strncmp(p->line_array.result[i], "+CMGR: \"REC R", 13) == 0)) { //TODO SMS FIXME in config! + if (option_debug) + DEBUGA_AT("|%s| +CMGR: Reading received READ SMS!\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } else if ((strncmp(p->line_array.result[i], "+CMGR: \"REC U", 13) == 0)) { //TODO SMS FIXME in config! + if (option_debug) + DEBUGA_AT("|%s| +CMGR: Reading received UNREAD SMS!\n", CELLIAX_P_LOG, + p->line_array.result[i]); + if (p->reading_sms_msg) + p->reading_sms_msg++; + } + + if ((strcmp(p->line_array.result[i], "+MCST: 17") == 0)) { /* motorola call processing unsolicited messages */ + p->phone_callflow = CALLFLOW_CALL_INFLUX; + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_INFLUX\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strcmp(p->line_array.result[i], "+MCST: 68") == 0)) { /* motorola call processing unsolicited messages */ + p->phone_callflow = CALLFLOW_CALL_NOSERVICE; + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_NOSERVICE\n", CELLIAX_P_LOG, + p->line_array.result[i]); + if (p->interface_state != AST_STATE_DOWN && p->owner) { + p->owner->hangupcause = AST_CAUSE_FAILURE; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + } + } + if ((strcmp(p->line_array.result[i], "+MCST: 70") == 0)) { /* motorola call processing unsolicited messages */ + p->phone_callflow = CALLFLOW_CALL_OUTGOINGRESTRICTED; + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_OUTGOINGRESTRICTED\n", CELLIAX_P_LOG, + p->line_array.result[i]); + if (p->interface_state != AST_STATE_DOWN && p->owner) { + p->owner->hangupcause = AST_CAUSE_FAILURE; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + } + } + if ((strcmp(p->line_array.result[i], "+MCST: 72") == 0)) { /* motorola call processing unsolicited messages */ + p->phone_callflow = CALLFLOW_CALL_SECURITYFAIL; + if (option_debug > 1) + DEBUGA_AT("|%s| CALLFLOW_CALL_SECURITYFAIL\n", CELLIAX_P_LOG, + p->line_array.result[i]); + if (p->interface_state != AST_STATE_DOWN && p->owner) { + p->owner->hangupcause = AST_CAUSE_FAILURE; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + } + } + + if ((strncmp(p->line_array.result[i], "+CPBR", 5) == 0)) { /* phonebook stuff begins */ + + if (p->phonebook_querying) { /* probably phonebook struct begins */ + int err, first_entry, last_entry, number_lenght, text_lenght; + + if (option_debug) + DEBUGA_AT("phonebook struct: |%s|\n", CELLIAX_P_LOG, p->line_array.result[i]); + + err = + sscanf(&p->line_array.result[i][8], "%d-%d),%d,%d", &first_entry, &last_entry, + &number_lenght, &text_lenght); + if (err < 4) { + + err = + sscanf(&p->line_array.result[i][7], "%d-%d,%d,%d", &first_entry, + &last_entry, &number_lenght, &text_lenght); + } + + if (err < 4) { + ERRORA + ("phonebook struct: |%s| is nor formatted as: |+CPBR: (1-750),40,14| neither as: |+CPBR: 1-750,40,14|\n", + CELLIAX_P_LOG, p->line_array.result[i]); + } else { + + if (option_debug) + DEBUGA_AT + ("First entry: %d, last entry: %d, phone number max lenght: %d, text max lenght: %d\n", + CELLIAX_P_LOG, first_entry, last_entry, number_lenght, text_lenght); + p->phonebook_first_entry = first_entry; + p->phonebook_last_entry = last_entry; + p->phonebook_number_lenght = number_lenght; + p->phonebook_text_lenght = text_lenght; + } + + } else { /* probably phonebook entry begins */ + + if (p->phonebook_listing) { + int err, entry_id, entry_type; + + char entry_number[256]; + char entry_text[256]; + + if (option_debug) + DEBUGA_AT("phonebook entry: |%s|\n", CELLIAX_P_LOG, + p->line_array.result[i]); + + err = + sscanf(&p->line_array.result[i][7], "%d,\"%255[0-9+]\",%d,\"%255[^\"]\"", + &entry_id, entry_number, &entry_type, entry_text); + if (err < 4) { + ERRORA + ("err=%d, phonebook entry: |%s| is not formatted as: |+CPBR: 504,\"+39025458068\",145,\"ciao a tutti\"|\n", + CELLIAX_P_LOG, err, p->line_array.result[i]); + } else { + //TODO: sanitize entry_text + if (option_debug) + DEBUGA_AT("Number: %s, Text: %s, Type: %d\n", CELLIAX_P_LOG, entry_number, + entry_text, entry_type); + /* write entry in phonebook file */ + if (p->phonebook_writing_fp) { + celliax_dir_entry_extension++; + + fprintf(p->phonebook_writing_fp, + "%s => ,%sSKO,,,hidefromdir=%s|phonebook_direct_calling_ext=%d%s%.4d|phonebook_entry_fromcell=%s|phonebook_entry_owner=%s\n", + entry_number, entry_text, "no", + p->celliax_dir_entry_extension_prefix, "2", + celliax_dir_entry_extension, "yes", "not_specified"); + fprintf(p->phonebook_writing_fp, + "%s => ,%sDO,,,hidefromdir=%s|phonebook_direct_calling_ext=%d%s%.4d|phonebook_entry_fromcell=%s|phonebook_entry_owner=%s\n", + entry_number, entry_text, "no", + p->celliax_dir_entry_extension_prefix, "3", + celliax_dir_entry_extension, "yes", "not_specified"); + } + } + + } + + if (p->phonebook_listing_received_calls) { + int err, entry_id, entry_type; + + char entry_number[256] = ""; + char entry_text[256] = ""; + + if (option_debug) + DEBUGA_AT("phonebook entry: |%s|\n", CELLIAX_P_LOG, + p->line_array.result[i]); + + err = + sscanf(&p->line_array.result[i][7], "%d,\"%255[0-9+]\",%d,\"%255[^\"]\"", + &entry_id, entry_number, &entry_type, entry_text); + if (err < 1) { //we match only on the progressive id, maybe the remote party has not sent its number, and/or there is no corresponding text entry in the phone directory + ERRORA + ("err=%d, phonebook entry: |%s| is not formatted as: |+CPBR: 504,\"+39025458068\",145,\"ciao a tutti\"|\n", + CELLIAX_P_LOG, err, p->line_array.result[i]); + } else { + //TODO: sanitize entry_text + + if (option_debug) + DEBUGA_AT("Number: %s, Text: %s, Type: %d\n", CELLIAX_P_LOG, entry_number, + entry_text, entry_type); + memset(p->callid_name, 0, sizeof(p->callid_name)); + memset(p->callid_number, 0, sizeof(p->callid_number)); + strncpy(p->callid_name, entry_text, sizeof(p->callid_name)); + strncpy(p->callid_number, entry_number, sizeof(p->callid_number)); + if (option_debug) + DEBUGA_AT("incoming callid: Text: %s, Number: %s\n", CELLIAX_P_LOG, + p->callid_name, p->callid_number); + + DEBUGA_AT("|%s| CPBR INCOMING CALLID: name is %s, number is %s\n", + CELLIAX_P_LOG, p->line_array.result[i], + p->callid_name[0] != 1 ? p->callid_name : "not available", + p->callid_number[0] ? p->callid_number : "not available"); + + /* mark the time of RING */ + gettimeofday(&(p->ringtime), NULL); + p->interface_state = AST_STATE_RING; + p->phone_callflow = CALLFLOW_INCOMING_RING; + + } + + } + + else { + DEBUGA_AT("phonebook entry: |%s|\n", CELLIAX_P_LOG, p->line_array.result[i]); + + } + } + + } + + if ((strncmp(p->line_array.result[i], "*ECAV", 5) == 0) || (strncmp(p->line_array.result[i], "*ECAM", 5) == 0)) { /* sony-ericsson call processing unsolicited messages */ + int res, ccid, ccstatus, calltype, processid, exitcause, number, type; + res = ccid = ccstatus = calltype = processid = exitcause = number = type = 0; + res = + sscanf(&p->line_array.result[i][6], "%d,%d,%d,%d,%d,%d,%d", &ccid, &ccstatus, + &calltype, &processid, &exitcause, &number, &type); + /* only changes the phone_callflow if enought parameters were parsed */ + if (res >= 3) { + switch (ccstatus) { + case 0: + if (p->owner) { + ast_setstate(p->owner, AST_STATE_DOWN); + p->owner->hangupcause = AST_CAUSE_NORMAL; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + } + p->phone_callflow = CALLFLOW_CALL_IDLE; + p->interface_state = AST_STATE_DOWN; + if (option_debug > 1) + DEBUGA_AT("|%s| Sony-Ericsson *ECAM/*ECAV: IDLE\n", CELLIAX_P_LOG, + p->line_array.result[i]); + break; + case 1: + if (option_debug > 1) + DEBUGA_AT("|%s| Sony-Ericsson *ECAM/*ECAV: CALLING\n", CELLIAX_P_LOG, + p->line_array.result[i]); + break; + case 2: + if (p->owner) { + ast_setstate(p->owner, AST_STATE_DIALING); + } + p->interface_state = CALLFLOW_CALL_DIALING; + if (option_debug > 1) + DEBUGA_AT("|%s| Sony-Ericsson *ECAM/*ECAV: CONNECTING\n", CELLIAX_P_LOG, + p->line_array.result[i]); + break; + case 3: + if (p->owner) { + ast_setstate(p->owner, AST_STATE_UP); + celliax_queue_control(p->owner, AST_CONTROL_ANSWER); + } + p->phone_callflow = CALLFLOW_CALL_ACTIVE; + p->interface_state = AST_STATE_UP; + if (option_debug > 1) + DEBUGA_AT("|%s| Sony-Ericsson *ECAM/*ECAV: ACTIVE\n", CELLIAX_P_LOG, + p->line_array.result[i]); + break; + case 4: + if (option_debug > 1) + DEBUGA_AT + ("|%s| Sony-Ericsson *ECAM/*ECAV: don't know how to handle HOLD event\n", + CELLIAX_P_LOG, p->line_array.result[i]); + break; + case 5: + if (option_debug > 1) + DEBUGA_AT + ("|%s| Sony-Ericsson *ECAM/*ECAV: don't know how to handle WAITING event\n", + CELLIAX_P_LOG, p->line_array.result[i]); + break; + case 6: + if (option_debug > 1) + DEBUGA_AT + ("|%s| Sony-Ericsson *ECAM/*ECAV: don't know how to handle ALERTING event\n", + CELLIAX_P_LOG, p->line_array.result[i]); + break; + case 7: + if (p->owner) { + ast_setstate(p->owner, AST_STATE_BUSY); + celliax_queue_control(p->owner, AST_CONTROL_BUSY); + } + p->phone_callflow = CALLFLOW_CALL_LINEBUSY; + p->interface_state = AST_STATE_BUSY; + if (option_debug > 1) + DEBUGA_AT("|%s| Sony-Ericsson *ECAM/*ECAV: BUSY\n", CELLIAX_P_LOG, + p->line_array.result[i]); + break; + } + } else { + if (option_debug > 1) + DEBUGA_AT("|%s| Sony-Ericsson *ECAM/*ECAV: could not parse parameters\n", + CELLIAX_P_LOG, p->line_array.result[i]); + } + + } + + /* at_indicator_* are unsolicited messages sent by the phone to signal us that some of its visual indicators on its screen has changed, based on CIND CMER ETSI docs */ + if ((strcmp(p->line_array.result[i], p->at_indicator_noservice_string) == 0)) { + if (option_debug > 1) + ERRORA("|%s| at_indicator_noservice_string\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strcmp(p->line_array.result[i], p->at_indicator_nosignal_string) == 0)) { + if (option_debug > 1) + ERRORA("|%s| at_indicator_nosignal_string\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strcmp(p->line_array.result[i], p->at_indicator_lowsignal_string) == 0)) { + if (option_debug > 1) + WARNINGA("|%s| at_indicator_lowsignal_string\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strcmp(p->line_array.result[i], p->at_indicator_lowbattchg_string) == 0)) { + if (option_debug > 1) + WARNINGA("|%s| at_indicator_lowbattchg_string\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strcmp(p->line_array.result[i], p->at_indicator_nobattchg_string) == 0)) { + if (option_debug > 1) + ERRORA("|%s| at_indicator_nobattchg_string\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strcmp(p->line_array.result[i], p->at_indicator_callactive_string) == 0)) { + if (option_debug > 1) + DEBUGA_AT("|%s| at_indicator_callactive_string\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strcmp(p->line_array.result[i], p->at_indicator_nocallactive_string) == 0)) { + if (option_debug > 1) + DEBUGA_AT("|%s| at_indicator_nocallactive_string\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strcmp(p->line_array.result[i], p->at_indicator_nocallsetup_string) == 0)) { + if (option_debug > 1) + DEBUGA_AT("|%s| at_indicator_nocallsetup_string\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strcmp(p->line_array.result[i], p->at_indicator_callsetupincoming_string) == + 0)) { + if (option_debug > 1) + DEBUGA_AT("|%s| at_indicator_callsetupincoming_string\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strcmp(p->line_array.result[i], p->at_indicator_callsetupoutgoing_string) == + 0)) { + if (option_debug > 1) + DEBUGA_AT("|%s| at_indicator_callsetupoutgoing_string\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + if ((strcmp(p->line_array.result[i], p->at_indicator_callsetupremoteringing_string) + == 0)) { + if (option_debug > 1) + DEBUGA_AT("|%s| at_indicator_callsetupremoteringing_string\n", CELLIAX_P_LOG, + p->line_array.result[i]); + } + + } + + /* let's look for OK, ERROR and EXPECTED_STRING in the complete lines read so far, without re-looking at the lines that has been yet looked at */ + for (i = la_read; i < la_counter; i++) { + if (expected_string) { + if ((strncmp(p->line_array.result[i], expected_string, strlen(expected_string)) + == 0)) { + if (option_debug > 1) + DEBUGA_AT("|%s| got what EXPECTED\n", CELLIAX_P_LOG, p->line_array.result[i]); + at_ack = AT_OK; + } + } else { + //if ((strcmp(p->line_array.result[i], "OK") == 0)) { + if ((strcmp(p->line_array.result[i], "OK") == 0) || (strcmp(p->line_array.result[i], "NO CARRIER") == 0) ) { + if (option_debug > 1) + DEBUGA_AT("got OK\n", CELLIAX_P_LOG); + at_ack = AT_OK; + } + } + if ((strcmp(p->line_array.result[i], "ERROR") == 0)) { + if (option_debug > 1) + DEBUGA_AT("got ERROR\n", CELLIAX_P_LOG); + at_ack = AT_ERROR; + } + + /* if we are reading an sms message from memory, put the line into the sms buffer if the line is not "OK" or "ERROR" */ + if (p->reading_sms_msg > 1 && at_ack == -1) { + int c; + char sms_body[16000]; + int err; + + if (strncmp(p->line_array.result[i], "+CMGR", 5) == 0) { /* we are reading the "header" of an SMS */ + char content[512]; + char content2[512]; + + memset(content, '\0', sizeof(content)); + + int inside_comma = 0; + int inside_quote = 0; + int d = 0; + + for (c = 0; c < strlen(p->line_array.result[i]); c++) { + if (p->line_array.result[i][c] == ',' + && p->line_array.result[i][c - 1] != '\\' && inside_quote == 0) { + if (inside_comma) { + inside_comma = 0; + //NOTICA("inside_comma=%d, inside_quote=%d, we're at=%s\n", CELLIAX_P_LOG, inside_comma, inside_quote, &p->line_array.result[i][c]); + } else { + inside_comma = 1; + //NOTICA("inside_comma=%d, inside_quote=%d, we're at=%s\n", CELLIAX_P_LOG, inside_comma, inside_quote, &p->line_array.result[i][c]); + } + } + if (p->line_array.result[i][c] == '"' + && p->line_array.result[i][c - 1] != '\\') { + if (inside_quote) { + inside_quote = 0; + //ERRORA("END_CONTENT inside_comma=%d, inside_quote=%d, we're at=%s\n", CELLIAX_P_LOG, inside_comma, inside_quote, &p->line_array.result[i][c]); + DEBUGA_AT("content=%s\n", CELLIAX_P_LOG, content); + + strncat(p->sms_message, "---", + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + strncat(p->sms_message, content, + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + strncat(p->sms_message, "|||", + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + + memset(content2, '\0', sizeof(content2)); + err = ucs2_to_utf8(p, content, content2, sizeof(content2)); + + strncat(p->sms_message, "---", + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + if (!err) + strncat(p->sms_message, content2, + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + strncat(p->sms_message, "|||", + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + memset(content, '\0', sizeof(content)); + d = 0; + } else { + inside_quote = 1; + //WARNINGA("START_CONTENT inside_comma=%d, inside_quote=%d, we're at=%s\n", CELLIAX_P_LOG, inside_comma, inside_quote, &p->line_array.result[i][c]); + } + } + if (inside_quote && p->line_array.result[i][c] != '"') { + + content[d] = p->line_array.result[i][c]; + d++; + + } + + } + } //it was the +CMGR answer from the cellphone + else { + strncat(p->sms_message, "---", + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + strncat(p->sms_message, p->line_array.result[i], + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + strncat(p->sms_message, "|||", + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + + memset(sms_body, '\0', sizeof(sms_body)); + err = ucs2_to_utf8(p, p->line_array.result[i], sms_body, sizeof(sms_body)); + + strncat(p->sms_message, "---", + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + if (!err) + strncat(p->sms_message, sms_body, + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + strncat(p->sms_message, "|||", + ((sizeof(p->sms_message) - strlen(p->sms_message)) - 1)); + + DEBUGA_AT("sms_message=%s\n", CELLIAX_P_LOG, p->sms_message); + + } //it was the UCS2 from cellphone + + } //we were reading the SMS + + } + + la_read = la_counter; + + if (look_for_ack && at_ack > -1) + break; + + if (la_counter > AT_MESG_MAX_LINES) { + ERRORA("Too many lines in result (>%d). Stopping reader.\n", CELLIAX_P_LOG, + AT_MESG_MAX_LINES); + at_ack = AT_ERROR; + break; + } + } + + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + if (select_err == -1) { + ERRORA("select returned -1 on %s, setting controldev_dead, error was: %s\n", + CELLIAX_P_LOG, p->controldevice_name, strerror(errno)); + p->controldev_dead = 1; + close(p->controldevfd); + if (p->owner) + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + return -1; + } + + if (p->phone_callflow == CALLFLOW_CALL_INCOMING && p->call_incoming_time.tv_sec) { //after three sec of CALLFLOW_CALL_INCOMING, we assume the phone is incapable of notifying RING (eg: motorola c350), so we try to answer + char list_command[64]; + struct timeval call_incoming_timeout; + gettimeofday(&call_incoming_timeout, NULL); + call_incoming_timeout.tv_sec -= 3; + DEBUGA_AT + ("CALLFLOW_CALL_INCOMING call_incoming_time.tv_sec=%ld, call_incoming_timeout.tv_sec=%ld\n", + CELLIAX_P_LOG, p->call_incoming_time.tv_sec, call_incoming_timeout.tv_sec); + if (call_incoming_timeout.tv_sec > p->call_incoming_time.tv_sec) { + + p->call_incoming_time.tv_sec = 0; + p->call_incoming_time.tv_usec = 0; + DEBUGA_AT + ("CALLFLOW_CALL_INCOMING call_incoming_time.tv_sec=%ld, call_incoming_timeout.tv_sec=%ld\n", + CELLIAX_P_LOG, p->call_incoming_time.tv_sec, call_incoming_timeout.tv_sec); + res = celliax_serial_write_AT_ack(p, "AT+CPBS=RC"); + if (res) { + ERRORA + ("AT+CPBS=RC (select memory of received calls) was not answered by the phone\n", + CELLIAX_P_LOG); + } + p->phonebook_querying = 1; + res = celliax_serial_write_AT_ack(p, "AT+CPBR=?"); + if (res) { + ERRORA + ("AT+CPBS=RC (select memory of received calls) was not answered by the phone\n", + CELLIAX_P_LOG); + } + p->phonebook_querying = 0; + sprintf(list_command, "AT+CPBR=%d,%d", p->phonebook_first_entry, + p->phonebook_last_entry); + p->phonebook_listing_received_calls = 1; + res = celliax_serial_write_AT_expect_longtime(p, list_command, "OK"); + if (res) { + WARNINGA("AT+CPBR=%d,%d failed, continue\n", CELLIAX_P_LOG, + p->phonebook_first_entry, p->phonebook_last_entry); + } + p->phonebook_listing_received_calls = 0; + } + } + + if (p->phone_callflow == CALLFLOW_INCOMING_RING) { + struct timeval call_incoming_timeout; + gettimeofday(&call_incoming_timeout, NULL); + call_incoming_timeout.tv_sec -= 10; + DEBUGA_AT + ("CALLFLOW_CALL_INCOMING call_incoming_time.tv_sec=%ld, call_incoming_timeout.tv_sec=%ld\n", + CELLIAX_P_LOG, p->call_incoming_time.tv_sec, call_incoming_timeout.tv_sec); + if (call_incoming_timeout.tv_sec > p->ringtime.tv_sec) { + ERRORA("Ringing stopped and I have not answered. Why?\n", CELLIAX_P_LOG); + DEBUGA_AT + ("CALLFLOW_CALL_INCOMING call_incoming_time.tv_sec=%ld, call_incoming_timeout.tv_sec=%ld\n", + CELLIAX_P_LOG, p->call_incoming_time.tv_sec, call_incoming_timeout.tv_sec); + if (p->owner) { + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + p->owner->hangupcause = AST_CAUSE_FAILURE; + } + } + } + p->line_array.elemcount = la_counter; + //NOTICA (" OUTSIDE this celliax_serial_device %s \n", CELLIAX_P_LOG, p->controldevice_name); + if (look_for_ack) + return at_ack; + else + return 0; +} + +int celliax_serial_write_AT(struct celliax_pvt *p, const char *data) +{ + int howmany; + int i; + int res; + int count; + + howmany = strlen(data); + + for (i = 0; i < howmany; i++) { + res = write(p->controldevfd, &data[i], 1); + + if (res != 1) { + DEBUGA_AT("Error sending (%.1s): %d (%s)\n", CELLIAX_P_LOG, &data[i], res, + strerror(errno)); + usleep(100000); + for (count = 0; count < 10; count++) { + res = write(p->controldevfd, &data[i], 1); + if (res == 1) { + DEBUGA_AT("Successfully RE-sent (%.1s): %d %d (%s)\n", CELLIAX_P_LOG, &data[i], + count, res, strerror(errno)); + break; + } else + DEBUGA_AT("Error RE-sending (%.1s): %d %d (%s)\n", CELLIAX_P_LOG, &data[i], + count, res, strerror(errno)); + usleep(100000); + + } + if (res != 1) { + ERRORA("Error RE-sending (%.1s): %d %d (%s)\n", CELLIAX_P_LOG, &data[i], count, + res, strerror(errno)); + return -1; + } + } + if (option_debug > 1) + DEBUGA_AT("sent data... (%.1s)\n", CELLIAX_P_LOG, &data[i]); + usleep(1000); /* release the cpu */ + } + + res = write(p->controldevfd, "\r", 1); + + if (res != 1) { + DEBUGA_AT("Error sending (carriage return): %d (%s)\n", CELLIAX_P_LOG, res, + strerror(errno)); + usleep(100000); + for (count = 0; count < 10; count++) { + res = write(p->controldevfd, "\r", 1); + + if (res == 1) { + DEBUGA_AT("Successfully RE-sent carriage return: %d %d (%s)\n", CELLIAX_P_LOG, + count, res, strerror(errno)); + break; + } else + DEBUGA_AT("Error RE-sending (carriage return): %d %d (%s)\n", CELLIAX_P_LOG, + count, res, strerror(errno)); + usleep(100000); + + } + if (res != 1) { + ERRORA("Error RE-sending (carriage return): %d %d (%s)\n", CELLIAX_P_LOG, count, + res, strerror(errno)); + return -1; + } + } + if (option_debug > 1) + DEBUGA_AT("sent (carriage return)\n", CELLIAX_P_LOG); + usleep(1000); /* release the cpu */ + + return howmany; +} + +int celliax_serial_write_AT_nocr(struct celliax_pvt *p, const char *data) +{ + int howmany; + int i; + int res; + int count; + + howmany = strlen(data); + + for (i = 0; i < howmany; i++) { + res = write(p->controldevfd, &data[i], 1); + + if (res != 1) { + DEBUGA_AT("Error sending (%.1s): %d (%s)\n", CELLIAX_P_LOG, &data[i], res, + strerror(errno)); + usleep(100000); + for (count = 0; count < 10; count++) { + res = write(p->controldevfd, &data[i], 1); + if (res == 1) + break; + else + DEBUGA_AT("Error RE-sending (%.1s): %d %d (%s)\n", CELLIAX_P_LOG, &data[i], + count, res, strerror(errno)); + usleep(100000); + + } + if (res != 1) { + ERRORA("Error RE-sending (%.1s): %d %d (%s)\n", CELLIAX_P_LOG, &data[i], count, + res, strerror(errno)); + return -1; + } + } + if (option_debug > 1) + DEBUGA_AT("sent data... (%.1s)\n", CELLIAX_P_LOG, &data[i]); + usleep(1000); /* release the cpu */ + } + + usleep(1000); /* release the cpu */ + + return howmany; +} + +int celliax_serial_write_AT_noack(struct celliax_pvt *p, const char *data) +{ + + if (option_debug > 1) + DEBUGA_AT("celliax_serial_write_AT_noack: %s\n", CELLIAX_P_LOG, data); + + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + if (celliax_serial_write_AT(p, data) != strlen(data)) { + + ERRORA("Error sending data... (%s)\n", CELLIAX_P_LOG, strerror(errno)); + UNLOCKA(&p->controldev_lock); + return -1; + } + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + + return 0; +} + +int celliax_serial_write_AT_ack(struct celliax_pvt *p, const char *data) +{ + int at_result = AT_ERROR; + + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + if (option_debug > 1) + DEBUGA_AT("sending: %s\n", CELLIAX_P_LOG, data); + if (celliax_serial_write_AT(p, data) != strlen(data)) { + ERRORA("Error sending data... (%s) \n", CELLIAX_P_LOG, strerror(errno)); + UNLOCKA(&p->controldev_lock); + return -1; + } + + at_result = celliax_serial_read_AT(p, 1, 500000, 2, NULL, 1); // 2.5 sec timeout + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + + return at_result; + +} + +int celliax_serial_write_AT_ack_nocr_longtime(struct celliax_pvt *p, const char *data) +{ + int at_result = AT_ERROR; + + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + if (option_debug > 1) + DEBUGA_AT("sending: %s\n", CELLIAX_P_LOG, data); + if (celliax_serial_write_AT_nocr(p, data) != strlen(data)) { + ERRORA("Error sending data... (%s) \n", CELLIAX_P_LOG, strerror(errno)); + UNLOCKA(&p->controldev_lock); + return -1; + } + + at_result = celliax_serial_read_AT(p, 1, 500000, 20, NULL, 1); // 20.5 sec timeout + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + + return at_result; + +} + +int celliax_serial_write_AT_expect1(struct celliax_pvt *p, const char *data, + const char *expected_string, int expect_crlf, + int seconds) +{ + int at_result = AT_ERROR; + + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + if (option_debug > 1) + DEBUGA_AT("sending: %s, expecting: %s\n", CELLIAX_P_LOG, data, expected_string); + if (celliax_serial_write_AT(p, data) != strlen(data)) { + ERRORA("Error sending data... (%s) \n", CELLIAX_P_LOG, strerror(errno)); + UNLOCKA(&p->controldev_lock); + return -1; + } + + at_result = celliax_serial_read_AT(p, 1, 500000, seconds, expected_string, expect_crlf); // 20.5 sec timeout, used for querying the SIM and sending SMSs + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + + return at_result; + +} + +int celliax_serial_AT_expect(struct celliax_pvt *p, const char *expected_string, + int expect_crlf, int seconds) +{ + int at_result = AT_ERROR; + + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + if (option_debug > 1) + DEBUGA_AT("expecting: %s\n", CELLIAX_P_LOG, expected_string); + + at_result = celliax_serial_read_AT(p, 1, 500000, seconds, expected_string, expect_crlf); // 20.5 sec timeout, used for querying the SIM and sending SMSs + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + + return at_result; + +} + +int celliax_serial_answer_AT(struct celliax_pvt *p) +{ + int res; + + res = celliax_serial_write_AT_expect(p, p->at_answer, p->at_answer_expect); + if (res) { + DEBUGA_AT + ("at_answer command failed, command used: %s, expecting: %s, trying with AT+CKPD=\"S\"\n", + CELLIAX_P_LOG, p->at_answer, p->at_answer_expect); + + res = celliax_serial_write_AT_ack(p, "AT+CKPD=\"S\""); + if (res) { + ERRORA("at_answer command failed, command used: 'AT+CKPD=\"S\"', giving up\n", + CELLIAX_P_LOG); + return -1; + } + } + //p->interface_state = AST_STATE_UP; + //p->phone_callflow = CALLFLOW_CALL_ACTIVE; + DEBUGA_AT("AT: call answered\n", CELLIAX_P_LOG); + return 0; +} + +int celliax_serial_hangup_AT(struct celliax_pvt *p) +{ + int res; + + if (p->interface_state != AST_STATE_DOWN) { + res = celliax_serial_write_AT_expect(p, p->at_hangup, p->at_hangup_expect); + if (res) { + DEBUGA_AT + ("at_hangup command failed, command used: %s, trying to use AT+CKPD=\"EEE\"\n", + CELLIAX_P_LOG, p->at_hangup); + res = celliax_serial_write_AT_ack(p, "AT+CKPD=\"EEE\""); + if (res) { + ERRORA("at_hangup command failed, command used: 'AT+CKPD=\"EEE\"'\n", + CELLIAX_P_LOG); + return -1; + } + } + } + p->interface_state = AST_STATE_DOWN; + p->phone_callflow = CALLFLOW_CALL_IDLE; + return 0; +} + +int celliax_serial_config_AT(struct celliax_pvt *p) +{ + int res; + +/* initial_pause? */ + if (p->at_initial_pause) { + DEBUGA_AT("sleeping for %d usec\n", CELLIAX_P_LOG, p->at_initial_pause); + usleep(p->at_initial_pause); + } + +/* go until first empty preinit string, or last preinit string */ + while (1) { + + if (strlen(p->at_preinit_1)) { + res = celliax_serial_write_AT_expect(p, p->at_preinit_1, p->at_preinit_1_expect); + if (res) { + DEBUGA_AT("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_preinit_1, p->at_preinit_1_expect); + } + } else { + break; + } + + if (strlen(p->at_preinit_2)) { + res = celliax_serial_write_AT_expect(p, p->at_preinit_2, p->at_preinit_2_expect); + if (res) { + DEBUGA_AT("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_preinit_2, p->at_preinit_2_expect); + } + } else { + break; + } + + if (strlen(p->at_preinit_3)) { + res = celliax_serial_write_AT_expect(p, p->at_preinit_3, p->at_preinit_3_expect); + if (res) { + DEBUGA_AT("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_preinit_3, p->at_preinit_3_expect); + } + } else { + break; + } + + if (strlen(p->at_preinit_4)) { + res = celliax_serial_write_AT_expect(p, p->at_preinit_4, p->at_preinit_4_expect); + if (res) { + DEBUGA_AT("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_preinit_4, p->at_preinit_4_expect); + } + } else { + break; + } + + if (strlen(p->at_preinit_5)) { + res = celliax_serial_write_AT_expect(p, p->at_preinit_5, p->at_preinit_5_expect); + if (res) { + DEBUGA_AT("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_preinit_5, p->at_preinit_5_expect); + } + } else { + break; + } + + break; + } + +/* after_preinit_pause? */ + if (p->at_after_preinit_pause) { + DEBUGA_AT("sleeping for %d usec\n", CELLIAX_P_LOG, p->at_after_preinit_pause); + usleep(p->at_after_preinit_pause); + } + + /* phone, brother, art you alive? */ + res = celliax_serial_write_AT_ack(p, "AT"); + if (res) { + ERRORA("no response to AT\n", CELLIAX_P_LOG); + return -1; + } + /* for motorola, bring it back to "normal" mode if it happens to be in another mode */ + res = celliax_serial_write_AT_ack(p, "AT+mode=0"); + if (res) { + DEBUGA_AT("AT+mode=0 does not get OK from the phone. If it is NOT Motorola," + " no problem.\n", CELLIAX_P_LOG); + } + usleep(50000); + /* for motorola end */ + + /* reset AT configuration to phone default */ + res = celliax_serial_write_AT_ack(p, "ATZ"); + if (res) { + DEBUGA_AT("ATZ failed\n", CELLIAX_P_LOG); + } + + /* disable AT command echo */ + res = celliax_serial_write_AT_ack(p, "ATE0"); + if (res) { + DEBUGA_AT("ATE0 failed\n", CELLIAX_P_LOG); + } + + /* disable extended error reporting */ + res = celliax_serial_write_AT_ack(p, "AT+CMEE=0"); + if (res) { + DEBUGA_AT("AT+CMEE failed\n", CELLIAX_P_LOG); + } + + /* various phone manufacturer identifier */ + char at_command[5]; + int i; + for (i = 0; i < 10; i++) { + memset(at_command, 0, sizeof(at_command)); + sprintf(at_command, "ATI%d", i); + res = celliax_serial_write_AT_ack(p, at_command); + if (res) { + DEBUGA_AT("ATI%d command failed, continue\n", CELLIAX_P_LOG, i); + } + } + + /* phone manufacturer */ + res = celliax_serial_write_AT_ack(p, "AT+CGMI"); + if (res) { + DEBUGA_AT("AT+CGMI failed\n", CELLIAX_P_LOG); + } + + /* phone model */ + res = celliax_serial_write_AT_ack(p, "AT+CGMM"); + if (res) { + DEBUGA_AT("AT+CGMM failed\n", CELLIAX_P_LOG); + } + + res = celliax_serial_write_AT_ack(p, "AT+CGSN"); + if (res) { + DEBUGA_AT("AT+CGSN failed\n", CELLIAX_P_LOG); + } + +/* this take a lot of time to complete on devices with slow serial link (eg.: 9600bps) */ +#if 0 + /* ask for the list of supported AT commands, useful to implement new models and debugging */ + res = celliax_serial_write_AT_ack(p, "AT+CLAC"); + if (res) { + DEBUGA_AT("AT+CLAC failed, continue\n", CELLIAX_P_LOG); + } +#endif + /* signal incoming SMS with a +CMTI unsolicited msg */ + res = celliax_serial_write_AT_ack(p, "AT+CNMI=3,1,0,0,0"); + if (res) { + DEBUGA_AT("AT+CNMI=3,1,0,0,0 failed, continue\n", CELLIAX_P_LOG); + p->sms_cnmi_not_supported = 1; + p->celliax_serial_sync_period = 30; + } + /* what is the Message Center address (number) to which the SMS has to be sent? */ + res = celliax_serial_write_AT_ack(p, "AT+CSCA?"); + if (res) { + DEBUGA_AT("AT+CSCA? failed, continue\n", CELLIAX_P_LOG); + } + /* what is the Message Format of SMSs? */ + res = celliax_serial_write_AT_ack(p, "AT+CMGF?"); + if (res) { + DEBUGA_AT("AT+CMGF? failed, continue\n", CELLIAX_P_LOG); + } + res = celliax_serial_write_AT_ack(p, "AT+CMGF=1"); //TODO: support phones that only accept pdu mode + if (res) { + ERRORA("Error setting SMS sending mode to TEXT on the cellphone\n", CELLIAX_P_LOG); + return RESULT_FAILURE; + } + /* what is the Charset of SMSs? */ + res = celliax_serial_write_AT_ack(p, "AT+CSCS?"); + if (res) { + DEBUGA_AT("AT+CSCS? failed, continue\n", CELLIAX_P_LOG); + } + + p->no_ucs2 = 0; + res = celliax_serial_write_AT_ack(p, "AT+CSCS=\"UCS2\""); + if (res) { + WARNINGA + ("AT+CSCS=\"UCS2\" (set TE messages to ucs2) do not got OK from the phone, let's try with 'GSM'\n", + CELLIAX_P_LOG); + p->no_ucs2 = 1; + } + + if (p->no_ucs2) { + res = celliax_serial_write_AT_ack(p, "AT+CSCS=\"GSM\""); + if (res) { + WARNINGA("AT+CSCS=\"GSM\" (set TE messages to GSM) do not got OK from the phone\n", + CELLIAX_P_LOG); + } + //res = celliax_serial_write_AT_ack(p, "AT+CSMP=17,167,0,16"); //"flash", class 0 sms 7 bit + res = celliax_serial_write_AT_ack(p, "AT+CSMP=17,167,0,0"); //normal, 7 bit message + if (res) { + WARNINGA("AT+CSMP do not got OK from the phone, continuing\n", CELLIAX_P_LOG); + } + } else { + //res = celliax_serial_write_AT_ack(p, "AT+CSMP=17,167,0,20"); //"flash", class 0 sms 16 bit unicode + res = celliax_serial_write_AT_ack(p, "AT+CSMP=17,167,0,8"); //unicode, 16 bit message + if (res) { + WARNINGA("AT+CSMP do not got OK from the phone, continuing\n", CELLIAX_P_LOG); + } + } + + /* is the unsolicited reporting of mobile equipment event supported? */ + res = celliax_serial_write_AT_ack(p, "AT+CMER=?"); + if (res) { + DEBUGA_AT("AT+CMER=? failed, continue\n", CELLIAX_P_LOG); + } + /* request unsolicited reporting of mobile equipment indicators' events, to be screened by categories reported by +CIND=? */ + res = celliax_serial_write_AT_ack(p, "AT+CMER=3,0,0,1"); + if (res) { + DEBUGA_AT("AT+CMER=? failed, continue\n", CELLIAX_P_LOG); + } + + /* is the solicited reporting of mobile equipment indications supported? */ + + res = celliax_serial_write_AT_ack(p, "AT+CIND=?"); + if (res) { + DEBUGA_AT("AT+CIND=? failed, continue\n", CELLIAX_P_LOG); + } + + /* is the unsolicited reporting of call monitoring supported? sony-ericsson specific */ + res = celliax_serial_write_AT_ack(p, "AT*ECAM=?"); + if (res) { + DEBUGA_AT("AT*ECAM=? failed, continue\n", CELLIAX_P_LOG); + } + /* enable the unsolicited reporting of call monitoring. sony-ericsson specific */ + res = celliax_serial_write_AT_ack(p, "AT*ECAM=1"); + if (res) { + DEBUGA_AT("AT*ECAM=1 failed, continue\n", CELLIAX_P_LOG); + p->at_has_ecam = 0; + } else { + p->at_has_ecam = 1; + } + + /* disable unsolicited signaling of call list */ + res = celliax_serial_write_AT_ack(p, "AT+CLCC=0"); + if (res) { + DEBUGA_AT("AT+CLCC=0 failed, continue\n", CELLIAX_P_LOG); + p->at_has_clcc = 0; + } else { + p->at_has_clcc = 1; + } + + /* give unsolicited caller id when incoming call */ + res = celliax_serial_write_AT_ack(p, "AT+CLIP=1"); + if (res) { + DEBUGA_AT("AT+CLIP failed, continue\n", CELLIAX_P_LOG); + } + /* for motorola */ + res = celliax_serial_write_AT_ack(p, "AT+MCST=1"); /* motorola call control codes + (to know when call is disconnected (they + don't give you "no carrier") */ + if (res) { + DEBUGA_AT("AT+MCST=1 does not get OK from the phone. If it is NOT Motorola," + " no problem.\n", CELLIAX_P_LOG); + } + /* for motorola end */ + +/* go until first empty postinit string, or last postinit string */ + while (1) { + + if (strlen(p->at_postinit_1)) { + res = celliax_serial_write_AT_expect(p, p->at_postinit_1, p->at_postinit_1_expect); + if (res) { + DEBUGA_AT("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_postinit_1, p->at_postinit_1_expect); + } + } else { + break; + } + + if (strlen(p->at_postinit_2)) { + res = celliax_serial_write_AT_expect(p, p->at_postinit_2, p->at_postinit_2_expect); + if (res) { + DEBUGA_AT("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_postinit_2, p->at_postinit_2_expect); + } + } else { + break; + } + + if (strlen(p->at_postinit_3)) { + res = celliax_serial_write_AT_expect(p, p->at_postinit_3, p->at_postinit_3_expect); + if (res) { + DEBUGA_AT("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_postinit_3, p->at_postinit_3_expect); + } + } else { + break; + } + + if (strlen(p->at_postinit_4)) { + res = celliax_serial_write_AT_expect(p, p->at_postinit_4, p->at_postinit_4_expect); + if (res) { + DEBUGA_AT("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_postinit_4, p->at_postinit_4_expect); + } + } else { + break; + } + + if (strlen(p->at_postinit_5)) { + res = celliax_serial_write_AT_expect(p, p->at_postinit_5, p->at_postinit_5_expect); + if (res) { + DEBUGA_AT("%s does not get %s from the phone. Continuing.\n", CELLIAX_P_LOG, + p->at_postinit_5, p->at_postinit_5_expect); + } + } else { + break; + } + + break; + } + + return 0; +} + +int celliax_serial_call_AT(struct celliax_pvt *p, char *dstr) +{ + int res; + char at_command[256]; + + if (option_debug) + DEBUGA_PBX("Dialing %s\n", CELLIAX_P_LOG, dstr); + memset(at_command, 0, sizeof(at_command)); + p->phone_callflow = CALLFLOW_CALL_DIALING; + p->interface_state = AST_STATE_DIALING; + ast_uri_decode(dstr); + size_t fixdstr = strspn(dstr, AST_DIGIT_ANYDIG); + if (fixdstr == 0) { + ERRORA("dial command failed because of invalid dial number. dial string was: %s\n", + CELLIAX_P_LOG, dstr); + return -1; + } + dstr[fixdstr] = '\0'; + sprintf(at_command, "%s%s%s", p->at_dial_pre_number, dstr, p->at_dial_post_number); + res = celliax_serial_write_AT_expect(p, at_command, p->at_dial_expect); + if (res) { + ERRORA("dial command failed, dial string was: %s\n", CELLIAX_P_LOG, at_command); + return -1; + } + // jet - early audio + if (p->at_early_audio) { + ast_queue_control(p->owner, AST_CONTROL_ANSWER); + } + + return 0; +} + +int celliax_console_at(int fd, int argc, char *argv[]) +{ + struct celliax_pvt *p = celliax_console_find_desc(celliax_console_active); + char at_cmd[1024]; + int i, a, c; + + if (argc == 1) + return RESULT_SHOWUSAGE; + if (!p) { + ast_cli(fd, + "No \"current\" console for celliax_at, please enter 'help celliax_console'\n"); + return RESULT_SUCCESS; + } + if (p->controldevprotocol != PROTOCOL_AT) { + ast_cli(fd, + "The \"current\" console is not connected to an 'AT modem' (cellphone)\n"); + return RESULT_SUCCESS; + } + + memset(at_cmd, 0, sizeof(at_cmd)); + c = 0; + for (i = 1; i < argc; i++) { + for (a = 0; a < strlen(argv[i]); a++) { + at_cmd[c] = argv[i][a]; + c++; + if (c == 1022) + break; + } + if (i != argc - 1) { + at_cmd[c] = ' '; + c++; + } + if (c == 1023) + break; + } + celliax_serial_write_AT_noack(p, at_cmd); + return RESULT_SUCCESS; +} + +#ifdef ASTERISK_VERSION_1_2 +int celliax_manager_sendsms(struct mansession *s, struct message *m) +#endif //ASTERISK_VERSION_1_2 +#ifdef ASTERISK_VERSION_1_4 +int celliax_manager_sendsms(struct mansession *s, const struct message *m) +#endif //ASTERISK_VERSION_1_4 +{ + int ret; + char command[512]; + const char *interfacename = astman_get_header(m, "Interface"); + const char *destinationnumber = astman_get_header(m, "Number"); + const char *text = astman_get_header(m, "Text"); + const char *action_id = astman_get_header(m, "ActionID"); + + if (ast_strlen_zero(interfacename)) { + astman_send_error(s, m, "Interface: missing.\n"); + return 0; + } + if (ast_strlen_zero(destinationnumber)) { + astman_send_error(s, m, "Number: missing.\n"); + return 0; + } + if (ast_strlen_zero(text)) { + astman_send_error(s, m, "Text: missing.\n"); + return 0; + } + if (ast_strlen_zero(action_id)) { + astman_send_error(s, m, "ActionID: missing.\n"); + return 0; + } + + memset(command, 0, sizeof(command)); + + sprintf(command, "%s/%s|%s|", interfacename, destinationnumber, text); + + ret = celliax_sendsms(NULL, (void *) &command); + +#ifndef ASTERISK_VERSION_1_4 + if (!ret) { + ast_cli(s->fd, "Response: Success\r\n"); + if (!ast_strlen_zero(action_id)) + ast_cli(s->fd, "ActionID: %s\r\n", action_id); + ast_cli(s->fd, "\r\n"); + return RESULT_SUCCESS; + } else { + ast_cli(s->fd, "Response: Error\r\n"); + if (!ast_strlen_zero(action_id)) + ast_cli(s->fd, "ActionID: %s\r\n", action_id); + ast_cli(s->fd, "Message: celliax_manager_sendsms failed\r\n"); + ast_cli(s->fd, "\r\n"); + return 0; + } +#else /* ASTERISK_VERSION_1_4 */ + if (!ret) { + astman_append(s, "Response: Success\r\n"); + if (!ast_strlen_zero(action_id)) + astman_append(s, "ActionID: %s\r\n", action_id); + astman_append(s, "\r\n"); + return RESULT_SUCCESS; + } else { + astman_append(s, "Response: Error\r\n"); + if (!ast_strlen_zero(action_id)) + astman_append(s, "ActionID: %s\r\n", action_id); + astman_append(s, "Message: celliax_manager_sendsms failed\r\n"); + astman_append(s, "\r\n"); + return 0; + } +#endif /* ASTERISK_VERSION_1_4 */ + + return RESULT_SUCCESS; //never reached +} + +int ucs2_to_utf8(struct celliax_pvt *p, char *ucs2_in, char *utf8_out, + size_t outbytesleft) +{ + char converted[16000]; + iconv_t iconv_format; + int iconv_res; + char *outbuf; + char *inbuf; + size_t inbytesleft; + int c; + char stringa[5]; + double hexnum; + int i = 0; + + memset(converted, '\0', sizeof(converted)); + + DEBUGA_AT("ucs2_in=%s\n", CELLIAX_P_LOG, ucs2_in); + /* cicopet */ + for (c = 0; c < strlen(ucs2_in); c++) { + sprintf(stringa, "0x%c%c", ucs2_in[c], ucs2_in[c + 1]); + c++; + hexnum = strtod(stringa, NULL); + converted[i] = hexnum; + i++; + } + + outbuf = utf8_out; + inbuf = converted; + + iconv_format = iconv_open("UTF8", "UCS-2BE"); + if (iconv_format == (iconv_t) - 1) { + ERRORA("error: %s\n", CELLIAX_P_LOG, strerror(errno)); + return -1; + } + + inbytesleft = i; + iconv_res = iconv(iconv_format, &inbuf, &inbytesleft, &outbuf, &outbytesleft); + if (iconv_res == (size_t) - 1) { + DEBUGA_AT("ciao in=%s, inleft=%d, out=%s, outleft=%d, converted=%s, utf8_out=%s\n", + CELLIAX_P_LOG, inbuf, inbytesleft, outbuf, outbytesleft, converted, + utf8_out); + DEBUGA_AT("error: %s %d\n", CELLIAX_P_LOG, strerror(errno), errno); + return -1; + } + DEBUGA_AT + ("iconv_res=%d, in=%s, inleft=%d, out=%s, outleft=%d, converted=%s, utf8_out=%s\n", + CELLIAX_P_LOG, iconv_res, inbuf, inbytesleft, outbuf, outbytesleft, converted, + utf8_out); + iconv_close(iconv_format); + + return 0; +} + +int utf_to_ucs2(struct celliax_pvt *p, char *utf_in, size_t inbytesleft, char *ucs2_out, + size_t outbytesleft) +{ + /* cicopet */ + iconv_t iconv_format; + int iconv_res; + char *outbuf; + char *inbuf; + char converted[16000]; + int i; + char stringa[16]; + char stringa2[16]; + + memset(converted, '\0', sizeof(converted)); + + outbuf = converted; + inbuf = utf_in; + + iconv_format = iconv_open("UCS-2BE", "UTF8"); + if (iconv_format == (iconv_t) - 1) { + ERRORA("error: %s\n", CELLIAX_P_LOG, strerror(errno)); + return -1; + } + outbytesleft = 16000; + + DEBUGA_AT("in=%s, inleft=%d, out=%s, outleft=%d, utf_in=%s, converted=%s\n", + CELLIAX_P_LOG, inbuf, inbytesleft, outbuf, outbytesleft, utf_in, converted); + iconv_res = iconv(iconv_format, &inbuf, &inbytesleft, &outbuf, &outbytesleft); + if (iconv_res == (size_t) - 1) { + ERRORA("error: %s %d\n", CELLIAX_P_LOG, strerror(errno), errno); + return -1; + } + DEBUGA_AT + ("iconv_res=%d, in=%s, inleft=%d, out=%s, outleft=%d, utf_in=%s, converted=%s\n", + CELLIAX_P_LOG, iconv_res, inbuf, inbytesleft, outbuf, outbytesleft, utf_in, + converted); + iconv_close(iconv_format); + + for (i = 0; i < 16000 - outbytesleft; i++) { + memset(stringa, '\0', sizeof(stringa)); + memset(stringa2, '\0', sizeof(stringa2)); + sprintf(stringa, "%02X", converted[i]); + DEBUGA_AT("character is |%02X|\n", CELLIAX_P_LOG, converted[i]); + stringa2[0] = stringa[strlen(stringa) - 2]; + stringa2[1] = stringa[strlen(stringa) - 1]; + strncat(ucs2_out, stringa2, ((outbytesleft - strlen(ucs2_out)) - 1)); //add the received line to the buffer + DEBUGA_AT("stringa=%s, stringa2=%s, ucs2_out=%s\n", CELLIAX_P_LOG, stringa, stringa2, + ucs2_out); + } + return 0; +} + +int celliax_sendsms(struct ast_channel *c, void *data) +{ + char *idest = data; + char rdest[256]; + struct celliax_pvt *p = NULL; + char *device; + char *dest; + char *text; + char *stringp = NULL; + int found = 0; + int failed = 0; + + strncpy(rdest, idest, sizeof(rdest) - 1); + ast_log(LOG_DEBUG, "CelliaxSendsms: %s\n", rdest); + ast_log(LOG_DEBUG, "START\n"); + /* we can use celliax_request to get the channel, but celliax_request would look for onowned channels, and probably we can send SMSs while a call is ongoing + * + */ + + stringp = rdest; + device = strsep(&stringp, "/"); + dest = strsep(&stringp, "|"); + text = strsep(&stringp, "|"); + + if (!device) { + ast_log(LOG_ERROR, + "CelliaxSendsms app do not recognize '%s'. Requires a destination with slashes (interfacename/destinationnumber, TEXT)\n", + idest); + return -1; + } + + if (!dest) { + ast_log(LOG_ERROR, + "CelliaxSendsms app do not recognize '%s'. Requires a destination with slashes (interfacename/destinationnumber, TEXT)\n", + idest); + return -1; + } + + if (!text) { + ast_log(LOG_ERROR, + "CelliaxSendsms app do not recognize '%s'. Requires a destination with slashes (interfacename/destinationnumber, TEXT)\n", + idest); + return -1; + } + + ast_log(LOG_DEBUG, "interfacename:%s, destinationnumber:%s, text:%s\n", device, dest, + text); + + /* lock the interfaces' list */ + LOKKA(&celliax_iflock); + /* make a pointer to the first interface in the interfaces list */ + p = celliax_iflist; + /* Search for the requested interface and verify if is unowned */ + //TODO implement groups a la chan_zap + while (p) { + size_t length = strlen(p->name); + /* is this the requested interface? */ + if (strncmp(device, p->name, length) == 0) { + /* this is the requested interface! */ + if (option_debug) + DEBUGA_AT("FOUND! interfacename:%s, destinationnumber:%s, text:%s, p->name=%s\n", + CELLIAX_P_LOG, device, dest, text, p->name); + found = 1; + break; + + } + /* not yet found, next please */ + p = p->next; + } + /* unlock the interfaces' list */ + UNLOCKA(&celliax_iflock); + + if (!found) { + ast_log(LOG_ERROR, "Interface '%s' requested by CelliaxSendsms NOT FOUND\n", device); + return RESULT_FAILURE; + } + + if (p->controldevprotocol != PROTOCOL_AT) { + ERRORA("CelliaxSendsms supports only AT command cellphones at the moment :-( !\n", + CELLIAX_P_LOG); + return RESULT_FAILURE; + } + + if (p->controldevprotocol == PROTOCOL_AT) { + int err = 0; + char smscommand[16000]; + memset(smscommand, '\0', sizeof(smscommand)); + + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + + if (p->no_ucs2) { + sprintf(smscommand, "AT+CMGS=\"%s\"", dest); //TODO: support phones that only accept pdu mode + } else { + char dest2[1048]; + + err = celliax_serial_write_AT_ack(p, "AT+CSCS=\"UCS2\""); + if (err) { + ERRORA + ("AT+CSCS=\"UCS2\" (set TE messages to ucs2) do not got OK from the phone\n", + CELLIAX_P_LOG); + } + + memset(dest2, '\0', sizeof(dest2)); + utf_to_ucs2(p, dest, strlen(dest), dest2, sizeof(dest2)); + sprintf(smscommand, "AT+CMGS=\"%s\"", dest2); //TODO: support phones that only accept pdu mode + } + //TODO: support phones that only accept pdu mode + //TODO would be better to lock controldev here + err = celliax_serial_write_AT_noack(p, smscommand); + if (err) { + ERRORA("Error sending SMS\n", CELLIAX_P_LOG); + failed = 1; + goto uscita; + } + err = celliax_serial_AT_expect(p, "> ", 0, 1); // wait 1.5s for the prompt, no crlf +#if 1 + if (err) { + DEBUGA_AT + ("Error or timeout getting prompt '> ' for sending sms directly to the remote party. BTW, seems that we cannot do that with Motorola c350, so we'll write to cellphone memory, then send from memory\n", + CELLIAX_P_LOG); + + err = celliax_serial_write_AT_ack(p, "ATE1"); //motorola (at least c350) do not echo the '>' prompt when in ATE0... go figure!!!! + if (err) { + ERRORA("Error activating echo from modem\n", CELLIAX_P_LOG); + } + p->at_cmgw[0] = '\0'; + sprintf(smscommand, "AT+CMGW=\"%s\"", dest); //TODO: support phones that only accept pdu mode + err = celliax_serial_write_AT_noack(p, smscommand); + if (err) { + ERRORA("Error writing SMS destination to the cellphone memory\n", CELLIAX_P_LOG); + failed = 1; + goto uscita; + } + err = celliax_serial_AT_expect(p, "> ", 0, 1); // wait 1.5s for the prompt, no crlf + if (err) { + ERRORA + ("Error or timeout getting prompt '> ' for writing sms text in cellphone memory\n", + CELLIAX_P_LOG); + failed = 1; + goto uscita; + } + } +#endif + + //sprintf(text,"ciao 123 belè новоÑти לק ר×ת ﺎﻠﺠﻤﻋﺓ 人大"); //let's test the beauty of utf + memset(smscommand, '\0', sizeof(smscommand)); + if (p->no_ucs2) { + sprintf(smscommand, "%s", text); + } else { + utf_to_ucs2(p, text, strlen(text), smscommand, sizeof(smscommand)); + } + + smscommand[strlen(smscommand)] = 0x1A; + DEBUGA_AT("smscommand len is: %d, text is:|||%s|||\n", CELLIAX_P_LOG, + strlen(smscommand), smscommand); + + err = celliax_serial_write_AT_ack_nocr_longtime(p, smscommand); + //TODO would be better to unlock controldev here + if (err) { + ERRORA("Error writing SMS text to the cellphone memory\n", CELLIAX_P_LOG); + //return RESULT_FAILURE; + failed = 1; + goto uscita; + } + if (p->at_cmgw[0]) { + sprintf(smscommand, "AT+CMSS=%s", p->at_cmgw); + err = celliax_serial_write_AT_expect_longtime(p, smscommand, "OK"); + if (err) { + ERRORA("Error sending SMS from the cellphone memory\n", CELLIAX_P_LOG); + //return RESULT_FAILURE; + failed = 1; + goto uscita; + } + + err = celliax_serial_write_AT_ack(p, "ATE0"); //motorola (at least c350) do not echo the '>' prompt when in ATE0... go figure!!!! + if (err) { + ERRORA("Error de-activating echo from modem\n", CELLIAX_P_LOG); + } + } + uscita: + usleep(1000); + + if (p->at_cmgw[0]) { + + /* let's see what we've sent, just for check TODO: Motorola it's not reliable! Motorola c350 tells that all was sent, but is not true! It just sends how much it fits into one SMS FIXME: need an algorithm to calculate how many ucs2 chars fits into an SMS. It make difference based, probably, on the GSM alphabet translation, or so */ + sprintf(smscommand, "AT+CMGR=%s", p->at_cmgw); + err = celliax_serial_write_AT_ack(p, smscommand); + if (err) { + ERRORA("Error reading SMS back from the cellphone memory\n", CELLIAX_P_LOG); + } + + /* let's delete from cellphone memory what we've sent */ + sprintf(smscommand, "AT+CMGD=%s", p->at_cmgw); + err = celliax_serial_write_AT_ack(p, smscommand); + if (err) { + ERRORA("Error deleting SMS from the cellphone memory\n", CELLIAX_P_LOG); + } + + p->at_cmgw[0] = '\0'; + } + //usleep(500000); //.5 secs + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + } + + ast_log(LOG_DEBUG, "FINISH\n"); + if (failed) + return -1; + else + return RESULT_SUCCESS; +} + +#ifdef CELLIAX_DIR +/* For simplicity, I'm keeping the format compatible with the voicemail config, + but i'm open to suggestions for isolating it */ +#define CELLIAX_DIR_CONFIG "directoriax.conf" + +/* How many digits to read in */ +#define CELLIAX_DIR_NUMDIGITS 3 + +struct ast_config *celliax_dir_realtime(char *context) +{ + //TODO: all the realtime stuff has to be re-made + struct ast_config *cfg; + struct celliax_pvt *p = NULL; +#ifdef ASTERISK_VERSION_1_6_0 + struct ast_flags config_flags = { 0 }; +#endif /* ASTERISK_VERSION_1_6_0 */ + + /* Load flat file config. */ +#ifdef ASTERISK_VERSION_1_6_0 + cfg = ast_config_load(CELLIAX_DIR_CONFIG, config_flags); +#else + cfg = ast_config_load(CELLIAX_DIR_CONFIG); +#endif /* ASTERISK_VERSION_1_6_0 */ + + if (!cfg) { + /* Loading config failed. */ + WARNINGA + ("Loading directoriax.conf config file failed. It's not necessary, continuing.\n", + CELLIAX_P_LOG); + return NULL; + } + return cfg; +} + +static char *celliax_dir_convert(char *lastname) +{ + char *tmp; + int lcount = 0; + tmp = malloc(CELLIAX_DIR_NUMDIGITS + 1); + if (tmp) { + while ((*lastname > 32) && lcount < CELLIAX_DIR_NUMDIGITS) { + switch (toupper(*lastname)) { + case '1': + tmp[lcount++] = '1'; + break; + case '2': + case 'A': + case 'B': + case 'C': + tmp[lcount++] = '2'; + break; + case '3': + case 'D': + case 'E': + case 'F': + tmp[lcount++] = '3'; + break; + case '4': + case 'G': + case 'H': + case 'I': + tmp[lcount++] = '4'; + break; + case '5': + case 'J': + case 'K': + case 'L': + tmp[lcount++] = '5'; + break; + case '6': + case 'M': + case 'N': + case 'O': + tmp[lcount++] = '6'; + break; + case '7': + case 'P': + case 'Q': + case 'R': + case 'S': + tmp[lcount++] = '7'; + break; + case '8': + case 'T': + case 'U': + case 'V': + tmp[lcount++] = '8'; + break; + case '9': + case 'W': + case 'X': + case 'Y': + case 'Z': + tmp[lcount++] = '9'; + break; + } + lastname++; + } + tmp[lcount] = '\0'; + } + return tmp; +} + +int celliax_console_celliax_dir_export(int fd, int argc, char *argv[]) +{ + struct ast_config *cfg; + + struct ast_variable *v; + char *start, *pos, *stringp, *space, *options = NULL, *conv = NULL; + struct celliax_pvt *p = celliax_console_find_desc(celliax_console_active); + char *context = "default"; + char *s; + char *var, *value; + int fromcell = 0; + int fromskype = 0; + char name[256] = ""; + char phonebook_direct_calling_ext[7] = ""; + char write_entry_command[256] = ""; + char entry_number[256] = ""; + char entry_text[256] = ""; + char final_entry_text[256] = ""; + int res; + int tocell = 0; +#ifdef CELLIAX_LIBCSV + int tocsv = 0; + int tovcf = 0; +#endif /* CELLIAX_LIBCSV */ + + if (argc < 3 || argc > 4) + return RESULT_SHOWUSAGE; + if (!p) { + ast_cli(fd, "No \"current\" console ???, please enter 'help celliax_console'\n"); + return RESULT_SUCCESS; + } + + if (!strcasecmp(argv[1], "tocell")) + tocell = 1; +#ifdef CELLIAX_LIBCSV + else if (!strcasecmp(argv[1], "tocsv")) + tocsv = 1; + else if (!strcasecmp(argv[1], "tovcf")) + tovcf = 1; +#endif /* CELLIAX_LIBCSV */ + else { + ast_cli(fd, +#ifdef CELLIAX_LIBCSV + "\n\nYou have neither specified 'tocell' nor 'tocsv'\n\n"); +#else /* CELLIAX_LIBCSV */ + "\n\nYou have not specified 'tocell'\n\n"); +#endif /* CELLIAX_LIBCSV */ + return RESULT_SHOWUSAGE; + } + if (tocell) + if (p->controldevprotocol != PROTOCOL_AT) { + ast_cli(fd, + "Exporting to the cellphone phonebook is currently supported only on \"AT\" cellphones :( !\n"); + return RESULT_SUCCESS; + } +#ifdef CELLIAX_LIBCSV + if (tocsv || tovcf) + if (argc != 4) { + ast_cli(fd, "\n\nYou have to specify a filename with 'tocsv'\n\n"); + return RESULT_SHOWUSAGE; + } +#endif /* CELLIAX_LIBCSV */ + + if (option_debug) + NOTICA("celliax_cellphonenumber is: %s\n", CELLIAX_P_LOG, argv[2]); + +#ifdef CELLIAX_LIBCSV + if (tocsv) { + if (option_debug) + NOTICA("filename is: %s\n", CELLIAX_P_LOG, argv[3]); + //ast_cli(fd, "\n\nnot yet implemented :P \n"); + //return RESULT_SUCCESS; + } + if (tovcf) { + if (option_debug) + NOTICA("filename is: %s\n", CELLIAX_P_LOG, argv[3]); + ast_cli(fd, "\n\nnot yet implemented :P \n"); + return RESULT_SUCCESS; + } +#endif /* CELLIAX_LIBCSV */ + + cfg = celliax_dir_realtime(context); + if (!cfg) { + return -1; + } + + if (tocell) { + /* which phonebook to use, use the SIM */ + res = celliax_serial_write_AT_ack(p, "AT+CPBS=SM"); + if (res) { + WARNINGA("AT+CPBS=SM failed, continue\n", CELLIAX_P_LOG); + } + /* which phonebook to use, trying to use phone, not SIM */ + res = celliax_serial_write_AT_ack(p, "AT+CPBS=ME"); + if (res) { + WARNINGA("AT+CPBS=ME failed, continue\n", CELLIAX_P_LOG); + } + /* retrieve the fields lenght in the selected phonebook */ + p->phonebook_querying = 1; + res = celliax_serial_write_AT_ack(p, "AT+CPBR=?"); + if (res) { + WARNINGA("AT+CPBR=? failed, continue\n", CELLIAX_P_LOG); + } + p->phonebook_querying = 0; + + v = ast_variable_browse(cfg, context); + /* Find all candidate extensions */ + while (v) { + /* Find a candidate extension */ + start = strdup(v->value); + if (strcasestr(start, "fromcell=yes")) { + fromcell = 1; + fromskype = 0; + + } + if (strcasestr(start, "fromskype=yes")) { + fromcell = 0; + fromskype = 1; + + } + + if (start && !strcasestr(start, "hidefromdir=yes")) { + memset(name, 0, sizeof(name)); + memset(phonebook_direct_calling_ext, 0, sizeof(phonebook_direct_calling_ext)); + memset(write_entry_command, 0, sizeof(write_entry_command)); + memset(entry_number, 0, sizeof(entry_number)); + memset(entry_text, 0, sizeof(entry_text)); + memset(final_entry_text, 0, sizeof(final_entry_text)); + + DEBUGA_AT("v->name=%s\n", CELLIAX_P_LOG, v->name); + DEBUGA_AT("v->value=%s\n", CELLIAX_P_LOG, v->value); + + stringp = start; + strsep(&stringp, ","); + pos = strsep(&stringp, ","); + if (pos) { + ast_copy_string(name, pos, sizeof(name)); + if (strchr(pos, ' ')) { + space = strchr(pos, ' '); + *space = '\0'; + } + if (pos) { + conv = celliax_dir_convert(pos); + DEBUGA_AT("%s%s<\n", CELLIAX_P_LOG, pos, conv); + + options = strdup(v->value); + strsep(&options, ","); + strsep(&options, ","); + strsep(&options, ","); + strsep(&options, ","); + DEBUGA_AT("options=%s\n", CELLIAX_P_LOG, options); + + while ((s = strsep(&options, "|"))) { + value = s; + if ((var = strsep(&value, "=")) && value) { + DEBUGA_AT("var=%s value=%s\n", CELLIAX_P_LOG, var, value); + if (!strcmp(var, "phonebook_direct_calling_ext")) + strncpy(phonebook_direct_calling_ext, value, 6); + } + } + + res = + snprintf(entry_number, p->phonebook_number_lenght + 1, "%s%s%d%s%s", + argv[2], "p", p->celliax_dir_prefix, "p", + phonebook_direct_calling_ext); + if (res == (p->phonebook_number_lenght + 1) + || res > (p->phonebook_number_lenght + 1)) { + ERRORA("entry_number truncated, was: '%s%s%d%s%s', now is: '%s'\n", + CELLIAX_P_LOG, argv[2], "p", p->celliax_dir_prefix, "p", + phonebook_direct_calling_ext, entry_number); + //FIXME: abort ??? + + } + + res = snprintf(final_entry_text, p->phonebook_text_lenght + 1, "%s", name); //FIXME result not checked + + res = + snprintf(write_entry_command, sizeof(write_entry_command) - 1, + "AT+CPBW=,\"%s\",,\"%s\"", entry_number, final_entry_text); + if (res == (sizeof(write_entry_command) - 1) + || res > (sizeof(write_entry_command) - 1)) { + WARNINGA + ("write_entry_command truncated, was supposed: 'AT+CPBW=,\"%s\",,\"%s\"', now is: '%s'\n", + CELLIAX_P_LOG, entry_number, final_entry_text, write_entry_command); + } + //if (option_debug) + NOTICA("%s\n", CELLIAX_P_LOG, write_entry_command); + } + } + if (conv) + free(conv); + if (start) + free(start); + if (options) + free(options); + } + v = v->next; + } + } +#ifdef CELLIAX_LIBCSV + if (tocsv) { + + v = ast_variable_browse(cfg, context); + /* Find all candidate extensions */ + while (v) { + /* Find a candidate extension */ + start = strdup(v->value); + if (strcasestr(start, "fromcell=yes")) { + fromcell = 1; + fromskype = 0; + + } + if (strcasestr(start, "fromskype=yes")) { + fromcell = 0; + fromskype = 1; + + } + + if (start && !strcasestr(start, "hidefromdir=yes")) { + memset(name, 0, sizeof(name)); + memset(phonebook_direct_calling_ext, 0, sizeof(phonebook_direct_calling_ext)); + memset(write_entry_command, 0, sizeof(write_entry_command)); + memset(entry_number, 0, sizeof(entry_number)); + memset(entry_text, 0, sizeof(entry_text)); + memset(final_entry_text, 0, sizeof(final_entry_text)); + + DEBUGA_AT("v->name=%s\n", CELLIAX_P_LOG, v->name); + DEBUGA_AT("v->value=%s\n", CELLIAX_P_LOG, v->value); + + stringp = start; + strsep(&stringp, ","); + pos = strsep(&stringp, ","); + if (pos) { + ast_copy_string(name, pos, sizeof(name)); + if (strchr(pos, ' ')) { + space = strchr(pos, ' '); + *space = '\0'; + } + if (pos) { + conv = celliax_dir_convert(pos); + DEBUGA_AT("%s%s<\n", CELLIAX_P_LOG, pos, conv); + + options = strdup(v->value); + strsep(&options, ","); + strsep(&options, ","); + strsep(&options, ","); + strsep(&options, ","); + DEBUGA_AT("options=%s\n", CELLIAX_P_LOG, options); + + while ((s = strsep(&options, "|"))) { + value = s; + if ((var = strsep(&value, "=")) && value) { + DEBUGA_AT("var=%s value=%s\n", CELLIAX_P_LOG, var, value); + if (!strcmp(var, "phonebook_direct_calling_ext")) + strncpy(phonebook_direct_calling_ext, value, 6); + } + } + + //FIXME choose a logic for fields maximum lenght + res = + snprintf(entry_number, sizeof(entry_number) - 1, "%s%s%d%s%s", argv[2], "p", + p->celliax_dir_prefix, "p", phonebook_direct_calling_ext); + if (res == (sizeof(entry_number) - 1) + || res > (sizeof(entry_number) - 1)) { + ERRORA("entry_number truncated, was: '%s%s%d%s%s', now is: '%s'\n", + CELLIAX_P_LOG, argv[2], "p", p->celliax_dir_prefix, "p", + phonebook_direct_calling_ext, entry_number); + //FIXME: abort ??? + + } + + res = snprintf(final_entry_text, sizeof(final_entry_text) - 1, "%s", name); //FIXME result not checked + + int i, a; + + a = 0; + for (i = 0; i < p->csv_complete_name_pos - 1; i++) { + if (p->csv_separator_is_semicolon) + write_entry_command[a] = ';'; + else + write_entry_command[a] = ','; + a++; + } + //NOTICA("i=%d a=%d\n", CELLIAX_P_LOG, i, a); + + write_entry_command[a] = '"'; + a++; + //NOTICA("i=%d a=%d\n", CELLIAX_P_LOG, i, a); + for (i = 0; i < strlen(final_entry_text); i++) { + write_entry_command[a] = final_entry_text[i]; + a++; + } + //NOTICA("i=%d a=%d\n", CELLIAX_P_LOG, i, a); + write_entry_command[a] = '"'; + a++; + //NOTICA("i=%d a=%d\n", CELLIAX_P_LOG, i, a); + for (i = 0; i < (p->csv_business_phone_pos - p->csv_complete_name_pos); i++) { + if (p->csv_separator_is_semicolon) + write_entry_command[a] = ';'; + else + write_entry_command[a] = ','; + a++; + } + + //NOTICA("i=%d a=%d\n", CELLIAX_P_LOG, i, a); + + write_entry_command[a] = '"'; + a++; + //NOTICA("i=%d a=%d\n", CELLIAX_P_LOG, i, a); + for (i = 0; i < strlen(entry_number); i++) { + write_entry_command[a] = entry_number[i]; + a++; + } + //NOTICA("i=%d a=%d\n", CELLIAX_P_LOG, i, a); + write_entry_command[a] = '"'; + a++; + //NOTICA("i=%d a=%d\n", CELLIAX_P_LOG, i, a); + + if (option_debug) + NOTICA("%s\n", CELLIAX_P_LOG, write_entry_command); + } + } + if (conv) + free(conv); + if (start) + free(start); + if (options) + free(options); + } + v = v->next; + } + + } + if (tovcf) { +//TODO implementation here + } +#endif /* CELLIAX_LIBCSV */ + ast_config_destroy(cfg); + return 0; +} + +#ifdef CELLIAX_LIBCSV + +void celliax_cb1(char *s, size_t len, void *data) +{ + struct celliax_pvt *p = data; + char field_content[256]; + + p->csv_fields++; + memset(field_content, 0, sizeof(field_content)); + strncpy(field_content, s, + sizeof(field_content) > (len + 1) ? len : (sizeof(field_content) - 1)); + if (p->csv_fields == p->csv_complete_name_pos) { + strncpy(p->csv_complete_name, field_content, sizeof(p->csv_complete_name) - 1); + } + if (p->csv_fields == p->csv_email_pos) { + strncpy(p->csv_email, field_content, sizeof(p->csv_email) - 1); + } + if (p->csv_fields == p->csv_home_phone_pos) { + strncpy(p->csv_home_phone, field_content, sizeof(p->csv_home_phone) - 1); + } + if (p->csv_fields == p->csv_mobile_phone_pos) { + strncpy(p->csv_mobile_phone, field_content, sizeof(p->csv_mobile_phone) - 1); + } + if (p->csv_fields == p->csv_business_phone_pos) { + strncpy(p->csv_business_phone, field_content, sizeof(p->csv_business_phone) - 1); + } +} + +void celliax_cb2(char c, void *data) +{ + struct celliax_pvt *p = data; + + p->csv_rows++; + p->csv_fields = 0; + + if (p->csv_first_row_is_title && p->csv_rows == 1) { + //do nothing + } else { + if (strlen(p->csv_complete_name)) { + if (option_debug) + NOTICA + ("ROW %d ENDED, complete_name=%s, email=%s, home_phone=%s, mobile_phone=%s, business_phone=%s\n", + CELLIAX_P_LOG, p->csv_rows, + strlen(p->csv_complete_name) ? p->csv_complete_name : "N/A", + strlen(p->csv_email) ? p->csv_email : "N/A", + strlen(p->csv_home_phone) ? p->csv_home_phone : "N/A", + strlen(p->csv_mobile_phone) ? p->csv_mobile_phone : "N/A", + strlen(p->csv_business_phone) ? p->csv_business_phone : "N/A"); + } + + /* write entries in phonebook file */ + if (p->phonebook_writing_fp) { + celliax_dir_entry_extension++; + + if (strlen(p->csv_complete_name)) { + /* let's start with home_phone */ + if (strlen(p->csv_home_phone)) { + fprintf(p->phonebook_writing_fp, + "%s => ,%s %sSKO,,,hidefromdir=%s|phonebook_direct_calling_ext=%d%s%.4d|phonebook_entry_fromcsv=%s|phonebook_entry_owner=%s\n", + p->csv_home_phone, p->csv_complete_name, "HOME", "no", + p->celliax_dir_entry_extension_prefix, "2", celliax_dir_entry_extension, + "yes", "not_specified"); + fprintf(p->phonebook_writing_fp, + "%s => ,%s %sDO,,,hidefromdir=%s|phonebook_direct_calling_ext=%d%s%.4d|phonebook_entry_fromcsv=%s|phonebook_entry_owner=%s\n", + p->csv_home_phone, p->csv_complete_name, "HOME", "no", + p->celliax_dir_entry_extension_prefix, "3", celliax_dir_entry_extension, + "yes", "not_specified"); + } + + /* now business_phone */ + if (strlen(p->csv_business_phone)) { + fprintf(p->phonebook_writing_fp, + "%s => ,%s %sSKO,,,hidefromdir=%s|phonebook_direct_calling_ext=%d%s%.4d|phonebook_entry_fromcsv=%s|phonebook_entry_owner=%s\n", + p->csv_business_phone, p->csv_complete_name, "BIZ", "no", + p->celliax_dir_entry_extension_prefix, "2", celliax_dir_entry_extension, + "yes", "not_specified"); + fprintf(p->phonebook_writing_fp, + "%s => ,%s %sDO,,,hidefromdir=%s|phonebook_direct_calling_ext=%d%s%.4d|phonebook_entry_fromcsv=%s|phonebook_entry_owner=%s\n", + p->csv_business_phone, p->csv_complete_name, "BIZ", "no", + p->celliax_dir_entry_extension_prefix, "3", celliax_dir_entry_extension, + "yes", "not_specified"); + } + + /* let's end with mobile_phone */ + if (strlen(p->csv_mobile_phone)) { + fprintf(p->phonebook_writing_fp, + "%s => ,%s %sSKO,,,hidefromdir=%s|phonebook_direct_calling_ext=%d%s%.4d|phonebook_entry_fromcsv=%s|phonebook_entry_owner=%s\n", + p->csv_mobile_phone, p->csv_complete_name, "CELL", "no", + p->celliax_dir_entry_extension_prefix, "2", celliax_dir_entry_extension, + "yes", "not_specified"); + fprintf(p->phonebook_writing_fp, + "%s => ,%s %sDO,,,hidefromdir=%s|phonebook_direct_calling_ext=%d%s%.4d|phonebook_entry_fromcsv=%s|phonebook_entry_owner=%s\n", + p->csv_mobile_phone, p->csv_complete_name, "CELL", "no", + p->celliax_dir_entry_extension_prefix, "3", celliax_dir_entry_extension, + "yes", "not_specified"); + } + } + + } + + } +} + +#endif /* CELLIAX_LIBCSV */ + +int celliax_console_celliax_dir_import(int fd, int argc, char *argv[]) +{ + int res; + struct celliax_pvt *p = celliax_console_find_desc(celliax_console_active); + char list_command[64]; + char fn[256]; + char date[256] = ""; + time_t t; + char *configfile = CELLIAX_DIR_CONFIG; + int add_to_celliax_dir_conf = 1; + //int fromskype = 0; + int fromcell = 0; +#ifdef CELLIAX_LIBCSV + int fromcsv = 0; + int fromvcf = 0; +#endif /* CELLIAX_LIBCSV */ + + if (argc < 3 || argc > 4) + return RESULT_SHOWUSAGE; + if (!p) { + ast_cli(fd, "No \"current\" console ???, please enter 'help celliax_console'\n"); + return RESULT_SUCCESS; + } + + if (!strcasecmp(argv[1], "add")) + add_to_celliax_dir_conf = 1; + else if (!strcasecmp(argv[1], "replace")) + add_to_celliax_dir_conf = 0; + else { + ast_cli(fd, "\n\nYou have neither specified 'add' nor 'replace'\n\n"); + return RESULT_SHOWUSAGE; + } + + //if (!strcasecmp(argv[2], "fromskype")) + //fromskype = 1; + //else + + if (!strcasecmp(argv[2], "fromcell")) + fromcell = 1; +#ifdef CELLIAX_LIBCSV + else if (!strcasecmp(argv[2], "fromcsv")) + fromcsv = 1; + else if (!strcasecmp(argv[2], "fromvcf")) + fromvcf = 1; +#endif /* CELLIAX_LIBCSV */ + else { + ast_cli(fd, "\n\nYou have neither specified 'fromcell' neither 'fromcsv'\n\n"); + return RESULT_SHOWUSAGE; + } + +#ifdef CELLIAX_LIBCSV + if (fromcsv || fromvcf) + if (argc != 4) { + ast_cli(fd, + "\n\nYou have to specify a filename with 'fromcsv' or with 'fromvcf'\n\n"); + return RESULT_SHOWUSAGE; + } +#endif /* CELLIAX_LIBCSV */ + if (fromcell) + if (p->controldevprotocol != PROTOCOL_AT) { + ast_cli(fd, + "Importing from cellphone is currently supported only on \"AT\" cellphones :( !\n"); + //fclose(p->phonebook_writing_fp); + //celliax_dir_create_extensions(); + return RESULT_SUCCESS; + } + + if (fromcell) + if (argc != 3) { + ast_cli(fd, "\n\nYou don't have to specify a filename with 'fromcell'\n\n"); + return RESULT_SHOWUSAGE; + } +#ifdef CELLIAX_LIBCSV + if (fromvcf) { + if (option_debug) + NOTICA("filename is: %s\n", CELLIAX_P_LOG, argv[3]); + ast_cli(fd, "\n\nnot yet implemented :P \n"); + return RESULT_SUCCESS; + } +#endif /* CELLIAX_LIBCSV */ + + /*******************************************************************************************/ + + if (configfile[0] == '/') { + ast_copy_string(fn, configfile, sizeof(fn)); + } else { + snprintf(fn, sizeof(fn), "%s/%s", ast_config_AST_CONFIG_DIR, configfile); + } + if (option_debug) + NOTICA("Opening '%s'\n", CELLIAX_P_LOG, fn); + time(&t); + ast_copy_string(date, ctime(&t), sizeof(date)); + + if (add_to_celliax_dir_conf) + p->phonebook_writing_fp = fopen(fn, "a+"); + else + p->phonebook_writing_fp = fopen(fn, "w+"); + + if (p->phonebook_writing_fp) { + if (add_to_celliax_dir_conf) { + if (option_debug) + NOTICA("Opened '%s' for appending \n", CELLIAX_P_LOG, fn); + fprintf(p->phonebook_writing_fp, ";!\n"); + fprintf(p->phonebook_writing_fp, ";! Update Date: %s", date); + fprintf(p->phonebook_writing_fp, ";! Updated by: %s, %d\n", __FILE__, __LINE__); + fprintf(p->phonebook_writing_fp, ";!\n"); + } else { + if (option_debug) + NOTICA("Opened '%s' for writing \n", CELLIAX_P_LOG, fn); + fprintf(p->phonebook_writing_fp, ";!\n"); + fprintf(p->phonebook_writing_fp, ";! Automatically generated configuration file\n"); + fprintf(p->phonebook_writing_fp, ";! Filename: %s (%s)\n", configfile, fn); + fprintf(p->phonebook_writing_fp, ";! Creation Date: %s", date); + fprintf(p->phonebook_writing_fp, ";! Generated by: %s, %d\n", __FILE__, __LINE__); + fprintf(p->phonebook_writing_fp, ";!\n"); + fprintf(p->phonebook_writing_fp, "[general]\n\n"); + fprintf(p->phonebook_writing_fp, "[default]\n"); + } + +#ifdef CELLIAX_LIBCSV + //FIXME: if add_to_celliax_dir_conf parse the "old" config file, so to have the correct next entry id-exten + if (fromcsv) { + if (option_debug) + NOTICA("filename is: %s\n", CELLIAX_P_LOG, argv[3]); + +/************************/ + FILE *fp; + struct csv_parser *csvp; + char buf[1024]; + size_t bytes_read; + unsigned char options = 0; + + p->csv_rows = 0; + p->csv_fields = 0; + + if (p->csv_separator_is_semicolon) { + if (csv_init(&csvp, options | CSV_USE_SEMICOLON_SEPARATOR) != 0) { + ERRORA("Failed to initialize csv parser\n", CELLIAX_P_LOG); + return RESULT_SUCCESS; + } + } else { + if (csv_init(&csvp, options) != 0) { + ERRORA("Failed to initialize csv parser\n", CELLIAX_P_LOG); + return RESULT_SUCCESS; + } + + } + + fp = fopen(argv[3], "rb"); + if (!fp) { + ERRORA("Failed to open %s: %s\n", CELLIAX_P_LOG, argv[3], strerror(errno)); + return RESULT_SUCCESS; + } + while ((bytes_read = fread(buf, 1, 1024, fp)) > 0) { + if (csv_parse(csvp, buf, bytes_read, celliax_cb1, celliax_cb2, p) != bytes_read) { + ERRORA("Error while parsing file: %s\n", CELLIAX_P_LOG, + csv_strerror(csv_error(csvp))); + } + } + + csv_fini(csvp, celliax_cb1, celliax_cb2, p); + + if (ferror(fp)) { + ERRORA("Error while reading file %s\n", CELLIAX_P_LOG, argv[3]); + fclose(fp); + return RESULT_SUCCESS; + } + + fclose(fp); + if (option_debug) + NOTICA("%s: %d fields, %d rows\n", CELLIAX_P_LOG, argv[3], p->csv_fields, + p->csv_rows); + + csv_free(csvp); + + /**************************/ + } +#endif /* CELLIAX_LIBCSV */ + + /*******************************************************************************************/ + //if (fromskype) { + //ast_cli(fd, + //"Skype not supported in celliax_dir. Load chan_skypiax and use skypiax_dir!\n"); + //} + + /*******************************************************************************************/ + if (fromcell) { + /* which phonebook to use, use the SIM */ + res = celliax_serial_write_AT_ack(p, "AT+CPBS=SM"); + if (res) { + WARNINGA("AT+CPBS=SM failed, continue\n", CELLIAX_P_LOG); + } + /* which phonebook to use, trying to use combined phone+SIM */ + res = celliax_serial_write_AT_ack(p, "AT+CPBS=MT"); + if (res) { + WARNINGA("AT+CPBS=MT failed, continue\n", CELLIAX_P_LOG); + } + /* How many entries in phonebook */ + p->phonebook_querying = 1; + res = celliax_serial_write_AT_ack(p, "AT+CPBR=?"); + if (res) { + WARNINGA("AT+CPBR=? failed, continue\n", CELLIAX_P_LOG); + } + p->phonebook_querying = 0; + /* list entries in phonebook, give the SIM the time to answer */ + WARNINGA + ("About to querying the cellphone phonebook, if the SIM do not answer may stuck here for 20 seconds... Don't worry.\n", + CELLIAX_P_LOG); + sprintf(list_command, "AT+CPBR=%d,%d", p->phonebook_first_entry, + p->phonebook_last_entry); + p->phonebook_listing = 1; + res = celliax_serial_write_AT_expect_longtime(p, list_command, "OK"); + if (res) { + WARNINGA("AT+CPBR=%d,%d failed, continue\n", CELLIAX_P_LOG, + p->phonebook_first_entry, p->phonebook_last_entry); + } + p->phonebook_listing = 0; + } + /*******************************************************************************************/ +#ifdef CELLIAX_LIBCSV + if (fromvcf) { + //TODO implementation here + } +#endif /* CELLIAX_LIBCSV */ + + } else { + ast_cli(fd, "\n\nfailed to open the directoriax.conf configuration file: %s\n", fn); + ERRORA("failed to open the directoriax.conf configuration file: %s\n", CELLIAX_P_LOG, + fn); + return RESULT_FAILURE; + } + + fclose(p->phonebook_writing_fp); + //celliax_dir_create_extensions(); + + return RESULT_SUCCESS; +} + +#endif /* CELLIAX_DIR */ + +#ifdef CELLIAX_FBUS2 + +int celliax_serial_getstatus_FBUS2(struct celliax_pvt *p) +{ + unsigned char MsgBuffer[7]; + int res; + int how_many_reads = 0; + + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + + MsgBuffer[0] = FBUS2_COMMAND_BYTE_1; + MsgBuffer[1] = FBUS2_COMMAND_BYTE_2; + MsgBuffer[2] = 0x00; + MsgBuffer[3] = 0x03; + MsgBuffer[4] = 0x00; + MsgBuffer[5] = FBUS2_IS_LAST_FRAME; + MsgBuffer[6] = celliax_serial_get_seqnum_FBUS2(p); + + if (option_debug > 1) + DEBUGA_FBUS2("asking model, outseqnum %.2X \n", CELLIAX_P_LOG, MsgBuffer[6]); + celliax_serial_write_FBUS2(p, MsgBuffer, 7, FBUS2_TYPE_MODEL_ASK); + usleep(1000); + res = celliax_serial_read_FBUS2(p); //we don't have no monitor neither do_controldev_thread + if (res == -1) { + ERRORA("failed celliax_serial_read_FBUS2\n", CELLIAX_P_LOG); + UNLOCKA(&p->controldev_lock); + return -1; + } + while (res != MsgBuffer[6] && res != FBUS2_TYPE_MODEL_ANSWER) { + usleep(1000); + res = celliax_serial_read_FBUS2(p); + how_many_reads++; + if (res == -1) { + ERRORA("failed celliax_serial_read_FBUS2\n", CELLIAX_P_LOG); + UNLOCKA(&p->controldev_lock); + return -1; + } + if (how_many_reads > 10) { + ERRORA("no expected results in %d celliax_serial_read_FBUS2\n", CELLIAX_P_LOG, + how_many_reads); + UNLOCKA(&p->controldev_lock); + return -1; + } + } + + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + return 0; +} + +int celliax_serial_sync_FBUS2(struct celliax_pvt *p) +{ + unsigned char initc = 0x55; /* FBUS2 initialization char */ + int c, rt; + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + /* init the link (sync receive uart) */ + for (c = 0; c < 55; c++) { /* 55 times */ + usleep(10000); + rt = write(p->controldevfd, &initc, 1); + if (rt != 1) { + ERRORA("serial error: %s", CELLIAX_P_LOG, strerror(errno)); + UNLOCKA(&p->controldev_lock); + return -1; + } + } + time(&p->celliax_serial_synced_timestamp); + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + return 0; +} + +int celliax_serial_answer_FBUS2(struct celliax_pvt *p) +{ + unsigned char MsgBuffer[6]; + + celliax_serial_security_command_FBUS2(p); + + MsgBuffer[0] = FBUS2_COMMAND_BYTE_1; + MsgBuffer[1] = FBUS2_COMMAND_BYTE_2; + MsgBuffer[2] = FBUS2_SECURIY_CALL_COMMANDS; + MsgBuffer[3] = FBUS2_SECURIY_CALL_COMMAND_ANSWER; + MsgBuffer[4] = FBUS2_IS_LAST_FRAME; + MsgBuffer[5] = celliax_serial_get_seqnum_FBUS2(p); + if (option_debug > 1) + DEBUGA_FBUS2("celliax_serial_answer_FBUS2, outseqnum %.2X \n", CELLIAX_P_LOG, + MsgBuffer[5]); + celliax_serial_write_FBUS2(p, MsgBuffer, 6, FBUS2_TYPE_SECURITY); + DEBUGA_FBUS2("FBUS2: sent commands to answer the call\n", CELLIAX_P_LOG); + p->interface_state = AST_STATE_UP; //FIXME + + return 0; +} + +int celliax_serial_call_FBUS2(struct celliax_pvt *p, char *dstr) +{ + unsigned char MsgBufferNum[255]; + int i; + + celliax_serial_security_command_FBUS2(p); + + MsgBufferNum[0] = FBUS2_COMMAND_BYTE_1; + MsgBufferNum[1] = FBUS2_COMMAND_BYTE_2; + MsgBufferNum[2] = FBUS2_SECURIY_CALL_COMMANDS; + MsgBufferNum[3] = FBUS2_SECURIY_CALL_COMMAND_CALL; + for (i = 0; i < strlen(dstr); i++) { + MsgBufferNum[4 + i] = dstr[i]; + } + MsgBufferNum[4 + strlen(dstr)] = 0x00; /* required by FBUS2 prot */ + MsgBufferNum[4 + strlen(dstr) + 1] = FBUS2_IS_LAST_FRAME; + MsgBufferNum[4 + strlen(dstr) + 2] = celliax_serial_get_seqnum_FBUS2(p); + if (option_debug > 1) + DEBUGA_FBUS2("celliax_serial_call_FBUS2, outseqnum %.2X \n", CELLIAX_P_LOG, + MsgBufferNum[4 + strlen(dstr) + 2]); + celliax_serial_write_FBUS2(p, MsgBufferNum, 5 + strlen(dstr) + 2, FBUS2_TYPE_SECURITY); + + p->phone_callflow = CALLFLOW_CALL_DIALING; + p->interface_state = AST_STATE_DIALING; + if (option_debug) + DEBUGA_FBUS2("FBUS2: sent commands to call\n", CELLIAX_P_LOG); + return 0; +} + +int celliax_serial_hangup_FBUS2(struct celliax_pvt *p) +{ + unsigned char MsgBuffer[6]; + + if (p->interface_state != AST_STATE_DOWN) { + celliax_serial_security_command_FBUS2(p); + + MsgBuffer[0] = FBUS2_COMMAND_BYTE_1; + MsgBuffer[1] = FBUS2_COMMAND_BYTE_2; + MsgBuffer[2] = FBUS2_SECURIY_CALL_COMMANDS; + MsgBuffer[3] = FBUS2_SECURIY_CALL_COMMAND_RELEASE; + MsgBuffer[4] = FBUS2_IS_LAST_FRAME; + MsgBuffer[5] = celliax_serial_get_seqnum_FBUS2(p); + + if (option_debug > 1) + DEBUGA_FBUS2("celliax_serial_hangup_FBUS2, outseqnum %.2X \n", CELLIAX_P_LOG, + MsgBuffer[5]); + celliax_serial_write_FBUS2(p, MsgBuffer, 6, FBUS2_TYPE_SECURITY); + + DEBUGA_FBUS2("FBUS2: sent commands to hangup the call\n", CELLIAX_P_LOG); + + } + p->interface_state = AST_STATE_DOWN; //FIXME + p->phone_callflow = CALLFLOW_CALL_IDLE; //FIXME + return 0; +} + +int celliax_serial_config_FBUS2(struct celliax_pvt *p) +{ + unsigned char MsgBuffer[6]; + int res; + int how_many_reads = 0; + + MsgBuffer[0] = FBUS2_COMMAND_BYTE_1; + MsgBuffer[1] = FBUS2_COMMAND_BYTE_2; + MsgBuffer[2] = FBUS2_SECURIY_EXTENDED_COMMANDS; + MsgBuffer[3] = FBUS2_SECURIY_EXTENDED_COMMAND_ON; + MsgBuffer[4] = FBUS2_IS_LAST_FRAME; + MsgBuffer[5] = celliax_serial_get_seqnum_FBUS2(p); + + if (option_debug > 1) + DEBUGA_FBUS2("activating security commands for getting IMEI, outseqnum %.2X \n", + CELLIAX_P_LOG, MsgBuffer[5]); + celliax_serial_write_FBUS2(p, MsgBuffer, 6, FBUS2_TYPE_SECURITY); + res = celliax_serial_read_FBUS2(p); //we don't have no monitor neither do_controldev_thread + if (res == -1) { + ERRORA("failed celliax_serial_read_FBUS2\n", CELLIAX_P_LOG); + return -1; + } + while (res != MsgBuffer[5] && res != FBUS2_SECURIY_EXTENDED_COMMAND_ON) { + usleep(1000); + res = celliax_serial_read_FBUS2(p); + how_many_reads++; + if (res == -1) { + ERRORA("failed celliax_serial_read_FBUS2\n", CELLIAX_P_LOG); + return -1; + } + if (how_many_reads > 10) { + ERRORA("no expected results in %d celliax_serial_read_FBUS2\n", CELLIAX_P_LOG, + how_many_reads); + return -1; + } + } + + MsgBuffer[0] = FBUS2_COMMAND_BYTE_1; + MsgBuffer[1] = FBUS2_COMMAND_BYTE_2; + MsgBuffer[2] = FBUS2_SECURIY_IMEI_COMMANDS; + MsgBuffer[3] = FBUS2_SECURIY_IMEI_COMMAND_GET; + MsgBuffer[4] = FBUS2_IS_LAST_FRAME; + MsgBuffer[5] = celliax_serial_get_seqnum_FBUS2(p); + if (option_debug > 1) + DEBUGA_FBUS2("celliax_serial_get_IMEI_init_FBUS2, outseqnum %.2X \n", CELLIAX_P_LOG, + MsgBuffer[5]); + celliax_serial_write_FBUS2(p, MsgBuffer, 6, FBUS2_TYPE_SECURITY); + res = celliax_serial_read_FBUS2(p); //we don't have no monitor neither do_controldev_thread + if (res == -1) { + ERRORA("failed celliax_serial_read_FBUS2\n", CELLIAX_P_LOG); + return -1; + } + how_many_reads = 0; + while (res != MsgBuffer[5] && res != CALLFLOW_GOT_IMEI) { + usleep(1000); + res = celliax_serial_read_FBUS2(p); + how_many_reads++; + if (res == -1) { + ERRORA("failed celliax_serial_read_FBUS2\n", CELLIAX_P_LOG); + return -1; + } + if (how_many_reads > 10) { + ERRORA("no expected results in %d celliax_serial_read_FBUS2\n", CELLIAX_P_LOG, + how_many_reads); + //FIXME return -1; + return 0; + } + } + + if (option_debug > 1) + DEBUGA_FBUS2("xxxxx GOT IMEI xxxxx res=%d %.2X \n", CELLIAX_P_LOG, res, res); + + return 0; +} + +int celliax_serial_get_seqnum_FBUS2(struct celliax_pvt *p) +{ + if (p->seqnumfbus > FBUS2_SEQNUM_MAX || p->seqnumfbus < FBUS2_SEQNUM_MIN) { + ERRORA("p->seqnumfbus: %2.X\n", CELLIAX_P_LOG, p->seqnumfbus); + p->seqnumfbus = FBUS2_SEQNUM_MIN; + } + + if (p->seqnumfbus == FBUS2_SEQNUM_MAX) { + p->seqnumfbus = FBUS2_SEQNUM_MIN; + } else { + p->seqnumfbus++; + } + if (option_debug > 10) + DEBUGA_FBUS2("sqnum: %2.X\n", CELLIAX_P_LOG, p->seqnumfbus); + return p->seqnumfbus; +} + +int celliax_serial_security_command_FBUS2(struct celliax_pvt *p) +{ + unsigned char MsgBuffer[6]; + + MsgBuffer[0] = FBUS2_COMMAND_BYTE_1; + MsgBuffer[1] = FBUS2_COMMAND_BYTE_2; + MsgBuffer[2] = FBUS2_SECURIY_EXTENDED_COMMANDS; + MsgBuffer[3] = FBUS2_SECURIY_EXTENDED_COMMAND_ON; + MsgBuffer[4] = FBUS2_IS_LAST_FRAME; + MsgBuffer[5] = celliax_serial_get_seqnum_FBUS2(p); + + if (option_debug > 1) + DEBUGA_FBUS2("activating security commands, outseqnum %.2X \n", CELLIAX_P_LOG, + MsgBuffer[5]); + celliax_serial_write_FBUS2(p, MsgBuffer, 6, FBUS2_TYPE_SECURITY); + return 0; +} + +/*! + * \brief Write on the serial port for all the FBUS2 (old Nokia) functions + * \param p celliax_pvt + * \param len lenght of buffer2 + * \param buffer2 chars to be written + * + * Write on the serial port for all the FBUS2 (old Nokia) functions + * + * \return the number of chars written on the serial, + * that can be different from len (or negative) in case of errors. + */ +int celliax_serial_send_FBUS2(struct celliax_pvt *p, int len, unsigned char *mesg_ptr) +{ + int ret; + size_t actual = 0; + unsigned char *mesg_ptr2 = mesg_ptr; + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + do { + ret = write(p->controldevfd, mesg_ptr, len - actual); + if (ret < 0 && errno == EAGAIN) + continue; + if (ret < 0) { + if (actual != len) + ERRORA("celliax_serial_write error: %s", CELLIAX_P_LOG, strerror(errno)); + UNLOCKA(&p->controldev_lock); + return -1; + } + actual += ret; + mesg_ptr += ret; + usleep(10000); + } while (actual < len); + + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + if (option_debug > 10) { + int i; + char debug_buf[1024]; + char *debug_buf_pos; + + memset(debug_buf, 0, 1024); + debug_buf_pos = debug_buf; + + for (i = 0; i < len; i++) { + debug_buf_pos += sprintf(debug_buf_pos, "[%.2X] ", mesg_ptr2[i]); + if (debug_buf_pos > ((char *) &debug_buf + 1000)) + break; + } + DEBUGA_FBUS2("%s was sent down the wire\n", CELLIAX_P_LOG, debug_buf); + } + + return 0; +} + +/*! + * \brief Flags as acknowledged an FBUS2 message previously sent + * \param p celliax_pvt + * \param seqnum identifier of the message to be acknowledged + * + * Called upon receiving an FBUS2 acknoledgement message, browse the fbus2_outgoing_list + * looking for the seqnum sent FBUS2 message, and flags it as acknowledged. + * (if an outgoing FBUS2 message is not aknowledged by the cellphone in a while, + * it will be retransmitted) + * + * \return 0 on error, 1 otherwise + */ +int celliax_serial_list_acknowledge_FBUS2(struct celliax_pvt *p, int seqnum) +{ + struct fbus2_msg *ptr; + + ptr = p->fbus2_outgoing_list; + if (ptr == NULL) { + ERRORA("fbus2_outgoing_list is NULL ?\n", CELLIAX_P_LOG); + return -1; + } + PUSHA_UNLOCKA(&p->fbus2_outgoing_list_lock); + LOKKA(&p->fbus2_outgoing_list_lock); + while (ptr->next != NULL) + ptr = ptr->next; + while (ptr->acknowledged == 0) { + if (ptr->seqnum == seqnum) { + ptr->acknowledged = 1; + if (option_debug > 1) + DEBUGA_FBUS2("Acknowledgment to %.2X\n", CELLIAX_P_LOG, seqnum); + + DEBUGA_FBUS2("PREFREE OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_FBUS2(p, p->fbus2_outgoing_list); + if (ptr->previous) { + if (ptr->next) { + ptr->previous->next = ptr->next; + } else { + ptr->previous->next = NULL; + } + } + if (ptr->next) { + if (ptr->previous) { + ptr->next->previous = ptr->previous; + } else { + ptr->next->previous = NULL; + } + } + + if ((NULL == ptr->next) && (NULL == ptr->previous)) { /* bug catched by Wojciech Andralojc */ + if (option_debug > 1) + DEBUGA_FBUS2("FREEING LAST\n", CELLIAX_P_LOG); + p->fbus2_outgoing_list = NULL; + p->fbus2_outgoing_list = celliax_serial_list_init_FBUS2(p); + } + + free(ptr); + DEBUGA_FBUS2("POSTFREE OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_FBUS2(p, p->fbus2_outgoing_list); + + break; + } + if (ptr->previous != NULL) { + ptr = ptr->previous; + } else { + ERRORA + ("The phone sent us an acknowledgement referring to a msg with a seqnum that is not in our sent list: %.2X\n", + CELLIAX_P_LOG, seqnum); + break; + } + } + UNLOCKA(&p->fbus2_outgoing_list_lock); + POPPA_UNLOCKA(&p->fbus2_outgoing_list_lock); + return 0; +} + +/*! + * \brief Sends an FBUS2 message or resends it if it was not acknowledged + * \param p celliax_pvt + * + * Called by celliax_serial_read_FBUS2, browse the fbus2_outgoing_list looking for FBUS2 messages to be sent, + * or for FBUS2 messages previously sent but not yet acknoledged. + * (if an outgoing FBUS2 message is not aknowledged by the cellphone in a while, + * it will be retransmitted) + * + * \return 0 on error, 1 otherwise + */ +int celliax_serial_send_if_time_FBUS2(struct celliax_pvt *p) +{ + struct fbus2_msg *ptr; + struct timeval tv; + struct timezone tz; + + gettimeofday(&tv, &tz); + ptr = p->fbus2_outgoing_list; + if (ptr == NULL) { + ERRORA("fbus2_outgoing_list is NULL ?\n", CELLIAX_P_LOG); + return -1; + } + while (ptr->next != NULL) { + WARNINGA("fbus2_outgoing_list->next is not null ?\n", CELLIAX_P_LOG); + ptr = ptr->next; //FIXME what to do? + } + while (ptr->sent == 0 && ptr->acknowledged == 0) { + if (ptr->previous != NULL) { + ptr = ptr->previous; + } else + break; + } + while (ptr->sent == 1 && ptr->acknowledged == 0) { + if (ptr->previous != NULL) { + ptr = ptr->previous; + } else + break; + } + if (ptr->sent == 1 && ptr->acknowledged == 1) { + if (ptr->next != NULL) { + ptr = ptr->next; + } + } + if (ptr->sent == 1 && ptr->acknowledged == 0 && ptr->msg > 0) { + if ((tv.tv_sec * 1000 + tv.tv_usec / 1000) > + ((ptr->tv_sec * 1000 + ptr->tv_usec / 1000) + 1000)) { + + PUSHA_UNLOCKA(&p->fbus2_outgoing_list_lock); + LOKKA(&p->fbus2_outgoing_list_lock); + + if (ptr->sent == 1 && ptr->acknowledged == 0 && ptr->msg > 0) { //retest, maybe has been changed? + if ((tv.tv_sec * 1000 + tv.tv_usec / 1000) > ((ptr->tv_sec * 1000 + ptr->tv_usec / 1000) + 1000)) { //retest, maybe has been changed? + + if (option_debug > 1) + DEBUGA_FBUS2("RESEND %.2X, passed %ld ms, sent %d times\n", CELLIAX_P_LOG, + ptr->seqnum, + ((tv.tv_sec * 1000 + tv.tv_usec / 1000) - + (ptr->tv_sec * 1000 + ptr->tv_usec / 1000)), + ptr->how_many_sent); + if (ptr->how_many_sent > 9) { + ERRORA("RESEND %.2X, passed %ld ms, sent %d times\n", CELLIAX_P_LOG, + ptr->seqnum, + ((tv.tv_sec * 1000 + tv.tv_usec / 1000) - + (ptr->tv_sec * 1000 + ptr->tv_usec / 1000)), ptr->how_many_sent); + + UNLOCKA(&p->fbus2_outgoing_list_lock); + return -1; + } + + celliax_serial_send_FBUS2(p, ptr->len, ptr->buffer); + if (ptr->buffer[3] == FBUS2_ACK_BYTE) { + if (option_debug > 1) + DEBUGA_FBUS2("RESEND ACK, passed %ld ms, sent %d times\n", CELLIAX_P_LOG, + ((tv.tv_sec * 1000 + tv.tv_usec / 1000) - + (ptr->tv_sec * 1000 + ptr->tv_usec / 1000)), + ptr->how_many_sent); + ptr->acknowledged = 1; + ptr->msg = FBUS2_OUTGOING_ACK; + } + ptr->tv_sec = tv.tv_sec; + ptr->tv_usec = tv.tv_usec; + ptr->sent = 1; + ptr->how_many_sent++; + if (option_debug > 1) { + DEBUGA_FBUS2("OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_FBUS2(p, p->fbus2_outgoing_list); + DEBUGA_FBUS2("OUTGOING list END\n", CELLIAX_P_LOG); + } + + } + } + + UNLOCKA(&p->fbus2_outgoing_list_lock); + POPPA_UNLOCKA(&p->fbus2_outgoing_list_lock); + } + } + if (ptr->sent == 0 && ptr->acknowledged == 0 && ptr->msg > 0) { + + PUSHA_UNLOCKA(&p->fbus2_outgoing_list_lock); + LOKKA(&p->fbus2_outgoing_list_lock); + + if (ptr->sent == 0 && ptr->acknowledged == 0 && ptr->msg > 0) { //retest, maybe has been changed? + + if (option_debug > 1) + DEBUGA_FBUS2("SENDING 1st TIME %.2X\n", CELLIAX_P_LOG, ptr->seqnum); + celliax_serial_send_FBUS2(p, ptr->len, ptr->buffer); + if (ptr->buffer[3] == FBUS2_ACK_BYTE) { + if (option_debug > 1) + DEBUGA_FBUS2("SENDING 1st TIME ACK\n", CELLIAX_P_LOG); + ptr->acknowledged = 1; + ptr->msg = FBUS2_OUTGOING_ACK; + } + ptr->tv_sec = tv.tv_sec; + ptr->tv_usec = tv.tv_usec; + ptr->sent = 1; + ptr->how_many_sent++; + if (option_debug > 1) { + DEBUGA_FBUS2("OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_FBUS2(p, p->fbus2_outgoing_list); + DEBUGA_FBUS2("OUTGOING list END\n", CELLIAX_P_LOG); + } + + } + + UNLOCKA(&p->fbus2_outgoing_list_lock); + POPPA_UNLOCKA(&p->fbus2_outgoing_list_lock); + + } + return 0; +} + +int celliax_serial_write_FBUS2(struct celliax_pvt *p, unsigned char *MsgBuffer, + int MsgLength, unsigned char MsgType) +{ + unsigned char buffer2[FBUS2_MAX_TRANSMIT_LENGTH + 10]; + unsigned char checksum = 0; + int i, len; + struct timeval tv; + struct timezone tz; + + buffer2[0] = FBUS2_SERIAL_FRAME_ID; + buffer2[1] = FBUS2_DEVICE_PHONE; /* destination */ + buffer2[2] = FBUS2_DEVICE_PC; /* source */ + buffer2[3] = MsgType; + buffer2[4] = 0x00; /* required by protocol */ + buffer2[5] = MsgLength; + + memcpy(buffer2 + 6, MsgBuffer, MsgLength); + len = MsgLength + 6; + + /* Odd messages require additional padding 0x00 byte */ + if (MsgLength % 2) + buffer2[len++] = 0x00; /* optional PaddingByte */ + + checksum = 0; + for (i = 0; i < len; i += 2) + checksum ^= buffer2[i]; + buffer2[len++] = checksum; /* ChkSum1 */ + + checksum = 0; + for (i = 1; i < len; i += 2) + checksum ^= buffer2[i]; + buffer2[len++] = checksum; /* ChkSum2 */ + + if (option_debug > 10) { + int i; + char debug_buf[1024]; + char *debug_buf_pos; + + memset(debug_buf, 0, 1024); + debug_buf_pos = debug_buf; + + for (i = 0; i < len; i++) { + debug_buf_pos += sprintf(debug_buf_pos, "[%.2X] ", buffer2[i]); + if (debug_buf_pos > (char *) (&debug_buf + 1000)) + break; + } + if (buffer2[3] == FBUS2_ACK_BYTE) { + DEBUGA_FBUS2("%s to be written, ACK\n", CELLIAX_P_LOG, debug_buf); + } else { + DEBUGA_FBUS2("%s to be written\n", CELLIAX_P_LOG, debug_buf); + } + } + + gettimeofday(&tv, &tz); + + if (buffer2[3] != FBUS2_ACK_BYTE) { + p->fbus2_outgoing_list = celliax_serial_list_init_FBUS2(p); + p->fbus2_outgoing_list->msg = 11; + + p->fbus2_outgoing_list->len = len; + for (i = 0; i < len; i++) { + p->fbus2_outgoing_list->buffer[i] = buffer2[i]; + } + p->fbus2_outgoing_list->seqnum = MsgBuffer[MsgLength - 1]; + if (option_debug > 1) { + DEBUGA_FBUS2("OUTGOING LIST seqnum is %2.X\n", CELLIAX_P_LOG, + MsgBuffer[MsgLength - 1]); + + DEBUGA_FBUS2("OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_FBUS2(p, p->fbus2_outgoing_list); + DEBUGA_FBUS2("OUTGOING list END\n", CELLIAX_P_LOG); + } + } else { + usleep(100); + celliax_serial_send_FBUS2(p, len, buffer2); + } + + return 0; +} + +int celliax_serial_send_ack_FBUS2(struct celliax_pvt *p, unsigned char MsgType, + unsigned char MsgSequence) +{ + unsigned char buffer2[2]; + + buffer2[0] = MsgType; + buffer2[1] = (MsgSequence - FBUS2_SEQNUM_MIN); + + if (option_debug > 1) + DEBUGA_FBUS2("SENDING ACK to %2.X, seqack %2.X \n", CELLIAX_P_LOG, MsgSequence, + (MsgSequence - FBUS2_SEQNUM_MIN)); + /* Sending to phone */ + return celliax_serial_write_FBUS2(p, buffer2, 2, FBUS2_ACK_BYTE); +} + +struct fbus2_msg *celliax_serial_list_init_FBUS2(struct celliax_pvt *p) +{ + struct fbus2_msg *list; + list = p->fbus2_outgoing_list; + + PUSHA_UNLOCKA(&p->fbus2_outgoing_list_lock); + LOKKA(&p->fbus2_outgoing_list_lock); + if (list == NULL) { + list = malloc(sizeof(*(list))); + list->msg = 0; + list->seqnum = 0; + list->len = 0; + list->acknowledged = 0; + list->how_many_sent = 0; + list->sent = 0; + list->tv_sec = 0; + list->tv_usec = 0; + list->next = NULL; + list->previous = NULL; + } + if (list->msg != 0) { + struct fbus2_msg *new; + new = malloc(sizeof(*new)); + new->msg = 0; + new->seqnum = 0; + new->len = 0; + new->acknowledged = 0; + new->how_many_sent = 0; + new->sent = 0; + new->tv_sec = 0; + new->tv_usec = 0; + new->next = NULL; + new->previous = list; + list->next = new; + list = new; + } + UNLOCKA(&p->fbus2_outgoing_list_lock); + POPPA_UNLOCKA(&p->fbus2_outgoing_list_lock); + return list; +} + +int celliax_serial_list_print_FBUS2(struct celliax_pvt *p, struct fbus2_msg *list) +{ + struct fbus2_msg *ptr; + ptr = list; + while (ptr) { + if (option_debug > 3) + DEBUGA_FBUS2 + ("PTR msg is: %d, seqnum is %.2X, tv_sec is %d, tv_usec is %d, acknowledged is: %d," + " sent is:%d, how_many_sent is: %d\n", CELLIAX_P_LOG, ptr->msg, ptr->seqnum, + ptr->tv_sec, ptr->tv_usec, ptr->acknowledged, ptr->sent, ptr->how_many_sent); + ptr = ptr->previous; + } + return 0; +} + +int celliax_serial_read_FBUS2(struct celliax_pvt *p) +{ + int read_count; + int select_err; + fd_set read_fds; + struct timeval timeout; + int fbus_mesg = 0; + int i; + + FD_ZERO(&read_fds); + FD_SET(p->controldevfd, &read_fds); + timeout.tv_sec = 0; + timeout.tv_usec = 50000; + + if ((select_err = select(p->controldevfd + 1, &read_fds, NULL, NULL, &timeout)) > 0) { + timeout.tv_sec = 0; //reset the timeout, linux modify it + timeout.tv_usec = 50000; //reset the timeout, linux modify it + PUSHA_UNLOCKA(&p->controldev_lock); + LOKKA(&p->controldev_lock); + while ((select_err = + select(p->controldevfd + 1, &read_fds, NULL, NULL, &timeout)) > 0) { + gettimeofday(&p->fbus2_list_tv, &p->fbus2_list_tz); + read_count = read(p->controldevfd, p->rxm, 255); + + if (read_count == 0) { + ERRORA + ("read 0 bytes!!! Nenormalno! Marking this celliax_serial_device %s as dead, andif it is owned by a channel, hanging up. Maybe the phone is stuck, switched off, power down or battery exhausted\n", + CELLIAX_P_LOG, p->controldevice_name); + p->controldev_dead = 1; + close(p->controldevfd); + UNLOCKA(&p->controldev_lock); + if (p->owner) { + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + p->owner->hangupcause = AST_CAUSE_FAILURE; + } + return -1; + } + if (option_debug > 10) { + int c; + char debug_buf[1024]; + char *debug_buf_pos; + + memset(debug_buf, 0, 1024); + debug_buf_pos = debug_buf; + for (c = 0; c < read_count; c++) { + debug_buf_pos += sprintf(debug_buf_pos, "[%.2X] ", p->rxm[c]); + if (debug_buf_pos > (char *) (&debug_buf + 1000)) + break; + } + DEBUGA_FBUS2("%s READ AT seconds=%ld usec=%6ld read_count=%d\n", CELLIAX_P_LOG, + debug_buf, p->fbus2_list_tv.tv_sec, p->fbus2_list_tv.tv_usec, + read_count); + } + + for (i = 0; i < read_count; i++) { + if (p->rxm[i] == FBUS2_DEVICE_PHONE && p->rxm[i - 1] == FBUS2_DEVICE_PC + && p->rxm[i - 2] == FBUS2_SERIAL_FRAME_ID) { + /* if we have identified the start of an fbus2 frame sent to us by the phone */ + /* clean the array, copy into it the beginning of the frame, move the counter in the array after the last byte copied */ + memset(p->array, 0, 255); + p->array[0] = FBUS2_SERIAL_FRAME_ID; + p->array[1] = FBUS2_DEVICE_PC; + p->arraycounter = 2; + } + if (p->rxm[i] == FBUS2_SERIAL_FRAME_ID && read_count == 1) { /* quick hack to try to identify the lone char + at the beginning a frame, often returned by + ark3116 based datacables */ + /* if we have identified the start of an fbus2 frame sent to us by the phone */ + /* clean the array, copy into it the beginning of the frame, move the counter in the array after the last byte copied */ + memset(p->array, 0, 255); + p->arraycounter = 0; + } + + /* continue copying into the array, until... */ + p->array[p->arraycounter] = p->rxm[i]; + /* we reach the end of the incoming frame, its lenght is in the p->array[5] byte, plus overhead */ + if (p->arraycounter == p->array[5] + 7) { + /* start categorizing frames */ + int seqnum; + int known = 0; + + /* ACK frames are always of lenght 10, without padding */ + seqnum = p->array[p->arraycounter - 2]; + /* first step in categorizing frames, look at the general kind of frame, in p->array[3] */ + switch (p->array[3]) { +/****************************************************************/ + case FBUS2_ACK_BYTE: + /* this is an ACKnowledgement frame sent to us in reply to an item we sent, take note we were ACKnowledged, no need to resend the item */ + if (option_debug > 1) + DEBUGA_FBUS2("INCOMING ACK, seqack %.2X \n", CELLIAX_P_LOG, seqnum); + if (seqnum == 0x80) { /* reset */ + seqnum = 0x00; + DEBUGA_FBUS2 + ("seqack was 0x80, interpreting as 0x00, first acknowledgement (session begin?) of our first sent item 0x40\n", + CELLIAX_P_LOG); + } + /* an ACK frame has the same seqnum as the item it acknowledge, minus 0x40, so here we obtain the seqnum of the item that has been ACKnowledged */ + fbus_mesg = seqnum + FBUS2_SEQNUM_MIN; + /* take note that the item sent was ACKnowledged, so no need to resend it */ + celliax_serial_list_acknowledge_FBUS2(p, fbus_mesg); + /* this frame has been categorized, bail out from the loop */ + known = 1; + break; +/****************************************************************/ + case FBUS2_TYPE_CALL_DIVERT: + if (option_debug > 1) + DEBUGA_FBUS2("CALL DIVERT SIGNALING seqnum %.2X \n", CELLIAX_P_LOG, seqnum); + fbus_mesg = FBUS2_TYPE_CALL_DIVERT; + /* this signal us that we have some settings in line divert, let's use it as activation of the line when we call */ + if (p->interface_state == AST_STATE_DIALING) { + p->interface_state = AST_STATE_UP; + p->phone_callflow = CALLFLOW_CALL_ACTIVE; + ast_setstate(p->owner, AST_STATE_RINGING); + celliax_queue_control(p->owner, AST_CONTROL_ANSWER); + if (option_debug) + DEBUGA_FBUS2 + ("call is active, I know it's not yet true, but 3310 do not give us remote answer signaling\n", + CELLIAX_P_LOG); + } + /* this frame has been categorized, bail out from the loop */ + known = 1; + break; + +/****************************************************************/ + /* this kind of frames is an answer to "ask model" actions */ + case FBUS2_TYPE_MODEL_ANSWER: + if (1) { + int newline = 0; + int c = i = 0; + unsigned char model[10]; + for (i = 10; i < p->arraycounter; i++) { + if (p->array[i] == '\n') + newline++; + if (newline == 2) { + if (p->array[i] != '\n') { + model[c] = p->array[i]; + c++; + } + } + if (newline == 3) { + break; + } + if (c == 9) + break; + } + model[c] = '\0'; + DEBUGA_FBUS2("FBUS2 PHONE MODEL is: %s, inseqnum %.2X \n", CELLIAX_P_LOG, + model, seqnum); + } + known = 1; + fbus_mesg = FBUS2_TYPE_MODEL_ANSWER; + break; +/****************************************************************/ + /* this kind of frames is an answer to "security enabled" actions */ + case FBUS2_TYPE_SECURITY: + switch (p->array[8]) { + /* this subkind of frames is an answer to "security enabled" CALL actions */ + case FBUS2_SECURIY_CALL_COMMANDS: + switch (p->array[9]) { + /* this sub-subkind of frames tell us that we answered the call */ + case FBUS2_SECURIY_CALL_COMMAND_ANSWER: + p->interface_state = AST_STATE_UP; + p->phone_callflow = CALLFLOW_CALL_ACTIVE; + + /* set the channel state to UP, we've answered */ + if (ast_setstate(p->owner, AST_STATE_UP)) { + ERRORA("ast_setstate failed, BAD\n", CELLIAX_P_LOG); + } + + if (option_debug > 1) + DEBUGA_FBUS2("ANSWERED CALL, inseqnum %.2X \n", CELLIAX_P_LOG, seqnum); + known = 1; + break; + /* this sub-subkind of frames tell us that we released the call */ + case FBUS2_SECURIY_CALL_COMMAND_RELEASE: + p->interface_state = AST_STATE_DOWN; + p->phone_callflow = CALLFLOW_CALL_IDLE; + if (option_debug > 1) + DEBUGA_FBUS2("RELEASED CALL, inseqnum %.2X \n", CELLIAX_P_LOG, seqnum); + fbus_mesg = CALLFLOW_CALL_RELEASED; + known = 1; + break; + } + break; + /* this subkind of frames is an answer to "enable security commands" action */ + case FBUS2_SECURIY_EXTENDED_COMMANDS: + if (option_debug > 1) + DEBUGA_FBUS2("SECURITY EXTENDED COMMANDS ON, inseqnum %.2X \n", + CELLIAX_P_LOG, seqnum); + fbus_mesg = FBUS2_SECURIY_EXTENDED_COMMAND_ON; + known = 1; + break; + /* this subkind of frames is an answer to "get IMEI" action */ + case FBUS2_SECURIY_IMEI_COMMANDS: + if (option_debug > 1) + DEBUGA_FBUS2("CALLFLOW_GOT_IMEI, inseqnum %.2X \n", CELLIAX_P_LOG, + seqnum); + fbus_mesg = CALLFLOW_GOT_IMEI; + known = 1; + break; + } + break; +/****************************************************************/ + /* this kind of frames is about SMSs */ + case FBUS2_TYPE_SMS: + switch (p->array[9]) { + /* this subkind of frames is about an INCOMING SMS */ + case FBUS2_SMS_INCOMING: + if (option_debug > 1) + DEBUGA_FBUS2("SMS, inseqnum %.2X \n", CELLIAX_P_LOG, seqnum); + known = 1; + break; + } + break; +/****************************************************************/ + /* this kind of frames is about PHONE CALLs */ + case FBUS2_TYPE_CALL: + switch (p->array[9]) { + int a; + /* this subkind of frame is about the CALL has been HUNGUP */ + case FBUS2_CALL_HANGUP: + p->interface_state = AST_STATE_DOWN; + p->phone_callflow = CALLFLOW_CALL_IDLE; + if (option_debug > 1) + DEBUGA_FBUS2("REMOTE PARTY HANG UP, inseqnum %.2X \n", CELLIAX_P_LOG, + seqnum); + fbus_mesg = CALLFLOW_INCOMING_HANGUP; + known = 1; + break; + /* this subkind of frame is about the remote CALLID (not signaled by 3310) */ + case FBUS2_CALL_CALLID: + if (option_debug > 1) + DEBUGA_FBUS2("CALLID, inseqnum %.2X \n", CELLIAX_P_LOG, seqnum); + memset(p->callid_name, 0, sizeof(p->callid_name)); + memset(p->callid_number, 0, sizeof(p->callid_number)); + for (a = 0; a < p->array[12]; a++) { + p->callid_number[a] = p->array[12 + a + 1]; + } + for (a = 0; a < p->array[12 + 1 + p->array[12]] + 1; a++) { + p->callid_name[a] = p->array[12 + 1 + a + p->array[12] + 1]; + } + if (option_debug > 1) + DEBUGA_FBUS2("CALLFLOW_INCOMING_CALLID: name is %s, number is %s\n", + CELLIAX_P_LOG, + p->callid_name[0] != 1 ? p->callid_name : "not available", + p->callid_number[0] ? p->callid_number : "not available"); + fbus_mesg = CALLFLOW_INCOMING_CALLID; + p->phone_callflow = CALLFLOW_INCOMING_RING; + p->interface_state = AST_STATE_RING; + known = 1; + break; + } + break; +/****************************************************************/ + /* this kind of frames is about NETWORK STATUS */ + case FBUS2_TYPE_NETWORK_STATUS: + switch (p->array[9]) { + /* this subkind of frames is NETWORK STATUS REGISTERED */ + case FBUS2_NETWORK_STATUS_REGISTERED: + if (option_debug > 1) + DEBUGA_FBUS2("NETWORK STATUS REGISTERED, inseqnum %.2X \n", CELLIAX_P_LOG, + seqnum); + if (p->callid_name[0] == 0 && p->owner + && p->interface_state != AST_STATE_DOWN) { + p->interface_state = AST_STATE_DOWN; + p->phone_callflow = CALLFLOW_CALL_IDLE; + if (option_debug) + NOTICA("We think we are using a nokia3310, so NETWORK STATUS REGISTERED" + " is interpreted as REMOTE PARTY HANG UP during a call, because" + " Nokia 3310 give no hint about remote hangup. Nokia 3310" + " does not signal the CALLID, while other nokias at least put" + " callid_name[0]=1 (also if no callid was transmitted by remote" + " party), we use this lack of CALLID as a sign of 3310nness." + " Outside a call, or when CALLID has been signaled, NETWORK STATUS" + " REGISTERED is ignored.\n", CELLIAX_P_LOG); + fbus_mesg = CALLFLOW_INCOMING_HANGUP; + } + known = 1; + break; + } + break; +/****************************************************************/ + /* this kind of frames is about CALL STATUS */ + case FBUS2_TYPE_CALL_STATUS: + switch (p->array[12]) { + /* this subkind of frames is about CALL STATUS OFF */ + case FBUS2_CALL_STATUS_OFF: + p->interface_state = AST_STATE_DOWN; + p->phone_callflow = CALLFLOW_CALL_IDLE; + if (option_debug > 1) + DEBUGA_FBUS2("STATUS call in progress OFF, inseqnum %.2X \n", + CELLIAX_P_LOG, seqnum); + fbus_mesg = CALLFLOW_INCOMING_HANGUP; + known = 1; + break; + /* this subkind of frames is about CALL STATUS ON */ + case FBUS2_CALL_STATUS_ON: + if (option_debug > 1) + DEBUGA_FBUS2("STATUS call in progress ON, inseqnum %.2X \n", + CELLIAX_P_LOG, seqnum); + known = 1; + break; + } +/****************************************************************/ + break; + } + + /* categorization of frame is ended, if it has not been recognized, whine */ + if (!known) { + WARNINGA("FBUS2 MSG UNKNOWN, inseqnum %.2X\n", CELLIAX_P_LOG, seqnum); + } + + /* let's print our frame */ + if (option_debug > 1) { + int i; + char debug_buf[1024]; + char *debug_buf_pos; + + memset(debug_buf, 0, 1024); + debug_buf_pos = debug_buf; + for (i = 0; i < p->arraycounter + 1; i++) { + debug_buf_pos += sprintf(debug_buf_pos, "[%.2X] ", p->array[i]); + if (debug_buf_pos > (char *) (&debug_buf + 1000)) + break; + } + DEBUGA_FBUS2("%s is the RECEIVED FRAME inseqnum %.2X\n", CELLIAX_P_LOG, + debug_buf, seqnum); + } + + /* if the frame we received is not an ACK frame, let's ACKnowledge it */ + if (p->array[0] == FBUS2_SERIAL_FRAME_ID && p->array[3] != FBUS2_ACK_BYTE) { + celliax_serial_send_ack_FBUS2(p, p->array[3], seqnum); + } + } + p->arraycounter++; + } + } + UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + } + /* oooops, select returned error, got a kill/cancel or problems with the serial file descriptor */ + if (select_err == -1) { + if (errno != EINTR) { + ERRORA + ("select returned -1 on %s, marking controldev as dead, errno was: %d, error was: %s\n", + CELLIAX_P_LOG, p->controldevice_name, errno, strerror(errno)); + p->controldev_dead = 1; + close(p->controldevfd); + if (p->owner) + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + return -1; + } else { + WARNINGA("select returned -1 on %s, errno was: %d, EINTR, error was: %s\n", + CELLIAX_P_LOG, p->controldevice_name, errno, strerror(errno)); + return 0; + } + } + /* OK, reading done, let's browse the list of pending frames to be sent, and act on it */ + if (celliax_serial_send_if_time_FBUS2(p)) { + ERRORA("celliax_serial_send_if_time_FBUS2 failed!\n", CELLIAX_P_LOG); + return -1; + } + + if (fbus_mesg == CALLFLOW_INCOMING_HANGUP) { + if (p->owner) { + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + DEBUGA_FBUS2("phone call ended\n", CELLIAX_P_LOG); + } + } + + return fbus_mesg; //FIXME breaks the convention of returning 0 on success +} + +#endif /* CELLIAX_FBUS2 */ + +#ifdef CELLIAX_CVM + +int celliax_serial_sync_CVM_BUSMAIL(struct celliax_pvt *p) +{ + usleep(1000); /* 1msec */ + time(&p->celliax_serial_synced_timestamp); + return 0; +} + +int celliax_serial_answer_CVM_BUSMAIL(struct celliax_pvt *p) +{ + if (AST_STATE_RING == p->interface_state) { + DEBUGA_CVM("Sending commands to answer an incomming call...\n", CELLIAX_P_LOG); + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_CONNECT_REQ, 0, NULL); + + } else { + DEBUGA_CVM + ("SKIPPING Sending commands to answer an incomming call, because: !AST_STATE_RING\n", + CELLIAX_P_LOG); + } + + return 0; +} + +int celliax_serial_call_CVM_BUSMAIL(struct celliax_pvt *p, char *dstr) +{ + unsigned char bCallType = 0x01; /* INTERNAL */ + + unsigned char DialReqBuff[2]; + + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_SETUP_REQ, sizeof(bCallType), + &bCallType); + + while (AST_STATE_DOWN == p->interface_state) { + usleep(10000); //10msec + } + + if (AST_STATE_DIALING == p->interface_state) { + /* as for now, we only support internal calls */ + /* "0" - call speaker phone */ + /* "1" - call handset #1 */ + /* "2" - call handset #2 */ + /* ... */ + + DialReqBuff[0] = 1; /* number of digits to send */ + DialReqBuff[1] = dstr[0]; /* digit to send */ + + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_KEYPAD_REQ, 2, DialReqBuff); + } + + if (option_debug) + NOTICA("CVM_BUSMAIL: sent commands to call\n", CELLIAX_P_LOG); + return 0; +} + +int celliax_serial_hangup_CVM_BUSMAIL(struct celliax_pvt *p) +{ + unsigned char bReason = 0x0; /* Normal hang-up */ + + if (p->interface_state != AST_STATE_DOWN) { + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_RELEASE_REQ, sizeof(bReason), + &bReason); + + DEBUGA_CVM("CVM_BUSMAIL: sent commands to hangup the call\n", CELLIAX_P_LOG); + + } else { + DEBUGA_CVM("CVM_BUSMAIL: sent commands to hangup skipped because: AST_STATE_DOWN\n", + CELLIAX_P_LOG); + } + + return 0; +} + +int celliax_serial_config_CVM_BUSMAIL(struct celliax_pvt *p) +{ + int res; + int how_many_reads = 0; + unsigned char SubcriptionNo = p->cvm_subsc_no; + unsigned char RegistartionData[5]; + + p->cvm_lock_state = CVM_UNKNOWN_LOCK_STATE; + p->cvm_register_state = CVM_UNKNOWN_REGISTER_STATE; + + PUSHA_UNLOCKA(&p->controldev_lock); + CVM_LOKKA(&p->controldev_lock); + + if (option_debug > 1) + DEBUGA_CVM("Try to init communication with CVM...\n", CELLIAX_P_LOG); + + /* CVM after reset sends SABM CTRL frame, let's assume that CVM already sent it, that's the reply... */ + celliax_serial_send_ctrl_frame_CVM_BUSMAIL(p, + BUSMAIL_HEADER_CTRL_FRAME | + BUSMAIL_HEADER_CTRL_UN_FRAME | + BUSMAIL_HEADER_UNID_SABM); + /* usleep(10000); *//* 10ms */ + + /* Now we are sending SABM CTRL frame, if CVM is out there, it should reply... */ + celliax_serial_send_ctrl_frame_CVM_BUSMAIL(p, + BUSMAIL_HEADER_CTRL_FRAME | + BUSMAIL_HEADER_CTRL_UN_FRAME | + BUSMAIL_HEADER_UNID_SABM | + (BUSMAIL_HEADER_PF_BIT_MASK & 0xFF)); +// usleep(1000); + + res = celliax_serial_read_CVM_BUSMAIL(p); //we don't have no monitor neither do_controldev_thread + + DEBUGA_CVM("celliax_serial_read_CVM_BUSMAIL res= %X, expected %X\n", CELLIAX_P_LOG, res, + (BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_UN_FRAME | + BUSMAIL_HEADER_SABM)); + + if (res == -1) { + ERRORA("failed celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + + how_many_reads = 0; + + while ((res & 0xF0) != + (BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_UN_FRAME | BUSMAIL_HEADER_SABM)) + { + + usleep(1000); + res = celliax_serial_read_CVM_BUSMAIL(p); + how_many_reads++; + + if (res == -1) { + ERRORA("failed celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + + if (how_many_reads > 10) { + ERRORA("no expected results in %d celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG, + how_many_reads); + + ERRORA("Unable to initialize cmmunication with CVM...\n", CELLIAX_P_LOG); + + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + } + + DEBUGA_CVM("Communication with CVM initialized successfully...\n", CELLIAX_P_LOG); + + DEBUGA_CVM("Attempt to lock to FP...\n", CELLIAX_P_LOG); + + /* Try to connect to FP, try to lock to FP, maybe we registered with it in the past... */ + /* CVM can hold up to 2 subscriptions in its EEPROM, celliax.conf contains number we should try */ + /* eg. cvm_subscription_no = 1 */ + + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_LOCK_REQ, sizeof(SubcriptionNo), + &SubcriptionNo); + + usleep(10000); + + res = celliax_serial_read_CVM_BUSMAIL(p); //we don't have no monitor neither do_controldev_thread + + if (res == -1) { + ERRORA("failed celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + + how_many_reads = 0; + + while (CVM_UNKNOWN_LOCK_STATE == p->cvm_lock_state) { + +/* + if (0 == (how_many_reads % 10)) + { + DEBUGA_CVM("Attempt to lock to FP... %d\n", CELLIAX_P_LOG, how_many_reads/10 ); + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_LOCK_REQ, sizeof(SubcriptionNo) ,&SubcriptionNo); + } +*/ + + usleep(100000); + + res = celliax_serial_read_CVM_BUSMAIL(p); + how_many_reads++; + + if (res == -1) { + ERRORA("failed celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + + if (how_many_reads > 50) { + ERRORA("no expected results in %d celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG, + how_many_reads); + + ERRORA("Unable to lock to FP...\n", CELLIAX_P_LOG); + break; + } + } + + if (CVM_LOCKED_TO_FP == p->cvm_lock_state) { + DEBUGA_CVM("CVM locked to FP successfully...\n", CELLIAX_P_LOG); + } else { + DEBUGA_CVM("Lock to FP failed, Attempt to register to FP...\n", CELLIAX_P_LOG); + + RegistartionData[0] = SubcriptionNo; + RegistartionData[1] = 0xFF; + RegistartionData[2] = 0xFF; + + if (1 == SubcriptionNo) { + RegistartionData[3] = + (((p->cvm_subsc_1_pin[3] - 0x30) & 0x0F) << 4) | ((p->cvm_subsc_1_pin[2] - + 0x30) & 0x0F); + RegistartionData[4] = + (((p->cvm_subsc_1_pin[1] - 0x30) & 0x0F) << 4) | ((p->cvm_subsc_1_pin[0] - + 0x30) & 0x0F); + } else { + RegistartionData[3] = + (((p->cvm_subsc_2_pin[3] - 0x30) & 0x0F) << 4) | ((p->cvm_subsc_2_pin[2] - + 0x30) & 0x0F); + RegistartionData[4] = + (((p->cvm_subsc_2_pin[1] - 0x30) & 0x0F) << 4) | ((p->cvm_subsc_2_pin[0] - + 0x30) & 0x0F); + } + + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_ACCESS_RIGHTS_REQ, + sizeof(RegistartionData), + RegistartionData); + + usleep(100000); + + res = celliax_serial_read_CVM_BUSMAIL(p); //we don't have no monitor neither do_controldev_thread + + if (res == -1) { + ERRORA("failed celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + + how_many_reads = 0; + + while (CVM_UNKNOWN_REGISTER_STATE == p->cvm_register_state) { + + if (0 == (how_many_reads % 50)) { + DEBUGA_CVM("Attempt to register to FP... %d\n", CELLIAX_P_LOG, + how_many_reads / 10); + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_ACCESS_RIGHTS_REQ, + sizeof(RegistartionData), + RegistartionData); + } + + /* up to 5 minutes for registration.... */ + usleep(1000000); + res = celliax_serial_read_CVM_BUSMAIL(p); + how_many_reads++; + + if (res == -1) { + ERRORA("failed celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + + if (how_many_reads > 300) { + ERRORA("no expected results in %d celliax_serial_read_CVM_BUSMAIL\n", + CELLIAX_P_LOG, how_many_reads); + + ERRORA("Unable to communication with CVM...\n", CELLIAX_P_LOG); + + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + } + + if (CVM_REGISTERED_TO_FP != p->cvm_register_state) { + ERRORA("Unable to register to FP...\n", CELLIAX_P_LOG); + + CVM_UNLOCKA(&p->controldev_lock); + return -1; + + } else { + DEBUGA_CVM("CVM registered to FP successfully...\n", CELLIAX_P_LOG); + DEBUGA_CVM("Attempt to lock to FP...\n", CELLIAX_P_LOG); + + /* Try to connect to FP, try to lock to FP, maybe we registered with it in the past... */ + /* CVM can hold up to 2 subscriptions in its EEPROM, celliax.conf contains number we should try */ + /* eg. cvm_subscription_no = 1 */ + + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_LOCK_REQ, + sizeof(SubcriptionNo), &SubcriptionNo); + + usleep(10000); + + res = celliax_serial_read_CVM_BUSMAIL(p); //we don't have no monitor neither do_controldev_thread + + if (res == -1) { + ERRORA("failed celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + + how_many_reads = 0; + + while (CVM_UNKNOWN_LOCK_STATE == p->cvm_lock_state) { + + if (0 == (how_many_reads % 10)) { + DEBUGA_CVM("Attempt to lock to FP... %d\n", CELLIAX_P_LOG, how_many_reads / 10); + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_ACCESS_RIGHTS_REQ, + sizeof(RegistartionData), + RegistartionData); + } + + usleep(10000); + res = celliax_serial_read_CVM_BUSMAIL(p); + how_many_reads++; + + if (res == -1) { + ERRORA("failed celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + + if (how_many_reads > 100) { + ERRORA("no expected results in %d celliax_serial_read_CVM_BUSMAIL\n", + CELLIAX_P_LOG, how_many_reads); + + ERRORA("Unable to communication with CVM...\n", CELLIAX_P_LOG); + + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + } + + if (CVM_LOCKED_TO_FP != p->cvm_lock_state) { + ERRORA("Unable to lock to FP...\n", CELLIAX_P_LOG); + + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } else { + DEBUGA_CVM("CVM locked to FP successfully...\n", CELLIAX_P_LOG); + } + } + } + + usleep(100000); + + CVM_UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + return 0; + +} + +int celliax_serial_read_CVM_BUSMAIL(struct celliax_pvt *p) +{ + int read_count; + int select_err; + fd_set read_fds; + struct timeval timeout; + int cvm_busmail_mesg = 0; + unsigned char busmail_crc = 0; + unsigned char MsgCrc = 0; + unsigned char MsgHeader = 0; + unsigned char MsgTxSeqNo = 0; + unsigned char MsgRxSeqNo = 0; + unsigned char MsgTaskId = 0; + unsigned char MsgProgId = 0; + unsigned char MsgPrimitiveLSB = 0; + unsigned char MsgPrimitiveMSB = 0; + unsigned int MsgPrimitive = 0; + + int i = 0; + + FD_ZERO(&read_fds); + FD_SET(p->controldevfd, &read_fds); + timeout.tv_sec = 0; + timeout.tv_usec = 10000; + + if ((select_err = select(p->controldevfd + 1, &read_fds, NULL, NULL, &timeout)) > 0) { + timeout.tv_sec = 0; //reset the timeout, linux modify it + timeout.tv_usec = 10000; //reset the timeout, linux modify it + PUSHA_UNLOCKA(&p->controldev_lock); + CVM_LOKKA(&p->controldev_lock); + + while ((select_err = + select(p->controldevfd + 1, &read_fds, NULL, NULL, &timeout)) > 0) { + gettimeofday(&p->cvm_busmail_list_tv, &p->cvm_busmail_list_tz); + read_count = read(p->controldevfd, p->rxm, 255); + + if (read_count == 0) { + ERRORA + ("read 0 bytes!!! Nenormalno! Marking this celliax_serial_device %s as dead, andif it is owned by a channel, hanging up. Maybe the CVM is stuck, switched off or power down.\n", + CELLIAX_P_LOG, p->controldevice_name); + + p->controldev_dead = 1; + close(p->controldevfd); + CVM_UNLOCKA(&p->controldev_lock); + + if (p->owner) + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + return -1; + } + + if (option_debug > 10) { + char debug_buf[1024]; + char *debug_buf_pos; + + memset(debug_buf, 0, 1024); + debug_buf_pos = debug_buf; + for (i = 0; i < read_count; i++) { + debug_buf_pos += sprintf(debug_buf_pos, "[%.2X] ", p->rxm[i]); + if (debug_buf_pos > (char *) (&debug_buf + 1000)) + break; + } + + DEBUGA_CVM("%s READ AT seconds=%ld usec=%6ld read_count=%d\n", CELLIAX_P_LOG, + debug_buf, p->cvm_busmail_list_tv.tv_sec, + p->cvm_busmail_list_tv.tv_usec, read_count); + } + + for (i = 0; i < read_count; i++) { + if (p->rxm[i] == BUSMAIL_SOF) { + /* if we have identified the start of an busmail frame sent to us by the CVM */ + /* clean the array, copy into it the beginning of the frame, move the counter in the array after the last byte copied */ + memset(p->array, 0, 255); + p->array[0] = p->rxm[i]; + p->arraycounter = 1; + } + + /* buffer overload protection */ + if (255 == p->arraycounter) { + p->arraycounter = 1; + } + + /* continue copying into the array, until... */ + p->array[p->arraycounter - 1] = p->rxm[i]; + + /* we reach the end of the incoming frame, its lenght is in the p->array[BUSMAIL_OFFSET_LEN_LSB] byte, plus overhead */ + if (p->arraycounter == p->array[BUSMAIL_OFFSET_LEN_LSB] + 4) { + + tcflush(p->controldevfd, TCIFLUSH); /* PL2303HX bug? */ + /* start categorizing frames */ + + if (option_debug > 10) { + char debug_buf[1024]; + char *debug_buf_pos; + + memset(debug_buf, 0, 1024); + debug_buf_pos = debug_buf; + + for (i = 0; i < p->arraycounter; i++) { + debug_buf_pos += sprintf(debug_buf_pos, "[%.2X] ", p->array[i]); + if (debug_buf_pos > (char *) (&debug_buf + 1000)) + break; + } + + DEBUGA_CVM("%s was received, Starting to categorize this frame\n", + CELLIAX_P_LOG, debug_buf); + } + + int known = 0; + int j = 0; + + busmail_crc = 0; + MsgCrc = p->array[p->arraycounter - 1]; + + busmail_crc = (unsigned char) (p->array[BUSMAIL_OFFSET_HEADER] + busmail_crc); + + for (j = BUSMAIL_OFFSET_MAIL; j < (p->arraycounter - 1); j++) { + busmail_crc = (unsigned char) (p->array[j] + busmail_crc); + } + + if (busmail_crc != MsgCrc) { + WARNINGA("BUSMAIL MSG CRC FAILED!, MsgCrc %.2X, calcd %.2X, dropping frame\n", + CELLIAX_P_LOG, MsgCrc, busmail_crc); + } else { + /* first step in categorizing frames, look at the general kind of frame, in p->array[BUSMAIL_OFFSET_HEADER] */ + if (option_debug > 1) + DEBUGA_CVM("BUSMAIL MSG CRC, MsgCrc %.2X, calcd %.2X...\n", CELLIAX_P_LOG, + MsgCrc, busmail_crc); + + MsgHeader = p->array[BUSMAIL_OFFSET_HEADER]; + cvm_busmail_mesg = MsgHeader; + + switch (MsgHeader & BUSMAIL_HEADER_IC_BIT_MASK) { + case BUSMAIL_HEADER_INFO_FRAME: + /* analyzis of frame header */ + MsgTxSeqNo = ((MsgHeader & BUSMAIL_HEADER_TXSEQ_MASK) >> 4); + MsgRxSeqNo = ((MsgHeader & BUSMAIL_HEADER_RXSEQ_MASK)); + + if (option_debug > 1) + DEBUGA_CVM("BUSMAIL_HEADER_INFO_FRAME TxSeq %X, RxSeq %X\n", + CELLIAX_P_LOG, MsgTxSeqNo, MsgRxSeqNo); + + if (((p->busmail_rxseq_cvm_last + 1) & 0x7) != MsgTxSeqNo) { + /* some CVM frames are missing, TxSeq of this frame is higher then expected */ + /* reject, I expected p->busmail_rxseq_cvm_last + 1, resend it to me, please */ + + WARNINGA("CVM TxSeq %X, does not match expected value %X\n", + CELLIAX_P_LOG, MsgTxSeqNo, + (p->busmail_rxseq_cvm_last + 1) & 0x7); + +// celliax_serial_send_ctrl_frame_CVM_BUSMAIL(p, BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_SU_FRAME | BUSMAIL_HEADER_SUID_REJ); + + if (((p->busmail_rxseq_cvm_last) & 0x7) == MsgTxSeqNo) { + + WARNINGA + ("It looks like our ACK to this frame was MIA :), lets ACK the frame one more time...\n", + CELLIAX_P_LOG); + + /* if the frame we received informs us that other side is waiting for ACK, let's ACK it */ + /* even if it is unknown to us */ + if (p->array[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_PF_BIT_MASK) { + if (BUSMAIL_HEADER_SABM == + (p->array[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_SABM_MASK)) { + celliax_serial_send_ctrl_frame_CVM_BUSMAIL(p, (unsigned char) + (BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_UN_FRAME | BUSMAIL_HEADER_UNID_SABM)); + } else { + celliax_serial_send_ctrl_frame_CVM_BUSMAIL(p, (unsigned char) + (BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_SU_FRAME | BUSMAIL_HEADER_SUID_RR)); + } + } + } + + break; + } else { + /* we expected packet with this seq no. */ + /* CVM ACKed our frames with info frame */ + celliax_serial_list_acknowledge_CVM_BUSMAIL(p, MsgRxSeqNo); + + /* save it but limit it to 3 bits only (valid values: 0-7) */ + p->busmail_rxseq_cvm_last = MsgTxSeqNo; + p->busmail_rxseq_cvm_last &= 0x7; + + /* if the frame we received informs us that other side is waiting for ACK, let's ACK it */ + /* even if it is unknown to us */ + if (p->array[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_PF_BIT_MASK) { + if (BUSMAIL_HEADER_SABM == + (p->array[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_SABM_MASK)) { + celliax_serial_send_ctrl_frame_CVM_BUSMAIL(p, (unsigned char) + (BUSMAIL_HEADER_CTRL_FRAME + | + BUSMAIL_HEADER_CTRL_UN_FRAME + | + BUSMAIL_HEADER_UNID_SABM)); + } else { + celliax_serial_send_ctrl_frame_CVM_BUSMAIL(p, (unsigned char) + (BUSMAIL_HEADER_CTRL_FRAME + | + BUSMAIL_HEADER_CTRL_SU_FRAME + | + BUSMAIL_HEADER_SUID_RR)); + } + } + + } + + /* frame header OK, let's see what's inside mail field */ + MsgTaskId = p->array[BUSMAIL_OFFSET_MAIL_TASK_ID]; + MsgProgId = p->array[BUSMAIL_OFFSET_MAIL_PROGRAM_ID]; + MsgPrimitiveLSB = p->array[BUSMAIL_OFFSET_MAIL_PRIMITIVE_LSB]; + MsgPrimitiveMSB = p->array[BUSMAIL_OFFSET_MAIL_PRIMITIVE_MSB]; + MsgPrimitive = MsgPrimitiveMSB << 8 | MsgPrimitiveLSB; + + if (option_debug > 1) + DEBUGA_CVM + ("BUSMAIL_HEADER_INFO_FRAME ProgId %X, TaskId %X, Primitive %X %X\n", + CELLIAX_P_LOG, MsgProgId, MsgTaskId, MsgPrimitiveMSB, MsgPrimitiveLSB); + + switch (MsgPrimitive) { + + case API_PP_ACCESS_RIGHTS_REJ: + /* FP rejected our registration... */ + WARNINGA("API_PP_ACCESS_RIGHTS_REJ, FP rejected our registration...\n", + CELLIAX_P_LOG); + + p->cvm_register_state = CVM_UNREGISTERED_TO_FP; + p->cvm_lock_state = CVM_UNKNOWN_LOCK_STATE; + known = 1; + break; + + case API_PP_ACCESS_RIGHTS_CFM: + /* FP accepted our registration... */ + if (option_debug > 1) + DEBUGA_CVM + ("API_PP_ACCESS_RIGHTS_CFM, FP accepted our registration...\n", + CELLIAX_P_LOG); + + p->cvm_register_state = CVM_REGISTERED_TO_FP; + p->cvm_lock_state = CVM_UNKNOWN_LOCK_STATE; + p->cvm_handset_no = p->array[BUSMAIL_OFFSET_MAIL_PARAMS + 0]; + p->cvm_fp_is_cvm = p->array[BUSMAIL_OFFSET_MAIL_PARAMS + 1]; + + if (option_debug > 1) + DEBUGA_CVM + ("API_PP_ACCESS_RIGHTS_CFM, FP accepted our registration, Our handset no. is %d, CVM? %X\n", + CELLIAX_P_LOG, p->cvm_handset_no, p->cvm_fp_is_cvm); + + known = 1; + break; + + case API_PP_LOCKED_IND: + /* CVM is connected to FP */ + if (option_debug > 1) + DEBUGA_CVM("API_PP_LOCKED_IND, Connection to FP completed...\n", + CELLIAX_P_LOG); + + p->cvm_register_state = CVM_REGISTERED_TO_FP; + p->cvm_lock_state = CVM_LOCKED_TO_FP; + known = 1; + break; + + case API_PP_UNLOCKED_IND: + /* CVM is unlocked with FP, Out of service */ + WARNINGA + ("API_PP_UNLOCKED_IND, CVM is unlocked with FP, Out of service !!!\n", + CELLIAX_P_LOG); + + p->cvm_lock_state = CVM_UNLOCKED_TO_FP; + known = 1; + break; + + case API_PP_SETUP_ACK_IND: + /* Outgoing call, connection to FP established, FP is waiting for a number to dial */ + if (option_debug > 1) + DEBUGA_CVM + ("API_PP_SETUP_ACK_IND, connection to FP established, FP is waiting for a numer to dial...\n", + CELLIAX_P_LOG); + + if (AST_STATE_DOWN == p->interface_state) { + p->interface_state = AST_STATE_DIALING; + } + + known = 1; + break; + + case API_PP_ALERT_IND: + /* Outgoing call, Remote end is ringing */ + if (option_debug > 1) + DEBUGA_CVM("API_PP_ALERT_IND, remote end is ringing...\n", + CELLIAX_P_LOG); + + if (AST_STATE_DIALING == p->interface_state) { + p->interface_state = AST_STATE_RINGING; + } + + known = 1; + break; + + case API_PP_CONNECT_IND: + /* Outgoing call, the remote end answered our call */ + if (option_debug > 1) + DEBUGA_CVM("API_PP_CONNECT_IND, our call was answered...\n", + CELLIAX_P_LOG); + + if (AST_STATE_RINGING == p->interface_state) { + + /* let's open audio and have a chat */ + celliax_serial_send_info_frame_CVM_BUSMAIL(p, CVM_PP_AUDIO_OPEN_REQ, 0, + NULL); + + unsigned char volume = (unsigned char) p->cvm_volume_level; + celliax_serial_send_info_frame_CVM_BUSMAIL(p, + CVM_PP_AUDIO_SET_VOLUME_REQ, + sizeof(volume), &volume); + + /* let's unmute mic and have a chat */ + celliax_serial_send_info_frame_CVM_BUSMAIL(p, + CVM_PP_AUDIO_UNMUTE_MIC_REQ, + 0, NULL); + + /* let's switch to headset, because we fried normal output.... */ +/* unsigned char headset_on = (unsigned char) 1; + celliax_serial_send_info_frame_CVM_BUSMAIL(p, CVM_PP_AUDIO_HS_PLUG_IND, sizeof(headset_on), &headset_on); +*/ + p->interface_state = AST_STATE_UP; + ast_setstate(p->owner, AST_STATE_RINGING); + celliax_queue_control(p->owner, AST_CONTROL_ANSWER); + } + + known = 1; + break; + + case API_PP_REJECT_IND: + /* Outgoing/Incoming call, FP rejected our connection... */ + if (option_debug > 1) + DEBUGA_CVM + ("API_PP_REJECT_IND, FP or ther PP rejected our connection...\n", + CELLIAX_P_LOG); + + if (AST_STATE_RING == p->interface_state && p->owner) { + /* Attempt to answer incoming call rejected by FP or PP */ + if (option_debug > 1) + DEBUGA_CVM("Was it PAGE_ALL CALL, that we should not answered?\n", + CELLIAX_P_LOG); + + p->interface_state = AST_STATE_DOWN; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + + } else if (AST_STATE_DOWN != p->interface_state && p->owner) { + /* Outgoing call rejected by other PP or FP */ + p->interface_state = AST_STATE_BUSY; + ast_setstate(p->owner, AST_STATE_BUSY); + celliax_queue_control(p->owner, AST_CONTROL_BUSY); + } + + known = 1; + break; + + case API_PP_SIGNAL_ON_IND: + /* Ringback, ignore it... */ + if (option_debug > 1) + DEBUGA_CVM("API_PP_SIGNAL_ON_IND, Ringback, ignore it...\n", + CELLIAX_P_LOG); + + known = 1; + break; + + case API_PP_SIGNAL_OFF_IND: + /* Ringback, ignore it... */ + if (option_debug > 1) + DEBUGA_CVM("API_PP_SIGNAL_OFF_IND, Ringback, ignore it...\n", + CELLIAX_P_LOG); + + known = 1; + break; + + case API_PP_SETUP_IND: + /* Incoming call, Somebody is calling us */ + + if (option_debug > 1) + DEBUGA_CVM("API_PP_SETUP_IND, somebody is calling us...\n", + CELLIAX_P_LOG); + + if (AST_STATE_DOWN == p->interface_state) { + + if (API_PP_SETUP_IND_CALL_INT == + p->array[BUSMAIL_OFFSET_MAIL_PARAMS + + API_PP_SETUP_IND_CALL_TYPE_OFFSET]) { + DEBUGA_CVM("INTERNAL CALL, receive it...\n", CELLIAX_P_LOG); + + p->interface_state = AST_STATE_RING; + + /* inform calling end, that we know about his call, and that we are alerting */ + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_ALERT_REQ, 0, + NULL); + + /* let's open audio before valid mac, to remove noise... */ + celliax_serial_send_info_frame_CVM_BUSMAIL(p, + CVM_PP_AUDIO_OPEN_ADPCM_OFF_REQ, + 0, NULL); + + } else { + DEBUGA_CVM("NOT an INTERNAL CALL, CALL TYPE %X, just ignore it...\n", + CELLIAX_P_LOG, + p->array[BUSMAIL_OFFSET_MAIL_PARAMS + + API_PP_SETUP_IND_CALL_TYPE_OFFSET]); + + /* inform calling end, that we know about his call, and that we are alerting OR not :) */ + /* probably it is needed so FP does not remove us from PP list :) */ + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_ALERT_REQ, 0, + NULL); + } + + } else { + WARNINGA + ("Ignore incoming call, Wrong interface state, current state %X\n", + CELLIAX_P_LOG, p->interface_state); + } + + known = 1; + break; + + case API_PP_ALERT_OFF_IND: + /* Incoming call, We should stop alerting about incoming call... */ + if (option_debug > 1) + DEBUGA_CVM + ("API_PP_ALERT_OFF_IND, Ringback, stop alerting about incoming call...\n", + CELLIAX_P_LOG); + + known = 1; + break; + + case API_PP_ALERT_ON_IND: + /* Incoming call, We should stop alerting about incoming call... */ + if (option_debug > 1) + DEBUGA_CVM + ("API_PP_ALERT_ON_IND, Ringback, start alerting about incoming call...\n", + CELLIAX_P_LOG); +/* + if (AST_STATE_DOWN == p->interface_state) { + DEBUGA_CVM("Somebody is calling us, we see a PP_ALERT_ON_IND, receive it...\n", CELLIAX_P_LOG); + p->interface_state = AST_STATE_RING; + } +*/ + known = 1; + break; + + case API_PP_CONNECT_CFM: + /* Incoming call, Confirmation for request to answer incoming call... */ + if (option_debug > 1) + DEBUGA_CVM + ("API_PP_CONNECT_CFM, Confirmation for request to answer incoming call...\n", + CELLIAX_P_LOG); + + if (AST_STATE_RING == p->interface_state && p->owner) { + + p->interface_state = AST_STATE_UP; + ast_setstate(p->owner, AST_STATE_UP); + + /* let's open audio and have a chat */ +// celliax_serial_send_info_frame_CVM_BUSMAIL(p, CVM_PP_AUDIO_OPEN_ADPCM_OFF_REQ, 0, NULL); + + /* let's open audio and have a chat */ + celliax_serial_send_info_frame_CVM_BUSMAIL(p, CVM_PP_AUDIO_OPEN_REQ, 0, + NULL); + + unsigned char volume = (unsigned char) p->cvm_volume_level; + celliax_serial_send_info_frame_CVM_BUSMAIL(p, + CVM_PP_AUDIO_SET_VOLUME_REQ, + sizeof(volume), &volume); + + /* let's unmute mic and have a chat */ + celliax_serial_send_info_frame_CVM_BUSMAIL(p, + CVM_PP_AUDIO_UNMUTE_MIC_REQ, + 0, NULL); + + /* let's switch to headset, because we fried normal output.... */ +/* unsigned char headset_on = (unsigned char) 1; + celliax_serial_send_info_frame_CVM_BUSMAIL(p, CVM_PP_AUDIO_HS_PLUG_IND, sizeof(headset_on), &headset_on); +*/ + } else { + WARNINGA + ("Ignore connection cfm, Wrong interface state, current state %X\n", + CELLIAX_P_LOG, p->interface_state); + } + + known = 1; + break; + + case API_PP_RELEASE_CFM: + /* Confirmation for request to hangup a call... */ + if (option_debug > 1) + DEBUGA_CVM + ("API_PP_RELEASE_CFM, Confirmation for request to hangup a call..\n", + CELLIAX_P_LOG); + + if (AST_STATE_UP == p->interface_state) { + /* let's close audio */ + celliax_serial_send_info_frame_CVM_BUSMAIL(p, CVM_PP_AUDIO_CLOSE_REQ, 0, + NULL); + + /* let's unmute mic and have a chat */ + celliax_serial_send_info_frame_CVM_BUSMAIL(p, CVM_PP_AUDIO_MUTE_MIC_REQ, + 0, NULL); + } + + p->interface_state = AST_STATE_DOWN; + + known = 1; + break; + + case API_PP_RELEASE_IND: + /* FP releases connection to CVM... */ + if (option_debug > 1) + DEBUGA_CVM("API_PP_RELEASE_IND, FP releases connection to CVM...\n", + CELLIAX_P_LOG); + + if (AST_STATE_UP == p->interface_state && p->owner) { + /* let's close audio */ + celliax_serial_send_info_frame_CVM_BUSMAIL(p, CVM_PP_AUDIO_CLOSE_REQ, 0, + NULL); + p->interface_state = AST_STATE_DOWN; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + + } else if (AST_STATE_RING == p->interface_state && p->owner) { + /* workaround for PAGE ALL CALL, FIXME!!!! */ + if (option_debug > 1) + DEBUGA_CVM("WAS IT A PAGE ALL ???...\n", CELLIAX_P_LOG); + + p->interface_state = AST_STATE_UP; + usleep(100000); + + p->interface_state = AST_STATE_DOWN; + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + } + + /* we need to ACK release */ + celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_RELEASE_RES, 0, + NULL); + + known = 1; + break; + + case API_PP_READ_RSSI_CFM: + if (option_debug > 1) + DEBUGA_CVM("API_PP_READ_RSSI_CFM, RSSI readout...\n", CELLIAX_P_LOG); + + p->cvm_rssi = p->array[BUSMAIL_OFFSET_MAIL_PARAMS + 0]; + int rssi_percent = p->cvm_rssi * 100 / 0x3F; + if (option_debug > 1) + DEBUGA_CVM("RSSI is %X, %d%%...\n", CELLIAX_P_LOG, p->cvm_rssi, + rssi_percent); + + known = 1; + break; + default: + WARNINGA("UNKNOWN MsgPrimitive!!! %X\n", CELLIAX_P_LOG, MsgPrimitive); + break; + } + + break; + + case BUSMAIL_HEADER_CTRL_FRAME: + if (option_debug > 1) + DEBUGA_CVM("BUSMAIL_HEADER_CTRL_FRAME\n", CELLIAX_P_LOG); + + switch (p->array[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_SU_BIT_MASK) { + case BUSMAIL_HEADER_CTRL_SU_FRAME: + if (option_debug > 1) + DEBUGA_CVM("BUSMAIL_HEADER_CTRL_SU_FRAME\n", CELLIAX_P_LOG); + + switch (p->array[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_SUID_MASK) { + case BUSMAIL_HEADER_SUID_REJ: + /* CVM Reject, CVM missed one of our packets, it will be resend, do nothing */ + MsgRxSeqNo = + ((p->array[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_RXSEQ_MASK)); + + if (option_debug > 1) + DEBUGA_CVM("BUSMAIL_HEADER_SUID_REJ, RxSeq %X\n", CELLIAX_P_LOG, + MsgRxSeqNo); + + /* Even that it is CVM Reject packet, it still ACKs some packets */ + celliax_serial_list_acknowledge_CVM_BUSMAIL(p, MsgRxSeqNo); + + known = 1; + break; + case BUSMAIL_HEADER_SUID_RNR: + /* CVM Receiver Not Ready, answer to packet that we sent, do nothing, it will be resend later */ + MsgRxSeqNo = + ((p->array[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_RXSEQ_MASK)); + + if (option_debug > 1) + DEBUGA_CVM("BUSMAIL_HEADER_SUID_RNR, RxSeq %X\n", CELLIAX_P_LOG, + MsgRxSeqNo); + + known = 1; + break; + case BUSMAIL_HEADER_SUID_RR: + /* CVM ACKs our packets */ + MsgRxSeqNo = + ((p->array[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_RXSEQ_MASK)); + + if (option_debug > 1) + DEBUGA_CVM("BUSMAIL_HEADER_SUID_RR, RxSeq %X\n", CELLIAX_P_LOG, + MsgRxSeqNo); + + /* CVM ACKed our frames with RR frame */ + celliax_serial_list_acknowledge_CVM_BUSMAIL(p, MsgRxSeqNo); + + known = 1; + break; + + default: + WARNINGA("BUSMAIL_HEADER_SUID_UNKNOWN!!!\n", CELLIAX_P_LOG); + break; + } + break; + + case BUSMAIL_HEADER_CTRL_UN_FRAME: + if (option_debug > 1) + DEBUGA_CVM("BUSMAIL_HEADER_CTRL_UN_FRAME\n", CELLIAX_P_LOG); + + switch (p->array[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_UNID_MASK) { + + case BUSMAIL_HEADER_UNID_SABM: + if (option_debug > 1) + DEBUGA_CVM("BUSMAIL_HEADER_UNID_SABM\n", CELLIAX_P_LOG); + /* reset seq counters */ + p->busmail_txseq_celliax_last = 0xFF; + p->busmail_rxseq_cvm_last = 0xFF; + + celliax_serial_lists_free_CVM_BUSMAIL(p); + /* if needed, reply will be send by code at the end of switch statements */ + known = 1; + break; + + default: + WARNINGA("BUSMAIL_HEADER_UNID_UNKNOWN!!!\n", CELLIAX_P_LOG); + break; + } + break; + + default: + WARNINGA("BUSMAIL_HEADER_CTRL_UNKNOWN!!!\n", CELLIAX_P_LOG); + break; + } + break; + + default: + WARNINGA("BUSMAIL_HEADER_UNKNOWN!!!\n", CELLIAX_P_LOG); + break; + } + + } + + /* categorization of frame is ended, if it has not been recognized, whine */ + if (!known) { + WARNINGA("BUSMAIL MSG UNKNOWN or REJECTED!\n", CELLIAX_P_LOG); + } + } + p->arraycounter++; + } + } + CVM_UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + } + + /* oooops, select returned error, got a kill/cancel or problems with the serial file descriptor */ + if (select_err == -1) { + if (errno != EINTR) { + ERRORA + ("select returned -1 on %s, marking controldev as dead, errno was: %d, error was: %s\n", + CELLIAX_P_LOG, p->controldevice_name, errno, strerror(errno)); + + p->controldev_dead = 1; + close(p->controldevfd); + + if (p->owner) + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + return -1; + + } else { + WARNINGA("select returned -1 on %s, errno was: %d, EINTR, error was: %s\n", + CELLIAX_P_LOG, p->controldevice_name, errno, strerror(errno)); + return 0; + } + } + /* OK, reading done, let's browse the list of pending frames to be sent, and act on it */ + if (celliax_serial_send_if_time_CVM_BUSMAIL(p)) { + ERRORA("celliax_serial_send_if_time_CVM_BUSMAIL failed!\n", CELLIAX_P_LOG); + return -1; + } + + return cvm_busmail_mesg; //FIXME breaks the convention of returning 0 on success +} + +int celliax_serial_getstatus_CVM_BUSMAIL(struct celliax_pvt *p) +{ + int res; + int how_many_reads = 0; + + PUSHA_UNLOCKA(&p->controldev_lock); + CVM_LOKKA(&p->controldev_lock); + + if (option_debug > 1) + DEBUGA_CVM("Sending RR CTRL frame wit PF bit set\n", CELLIAX_P_LOG); + + /* this ctrl frame can be used as low level keep alive */ + celliax_serial_send_ctrl_frame_CVM_BUSMAIL(p, + BUSMAIL_HEADER_CTRL_FRAME | + BUSMAIL_HEADER_CTRL_SU_FRAME | + BUSMAIL_HEADER_SUID_RR | + (BUSMAIL_HEADER_PF_BIT_MASK & 0xFF)); + + //usleep(1000); + + res = celliax_serial_read_CVM_BUSMAIL(p); //we don't have no monitor neither do_controldev_thread + + if (res == -1) { + ERRORA("failed celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + + while ((res & 0xF0) != + (BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_SU_FRAME | + BUSMAIL_HEADER_SUID_RR)) { + + usleep(1000); + res = celliax_serial_read_CVM_BUSMAIL(p); + how_many_reads++; + + if (res == -1) { + ERRORA("failed celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + + if (how_many_reads > 10) { + ERRORA("no expected results in %d celliax_serial_read_CVM_BUSMAIL\n", CELLIAX_P_LOG, + how_many_reads); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + } + + //celliax_serial_send_info_frame_CVM_BUSMAIL(p, API_PP_READ_RSSI_REQ, 0, NULL); + + CVM_UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + + return 0; + +} + +/*! + * \brief Write on the serial port for all the CVM_BUSMAIL functions + * \param p celliax_pvt + * \param len lenght of buffer2 + * \param buffer2 chars to be written + * + * Write on the serial port for all the CVM_BUSMAIL functions + * + * \return the number of chars written on the serial, + * that can be different from len (or negative) in case of errors. + */ +int celliax_serial_send_CVM_BUSMAIL(struct celliax_pvt *p, int len, + unsigned char *mesg_ptr) +{ + int ret; + size_t actual = 0; + unsigned char *mesg_ptr2 = mesg_ptr; + PUSHA_UNLOCKA(&p->controldev_lock); + CVM_LOKKA(&p->controldev_lock); + do { + ret = write(p->controldevfd, mesg_ptr, len - actual); + if (ret < 0 && errno == EAGAIN) + continue; + if (ret < 0) { + if (actual != len) + ERRORA("celliax_serial_write error: %s", CELLIAX_P_LOG, strerror(errno)); + CVM_UNLOCKA(&p->controldev_lock); + return -1; + } + actual += ret; + mesg_ptr += ret; + usleep(10000); +// usleep(p->cvm_celliax_serial_delay*1000); + } while (actual < len); + + usleep(p->cvm_celliax_serial_delay * 1000); + +// tcdrain(p->controldevfd); + + CVM_UNLOCKA(&p->controldev_lock); + POPPA_UNLOCKA(&p->controldev_lock); + + if (option_debug > 10) { + int i; + char debug_buf[1024]; + char *debug_buf_pos; + + memset(debug_buf, 0, 1024); + debug_buf_pos = debug_buf; + + for (i = 0; i < len; i++) { + debug_buf_pos += sprintf(debug_buf_pos, "[%.2X] ", mesg_ptr2[i]); + if (debug_buf_pos > ((char *) &debug_buf + 1000)) + break; + } + DEBUGA_CVM("%s was sent down the wire\n", CELLIAX_P_LOG, debug_buf); + } + + return 0; +} + +/*! + * \brief Flags as acknowledged an BUSMAIL message previously sent + * \param p celliax_pvt + * \param seqnum identifier of the message to be acknowledged + * + * Called upon receiving an BUSMAIL acknoledgement message, browse the cvm_busmail_outgoing_list + * looking for the seqnum sent BUSMAIL message, and flags it as acknowledged. + * (if an outgoing BUSMAIL message is not aknowledged by the cellphone in a while, + * it will be retransmitted) + * + * \return 0 on error, 1 otherwise + */ +int celliax_serial_list_acknowledge_CVM_BUSMAIL(struct celliax_pvt *p, + unsigned char AckTxSeqNo) +{ + struct cvm_busmail_msg *ptr = NULL; + struct cvm_busmail_msg *old = NULL; + + unsigned char MsgTxSeqNo; + unsigned char MsgRxSeqNo; + + ptr = p->cvm_busmail_outgoing_list; + + if (ptr == NULL) { + ERRORA("cvm_busmail_outgoing_list is NULL ?\n", CELLIAX_P_LOG); + return -1; + } + + PUSHA_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + CVM_LOKKA(&p->cvm_busmail_outgoing_list_lock); +/* + DEBUGA_CVM("PREFREE OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_CVM_BUSMAIL(p, p->cvm_busmail_outgoing_list); +*/ + while (ptr->next != NULL) + ptr = ptr->next; + + while (ptr) { + + if ((1 == ptr->valid) && (0 == ptr->acknowledged) && (0 != ptr->sent)) { + MsgTxSeqNo = + ((ptr->busmail_msg_buffer[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_TXSEQ_MASK) >> + 4); + MsgRxSeqNo = + ((ptr->busmail_msg_buffer[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_RXSEQ_MASK)); + +/* + if (option_debug > 1) + DEBUGA_CVM("OUTGOING LIST TxSeq is %X, RxSeq is %X\n", CELLIAX_P_LOG, MsgTxSeqNo, MsgRxSeqNo); +*/ + unsigned char TxToAck = 0; + + if (0 == AckTxSeqNo) { + TxToAck = 7; + } else { + TxToAck = AckTxSeqNo - 1; + } + + if (MsgTxSeqNo <= TxToAck) { + + if (option_debug > 1) + DEBUGA_CVM("Msg with TxSeq=%X ACKed with CvmRxSeq=%X\n", CELLIAX_P_LOG, + MsgTxSeqNo, AckTxSeqNo); + + old = ptr; + old->acknowledged = 1; + old->valid = 0; + ptr = old->previous; + + if (old->previous) { + if (old->next) { + old->previous->next = old->next; + } else { + old->previous->next = NULL; + } + } + + if (old->next) { + if (old->previous) { + old->next->previous = old->previous; + } else { + old->next->previous = NULL; + } + } + + if ((NULL == old->next) && (NULL == old->previous)) { + if (option_debug > 1) { + DEBUGA_CVM("FREEING LAST\n", CELLIAX_P_LOG); + } + + p->cvm_busmail_outgoing_list = NULL; + p->cvm_busmail_outgoing_list = celliax_serial_list_init_CVM_BUSMAIL(p); + } + +/* + if (option_debug > 1) + DEBUGA_CVM("FREEING TxSeq is %X, RxSeq is %X\n", CELLIAX_P_LOG, MsgTxSeqNo, MsgRxSeqNo); +*/ + + free(old); + + } else { + ptr = ptr->previous; + } + + } else { + ptr = ptr->previous; + } + } + +/* + DEBUGA_CVM("POSTFREE OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_CVM_BUSMAIL(p, p->cvm_busmail_outgoing_list); +*/ + + CVM_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + POPPA_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + return 0; +} + +/*! + * \brief Sends an FBUS2 message or resends it if it was not acknowledged + * \param p celliax_pvt + * + * Called by celliax_serial_read_CVM_BUSMAIL, browse the fbus2_outgoing_list looking for FBUS2 messages to be sent, + * or for FBUS2 messages previously sent but not yet acknoledged. + * (if an outgoing FBUS2 message is not aknowledged by the cellphone in a while, + * it will be retransmitted) + * + * \return 0 on error, 1 otherwise + */ +int celliax_serial_send_if_time_CVM_BUSMAIL(struct celliax_pvt *p) +{ + struct cvm_busmail_msg *ptr; + struct timeval tv; + struct timezone tz; + + gettimeofday(&tv, &tz); + ptr = p->cvm_busmail_outgoing_list; + + if (ptr == NULL) { +/* ERRORA("cvm_busmail_outgoing_list is NULL ?\n", CELLIAX_P_LOG); */ + WARNINGA("cvm_busmail_outgoing_list is NULL, nothing to send...\n", CELLIAX_P_LOG); + +/* return -1; */ + return 0; + + } + + while (ptr->next != NULL) { + WARNINGA("cvm_busmail_outgoing_list->next is not null ?\n", CELLIAX_P_LOG); + ptr = ptr->next; //FIXME what to do? + } + + while (ptr->sent == 0 && ptr->acknowledged == 0) { + if (ptr->previous != NULL) { + ptr = ptr->previous; + } else + break; + } + + while (ptr->sent == 1 && ptr->acknowledged == 0) { + if (ptr->previous != NULL) { + ptr = ptr->previous; + } else + break; + } + + if (ptr->sent == 1 && ptr->acknowledged == 1) { + if (ptr->next != NULL) { + ptr = ptr->next; + } + } + + if (ptr->sent == 1 && ptr->acknowledged == 0 && ptr->valid == 1) { + if ((tv.tv_sec * 1000 + tv.tv_usec / 1000) > + ((ptr->tv_sec * 1000 + ptr->tv_usec / 1000) + 1000)) { + + PUSHA_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + CVM_LOKKA(&p->cvm_busmail_outgoing_list_lock); + + if (ptr->sent == 1 && ptr->acknowledged == 0 && ptr->valid == 1) { //retest, maybe has been changed? + if ((tv.tv_sec * 1000 + tv.tv_usec / 1000) > ((ptr->tv_sec * 1000 + ptr->tv_usec / 1000) + 1000)) { //retest, maybe has been changed? + + if (option_debug > 1) + DEBUGA_CVM("RESEND TxSeq=%X, passed %ld ms, sent %d times\n", CELLIAX_P_LOG, + ptr->txseqno, + ((tv.tv_sec * 1000 + tv.tv_usec / 1000) - + (ptr->tv_sec * 1000 + ptr->tv_usec / 1000)), ptr->how_many_sent); + + if (ptr->how_many_sent > 9) { + ERRORA("RESEND TxSeq=%X, passed %ld ms, sent %d times\n", CELLIAX_P_LOG, + ptr->txseqno, + ((tv.tv_sec * 1000 + tv.tv_usec / 1000) - + (ptr->tv_sec * 1000 + ptr->tv_usec / 1000)), ptr->how_many_sent); + + CVM_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + return -1; + } + + celliax_serial_send_CVM_BUSMAIL(p, ptr->busmail_msg_len, + ptr->busmail_msg_buffer); + + ptr->tv_sec = tv.tv_sec; + ptr->tv_usec = tv.tv_usec; + ptr->sent = 1; + ptr->how_many_sent++; +/* + if (option_debug > 1) { + DEBUGA_CVM("OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_CVM_BUSMAIL(p, p->cvm_busmail_outgoing_list); + DEBUGA_CVM("OUTGOING list END\n", CELLIAX_P_LOG); + } +*/ + } + } + + CVM_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + POPPA_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + } + } + + if (ptr->sent == 0 && ptr->acknowledged == 0 && ptr->valid == 1) { + + PUSHA_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + CVM_LOKKA(&p->cvm_busmail_outgoing_list_lock); + + if (ptr->sent == 0 && ptr->acknowledged == 0 && ptr->valid == 1) { //retest, maybe has been changed? + + if (option_debug > 1) + DEBUGA_CVM("SENDING 1st TIME TxSeq=%X\n", CELLIAX_P_LOG, ptr->txseqno); + + celliax_serial_send_CVM_BUSMAIL(p, ptr->busmail_msg_len, ptr->busmail_msg_buffer); + + ptr->tv_sec = tv.tv_sec; + ptr->tv_usec = tv.tv_usec; + ptr->sent = 1; + ptr->how_many_sent++; +/* + if (option_debug > 1) { + DEBUGA_CVM("OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_CVM_BUSMAIL(p, p->cvm_busmail_outgoing_list); + DEBUGA_CVM("OUTGOING list END\n", CELLIAX_P_LOG); + } +*/ + } + + CVM_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + POPPA_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + + } + return 0; +} + +int celliax_serial_write_CVM_BUSMAIL(struct celliax_pvt *p, + struct cvm_busmail_frame *busmail_frame) +{ + unsigned char buffer2[BUSMAIL_MAX_FRAME_LENGTH]; + int i = 0; + int len = 0; + unsigned int busmail_len_total = 0; + + busmail_frame->busmail_sof = BUSMAIL_SOF; + busmail_frame->busmail_crc = 0; + +/* because of Rx Tx SEQ HEADER fields problem, update when these fields are filled with correct data + busmail_frame->busmail_crc = (unsigned char)(busmail_frame->busmail_header + busmail_frame->busmail_crc); +*/ + + buffer2[BUSMAIL_OFFSET_SOF] = busmail_frame->busmail_sof; + buffer2[BUSMAIL_OFFSET_HEADER] = busmail_frame->busmail_header; + + if ((buffer2[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_IC_BIT_MASK) == + BUSMAIL_HEADER_INFO_FRAME) { + len = + BUSMAIL_OFFSET_MAIL_PARAMS + busmail_frame->busmail_mail_params_buffer_len + + sizeof(busmail_frame->busmail_crc); + busmail_len_total = + busmail_frame->busmail_mail_params_buffer_len + + sizeof(busmail_frame->busmail_header) + + sizeof(busmail_frame->busmail_mail_program_id) + + sizeof(busmail_frame->busmail_mail_task_id) + 2; + + if (option_debug > 1) + DEBUGA_CVM("INFO frame to send\n", CELLIAX_P_LOG); + + buffer2[BUSMAIL_OFFSET_MAIL_PROGRAM_ID] = busmail_frame->busmail_mail_program_id; + buffer2[BUSMAIL_OFFSET_MAIL_TASK_ID] = busmail_frame->busmail_mail_task_id; + buffer2[BUSMAIL_OFFSET_MAIL_PRIMITIVE_LSB] = + busmail_frame->busmail_mail_primitive[BUSMAIL_MAIL_PRIMITIVE_LSB]; + buffer2[BUSMAIL_OFFSET_MAIL_PRIMITIVE_MSB] = + busmail_frame->busmail_mail_primitive[BUSMAIL_MAIL_PRIMITIVE_MSB]; + + if (busmail_frame->busmail_mail_params_buffer_len) { + memcpy(buffer2 + BUSMAIL_OFFSET_MAIL_PARAMS, + busmail_frame->busmail_mail_params_buffer, + busmail_frame->busmail_mail_params_buffer_len); + } + + for (i = 0; i < busmail_frame->busmail_mail_params_buffer_len; i++) { + busmail_frame->busmail_crc = + (unsigned char) (busmail_frame->busmail_mail_params_buffer[i] + + busmail_frame->busmail_crc); + } + + busmail_frame->busmail_crc += busmail_frame->busmail_mail_program_id; + busmail_frame->busmail_crc += busmail_frame->busmail_mail_task_id; + busmail_frame->busmail_crc += + busmail_frame->busmail_mail_primitive[BUSMAIL_MAIL_PRIMITIVE_LSB]; + busmail_frame->busmail_crc += + busmail_frame->busmail_mail_primitive[BUSMAIL_MAIL_PRIMITIVE_MSB]; + } else { + busmail_len_total = sizeof(busmail_frame->busmail_header); + len = BUSMAIL_OFFSET_MAIL + sizeof(busmail_frame->busmail_crc); + + if (option_debug > 1) + DEBUGA_CVM("CTRL frame to send\n", CELLIAX_P_LOG); + } + +/* + DEBUGA_CVM("Its len=%d\n", CELLIAX_P_LOG, len); +*/ + + busmail_frame->busmail_len[BUSMAIL_LEN_LSB] = + (unsigned char) (busmail_len_total & 0xFF); + busmail_frame->busmail_len[BUSMAIL_LEN_MSB] = (unsigned char) (busmail_len_total >> 8); + buffer2[BUSMAIL_OFFSET_LEN_MSB] = busmail_frame->busmail_len[BUSMAIL_LEN_MSB]; + buffer2[BUSMAIL_OFFSET_LEN_LSB] = busmail_frame->busmail_len[BUSMAIL_LEN_LSB]; + +/* + buffer2[len-1] = busmail_frame->busmail_crc; +*/ + buffer2[len - 1] = 0xFF; + + if ((buffer2[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_IC_BIT_MASK) == + BUSMAIL_HEADER_INFO_FRAME) { + /* if it is INFO frame, queue it */ + + /* update TxSeq and RxSeq bits */ + /* clear TxSeq and RxSeq bits */ + buffer2[BUSMAIL_OFFSET_HEADER] &= + ~(BUSMAIL_HEADER_RXSEQ_MASK | BUSMAIL_HEADER_TXSEQ_MASK); + + buffer2[BUSMAIL_OFFSET_HEADER] |= + (p->busmail_rxseq_cvm_last + 1) & BUSMAIL_HEADER_RXSEQ_MASK; + + p->busmail_txseq_celliax_last++; + p->busmail_txseq_celliax_last &= 0x07; + + buffer2[BUSMAIL_OFFSET_HEADER] |= + ((p->busmail_txseq_celliax_last) << 4) & BUSMAIL_HEADER_TXSEQ_MASK; + + /* update CRC */ + busmail_frame->busmail_crc += buffer2[BUSMAIL_OFFSET_HEADER]; + buffer2[len - 1] = busmail_frame->busmail_crc; + + p->cvm_busmail_outgoing_list = celliax_serial_list_init_CVM_BUSMAIL(p); + p->cvm_busmail_outgoing_list->busmail_msg_len = len; + + for (i = 0; i < len; i++) { + p->cvm_busmail_outgoing_list->busmail_msg_buffer[i] = buffer2[i]; + } + + if (option_debug > 10) { + char debug_buf[1024]; + char *debug_buf_pos; + + memset(debug_buf, 0, 1024); + debug_buf_pos = debug_buf; + + for (i = 0; i < len; i++) { + debug_buf_pos += sprintf(debug_buf_pos, "[%.2X] ", buffer2[i]); + if (debug_buf_pos > (char *) (&debug_buf + 1000)) + break; + } + + if (option_debug > 1) + DEBUGA_CVM("INFO: %s was prepared to send\n", CELLIAX_P_LOG, debug_buf); + } + + if (option_debug > 1) { + DEBUGA_CVM("OUTGOING INFO Frame TxSeq is %X, RxSeq is %X\n", CELLIAX_P_LOG, + (buffer2[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_TXSEQ_MASK) >> 4, + buffer2[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_RXSEQ_MASK); +/* + DEBUGA_CVM("OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_CVM_BUSMAIL(p, p->cvm_busmail_outgoing_list); + DEBUGA_CVM("OUTGOING list END\n", CELLIAX_P_LOG); */ + } + p->cvm_busmail_outgoing_list->txseqno = + (unsigned char) (buffer2[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_TXSEQ_MASK) >> 4; + p->cvm_busmail_outgoing_list->valid = 1; /* ready to send (?) */ + + } else { + /* if it is CTRL frame, send it straight to the wire */ + if (BUSMAIL_HEADER_SABM != + (buffer2[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_SABM_MASK)) { + /*SABM ctrl frames have no RxSeq bits */ + + buffer2[BUSMAIL_OFFSET_HEADER] &= ~BUSMAIL_HEADER_RXSEQ_MASK; + + if (BUSMAIL_HEADER_REJ == + (buffer2[BUSMAIL_OFFSET_HEADER] & BUSMAIL_HEADER_REJ_MASK)) { + + if (option_debug > 1) + DEBUGA_CVM("CTRL REJ frame...\n", CELLIAX_P_LOG); + + if (0xFF != p->busmail_rxseq_cvm_last) { + buffer2[BUSMAIL_OFFSET_HEADER] |= + (p->busmail_rxseq_cvm_last + 1) & BUSMAIL_HEADER_RXSEQ_MASK; + } else { + if (option_debug > 1) + DEBUGA_CVM + ("Skipping sending REJ, because we just cleared RxSeq counter, and probably it was a packet that is invalid now...\n", + CELLIAX_P_LOG); + return 0; + } + + } else { + buffer2[BUSMAIL_OFFSET_HEADER] |= + (p->busmail_rxseq_cvm_last + 1) & BUSMAIL_HEADER_RXSEQ_MASK; + } + } + + /* update CRC */ + busmail_frame->busmail_crc += buffer2[BUSMAIL_OFFSET_HEADER]; + buffer2[len - 1] = busmail_frame->busmail_crc; + + if (option_debug > 10) { + char debug_buf[1024]; + char *debug_buf_pos; + + memset(debug_buf, 0, 1024); + debug_buf_pos = debug_buf; + + for (i = 0; i < len; i++) { + debug_buf_pos += sprintf(debug_buf_pos, "[%.2X] ", buffer2[i]); + if (debug_buf_pos > (char *) (&debug_buf + 1000)) + break; + } + + if (option_debug > 1) + DEBUGA_CVM("CTRL: %s was prepared to send\n", CELLIAX_P_LOG, debug_buf); + } +// usleep(100); + celliax_serial_send_CVM_BUSMAIL(p, len, buffer2); + } + + return 0; +} + +int celliax_serial_send_ctrl_frame_CVM_BUSMAIL(struct celliax_pvt *p, + unsigned char FrameType) +{ + /*FrameType parameter is really a busmail header with info neeeded to tell the frame type to send */ + struct cvm_busmail_frame busmail_frame; + + switch (FrameType & 0xF0) { + /* only higher nibble is important for us, do not take PF bit into considration */ + + case BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_SU_FRAME | BUSMAIL_HEADER_SUID_RR: + case BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_SU_FRAME | BUSMAIL_HEADER_SUID_REJ: + case BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_SU_FRAME | BUSMAIL_HEADER_SUID_RNR: + case BUSMAIL_HEADER_CTRL_FRAME | BUSMAIL_HEADER_CTRL_UN_FRAME | BUSMAIL_HEADER_UNID_SABM: + + busmail_frame.busmail_header = + (FrameType & 0xF8); + + break; + + default: + WARNINGA("UNKNOWN CTRL TYPE specified, sending nothing!!!\n", CELLIAX_P_LOG); + return -1; + break; + } + + busmail_frame.busmail_mail_params_buffer_len = 0; + + /* Sending to CVM */ + return celliax_serial_write_CVM_BUSMAIL(p, &busmail_frame); +} + +int celliax_serial_send_info_frame_CVM_BUSMAIL(struct celliax_pvt *p, int FrameType, + unsigned char ParamsLen, + unsigned char *Params) +{ + /*FrameType parameter is really a Primitive ID */ + struct cvm_busmail_frame busmail_frame; + int i = 0; + busmail_frame.busmail_header = + (BUSMAIL_HEADER_PF_BIT_MASK & 0xFF) | BUSMAIL_HEADER_INFO_FRAME; + + busmail_frame.busmail_mail_primitive[BUSMAIL_MAIL_PRIMITIVE_LSB] = FrameType & 0xFF; + busmail_frame.busmail_mail_primitive[BUSMAIL_MAIL_PRIMITIVE_MSB] = + (FrameType >> 8) & 0xFF; + + busmail_frame.busmail_mail_program_id = BUSMAIL_MAIL_PROGRAM_ID; + busmail_frame.busmail_mail_task_id = BUSMAIL_MAIL_TASK_ID; + + for (i = 0; i < ParamsLen; i++) { + busmail_frame.busmail_mail_params_buffer[i] = Params[i]; + } + + busmail_frame.busmail_mail_params_buffer_len = ParamsLen; + + /* Sending to CVM */ + return celliax_serial_write_CVM_BUSMAIL(p, &busmail_frame); +} + +int celliax_serial_lists_free_CVM_BUSMAIL(struct celliax_pvt *p) +{ + struct cvm_busmail_msg *ptr, *prev; +/* + if (option_debug > 1) { + DEBUGA_CVM("START FREEING OUTGOING\n", CELLIAX_P_LOG); + DEBUGA_CVM("OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_CVM_BUSMAIL(p, p->cvm_busmail_outgoing_list); + DEBUGA_CVM("OUTGOING list END\n", CELLIAX_P_LOG); + } +*/ + ptr = p->cvm_busmail_outgoing_list; + + if (ptr) { + while (ptr->next != NULL) + ptr = ptr->next; + + while (ptr->previous != NULL) { + + if (option_debug > 1) + DEBUGA_CVM("FREED \n", CELLIAX_P_LOG); + + prev = ptr->previous; + free(ptr); + ptr = prev; + } + + free(ptr); + } + + if (option_debug > 1) + DEBUGA_CVM("LAST FREED \n", CELLIAX_P_LOG); + + p->cvm_busmail_outgoing_list = NULL; + p->cvm_busmail_outgoing_list = celliax_serial_list_init_CVM_BUSMAIL(p); + + if (option_debug > 1) { + DEBUGA_CVM("OUTGOING list:\n", CELLIAX_P_LOG); + celliax_serial_list_print_CVM_BUSMAIL(p, p->cvm_busmail_outgoing_list); + DEBUGA_CVM("OUTGOING list END\n", CELLIAX_P_LOG); + DEBUGA_CVM("STARTING FREE INGOING\n", CELLIAX_P_LOG); + } + + return 0; +} + +struct cvm_busmail_msg *celliax_serial_list_init_CVM_BUSMAIL(struct celliax_pvt *p) +{ + struct cvm_busmail_msg *list; + list = p->cvm_busmail_outgoing_list; + + PUSHA_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + CVM_LOKKA(&p->cvm_busmail_outgoing_list_lock); + + if (list == NULL) { + list = malloc(sizeof(*(list))); + list->valid = 0; + list->busmail_msg_len = 0; + list->acknowledged = 0; + list->how_many_sent = 0; + list->sent = 0; + list->tv_sec = 0; + list->tv_usec = 0; + list->next = NULL; + list->previous = NULL; + } + + if (list->valid != 0) { + struct cvm_busmail_msg *new; + new = malloc(sizeof(*new)); + new->valid = 0; + new->busmail_msg_len = 0; + new->acknowledged = 0; + new->how_many_sent = 0; + new->sent = 0; + new->tv_sec = 0; + new->tv_usec = 0; + new->next = NULL; + new->previous = list; + list->next = new; + list = new; + } + + CVM_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + POPPA_UNLOCKA(&p->cvm_busmail_outgoing_list_lock); + + return list; +} + +int celliax_serial_list_print_CVM_BUSMAIL(struct celliax_pvt *p, + struct cvm_busmail_msg *list) +{ + struct cvm_busmail_msg *ptr; + ptr = list; + + if (ptr) { + while (ptr->next != NULL) + ptr = ptr->next; + + while (ptr) { + + if (option_debug > 3) + DEBUGA_CVM + ("PTR msg is: %d, seqnum is %.2X, tv_sec is %d, tv_usec is %d, acknowledged is: %d," + " sent is:%d, how_many_sent is: %d\n", CELLIAX_P_LOG, ptr->valid, + /*ptr->seqnum */ 44, + ptr->tv_sec, ptr->tv_usec, ptr->acknowledged, ptr->sent, ptr->how_many_sent); + + ptr = ptr->previous; + } + } + + return 0; +} + +#endif /* CELLIAX_CVM */ diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/celliax_libcsv.c b/src/mod/endpoints/mod_gsmopen/asterisk/celliax_libcsv.c new file mode 100644 index 0000000000..6b5dc3fe4b --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/celliax_libcsv.c @@ -0,0 +1,356 @@ +/* +libcsv - parse and write csv data +Copyright (C) 2007 Robert Gamble + +This library is free software; you can redistribute it and/or +modify it under the terms of the GNU Lesser General Public +License as published by the Free Software Foundation; either +version 2.1 of the License, or (at your option) any later version. + +This library 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 +Lesser General Public License for more details. + +You should have received a copy of the GNU Lesser General Public +License along with this library; if not, write to the Free Software +Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA +*/ + +#if ___STDC_VERSION__ >= 199901L +# include +#else +# define SIZE_MAX ((size_t)-1) /* C89 doesn't have stdint.h or SIZE_MAX */ +#endif + +#include "celliax_libcsv.h" + +#define VERSION "1.0.0" + +#define ROW_NOT_BEGUN 0 +#define FIELD_NOT_BEGUN 1 +#define FIELD_BEGUN 2 +#define FIELD_MIGHT_HAVE_ENDED 3 + +/* + Explanation of states + ROW_NOT_BEGUN There have not been any fields encountered for this row + FIELD_NOT_BEGUN There have been fields but we are currently not in one + FIELD_BEGUN We are in a field + FIELD_MIGHT_HAVE_ENDED + We encountered a double quote inside a quoted field, the + field is either ended or the quote is literal +*/ + +#define MEM_BLK_SIZE 128 + +#define SUBMIT_FIELD(p) \ + do { \ + if (!(p)->quoted) \ + (p)->entry_pos -= (p)->spaces; \ + if (cb1) \ + cb1(p->entry_buf, (p)->entry_pos, data); \ + (p)->pstate = FIELD_NOT_BEGUN; \ + (p)->entry_pos = (p)->quoted = (p)->spaces = 0; \ + } while (0) + +#define SUBMIT_ROW(p, c) \ + do { \ + if (cb2) \ + cb2(c, data); \ + (p)->pstate = ROW_NOT_BEGUN; \ + (p)->entry_pos = (p)->quoted = (p)->spaces = 0; \ + } while (0) + +#define SUBMIT_CHAR(p, c) ((p)->entry_buf[(p)->entry_pos++] = (c)) + +static char *csv_errors[] = {"success", + "error parsing data while strict checking enabled", + "memory exhausted while increasing buffer size", + "data size too large", + "invalid status code"}; + +int +csv_error(struct csv_parser *p) +{ + return p->status; +} + +char * +csv_strerror(int status) +{ + if (status >= CSV_EINVALID || status < 0) + return csv_errors[CSV_EINVALID]; + else + return csv_errors[status]; +} + +int +csv_opts(struct csv_parser *p, unsigned char options) +{ + if (p == NULL) + return -1; + + p->options = options; + return 0; +} + +int +csv_init(struct csv_parser **p, unsigned char options) +{ + /* Initialize a csv_parser object returns 0 on success, -1 on error */ + if (p == NULL) + return -1; + + if ((*p = malloc(sizeof(struct csv_parser))) == NULL) + return -1; + + if ( ((*p)->entry_buf = malloc(MEM_BLK_SIZE)) == NULL ) { + free(*p); + return -1; + } + (*p)->pstate = ROW_NOT_BEGUN; + (*p)->quoted = 0; + (*p)->spaces = 0; + (*p)->entry_pos = 0; + (*p)->entry_size = MEM_BLK_SIZE; + (*p)->status = 0; + (*p)->options = options; + + return 0; +} + +void +csv_free(struct csv_parser *p) +{ + /* Free the entry_buffer and the csv_parser object */ + if (p == NULL) + return; + + if (p->entry_buf) + free(p->entry_buf); + + free(p); + return; +} + +int +csv_fini(struct csv_parser *p, void (*cb1)(char *, size_t, void *), void (*cb2)(char c, void *), void *data) +{ + /* Finalize parsing. Needed, for example, when file does not end in a newline */ + if (p == NULL) + return -1; + + switch (p->pstate) { + case FIELD_MIGHT_HAVE_ENDED: + p->entry_pos -= p->spaces + 1; /* get rid of spaces and original quote */ + case FIELD_NOT_BEGUN: + case FIELD_BEGUN: + SUBMIT_FIELD(p); + SUBMIT_ROW(p, 0); + case ROW_NOT_BEGUN: /* Already ended properly */ + ; + } + + p->spaces = p->quoted = p->entry_pos = p->status = 0; + p->pstate = ROW_NOT_BEGUN; + + return 0; +} + +size_t +csv_parse(struct csv_parser *p, const char *s, size_t len, void (*cb1)(char *, size_t, void *), void (*cb2)(char c, void *), void *data) +{ + char c; /* The character we are currently processing */ + size_t pos = 0; /* The number of characters we have processed in this call */ + + while (pos < len) { + /* Check memory usage */ + if (p->entry_pos == p->entry_size) { + size_t to_add = MEM_BLK_SIZE; + void *vp; + while ( p->entry_size >= SIZE_MAX - to_add ) + to_add /= 2; + if (!to_add) { + p->status = CSV_ETOOBIG; + return pos; + } + while ((vp = realloc(p->entry_buf, p->entry_size + to_add)) == NULL) { + to_add /= 2; + if (!to_add) { + p->status = CSV_ENOMEM; + return pos; + } + } + p->entry_buf = vp; + p->entry_size += to_add; + } + + c = s[pos++]; + switch (p->pstate) { + case ROW_NOT_BEGUN: + case FIELD_NOT_BEGUN: + if (c == CSV_SPACE || c == CSV_TAB) { /* Space or Tab */ + continue; + } else if (c == CSV_CR || c == CSV_LF) { /* Carriage Return or Line Feed */ + if (p->pstate == FIELD_NOT_BEGUN) { + SUBMIT_FIELD(p); + SUBMIT_ROW(p, c); + } else { /* ROW_NOT_BEGUN */ + /* Don't submit empty rows by default */ + if (p->options & CSV_REPALL_NL) { + SUBMIT_ROW(p, c); + } + } + continue; + } else if ( (!(p->options & CSV_USE_SEMICOLON_SEPARATOR) && (c == CSV_COMMA)) || ((p->options & CSV_USE_SEMICOLON_SEPARATOR) && (c == CSV_SEMICOLON)) ) { /* Comma or SemiColon */ + SUBMIT_FIELD(p); + break; + } else if (c == CSV_QUOTE) { /* Quote */ + p->pstate = FIELD_BEGUN; + p->quoted = 1; + } else { /* Anything else */ + p->pstate = FIELD_BEGUN; + p->quoted = 0; + SUBMIT_CHAR(p, c); + } + break; + case FIELD_BEGUN: + if (c == CSV_QUOTE) { /* Quote */ + if (p->quoted) { + SUBMIT_CHAR(p, c); + p->pstate = FIELD_MIGHT_HAVE_ENDED; + } else { + /* STRICT ERROR - double quote inside non-quoted field */ + if (p->options & CSV_STRICT) { + p->status = CSV_EPARSE; + return pos-1; + } + SUBMIT_CHAR(p, c); + p->spaces = 0; + } + } else if ((!(p->options & CSV_USE_SEMICOLON_SEPARATOR) && (c == CSV_COMMA)) || ((p->options & CSV_USE_SEMICOLON_SEPARATOR) && (c == CSV_SEMICOLON))) { /* Comma or SemiColon */ + if (p->quoted) { + SUBMIT_CHAR(p, c); + } else { + SUBMIT_FIELD(p); + } + } else if (c == CSV_CR || c == CSV_LF) { /* Carriage Return or Line Feed */ + if (!p->quoted) { + SUBMIT_FIELD(p); + SUBMIT_ROW(p, c); + } else { + SUBMIT_CHAR(p, c); + } + } else if (!p->quoted && (c == CSV_SPACE || c == CSV_TAB)) { /* Tab or space for non-quoted field */ + SUBMIT_CHAR(p, c); + p->spaces++; + } else { /* Anything else */ + SUBMIT_CHAR(p, c); + p->spaces = 0; + } + break; + case FIELD_MIGHT_HAVE_ENDED: + /* This only happens when a quote character is encountered in a quoted field */ + if ((!(p->options & CSV_USE_SEMICOLON_SEPARATOR) && (c == CSV_COMMA)) || ((p->options & CSV_USE_SEMICOLON_SEPARATOR) && (c == CSV_SEMICOLON))) { /* Comma or SemiColon */ + p->entry_pos -= p->spaces + 1; /* get rid of spaces and original quote */ + SUBMIT_FIELD(p); + } else if (c == CSV_CR || c == CSV_LF) { /* Carriage Return or Line Feed */ + p->entry_pos -= p->spaces + 1; /* get rid of spaces and original quote */ + SUBMIT_FIELD(p); + SUBMIT_ROW(p, c); + } else if (c == CSV_SPACE || c == CSV_TAB) { /* Space or Tab */ + SUBMIT_CHAR(p, c); + p->spaces++; + } else if (c == CSV_QUOTE) { /* Quote */ + if (p->spaces) { + /* STRICT ERROR - unescaped double quote */ + if (p->options & CSV_STRICT) { + p->status = CSV_EPARSE; + return pos-1; + } + p->spaces = 0; + SUBMIT_CHAR(p, c); + } else { + /* Two quotes in a row */ + p->pstate = FIELD_BEGUN; + } + } else { /* Anything else */ + /* STRICT ERROR - unescaped double quote */ + if (p->options & CSV_STRICT) { + p->status = CSV_EPARSE; + return pos-1; + } + p->pstate = FIELD_BEGUN; + p->spaces = 0; + SUBMIT_CHAR(p, c); + } + break; + default: + break; + } + } + return pos; +} + +size_t +csv_write (char *dest, size_t dest_size, const char *src, size_t src_size) +{ + size_t chars = 0; + + if (src == NULL) + return 0; + + if (dest == NULL) + dest_size = 0; + + if (dest_size > 0) + *dest++ = '"'; + chars++; + + while (src_size) { + if (*src == '"') { + if (dest_size > chars) + *dest++ = '"'; + if (chars < SIZE_MAX) chars++; + } + if (dest_size > chars) + *dest++ = *src; + if (chars < SIZE_MAX) chars++; + src_size--; + src++; + } + + if (dest_size > chars) + *dest = '"'; + if (chars < SIZE_MAX) chars++; + + return chars; +} + +int +csv_fwrite (FILE *fp, const char *src, size_t src_size) +{ + if (fp == NULL || src == NULL) + return 0; + + if (fputc('"', fp) == EOF) + return EOF; + + while (src_size) { + if (*src == '"') { + if (fputc('"', fp) == EOF) + return EOF; + } + if (fputc(*src, fp) == EOF) + return EOF; + src_size--; + src++; + } + + if (fputc('"', fp) == EOF) { + return EOF; + } + + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/celliax_libcsv.h b/src/mod/endpoints/mod_gsmopen/asterisk/celliax_libcsv.h new file mode 100644 index 0000000000..2a2e4465a9 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/celliax_libcsv.h @@ -0,0 +1,48 @@ +#ifndef LIBCSV_H__ +#define LIBCSV_H__ +#include +#include + +/* Error Codes */ +#define CSV_SUCCESS 0 +#define CSV_EPARSE 1 /* Parse error in strict mode */ +#define CSV_ENOMEM 2 /* Out of memory while increasing buffer size */ +#define CSV_ETOOBIG 3 /* Buffer larger than SIZE_MAX needed */ +#define CSV_EINVALID 4 /* Invalid code, should never receive this from csv_error */ + +/* parser options */ +#define CSV_STRICT 1 /* enable strict mode */ +#define CSV_REPALL_NL 2 /* report all unquoted carriage returns and linefeeds */ +#define CSV_USE_SEMICOLON_SEPARATOR 4 /* use CSV_SEMICOLON as separator instead of CSV_COMMA */ + +/* Character values */ +#define CSV_TAB 0x09 +#define CSV_SPACE 0x20 +#define CSV_CR 0x0d +#define CSV_LF 0x0a +#define CSV_COMMA 0x2c +#define CSV_SEMICOLON 0x3b /* ; */ +#define CSV_QUOTE 0x22 + +struct csv_parser { + int pstate; /* Parser state */ + int quoted; /* Is the current field a quoted field? */ + size_t spaces; /* Number of continious spaces after quote or in a non-quoted field */ + char * entry_buf; /* Entry buffer */ + size_t entry_pos; /* Current position in entry_buf (and current size of entry) */ + size_t entry_size; /* Size of buffer */ + int status; /* Operation status */ + unsigned char options; +}; + +int csv_init(struct csv_parser **p, unsigned char options); +int csv_fini(struct csv_parser *p, void (*cb1)(char *, size_t, void *), void (*cb2)(char, void *), void *data); +void csv_free(struct csv_parser *p); +int csv_error(struct csv_parser *p); +char * csv_strerror(int error); +size_t csv_parse(struct csv_parser *p, const char *s, size_t len, void (*cb1)(char *, size_t, void *), void (*cb2)(char, void *), void *data); +size_t csv_write(char *dest, size_t dest_size, const char *src, size_t src_size); +int csv_fwrite(FILE *fp, const char *src, size_t src_size); +int csv_opts(struct csv_parser *p, unsigned char options); + +#endif diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/celliax_spandsp.c b/src/mod/endpoints/mod_gsmopen/asterisk/celliax_spandsp.c new file mode 100644 index 0000000000..b18a498e8d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/celliax_spandsp.c @@ -0,0 +1,1059 @@ +/* + * SpanDSP - a series of DSP components for telephony + * + * echo.c - An echo cancellor, suitable for electrical and acoustic + * cancellation. This code does not currently comply with + * any relevant standards (e.g. G.164/5/7/8). One day.... + * + * Written by Steve Underwood + * + * Copyright (C) 2001, 2003 Steve Underwood + * + * Based on a bit from here, a bit from there, eye of toad, + * ear of bat, etc - plus, of course, my own 2 cents. + * + * All rights reserved. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2, as + * published by the Free Software Foundation. + * + * 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., 675 Mass Ave, Cambridge, MA 02139, USA. + * + * $Id: echo.c,v 1.20 2006/12/01 18:00:48 steveu Exp $ + */ + +/*! \file */ + +/* TODO: + Finish the echo suppressor option, however nasty suppression may be. + Add an option to reintroduce side tone at -24dB under appropriate conditions. + Improve double talk detector (iterative!) +*/ + +/* We need to differentiate between transmitted energy which will train the echo + canceller well (voice, white noise, and other broadband sources) and energy + which will train it badly (supervisory tones, DTMF, whistles, and other + narrowband sources). There are many ways this might be done. This canceller uses + a method based on the autocorrelation qualities of the transmitted signal. A rather + peaky autocorrelation function is a clear sign of a narrowband signal. We only need + perform the autocorrelation at well spaced intervals, so the compute load is not too + great. Multiple successive autocorrelation functions with a similar peaky shape are a + clear indication of a stationary narrowband signal. Using TKEO, it should be possible to + greatly reduce the compute requirement for narrowband detection. */ + +/* The FIR taps must be adapted as 32 bit values, to get the necessary finesse + in the adaption process. However, they are applied as 16 bit values (bits 30-15 + of the 32 bit values) in the FIR. For the working 16 bit values, we need 4 sets. + + 3 of the 16 bit sets are used on a rotating basis. Normally the canceller steps + round these 3 sets at regular intervals. Any time we detect double talk, we can go + back to the set from two steps ago with reasonable assurance it is a well adapted + set. We cannot just go back one step, as we may have rotated the sets just before + double talk or tone was detected, and that set may already be somewhat corrupted. + + When narrowband energy is detected we need to continue adapting to it, to echo + cancel it. However, the adaption will almost certainly be going astray. Broadband + (or even complex sequences of narrowband) energy will normally lead to a well + trained cancellor, with taps matching the impulse response of the channel. + For stationary narrowband energy, there is usually has an infinite number of + alternative tap sets which will cancel it well. A previously well trained set of + taps will tend to drift amongst the alternatives. When broadband energy resumes, the + taps may be a total mismatch for the signal, and could even amplify rather than + attenuate the echo. The solution is to use a fourth set of 16 bit taps. When we first + detect the narrowband energy we save the oldest of the group of three sets, but do + not change back to an older set. We let the canceller cancel, and it adaption drift + while the narrowband energy is present. When we detect the narrowband energy has ceased, + we switch to using the fourth set of taps which was saved. + + When we revert to an older set of taps, we must replace both the 16 bit and 32 bit + working tap sets. The saved 16 bit values are good enough to also be used as a replacement + for the 32 bit values. We loose the fractions, but they should soon settle down in a + reasonable way. */ + +#ifdef HAVE_CONFIG_H +#include +#endif + +#include +#include +#include +#include + +#include "celliax_spandsp.h" + +//#include "spandsp/telephony.h" +//#include "spandsp/logging.h" +//#include "spandsp/bit_operations.h" +//#include "spandsp/echo.h" + +//#include "bit_operations.h" +//#include "giova.h" + +#if !defined(NULL) +#define NULL (void *) 0 +#endif +#if !defined(FALSE) +#define FALSE 0 +#endif +#if !defined(TRUE) +#define TRUE (!FALSE) +#endif + +#if 0 +#define MIN_TX_POWER_FOR_ADAPTION 64*64 +#define MIN_RX_POWER_FOR_ADAPTION 64*64 + +static int narrowband_detect(echo_can_state_t * ec) +{ + int k; + int i; + float temp; + float scale; + float sf[128]; + float f_acf[128]; + int32_t acf[28]; + int score; + int len = 32; + int alen = 9; + + k = ec->curr_pos; + for (i = 0; i < len; i++) { + sf[i] = ec->fir_state.history[k++]; + if (k >= 256) + k = 0; + } + for (k = 0; k < alen; k++) { + temp = 0; + for (i = k; i < len; i++) + temp += sf[i] * sf[i - k]; + f_acf[k] = temp; + } + scale = 0x1FFFFFFF / f_acf[0]; + for (k = 0; k < alen; k++) + acf[k] = (int32_t) (f_acf[k] * scale); + score = 0; + for (i = 0; i < 9; i++) { + if (ec->last_acf[i] >= 0 && acf[i] >= 0) { + if ((ec->last_acf[i] >> 1) < acf[i] && acf[i] < (ec->last_acf[i] << 1)) + score++; + } else if (ec->last_acf[i] < 0 && acf[i] < 0) { + if ((ec->last_acf[i] >> 1) > acf[i] && acf[i] > (ec->last_acf[i] << 1)) + score++; + } + } + memcpy(ec->last_acf, acf, alen * sizeof(ec->last_acf[0])); + return score; +} + +static __inline__ void lms_adapt(echo_can_state_t * ec, int factor) +{ + int i; + +#if 0 + mmx_t *mmx_taps; + mmx_t *mmx_coeffs; + mmx_t *mmx_hist; + mmx_t mmx; + + mmx.w[0] = mmx.w[1] = mmx.w[2] = mmx.w[3] = factor; + mmx_hist = (mmx_t *) & fir->history[fir->curr_pos]; + mmx_taps = (mmx_t *) & fir->taps; + mmx_coeffs = (mmx_t *) fir->coeffs; + i = fir->taps; + movq_m2r(mmx, mm0); + while (i > 0) { + movq_m2r(mmx_hist[0], mm1); + movq_m2r(mmx_taps[0], mm0); + movq_m2r(mmx_taps[1], mm1); + movq_r2r(mm1, mm2); + pmulhw(mm0, mm1); + pmullw(mm0, mm2); + + pmaddwd_r2r(mm1, mm0); + pmaddwd_r2r(mm3, mm2); + paddd_r2r(mm0, mm4); + paddd_r2r(mm2, mm4); + movq_r2m(mm0, mmx_taps[0]); + movq_r2m(mm1, mmx_taps[0]); + movq_r2m(mm2, mmx_coeffs[0]); + mmx_taps += 2; + mmx_coeffs += 1; + mmx_hist += 1; + i -= 4; + ) + emms(); +#elif 0 + /* Update the FIR taps */ + for (i = ec->taps - 1; i >= 0; i--) { + /* Leak to avoid the coefficients drifting beyond the ability of the + adaption process to bring them back under control. */ + ec->fir_taps32[i] -= (ec->fir_taps32[i] >> 23); + ec->fir_taps32[i] += (ec->fir_state.history[i + ec->curr_pos] * factor); + ec->latest_correction = (ec->fir_state.history[i + ec->curr_pos] * factor); + ec->fir_taps16[ec->tap_set][i] = ec->fir_taps32[i] >> 15; + } +#else + int offset1; + int offset2; + + /* Update the FIR taps */ + offset2 = ec->curr_pos; + offset1 = ec->taps - offset2; + for (i = ec->taps - 1; i >= offset1; i--) { + ec->fir_taps32[i] += (ec->fir_state.history[i - offset1] * factor); + ec->fir_taps16[ec->tap_set][i] = (int16_t) (ec->fir_taps32[i] >> 15); + } + for (; i >= 0; i--) { + ec->fir_taps32[i] += (ec->fir_state.history[i + offset2] * factor); + ec->fir_taps16[ec->tap_set][i] = (int16_t) (ec->fir_taps32[i] >> 15); + } +#endif +} + +/*- End of function --------------------------------------------------------*/ + +#ifdef NOT_NEEDED +echo_can_state_t *echo_can_create(int len, int adaption_mode) +{ + echo_can_state_t *ec; + int i; + int j; + + ec = (echo_can_state_t *) malloc(sizeof(*ec)); + if (ec == NULL) + return NULL; + memset(ec, 0, sizeof(*ec)); + ec->taps = len; + ec->curr_pos = ec->taps - 1; + ec->tap_mask = ec->taps - 1; + if ((ec->fir_taps32 = (int32_t *) malloc(ec->taps * sizeof(int32_t))) == NULL) { + free(ec); + return NULL; + } + memset(ec->fir_taps32, 0, ec->taps * sizeof(int32_t)); + for (i = 0; i < 4; i++) { + if ((ec->fir_taps16[i] = (int16_t *) malloc(ec->taps * sizeof(int16_t))) == NULL) { + for (j = 0; j < i; j++) + free(ec->fir_taps16[j]); + free(ec->fir_taps32); + free(ec); + return NULL; + } + memset(ec->fir_taps16[i], 0, ec->taps * sizeof(int16_t)); + } + fir16_create(&ec->fir_state, ec->fir_taps16[0], ec->taps); + ec->rx_power_threshold = 10000000; + ec->geigel_max = 0; + ec->geigel_lag = 0; + ec->dtd_onset = FALSE; + ec->tap_set = 0; + ec->tap_rotate_counter = 1600; + ec->cng_level = 1000; + echo_can_adaption_mode(ec, adaption_mode); + return ec; +} + +/*- End of function --------------------------------------------------------*/ + +void echo_can_free(echo_can_state_t * ec) +{ + int i; + + fir16_free(&ec->fir_state); + free(ec->fir_taps32); + for (i = 0; i < 4; i++) + free(ec->fir_taps16[i]); + free(ec); +} + +/*- End of function --------------------------------------------------------*/ + +void echo_can_adaption_mode(echo_can_state_t * ec, int adaption_mode) +{ + ec->adaption_mode = adaption_mode; +} + +/*- End of function --------------------------------------------------------*/ + +void echo_can_flush(echo_can_state_t * ec) +{ + int i; + + for (i = 0; i < 4; i++) + ec->tx_power[i] = 0; + for (i = 0; i < 3; i++) + ec->rx_power[i] = 0; + ec->clean_rx_power = 0; + ec->nonupdate_dwell = 0; + + fir16_flush(&ec->fir_state); + ec->fir_state.curr_pos = ec->taps - 1; + memset(ec->fir_taps32, 0, ec->taps * sizeof(int32_t)); + for (i = 0; i < 4; i++) + memset(ec->fir_taps16[i], 0, ec->taps * sizeof(int16_t)); + + ec->curr_pos = ec->taps - 1; + + ec->supp_test1 = 0; + ec->supp_test2 = 0; + ec->supp1 = 0; + ec->supp2 = 0; + ec->vad = 0; + ec->cng_level = 1000; + ec->cng_filter = 0; + + ec->geigel_max = 0; + ec->geigel_lag = 0; + ec->dtd_onset = FALSE; + ec->tap_set = 0; + ec->tap_rotate_counter = 1600; + + ec->latest_correction = 0; + + memset(ec->last_acf, 0, sizeof(ec->last_acf)); + ec->narrowband_count = 0; + ec->narrowband_score = 0; +} + +/*- End of function --------------------------------------------------------*/ + +int sample_no = 0; + +int16_t echo_can_update(echo_can_state_t * ec, int16_t tx, int16_t rx) +{ + int32_t echo_value; + int clean_rx; + int nsuppr; + int score; + int i; + + sample_no++; + ec->latest_correction = 0; + /* Evaluate the echo - i.e. apply the FIR filter */ + /* Assume the gain of the FIR does not exceed unity. Exceeding unity + would seem like a rather poor thing for an echo cancellor to do :) + This means we can compute the result with a total disregard for + overflows. 16bits x 16bits -> 31bits, so no overflow can occur in + any multiply. While accumulating we may overflow and underflow the + 32 bit scale often. However, if the gain does not exceed unity, + everything should work itself out, and the final result will be + OK, without any saturation logic. */ + /* Overflow is very much possible here, and we do nothing about it because + of the compute costs */ + /* 16 bit coeffs for the LMS give lousy results (maths good, actual sound + bad!), but 32 bit coeffs require some shifting. On balance 32 bit seems + best */ + echo_value = fir16(&ec->fir_state, tx); + + /* And the answer is..... */ + clean_rx = rx - echo_value; +//printf("echo is %" PRId32 "\n", echo_value); + /* That was the easy part. Now we need to adapt! */ + if (ec->nonupdate_dwell > 0) + ec->nonupdate_dwell--; + + /* Calculate short term power levels using very simple single pole IIRs */ + /* TODO: Is the nasty modulus approach the fastest, or would a real + tx*tx power calculation actually be faster? Using the squares + makes the numbers grow a lot! */ + ec->tx_power[3] += ((abs(tx) - ec->tx_power[3]) >> 5); + ec->tx_power[2] += ((tx * tx - ec->tx_power[2]) >> 8); + ec->tx_power[1] += ((tx * tx - ec->tx_power[1]) >> 5); + ec->tx_power[0] += ((tx * tx - ec->tx_power[0]) >> 3); + ec->rx_power[1] += ((rx * rx - ec->rx_power[1]) >> 6); + ec->rx_power[0] += ((rx * rx - ec->rx_power[0]) >> 3); + ec->clean_rx_power += ((clean_rx * clean_rx - ec->clean_rx_power) >> 6); + + score = 0; + /* If there is very little being transmitted, any attempt to train is + futile. We would either be training on the far end's noise or signal, + the channel's own noise, or our noise. Either way, this is hardly good + training, so don't do it (avoid trouble). */ + if (ec->tx_power[0] > MIN_TX_POWER_FOR_ADAPTION) { + /* If the received power is very low, either we are sending very little or + we are already well adapted. There is little point in trying to improve + the adaption under these circumstances, so don't do it (reduce the + compute load). */ + if (ec->tx_power[1] > ec->rx_power[0]) { + /* There is no (or little) far-end speech. */ + if (ec->nonupdate_dwell == 0) { + if (++ec->narrowband_count >= 160) { + ec->narrowband_count = 0; + score = narrowband_detect(ec); +//printf("Do the narrowband test %d at %d\n", score, ec->curr_pos); + if (score > 6) { + if (ec->narrowband_score == 0) + memcpy(ec->fir_taps16[3], ec->fir_taps16[(ec->tap_set + 1) % 3], + ec->taps * sizeof(int16_t)); + ec->narrowband_score += score; + } else { + if (ec->narrowband_score > 200) { +//printf("Revert to %d at %d\n", (ec->tap_set + 1)%3, sample_no); + memcpy(ec->fir_taps16[ec->tap_set], ec->fir_taps16[3], + ec->taps * sizeof(int16_t)); + memcpy(ec->fir_taps16[(ec->tap_set - 1) % 3], ec->fir_taps16[3], + ec->taps * sizeof(int16_t)); + for (i = 0; i < ec->taps; i++) + ec->fir_taps32[i] = ec->fir_taps16[3][i] << 15; + ec->tap_rotate_counter = 1600; + } + ec->narrowband_score = 0; + } + } + ec->dtd_onset = FALSE; + if (--ec->tap_rotate_counter <= 0) { +//printf("Rotate to %d at %d\n", ec->tap_set, sample_no); + ec->tap_rotate_counter = 1600; + ec->tap_set++; + if (ec->tap_set > 2) + ec->tap_set = 0; + ec->fir_state.coeffs = ec->fir_taps16[ec->tap_set]; + } + /* ... and we are not in the dwell time from previous speech. */ + if ((ec->adaption_mode & ECHO_CAN_USE_ADAPTION) && ec->narrowband_score == 0) { + //nsuppr = saturate((clean_rx << 16)/ec->tx_power[1]); + //nsuppr = clean_rx/ec->tx_power[1]; + /* If a sudden surge in signal level (e.g. the onset of a tone + burst) cause an abnormally high instantaneous to average + signal power ratio, we could kick the adaption badly in the + wrong direction. This is because the tx_power takes too long + to react and rise. We need to stop too rapid adaption to the + new signal. We normalise to a value derived from the + instantaneous signal if it exceeds the peak by too much. */ + nsuppr = clean_rx; + /* Divide isn't very quick, but the "where is the top bit" and shift + instructions are single cycle. */ + if (tx > 4 * ec->tx_power[3]) + i = top_bit(tx) - 8; + else + i = top_bit(ec->tx_power[3]) - 8; + if (i > 0) + nsuppr >>= i; + lms_adapt(ec, nsuppr); + } + } + //printf("%10d %10d %10d %10d %10d\n", rx, clean_rx, nsuppr, ec->tx_power[1], ec->rx_power[1]); + //printf("%.4f\n", (float) ec->rx_power[1]/(float) ec->clean_rx_power); + } else { + if (!ec->dtd_onset) { +//printf("Revert to %d at %d\n", (ec->tap_set + 1)%3, sample_no); + memcpy(ec->fir_taps16[ec->tap_set], ec->fir_taps16[(ec->tap_set + 1) % 3], + ec->taps * sizeof(int16_t)); + memcpy(ec->fir_taps16[(ec->tap_set - 1) % 3], + ec->fir_taps16[(ec->tap_set + 1) % 3], ec->taps * sizeof(int16_t)); + for (i = 0; i < ec->taps; i++) + ec->fir_taps32[i] = ec->fir_taps16[(ec->tap_set + 1) % 3][i] << 15; + ec->tap_rotate_counter = 1600; + ec->dtd_onset = TRUE; + } + ec->nonupdate_dwell = NONUPDATE_DWELL_TIME; + } + } + + if (ec->rx_power[1]) + ec->vad = (8000 * ec->clean_rx_power) / ec->rx_power[1]; + else + ec->vad = 0; + if (ec->rx_power[1] > 2048 * 2048 && ec->clean_rx_power > 4 * ec->rx_power[1]) { + /* The EC seems to be making things worse, instead of better. Zap it! */ + memset(ec->fir_taps32, 0, ec->taps * sizeof(int32_t)); + for (i = 0; i < 4; i++) + memset(ec->fir_taps16[i], 0, ec->taps * sizeof(int16_t)); + } +#if defined(XYZZY) + if ((ec->adaption_mode & ECHO_CAN_USE_SUPPRESSOR)) { + ec->supp_test1 += + (ec->fir_state.history[ec->curr_pos] - + ec->fir_state.history[(ec->curr_pos - 7) & ec->tap_mask]); + ec->supp_test2 += + (ec->fir_state.history[(ec->curr_pos - 24) & ec->tap_mask] - + ec->fir_state.history[(ec->curr_pos - 31) & ec->tap_mask]); + if (ec->supp_test1 > 42 && ec->supp_test2 > 42) + supp_change = 25; + else + supp_change = 50; + supp = supp_change + k1 * ec->supp1 + k2 * ec->supp2; + ec->supp2 = ec->supp1; + ec->supp1 = supp; + clean_rx *= (1 - supp); + } +#endif + + if ((ec->adaption_mode & ECHO_CAN_USE_NLP)) { + /* Non-linear processor - a fancy way to say "zap small signals, to avoid + residual echo due to (uLaw/ALaw) non-linearity in the channel.". */ + if (ec->rx_power[1] < 30000000) { + if (!ec->cng) { + ec->cng_level = ec->clean_rx_power; + ec->cng = TRUE; + } + if ((ec->adaption_mode & ECHO_CAN_USE_CNG)) { + /* Very elementary comfort noise generation */ + /* Just random numbers rolled off very vaguely Hoth-like */ + ec->cng_rndnum = 1664525U * ec->cng_rndnum + 1013904223U; + ec->cng_filter = ((ec->cng_rndnum & 0xFFFF) - 32768 + 5 * ec->cng_filter) >> 3; + clean_rx = (ec->cng_filter * ec->cng_level) >> 17; + /* TODO: A better CNG, with more accurate (tracking) spectral shaping! */ + } else { + clean_rx = 0; + } +//clean_rx = -16000; + } else { + ec->cng = FALSE; + } + } else { + ec->cng = FALSE; + } + +//printf("Narrowband score %4d %5d at %d\n", ec->narrowband_score, score, sample_no); + /* Roll around the rolling buffer */ + if (ec->curr_pos <= 0) + ec->curr_pos = ec->taps; + ec->curr_pos--; + return (int16_t) clean_rx; +} + +#endif //NOT_NEEDED +/*- End of function --------------------------------------------------------*/ +/*- End of file ------------------------------------------------------------*/ +#endif + +#include +#include +#include +#include +#include +#include +#include + +//#include "spandsp/telephony.h" +//#include "spandsp/tone_detect.h" +//#include "spandsp/tone_generate.h" +//#include "spandsp/super_tone_rx.h" +//#include "giova.h" + +#if !defined(M_PI) +/* C99 systems may not define M_PI */ +#define M_PI 3.14159265358979323846264338327 +#endif + +//#define USE_3DNOW + +#define DEFAULT_DTMF_TX_LEVEL -10 +#define DEFAULT_DTMF_TX_ON_TIME 50 +#define DEFAULT_DTMF_TX_OFF_TIME 55 + +#define DTMF_THRESHOLD 8.0e7f +#define DTMF_NORMAL_TWIST 6.3f /* 8dB */ +#define DTMF_REVERSE_TWIST 2.5f /* 4dB */ +#define DTMF_RELATIVE_PEAK_ROW 6.3f /* 8dB */ +#define DTMF_RELATIVE_PEAK_COL 6.3f /* 8dB */ +#define DTMF_TO_TOTAL_ENERGY 42.0f + +static const float dtmf_row[] = { + 697.0f, 770.0f, 852.0f, 941.0f +}; +static const float dtmf_col[] = { + 1209.0f, 1336.0f, 1477.0f, 1633.0f +}; + +static const char dtmf_positions[] = "123A" "456B" "789C" "*0#D"; + +static goertzel_descriptor_t dtmf_detect_row[4]; +static goertzel_descriptor_t dtmf_detect_col[4]; + +// +//static int dtmf_tx_inited = 0; +//static tone_gen_descriptor_t dtmf_digit_tones[16]; + +#if defined(USE_3DNOW) +static __inline__ void _dtmf_goertzel_update(goertzel_state_t * s, float x[], int samples) +{ + int n; + float v; + int i; + float vv[16]; + + vv[4] = s[0].v2; + vv[5] = s[1].v2; + vv[6] = s[2].v2; + vv[7] = s[3].v2; + vv[8] = s[0].v3; + vv[9] = s[1].v3; + vv[10] = s[2].v3; + vv[11] = s[3].v3; + vv[12] = s[0].fac; + vv[13] = s[1].fac; + vv[14] = s[2].fac; + vv[15] = s[3].fac; + + //v1 = s->v2; + //s->v2 = s->v3; + //s->v3 = s->fac*s->v2 - v1 + x[0]; + + __asm__ __volatile__(" femms;\n" " movq 16(%%edx),%%mm2;\n" + " movq 24(%%edx),%%mm3;\n" " movq 32(%%edx),%%mm4;\n" + " movq 40(%%edx),%%mm5;\n" " movq 48(%%edx),%%mm6;\n" + " movq 56(%%edx),%%mm7;\n" " jmp 1f;\n" + " .align 32;\n" " 1: ;\n" " prefetch (%%eax);\n" + " movq %%mm3,%%mm1;\n" " movq %%mm2,%%mm0;\n" + " movq %%mm5,%%mm3;\n" " movq %%mm4,%%mm2;\n" + " pfmul %%mm7,%%mm5;\n" " pfmul %%mm6,%%mm4;\n" + " pfsub %%mm1,%%mm5;\n" " pfsub %%mm0,%%mm4;\n" + " movq (%%eax),%%mm0;\n" " movq %%mm0,%%mm1;\n" + " punpckldq %%mm0,%%mm1;\n" " add $4,%%eax;\n" + " pfadd %%mm1,%%mm5;\n" " pfadd %%mm1,%%mm4;\n" + " dec %%ecx;\n" " jnz 1b;\n" + " movq %%mm2,16(%%edx);\n" " movq %%mm3,24(%%edx);\n" + " movq %%mm4,32(%%edx);\n" " movq %%mm5,40(%%edx);\n" + " femms;\n"::"c"(samples), "a"(x), "d"(vv) + :"memory", "eax", "ecx"); + + s[0].v2 = vv[4]; + s[1].v2 = vv[5]; + s[2].v2 = vv[6]; + s[3].v2 = vv[7]; + s[0].v3 = vv[8]; + s[1].v3 = vv[9]; + s[2].v3 = vv[10]; + s[3].v3 = vv[11]; +} + +/*- End of function --------------------------------------------------------*/ +#endif + +int dtmf_rx(dtmf_rx_state_t * s, const int16_t amp[], int samples) +{ + float row_energy[4]; + float col_energy[4]; + float famp; + float v1; + int i; + int j; + int sample; + int best_row; + int best_col; + int limit; + uint8_t hit; + + hit = 0; + for (sample = 0; sample < samples; sample = limit) { + /* The block length is optimised to meet the DTMF specs. */ + if ((samples - sample) >= (102 - s->current_sample)) + limit = sample + (102 - s->current_sample); + else + limit = samples; +#if defined(USE_3DNOW) + _dtmf_goertzel_update(s->row_out, amp + sample, limit - sample); + _dtmf_goertzel_update(s->col_out, amp + sample, limit - sample); +#else + /* The following unrolled loop takes only 35% (rough estimate) of the + time of a rolled loop on the machine on which it was developed */ + for (j = sample; j < limit; j++) { + famp = amp[j]; + if (s->filter_dialtone) { + /* Sharp notches applied at 350Hz and 440Hz - the two common dialtone frequencies. + These are rather high Q, to achieve the required narrowness, without using lots of + sections. */ + v1 = 0.98356f * famp + 1.8954426f * s->z350_1 - 0.9691396f * s->z350_2; + famp = v1 - 1.9251480f * s->z350_1 + s->z350_2; + s->z350_2 = s->z350_1; + s->z350_1 = v1; + + v1 = 0.98456f * famp + 1.8529543f * s->z440_1 - 0.9691396f * s->z440_2; + famp = v1 - 1.8819938f * s->z440_1 + s->z440_2; + s->z440_2 = s->z440_1; + s->z440_1 = v1; + } + s->energy += famp * famp; + /* With GCC 2.95, the following unrolled code seems to take about 35% + (rough estimate) as long as a neat little 0-3 loop */ + v1 = s->row_out[0].v2; + s->row_out[0].v2 = s->row_out[0].v3; + s->row_out[0].v3 = s->row_out[0].fac * s->row_out[0].v2 - v1 + famp; + + v1 = s->col_out[0].v2; + s->col_out[0].v2 = s->col_out[0].v3; + s->col_out[0].v3 = s->col_out[0].fac * s->col_out[0].v2 - v1 + famp; + + v1 = s->row_out[1].v2; + s->row_out[1].v2 = s->row_out[1].v3; + s->row_out[1].v3 = s->row_out[1].fac * s->row_out[1].v2 - v1 + famp; + + v1 = s->col_out[1].v2; + s->col_out[1].v2 = s->col_out[1].v3; + s->col_out[1].v3 = s->col_out[1].fac * s->col_out[1].v2 - v1 + famp; + + v1 = s->row_out[2].v2; + s->row_out[2].v2 = s->row_out[2].v3; + s->row_out[2].v3 = s->row_out[2].fac * s->row_out[2].v2 - v1 + famp; + + v1 = s->col_out[2].v2; + s->col_out[2].v2 = s->col_out[2].v3; + s->col_out[2].v3 = s->col_out[2].fac * s->col_out[2].v2 - v1 + famp; + + v1 = s->row_out[3].v2; + s->row_out[3].v2 = s->row_out[3].v3; + s->row_out[3].v3 = s->row_out[3].fac * s->row_out[3].v2 - v1 + famp; + + v1 = s->col_out[3].v2; + s->col_out[3].v2 = s->col_out[3].v3; + s->col_out[3].v3 = s->col_out[3].fac * s->col_out[3].v2 - v1 + famp; + } +#endif + s->current_sample += (limit - sample); + if (s->current_sample < 102) + continue; + + /* We are at the end of a DTMF detection block */ + /* Find the peak row and the peak column */ + row_energy[0] = goertzel_result(&s->row_out[0]); + best_row = 0; + col_energy[0] = goertzel_result(&s->col_out[0]); + best_col = 0; + + for (i = 1; i < 4; i++) { + row_energy[i] = goertzel_result(&s->row_out[i]); + if (row_energy[i] > row_energy[best_row]) + best_row = i; + col_energy[i] = goertzel_result(&s->col_out[i]); + if (col_energy[i] > col_energy[best_col]) + best_col = i; + } + hit = 0; + /* Basic signal level test and the twist test */ + if (row_energy[best_row] >= DTMF_THRESHOLD && col_energy[best_col] >= DTMF_THRESHOLD + && col_energy[best_col] < row_energy[best_row] * s->reverse_twist + && col_energy[best_col] * s->normal_twist > row_energy[best_row]) { + /* Relative peak test ... */ + for (i = 0; i < 4; i++) { + if ((i != best_col + && col_energy[i] * DTMF_RELATIVE_PEAK_COL > col_energy[best_col]) + || (i != best_row + && row_energy[i] * DTMF_RELATIVE_PEAK_ROW > row_energy[best_row])) { + break; + } + } + /* ... and fraction of total energy test */ + if (i >= 4 + && (row_energy[best_row] + col_energy[best_col]) > + DTMF_TO_TOTAL_ENERGY * s->energy) { + hit = dtmf_positions[(best_row << 2) + best_col]; + } + } + /* The logic in the next test should ensure the following for different successive hit patterns: + -----ABB = start of digit B. + ----B-BB = start of digit B + ----A-BB = start of digit B + BBBBBABB = still in digit B. + BBBBBB-- = end of digit B + BBBBBBC- = end of digit B + BBBBACBB = B ends, then B starts again. + BBBBBBCC = B ends, then C starts. + BBBBBCDD = B ends, then D starts. + This can work with: + - Back to back differing digits. Back-to-back digits should + not happen. The spec. says there should be a gap between digits. + However, many real phones do not impose a gap, and rolling across + the keypad can produce little or no gap. + - It tolerates nasty phones that give a very wobbly start to a digit. + - VoIP can give sample slips. The phase jumps that produces will cause + the block it is in to give no detection. This logic will ride over a + single missed block, and not falsely declare a second digit. If the + hiccup happens in the wrong place on a minimum length digit, however + we would still fail to detect that digit. Could anything be done to + deal with that? Packet loss is clearly a no-go zone. + Note this is only relevant to VoIP using A-law, u-law or similar. + Low bit rate codecs scramble DTMF too much for it to be recognised, + and often slip in units larger than a sample. */ + if (hit != s->in_digit) { + if (s->last_hit != s->in_digit) { + /* We have two successive indications that something has changed. */ + /* To declare digit on, the hits must agree. Otherwise we declare tone off. */ + hit = (hit && hit == s->last_hit) ? hit : 0; +#if 0 + if (s->realtime_callback) { + /* Avoid reporting multiple no digit conditions on flaky hits */ + if (s->in_digit || hit) { + i = (s->in_digit + && !hit) ? -99 : rint(log10f(s->energy) * 10.0f - 20.08f - 90.30F + + DBM0_MAX_POWER); + s->realtime_callback(s->realtime_callback_data, hit, i); + } + } else { +#endif + if (hit) { + if (s->current_digits < MAX_DTMF_DIGITS) { + s->digits[s->current_digits++] = (char) hit; + s->digits[s->current_digits] = '\0'; + if (s->callback) { + s->callback(s->callback_data, s->digits, s->current_digits); + s->current_digits = 0; + } + } else { + s->lost_digits++; + } + } +#if 0 + } +#endif + s->in_digit = hit; + } + } + s->last_hit = hit; + /* Reinitialise the detector for the next block */ + for (i = 0; i < 4; i++) { + goertzel_reset(&s->row_out[i]); + goertzel_reset(&s->col_out[i]); + } + s->energy = 0.0f; + s->current_sample = 0; + } + if (s->current_digits && s->callback) { + s->callback(s->callback_data, s->digits, s->current_digits); + s->digits[0] = '\0'; + s->current_digits = 0; + } + return 0; +} + +/*- End of function --------------------------------------------------------*/ + +size_t dtmf_rx_get(dtmf_rx_state_t * s, char *buf, int max) +{ + if (max > s->current_digits) + max = s->current_digits; + if (max > 0) { + memcpy(buf, s->digits, max); + memmove(s->digits, s->digits + max, s->current_digits - max); + s->current_digits -= max; + } + buf[max] = '\0'; + return max; +} + +/*- End of function --------------------------------------------------------*/ + +#if 0 +void dtmf_rx_set_realtime_callback(dtmf_rx_state_t * s, tone_report_func_t callback, + void *user_data) +{ + s->realtime_callback = callback; + s->realtime_callback_data = user_data; +} +#endif +/*- End of function --------------------------------------------------------*/ + +void dtmf_rx_parms(dtmf_rx_state_t * s, int filter_dialtone, int twist, int reverse_twist) +{ + if (filter_dialtone >= 0) { + s->z350_1 = 0.0f; + s->z350_2 = 0.0f; + s->z440_1 = 0.0f; + s->z440_2 = 0.0f; + s->filter_dialtone = filter_dialtone; + } + if (twist >= 0) + s->normal_twist = powf(10.0f, twist / 10.0f); + if (reverse_twist >= 0) + s->reverse_twist = powf(10.0f, reverse_twist / 10.0f); +} + +/*- End of function --------------------------------------------------------*/ + +dtmf_rx_state_t *dtmf_rx_init(dtmf_rx_state_t * s, dtmf_rx_callback_t callback, + void *user_data) +{ + int i; + static int initialised = 0; + + s->callback = callback; + s->callback_data = user_data; + s->realtime_callback = NULL; + s->realtime_callback_data = NULL; + s->filter_dialtone = 0; + s->normal_twist = DTMF_NORMAL_TWIST; + s->reverse_twist = DTMF_REVERSE_TWIST; + + s->in_digit = 0; + s->last_hit = 0; + + if (!initialised) { + for (i = 0; i < 4; i++) { + make_goertzel_descriptor(&dtmf_detect_row[i], dtmf_row[i], 102); + make_goertzel_descriptor(&dtmf_detect_col[i], dtmf_col[i], 102); + } + initialised = 1; + } + for (i = 0; i < 4; i++) { + goertzel_init(&s->row_out[i], &dtmf_detect_row[i]); + goertzel_init(&s->col_out[i], &dtmf_detect_col[i]); + } + s->energy = 0.0f; + s->current_sample = 0; + s->lost_digits = 0; + s->current_digits = 0; + s->digits[0] = '\0'; + return s; +} + +/*- End of function --------------------------------------------------------*/ + +#if 0 +static void dtmf_tx_initialise(void) +{ + int row; + int col; + + if (dtmf_tx_inited) + return; + for (row = 0; row < 4; row++) { + for (col = 0; col < 4; col++) { + make_tone_gen_descriptor(&dtmf_digit_tones[row * 4 + col], (int) dtmf_row[row], + DEFAULT_DTMF_TX_LEVEL, (int) dtmf_col[col], + DEFAULT_DTMF_TX_LEVEL, DEFAULT_DTMF_TX_ON_TIME, + DEFAULT_DTMF_TX_OFF_TIME, 0, 0, FALSE); + } + } + dtmf_tx_inited = TRUE; +} + +/*- End of function --------------------------------------------------------*/ + +int dtmf_tx(dtmf_tx_state_t * s, int16_t amp[], int max_samples) +{ + int len; + size_t dig; + char *cp; + + len = 0; + if (s->tones.current_section >= 0) { + /* Deal with the fragment left over from last time */ + len = tone_gen(&(s->tones), amp, max_samples); + } + dig = 0; + while (dig < s->current_digits && len < max_samples) { + /* Step to the next digit */ + if ((cp = strchr(dtmf_positions, s->digits[dig++])) == NULL) + continue; + tone_gen_init(&(s->tones), &(s->tone_descriptors[cp - dtmf_positions])); + len += tone_gen(&(s->tones), amp + len, max_samples - len); + } + if (dig) { + /* Shift out the consumed digits */ + s->current_digits -= dig; + memmove(s->digits, s->digits + dig, s->current_digits); + } + return len; +} + +/*- End of function --------------------------------------------------------*/ + +size_t dtmf_tx_put(dtmf_tx_state_t * s, const char *digits) +{ + size_t len; + + /* This returns the number of characters that would not fit in the buffer. + The buffer will only be loaded if the whole string of digits will fit, + in which case zero is returned. */ + if ((len = strlen(digits)) > 0) { + if (s->current_digits + len <= MAX_DTMF_DIGITS) { + memcpy(s->digits + s->current_digits, digits, len); + s->current_digits += len; + len = 0; + } else { + len = MAX_DTMF_DIGITS - s->current_digits; + } + } + return len; +} + +/*- End of function --------------------------------------------------------*/ + +dtmf_tx_state_t *dtmf_tx_init(dtmf_tx_state_t * s) +{ + if (!dtmf_tx_inited) + dtmf_tx_initialise(); + s->tone_descriptors = dtmf_digit_tones; + tone_gen_init(&(s->tones), &dtmf_digit_tones[0]); + s->current_sample = 0; + s->current_digits = 0; + s->tones.current_section = -1; + return s; +} +#endif //NO TX +/*- End of function --------------------------------------------------------*/ +/*- End of file ------------------------------------------------------------*/ + +void make_goertzel_descriptor(goertzel_descriptor_t * t, float freq, int samples) +{ + //t->fac = 2.0f*cosf(2.0f*M_PI*(freq/(float) SAMPLE_RATE)); + t->fac = 2.0f * cosf(2.0f * M_PI * (freq / (float) 8000)); + t->samples = samples; +} + +/*- End of function --------------------------------------------------------*/ + +goertzel_state_t *goertzel_init(goertzel_state_t * s, goertzel_descriptor_t * t) +{ + if (s || (s = malloc(sizeof(goertzel_state_t)))) { + s->v2 = s->v3 = 0.0; + s->fac = t->fac; + s->samples = t->samples; + s->current_sample = 0; + } + return s; +} + +/*- End of function --------------------------------------------------------*/ + +void goertzel_reset(goertzel_state_t * s) +{ + s->v2 = s->v3 = 0.0; + s->current_sample = 0; +} + +/*- End of function --------------------------------------------------------*/ + +int goertzel_update(goertzel_state_t * s, const int16_t amp[], int samples) +{ + int i; + float v1; + + if (samples > s->samples - s->current_sample) + samples = s->samples - s->current_sample; + for (i = 0; i < samples; i++) { + v1 = s->v2; + s->v2 = s->v3; + s->v3 = s->fac * s->v2 - v1 + amp[i]; + } + s->current_sample += samples; + return samples; +} + +/*- End of function --------------------------------------------------------*/ + +float goertzel_result(goertzel_state_t * s) +{ + float v1; + + /* Push a zero through the process to finish things off. */ + v1 = s->v2; + s->v2 = s->v3; + s->v3 = s->fac * s->v2 - v1; + /* Now calculate the non-recursive side of the filter. */ + /* The result here is not scaled down to allow for the magnification + effect of the filter (the usual DFT magnification effect). */ + return s->v3 * s->v3 + s->v2 * s->v2 - s->v2 * s->v3 * s->fac; +} + +/*- End of function --------------------------------------------------------*/ +/*- End of file ------------------------------------------------------------*/ diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/celliax_spandsp.h b/src/mod/endpoints/mod_gsmopen/asterisk/celliax_spandsp.h new file mode 100644 index 0000000000..2fed42d089 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/celliax_spandsp.h @@ -0,0 +1,1028 @@ + +/* + * SpanDSP - a series of DSP components for telephony + * + * bit_operations.h - Various bit level operations, such as bit reversal + * + * Written by Steve Underwood + * + * Copyright (C) 2006 Steve Underwood + * + * All rights reserved. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2, as + * published by the Free Software Foundation. + * + * 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., 675 Mass Ave, Cambridge, MA 02139, USA. + * + * $Id: bit_operations.h,v 1.15 2007/02/23 13:16:13 steveu Exp $ + */ + +/*! \file */ + +#ifndef _CELLIAX_SPANDSP_H +#define _CELLIAX_SPANDSP_H + +#include + +/*! \brief Find the bit position of the highest set bit in a word + \param bits The word to be searched + \return The bit number of the highest set bit, or -1 if the word is zero. */ +static __inline__ int top_bit(unsigned int bits) +{ + int res; + +#if defined(__i386__) || defined(__x86_64__) +__asm__(" xorl %[res],%[res];\n" " decl %[res];\n" " bsrl %[bits],%[res]\n":[res] "=&r" + (res) +: [bits] "rm"(bits)); + return res; +#elif defined(__ppc__) || defined(__powerpc__) +__asm__("cntlzw %[res],%[bits];\n":[res] "=&r"(res) +: [bits] "r"(bits)); + return 31 - res; +#else + if (bits == 0) + return -1; + res = 0; + if (bits & 0xFFFF0000) { + bits &= 0xFFFF0000; + res += 16; + } + if (bits & 0xFF00FF00) { + bits &= 0xFF00FF00; + res += 8; + } + if (bits & 0xF0F0F0F0) { + bits &= 0xF0F0F0F0; + res += 4; + } + if (bits & 0xCCCCCCCC) { + bits &= 0xCCCCCCCC; + res += 2; + } + if (bits & 0xAAAAAAAA) { + bits &= 0xAAAAAAAA; + res += 1; + } + return res; +#endif +} + +/*- End of function --------------------------------------------------------*/ + +/*! \brief Find the bit position of the lowest set bit in a word + \param bits The word to be searched + \return The bit number of the lowest set bit, or -1 if the word is zero. */ +static __inline__ int bottom_bit(unsigned int bits) +{ + int res; + +#if defined(__i386__) || defined(__x86_64__) +__asm__(" xorl %[res],%[res];\n" " decl %[res];\n" " bsfl %[bits],%[res]\n":[res] "=&r" + (res) +: [bits] "rm"(bits)); + return res; +#else + if (bits == 0) + return -1; + res = 31; + if (bits & 0x0000FFFF) { + bits &= 0x0000FFFF; + res -= 16; + } + if (bits & 0x00FF00FF) { + bits &= 0x00FF00FF; + res -= 8; + } + if (bits & 0x0F0F0F0F) { + bits &= 0x0F0F0F0F; + res -= 4; + } + if (bits & 0x33333333) { + bits &= 0x33333333; + res -= 2; + } + if (bits & 0x55555555) { + bits &= 0x55555555; + res -= 1; + } + return res; +#endif +} + +/*- End of function --------------------------------------------------------*/ + +/*! \brief Bit reverse a byte. + \param data The byte to be reversed. + \return The bit reversed version of data. */ +static __inline__ uint8_t bit_reverse8(uint8_t x) +{ +#if defined(__i386__) || defined(__x86_64__) || defined(__ppc__) || defined(__powerpc__) + /* If multiply is fast */ + return ((x * 0x0802U & 0x22110U) | (x * 0x8020U & 0x88440U)) * 0x10101U >> 16; +#else + /* If multiply is slow, but we have a barrel shifter */ + x = (x >> 4) | (x << 4); + x = ((x & 0xCC) >> 2) | ((x & 0x33) << 2); + return ((x & 0xAA) >> 1) | ((x & 0x55) << 1); +#endif +} + +/*- End of function --------------------------------------------------------*/ + +/*! \brief Bit reverse a 16 bit word. + \param data The word to be reversed. + \return The bit reversed version of data. */ +uint16_t bit_reverse16(uint16_t data); + +/*! \brief Bit reverse a 32 bit word. + \param data The word to be reversed. + \return The bit reversed version of data. */ +uint32_t bit_reverse32(uint32_t data); + +/*! \brief Bit reverse each of the four bytes in a 32 bit word. + \param data The word to be reversed. + \return The bit reversed version of data. */ +uint32_t bit_reverse_4bytes(uint32_t data); + +#if defined(__x86_64__) +/*! \brief Bit reverse each of the eight bytes in a 64 bit word. + \param data The word to be reversed. + \return The bit reversed version of data. */ +uint64_t bit_reverse_8bytes(uint64_t data); +#endif + +/*! \brief Bit reverse each bytes in a buffer. + \param to The buffer to place the reversed data in. + \param from The buffer containing the data to be reversed. + \param The length of the data in the buffer. */ +void bit_reverse(uint8_t to[], const uint8_t from[], int len); + +/*! \brief Find the number of set bits in a 32 bit word. + \param x The word to be searched. + \return The number of set bits. */ +int one_bits32(uint32_t x); + +/*! \brief Create a mask as wide as the number in a 32 bit word. + \param x The word to be searched. + \return The mask. */ +uint32_t make_mask32(uint32_t x); + +/*! \brief Create a mask as wide as the number in a 16 bit word. + \param x The word to be searched. + \return The mask. */ +uint16_t make_mask16(uint16_t x); + +/*! \brief Find the least significant one in a word, and return a word + with just that bit set. + \param x The word to be searched. + \return The word with the single set bit. */ +static __inline__ uint32_t least_significant_one32(uint32_t x) +{ + return (x & (-(int32_t) x)); +} + +/*- End of function --------------------------------------------------------*/ + +/*! \brief Find the most significant one in a word, and return a word + with just that bit set. + \param x The word to be searched. + \return The word with the single set bit. */ +static __inline__ uint32_t most_significant_one32(uint32_t x) +{ +#if defined(__i386__) || defined(__x86_64__) || defined(__ppc__) || defined(__powerpc__) + return 1 << top_bit(x); +#else + x = make_mask32(x); + return (x ^ (x >> 1)); +#endif +} + +/*- End of function --------------------------------------------------------*/ + +/*! \brief Find the parity of a byte. + \param x The byte to be checked. + \return 1 for odd, or 0 for even. */ +static __inline__ int parity8(uint8_t x) +{ + x = (x ^ (x >> 4)) & 0x0F; + return (0x6996 >> x) & 1; +} + +/*- End of function --------------------------------------------------------*/ + +/*! \brief Find the parity of a 16 bit word. + \param x The word to be checked. + \return 1 for odd, or 0 for even. */ +static __inline__ int parity16(uint16_t x) +{ + x ^= (x >> 8); + x = (x ^ (x >> 4)) & 0x0F; + return (0x6996 >> x) & 1; +} + +/*- End of function --------------------------------------------------------*/ + +/*! \brief Find the parity of a 32 bit word. + \param x The word to be checked. + \return 1 for odd, or 0 for even. */ +static __inline__ int parity32(uint32_t x) +{ + x ^= (x >> 16); + x ^= (x >> 8); + x = (x ^ (x >> 4)) & 0x0F; + return (0x6996 >> x) & 1; +} + +/*- End of function --------------------------------------------------------*/ + +/*- End of file ------------------------------------------------------------*/ +/* + * SpanDSP - a series of DSP components for telephony + * + * fir.h - General telephony FIR routines + * + * Written by Steve Underwood + * + * Copyright (C) 2002 Steve Underwood + * + * All rights reserved. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2, as + * published by the Free Software Foundation. + * + * 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., 675 Mass Ave, Cambridge, MA 02139, USA. + * + * $Id: fir.h,v 1.8 2006/10/24 13:45:28 steveu Exp $ + */ + +/*! \page fir_page FIR filtering +\section fir_page_sec_1 What does it do? +???. + +\section fir_page_sec_2 How does it work? +???. +*/ + +#if 0 +#if defined(USE_MMX) || defined(USE_SSE2) +#include "mmx.h" +#endif + +/*! + 16 bit integer FIR descriptor. This defines the working state for a single + instance of an FIR filter using 16 bit integer coefficients. +*/ +typedef struct { + int taps; + int curr_pos; + const int16_t *coeffs; + int16_t *history; +} fir16_state_t; + +/*! + 32 bit integer FIR descriptor. This defines the working state for a single + instance of an FIR filter using 32 bit integer coefficients, and filtering + 16 bit integer data. +*/ +typedef struct { + int taps; + int curr_pos; + const int32_t *coeffs; + int16_t *history; +} fir32_state_t; + +/*! + Floating point FIR descriptor. This defines the working state for a single + instance of an FIR filter using floating point coefficients and data. +*/ +typedef struct { + int taps; + int curr_pos; + const float *coeffs; + float *history; +} fir_float_state_t; + +static __inline__ const int16_t *fir16_create(fir16_state_t * fir, const int16_t * coeffs, + int taps) +{ + fir->taps = taps; + fir->curr_pos = taps - 1; + fir->coeffs = coeffs; +#if defined(USE_MMX) || defined(USE_SSE2) + if ((fir->history = malloc(2 * taps * sizeof(int16_t)))) + memset(fir->history, 0, 2 * taps * sizeof(int16_t)); +#else + if ((fir->history = (int16_t *) malloc(taps * sizeof(int16_t)))) + memset(fir->history, 0, taps * sizeof(int16_t)); +#endif + return fir->history; +} + +/*- End of function --------------------------------------------------------*/ + +static __inline__ void fir16_flush(fir16_state_t * fir) +{ +#if defined(USE_MMX) || defined(USE_SSE2) + memset(fir->history, 0, 2 * fir->taps * sizeof(int16_t)); +#else + memset(fir->history, 0, fir->taps * sizeof(int16_t)); +#endif +} + +/*- End of function --------------------------------------------------------*/ + +static __inline__ void fir16_free(fir16_state_t * fir) +{ + free(fir->history); +} + +/*- End of function --------------------------------------------------------*/ + +static __inline__ int16_t fir16(fir16_state_t * fir, int16_t sample) +{ + int i; + int32_t y; +#if defined(USE_MMX) + mmx_t *mmx_coeffs; + mmx_t *mmx_hist; + + fir->history[fir->curr_pos] = sample; + fir->history[fir->curr_pos + fir->taps] = sample; + + mmx_coeffs = (mmx_t *) fir->coeffs; + mmx_hist = (mmx_t *) & fir->history[fir->curr_pos]; + i = fir->taps; + pxor_r2r(mm4, mm4); + /* 8 samples per iteration, so the filter must be a multiple of 8 long. */ + while (i > 0) { + movq_m2r(mmx_coeffs[0], mm0); + movq_m2r(mmx_coeffs[1], mm2); + movq_m2r(mmx_hist[0], mm1); + movq_m2r(mmx_hist[1], mm3); + mmx_coeffs += 2; + mmx_hist += 2; + pmaddwd_r2r(mm1, mm0); + pmaddwd_r2r(mm3, mm2); + paddd_r2r(mm0, mm4); + paddd_r2r(mm2, mm4); + i -= 8; + } + movq_r2r(mm4, mm0); + psrlq_i2r(32, mm0); + paddd_r2r(mm0, mm4); + movd_r2m(mm4, y); + emms(); +#elif defined(USE_SSE2) + xmm_t *xmm_coeffs; + xmm_t *xmm_hist; + + fir->history[fir->curr_pos] = sample; + fir->history[fir->curr_pos + fir->taps] = sample; + + xmm_coeffs = (xmm_t *) fir->coeffs; + xmm_hist = (xmm_t *) & fir->history[fir->curr_pos]; + i = fir->taps; + pxor_r2r(xmm4, xmm4); + /* 16 samples per iteration, so the filter must be a multiple of 16 long. */ + while (i > 0) { + movdqu_m2r(xmm_coeffs[0], xmm0); + movdqu_m2r(xmm_coeffs[1], xmm2); + movdqu_m2r(xmm_hist[0], xmm1); + movdqu_m2r(xmm_hist[1], xmm3); + xmm_coeffs += 2; + xmm_hist += 2; + pmaddwd_r2r(xmm1, xmm0); + pmaddwd_r2r(xmm3, xmm2); + paddd_r2r(xmm0, xmm4); + paddd_r2r(xmm2, xmm4); + i -= 16; + } + movdqa_r2r(xmm4, xmm0); + psrldq_i2r(8, xmm0); + paddd_r2r(xmm0, xmm4); + movdqa_r2r(xmm4, xmm0); + psrldq_i2r(4, xmm0); + paddd_r2r(xmm0, xmm4); + movd_r2m(xmm4, y); +#else + int offset1; + int offset2; + + fir->history[fir->curr_pos] = sample; + + offset2 = fir->curr_pos; + offset1 = fir->taps - offset2; + y = 0; + for (i = fir->taps - 1; i >= offset1; i--) + y += fir->coeffs[i] * fir->history[i - offset1]; + for (; i >= 0; i--) + y += fir->coeffs[i] * fir->history[i + offset2]; +#endif + if (fir->curr_pos <= 0) + fir->curr_pos = fir->taps; + fir->curr_pos--; + return (int16_t) (y >> 15); +} + +/*- End of function --------------------------------------------------------*/ + +static __inline__ const int16_t *fir32_create(fir32_state_t * fir, const int32_t * coeffs, + int taps) +{ + fir->taps = taps; + fir->curr_pos = taps - 1; + fir->coeffs = coeffs; + fir->history = (int16_t *) malloc(taps * sizeof(int16_t)); + if (fir->history) + memset(fir->history, '\0', taps * sizeof(int16_t)); + return fir->history; +} + +/*- End of function --------------------------------------------------------*/ + +static __inline__ void fir32_flush(fir32_state_t * fir) +{ + memset(fir->history, 0, fir->taps * sizeof(int16_t)); +} + +/*- End of function --------------------------------------------------------*/ + +static __inline__ void fir32_free(fir32_state_t * fir) +{ + free(fir->history); +} + +/*- End of function --------------------------------------------------------*/ + +static __inline__ int16_t fir32(fir32_state_t * fir, int16_t sample) +{ + int i; + int32_t y; + int offset1; + int offset2; + + fir->history[fir->curr_pos] = sample; + offset2 = fir->curr_pos; + offset1 = fir->taps - offset2; + y = 0; + for (i = fir->taps - 1; i >= offset1; i--) + y += fir->coeffs[i] * fir->history[i - offset1]; + for (; i >= 0; i--) + y += fir->coeffs[i] * fir->history[i + offset2]; + if (fir->curr_pos <= 0) + fir->curr_pos = fir->taps; + fir->curr_pos--; + return (int16_t) (y >> 15); +} + +/*- End of function --------------------------------------------------------*/ + +static __inline__ const float *fir_float_create(fir_float_state_t * fir, + const float *coeffs, int taps) +{ + fir->taps = taps; + fir->curr_pos = taps - 1; + fir->coeffs = coeffs; + fir->history = (float *) malloc(taps * sizeof(float)); + if (fir->history) + memset(fir->history, '\0', taps * sizeof(float)); + return fir->history; +} + +/*- End of function --------------------------------------------------------*/ + +static __inline__ void fir_float_free(fir_float_state_t * fir) +{ + free(fir->history); +} + +/*- End of function --------------------------------------------------------*/ + +static __inline__ int16_t fir_float(fir_float_state_t * fir, int16_t sample) +{ + int i; + float y; + int offset1; + int offset2; + + fir->history[fir->curr_pos] = sample; + + offset2 = fir->curr_pos; + offset1 = fir->taps - offset2; + y = 0; + for (i = fir->taps - 1; i >= offset1; i--) + y += fir->coeffs[i] * fir->history[i - offset1]; + for (; i >= 0; i--) + y += fir->coeffs[i] * fir->history[i + offset2]; + if (fir->curr_pos <= 0) + fir->curr_pos = fir->taps; + fir->curr_pos--; + return (int16_t) y; +} + +/*- End of function --------------------------------------------------------*/ +#endif + +/*- End of file ------------------------------------------------------------*/ + +/* + * SpanDSP - a series of DSP components for telephony + * + * echo.h - An echo cancellor, suitable for electrical and acoustic + * cancellation. This code does not currently comply with + * any relevant standards (e.g. G.164/5/7/8). + * + * Written by Steve Underwood + * + * Copyright (C) 2001 Steve Underwood + * + * Based on a bit from here, a bit from there, eye of toad, + * ear of bat, etc - plus, of course, my own 2 cents. + * + * All rights reserved. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2, as + * published by the Free Software Foundation. + * + * 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., 675 Mass Ave, Cambridge, MA 02139, USA. + * + * $Id: echo.h,v 1.9 2006/10/24 13:45:28 steveu Exp $ + */ + +/*! \file */ + +/*! \page echo_can_page Line echo cancellation for voice + +\section echo_can_page_sec_1 What does it do? +This module aims to provide G.168-2002 compliant echo cancellation, to remove +electrical echoes (e.g. from 2-4 wire hybrids) from voice calls. + +\section echo_can_page_sec_2 How does it work? +The heart of the echo cancellor is FIR filter. This is adapted to match the echo +impulse response of the telephone line. It must be long enough to adequately cover +the duration of that impulse response. The signal transmitted to the telephone line +is passed through the FIR filter. Once the FIR is properly adapted, the resulting +output is an estimate of the echo signal received from the line. This is subtracted +from the received signal. The result is an estimate of the signal which originated +at the far end of the line, free from echos of our own transmitted signal. + +The least mean squares (LMS) algorithm is attributed to Widrow and Hoff, and was +introduced in 1960. It is the commonest form of filter adaption used in things +like modem line equalisers and line echo cancellers. There it works very well. +However, it only works well for signals of constant amplitude. It works very poorly +for things like speech echo cancellation, where the signal level varies widely. +This is quite easy to fix. If the signal level is normalised - similar to applying +AGC - LMS can work as well for a signal of varying amplitude as it does for a modem +signal. This normalised least mean squares (NLMS) algorithm is the commonest one used +for speech echo cancellation. Many other algorithms exist - e.g. RLS (essentially +the same as Kalman filtering), FAP, etc. Some perform significantly better than NLMS. +However, factors such as computational complexity and patents favour the use of NLMS. + +A simple refinement to NLMS can improve its performance with speech. NLMS tends +to adapt best to the strongest parts of a signal. If the signal is white noise, +the NLMS algorithm works very well. However, speech has more low frequency than +high frequency content. Pre-whitening (i.e. filtering the signal to flatten +its spectrum) the echo signal improves the adapt rate for speech, and ensures the +final residual signal is not heavily biased towards high frequencies. A very low +complexity filter is adequate for this, so pre-whitening adds little to the +compute requirements of the echo canceller. + +An FIR filter adapted using pre-whitened NLMS performs well, provided certain +conditions are met: + + - The transmitted signal has poor self-correlation. + - There is no signal being generated within the environment being cancelled. + +The difficulty is that neither of these can be guaranteed. + +If the adaption is performed while transmitting noise (or something fairly noise +like, such as voice) the adaption works very well. If the adaption is performed +while transmitting something highly correlative (typically narrow band energy +such as signalling tones or DTMF), the adaption can go seriously wrong. The reason +is there is only one solution for the adaption on a near random signal - the impulse +response of the line. For a repetitive signal, there are any number of solutions +which converge the adaption, and nothing guides the adaption to choose the generalised +one. Allowing an untrained canceller to converge on this kind of narrowband +energy probably a good thing, since at least it cancels the tones. Allowing a well +converged canceller to continue converging on such energy is just a way to ruin +its generalised adaption. A narrowband detector is needed, so adapation can be +suspended at appropriate times. + +The adaption process is based on trying to eliminate the received signal. When +there is any signal from within the environment being cancelled it may upset the +adaption process. Similarly, if the signal we are transmitting is small, noise +may dominate and disturb the adaption process. If we can ensure that the +adaption is only performed when we are transmitting a significant signal level, +and the environment is not, things will be OK. Clearly, it is easy to tell when +we are sending a significant signal. Telling, if the environment is generating a +significant signal, and doing it with sufficient speed that the adaption will +not have diverged too much more we stop it, is a little harder. + +The key problem in detecting when the environment is sourcing significant energy +is that we must do this very quickly. Given a reasonably long sample of the +received signal, there are a number of strategies which may be used to assess +whether that signal contains a strong far end component. However, by the time +that assessment is complete the far end signal will have already caused major +mis-convergence in the adaption process. An assessment algorithm is needed which +produces a fairly accurate result from a very short burst of far end energy. + +\section echo_can_page_sec_3 How do I use it? +The echo cancellor processes both the transmit and receive streams sample by +sample. The processing function is not declared inline. Unfortunately, +cancellation requires many operations per sample, so the call overhead is only a +minor burden. +*/ + +#define NONUPDATE_DWELL_TIME 600 /* 600 samples, or 75ms */ + +#if 0 +/* Mask bits for the adaption mode */ +#define ECHO_CAN_USE_NLP 0x01 +#define ECHO_CAN_USE_SUPPRESSOR 0x02 +#define ECHO_CAN_USE_CNG 0x04 +#define ECHO_CAN_USE_ADAPTION 0x08 + +/*! + G.168 echo canceller descriptor. This defines the working state for a line + echo canceller. +*/ +typedef struct { + int tx_power[4]; + int rx_power[3]; + int clean_rx_power; + + int rx_power_threshold; + int nonupdate_dwell; + + fir16_state_t fir_state; + /*! Echo FIR taps (16 bit version) */ + int16_t *fir_taps16[4]; + /*! Echo FIR taps (32 bit version) */ + int32_t *fir_taps32; + + int curr_pos; + + int taps; + int tap_mask; + int adaption_mode; + + int32_t supp_test1; + int32_t supp_test2; + int32_t supp1; + int32_t supp2; + int vad; + int cng; + /* Parameters for the Hoth noise generator */ + int cng_level; + int cng_rndnum; + int cng_filter; + + int16_t geigel_max; + int geigel_lag; + int dtd_onset; + int tap_set; + int tap_rotate_counter; + + int32_t latest_correction; /* Indication of the magnitude of the latest + adaption, or a code to indicate why adaption + was skipped, for test purposes */ + int32_t last_acf[28]; + int narrowband_count; + int narrowband_score; +} echo_can_state_t; + +/*! Create a voice echo canceller context. + \param len The length of the canceller, in samples. + \return The new canceller context, or NULL if the canceller could not be created. +*/ +echo_can_state_t *echo_can_create(int len, int adaption_mode); + +/*! Free a voice echo canceller context. + \param ec The echo canceller context. +*/ +void echo_can_free(echo_can_state_t * ec); + +/*! Flush (reinitialise) a voice echo canceller context. + \param ec The echo canceller context. +*/ +void echo_can_flush(echo_can_state_t * ec); + +/*! Set the adaption mode of a voice echo canceller context. + \param ec The echo canceller context. + \param adapt The mode. +*/ +void echo_can_adaption_mode(echo_can_state_t * ec, int adaption_mode); + +/*! Process a sample through a voice echo canceller. + \param ec The echo canceller context. + \param tx The transmitted audio sample. + \param rx The received audio sample. + \return The clean (echo cancelled) received sample. +*/ +int16_t echo_can_update(echo_can_state_t * ec, int16_t tx, int16_t rx); + +#endif +/*- End of file ------------------------------------------------------------*/ + +/*! + Floating point Goertzel filter descriptor. +*/ +typedef struct { + float fac; + int samples; +} goertzel_descriptor_t; + +/*! + Floating point Goertzel filter state descriptor. +*/ +typedef struct { + float v2; + float v3; + float fac; + int samples; + int current_sample; +} goertzel_state_t; + +/*! \brief Create a descriptor for use with either a Goertzel transform */ +void make_goertzel_descriptor(goertzel_descriptor_t * t, float freq, int samples); + +/*! \brief Initialise the state of a Goertzel transform. + \param s The Goertzel context. If NULL, a context is allocated with malloc. + \param t The Goertzel descriptor. + \return A pointer to the Goertzel state. */ +goertzel_state_t *goertzel_init(goertzel_state_t * s, goertzel_descriptor_t * t); + +/*! \brief Reset the state of a Goertzel transform. + \param s The Goertzel context. + \param t The Goertzel descriptor. + \return A pointer to the Goertzel state. */ +void goertzel_reset(goertzel_state_t * s); + +/*! \brief Update the state of a Goertzel transform. + \param s The Goertzel context + \param amp The samples to be transformed + \param samples The number of samples + \return The number of samples unprocessed */ +int goertzel_update(goertzel_state_t * s, const int16_t amp[], int samples); + +/*! \brief Evaluate the final result of a Goertzel transform. + \param s The Goertzel context + \return The result of the transform. */ +float goertzel_result(goertzel_state_t * s); + +/*! \brief Update the state of a Goertzel transform. + \param s The Goertzel context + \param amp The sample to be transformed. */ +static __inline__ void goertzel_sample(goertzel_state_t * s, int16_t amp) +{ + float v1; + + v1 = s->v2; + s->v2 = s->v3; + s->v3 = s->fac * s->v2 - v1 + amp; + s->current_sample++; +} + +/*- End of function --------------------------------------------------------*/ + +/* + * SpanDSP - a series of DSP components for telephony + * + * tone_detect.c - General telephony tone detection. + * + * Written by Steve Underwood + * + * Copyright (C) 2001-2003, 2005 Steve Underwood + * + * All rights reserved. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2, as + * published by the Free Software Foundation. + * + * 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., 675 Mass Ave, Cambridge, MA 02139, USA. + * + * $Id: tone_detect.c,v 1.31 2007/03/03 10:40:33 steveu Exp $ + */ + +/*! \file tone_detect.h */ + +#if !defined(M_PI) +/* C99 systems may not define M_PI */ +#define M_PI 3.14159265358979323846264338327 +#endif +/*! \page dtmf_rx_page DTMF receiver +\section dtmf_rx_page_sec_1 What does it do? +The DTMF receiver detects the standard DTMF digits. It is compliant with +ITU-T Q.23, ITU-T Q.24, and the local DTMF specifications of most administrations. +Its passes the test suites. It also scores *very* well on the standard +talk-off tests. + +The current design uses floating point extensively. It is not tolerant of DC. +It is expected that a DC restore stage will be placed before the DTMF detector. +Unless the dial tone filter is switched on, the detector has poor tolerance +of dial tone. Whether this matter depends on your application. If you are using +the detector in an IVR application you will need proper echo cancellation to +get good performance in the presence of speech prompts, so dial tone will not +exist. If you do need good dial tone tolerance, a dial tone filter can be +enabled in the detector. + +\section dtmf_rx_page_sec_2 How does it work? +Like most other DSP based DTMF detector's, this one uses the Goertzel algorithm +to look for the DTMF tones. What makes each detector design different is just how +that algorithm is used. + +Basic DTMF specs: + - Minimum tone on = 40ms + - Minimum tone off = 50ms + - Maximum digit rate = 10 per second + - Normal twist <= 8dB accepted + - Reverse twist <= 4dB accepted + - S/N >= 15dB will detect OK + - Attenuation <= 26dB will detect OK + - Frequency tolerance +- 1.5% will detect, +-3.5% will reject + +TODO: +*/ + +/*! \page dtmf_tx_page DTMF tone generation +\section dtmf_tx_page_sec_1 What does it do? + +The DTMF tone generation module provides for the generation of the +repertoire of 16 DTMF dual tones. + +\section dtmf_tx_page_sec_2 How does it work? +*/ + +#define MAX_DTMF_DIGITS 128 + +typedef void (*dtmf_rx_callback_t) (void *user_data, const char *digits, int len); + +/*! + DTMF generator state descriptor. This defines the state of a single + working instance of a DTMF generator. +*/ +#if 0 +typedef struct { + tone_gen_descriptor_t *tone_descriptors; + tone_gen_state_t tones; + char digits[MAX_DTMF_DIGITS + 1]; + int current_sample; + size_t current_digits; +} dtmf_tx_state_t; + +#endif + +/*! + DTMF digit detector descriptor. +*/ +typedef struct { + /*! Optional callback funcion to deliver received digits. */ + dtmf_rx_callback_t callback; + /*! An opaque pointer passed to the callback function. */ + void *callback_data; + /*! Optional callback funcion to deliver real time digit state changes. */ + //tone_report_func_t realtime_callback; + void *realtime_callback; + /*! An opaque pointer passed to the real time callback function. */ + void *realtime_callback_data; + /*! TRUE if dialtone should be filtered before processing */ + int filter_dialtone; + /*! Maximum acceptable "normal" (lower bigger than higher) twist ratio */ + float normal_twist; + /*! Maximum acceptable "reverse" (higher bigger than lower) twist ratio */ + float reverse_twist; + + /*! 350Hz filter state for the optional dialtone filter */ + float z350_1; + float z350_2; + /*! 440Hz filter state for the optional dialtone filter */ + float z440_1; + float z440_2; + + /*! Tone detector working states */ + goertzel_state_t row_out[4]; + goertzel_state_t col_out[4]; + /*! The accumlating total energy on the same period over which the Goertzels work. */ + float energy; + /*! The result of the last tone analysis. */ + uint8_t last_hit; + /*! The confirmed digit we are currently receiving */ + uint8_t in_digit; + /*! The current sample number within a processing block. */ + int current_sample; + + /*! The received digits buffer. This is a NULL terminated string. */ + char digits[MAX_DTMF_DIGITS + 1]; + /*! The number of digits currently in the digit buffer. */ + int current_digits; + /*! The number of digits which have been lost due to buffer overflows. */ + int lost_digits; +} dtmf_rx_state_t; + +#if 0 +/*! \brief Generate a buffer of DTMF tones. + \param s The DTMF generator context. + \param amp The buffer for the generated signal. + \param max_samples The required number of generated samples. + \return The number of samples actually generated. This may be less than + samples if the input buffer empties. */ +int dtmf_tx(dtmf_tx_state_t * s, int16_t amp[], int max_samples); + +/*! \brief Put a string of digits in a DTMF generator's input buffer. + \param s The DTMF generator context. + \param digits The string of digits to be added. + \return The number of digits actually added. This may be less than the + length of the digit string, if the buffer fills up. */ +size_t dtmf_tx_put(dtmf_tx_state_t * s, const char *digits); + +/*! \brief Initialise a DTMF tone generator context. + \param s The DTMF generator context. + \return A pointer to the DTMF generator context. */ +dtmf_tx_state_t *dtmf_tx_init(dtmf_tx_state_t * s); +#endif + +/*! Set a optional realtime callback for a DTMF receiver context. This function + is called immediately a confirmed state change occurs in the received DTMF. It + is called with the ASCII value for a DTMF tone pair, or zero to indicate no tone + is being received. + \brief Set a realtime callback for a DTMF receiver context. + \param s The DTMF receiver context. + \param callback Callback routine used to report the start and end of digits. + \param user_data An opaque pointer which is associated with the context, + and supplied in callbacks. */ +void dtmf_rx_set_realtime_callback(dtmf_rx_state_t * s, + //tone_report_func_t callback, + void *callback, void *user_data); + +/*! \brief Adjust a DTMF receiver context. + \param s The DTMF receiver context. + \param filter_dialtone TRUE to enable filtering of dialtone, FALSE + to disable, < 0 to leave unchanged. + \param twist Acceptable twist, in dB. < 0 to leave unchanged. + \param reverse_twist Acceptable reverse twist, in dB. < 0 to leave unchanged. */ +void dtmf_rx_parms(dtmf_rx_state_t * s, int filter_dialtone, int twist, + int reverse_twist); + +/*! Process a block of received DTMF audio samples. + \brief Process a block of received DTMF audio samples. + \param s The DTMF receiver context. + \param amp The audio sample buffer. + \param samples The number of samples in the buffer. + \return The number of samples unprocessed. */ +int dtmf_rx(dtmf_rx_state_t * s, const int16_t amp[], int samples); + +/*! \brief Get a string of digits from a DTMF receiver's output buffer. + \param s The DTMF receiver context. + \param digits The buffer for the received digits. + \param max The maximum number of digits to be returned, + \return The number of digits actually returned. */ +size_t dtmf_rx_get(dtmf_rx_state_t * s, char *digits, int max); + +/*! \brief Initialise a DTMF receiver context. + \param s The DTMF receiver context. + \param callback An optional callback routine, used to report received digits. If + no callback routine is set, digits may be collected, using the dtmf_rx_get() + function. + \param user_data An opaque pointer which is associated with the context, + and supplied in callbacks. + \return A pointer to the DTMF receiver context. */ +dtmf_rx_state_t *dtmf_rx_init(dtmf_rx_state_t * s, dtmf_rx_callback_t callback, + void *user_data); + +/*- End of file ------------------------------------------------------------*/ + +#endif /* _CELLIAX_SPANDSP_H */ diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/chan_celliax.c b/src/mod/endpoints/mod_gsmopen/asterisk/chan_celliax.c new file mode 100644 index 0000000000..32c6fef4b8 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/chan_celliax.c @@ -0,0 +1,3094 @@ +//indent -gnu -ts4 -br -brs -cdw -lp -ce -nbfda -npcs -nprs -npsl -nbbo -saf -sai -saw -cs -bbo -nhnl -nut -sob -l90 +#include "celliax.h" + +/* GLOBAL VARIABLES */ +char celliax_console_active_array[50] = ""; +char *celliax_console_active = celliax_console_active_array; +/*! \brief Count of active channels for this module */ +int celliax_usecnt = 0; +int celliax_debug = 0; +/*! \brief This is the thread for the monitor which checks for input on the channels + * which are not currently in use. */ +pthread_t celliax_monitor_thread = AST_PTHREADT_NULL; +pthread_t celliax_monitor_audio_thread = AST_PTHREADT_NULL; +int celliax_dir_entry_extension = 0; + +/* CONSTANTS */ +/*! \brief Name of configuration file for this module */ +const char celliax_config[] = "celliax.conf"; + +/*! \brief Textual description for this module */ +const char celliax_desc[] = "Celliax, Audio-Serial Driver"; +/*! \brief Textual type for this module */ +const char celliax_type[] = "Celliax"; + +/*! \brief Definition of this channel for PBX channel registration */ +const struct ast_channel_tech celliax_tech = { + .type = celliax_type, + .description = celliax_desc, + .capabilities = AST_FORMAT_SLINEAR, + .requester = celliax_request, + .hangup = celliax_hangup, + .answer = celliax_answer, + .read = celliax_read, + .call = celliax_call, + .write = celliax_write, + .indicate = celliax_indicate, + .fixup = celliax_fixup, + .devicestate = celliax_devicestate, +#ifdef ASTERISK_VERSION_1_4 + .send_digit_begin = celliax_senddigit_begin, + .send_digit_end = celliax_senddigit_end, +#else /* ASTERISK_VERSION_1_4 */ + .send_digit = celliax_senddigit, +#endif /* ASTERISK_VERSION_1_4 */ +}; + +#ifdef ASTERISK_VERSION_1_4 +#include "asterisk/abstract_jb.h" +/*! Global jitterbuffer configuration - by default, jb is disabled */ +static struct ast_jb_conf default_jbconf = { + .flags = 0, + .max_size = -1, + .resync_threshold = -1, + .impl = "" +}; +static struct ast_jb_conf global_jbconf; +#endif /* ASTERISK_VERSION_1_4 */ + + +#ifdef CELLIAX_ALSA +char celliax_console_alsa_period_usage[] = + "Usage: celliax_alsa_period [alsa_period_size, in bytes] [alsa_periods_in_buffer, how many]\n" + " Shows or set the values of the period and the buffer used by the ALSA subsistem. Standard values are 160 for alsa_period_size and 4 for alsa_periods_in_buffer. Without specifying a value, it just shows the current values. The values are for the \"current\" console (Celliax) channel.\n" + " Enter 'help console' on how to change the \"current\" console\n"; +#endif /* CELLIAX_ALSA */ + +char mandescr_celliax_sendsms[] = + "Description: Send an SMS through the designated Celliax interface.\n" "Variables: \n" + " Interface: The Celliax interface name you want to use.\n" + " Number: The recipient number you want to send the SMS to.\n" + " Text: The text of the SMS to be sent.\n" + " ActionID: The Action ID for this AMI transaction.\n"; + +char celliax_console_celliax_usage[] = + " \n" "chan_celliax commands info\n" " \n" + " chan_celliax adds to Asterisk the following CLI commands and DIALPLAN applications:\n" + " \n" " CLI COMMANDS:\n" " celliax_hangup\n" + " celliax_dial\n" " celliax_console\n" +#ifdef CELLIAX_DIR + " celliax_dir_import\n" " celliax_dir_export\n" +#endif /* CELLIAX_DIR */ + " celliax_playback_boost\n" " celliax_capture_boost\n" + " celliax_sendsms\n" " celliax_echo\n" " celliax_at\n" + " \n" " DIALPLAN APPLICATIONS:\n" " CelliaxSendsms\n" " \n" + " You can type 'help [command]' or 'show application [application]' to obtain more specific info on usage.\n" + " \n"; +char celliax_console_hangup_usage[] = + "Usage: celliax_hangup\n" + " Hangs up any call currently placed on the \"current\" celliax_console (Celliax) channel.\n" + " Enter 'help celliax_console' on how to change the \"current\" celliax_console\n"; +char celliax_console_playback_boost_usage[] = + "Usage: celliax_playback_boost [value]\n" + " Shows or set the value of boost applied to the outgoing sound (voice). Possible values are: 0 (no boost applied), -40 to 40 (negative to positive range, in db). Without specifying a value, it just shows the current value. The value is for the \"current\" celliax_console (Celliax) channel.\n" + " Enter 'help celliax_console' on how to change the \"current\" celliax_console\n"; +char celliax_console_capture_boost_usage[] = + "Usage: celliax_capture_boost [value]\n" + " Shows or set the value of boost applied to the incoming sound (voice). Possible values are: 0 (no boost applied), -40 to 40 (negative to positive range, in db). Without specifying a value, it just shows the current value. The value is for the \"current\" celliax_console (Celliax) channel.\n" + " Enter 'help celliax_console' on how to change the \"current\" celliax_console\n"; + +#ifdef CELLIAX_DIR +char celliax_console_celliax_dir_import_usage[] = + "Usage: celliax_dir_import [add | replace] fromcell\n" + " Write in the celliax_dir.conf config file all the entries found in the phonebook of the cellphone connected on the \"current\" celliax_console (Celliax) channel or in the 'Contacts' list of the Skype client.\n" + " Enter 'help celliax_console' on how to change the \"current\" celliax_console\n"; +char celliax_console_celliax_dir_export_usage[] = +#ifdef CELLIAX_LIBCSV + "Usage: celliax_dir_export tocell|tocsv celliax_cellphonenumber [csv_filename]\n" +#else /* CELLIAX_LIBCSV */ + "Usage: celliax_dir_export tocell celliax_cellphonenumber\n" +#endif /* CELLIAX_LIBCSV */ + " With 'tocell' modifier, write in the cellphone connected on the \"current\" celliax_console (Celliax) all the entries found in directoriax.conf, in the form: [celliax_cellphonenumber]wait_for_answer celliax_dir_prefix celliax_dir_entry. So, you can choose the new entry from the cellphone phonebook, dial it, and be directly connected to celliax_dir extension chosen, without having to pass through the voice menu.\n" +#ifdef CELLIAX_LIBCSV + " With 'tocsv' modifier, write in a file (Comma Separated Values, suitable to be imported by various software (eg Outlook) and smartphones) all the entries found in directoriax.conf, in the form: [celliax_cellphonenumber]wait_for_answer celliax_dir_prefix celliax_dir_entry. So, you can choose the new entry from the imported phonebook, dial it, and be directly connected to celliax_dir extension chosen, without having to pass through the voice menu.\n" +#endif /* CELLIAX_LIBCSV */ + " Enter 'help celliax_console' on how to change the \"current\" celliax_console\n"; + +#endif /* CELLIAX_DIR */ + +char celliax_console_dial_usage[] = + "Usage: celliax_dial [DTMFs]\n" + " Dials a given DTMF string in the call currently placed on the\n" + " \"current\" celliax_console (Celliax) channel.\n" + " Enter 'help celliax_console' on how to change the \"current\" celliax_console\n"; +char celliax_console_sendsms_usage[] = + "Usage: celliax_sendsms interfacename/number_to_send_sms_to SMS_TEXT\n" + " This CLI command will use the specified Celliax interface to send an SMS with content SMS_TEXT to the number_to_send_sms_to\n" + " Eg:\n" " celliax_sendsms nicephone/3472665618 \"ciao bello\"\n"; + +char celliax_console_celliax_console_usage[] = + "Usage: celliax_console [interface] | show\n" + " If used without a parameter, displays which interface is the \"current\"\n" + " celliax_console. If a device is specified, the \"current\" celliax_console is changed to\n" + " the interface specified.\n" + " If the parameter is \"show\", the available interfaces are listed\n"; +char *celliax_sendsmsapp = "CelliaxSendsms"; + +char *celliax_sendsmssynopsis = "CelliaxSendsms sends an SMS through the cellphone"; +char *celliax_sendsmsdescrip = + " CelliaxSendsms(interface_name / number_to_send_sms_to , SMS_TEXT):\n" + " This application will use the specified Celliax interface to send an SMS with content SMS_TEXT to the number_to_send_sms_to\n" + " Eg:\n" " CelliaxSendsms(nicephone/3472665618,\"ciao bello\")\n" " or\n" + " CelliaxSendsms(nicephone/3472665618,${DATETIME}\"ciao bello\")\n" "\n"; +char celliax_console_echo_usage[] = + "Usage: celliax_echo [0|1] [0|1]\n" + " Shows or set the values (0 meaning OFF and 1 meaning ON) of the echo suppression options: speexecho and speexpreprocess. Without specifying a value, it just shows the current values. The values are for the \"current\" celliax_console (Celliax) channel.\n" + " Enter 'help celliax_console' on how to change the \"current\" celliax_console\n"; +char celliax_console_at_usage[] = + "Usage: celliax_at [command string]\n" + " Send the 'command string' to the 'AT modem' (cellphone) connected to the \"current\" celliax_console (Celliax) channel.\n" + " Enter 'help celliax_console' on how to change the \"current\" celliax_console\n"; +/*! \brief fake celliax_pvt structure values, + * just for logging purposes */ +struct celliax_pvt celliax_log_struct = { + .name = "none", +}; + +/*! \brief Default celliax_pvt structure values, + * used by celliax_mkif to initialize the interfaces */ +struct celliax_pvt celliax_default = { + .readpos = AST_FRIENDLY_OFFSET, /* start here on reads */ + .oss_write_dst = 0, /* start here on reads */ + .interface_state = AST_STATE_DOWN, + .phone_callflow = CALLFLOW_CALL_IDLE, + .dsp_silence_threshold = 512, + .context = "default", + .language = "en", + .exten = "s", + .controldevice_name = "none", + .controldevfd = 0, + .next = NULL, + .owner = NULL, + .dsp = NULL, + .fbus2_outgoing_list = NULL, + .seqnumfbus = FBUS2_SEQNUM_MAX, + .controldev_thread = AST_PTHREADT_NULL, + .arraycounter = 0, +#ifndef GIOVA48 + .celliax_sound_rate = 8000, +#else // GIOVA48 + .celliax_sound_rate = 48000, +#endif // GIOVA48 + .celliax_sound_capt_fd = -1, + .need_acoustic_ring = 0, + .celliax_serial_synced_timestamp = 0, + .celliax_serial_sync_period = 300, + .audio_play_reset_timestamp = 0, + .audio_capture_reset_timestamp = 0, + .controldevice_speed = B38400, + .capture_boost = 0, + .playback_boost = 0, + .stripmsd = 0, + .controldev_dead = 0, + .dtmf_inited = 0, + .at_dial_pre_number = "AT+CKPD=\"", + //.at_dial_post_number = "S\"", + .at_dial_post_number = ";", + .at_dial_expect = "OK", + .at_early_audio = 0, + .at_hangup = "AT+CKPD=\"E\"", + .at_hangup_expect = "OK", + .at_answer = "ATA", + .at_answer_expect = "OK", + .at_send_dtmf = "AT+CKPD", + .at_initial_pause = 0, + .at_preinit_1 = "", + .at_preinit_1_expect = "", + .at_preinit_2 = "", + .at_preinit_2_expect = "", + .at_preinit_3 = "", + .at_preinit_3_expect = "", + .at_preinit_4 = "", + .at_preinit_4_expect = "", + .at_preinit_5 = "", + .at_preinit_5_expect = "", + .at_after_preinit_pause = 0, + .at_postinit_1 = "", + .at_postinit_1_expect = "", + .at_postinit_2 = "", + .at_postinit_2_expect = "", + .at_postinit_3 = "", + .at_postinit_3_expect = "", + .at_postinit_4 = "", + .at_postinit_4_expect = "", + .at_postinit_5 = "", + .at_postinit_5_expect = "", + .at_query_battchg = "", + .at_query_battchg_expect = "", + .at_query_signal = "", + .at_query_signal_expect = "", + .at_call_idle = "", + .at_call_incoming = "", + .at_call_active = "", + .at_call_failed = "", + .at_call_calling = "", + .at_indicator_noservice_string = "CIEV: 2,0", + .at_indicator_nosignal_string = "CIEV: 5,0", + .at_indicator_lowsignal_string = "CIEV: 5,1", + .at_indicator_lowbattchg_string = "CIEV: 0,1", + .at_indicator_nobattchg_string = "CIEV: 0,0", + .at_indicator_callactive_string = "CIEV: 3,1", + .at_indicator_nocallactive_string = "CIEV: 3,0", + .at_indicator_nocallsetup_string = "CIEV: 6,0", + .at_indicator_callsetupincoming_string = "CIEV: 6,1", + .at_indicator_callsetupoutgoing_string = "CIEV: 6,2", + .at_indicator_callsetupremoteringing_string = "CIEV: 6,3", + .at_has_clcc = 0, + .at_has_ecam = 0, + + .skype = 0, + .celliax_dir_entry_extension_prefix = 5, + +#ifdef CELLIAX_CVM + .cvm_subsc_1_pin = "0000", + .cvm_subsc_2_pin = "0000", + .cvm_subsc_no = 1, + .cvm_lock_state = CVM_UNKNOWN_LOCK_STATE, + .cvm_register_state = CVM_UNKNOWN_REGISTER_STATE, + .cvm_busmail_outgoing_list = NULL, + .busmail_rxseq_cvm_last = 0xFF, /*!< \brief sequential number of BUSMAIL messages, (0-7) */ + .busmail_txseq_celliax_last = 0xFF, /*!< \brief sequential number of BUSMAIL messages, (0-7) */ + .cvm_volume_level = 5, + .cvm_celliax_serial_delay = 200, /* 200ms delay after sending down the wire, fix for a bug ? */ + .cvm_handset_no = 0, + .cvm_fp_is_cvm = 0, + .cvm_rssi = 0, + +#endif /* CELLIAX_CVM */ +#ifdef CELLIAX_LIBCSV + .csv_separator_is_semicolon = 0, //FIXME as option + .csv_complete_name_pos = 4, //FIXME as option was 4 for outlook express and some outlook, other outlook 2 + .csv_email_pos = 6, //FIXME as option for outlook express + .csv_home_phone_pos = 32, //FIXME as option was 12 for outlook express + .csv_mobile_phone_pos = 33, //FIXME as option was 14 for outlook express + .csv_business_phone_pos = 41, //FIXME as option was 22 for outlook express + .csv_first_row_is_title = 1, //FIXME as option +#endif /* CELLIAX_LIBCSV */ + + .audio_play_reset_period = 0, //do not reset + + .isInputInterleaved = 1, + .isOutputInterleaved = 1, + .numInputChannels = 1, + .numOutputChannels = 1, +#ifndef GIOVA48 + .framesPerCallback = 160, +#else // GIOVA48 + .framesPerCallback = 960, +#endif // GIOVA48 + .speexecho = 1, + .speexpreprocess = 1, + .portaudiocindex = -1, + .portaudiopindex = -1, +#ifdef CELLIAX_ALSA + .alsa_period_size = 160, + .alsa_periods_in_buffer = 4, + .alsac = NULL, + .alsap = NULL, + .alsawrite_filled = 0, +#endif /* CELLIAX_ALSA */ + +}; + +/*! + * \brief PVT structure for a celliax interface (channel), created by celliax_mkif + */ +struct celliax_pvt *celliax_iflist = NULL; + +#ifdef ASTERISK_VERSION_1_6_0 +struct ast_cli_entry myclis[] = { + AST_CLI_DEFINE(celliax_console_hangup, "Hangup a call on the console"), + //AST_CLI_DEFINE(celliax_console_dial, "Dial an extension on the console"), + //AST_CLI_DEFINE(celliax_console_playback_boost, "Sets/displays spk boost in dB"), + //AST_CLI_DEFINE(celliax_console_capture_boost, "Sets/displays mic boost in dB"), + //AST_CLI_DEFINE(celliax_console_set_active, "Sets/displays active console"), + //AST_CLI_DEFINE(celliax_console_at, "Sends an AT command"), + //AST_CLI_DEFINE(celliax_console_echo, "Echo suppression"), +#ifdef CELLIAX_DIR + //AST_CLI_DEFINE(celliax_console_celliax_dir_import, "imports entries from cellphone"), + //AST_CLI_DEFINE(celliax_console_celliax_dir_export, "exports entries to cellphone"), +#endif /* CELLIAX_DIR */ + //AST_CLI_DEFINE(celliax_console_celliax, "all things celliax"), + //AST_CLI_DEFINE(celliax_console_sendsms, "Send an SMS from a Celliax interface"), +}; +#else +struct ast_cli_entry myclis[] = { + {{"celliax_hangup", NULL}, celliax_console_hangup, + "Hangup a call on the celliax_console", + celliax_console_hangup_usage}, + {{"celliax_playback_boost", NULL}, celliax_console_playback_boost, "playback boost", + celliax_console_playback_boost_usage}, + {{"celliax_capture_boost", NULL}, celliax_console_capture_boost, "capture boost", + celliax_console_capture_boost_usage}, + {{"celliax_usage", NULL}, celliax_console_celliax, "chan_celliax commands info", + celliax_console_celliax_usage}, + + {{"celliax_at", NULL}, celliax_console_at, "AT command", + celliax_console_at_usage}, + {{"celliax_echo", NULL}, celliax_console_echo, "echo suppression", + celliax_console_echo_usage}, +#ifdef CELLIAX_DIR + {{"celliax_dir_import", NULL}, celliax_console_celliax_dir_import, + "Write the celliax_dir.conf file, used by celliax_dir app", + celliax_console_celliax_dir_import_usage}, + {{"celliax_dir_export", NULL}, celliax_console_celliax_dir_export, + "Write in the cellphone the contents of the celliax_dir.conf file, used by celliax_dir app", + celliax_console_celliax_dir_export_usage}, +#endif /* CELLIAX_DIR */ +#ifdef CELLIAX_ALSA + {{"celliax_alsa_period", NULL}, console_alsa_period, "alsa_period", + celliax_console_alsa_period_usage}, +#endif /* CELLIAX_ALSA */ + + {{"celliax_dial", NULL}, celliax_console_dial, + "Dial an extension on the celliax_console", + celliax_console_dial_usage}, + {{"celliax_sendsms", NULL}, celliax_console_sendsms, + "Send an SMS from a Celliax interface", + celliax_console_sendsms_usage}, + {{"celliax_console", NULL}, celliax_console_set_active, + "Sets/displays active celliax_console", + celliax_console_celliax_console_usage}, +}; +#endif /* ASTERISK_VERSION_1_6_0 */ + +/* IMPLEMENTATION */ + +#ifdef CELLIAX_ALSA +int console_alsa_period(int fd, int argc, char *argv[]) +{ + struct celliax_pvt *p = celliax_console_find_desc(celliax_console_active); + + if (argc > 3 || argc == 2) + return RESULT_SHOWUSAGE; + if (!p) { + ast_cli(fd, + "No \"current\" console for alsa_period_size, please enter 'help console'\n"); + return RESULT_SUCCESS; + } + + if (argc == 1) { + ast_cli(fd, + "On the active console, that is [%s], alsa_period_size and alsa_periods_in_buffer are: %d and %d\n", + celliax_console_active, p->alsa_period_size, p->alsa_periods_in_buffer); + } else if (argc == 3) { + + if (p->owner) { + ast_cli(fd, + "CANNOT SET alsa_period_size and alsa_periods_in_buffer on the active console, that is [%s], because there is a call ongoing\n", + celliax_console_active); + return RESULT_SUCCESS; + } + sscanf(argv[1], "%d", &p->alsa_period_size); + sscanf(argv[2], "%d", &p->alsa_periods_in_buffer); + ast_cli(fd, + "alsa_period_size and alsa_periods_in_buffer on the active console, that is [%s], are now: %d and %d\n", + celliax_console_active, p->alsa_period_size, p->alsa_periods_in_buffer); + + if (celliax_monitor_audio_thread + && (celliax_monitor_audio_thread != AST_PTHREADT_NULL) + && (celliax_monitor_audio_thread != AST_PTHREADT_STOP)) { + + if (pthread_cancel(celliax_monitor_audio_thread)) { + ERRORA("pthread_cancel celliax_monitor_audio_thread failed, BAD\n", + CELLIAX_P_LOG); + } + if (pthread_kill(celliax_monitor_audio_thread, SIGURG)) { + DEBUGA_PBX("pthread_kill celliax_monitor_audio_thread failed, no problem\n", CELLIAX_P_LOG); //maybe it just died + } + + if (pthread_join(celliax_monitor_audio_thread, NULL)) { + ERRORA("pthread_join failed, BAD\n", CELLIAX_P_LOG); + } + } + + alsa_shutdown(p); + //sleep(5); + alsa_init(p); + + if (ast_pthread_create + (&celliax_monitor_audio_thread, NULL, celliax_do_audio_monitor, NULL) < 0) { + ERRORA("Unable to start audio_monitor thread.\n", CELLIAX_P_LOG); + return -1; + } + + ast_cli(fd, + "ACTIVATED alsa_period_size and alsa_periods_in_buffer on the active console\n"); + } + + return RESULT_SUCCESS; +} +#endif /* CELLIAX_ALSA */ + +void celliax_unlocka_log(void *x) +{ + ast_mutex_t *y; + y = x; + int i; + + for (i = 0; i < 5; i++) { //let's be generous + + ast_log(LOG_DEBUG, + CELLIAX_SVN_VERSION + "[%-7lx] I'm a dying thread, and I'm to go unlocking mutex %p for the %dth time\n", + (unsigned long int) pthread_self(), y, i); + + ast_mutex_unlock(y); + } + ast_log(LOG_DEBUG, + CELLIAX_SVN_VERSION + "[%-7lx] I'm a dying thread, I've finished unlocking mutex %p\n", + (unsigned long int) pthread_self(), y); +} + +int celliax_queue_control(struct ast_channel *c, int control) +{ + struct celliax_pvt *p = c->tech_pvt; + int times; + +/* queue the frame */ + if (p) + p->control_to_send = control; + else + return 0; + DEBUGA_PBX("Queued CONTROL FRAME %d\n", CELLIAX_P_LOG, control); + +/* wait for the frame to be sent */ + while (p->control_to_send){ + usleep(1000); + times++; + if(times == 1000){ + ERRORA("Queued CONTROL FRAME %d FAILED to be sent\n", CELLIAX_P_LOG, control); + p->control_to_send = 0; + break; + } + } + + return 0; +} + +int celliax_devicestate(void *data) +{ + struct celliax_pvt *p = NULL; + char *name = data; + int res = AST_DEVICE_INVALID; + + if (!data) { + ERRORA("Devicestate requested with no data\n", CELLIAX_P_LOG); + return res; + } + + /* lock the interfaces' list */ + LOKKA(&celliax_iflock); + /* make a pointer to the first interface in the interfaces list */ + p = celliax_iflist; + /* Search for the requested interface and verify if is unowned */ + while (p) { + size_t length = strlen(p->name); + /* is this the requested interface? */ + if (strncmp(name, p->name, length) == 0) { + /* is this interface unowned? */ + if (!p->owner) { + res = AST_DEVICE_NOT_INUSE; + DEBUGA_PBX("Interface is NOT OWNED by a channel\n", CELLIAX_P_LOG); + } else { + /* interface owned by a channel */ + res = AST_DEVICE_INUSE; + DEBUGA_PBX("Interface is OWNED by a channel\n", CELLIAX_P_LOG); + } + + /* we found the requested interface, bail out from the while loop */ + break; + } + /* not yet found, next please */ + p = p->next; + } + /* unlock the interfaces' list */ + UNLOCKA(&celliax_iflock); + + if (res == AST_DEVICE_INVALID) { + ERRORA("Checking device state for interface [%s] returning AST_DEVICE_INVALID\n", + CELLIAX_P_LOG, name); + } + return res; +} + +#ifndef ASTERISK_VERSION_1_4 +int celliax_indicate(struct ast_channel *c, int cond) +#else +int celliax_indicate(struct ast_channel *c, int cond, const void *data, size_t datalen) +#endif +{ + struct celliax_pvt *p = c->tech_pvt; + int res = 0; + + switch (cond) { + case AST_CONTROL_BUSY: + case AST_CONTROL_CONGESTION: + case AST_CONTROL_RINGING: + case -1: + NOTICA("Let's INDICATE %d\n", CELLIAX_P_LOG, cond); + res = -1; /* Ask for inband indications */ + break; + case AST_CONTROL_PROGRESS: + case AST_CONTROL_PROCEEDING: + case AST_CONTROL_VIDUPDATE: + case AST_CONTROL_HOLD: + case AST_CONTROL_UNHOLD: +#ifdef ASTERISK_VERSION_1_4 + //FIXME case AST_CONTROL_SRCUPDATE: +#endif /* ASTERISK_VERSION_1_4 */ + NOTICA("Let's NOT INDICATE %d\n", CELLIAX_P_LOG, cond); + break; + default: + WARNINGA("Don't know how to display condition %d on %s\n", CELLIAX_P_LOG, cond, + c->name); + /* The core will play inband indications for us if appropriate */ + res = -1; + } + + return res; +} + +/*! \brief PBX interface function -build celliax pvt structure + * celliax calls initiated by the PBX arrive here */ +struct ast_channel *celliax_request(const char *type, int format, void *data, int *cause) +{ + struct celliax_pvt *p = NULL; + struct ast_channel *tmp = NULL; + char *name = data; + + if (option_debug) { + DEBUGA_PBX("ENTERING FUNC\n", CELLIAX_P_LOG); + } + + DEBUGA_PBX("Try to request type: %s, name: %s, cause: %d," " format: %d\n", + CELLIAX_P_LOG, type, name, *cause, format); + + if (!data) { + ERRORA("Channel requested with no data\n", CELLIAX_P_LOG); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return NULL; + } + + /* lock the interfaces' list */ + LOKKA(&celliax_iflock); + /* make a pointer to the first interface in the interfaces list */ + p = celliax_iflist; + /* Search for the requested interface and verify if is unowned and format compatible */ + //TODO implement groups a la chan_zap + while (p) { + size_t length = strlen(p->name); + /* is this the requested interface? */ + if (strncmp(name, p->name, length) == 0) { + /* is the requested format supported by this interface? */ + if ((format & AST_FORMAT_SLINEAR) != 0) { + /* is this interface unowned? */ + if (!p->owner) { + DEBUGA_PBX("Requesting: %s, name: %s, format: %d\n", CELLIAX_P_LOG, type, name, + format); + /* create a new channel owning this interface */ + tmp = celliax_new(p, AST_STATE_DOWN, p->context); + if (!tmp) { + /* the channel was not created, probable memory allocation error */ + *cause = AST_CAUSE_SWITCH_CONGESTION; + } + } else { + /* interface owned by another channel */ + WARNINGA("owned by another channel\n", CELLIAX_P_LOG); + *cause = AST_CAUSE_REQUESTED_CHAN_UNAVAIL; + } + } else { + /* requested format not supported */ + WARNINGA("format %d not supported\n", CELLIAX_P_LOG, format); + *cause = AST_CAUSE_BEARERCAPABILITY_NOTAVAIL; + } + /* we found the requested interface, bail out from the while loop */ + break; + } + /* not yet found, next please */ + p = p->next; + } + /* unlock the interfaces' list */ + UNLOCKA(&celliax_iflock); + /* restart the monitor so it will watch only the remaining unowned interfaces */ + celliax_restart_monitor(); + if (tmp == NULL) { + /* new channel was not created */ + WARNINGA("Unable to create new Celliax channel %s\n", CELLIAX_P_LOG, name); + } + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + /* return the newly created channel */ + return tmp; +} + +/*! \brief Hangup celliax call + * Part of PBX interface, called from ast_hangup */ + +int celliax_hangup(struct ast_channel *c) +{ + struct celliax_pvt *p; + int res; + + /* get our celliax pvt interface from channel */ + p = c->tech_pvt; + /* if there is not celliax pvt why we are here ? */ + if (!p) { + ERRORA("Asked to hangup channel not connected\n", CELLIAX_P_LOG); + return 0; + } + + if (option_debug) { + DEBUGA_PBX("ENTERING FUNC\n", CELLIAX_P_LOG); + } + + p->phone_callflow = CALLFLOW_CALL_HANGUP_REQUESTED; + /* shutdown the serial monitoring thread */ + if (p->controldev_thread && (p->controldev_thread != AST_PTHREADT_NULL) + && (p->controldev_thread != AST_PTHREADT_STOP)) { + if (pthread_cancel(p->controldev_thread)) { + ERRORA("controldev_thread pthread_cancel failed, maybe he killed himself?\n", + CELLIAX_P_LOG); + } + /* push it, maybe is stuck in a select or so */ + if (pthread_kill(p->controldev_thread, SIGURG)) { + DEBUGA_SERIAL("controldev_thread pthread_kill failed, no problem\n", CELLIAX_P_LOG); + } +#ifndef __CYGWIN__ /* under cygwin, this seems to be not reliable, get stuck at times */ + /* wait for it to die */ + if (pthread_join(p->controldev_thread, NULL)) { + ERRORA("controldev_thread pthread_join failed, BAD\n", CELLIAX_P_LOG); + } +#else /* __CYGWIN__ */ +/* allow the serial thread to die */ + usleep(300000); //300msecs +#endif /* __CYGWIN__ */ + } + p->controldev_thread = AST_PTHREADT_NULL; + + if (p->controldevprotocol != PROTOCOL_NO_SERIAL) { + if (p->interface_state != AST_STATE_DOWN) { + /* actually hangup through the serial port */ + if (p->controldevprotocol != PROTOCOL_NO_SERIAL) { + res = celliax_serial_hangup(p); + if (res) { + ERRORA("celliax_serial_hangup error: %d\n", CELLIAX_P_LOG, res); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } + } + + while (p->interface_state != AST_STATE_DOWN) { + usleep(10000); //10msec + } + if (p->interface_state != AST_STATE_DOWN) { + ERRORA("call hangup failed\n", CELLIAX_P_LOG); + return -1; + } else { + DEBUGA_SERIAL("call hungup\n", CELLIAX_P_LOG); + } + } + } else { + p->interface_state = AST_STATE_DOWN; + p->phone_callflow = CALLFLOW_CALL_IDLE; + } + /* if there is a dsp struct alloced, free it */ + if (p->dsp) { + ast_dsp_free(p->dsp); + p->dsp = NULL; + } +#ifndef __CYGWIN__ +#ifdef CELLIAX_ALSA +/* restart alsa */ + snd_pcm_drop(p->alsap); + snd_pcm_prepare(p->alsap); + + snd_pcm_prepare(p->alsac); + snd_pcm_start(p->alsac); + + /* shutdown the sound system, close sound fds, and if exist shutdown the sound managing threads */ + DEBUGA_SOUND("shutting down sound\n", CELLIAX_P_LOG); + res = celliax_sound_shutdown(p); + if (res == -1) { + ERRORA("Failed to shutdown sound\n", CELLIAX_P_LOG); + } + + +#endif /* CELLIAX_ALSA */ + +#endif /* __CYGWIN__ */ +#ifdef CELLIAX_PORTAUDIO + speex_echo_state_reset(p->stream->echo_state); +#endif // CELLIAX_PORTAUDIO + + /* re-init the serial port, be paranoid */ + if (p->controldevprotocol != PROTOCOL_NO_SERIAL) { + p->controldevfd = celliax_serial_init(p, p->controldevice_speed); + if (p->controldevfd < 1) { + ERRORA("bad, bad, bad\n", CELLIAX_P_LOG); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } + } +#ifndef ASTERISK_VERSION_1_4 + /* subtract one to the usage count of Celliax-type channels */ + LOKKA(&celliax_usecnt_lock); + celliax_usecnt--; + if (celliax_usecnt < 0) + ERRORA("Usecnt < 0???\n", CELLIAX_P_LOG); + UNLOCKA(&celliax_usecnt_lock); + ast_update_use_count(); +#else /* ASTERISK_VERSION_1_4 */ + ast_module_unref(ast_module_info->self); +#endif /* ASTERISK_VERSION_1_4 */ + + /* our celliax pvt interface is no more part of a channel */ + p->owner = NULL; + /* our channel has no more this celliax pvt interface to manage */ + c->tech_pvt = NULL; + /* set the channel state to DOWN, eg. available, not in active use */ + if (ast_setstate(c, AST_STATE_DOWN)) { + ERRORA("ast_setstate failed, BAD\n", CELLIAX_P_LOG); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } + + if (option_debug) + DEBUGA_PBX("Hanged Up\n", CELLIAX_P_LOG); + /* restart the monitor thread, so it can recheck which interfaces it have to watch during its loop (the interfaces that are not owned by channels) */ + if (celliax_restart_monitor()) { + ERRORA("celliax_restart_monitor failed, BAD\n", CELLIAX_P_LOG); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } + + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return 0; +} + +/*! \brief Answer incoming call, + * Part of PBX interface */ +int celliax_answer(struct ast_channel *c) +{ + struct celliax_pvt *p = c->tech_pvt; + int res; + + if (option_debug) { + DEBUGA_PBX("ENTERING FUNC\n", CELLIAX_P_LOG); + } + /* do something to actually answer the call, if needed (eg. pick up the phone) */ + if (p->controldevprotocol != PROTOCOL_NO_SERIAL) { + if (celliax_serial_answer(p)) { + ERRORA("celliax_answer FAILED\n", CELLIAX_P_LOG); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } + } + p->interface_state = AST_STATE_UP; + p->phone_callflow = CALLFLOW_CALL_ACTIVE; + + while (p->interface_state == AST_STATE_RING) { + usleep(10000); //10msec + } + if (p->interface_state != AST_STATE_UP) { + ERRORA("call answering failed\n", CELLIAX_P_LOG); + res = -1; + } else { + if (option_debug) + DEBUGA_PBX("call answered\n", CELLIAX_P_LOG); + res = 0; +#ifdef CELLIAX_PORTAUDIO + speex_echo_state_reset(p->stream->echo_state); +#endif // CELLIAX_PORTAUDIO + + if (p->owner) { + DEBUGA_PBX("going to send AST_STATE_UP\n", CELLIAX_P_LOG); + ast_setstate(p->owner, AST_STATE_UP); + //ast_queue_control(p->owner, AST_CONTROL_ANSWER); + //celliax_queue_control(p->owner, AST_CONTROL_ANSWER); + DEBUGA_PBX("just sent AST_STATE_UP\n", CELLIAX_P_LOG); + } + } + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return res; +} + +#ifdef ASTERISK_VERSION_1_4 +int celliax_senddigit_begin(struct ast_channel *c, char digit) +{ + struct celliax_pvt *p = c->tech_pvt; + + DEBUGA_PBX("DIGIT BEGIN received: %c\n", CELLIAX_P_LOG, digit); + + return 0; +} + +int celliax_senddigit_end(struct ast_channel *c, char digit, unsigned int duration) +{ + struct celliax_pvt *p = c->tech_pvt; + + NOTICA("DIGIT END received: %c %d\n", CELLIAX_P_LOG, digit, duration); + + if (p->controldevprotocol == PROTOCOL_AT && p->at_send_dtmf[0]) { + int res = 0; + char at_command[256]; + + memset(at_command, '\0', 256); + sprintf(at_command, "%s=\"%c\"", p->at_send_dtmf, digit); + res = celliax_serial_write_AT_ack(p, at_command); + if (res) { + ERRORA("senddigit command failed, command used: '%s=\"%c\"', giving up\n", + CELLIAX_P_LOG, p->at_send_dtmf, digit); + } + } + return 0; +} +#else /* ASTERISK_VERSION_1_4 */ +int celliax_senddigit(struct ast_channel *c, char digit) +{ + struct celliax_pvt *p = c->tech_pvt; + + NOTICA("DIGIT received: %c\n", CELLIAX_P_LOG, digit); + + if (p->controldevprotocol == PROTOCOL_AT && p->at_send_dtmf[0]) { + int res = 0; + char at_command[256]; + + memset(at_command, '\0', 256); + sprintf(at_command, "%s=\"%c\"", p->at_send_dtmf, digit); + res = celliax_serial_write_AT_ack(p, at_command); + if (res) { + ERRORA("senddigit command failed, command used: '%s=\"%c\"', giving up\n", + CELLIAX_P_LOG, p->at_send_dtmf, digit); + } + } + return 0; +} + +#endif /* ASTERISK_VERSION_1_4 */ + +/*! \brief Read audio frames from channel */ +struct ast_frame *celliax_read(struct ast_channel *c) +{ + struct ast_frame *f; + struct celliax_pvt *p = c->tech_pvt; + int actual; + char buf[128 + 1]; + + if (p->dtmf_inited == 0) { + dtmf_rx_init(&p->dtmf_state, NULL, NULL); + p->dtmf_inited = 1; + dtmf_rx_parms(&p->dtmf_state, 0, 10, 10); + p->dtmf_timestamp.tv_sec=0; + p->dtmf_timestamp.tv_usec=0; + DEBUGA_SOUND("DTMF recognition inited\n", CELLIAX_P_LOG); + } + +/* if there are control frames queued to be sent by celliax_queue_control, send it the first */ +//FIXME maybe better a real queue? + if (p && p->owner && p->control_to_send) { + ast_queue_control(p->owner, p->control_to_send); + DEBUGA_PBX("Sent CONTROL FRAME %d\n", CELLIAX_P_LOG, p->control_to_send); + p->control_to_send = 0; + } + +#ifdef CELLIAX_PORTAUDIO +/* if the call is not active (ie: answered), do not send audio frames, they would pile up in a lag queue */ + if (!p->owner || p->owner->_state != AST_STATE_UP) +#else /* CELLIAX_PORTAUDIO */ + if (!p->owner ) +#endif /* CELLIAX_PORTAUDIO */ + { + static struct ast_frame f; +#ifdef CELLIAX_PORTAUDIO + char c; +#endif /* CELLIAX_PORTAUDIO */ + + f.frametype = AST_FRAME_NULL; + f.subclass = 0; + f.samples = 0; + f.datalen = 0; +#ifdef ASTERISK_VERSION_1_6_0_1 + f.data.ptr = NULL; +#else + f.data = NULL; +#endif /* ASTERISK_VERSION_1_6_0_1 */ + f.offset = 0; + f.src = celliax_type; + f.mallocd = 0; + f.delivery.tv_sec = 0; + f.delivery.tv_usec = 0; +/* read the char that was written by the audio thread in this pipe, this pipe is the fd monitored by asterisk, asterisk then has called the function we are inside) */ +#ifdef CELLIAX_PORTAUDIO + read(p->audiopipe[0], &c, 1); +#endif /* CELLIAX_PORTAUDIO */ + + return &f; + } + + /* read one asterisk frame of audio from sound interface */ + f = celliax_sound_read(p); + if (f) { + struct timeval now_timestamp; +#ifndef __CYGWIN__ +#ifdef CELLIAX_PORTAUDIO + char c[1000]; + int letti = 2; + + while (letti > 1) { + letti = read(p->audiopipe[0], &c, 1000); + if (letti > 0) + DEBUGA_SOUND("READ from audiopipe: %d\n", CELLIAX_P_LOG, letti); + //usleep(1); + } + //if(letti == -1) + //ERRORA("error: %s\n", CELLIAX_P_LOG, strerror(errno)); +#endif /* CELLIAX_PORTAUDIO */ +#endif /* __CYGWIN__ */ + + /* scale sound samples volume up or down */ + celliax_sound_boost(f, p->capture_boost); + + gettimeofday(&now_timestamp, NULL); + + if( (((now_timestamp.tv_sec - p->dtmf_timestamp.tv_sec) * 1000000) < 0) || ( ((now_timestamp.tv_sec - p->dtmf_timestamp.tv_sec) * 1000000) + (now_timestamp.tv_usec - p->dtmf_timestamp.tv_usec) ) > 300000) { // if more than 0.3 seconds from last DTMF, or never got DTMFs before + +#ifdef ASTERISK_VERSION_1_6_0_1 + dtmf_rx(&p->dtmf_state, f->data.ptr, f->samples); +#else + dtmf_rx(&p->dtmf_state, f->data, f->samples); +#endif /* ASTERISK_VERSION_1_6_0_1 */ + actual = dtmf_rx_get(&p->dtmf_state, buf, 128); + if (actual) { + //if (option_debug) + NOTICA("delta_usec=%ld, inband audio DTMF: %s\n", CELLIAX_P_LOG, ( (now_timestamp.tv_sec - p->dtmf_timestamp.tv_sec) * 1000000) + (now_timestamp.tv_usec - p->dtmf_timestamp.tv_usec), buf); + struct ast_frame f2 = { AST_FRAME_DTMF, buf[0], }; + ast_queue_frame(p->owner, &f2); + gettimeofday(&p->dtmf_timestamp, NULL); + } + } + return f; + } + return NULL; +} + +/*! \brief Initiate celliax call from PBX + * used from the dial() application + */ +int celliax_call(struct ast_channel *c, char *idest, int timeout) +{ + struct celliax_pvt *p = NULL; + p = c->tech_pvt; + char rdest[80], *where, dstr[100] = ""; + char *stringp = NULL; + int status; + + if (option_debug) { + DEBUGA_PBX("ENTERING FUNC\n", CELLIAX_P_LOG); + } + if ((c->_state != AST_STATE_DOWN) + && (c->_state != AST_STATE_RESERVED)) { + ERRORA("celliax_call called on %s, neither down nor reserved\n", CELLIAX_P_LOG, + c->name); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } + + if (option_debug > 1) + DEBUGA_PBX("celliax_call to call idest: %s, timeout: %d!\n", CELLIAX_P_LOG, idest, + timeout); + + strncpy(rdest, idest, sizeof(rdest) - 1); + // try '/' as separator + stringp = rdest; + strsep(&stringp, "/"); + where = strsep(&stringp, "/"); + + if (!where) { + ERRORA + ("Destination %s is not recognized. Chan_celliax requires a standard destination with slashes (Celliax/device/destination, eg: 'Celliax/nicephone/3472665618')\n", + CELLIAX_P_LOG, idest); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } + + strncpy(dstr, where + p->stripmsd, sizeof(dstr) - 1); + if (option_debug > 1) + DEBUGA_PBX("celliax_call dialing idest: %s, timeout: %d, dstr: %s!\n", CELLIAX_P_LOG, + idest, timeout, dstr); + + if (p->controldev_dead) { + WARNINGA("celliax_call: device is dead, cannot call!\n", CELLIAX_P_LOG); + status = -1; + } else { + ast_setstate(c, AST_STATE_DIALING); + status = celliax_serial_call(p, dstr); + } + + if (status) { + WARNINGA("celliax_call dialing failed: %d!\n", CELLIAX_P_LOG, status); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } else { + if (option_debug) + DEBUGA_PBX("call ongoing\n", CELLIAX_P_LOG); + ast_queue_control(p->owner, AST_CONTROL_RINGING); + } + + if (option_debug > 1) + DEBUGA_PBX("celliax_call dialed idest: %s, timeout: %d, dstr: %s!\n", CELLIAX_P_LOG, + idest, timeout, dstr); + + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } +#ifdef CELLIAX_PORTAUDIO + speex_echo_state_reset(p->stream->echo_state); +#endif // CELLIAX_PORTAUDIO + return 0; +} + +/*! \brief Send audio frame to channel */ +int celliax_write(struct ast_channel *c, struct ast_frame *f) +{ + struct celliax_pvt *p = c->tech_pvt; + if (p->owner && p->owner->_state != AST_STATE_UP) { + return 0; + } + + celliax_sound_boost(f, p->playback_boost); + + return celliax_sound_write(p, f); +} + +/*! \brief Fix up a channel: If a channel is consumed, this is called. + * Basically update any ->owner links */ +int celliax_fixup(struct ast_channel *oldchan, struct ast_channel *newchan) +{ + struct celliax_pvt *p = newchan->tech_pvt; + + if (!p) { + ERRORA("No pvt after masquerade. Strange things may happen\n", CELLIAX_P_LOG); + return -1; + } + + if (p->owner != oldchan) { + ERRORA("old channel wasn't %p but was %p\n", CELLIAX_P_LOG, oldchan, p->owner); + return -1; + } + + p->owner = newchan; + return 0; +} + +int celliax_sound_boost(struct ast_frame *f, double boost) +{ +/* LUIGI RIZZO's magic */ + if (boost != 0) { /* scale and clip values */ + int i, x; + +#ifdef ASTERISK_VERSION_1_6_0_1 + int16_t *ptr = (int16_t *) f->data.ptr; +#else + int16_t *ptr = (int16_t *) f->data; +#endif /* ASTERISK_VERSION_1_6_0_1 */ + for (i = 0; i < f->samples; i++) { + x = (ptr[i] * boost) / BOOST_SCALE; + if (x > 32767) { + x = 32767; + } else if (x < -32768) { + x = -32768; + } + ptr[i] = x; + } + } + return 0; +} + +struct ast_channel *celliax_new(struct celliax_pvt *p, int state, char *context) +{ + struct ast_channel *tmp; + + if (option_debug) { + DEBUGA_PBX("ENTERING FUNC\n", CELLIAX_P_LOG); + } + /* alloc a generic channel struct */ +#ifndef ASTERISK_VERSION_1_4 + tmp = ast_channel_alloc(1); +#else + //tmp = ast_channel_alloc(1, state, 0, 0, "", p->exten, p->context, 0, ""); + tmp = + ast_channel_alloc(1, state, 0, 0, "", p->exten, p->context, 0, "Celliax/%s", p->name); + +#endif /* ASTERISK_VERSION_1_4 */ + if (tmp) { +int res; + +/* initialize the soundcard channels (input and output) used by this interface (a multichannel soundcard can be used by multiple interfaces), optionally starting the sound managing threads */ + res = celliax_sound_init(p); + if (res == -1) { + ERRORA("Failed initializing sound device\n", CELLIAX_P_LOG); + /* we failed, free the PVT */ + if (tmp) + free(tmp); + return NULL; + } + + /* give a name to the newly created channel */ +#ifndef ASTERISK_VERSION_1_4 + snprintf(tmp->name, sizeof(tmp->name), "Celliax/%s", p->name); + tmp->type = celliax_type; +#else /* ASTERISK_VERSION_1_4 */ + ast_string_field_build(tmp, name, "Celliax/%s", p->name); +#endif /* ASTERISK_VERSION_1_4 */ + + DEBUGA_PBX("new channel: name=%s requested_state=%d\n", CELLIAX_P_LOG, tmp->name, + state); + + /* fd for the channel to poll for incoming audio */ + tmp->fds[0] = p->celliax_sound_capt_fd; + + /* audio formats managed */ + tmp->nativeformats = AST_FORMAT_SLINEAR; + tmp->readformat = AST_FORMAT_SLINEAR; + tmp->writeformat = AST_FORMAT_SLINEAR; + /* the technology description (eg. the interface type) of the newly created channel is the Celliax's one */ + tmp->tech = &celliax_tech; + /* the technology pvt (eg. the interface) of the newly created channel is this interface pvt */ + tmp->tech_pvt = p; + + /* copy this interface default context, extension, language to the newly created channel */ + if (strlen(p->context)) + strncpy(tmp->context, p->context, sizeof(tmp->context) - 1); + if (strlen(p->exten)) + strncpy(tmp->exten, p->exten, sizeof(tmp->exten) - 1); +#ifndef ASTERISK_VERSION_1_4 + if (strlen(p->language)) + strncpy(tmp->language, p->language, sizeof(tmp->language) - 1); +#else + if (strlen(p->language)) + ast_string_field_set(tmp, language, p->language); +#endif /* ASTERISK_VERSION_1_4 */ + /* copy the requested context (not necessarily the interface default) to the newly created channel */ + if (strlen(context)) + strncpy(tmp->context, context, sizeof(tmp->context) - 1); + + /* copy this interface default callerid in the newly created channel */ + ast_set_callerid(tmp, !ast_strlen_zero(p->callid_number) ? p->callid_number : NULL, + !ast_strlen_zero(p->callid_name) ? p->callid_name : NULL, + !ast_strlen_zero(p->callid_number) ? p->callid_number : NULL); + + /* the owner of this interface pvt is the newly created channel */ + p->owner = tmp; + /* if this interface pvt has an initialized dsp struct, free it */ + if (p->dsp) { + DEBUGA_SOUND("freeing dsp\n", CELLIAX_P_LOG); + ast_dsp_free(p->dsp); + p->dsp = NULL; + } +#ifndef ASTERISK_VERSION_1_4 + /* set the newly created channel state to the requested state */ + if (ast_setstate(tmp, state)) { + ERRORA("ast_setstate failed, BAD\n", CELLIAX_P_LOG); + ast_dsp_free(p->dsp); + ast_channel_free(tmp); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return NULL; + } +#endif /* ASTERISK_VERSION_1_4 */ + +#ifdef AST_VERION_1_4 + ast_module_ref(ast_module_info->self); + ast_jb_configure(tmp, &global_jbconf); +#endif /* AST_VERION_1_4 */ + + /* if the requested state is different from DOWN, let the pbx manage this interface (now part of the newly created channel) */ + if (state != AST_STATE_DOWN) { + DEBUGA_PBX("Try to start PBX on %s, state=%d\n", CELLIAX_P_LOG, tmp->name, state); + if (ast_pbx_start(tmp)) { + ERRORA("Unable to start PBX on %s\n", CELLIAX_P_LOG, tmp->name); + ast_dsp_free(p->dsp); + ast_channel_free(tmp); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return NULL; + } + } + /* let's start the serial monitoring thread too, so we can have serial signaling */ + if (ast_pthread_create(&p->controldev_thread, NULL, celliax_do_controldev_thread, p) < + 0) { + ERRORA("Unable to start controldev thread.\n", CELLIAX_P_LOG); + ast_dsp_free(p->dsp); + ast_channel_free(tmp); + tmp = NULL; + } + DEBUGA_SERIAL("STARTED controldev_thread=%lu STOP=%lu NULL=%lu\n", CELLIAX_P_LOG, + (unsigned long) p->controldev_thread, (unsigned long) AST_PTHREADT_STOP, + (unsigned long) AST_PTHREADT_NULL); + +#ifndef ASTERISK_VERSION_1_4 + /* add one to the usage count of Celliax-type channels */ + LOKKA(&celliax_usecnt_lock); + celliax_usecnt++; + UNLOCKA(&celliax_usecnt_lock); + ast_update_use_count(); +#endif /* ASTERISK_VERSION_1_4 */ + + /* return the newly created channel */ + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return tmp; + } + ERRORA("failed memory allocation for Celliax channel\n", CELLIAX_P_LOG); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return NULL; +} + +/*! + * \brief Load the module into Asterisk and start its threads + * + * This function register the module into Asterisk, + * create the interfaces for the channels, + * start the auxiliary threads for the interfaces, + * then start a monitor thread. The monitor thread + * will signal Asterisk when an interface receive a call. + * + * + * \return zero on success, -1 on error. + */ +int load_module(void) +{ + int i; + struct ast_config *cfg; + struct celliax_pvt *tmp; + struct celliax_pvt *p = NULL; +#ifdef ASTERISK_VERSION_1_6_0 + struct ast_flags config_flags = { 0 }; +#endif /* ASTERISK_VERSION_1_6_0 */ + + + +#ifdef ASTERISK_VERSION_1_4 + /* Copy the default jb config over global_jbconf */ + memcpy(&global_jbconf, &default_jbconf, sizeof(struct ast_jb_conf)); +#endif /* ASTERISK_VERSION_1_4 */ + + if (option_debug) { + DEBUGA_PBX("ENTERING FUNC\n", CELLIAX_P_LOG); + } + ast_register_application(celliax_sendsmsapp, celliax_sendsms, celliax_sendsmssynopsis, + celliax_sendsmsdescrip); + + ast_manager_register2("CELLIAXsendsms", EVENT_FLAG_SYSTEM, celliax_manager_sendsms, + "Send an SMS", mandescr_celliax_sendsms); + /* make sure we can register our channel type with Asterisk */ + i = ast_channel_register(&celliax_tech); + if (i < 0) { + ERRORA("Unable to register channel type '%s'\n", CELLIAX_P_LOG, celliax_type); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } + /* load celliax.conf config file */ +#ifdef ASTERISK_VERSION_1_6_0 + cfg = ast_config_load(celliax_config, config_flags); +#else + cfg = ast_config_load(celliax_config); +#endif /* ASTERISK_VERSION_1_6_0 */ + if (cfg != NULL) { + char *ctg = NULL; + int is_first_category = 1; + while ((ctg = ast_category_browse(cfg, ctg)) != NULL) { + /* create one interface for each category in celliax.conf config file, first one set the defaults */ + tmp = celliax_mkif(cfg, ctg, is_first_category); + if (tmp) { + NOTICA("Created channel Celliax: celliax.conf category '[%s]', channel name '%s'" + " control_device_name '%s'\n", CELLIAX_P_LOG, ctg, tmp->name, + tmp->controldevice_name); + /* add interface to celliax_iflist */ + tmp->next = celliax_iflist; + celliax_iflist = tmp; + /* next one will not be the first ;) */ + if (is_first_category == 1) { + is_first_category = 0; + celliax_console_active = tmp->name; + } + } else { + ERRORA("Unable to create channel Celliax from celliax.conf category '[%s]'\n", + CELLIAX_P_LOG, ctg); + /* if error, unload config from memory and return */ + ast_config_destroy(cfg); + ast_channel_unregister(&celliax_tech); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } + /* do it for each category described in config */ + } + + /* we finished, unload config from memory */ + ast_config_destroy(cfg); + } else { + ERRORA("Unable to load celliax_config celliax.conf\n", CELLIAX_P_LOG); + ast_channel_unregister(&celliax_tech); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } +#ifndef ASTERISK_VERSION_1_6_0 + ast_cli_register_multiple(myclis, sizeof(myclis) / sizeof(struct ast_cli_entry)); +#endif /* ASTERISK_VERSION_1_6_0 */ + /* start to monitor the interfaces (celliax_iflist) for the first time */ + if (celliax_restart_monitor()) { + ERRORA("celliax_restart_monitor failed, BAD\n", CELLIAX_P_LOG); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } +#ifdef CELLIAX_DIR + //celliax_dir_create_extensions(); +#endif /* CELLIAX_DIR */ + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return 0; +} + +/*! + * \brief Unload the module from Asterisk and shutdown its threads + * + * This function unregister the module from Asterisk, + * destroy the interfaces for the channels, + * shutdown the auxiliary threads for the interfaces, + * then shutdown its monitor thread. + * + * \return zero on success, -1 on error. + */ +int unload_module(void) +{ + struct celliax_pvt *p = NULL, *p2 = NULL; + int res; + + if (option_debug) { + DEBUGA_PBX("ENTERING FUNC\n", CELLIAX_P_LOG); + } + + /* unregister our channel type with Asterisk */ + ast_channel_unregister(&celliax_tech); + ast_cli_unregister_multiple(myclis, sizeof(myclis) / sizeof(struct ast_cli_entry)); + + ast_unregister_application(celliax_sendsmsapp); + + /* lock the celliax_monlock, kill the monitor thread, unlock the celliax_monlock */ + LOKKA(&celliax_monlock); + if (celliax_monitor_thread && (celliax_monitor_thread != AST_PTHREADT_NULL) + && (celliax_monitor_thread != AST_PTHREADT_STOP)) { + if (pthread_cancel(celliax_monitor_thread)) { + ERRORA("pthread_cancel failed, BAD\n", CELLIAX_P_LOG); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } + if (pthread_kill(celliax_monitor_thread, SIGURG)) { + DEBUGA_PBX("pthread_kill failed\n", CELLIAX_P_LOG); //maybe it just died + } +#ifndef __CYGWIN__ /* under cygwin, this seems to be not reliable, get stuck at times */ + if (pthread_join(celliax_monitor_thread, NULL)) { + ERRORA("pthread_join failed, BAD\n", CELLIAX_P_LOG); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return -1; + } +#endif /* __CYGWIN__ */ + } + celliax_monitor_thread = AST_PTHREADT_STOP; + UNLOCKA(&celliax_monlock); + + if (celliax_monitor_audio_thread && (celliax_monitor_audio_thread != AST_PTHREADT_NULL) + && (celliax_monitor_audio_thread != AST_PTHREADT_STOP)) { + + if (pthread_cancel(celliax_monitor_audio_thread)) { + ERRORA("pthread_cancel celliax_monitor_audio_thread failed, BAD\n", CELLIAX_P_LOG); + } + if (pthread_kill(celliax_monitor_audio_thread, SIGURG)) { + DEBUGA_PBX("pthread_kill celliax_monitor_audio_thread failed, no problem\n", CELLIAX_P_LOG); //maybe it just died + } + + if (pthread_join(celliax_monitor_audio_thread, NULL)) { + ERRORA("pthread_join failed, BAD\n", CELLIAX_P_LOG); + } + } + /* lock the celliax_iflock, and go through the interfaces list (celliax_iflist) */ + LOKKA(&celliax_iflock); + p = celliax_iflist; + while (p) { + /* for each interface in list */ + p2 = p->next; + /* shutdown the sound system, close sound fds, and if exist shutdown the sound managing threads */ + DEBUGA_SOUND("shutting down sound\n", CELLIAX_P_LOG); + res = celliax_sound_shutdown(p); + if (res == -1) { + ERRORA("Failed to shutdown sound\n", CELLIAX_P_LOG); + } + + /* if a serial port has been opened, close it */ + if (p->controldevprotocol != PROTOCOL_NO_SERIAL) + if (p->controldevfd) + close(p->controldevfd); + + /* if a dsp struct has been allocated, free it */ + if (p->dsp) { + ast_dsp_free(p->dsp); + p->dsp = NULL; + } + DEBUGA_PBX("freeing PVT\n", CELLIAX_P_LOG); + /* free the pvt allocated memory */ + free(p); + /* next one, please */ + p = p2; + } + /* finished with the interfaces list, unlock the celliax_iflock */ + UNLOCKA(&celliax_iflock); + +#ifdef __CYGWIN__ + NOTICA("Sleping 5 secs, please wait...\n", CELLIAX_P_LOG); + sleep(5); /* without this pause, for some unknown (to me) reason it crashes on cygwin */ +#endif /* __CYGWIN__ */ + NOTICA("Unloaded Celliax Module\n", CELLIAX_P_LOG); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", CELLIAX_P_LOG); + } + return 0; +} + +/*! + * \brief Return the count of active channels for this module + * + * \return the count of active channels for this module + */ +int usecount() +{ + int res; + static struct celliax_pvt *p = &celliax_log_struct; +/* lock the celliax_usecnt lock */ + LOKKA(&celliax_usecnt_lock); + /* retrieve the celliax_usecnt */ + res = celliax_usecnt; +/* unlock the celliax_usecnt lock */ + UNLOCKA(&celliax_usecnt_lock); + /* return the celliax_usecnt */ + return res; +} + +/*! + * \brief Return the textual description of the module + * + * \return the textual description of the module + */ +char *description() +{ + return (char *) celliax_desc; +} + +/*! + * \brief Return the ASTERISK_GPL_KEY + * + * \return the ASTERISK_GPL_KEY + */ +char *key() +{ + struct celliax_pvt *p = NULL; + + if (option_debug) + NOTICA("Returning Key\n", CELLIAX_P_LOG); + + return ASTERISK_GPL_KEY; +} + +/*! + * \brief Create and initialize one interface for the module + * \param cfg pointer to configuration data from celliax.conf + * \param ctg pointer to a category name to be found in cfg + * \param is_first_category is this the first category in cfg + * + * This function create and initialize one interface for the module + * + * \return a pointer to the PVT structure of interface on success, NULL on error. + */ +struct celliax_pvt *celliax_mkif(struct ast_config *cfg, char *ctg, int is_first_category) +{ + struct celliax_pvt *tmp; + struct ast_variable *v; + int res; + + int debug_all = 0; + int debug_at = 0; + int debug_fbus2 = 0; + int debug_serial = 0; + int debug_sound = 0; + int debug_pbx = 0; + int debug_skype = 0; + int debug_call = 0; + int debug_locks = 0; + int debug_monitorlocks = 0; +#ifdef CELLIAX_CVM + int debug_cvm = 0; +#endif /* CELLIAX_CVM */ + + /* alloc memory for PVT */ + tmp = malloc(sizeof(struct celliax_pvt)); + if (tmp == NULL) /* fail */ + return NULL; + /* clear memory for PVT */ + memset(tmp, 0, sizeof(struct celliax_pvt)); + + //NOTICA("malloced %d bytes\n", CELLIAX_TMP_LOG, sizeof(struct celliax_pvt)); + + /* if we are reading the "first" category of the config file, take SELECTED values as defaults, overriding the values in celliax_default */ + if (is_first_category == 1) { + /* for each variable in category, copy it in the celliax_default struct */ + for (v = ast_variable_browse(cfg, ctg); v; v = v->next) { + M_START(v->name, v->value); + + M_STR("control_device_protocol", celliax_default.controldevprotocolname) + M_STR("context", celliax_default.context) + M_STR("language", celliax_default.language) + M_STR("extension", celliax_default.exten) + M_UINT("dsp_silence_threshold", celliax_default.dsp_silence_threshold) + M_UINT("audio_play_reset_period", celliax_default.audio_play_reset_period) +#ifdef CELLIAX_ALSA + M_UINT("alsa_period_size", celliax_default.alsa_period_size) + M_UINT("alsa_periods_in_buffer", celliax_default.alsa_periods_in_buffer) +#endif /* CELLIAX_ALSA */ + M_F("playback_boost", + celliax_store_boost(v->value, &celliax_default.playback_boost)) + M_F("capture_boost", + celliax_store_boost(v->value, &celliax_default.capture_boost)) + M_UINT("celliax_dir_entry_extension_prefix", + celliax_default.celliax_dir_entry_extension_prefix) + M_UINT("celliax_dir_prefix", celliax_default.celliax_dir_prefix) + M_STR("sms_receiving_program", tmp->sms_receiving_program) + M_END(; + ); + } + } + + /* initialize the newly created PVT from the celliax_default values */ + *tmp = celliax_default; + + /* initialize the mutexes */ + ast_mutex_init(&tmp->controldev_lock); + ast_mutex_init(&tmp->fbus2_outgoing_list_lock); +#ifdef CELLIAX_CVM + ast_mutex_init(&tmp->cvm_busmail_outgoing_list_lock); +#endif /* CELLIAX_CVM */ + + /* the category name becomes the interface name */ + tmp->name = strdup(ctg); + + /* for each category in config file, "first" included, read in ALL the values */ + for (v = ast_variable_browse(cfg, ctg); v; v = v->next) { + M_START(v->name, v->value); + + M_BOOL("debug_all", debug_all) + M_BOOL("debug_at", debug_at) + M_BOOL("debug_fbus2", debug_fbus2) + M_BOOL("debug_serial", debug_serial) + M_BOOL("debug_sound", debug_sound) + M_BOOL("debug_pbx", debug_pbx) + M_BOOL("debug_skype", debug_skype) + M_BOOL("debug_call", debug_call) + M_BOOL("debug_locks", debug_locks) + M_BOOL("debug_monitorlocks", debug_monitorlocks) +#ifdef CELLIAX_CVM + M_BOOL("debug_cvm", debug_cvm) + M_STR("cvm_subscription_1_pin", tmp->cvm_subsc_1_pin) + M_STR("cvm_subscription_2_pin", tmp->cvm_subsc_2_pin) + M_UINT("cvm_subscription_no", tmp->cvm_subsc_no) + M_UINT("cvm_volume_level", tmp->cvm_volume_level) + M_UINT("cvm_celliax_serial_delay", tmp->cvm_celliax_serial_delay) +#endif /* CELLIAX_CVM */ + M_BOOL("skype", tmp->skype) + M_BOOL("need_acoustic_ring", tmp->need_acoustic_ring) + M_STR("control_device_name", tmp->controldevice_name) + M_UINT("control_device_speed", tmp->controldevice_speed) + M_STR("control_device_protocol", tmp->controldevprotocolname) + M_STR("context", tmp->context) + M_STR("language", tmp->language) + M_STR("extension", tmp->exten) + M_UINT("dsp_silence_threshold", tmp->dsp_silence_threshold) + M_UINT("audio_play_reset_period", tmp->audio_play_reset_period) + M_UINT("portaudio_capture_device_id", tmp->portaudiocindex) + M_UINT("portaudio_playback_device_id", tmp->portaudiopindex) + M_F("playback_boost", celliax_store_boost(v->value, &tmp->playback_boost)) + M_F("capture_boost", celliax_store_boost(v->value, &tmp->capture_boost)) +#ifdef CELLIAX_ALSA + M_STR("alsa_capture_device_name", tmp->alsacname) + M_STR("alsa_playback_device_name", tmp->alsapname) + M_UINT("alsa_period_size", tmp->alsa_period_size) + M_UINT("alsa_periods_in_buffer", tmp->alsa_periods_in_buffer) +#endif /* CELLIAX_WINMM */ + M_STR("at_dial_pre_number", tmp->at_dial_pre_number) + M_STR("at_dial_post_number", tmp->at_dial_post_number) + + M_STR("at_dial_expect", tmp->at_dial_expect) + M_UINT("at_early_audio", tmp->at_early_audio) + M_STR("at_hangup", tmp->at_hangup) + M_STR("at_hangup_expect", tmp->at_hangup_expect) + M_STR("at_answer", tmp->at_answer) + M_STR("at_answer_expect", tmp->at_answer_expect) + M_STR("at_send_dtmf", tmp->at_send_dtmf) + + M_UINT("at_initial_pause", tmp->at_initial_pause) + M_STR("at_preinit_1", tmp->at_preinit_1) + M_STR("at_preinit_1_expect", tmp->at_preinit_1_expect) + M_STR("at_preinit_2", tmp->at_preinit_2) + M_STR("at_preinit_2_expect", tmp->at_preinit_2_expect) + M_STR("at_preinit_3", tmp->at_preinit_3) + M_STR("at_preinit_3_expect", tmp->at_preinit_3_expect) + M_STR("at_preinit_4", tmp->at_preinit_4) + M_STR("at_preinit_4_expect", tmp->at_preinit_4_expect) + M_STR("at_preinit_5", tmp->at_preinit_5) + M_STR("at_preinit_5_expect", tmp->at_preinit_5_expect) + M_UINT("at_after_preinit_pause", tmp->at_after_preinit_pause) + + M_STR("at_postinit_1", tmp->at_postinit_1) + M_STR("at_postinit_1_expect", tmp->at_postinit_1_expect) + M_STR("at_postinit_2", tmp->at_postinit_2) + M_STR("at_postinit_2_expect", tmp->at_postinit_2_expect) + M_STR("at_postinit_3", tmp->at_postinit_3) + M_STR("at_postinit_3_expect", tmp->at_postinit_3_expect) + M_STR("at_postinit_4", tmp->at_postinit_4) + M_STR("at_postinit_4_expect", tmp->at_postinit_4_expect) + M_STR("at_postinit_5", tmp->at_postinit_5) + M_STR("at_postinit_5_expect", tmp->at_postinit_5_expect) + + M_STR("at_query_battchg", tmp->at_query_battchg) + M_STR("at_query_battchg_expect", tmp->at_query_battchg_expect) + M_STR("at_query_signal", tmp->at_query_signal) + M_STR("at_query_signal_expect", tmp->at_query_signal_expect) + M_STR("at_call_idle", tmp->at_call_idle) + M_STR("at_call_incoming", tmp->at_call_incoming) + M_STR("at_call_active", tmp->at_call_active) + M_STR("at_call_failed", tmp->at_call_failed) + M_STR("at_call_calling", tmp->at_call_calling) + M_STR("at_indicator_noservice_string", tmp->at_indicator_noservice_string) + M_STR("at_indicator_nosignal_string", tmp->at_indicator_nosignal_string) + M_STR("at_indicator_lowsignal_string", tmp->at_indicator_lowsignal_string) + M_STR("at_indicator_lowbattchg_string", tmp->at_indicator_lowbattchg_string) + M_STR("at_indicator_nobattchg_string", tmp->at_indicator_nobattchg_string) + M_STR("at_indicator_callactive_string", tmp->at_indicator_callactive_string) + M_STR("at_indicator_nocallactive_string", tmp->at_indicator_nocallactive_string) + M_STR("at_indicator_nocallsetup_string", tmp->at_indicator_nocallsetup_string) + M_STR("at_indicator_callsetupincoming_string", + tmp->at_indicator_callsetupincoming_string) + M_STR("at_indicator_callsetupoutgoing_string", + tmp->at_indicator_callsetupoutgoing_string) + M_STR("at_indicator_callsetupremoteringing_string", + tmp->at_indicator_callsetupremoteringing_string) + M_UINT("celliax_dir_entry_extension_prefix", + tmp->celliax_dir_entry_extension_prefix) + M_UINT("celliax_dir_prefix", tmp->celliax_dir_prefix) +#ifdef CELLIAX_LIBCSV + M_UINT("csv_separator_is_semicolon", tmp->csv_separator_is_semicolon) + M_UINT("csv_complete_name_pos", tmp->csv_complete_name_pos) + M_UINT("csv_email_pos", tmp->csv_email_pos) + M_UINT("csv_home_phone_pos", tmp->csv_home_phone_pos) + M_UINT("csv_mobile_phone_pos", tmp->csv_mobile_phone_pos) + M_UINT("csv_business_phone_pos", tmp->csv_business_phone_pos) + M_UINT("csv_first_row_is_title", tmp->csv_first_row_is_title) +#endif /* CELLIAX_LIBCSV */ + M_STR("sms_receiving_program", tmp->sms_receiving_program) + M_BOOL("speexecho", tmp->speexecho) + M_BOOL("speexpreprocess", tmp->speexpreprocess) + M_END(; + ); + } + + if (debug_all) { + celliax_debug = celliax_debug | DEBUG_ALL; + if (!option_debug) { + WARNINGA + ("DEBUG_ALL activated, but option_debug is 0. You have to set debug level higher than zero to see some debugging output. Please use the command \"set debug 10\" or start Asterisk with \"-dddddddddd\" option for full DEBUG_ALL debugging output.\n", + CELLIAX_TMP_LOG); + } else { + NOTICA("DEBUG_ALL activated. \n", CELLIAX_TMP_LOG); + } + } + if (debug_at) { + celliax_debug = celliax_debug | DEBUG_AT; + if (!option_debug) { + WARNINGA + ("DEBUG_AT activated, but option_debug is 0. You have to set debug level higher than zero to see some debugging output. Please use the command \"set debug 10\" or start Asterisk with \"-dddddddddd\" option for full DEBUG_AT debugging output.\n", + CELLIAX_TMP_LOG); + } else { + NOTICA("DEBUG_AT activated. \n", CELLIAX_TMP_LOG); + } + } + + if (debug_fbus2) { + celliax_debug = celliax_debug | DEBUG_FBUS2; + if (!option_debug) { + WARNINGA + ("DEBUG_FBUS2 activated, but option_debug is 0. You have to set debug level higher than zero to see some debugging output. Please use the command \"set debug 10\" or start Asterisk with \"-dddddddddd\" option for full DEBUG_FBUS2 debugging output.\n", + CELLIAX_TMP_LOG); + } else { + NOTICA("DEBUG_FBUS2 activated. \n", CELLIAX_TMP_LOG); + } + } + + if (debug_serial) { + celliax_debug = celliax_debug | DEBUG_SERIAL; + if (!option_debug) { + WARNINGA + ("DEBUG_SERIAL activated, but option_debug is 0. You have to set debug level higher than zero to see some debugging output. Please use the command \"set debug 10\" or start Asterisk with \"-dddddddddd\" option for full DEBUG_SERIAL debugging output.\n", + CELLIAX_TMP_LOG); + } else { + NOTICA("DEBUG_SERIAL activated. \n", CELLIAX_TMP_LOG); + } + } + + if (debug_sound) { + celliax_debug = celliax_debug | DEBUG_SOUND; + if (!option_debug) { + WARNINGA + ("DEBUG_SOUND activated, but option_debug is 0. You have to set debug level higher than zero to see some debugging output. Please use the command \"set debug 10\" or start Asterisk with \"-dddddddddd\" option for full DEBUG_SOUND debugging output.\n", + CELLIAX_TMP_LOG); + } else { + NOTICA("DEBUG_SOUND activated. \n", CELLIAX_TMP_LOG); + } + } + + if (debug_pbx) { + celliax_debug = celliax_debug | DEBUG_PBX; + if (!option_debug) { + WARNINGA + ("DEBUG_PBX activated, but option_debug is 0. You have to set debug level higher than zero to see some debugging output. Please use the command \"set debug 10\" or start Asterisk with \"-dddddddddd\" option for full DEBUG_PBX debugging output.\n", + CELLIAX_TMP_LOG); + } else { + NOTICA("DEBUG_PBX activated. \n", CELLIAX_TMP_LOG); + } + } + + if (debug_call) { + celliax_debug = celliax_debug | DEBUG_CALL; + if (!option_debug) { + WARNINGA + ("DEBUG_CALL activated, but option_debug is 0. You have to set debug level higher than zero to see some debugging output. Please use the command \"set debug 10\" or start Asterisk with \"-dddddddddd\" option for full DEBUG_CALL debugging output.\n", + CELLIAX_TMP_LOG); + } else { + NOTICA("DEBUG_CALL activated. \n", CELLIAX_TMP_LOG); + } + } + + if (debug_locks) { + celliax_debug = celliax_debug | DEBUG_LOCKS; + if (!option_debug) { + WARNINGA + ("DEBUG_LOCKS activated, but option_debug is 0. You have to set debug level higher than zero to see some debugging output. Please use the command \"set debug 10\" or start Asterisk with \"-dddddddddd\" option for full DEBUG_LOCKS debugging output.\n", + CELLIAX_TMP_LOG); + } else { + NOTICA("DEBUG_LOCKS activated. \n", CELLIAX_TMP_LOG); + } + } + + if (debug_monitorlocks) { + celliax_debug = celliax_debug | DEBUG_MONITORLOCKS; + if (!option_debug) { + WARNINGA + ("DEBUG_MONITORLOCKS activated, but option_debug is 0. You have to set debug level higher than zero to see some debugging output. Please use the command \"set debug 10\" or start Asterisk with \"-dddddddddd\" option for full DEBUG_MONITORLOCKS debugging output.\n", + CELLIAX_TMP_LOG); + } else { + NOTICA("DEBUG_MONITORLOCKS activated. \n", CELLIAX_TMP_LOG); + } + } +#ifdef CELLIAX_CVM + if (debug_cvm) { + celliax_debug = celliax_debug | DEBUG_CVM; + if (!option_debug) { + WARNINGA + ("DEBUG_CVM activated, but option_debug is 0. You have to set debug level higher than zero to see some debugging output. Please use the command \"set debug 10\" or start Asterisk with \"-dddddddddd\" option for full DEBUG_CVM debugging output.\n", + CELLIAX_TMP_LOG); + } else { + NOTICA("DEBUG_CVM activated. \n", CELLIAX_TMP_LOG); + } + } +#endif /* CELLIAX_CVM */ + + if (option_debug > 1) { + DEBUGA_SOUND("playback_boost is %f\n", CELLIAX_TMP_LOG, tmp->playback_boost); + DEBUGA_SOUND("capture_boost is %f\n", CELLIAX_TMP_LOG, tmp->capture_boost); + } + + /* serial protocols are named in config with a string, but as int in this software */ + if (strcasecmp(tmp->controldevprotocolname, "fbus2") == 0) + tmp->controldevprotocol = PROTOCOL_FBUS2; + else if (strcasecmp(tmp->controldevprotocolname, "at") == 0) + tmp->controldevprotocol = PROTOCOL_AT; + else if (strcasecmp(tmp->controldevprotocolname, "no_serial") == 0) + tmp->controldevprotocol = PROTOCOL_NO_SERIAL; + else if (strcasecmp(tmp->controldevprotocolname, "alsa_voicemodem") == 0) + tmp->controldevprotocol = PROTOCOL_ALSA_VOICEMODEM; +#ifdef CELLIAX_CVM + else if (strcasecmp(tmp->controldevprotocolname, "cvm_busmail") == 0) + tmp->controldevprotocol = PROTOCOL_CVM_BUSMAIL; +#endif /* CELLIAX_CVM */ + else { +#ifndef CELLIAX_CVM + ERRORA + ("control_device_protocol in celliax.conf MUST be = fbus2|at|no_serial|alsa_voicemodem, but is = '%s'\n", + CELLIAX_TMP_LOG, + tmp->controldevprotocolname ? tmp->controldevprotocolname : "NULL"); +#else + ERRORA + ("control_device_protocol in celliax.conf MUST be = fbus2|at|no_serial|alsa_voicemodem|cvm_busmail, but is = '%s'\n", + CELLIAX_TMP_LOG, + tmp->controldevprotocolname ? tmp->controldevprotocolname : "NULL"); +#endif /* CELLIAX_CVM */ + + /* we failed, free the PVT */ + free(tmp); + return NULL; + } + + if (tmp->controldevice_speed != celliax_default.controldevice_speed) { + /* serial speeds are numbers in config file, but we needs definitions in this software */ + if (tmp->controldevice_speed == 9600) + tmp->controldevice_speed = B9600; + else if (tmp->controldevice_speed == 19200) + tmp->controldevice_speed = B19200; + else if (tmp->controldevice_speed == 38400) + tmp->controldevice_speed = B38400; + else if (tmp->controldevice_speed == 57600) + tmp->controldevice_speed = B57600; + else if (tmp->controldevice_speed == 115200) + tmp->controldevice_speed = B115200; + else { + ERRORA + ("controldevice_speed has to be given one of the following values: 9600|19200|38400|57600|115200. In the config file, was given: %d\n", + CELLIAX_TMP_LOG, tmp->controldevice_speed); + free(tmp); + return NULL; + } + } + +/* CVM PP DECT modules supports registration to two DECT FPs (bases), but CVM can be only connected to one DECT FP at the time, so we need two PINs (for registration) and info to which DECT FP connect*/ +#ifdef CELLIAX_CVM + if (tmp->cvm_subsc_no != celliax_default.cvm_subsc_no) { + if ((tmp->cvm_subsc_no != 1) && (tmp->cvm_subsc_no != 2)) { + ERRORA + ("cvm_subscription_no has to be given one of the following values: 1|2. In the config file, was given: %d\n", + CELLIAX_TMP_LOG, tmp->cvm_subsc_no); + free(tmp); + return NULL; + } + } + + if (tmp->cvm_subsc_1_pin != celliax_default.cvm_subsc_1_pin) { + if (4 != strlen(tmp->cvm_subsc_1_pin)) { + ERRORA + ("cvm_subscription_1_pin has to be 4 digits long. In the config file, was given: %s\n", + CELLIAX_TMP_LOG, tmp->cvm_subsc_1_pin); + free(tmp); + return NULL; + } + } + + if (tmp->cvm_subsc_2_pin != celliax_default.cvm_subsc_2_pin) { + if (4 != strlen(tmp->cvm_subsc_2_pin)) { + ERRORA + ("cvm_subscription_2_pin has to be 4 digits long. In the config file, was given: %s\n", + CELLIAX_TMP_LOG, tmp->cvm_subsc_2_pin); + free(tmp); + return NULL; + } + } + + if (tmp->cvm_volume_level != celliax_default.cvm_volume_level) { + if ((0 > tmp->cvm_volume_level) && (9 < tmp->cvm_volume_level)) { + ERRORA("cvm_volume_level has to be 0-9. In the config file, was given: %d\n", + CELLIAX_TMP_LOG, tmp->cvm_volume_level); + free(tmp); + return NULL; + } + } + + if (tmp->cvm_celliax_serial_delay != celliax_default.cvm_celliax_serial_delay) { + if ((0 > tmp->cvm_celliax_serial_delay) && (65535 < tmp->cvm_celliax_serial_delay)) { + ERRORA + ("cvm_celliax_serial_dealy has to be 0-65535. In the config file, was given: %d\n", + CELLIAX_TMP_LOG, tmp->cvm_celliax_serial_delay); + free(tmp); + return NULL; + } + } +#endif /* CELLIAX_CVM */ + if (tmp->need_acoustic_ring) { + /* alloc and initialize a new dsp struct for this interface pvt, WITH silence suppression */ + if (celliax_sound_dsp_set(tmp, tmp->dsp_silence_threshold, 1)) { + ERRORA("celliax_sound_dsp_set failed\n", CELLIAX_TMP_LOG); + celliax_sound_shutdown(tmp); + if (tmp) + free(tmp); + return NULL; + } + +/* initialize the soundcard channels (input and output) used by this interface (a multichannel soundcard can be used by multiple interfaces), optionally starting the sound managing threads */ + res = celliax_sound_init(tmp); + if (res == -1) { + ERRORA("Failed initializing sound device\n", CELLIAX_TMP_LOG); + /* we failed, free the PVT */ + if (tmp) + free(tmp); + return NULL; + } + + } + + /* init the serial port */ + if (tmp->controldevprotocol != PROTOCOL_NO_SERIAL) { + tmp->controldevfd = celliax_serial_init(tmp, tmp->controldevice_speed); + if (tmp->controldevfd < 1) { + ERRORA("celliax_serial_init failed\n", CELLIAX_TMP_LOG); + celliax_sound_shutdown(tmp); + if (tmp) + free(tmp); + return NULL; + } + } + + /* config the phone/modem on the serial port */ + if (tmp->controldevprotocol != PROTOCOL_NO_SERIAL) { + //int res; + res = celliax_serial_config(tmp); + if (res) { + ERRORA("celliax_serial_config failed\n", CELLIAX_TMP_LOG); + celliax_sound_shutdown(tmp); + if (tmp) + free(tmp); + return NULL; + } + } + + /* return the newly created celliax_pvt */ + return tmp; +} + +/*! \brief (Re)Start the module main monitor thread, watching for incoming calls on the interfaces */ +int celliax_restart_monitor(void) +{ + static struct celliax_pvt *p = &celliax_log_struct; + /* If we're supposed to be stopped -- stay stopped */ + if (celliax_monitor_thread == AST_PTHREADT_STOP) + return 0; + LOKKA(&celliax_monlock); + /* Do not seems possible to me that this function can be called by the very same monitor thread, but let's be paranoid */ + if (celliax_monitor_thread == pthread_self()) { + UNLOCKA(&celliax_monlock); + ERRORA("Cannot kill myself\n", CELLIAX_P_LOG); + return -1; + } + /* if the monitor thread exists */ + if (celliax_monitor_thread != AST_PTHREADT_NULL) { + /* Wake up the thread, it can be stuck waiting in a select or so */ + pthread_kill(celliax_monitor_thread, SIGURG); + pthread_kill(celliax_monitor_audio_thread, SIGURG); + } else { + /* the monitor thread does not exists, start a new monitor */ + if (ast_pthread_create(&celliax_monitor_thread, NULL, celliax_do_monitor, NULL) < 0) { + UNLOCKA(&celliax_monlock); + ERRORA("Unable to start monitor thread.\n", CELLIAX_P_LOG); + return -1; + } + + if (ast_pthread_create + (&celliax_monitor_audio_thread, NULL, celliax_do_audio_monitor, NULL) < 0) { + ERRORA("Unable to start audio_monitor thread.\n", CELLIAX_P_LOG); + return -1; + } + + } + UNLOCKA(&celliax_monlock); + return 0; +} + +/*! \brief The celliax monitoring thread + * \note This thread monitors all the celliax interfaces that are not in a call + * (and thus do not have a separate thread) indefinitely + * */ +void *celliax_do_monitor(void *data) +{ + fd_set rfds; + int res; + struct celliax_pvt *p = NULL; + int max = -1; + struct timeval to; + time_t now_timestamp; + + if (pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED, NULL)) { + ERRORA("Unable to set cancel type to deferred\n", CELLIAX_P_LOG); + return NULL; + } + + for (;;) { + pthread_testcancel(); + /* Don't let anybody kill us right away. Nobody should lock the interface list + and wait for the monitor list, but the other way around is okay. */ + PUSHA_UNLOCKA(&celliax_monlock); + MONITORLOKKA(&celliax_monlock); + /* Lock the interface list */ + PUSHA_UNLOCKA(&celliax_iflock); + MONITORLOKKA(&celliax_iflock); + /* Build the stuff we're going to select on, that is the celliax_serial_fd of every + celliax_pvt that does not have an associated owner channel. In the case of FBUS2 3310 + and in the case of PROTOCOL_NO_SERIAL we add the audio_fd as well, because there is not serial signaling of incoming calls */ + FD_ZERO(&rfds); + + time(&now_timestamp); + p = celliax_iflist; + while (p) { + if (!p->owner) { + /* This interface needs to be watched, as it lacks an owner */ + + if (p->controldevprotocol != PROTOCOL_NO_SERIAL && !p->controldev_dead) { + /* This interface needs its serial connection to be watched, nokia 3310 and compatibles needs sounds as well */ + if (FD_ISSET(p->controldevfd, &rfds)) { + ERRORA("Bizarre! Descriptor %d (controldevfd) appears twice ?\n", + CELLIAX_P_LOG, p->controldevfd); + } + if (p->controldevfd > 0) { + + //time(&now_timestamp); + if ((now_timestamp - p->celliax_serial_synced_timestamp) > p->celliax_serial_sync_period) { //TODO find a sensible period. 5min? in config? + int rt; + if (option_debug > 1) + DEBUGA_SERIAL("Syncing Serial\n", CELLIAX_P_LOG); + rt = celliax_serial_sync(p); + if (rt) { + p->controldev_dead = 1; + close(p->controldevfd); + ERRORA("serial sync failed, declaring %s dead\n", CELLIAX_P_LOG, + p->controldevice_name); + } + rt = celliax_serial_getstatus(p); + if (rt) { + p->controldev_dead = 1; + close(p->controldevfd); + ERRORA("serial getstatus failed, declaring %s dead\n", CELLIAX_P_LOG, + p->controldevice_name); + } + + } + + if (!p->controldev_dead) { + /* add this file descriptor to the set watched by the select */ + FD_SET(p->controldevfd, &rfds); + if (p->controldevfd > max) { + /* adjust the maximum file descriptor value the select has to watch for */ + max = p->controldevfd; + } + } + } + } + + } + /* next interface, please */ + p = p->next; + } + /* Okay, now that we know what to do, release the interface lock */ + MONITORUNLOCKA(&celliax_iflock); + POPPA_UNLOCKA(&celliax_iflock); + /* And from now on, we're okay to be killed, so release the monitor lock as well */ + MONITORUNLOCKA(&celliax_monlock); + POPPA_UNLOCKA(&celliax_monlock); + + /* you want me to die? */ + pthread_testcancel(); + + /* Wait for something to happen */ + to.tv_sec = 0; + to.tv_usec = 500000; /* we select with this timeout because under cygwin we avoid the signal usage, so there is no way to end the thread if it is stuck waiting for select */ + res = ast_select(max + 1, &rfds, NULL, NULL, &to); + + /* you want me to die? */ + pthread_testcancel(); + + /* Okay, select has finished. Let's see what happened. */ + + /* If there are errors... */ + if (res < 0) { + if (errno == EINTR) /* EINTR is just the select + being interrupted by a SIGURG, or so */ + continue; + else { + ERRORA("select returned %d: %s\n", CELLIAX_P_LOG, res, strerror(errno)); +//FIXME what to do here? is the interface that failed signaled? which interface we have to disable? + return NULL; + } + } + + /* must not be killed while celliax_iflist is locked */ + PUSHA_UNLOCKA(&celliax_monlock); + MONITORLOKKA(&celliax_monlock); + /* Alright, lock the interface list again, and let's look and see what has + happened */ + PUSHA_UNLOCKA(&celliax_iflock); + MONITORLOKKA(&celliax_iflock); + + p = celliax_iflist; + for (; p; p = p->next) { + + if (p->controldevprotocol != PROTOCOL_NO_SERIAL && !p->controldev_dead) { + if (!p->owner) { //give all the serial channels that have no owner a read, so we can have the timers clicking + + if (!p->celliax_serial_monitoring) { + p->celliax_serial_monitoring = 1; + res = celliax_serial_monitor(p); + if (res == -1) { //manage the graceful interface shutdown + p->controldev_dead = 1; + close(p->controldevfd); + ERRORA("celliax_serial_monitor failed, declaring %s dead\n", CELLIAX_P_LOG, + p->controldevice_name); + } else if (!p->need_acoustic_ring + && p->controldevprotocol != PROTOCOL_NO_SERIAL + && p->interface_state == AST_STATE_RING) { + if (option_debug) + DEBUGA_PBX("INCOMING RING\n", CELLIAX_P_LOG); + if (!celliax_new(p, AST_STATE_RING, p->context)) { + //FIXME what to do here? + ERRORA("celliax_new failed! BAD BAD BAD\n", CELLIAX_P_LOG); + } + } + p->celliax_serial_monitoring = 0; + } + } + } + + if (p->controldevprotocol != PROTOCOL_NO_SERIAL && p->controldev_dead) { + + /* init the serial port */ + p->controldevfd = celliax_serial_init(p, p->controldevice_speed); + if (p->controldevfd < 1) { + DEBUGA_SERIAL("celliax_serial_init failed\n", CELLIAX_P_LOG); + } else { + + /* config the phone/modem on the serial port */ + res = celliax_serial_config(p); + if (res) { + DEBUGA_SERIAL("celliax_serial_config failed\n", CELLIAX_P_LOG); + close(p->controldevfd); + } else { + + NOTICA("Wow, the serial port has come back! Let's see if it will work\n", + CELLIAX_P_LOG); + p->controldev_dead = 0; + } + + } + + } + + } + MONITORUNLOCKA(&celliax_iflock); + POPPA_UNLOCKA(&celliax_iflock); + MONITORUNLOCKA(&celliax_monlock); + POPPA_UNLOCKA(&celliax_monlock); + pthread_testcancel(); + } +/* Never reached */ + return NULL; + +} + +void *celliax_do_audio_monitor(void *data) +{ + fd_set rfds; + int res; + struct celliax_pvt *p = NULL; + int max = -1; + struct timeval to; + + if (pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED, NULL)) { + ERRORA("Unable to set cancel type to deferred\n", CELLIAX_P_LOG); + return NULL; + } + + for (;;) { + pthread_testcancel(); + /* Lock the interface list */ + PUSHA_UNLOCKA(&celliax_iflock); + MONITORLOKKA(&celliax_iflock); + + FD_ZERO(&rfds); + + p = celliax_iflist; + while (p) { + if (!p->owner) { + /* This interface needs to be watched, as it lacks an owner */ + + if (p->controldevprotocol == PROTOCOL_NO_SERIAL || p->need_acoustic_ring) { + /* This interface needs its incoming sound to be watched, because it cannot signal incoming ring from serial (eg nokia 3310 and compatibles) */ + if (p->celliax_sound_capt_fd > 0) { + /* if fd exist */ + if (FD_ISSET(p->celliax_sound_capt_fd, &rfds)) { + ERRORA("Bizarre! Descriptor %d (celliax_sound_capt_fd) appears twice ?\n", + CELLIAX_P_LOG, p->celliax_sound_capt_fd); + } + /* add this file descriptor to the set watched by the select */ + FD_SET(p->celliax_sound_capt_fd, &rfds); + if (p->celliax_sound_capt_fd > max) { + /* adjust the maximum file descriptor value the select has to watch for */ + max = p->celliax_sound_capt_fd; + } + } + } + + } + /* next interface, please */ + p = p->next; + } + /* Okay, now that we know what to do, release the interface lock */ + + MONITORUNLOCKA(&celliax_iflock); + POPPA_UNLOCKA(&celliax_iflock); + /* you want me to die? */ + pthread_testcancel(); + + /* Wait for something to happen */ + to.tv_sec = 0; + to.tv_usec = 500000; /* we select with this timeout because under cygwin we avoid the signal usage, so there is no way to end the thread if it is stuck waiting for select */ + res = ast_select(max + 1, &rfds, NULL, NULL, &to); + + /* you want me to die? */ + pthread_testcancel(); + + /* Okay, select has finished. Let's see what happened. */ + + /* If there are errors... */ + if (res < 0) { + if (errno == EINTR) { /* EINTR is just the select + being interrupted by a SIGURG, or so */ + usleep(100); + continue; + } else { + ERRORA("select returned %d: %s\n", CELLIAX_P_LOG, res, strerror(errno)); +//FIXME what to do here? is the interface that failed signaled? which interface we have to disable? + return NULL; + } + } + /* If there are no file descriptors changed, just continue */ + + if (res == 0) { + usleep(100); //let's breath + continue; + } +//usleep(10); //let's breath + + /* Lock the interface list */ + PUSHA_UNLOCKA(&celliax_iflock); + MONITORLOKKA(&celliax_iflock); + + p = celliax_iflist; + for (; p; p = p->next) { + + if (FD_ISSET(p->celliax_sound_capt_fd, &rfds)) { + res = celliax_sound_monitor(p); + if (res < 0) { + ERRORA("celliax_sound_monitor ERROR %d\n", CELLIAX_P_LOG, res); + } else if (res == CALLFLOW_INCOMING_RING) { + p->phone_callflow = CALLFLOW_INCOMING_RING; + p->interface_state = AST_STATE_RING; + if (option_debug) + DEBUGA_PBX("INCOMING RING\n", CELLIAX_P_LOG); + if (!celliax_new(p, AST_STATE_RING, p->context)) + ERRORA("celliax_new failed! BAD BAD BAD\n", CELLIAX_P_LOG); + } else { + } + + } + + } +/* Okay, now that we know what to do, release the interface lock */ + + MONITORUNLOCKA(&celliax_iflock); + POPPA_UNLOCKA(&celliax_iflock); + + pthread_testcancel(); + } +/* Never reached */ + return NULL; +} + +/*! + * \brief Initialize the soundcard channels (input and output) used by one interface (a multichannel soundcard can be used by multiple interfaces) + * \param p the celliax_pvt of the interface + * + * This function initialize the soundcard channels (input and output) used by one interface (a multichannel soundcard can be used by multiple interfaces). It simply pass its parameters to the right function for the sound system for which has been compiled, eg. alsa_init for ALSA, oss_init for OSS, winmm_init for Windows Multimedia, etc and return the result + * + * \return zero on success, -1 on error. + */ + +int celliax_sound_init(struct celliax_pvt *p) +{ +#ifdef CELLIAX_ALSA + return alsa_init(p); +#endif /* CELLIAX_ALSA */ +#ifdef CELLIAX_PORTAUDIO + return celliax_portaudio_init(p); +#endif /* CELLIAX_PORTAUDIO */ + + return -1; +} + +/*! + * \brief Shutdown the soundcard channels (input and output) used by one interface (a multichannel soundcard can be used by multiple interfaces) + * \param p the celliax_pvt of the interface + * + * This function shutdown the soundcard channels (input and output) used by one interface (a multichannel soundcard can be used by multiple interfaces). It simply pass its parameters to the right function for the sound system for which has been compiled, eg. alsa_shutdown for ALSA, oss_shutdown for OSS, winmm_shutdown for Windows Multimedia, etc and return the result + * + * \return zero on success, -1 on error. + */ + +int celliax_sound_shutdown(struct celliax_pvt *p) +{ + +#ifdef CELLIAX_ALSA + return alsa_shutdown(p); +#endif /* CELLIAX_ALSA */ +#ifdef CELLIAX_PORTAUDIO + return celliax_portaudio_shutdown(p); +#endif /* CELLIAX_PORTAUDIO */ + + return -1; +} + +/*! \brief returns an asterisk frame categorized by dsp algorithms */ +struct ast_frame *celliax_sound_dsp_analize(struct celliax_pvt *p, struct ast_frame *f, + int dsp_silence_threshold) +{ + if (!p->dsp) { + DEBUGA_SOUND("no dsp, initializing it \n", CELLIAX_P_LOG); + if (celliax_sound_dsp_set(p, dsp_silence_threshold, 1)) { + ERRORA("celliax_sound_dsp_set failed\n", CELLIAX_P_LOG); + return NULL; + } + } + + /* process with dsp */ + if (p->dsp) { + if (f->frametype == AST_FRAME_VOICE) { + f = ast_dsp_process(p->owner, p->dsp, f); + } else { + //WARNINGA("not a VOICE frame ! \n", CELLIAX_P_LOG); + } + } + return f; +} + +/*! \brief initialize the dsp algorithms and structures */ +int celliax_sound_dsp_set(struct celliax_pvt *p, int dsp_silence_threshold, + int silence_suppression) +{ + +/* let asterisk dsp algorithms detect dtmf */ + if (p->dsp) { + return 0; + } + if (option_debug > 1) + DEBUGA_SOUND("alloc dsp \n", CELLIAX_P_LOG); + p->dsp = ast_dsp_new(); + if (p->dsp) { + if (silence_suppression) { + ast_dsp_set_threshold(p->dsp, dsp_silence_threshold); + DEBUGA_SOUND("set dsp_silence_threshold=%d\n", CELLIAX_P_LOG, + dsp_silence_threshold); + if (option_debug > 1) + DEBUGA_SOUND("Detecting silence, I mean, voice\n", CELLIAX_P_LOG); + ast_dsp_set_features(p->dsp, 0 | DSP_FEATURE_SILENCE_SUPPRESS); + } else { + if (option_debug > 1) + DEBUGA_SOUND("WITHOUT SILENCE_SUPPRESS, Detecting inband dtmf with sw DSP\n", + CELLIAX_P_LOG); + +#ifdef ASTERISK_VERSION_1_6_0_1 + ast_dsp_set_features(p->dsp, 0 | DSP_FEATURE_DIGIT_DETECT); +#else + ast_dsp_set_features(p->dsp, 0 | DSP_FEATURE_DTMF_DETECT); +#endif /* ASTERISK_VERSION_1_6_0_1 */ + } + + /* + if (ast_dsp_digitmode(p->dsp, DSP_DIGITMODE_DTMF | DSP_DIGITMODE_RELAXDTMF)) { + ERRORA("ast_dsp_digitmode failed\n", CELLIAX_P_LOG); + return -1; + } + */ + } else { + ERRORA("ast_dsp_new failed\n", CELLIAX_P_LOG); + return -1; + } + return 0; +} + +/*! \brief Read audio frames from interface */ +struct ast_frame *celliax_sound_read(struct celliax_pvt *p) +{ + struct ast_frame *f = NULL; +#ifdef CELLIAX_ALSA + f = alsa_read(p); +#endif /* CELLIAX_ALSA */ +#ifdef CELLIAX_PORTAUDIO + f = celliax_portaudio_read(p); +#endif /* CELLIAX_PORTAUDIO */ + + return f; +} + +/*! \brief Send audio frame to interface */ +int celliax_sound_write(struct celliax_pvt *p, struct ast_frame *f) +{ + int ret = -1; + +#ifdef CELLIAX_ALSA + ret = alsa_write(p, f); +#endif /* CELLIAX_ALSA */ +#ifdef CELLIAX_PORTAUDIO + ret = celliax_portaudio_write(p, f); +#endif /* CELLIAX_PORTAUDIO */ + + return ret; +} + +/*! \brief read an audio frame and tell if is "voice" (interpreted as incoming RING) */ +int celliax_sound_monitor(struct celliax_pvt *p) +{ + struct ast_frame *f; + f = celliax_sound_read(p); + if (f) { + f = celliax_sound_dsp_analize(p, f, p->dsp_silence_threshold); + if (f) { + if (f->frametype == AST_FRAME_VOICE) { + DEBUGA_SOUND("VOICE\n", CELLIAX_P_LOG); + return CALLFLOW_INCOMING_RING; + } else { + return AST_STATE_DOWN; + } + } + } + return -1; +} + +/*! + * \brief This thread runs during a call, and monitor the interface serial port for signaling, like hangup, caller id, etc + * + */ +void *celliax_do_controldev_thread(void *data) +{ + struct celliax_pvt *p = data; + int res; + + DEBUGA_SERIAL("In celliax_do_controldev_thread: started, p=%p\n", CELLIAX_P_LOG, p); + + if (pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED, NULL)) { + ERRORA("Unable to set cancel type to deferred\n", CELLIAX_P_LOG); + return NULL; + } + + while (1) { + int rt; + time_t now_timestamp; + + if (p->controldevprotocol == PROTOCOL_NO_SERIAL) { + while (1) { + usleep(10000); + pthread_testcancel(); + } + } +#ifdef CELLIAX_CVM + if (p->controldevprotocol == PROTOCOL_CVM_BUSMAIL) { + usleep(p->cvm_celliax_serial_delay * 1000); //to get msecs + } else { + usleep(1000); + } + +#else + usleep(1000); +#endif /* CELLIAX_CVM */ + + pthread_testcancel(); + /* do not read from a dead controldev */ + if (p->controldev_dead) { + DEBUGA_SERIAL("celliax_do_controldev_thread: device %s is dead\n", CELLIAX_P_LOG, + p->controldevice_name); + if (p->owner) + celliax_queue_control(p->owner, AST_CONTROL_HANGUP); + return NULL; + } else { + pthread_testcancel(); + res = celliax_serial_read(p); + pthread_testcancel(); + if (res == -1) { + p->controldev_dead = 1; + close(p->controldevfd); + ERRORA("serial read failed, declaring %s dead\n", CELLIAX_P_LOG, + p->controldevice_name); + } + } + + pthread_testcancel(); + time(&now_timestamp); + if ((now_timestamp - p->celliax_serial_synced_timestamp) > p->celliax_serial_synced_timestamp && !p->controldev_dead) { //TODO find a sensible period. 5min? in config? + DEBUGA_SERIAL("Syncing Serial\n", CELLIAX_P_LOG); + pthread_testcancel(); + rt = celliax_serial_sync(p); + pthread_testcancel(); + if (rt) { + p->controldev_dead = 1; + close(p->controldevfd); + ERRORA("serial sync failed, declaring %s dead\n", CELLIAX_P_LOG, + p->controldevice_name); + } + pthread_testcancel(); + rt = celliax_serial_getstatus(p); + pthread_testcancel(); + if (rt) { + p->controldev_dead = 1; + close(p->controldevfd); + ERRORA("serial getstatus failed, declaring %s dead\n", CELLIAX_P_LOG, + p->controldevice_name); + } + + } + pthread_testcancel(); + } + return NULL; + +} + +int celliax_serial_init(struct celliax_pvt *p, speed_t controldevice_speed) +{ + int fd; + int rt; + struct termios tp; + +/* if there is a file descriptor, close it. But it is probably just an old value, so don't check for close success*/ + fd = p->controldevfd; + if (fd) { + close(fd); + } +/* open the serial port */ +#ifdef __CYGWIN__ + fd = open(p->controldevice_name, O_RDWR | O_NOCTTY | O_NONBLOCK); + sleep(1); + close(fd); +#endif /* __CYGWIN__ */ + fd = open(p->controldevice_name, O_RDWR | O_NOCTTY | O_NONBLOCK); + if (fd == -1) { + DEBUGA_SERIAL("serial error: %s\n", CELLIAX_P_LOG, strerror(errno)); + p->controldevfd = fd; + return -1; + } +/* flush it */ + rt = tcflush(fd, TCIFLUSH); + if (rt == -1) { + ERRORA("serial error: %s", CELLIAX_P_LOG, strerror(errno)); + } +/* attributes */ + tp.c_cflag = B0 | CS8 | CLOCAL | CREAD | HUPCL; + tp.c_iflag = IGNPAR; + tp.c_cflag &= ~CRTSCTS; + tp.c_oflag = 0; + tp.c_lflag = 0; + tp.c_cc[VMIN] = 1; + tp.c_cc[VTIME] = 0; +/* set controldevice_speed */ + rt = cfsetispeed(&tp, p->controldevice_speed); + if (rt == -1) { + ERRORA("serial error: %s", CELLIAX_P_LOG, strerror(errno)); + } + rt = cfsetospeed(&tp, p->controldevice_speed); + if (rt == -1) { + ERRORA("serial error: %s", CELLIAX_P_LOG, strerror(errno)); + } +/* set port attributes */ + if (tcsetattr(fd, TCSADRAIN, &tp) == -1) { + ERRORA("serial error: %s", CELLIAX_P_LOG, strerror(errno)); + } + rt = tcsetattr(fd, TCSANOW, &tp); + if (rt == -1) { + ERRORA("serial error: %s", CELLIAX_P_LOG, strerror(errno)); + } + unsigned int status = 0; +#ifndef __CYGWIN__ + ioctl(fd, TIOCMGET, &status); + status |= TIOCM_DTR; /* Set DTR high */ + status &= ~TIOCM_RTS; /* Set RTS low */ + ioctl(fd, TIOCMSET, &status); + ioctl(fd, TIOCMGET, &status); + unsigned int flags = TIOCM_DTR; + ioctl(fd, TIOCMBIS, &flags); + flags = TIOCM_RTS; + ioctl(fd, TIOCMBIC, &flags); + ioctl(fd, TIOCMGET, &status); +#else /* __CYGWIN__ */ + ioctl(fd, TIOCMGET, &status); + status |= TIOCM_DTR; /* Set DTR high */ + status &= ~TIOCM_RTS; /* Set RTS low */ + ioctl(fd, TIOCMSET, &status); +#endif /* __CYGWIN__ */ + p->controldevfd = fd; + DEBUGA_SERIAL("Syncing Serial\n", CELLIAX_P_LOG); + rt = celliax_serial_sync(p); + if (rt == -1) { + ERRORA("Serial init error\n", CELLIAX_P_LOG); + return -1; + } + return (fd); +} + +int celliax_serial_sync(struct celliax_pvt *p) +{ + if (p->controldevprotocol == PROTOCOL_AT) + return celliax_serial_sync_AT(p); +#ifdef CELLIAX_FBUS2 + if (p->controldevprotocol == PROTOCOL_FBUS2) + return celliax_serial_sync_FBUS2(p); +#endif /* CELLIAX_FBUS2 */ +#ifdef CELLIAX_CVM + if (p->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return celliax_serial_sync_CVM_BUSMAIL(p); +#endif /* CELLIAX_CVM */ + + return -1; +} + +int celliax_serial_getstatus(struct celliax_pvt *p) +{ + if (p->controldevprotocol == PROTOCOL_AT) + return celliax_serial_getstatus_AT(p); +#ifdef CELLIAX_FBUS2 + if (p->controldevprotocol == PROTOCOL_FBUS2) + return celliax_serial_getstatus_FBUS2(p); +#endif /* CELLIAX_FBUS2 */ + +#ifdef CELLIAX_CVM + if (p->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return celliax_serial_getstatus_CVM_BUSMAIL(p); +#endif /* CELLIAX_CVM */ + return -1; +} + +int celliax_serial_read(struct celliax_pvt *p) +{ + if (p->controldevprotocol == PROTOCOL_AT) + return celliax_serial_read_AT(p, 0, 100000, 0, NULL, 1); // a 10th of a second timeout +#ifdef CELLIAX_FBUS2 + if (p->controldevprotocol == PROTOCOL_FBUS2) + return celliax_serial_read_FBUS2(p); +#endif /* CELLIAX_FBUS2 */ +#ifdef CELLIAX_CVM + if (p->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return celliax_serial_read_CVM_BUSMAIL(p); +#endif /* CELLIAX_CVM */ + return -1; +} + +int celliax_serial_hangup(struct celliax_pvt *p) +{ + if (p->controldevprotocol == PROTOCOL_AT) + return celliax_serial_hangup_AT(p); +#ifdef CELLIAX_FBUS2 + if (p->controldevprotocol == PROTOCOL_FBUS2) + return celliax_serial_hangup_FBUS2(p); +#endif /* CELLIAX_FBUS2 */ +#ifdef CELLIAX_CVM + if (p->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return celliax_serial_hangup_CVM_BUSMAIL(p); +#endif /* CELLIAX_CVM */ + return -1; +} + +int celliax_serial_answer(struct celliax_pvt *p) +{ + if (p->controldevprotocol == PROTOCOL_AT) + return celliax_serial_answer_AT(p); +#ifdef CELLIAX_FBUS2 + if (p->controldevprotocol == PROTOCOL_FBUS2) + return celliax_serial_answer_FBUS2(p); +#endif /* CELLIAX_FBUS2 */ +#ifdef CELLIAX_CVM + if (p->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return celliax_serial_answer_CVM_BUSMAIL(p); +#endif /* CELLIAX_CVM */ + return -1; +} + +int celliax_serial_config(struct celliax_pvt *p) +{ + if (p->controldevprotocol == PROTOCOL_AT) + return celliax_serial_config_AT(p); +#ifdef CELLIAX_FBUS2 + if (p->controldevprotocol == PROTOCOL_FBUS2) + return celliax_serial_config_FBUS2(p); +#endif /* CELLIAX_FBUS2 */ +#ifdef CELLIAX_CVM + if (p->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return celliax_serial_config_CVM_BUSMAIL(p); +#endif /* CELLIAX_CVM */ + return -1; +} + +int celliax_serial_monitor(struct celliax_pvt *p) +{ + if (p->controldevprotocol == PROTOCOL_AT) + return celliax_serial_read_AT(p, 0, 100000, 0, NULL, 1); // a 10th of a second timeout +#ifdef CELLIAX_FBUS2 + if (p->controldevprotocol == PROTOCOL_FBUS2) + return celliax_serial_read_FBUS2(p); +#endif /* CELLIAX_FBUS2 */ +#ifdef CELLIAX_CVM + if (p->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return celliax_serial_read_CVM_BUSMAIL(p); +#endif /* CELLIAX_CVM */ + return -1; +} + +/************************************************/ + +/* LUIGI RIZZO's magic */ +/* + * store the boost factor + */ +#ifdef ASTERISK_VERSION_1_6_0 +void celliax_store_boost(const char *s, double *boost) +#else +void celliax_store_boost(char *s, double *boost) +#endif /* ASTERISK_VERSION_1_6_0 */ +{ + struct celliax_pvt *p = NULL; + + if (sscanf(s, "%lf", boost) != 1) { + ERRORA("invalid boost <%s>\n", CELLIAX_P_LOG, s); + return; + } + if (*boost < -BOOST_MAX) { + WARNINGA("boost %s too small, using %d\n", CELLIAX_P_LOG, s, -BOOST_MAX); + *boost = -BOOST_MAX; + } else if (*boost > BOOST_MAX) { + WARNINGA("boost %s too large, using %d\n", CELLIAX_P_LOG, s, BOOST_MAX); + *boost = BOOST_MAX; + } + *boost = exp(log(10) * *boost / 20) * BOOST_SCALE; + if (option_debug > 1) + DEBUGA_SOUND("setting boost %s to %f\n", CELLIAX_P_LOG, s, *boost); +} + +int celliax_serial_call(struct celliax_pvt *p, char *dstr) +{ + if (p->controldevprotocol == PROTOCOL_AT) + return celliax_serial_call_AT(p, dstr); +#ifdef CELLIAX_FBUS2 + if (p->controldevprotocol == PROTOCOL_FBUS2) + return celliax_serial_call_FBUS2(p, dstr); +#endif /* CELLIAX_FBUS2 */ + if (p->controldevprotocol == PROTOCOL_NO_SERIAL) + return 0; +#ifdef CELLIAX_CVM + if (p->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return celliax_serial_call_CVM_BUSMAIL(p, dstr); +#endif /* CELLIAX_CVM */ + return -1; +} + +/* + * returns a pointer to the descriptor with the given name + */ +struct celliax_pvt *celliax_console_find_desc(char *dev) +{ + struct celliax_pvt *p; + + for (p = celliax_iflist; p && strcmp(p->name, dev) != 0; p = p->next); + if (p == NULL) + WARNINGA("could not find <%s>\n", CELLIAX_P_LOG, dev); + + return p; +} + +int celliax_console_playback_boost(int fd, int argc, char *argv[]) +{ + struct celliax_pvt *p = celliax_console_find_desc(celliax_console_active); + + if (argc > 2) + return RESULT_SHOWUSAGE; + if (!p) { + ast_cli(fd, + "No \"current\" celliax_console for playback_boost, please enter 'help celliax_console'\n"); + return RESULT_SUCCESS; + } + + if (argc == 1) { + ast_cli(fd, "playback_boost on the active celliax_console, that is [%s], is: %5.1f\n", + celliax_console_active, + 20 * log10(((double) p->playback_boost / (double) BOOST_SCALE))); + } else if (argc == 2) { + celliax_store_boost(argv[1], &p->playback_boost); + + ast_cli(fd, + "playback_boost on the active celliax_console, that is [%s], is now: %5.1f\n", + celliax_console_active, + 20 * log10(((double) p->playback_boost / (double) BOOST_SCALE))); + } + + return RESULT_SUCCESS; +} + +int celliax_console_capture_boost(int fd, int argc, char *argv[]) +{ + struct celliax_pvt *p = celliax_console_find_desc(celliax_console_active); + + if (argc > 2) + return RESULT_SHOWUSAGE; + if (!p) { + ast_cli(fd, + "No \"current\" celliax_console for capture_boost, please enter 'help celliax_console'\n"); + return RESULT_SUCCESS; + } + + if (argc == 1) { + ast_cli(fd, "capture_boost on the active celliax_console, that is [%s], is: %5.1f\n", + celliax_console_active, + 20 * log10(((double) p->capture_boost / (double) BOOST_SCALE))); + } else if (argc == 2) { + celliax_store_boost(argv[1], &p->capture_boost); + + ast_cli(fd, + "capture_boost on the active celliax_console, that is [%s], is now: %5.1f\n", + celliax_console_active, + 20 * log10(((double) p->capture_boost / (double) BOOST_SCALE))); + } + + return RESULT_SUCCESS; +} + +int celliax_console_echo(int fd, int argc, char *argv[]) +{ + struct celliax_pvt *p = celliax_console_find_desc(celliax_console_active); + + if (argc != 3 && argc != 1) + return RESULT_SHOWUSAGE; + if (!p) { + ast_cli(fd, + "No \"current\" celliax_console for celliax_echo, please enter 'help celliax_console'\n"); + return RESULT_SUCCESS; + } + + if (argc == 1) { + ast_cli(fd, + "On the active celliax_console, that is [%s], speexecho and speexpreprocess are: %d and %d\n", + celliax_console_active, p->speexecho, p->speexpreprocess); + } else if (argc == 3) { + sscanf(argv[1], "%d", &p->speexecho); + sscanf(argv[2], "%d", &p->speexpreprocess); + ast_cli(fd, + "On the active celliax_console, that is [%s], speexecho and speexpreprocess are NOW: %d and %d\n", + celliax_console_active, p->speexecho, p->speexpreprocess); + } + + return RESULT_SUCCESS; +} + +#ifndef ASTERISK_VERSION_1_6_0 +int celliax_console_hangup(int fd, int argc, char *argv[]) +{ + struct celliax_pvt *p = celliax_console_find_desc(celliax_console_active); + + if (argc != 1) + return RESULT_SHOWUSAGE; + if (!p) { + ast_cli(fd, + "No \"current\" celliax_console for hanging up, please enter 'help celliax_console'\n"); + return RESULT_SUCCESS; + } + if (!p->owner) { + ast_cli(fd, "No call to hangup on the active celliax_console, that is [%s]\n", + celliax_console_active); + return RESULT_FAILURE; + } + if (p->owner) + ast_queue_hangup(p->owner); + return RESULT_SUCCESS; +} +#else /* ASTERISK_VERSION_1_6_0 */ +char *celliax_console_hangup(struct ast_cli_entry *e, int cmd, struct ast_cli_args *a) +{ + struct celliax_pvt *p = celliax_console_find_desc(celliax_console_active); + + + switch (cmd) { + case CLI_INIT: + e->command = "celliax hangup"; + e->usage = + "Usage: celliax hangup\n" + " Hangup a call on the celliax channel.\n"; + + return NULL; + case CLI_GENERATE: + return NULL; + } + + if (a->argc != 2) + return CLI_SHOWUSAGE; + if (!p) { + ast_cli(a->fd, + "No \"current\" celliax_console for hanging up, please enter 'help celliax_console'\n"); + return CLI_SUCCESS; + } + if (!p->owner) { + ast_cli(a->fd, "No call to hangup on the active celliax_console, that is [%s]\n", + celliax_console_active); + return CLI_FAILURE; + } + if (p->owner) + ast_queue_hangup(p->owner); + return CLI_SUCCESS; +} + +#endif /* ASTERISK_VERSION_1_6_0 */ +int celliax_console_sendsms(int fd, int argc, char *argv[]) +{ + char *s = NULL; + char *s1 = NULL; + char command[512]; + + if (argc != 3) + return RESULT_SHOWUSAGE; + + s = argv[1]; + s1 = argv[2]; + + memset(command, 0, sizeof(command)); + + sprintf(command, "%s|%s|", s, s1); + + celliax_sendsms(NULL, (void *) &command); + + return RESULT_SUCCESS; +} + +int celliax_console_dial(int fd, int argc, char *argv[]) +{ + char *s = NULL; + struct celliax_pvt *p = celliax_console_find_desc(celliax_console_active); + + if (argc != 2) + return RESULT_SHOWUSAGE; + if (!p) { + ast_cli(fd, + "No \"current\" celliax_console for dialing, please enter 'help celliax_console'\n"); + return RESULT_SUCCESS; + } + + if (p->owner) { /* already in a call */ + int i; + struct ast_frame f = { AST_FRAME_DTMF, 0 }; + + s = argv[1]; + /* send the string one char at a time */ + for (i = 0; i < strlen(s); i++) { + f.subclass = s[i]; + ast_queue_frame(p->owner, &f); + } + return RESULT_SUCCESS; + } else + ast_cli(fd, + "No call in which to dial on the \"current\" celliax_console, that is [%s]\n", + celliax_console_active); + if (s) + free(s); + return RESULT_SUCCESS; +} + +int celliax_console_set_active(int fd, int argc, char *argv[]) +{ + if (argc == 1) + ast_cli(fd, + "\"current\" celliax_console is [%s]\n Enter 'celliax_console show' to see the available interfaces.\n Enter 'celliax_console interfacename' to change the \"current\" celliax_console.\n", + celliax_console_active); + else if (argc != 2) + return RESULT_SHOWUSAGE; + else { + struct celliax_pvt *p; + if (strcmp(argv[1], "show") == 0) { + ast_cli(fd, "Available interfaces:\n"); + for (p = celliax_iflist; p; p = p->next) + ast_cli(fd, " [%s]\n", p->name); + return RESULT_SUCCESS; + } + p = celliax_console_find_desc(argv[1]); + if (p == NULL) + ast_cli(fd, "Interface [%s] do not exists!\n", argv[1]); + else { + celliax_console_active = p->name; + ast_cli(fd, "\"current\" celliax_console is now: [%s]\n", argv[1]); + } + } + return RESULT_SUCCESS; +} + +int celliax_console_celliax(int fd, int argc, char *argv[]) +{ + return RESULT_SHOWUSAGE; +} + +#ifdef ASTERISK_VERSION_1_4 +#ifndef AST_MODULE +#define AST_MODULE "chan_celliax" +#endif +AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Celliax, Audio-Serial Driver"); +#endif /* ASTERISK_VERSION_1_4 */ diff --git a/src/mod/endpoints/mod_gsmopen/asterisk/ciapalo b/src/mod/endpoints/mod_gsmopen/asterisk/ciapalo new file mode 100755 index 0000000000..aa9ea7f4dd --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/asterisk/ciapalo @@ -0,0 +1,8 @@ +#!/usr/bin/perl +open(FILEOUT, ">> /tmp/smses_received"); +while(<>){ + print FILEOUT $_ ; + printf FILEOUT "\n" ; +} +close(FILEOUT); + diff --git a/src/mod/endpoints/mod_gsmopen/configs/asound.conf b/src/mod/endpoints/mod_gsmopen/configs/asound.conf new file mode 100644 index 0000000000..c3a8068e9c --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/configs/asound.conf @@ -0,0 +1,6 @@ +defaults.pcm.rate_converter "linear" +#defaults.pcm.rate_converter "speexrate" +#defaults.pcm.dmix.rate 16000 +#defaults.pcm.dsnoop.rate 16000 + + diff --git a/src/mod/endpoints/mod_gsmopen/configs/gsmopen.conf.xml b/src/mod/endpoints/mod_gsmopen/configs/gsmopen.conf.xml new file mode 100644 index 0000000000..d21a4c1969 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/configs/gsmopen.conf.xml @@ -0,0 +1,23 @@ + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/configs/gsmopen.conf.xml.motorola b/src/mod/endpoints/mod_gsmopen/configs/gsmopen.conf.xml.motorola new file mode 100644 index 0000000000..a38257ef1c --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/configs/gsmopen.conf.xml.motorola @@ -0,0 +1,110 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/filtra48down8.c b/src/mod/endpoints/mod_gsmopen/filtra48down8.c new file mode 100644 index 0000000000..615f80295b --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/filtra48down8.c @@ -0,0 +1,71 @@ +/* Copyright (C) 2007 Jean-Marc Valin + + File: testresample.c + Testing the resampling code + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are + met: + + 1. Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + 3. The name of the author may not be used to endorse or promote products + derived from this software without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR + IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, + INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, + STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN + ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. +*/ + +#include +#include +#include + +#define NN 256 + +int main() +{ + short *in; + short *out; + int i; + int a; + + in = malloc(NN*sizeof(short)); + out = malloc(NN*sizeof(short)/6); + while (1) + { + fread(in, sizeof(short), NN, stdin); + if (feof(stdin)) + break; + + a=0; + for (i=0;i +//#include "speex/speex_resampler.h" +#include +#include + +#define NN 256 + +int main() +{ + short *in; + short *out; + int i; + int a; + + in = malloc(NN*sizeof(short)); + out = malloc(NN*sizeof(short)*6); + while (1) + { + fread(in, sizeof(short), NN, stdin); + if (feof(stdin)) + break; + + a=0; + for (i=0;i + Copyright (C) + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + This library 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 + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public + License along with this library; if not, write to the + Free Software Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307 USA. + +Also add information on how to contact you by electronic and paper mail. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the library, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the + library `Frob' (a library for tweaking knobs) written by James Random Hacker. + + , 1 April 1990 + Ty Coon, President of Vice + +That's all there is to it! diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ChangeLog b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ChangeLog new file mode 100644 index 0000000000..bdd64ab61c --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ChangeLog @@ -0,0 +1,386 @@ +gsmlib-1.10 + - reactivated code in gsm_at to retry sending PDU after + unsolicited result code + + - added description of unicode handling to FAQ + + - compilation fixes for gcc-3.0.4 + + - added quick exit for ATZ in UnixSerialPort constructor + if phone gives ERROR + + - added fix for phones that return +CLIP: "Number not available." + instead of giving caller ID + + - added get/setCLIRPresentation() functions to MeTa (contribution by + ivan) + + - added "NO CARRIER" event to the event mechanism (contribution by + clock) + + - added Win32 port of gsmsmsd (thanks to Konstantin Forostyan) + + - further extented Win32 port of gsmsmsd to handle outgoing messages + + - fixed problem with Ericsson T39m SMS sending (zero bytes in handshake) + + - added capability to send concatenated SMSs in gsmsmsd and gsmsendsms + + - fixed unsigned/signed char problems in Unix/Win32 serial port + implementations + + - added capability to send multiple SMSs to gsmsendsms/gsmsmsd + +gsmlib-1.9 + - fixed decoding of alphanumeric addresses in gsm_sms_codec. + + - fixed bug in gsm_event when checking whether to send an + acknowledgment for a received SMS + + - More Siemens-specific patches, some extensions to the AT + command parser + + - New code to print PIN status and set the PIN in gsmctl, setPIN + function in MeTa class (Andreas Roedl ) + + - Missing virtual destructor in Port class caused destructors of + UnixSerialPort and Win32SerialPort not to be called - fixed + + - Added new code to set functionality level on or off (thanks to + David Woodhouse) + + - found bug in SMS store implementation that caused the now + obsolete _capacity member to be set to a too low value + + - Added changes contributed by Frediano Ziglio to enable compilation + on Windows + + - Added call waiting functions contributed by Ivan + +gsmlib-1.8 + - added workaround for Nokia Cellular Card Phone RPE-1 GSM900 + that reports a CDS event that actually is an CDSI and sends a spurious + CR when waiting for a PDU + + - SMS are stored without index in files now + + - tested compilation with gcc-3.0.2 + + - added workaround for gsmlib getting confused when receiving SMS + and echo cannot be switched off - echos of the AT command are + filtered out in chat() now + + - extended gsm_phonebook preload mechanism to batch-load phonebooks + where the index does not start with 1 + + - Added workaround for Motorola Timeport 260 to write back + deliver messages to the ME + + - added workaround for compilation with libstdc++-v2 + + - private members of MeTa made protected + + - new ext directory for phone-specific extensions + +gsmlib-1.7 + - fixed bug with calculation of userData length if userDataHeader + is present (octet count was subtracted, not septet count) + + - fixed problem with string erase() at end of PDU for Falcom A2-1 + + - -t/--charset option of gsmpb did not work due to missing parameter + of getopt_long, fixed + + - The SMS decoder/encoder can now handle alphanumeric addresses + in the GSM default alphabet + + - set only those SMS stores that are actually needed to perform + SMS store operation + + - Fixed signalling error 321 (Invalid memory index) when trying to + read from empty SMS store entry + + - Fixed parsing error when reading current network operator if no + network connection + + - Added capability to parse cell broadcast messages to gsmlib and + the gsmsmsd program + + - Added workaround for Motorola Timeport 260 bug that doesn't correctly + report the message status when retrieving SMS messages from the + store + + - Added workaround for Motorola Timeport 260 that allocates index + numbers to SMS messages linearly so that index number can be + be larger than capacity reported by AT command + +gsmlib-1.6 + - more fixes for the COPS=? return format + + - fixed putBack() behaviour in gsm_parser (don't put back if end-of- + stream is reached) + + - added toString() function to gsm_sms_codec's Address class + + - SMS dates and times are now output in a locale-specific manner + + - fixed bug in Parser::getEol() (_eos was accidentally set to true) + + - added gsm_win32_serial module, Win32 project (VC++), and + Option FirstFone changes contributed by Frediano Ziglio + + + - fix in COM port recognition for Win32 (gsm_util) + + - renamed library files libgsm.* to libgsmme.* (now starting with + version 1.0) because of conflict with another Debian package + + - in gsm_phonebook and gsm_store the caching of entries can now + be disabled + + - added facilities to use other character sets for phonebooks + + - fixed workaround for Ericcson SH888 (missing service centre address) + + - fixed bug in gsm_phonebook that prevented texts with the + character '@' to be written to to the phonebook + + - fixed nasty memory allocation bug in gsmpb/gsmsmsstore + (automatic MeTa variable went out of scope even though used + later) + + - fixed Y2K problem in timestamp printing + + - fixed "make dist" to include win32 files + + - added workarounds for Falcom A2-1 (autodetection and enabling by + "export GSMLIB_FALCOM_A2_1_FIX=1", zero after PDU) + + - fixed bug that caused gsmlib to abort with an assert if a malformed + PDU was read + +gsmlib-1.5 + - adapted MeTa::getCurrentOPInfo() and MeTa::getAvailableOPInfo() + to handle Nokia 8290 quirks + + - code to set line speed in gsm_unix_serial reinserted (it was + accidentally removed in previous version) + + - minor changes to initialization sequence in gsm_unix_serial + + - bugfix in gsm_unix_serial.cc: readByte() == 0 does not mean no + more bytes, but is legal value + + - additionally allowed characters "*#pwPW" and '+' at any + position in telephone numbers + + - added environment variable GSMLIB_SH888_FIX that (if set) + enables the gsmlib workaround for Ericsson SH888's broken SMS TPDUs + + - fixed command line parameter handling bug in gsmsmsstore + + - fixed %files section .spec file to correctly include manual pages + + - fixed some bugs in terminal line setup (gsm_unix_serial) regarding + software/hardware handshake + + - added new "--sca" option to SMS-related apps to set the SMS + service centre address on the command line (useful if default is not + set correctly in the phone) + + - removed tcflush() call in UnixSerialPort::putLine that broke + the event system needed for gsmsmsd + +gsmlib-1.4 + - more attempts to fix UNIX serial port access + + - allow custom backends for sorted phonebooks to be integrated + into gsmlib (eg. for RDBMS or LDAP storage). Introduced a new + module gsm_sorted_phonebook_base that contains the infrastructure for + this. + + - Now gsmlib needs at least gcc-2.95.2 to compile correctly. + + - Implemented option to open device with software handshaking (XON/XOFF). + The applications now have an -X option to turn this on. + + - gsmlib now contains a facility to interrupt ongoing activity in a + controlled way. gsm_unix_serial now blocks for one second + maximum until it checks whether it was interrupted. + + - various small bugfixes + + - added workaround for phones that omit ':' in AT command responses + + - all debugging output is now printed to stderr + + - gsm_unix_serial: new attempt to initialize modem in a more + robust way (contributed) + + - gsm_sms: fixed handling of user data header (contributed) + +gsmlib-1.3 + - fixed bug that caused gsmlib to hang if TAs don't respond + to AT inquiries for serial number etc. + + - fixed bug with handling of CB mode AT command construction in + gsm_me_ta.cc, setSMSRoutingToTA() + + - allow '+' as the first character of phonenumbers + + - implemented reading and writing from/to stdin/stdout in + gsm_sorted_[sms_store|phonebook] and gsmpb/gsmsmsstore + + - fixed (hopefully) the intermittent hangup problem in + gsm_unix_serial_port + + - Some mobile phones cannot report the status of some facility + locks. The gsmctl program now prints out "unknown" in the + corresponding result line from the FLSTAT + operation if this problem occurs (instead of terminating). + + - switched off non-blocking access to serial device + +gsmlib-1.2 + - gsmlib now also works with TAs that can not switch off echo + + - fixed bug that prevented gsmlib from copying SMS_DELIVER and + SMS_STATUS_REPORT back to the ME + + - introduced -I (--init) parameter to all command line apps to + allow for device-specific initialization + + - made SMS decoding routines more robust against bad SMS (especially + premature end of PDU) + + - New debugging feature: If compiled without NDEBUG, the + environment variable GSMLIB_DEBUG determines the verbosity of + debugging messages (0 = none, 1 = many, 2 = extreme) + +gsmlib-1.1 + + - Parse multiple COPS (operator info) lines returned by some phones + + - accept string as numeric value when interpreting COPS=? response + (Ericsson phone + GSM12 GSM module) + + - accept string as numeric value when interpreting COPS? response + (Ericsson phone + GSM12 GSM module) + + - retry when initializing TA (ATZ/ATE0 sequences) + + - Set SMS routing: + allow mode 3 (special in-band technique) when setting routing + to TA (gsmlib should not be active when phone is switched to data mode + anyway) + + - Set SMS routing: + handle buffer mode but only if it was reported by the +CNMI=? command + (the Ericsson GM12 GSM modem does not like it otherwise) + + - Determine CPMS number of parameters for CPMS command (better + compability with some mobile phones / GSM modems) + + - handle missing service centre address in incoming SMS for Ericsson + model 6050102 + + - add new RING event to gsm_event.h/.cc, gsmsmsd now handles RING + indications properly + + - defined default event handler mostly to handle unexpected RING + indications that might otherwise confuse gsmlib + + - gsmsmsd: can now be cleanly terminated using the SIGINT or SIGTERM + signals + + - gsmsmsd: now handles multiple incoming SMS messages cleanly, before + there was a chance that some SMS messages coming in rapid succession + might have been lost + + - gsmsmsd: flush option implemented that dispatches and erases + existing messages in SMS store + + - gsmsmsd: added sending of SMS messages. gsmsmsd now accepts a + spool directory options where it expects to find SMS message file in a + simple format, these are dispatched every 5 seconds + +gsmlib-1.0 + + - RPM support (spec file) + + - the "+" is at least for the Siemens S10 and S25 a valid char in + telephone numbers (inserts a pause of 3 seconds), therefore it is now + allowed as part of telephone numbers + + - fixed incorrect analysis of facility class parameters in gsmctl.cc + + - restricted call forward time to 0..30 seconds in gsm_me_ta.cc + +gsmlib-0.3 + + - implemented timeout for accessing the mobile phone in order + to avoid hangs + + - upgraded to BETA status + + - written glossary for abbreviations (gsminfo(7)) + + - implemented NLS support, added German translations + + - implemented preserving the index position of phonebook entries in + gsmpb.cc and gsm_sorted_phonebook + + - cleaned up manual pages (alphabetic ordering of options etc.) + + - gsmsmstore program and gsm_sorted_sms_store./.cc completed and + tested + + - gsmpb and gsmsmsstore now have --verbose (-V) options for detailed + progress reporting + + - now check for getopt_long in configure (can be compiled on non-GNU + systems) + + - removed asserts regarding lengths of numeric data types, put them + into configure script + + - sorted options in apps/*.cc alphabetically (--help option) + + - in gsm_sorted_sms_store compare telephone numbers more sensibly + + - introduced -v option to gsmpb and gsmsmsstore to report execution + statistics + + - tested new synchronization function in gsmpb program + + - implemented operations in the gsmctl program + + - rewrote test cases (compare output) + + - completed gsmsmsstore program + + - first changes for compilation with VC++ 6.0 on WIN32 + +gsmlib-0.2 + + - gsmsmstore program and gsm_sorted_sms_store./.cc mostly + completed but not yet much tested + + - Fixed problem with some mobiles/TAs not giving prefixes after + certain AT sequences (reported for SIEMENS S25/IrDA, Nokia + 8810/IrDA) + + - Fixed problem with Xircom REM56G.100/Nokia 6150 that give + "CABLE: GSM" instead of "OK" after ATZ + + - Mobiles that return nothing when empty phonebook entries are + requested are now handled correctly (reported for SIEMENS S25/IrDA) + + - optimizations in gsm_*_phonebook modules (less AT commands necessary) + + - new synchronization function in gsmpb program that is (hopefully) + more sensible (see man page for details) + +gsmlib-0.1 + + - Initial release diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/INSTALL b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/INSTALL new file mode 100644 index 0000000000..6242d6f388 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/INSTALL @@ -0,0 +1,198 @@ +GSMLIB Installation +=================== + + This distribution uses autoconf/automake/libtool. See below + for generic installation instructions. The default commands would be: + + ./configure + make + make install + + See also the section INSTALLATION in the README file in this + directory. For questions regarding the internationalization of this + package refer to doc/README.NLS and ./ABOUT-NLS. + + Developers: See also the file doc/README.developers. + +Basic Installation +================== + + These are generic installation instructions. + + 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, a file +`config.cache' that saves the results of its tests to speed up +reconfiguring, and a file `config.log' containing compiler output +(useful mainly for debugging `configure'). + + 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 at some point `config.cache' +contains results you don't want to keep, you may remove or edit it. + + The file `configure.in' is used to create `configure' by a program +called `autoconf'. You only need `configure.in' 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. If you're + using `csh' on an old version of System V, you might need to type + `sh ./configure' instead to prevent `csh' from trying to execute + `configure' itself. + + Running `configure' takes awhile. 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. You can give `configure' +initial values for variables by setting them in the environment. Using +a Bourne-compatible shell, you can do that on the command line like +this: + CC=c89 CFLAGS=-O2 LIBS=-lposix ./configure + +Or on systems that have the `env' program, you can do it like this: + env CPPFLAGS=-I/usr/local/include LDFLAGS=-s ./configure + +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 must use a version of `make' that +supports the `VPATH' variable, such as 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 `..'. + + If you have to use a `make' that does not supports the `VPATH' +variable, you have 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' will install the package's files in +`/usr/local/bin', `/usr/local/man', etc. You can specify an +installation prefix other than `/usr/local' by giving `configure' the +option `--prefix=PATH'. + + You can specify separate installation prefixes for +architecture-specific files and architecture-independent files. If you +give `configure' the option `--exec-prefix=PATH', the package will use +PATH as the prefix for installing programs and libraries. +Documentation and other data files will still use the regular prefix. + + In addition, if you use an unusual directory layout you can give +options like `--bindir=PATH' 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' can not figure out +automatically, but needs to determine by the type of host the package +will run on. Usually `configure' can figure that out, but if it prints +a message saying it can not guess the host type, give it the +`--host=TYPE' option. TYPE can either be a short name for the system +type, such as `sun4', or a canonical name with three fields: + CPU-COMPANY-SYSTEM + +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 host type. + + If you are building compiler tools for cross-compiling, you can also +use the `--target=TYPE' option to select the type of system they will +produce code for and the `--build=TYPE' option to select the type of +system on which you are compiling the package. + +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. + +Operation Controls +================== + + `configure' recognizes the following options to control how it +operates. + +`--cache-file=FILE' + Use and save the results of the tests in FILE instead of + `./config.cache'. Set FILE to `/dev/null' to disable caching, for + debugging `configure'. + +`--help' + Print a summary of the options to `configure', and exit. + +`--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. + +`--version' + Print the version of Autoconf used to generate the `configure' + script, and exit. + +`configure' also accepts some other, not widely useful, options. diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/Makefile.am b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/Makefile.am new file mode 100644 index 0000000000..daf1ea0047 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/Makefile.am @@ -0,0 +1,24 @@ +## Process this file with automake to produce Makefile.in +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: Toplevel Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 21.5.1999 +# ************************************************************************* + +SUBDIRS_ = po gsmlib apps tests doc scripts win32 ext + +EXTRA_DIST = gsmlib.spec + +if COMPILE_INTL +SUBDIRS = intl $(SUBDIRS_) # po - make automake happy +else +SUBDIRS = $(SUBDIRS_) # po intl - make automake happy +endif + +all: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/Makefile.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/Makefile.in new file mode 100644 index 0000000000..e9676cc981 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/Makefile.in @@ -0,0 +1,423 @@ +# Makefile.in generated automatically by automake 1.4-p6 from Makefile.am + +# Copyright (C) 1994, 1995-8, 1999, 2001 Free Software Foundation, Inc. +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: Toplevel Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 21.5.1999 +# ************************************************************************* + + +SHELL = @SHELL@ + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ + +bindir = @bindir@ +sbindir = @sbindir@ +libexecdir = @libexecdir@ +datadir = @datadir@ +sysconfdir = @sysconfdir@ +sharedstatedir = @sharedstatedir@ +localstatedir = @localstatedir@ +libdir = @libdir@ +infodir = @infodir@ +mandir = @mandir@ +includedir = @includedir@ +oldincludedir = /usr/include + +DESTDIR = + +pkgdatadir = $(datadir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ + +top_builddir = . + +ACLOCAL = @ACLOCAL@ +AUTOCONF = @AUTOCONF@ +AUTOMAKE = @AUTOMAKE@ +AUTOHEADER = @AUTOHEADER@ + +INSTALL = @INSTALL@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ $(AM_INSTALL_PROGRAM_FLAGS) +INSTALL_DATA = @INSTALL_DATA@ +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +transform = @program_transform_name@ + +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +host_alias = @host_alias@ +host_triplet = @host@ +AR = @AR@ +AS = @AS@ +BUILD_INCLUDED_LIBINTL = @BUILD_INCLUDED_LIBINTL@ +CATOBJEXT = @CATOBJEXT@ +CC = @CC@ +CPP = @CPP@ +CXX = @CXX@ +CXXCPP = @CXXCPP@ +DATADIRNAME = @DATADIRNAME@ +DLLTOOL = @DLLTOOL@ +ECHO = @ECHO@ +EGREP = @EGREP@ +EXEEXT = @EXEEXT@ +F77 = @F77@ +GCJ = @GCJ@ +GCJFLAGS = @GCJFLAGS@ +GENCAT = @GENCAT@ +GLIBC2 = @GLIBC2@ +GLIBC21 = @GLIBC21@ +GMSGFMT = @GMSGFMT@ +GSM_VERSION = @GSM_VERSION@ +HAVE_ASPRINTF = @HAVE_ASPRINTF@ +HAVE_LIB = @HAVE_LIB@ +HAVE_POSIX_PRINTF = @HAVE_POSIX_PRINTF@ +HAVE_SNPRINTF = @HAVE_SNPRINTF@ +HAVE_WPRINTF = @HAVE_WPRINTF@ +INSTOBJEXT = @INSTOBJEXT@ +INTLBISON = @INTLBISON@ +INTLLIBS = @INTLLIBS@ +INTLOBJS = @INTLOBJS@ +INTL_LIBTOOL_SUFFIX_PREFIX = @INTL_LIBTOOL_SUFFIX_PREFIX@ +INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ +LIB = @LIB@ +LIBICONV = @LIBICONV@ +LIBINTL = @LIBINTL@ +LIBTOOL = @LIBTOOL@ +LN_S = @LN_S@ +LTLIB = @LTLIB@ +LTLIBICONV = @LTLIBICONV@ +LTLIBINTL = @LTLIBINTL@ +MAKEINFO = @MAKEINFO@ +MKINSTALLDIRS = @MKINSTALLDIRS@ +OBJDUMP = @OBJDUMP@ +OBJEXT = @OBJEXT@ +PACKAGE = @PACKAGE@ +POSUB = @POSUB@ +RANLIB = @RANLIB@ +RC = @RC@ +STRIP = @STRIP@ +USE_INCLUDED_LIBINTL = @USE_INCLUDED_LIBINTL@ +USE_NLS = @USE_NLS@ +VERSION = @VERSION@ + +SUBDIRS_ = po gsmlib apps tests doc scripts win32 ext + +EXTRA_DIST = gsmlib.spec +@COMPILE_INTL_TRUE@SUBDIRS = intl $(SUBDIRS_) # po - make automake happy +@COMPILE_INTL_FALSE@SUBDIRS = $(SUBDIRS_) # po intl - make automake happy +ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 +mkinstalldirs = $(SHELL) $(top_srcdir)/scripts/mkinstalldirs +CONFIG_HEADER = gsm_config.h +CONFIG_CLEAN_FILES = +DIST_COMMON = README ./stamp-h.in ABOUT-NLS AUTHORS COPYING ChangeLog \ +INSTALL Makefile.am Makefile.in NEWS TODO acconfig.h acinclude.m4 \ +aclocal.m4 configure configure.in gsm_config.h.in + + +DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST) + +TAR = tar +GZIP_ENV = --best +DIST_SUBDIRS = intl po gsmlib apps tests doc scripts win32 ext po \ +gsmlib apps tests doc scripts win32 ext +all: all-redirect +.SUFFIXES: +$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4) + cd $(top_srcdir) && $(AUTOMAKE) --gnu Makefile + +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status $(BUILT_SOURCES) + cd $(top_builddir) \ + && CONFIG_FILES=$@ CONFIG_HEADERS= $(SHELL) ./config.status + +$(ACLOCAL_M4): configure.in acinclude.m4 + cd $(srcdir) && $(ACLOCAL) + +config.status: $(srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) + $(SHELL) ./config.status --recheck +$(srcdir)/configure: $(srcdir)/configure.in $(ACLOCAL_M4) $(CONFIGURE_DEPENDENCIES) + cd $(srcdir) && $(AUTOCONF) + +gsm_config.h: stamp-h + @if test ! -f $@; then \ + rm -f stamp-h; \ + $(MAKE) stamp-h; \ + else :; fi +stamp-h: $(srcdir)/gsm_config.h.in $(top_builddir)/config.status + cd $(top_builddir) \ + && CONFIG_FILES= CONFIG_HEADERS=gsm_config.h \ + $(SHELL) ./config.status + @echo timestamp > stamp-h 2> /dev/null +$(srcdir)/gsm_config.h.in: $(srcdir)/stamp-h.in + @if test ! -f $@; then \ + rm -f $(srcdir)/stamp-h.in; \ + $(MAKE) $(srcdir)/stamp-h.in; \ + else :; fi +$(srcdir)/stamp-h.in: $(top_srcdir)/configure.in $(ACLOCAL_M4) acconfig.h + cd $(top_srcdir) && $(AUTOHEADER) + @echo timestamp > $(srcdir)/stamp-h.in 2> /dev/null + +mostlyclean-hdr: + +clean-hdr: + +distclean-hdr: + -rm -f gsm_config.h + +maintainer-clean-hdr: + +# This directory's subdirectories are mostly independent; you can cd +# into them and run `make' without going through this Makefile. +# To change the values of `make' variables: instead of editing Makefiles, +# (1) if the variable is set in `config.status', edit `config.status' +# (which will cause the Makefiles to be regenerated when you run `make'); +# (2) otherwise, pass the desired values on the `make' command line. + +@SET_MAKE@ + +all-recursive install-data-recursive install-exec-recursive \ +installdirs-recursive install-recursive uninstall-recursive \ +check-recursive installcheck-recursive info-recursive dvi-recursive: + @set fnord $(MAKEFLAGS); amf=$$2; \ + dot_seen=no; \ + target=`echo $@ | sed s/-recursive//`; \ + list='$(SUBDIRS)'; for subdir in $$list; do \ + echo "Making $$target in $$subdir"; \ + if test "$$subdir" = "."; then \ + dot_seen=yes; \ + local_target="$$target-am"; \ + else \ + local_target="$$target"; \ + fi; \ + (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ + || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ + done; \ + if test "$$dot_seen" = "no"; then \ + $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ + fi; test -z "$$fail" + +mostlyclean-recursive clean-recursive distclean-recursive \ +maintainer-clean-recursive: + @set fnord $(MAKEFLAGS); amf=$$2; \ + dot_seen=no; \ + rev=''; list='$(SUBDIRS)'; for subdir in $$list; do \ + rev="$$subdir $$rev"; \ + test "$$subdir" != "." || dot_seen=yes; \ + done; \ + test "$$dot_seen" = "no" && rev=". $$rev"; \ + target=`echo $@ | sed s/-recursive//`; \ + for subdir in $$rev; do \ + echo "Making $$target in $$subdir"; \ + if test "$$subdir" = "."; then \ + local_target="$$target-am"; \ + else \ + local_target="$$target"; \ + fi; \ + (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ + || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ + done && test -z "$$fail" +tags-recursive: + list='$(SUBDIRS)'; for subdir in $$list; do \ + test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \ + done + +tags: TAGS + +ID: $(HEADERS) $(SOURCES) $(LISP) + list='$(SOURCES) $(HEADERS)'; \ + unique=`for i in $$list; do echo $$i; done | \ + awk ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + here=`pwd` && cd $(srcdir) \ + && mkid -f$$here/ID $$unique $(LISP) + +TAGS: tags-recursive $(HEADERS) $(SOURCES) gsm_config.h.in $(TAGS_DEPENDENCIES) $(LISP) + tags=; \ + here=`pwd`; \ + list='$(SUBDIRS)'; for subdir in $$list; do \ + if test "$$subdir" = .; then :; else \ + test -f $$subdir/TAGS && tags="$$tags -i $$here/$$subdir/TAGS"; \ + fi; \ + done; \ + list='$(SOURCES) $(HEADERS)'; \ + unique=`for i in $$list; do echo $$i; done | \ + awk ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + test -z "$(ETAGS_ARGS)gsm_config.h.in$$unique$(LISP)$$tags" \ + || (cd $(srcdir) && etags -o $$here/TAGS $(ETAGS_ARGS) $$tags gsm_config.h.in $$unique $(LISP)) + +mostlyclean-tags: + +clean-tags: + +distclean-tags: + -rm -f TAGS ID + +maintainer-clean-tags: + +distdir = $(PACKAGE)-$(VERSION) +top_distdir = $(distdir) + +# This target untars the dist file and tries a VPATH configuration. Then +# it guarantees that the distribution is self-contained by making another +# tarfile. +distcheck: dist + -rm -rf $(distdir) + GZIP=$(GZIP_ENV) $(TAR) zxf $(distdir).tar.gz + mkdir $(distdir)/=build + mkdir $(distdir)/=inst + dc_install_base=`cd $(distdir)/=inst && pwd`; \ + cd $(distdir)/=build \ + && ../configure --with-included-gettext --srcdir=.. --prefix=$$dc_install_base \ + && $(MAKE) $(AM_MAKEFLAGS) \ + && $(MAKE) $(AM_MAKEFLAGS) dvi \ + && $(MAKE) $(AM_MAKEFLAGS) check \ + && $(MAKE) $(AM_MAKEFLAGS) install \ + && $(MAKE) $(AM_MAKEFLAGS) installcheck \ + && $(MAKE) $(AM_MAKEFLAGS) dist + -rm -rf $(distdir) + @banner="$(distdir).tar.gz is ready for distribution"; \ + dashes=`echo "$$banner" | sed s/./=/g`; \ + echo "$$dashes"; \ + echo "$$banner"; \ + echo "$$dashes" +dist: distdir + -chmod -R a+r $(distdir) + GZIP=$(GZIP_ENV) $(TAR) chozf $(distdir).tar.gz $(distdir) + -rm -rf $(distdir) +dist-all: distdir + -chmod -R a+r $(distdir) + GZIP=$(GZIP_ENV) $(TAR) chozf $(distdir).tar.gz $(distdir) + -rm -rf $(distdir) +distdir: $(DISTFILES) + -rm -rf $(distdir) + mkdir $(distdir) + -chmod 777 $(distdir) + here=`cd $(top_builddir) && pwd`; \ + top_distdir=`cd $(distdir) && pwd`; \ + distdir=`cd $(distdir) && pwd`; \ + cd $(top_srcdir) \ + && $(AUTOMAKE) --include-deps --build-dir=$$here --srcdir-name=$(top_srcdir) --output-dir=$$top_distdir --gnu Makefile + @for file in $(DISTFILES); do \ + d=$(srcdir); \ + if test -d $$d/$$file; then \ + cp -pr $$d/$$file $(distdir)/$$file; \ + else \ + test -f $(distdir)/$$file \ + || ln $$d/$$file $(distdir)/$$file 2> /dev/null \ + || cp -p $$d/$$file $(distdir)/$$file || :; \ + fi; \ + done + for subdir in $(DIST_SUBDIRS); do \ + if test "$$subdir" = .; then :; else \ + test -d $(distdir)/$$subdir \ + || mkdir $(distdir)/$$subdir \ + || exit 1; \ + chmod 777 $(distdir)/$$subdir; \ + (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir=../$(distdir) distdir=../$(distdir)/$$subdir distdir) \ + || exit 1; \ + fi; \ + done +info-am: +info: info-recursive +dvi-am: +dvi: dvi-recursive +check-am: all-am +check: check-recursive +installcheck-am: +installcheck: installcheck-recursive +all-recursive-am: gsm_config.h + $(MAKE) $(AM_MAKEFLAGS) all-recursive + +install-exec-am: +install-exec: install-exec-recursive + +install-data-am: +install-data: install-data-recursive + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am +install: install-recursive +uninstall-am: +uninstall: uninstall-recursive +all-am: Makefile gsm_config.h +all-redirect: all-recursive-am +install-strip: + $(MAKE) $(AM_MAKEFLAGS) AM_INSTALL_PROGRAM_FLAGS=-s install +installdirs: installdirs-recursive +installdirs-am: + + +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -rm -f Makefile $(CONFIG_CLEAN_FILES) + -rm -f config.cache config.log stamp-h stamp-h[0-9]* + +maintainer-clean-generic: +mostlyclean-am: mostlyclean-hdr mostlyclean-tags mostlyclean-generic + +mostlyclean: mostlyclean-recursive + +clean-am: clean-hdr clean-tags clean-generic mostlyclean-am + +clean: clean-recursive + +distclean-am: distclean-hdr distclean-tags distclean-generic clean-am + -rm -f libtool + +distclean: distclean-recursive + -rm -f config.status + +maintainer-clean-am: maintainer-clean-hdr maintainer-clean-tags \ + maintainer-clean-generic distclean-am + @echo "This command is intended for maintainers to use;" + @echo "it deletes files that may require special tools to rebuild." + +maintainer-clean: maintainer-clean-recursive + -rm -f config.status + +.PHONY: mostlyclean-hdr distclean-hdr clean-hdr maintainer-clean-hdr \ +install-data-recursive uninstall-data-recursive install-exec-recursive \ +uninstall-exec-recursive installdirs-recursive uninstalldirs-recursive \ +all-recursive check-recursive installcheck-recursive info-recursive \ +dvi-recursive mostlyclean-recursive distclean-recursive clean-recursive \ +maintainer-clean-recursive tags tags-recursive mostlyclean-tags \ +distclean-tags clean-tags maintainer-clean-tags distdir info-am info \ +dvi-am dvi check check-am installcheck-am installcheck all-recursive-am \ +install-exec-am install-exec install-data-am install-data install-am \ +install uninstall-am uninstall all-redirect all-am all installdirs-am \ +installdirs mostlyclean-generic distclean-generic clean-generic \ +maintainer-clean-generic clean mostlyclean distclean maintainer-clean + + +all: + +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/NEWS b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/NEWS new file mode 100644 index 0000000000..1efffa7d86 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/NEWS @@ -0,0 +1,11 @@ +NEWS - 9.1.2000 + + Version 1.0 - first release with RPM support and binary packages + +NEWS - 15.11.1999 + + BETA version (details see ChangeLog) + +NEWS - 16.7.1999 + + initial release diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/README b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/README new file mode 100644 index 0000000000..2f5db9eb27 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/README @@ -0,0 +1,166 @@ +INTRODUCTION + + This distribution contains a library to access GSM mobile phones + through GSM modems or IrDA devices. Features include: + + * modification of phonebooks stored in the mobile phone or on the + SIM card + + * reading and writing of SMS messages stored in the mobile phone + + * sending and reception of SMS messages + + Additionally, some simple command line programs are provided to + use these functionalities. + + +REQUIREMENTS + + You need a mobile phone that conforms to the GSM + standards ETSI GSM 07.07, ETSI GSM 07.05, and others. + Non-GSM mobile phones will not work! Additionally, + to access the mobile phone from the computer you will probably need an + GSM modem (that would be a PC-CARD, usually). There might be some + mobile phones, however, that incorporate directly terminal + adapter (TA) functionality. Access via IrDA interfaces is also + reported to work. + + If you want to compile the library yourself please also read + doc/README.developers. + + +INSTALLATION + + This distribution uses autoconf/automake/libtool. See the file + INSTALL for generic installation instructions. The default + commands for installation under /usr/local would be: + + ./configure + make + make install + + If there are any problems you can generate a debug version. See + doc/README.developers for details. + + +AVAILABLE DOCUMENTATION + + For the command line tools UNIX manual pages are available in the + doc subdirectory of this distribution. These are installed by + default in the directories /usr/local/man1, man7, and man8. + + See also the files doc/README.developers, doc/README.NLS and doc/FAQ. + + +HARDWARE + + The following mobile phone/GSM modem combinations are reported to + be compatible in varying degrees with the current release: + + - Nokia 6150/Xircom REM56G.100 + - Nokia 6150/Options "GSM-Ready(R) Cellular-Only" modem + from Option International + - Nokia 6210/- (Linux IrDA serial device) + - Nokia 8810/- (Linux IrDA serial device) + - Siemens S10D/Dr Neuhaus Gipsy Card GSM + - Siemens S25/- (Linux IrDA serial device) + - Siemens S35i/- (Linux IrDA serial device) + - Siemens S45 + - Ericcson SH888/- (Linux IrDA serial device) + - Ericsson 6050102/GM 12 GSM module + - Ericsson T28s (firmware 000809 1106) + - Ericsson T20e (firmware R3A007) + - -/Siemens M20T (stand-alone GSM module) + - -/Wavecom WM02 GSM (stand-alone GSM module) + - Nokia 7110 (firware rev 4.80)/- (Linux IrDA serial device) + - Nokia 8290 (USA GSM 1900MHz)/- (Linux IrDA serial device) + - Falcom A2-1/- (stand-alone GSM module) + - Ericsson R320s/- (Linux IrDA serial device) + - Motorola Timeport 260/- (Serial cable and Linux IrDA serial device) + - Motorola Timeport 250/- (Linux IrDA serial device) + - Motorola Timeport P7389/- (Linux IrDA serial device) + - Nokia Cellular Card Phone RPE-1 GSM900 and + - Nokia Card Phone RPM-1 GSM900/1800 + - Nokia Cardphone/Compaq iPAQ + - Omnipoint technologies Redhawk 2000 GSM modem + - Ericsson T28 (but one firmware revision is reported to have problems) + - Ericcson T65 + - Ericcson T39m/Bluetooth + - Option International GlobeTrotter PCMCIA + + Note 1: Some of the mobile phones have an integrated GSM modem + that can be accessed via the Linux IrDA drivers. + + Note 2: Some of the abovementioned phones have still some glitches + with gsmlib (and I haven't tested them myself). + + For the following phones I receive a lot of errors reports: + + - Ericcson SH888: SMS function don't work with many firmware releases + + This list is not exhaustive, there are probably many other types of + phone or GSM modem that work with gsmlib. Just try it and report back + to me! + + +DISCLAIMER + + Even though care has been taken in the design and implementation + of this software it can not be excluded that this software could + destroy data in your mobile phone or may even render your mobile + phone useless (by erroneous PIN settings, for example). The + author will not be held responsible legally, financially, or in any + other form for any kind of damage that might occur from using + this software. + + This software is provided "as is" and without any expressed or implied + warranties, including, without limitation, the implied warranties of + merchantibility and fitness for any particular purpose. + + If you are not ready to accept these conditions please don't use + this software. + + +COPYING + + This software is available on the LGPL (GNU LIBRARY GENERAL + PUBLIC LICENSE), ie. it is allowed to link + the library to commercial programs. + + See the file COPYING for details on the license. + + +BUGS + + There still seem to be some problems with IrDA devices under + Linux. There have been reports of gsmlib-based applications + (eg. gsmctl) hanging upon startup after initializing the serial port + /dev/ircomm. I would be thankful for any input on this problem. + + If something does not work with your OS platform or the mobile/TA + combination please send a complete trace of the compilation or the + program execution that did fail. Make sure to compile with debugging + information enabled. Otherwise it will not be possible for me to do + much about the problem. Send bug reports to the mailing list or + to software@pxh.de. I promise not to publish telephone numbers or other + private information that might be contained in the execution traces + that you send me. + + +MAILING LISTS + + There are now two mailings lists available for announcements and + discussion of gsmlib-related issues (hosted on lists.over.net). + Refer to these pages for information on subscription procedures + and an archive of previous postings: + + http://lists.over.net/mailman/listinfo/gsmlib-announce/ + for announcements regarding GSMLIB + + http://lists.over.net/mailman/listinfo/gsmlib-devel/ + the GSMLIB development list + + +AUTHOR + + Peter Hofmann . diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/TODO b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/TODO new file mode 100644 index 0000000000..3ea3aa3fd5 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/TODO @@ -0,0 +1,289 @@ +This is my list of TODOs for development of this software (not +necessarily in order of importance): + +("+" = DONE) + ++ handle: + > --> AT+COPS=? + > <-- + > <-- +COPS: (1,"AMENA",,"21403"),(3,"MOVISTAR",,"21407"), + > <-- (3,"E VODAFONE",,"21401"),,(0,1),(2) + > <-- + > <-- OK + > gsmctl[ERROR]: expected comma (at position 45 of string '(1,"AMENA",,"21403"),(3,"MOVISTAR",,"21407"),') + ++ extend README and web site with names of working phones (Siemens S45,...) + ++ add workaround: + > Manufacturer: Nokia Mobile Phones + > Model: 8290 + > Revision: SW5.22 + > Serial Number: 010070303406434 + > Functionality Level: 1 + > gsmctl[ERROR]: expected number, got '(2)' + +- add fork to gsmsmsd + ++ document "on" and "off" operations of gsmctl + +- Just assume full functionality and issue AT+CGMF=0 if we haven't already + done so for this MeTa. + ++ make update po + ++ add find function + ++ specify exact location of manual files in /usr/man/man* in spec + file, so that erase does not try to delete these directories + ++ update PO + ++ add option to gsmsendsms/gsmsmsd to request delivery reports + ++ Fix CBM reception in gsmsmsd, see testcb.cc program + ++ fix gsmsmsd: + --> AT+CNMI=? + <-- + <-- +CNMI: (1),(1),(0),(0),(0) + <-- + <-- OK + --> AT+CNMI=1,0,0,0,0 + <-- + <-- +CME ERROR: 003 + ./gsmsmsd[ERROR]: ME/TA error 'operation not allowed' (code 003) + ++ Wenn ich den SMS-Speicher auslesen möchte, bricht gsmlib ab, weil der + Speicherplatz 1 auf der SIM-Karte nicht belegt ist. Das kann z.B. + passieren, wenn man Nachrichten im Handy löscht. Es kommt der Fehlercode + 321 (Invalid memory index). Wie wäre es, in der Leseroutine alle + ungültigen Plätze zu ignorieren und solange zu lesen, bis die Anzahl der + vorhandenen Nachrichten im Speicher eingelesen ist? + ++ document --charset option of gsmpb + ++ Problems with PDUs with alphanumeric SCA, e.g.: + 07911497941902F00414D0E474989D769F5DE4320839001040122151820000 + ++ > 2. Ich kann mit meinem Nokia 6210 nicht den Telefon-SMS-Speicher + auslesen. Dies liegt an der Speicherwahl, die vor dem Auslesen + an das Telefon übermittelt wird. Von der gsmlib wird anscheinend + immer die Anzahl der Speicher aus dem "CPMS=?"-Befehl genommen + (z.B. "SM","SM","SM"). Notwendig ist es aber nur, die erste + Position (zum Lesen und Löschen) bzw. die ersten beiden + Positionen (zum Schreiben) zu benutzen. + Das Nokia 6210 unterstützt aber an der ritten Stelle nur "SM", + nicht "ME". So kann ich die SMS im Telefon leider nicht + auslesen :-( + +- add option to gsmpb/gsmssmstore deletion to delete ALL entries + +- recheck Solaris port + ++ cache character set settings in MeTa + ++ add documentation for new gsmctl and gsmpb charset parameters + ++ support characters sets other than GSM default alphabet for phone books + ++ create non-existent files (gsmpb and gsmsmsstore) + ++ rename libgsm to libgsmme, new major version 1 + ++ document sca/setsca operations/parameters in gsmctl + ++ document option to set SCA in SMS-related apps + ++ implement option to set SCA in SMS-related apps + ++ convert NDEBUG test output from cout to cerr + ++ test new gsm_unix_serial behaviour + ++ apply checks for telephone number in gsm_sorted_phonebook + ++ add interrupted() checks + ++ check for gcc-2.95.2 in configure + +- document custom backend options of gsmpb (and gsmsmsstore) + +- /var/lock/LCK..modem + ++ make gsmctl all continue even if there are some failures + ++ CPIN thing + ++ bring German translations up-to-date + ++ document -I parameter + ++ make chat routines robust against TAs that insist on echoing AT commands + ++ ericsson sh 888: + <-- AT+CLCK="P2",2,,1 + <-- + +CME ERROR: 4 + gsmctl[ERROR]: ME/TA error 'operation not supported' (code 4) + ++ put README etc. into gsmlib package (not only devel) + ++ make SMS decoding routines more robust against bad SMS (especially + premature end of PDU) + ++ stop gsm_sorted_sms_store.cc from copying back SMS that came from + the SC (SMS_DELIVER, SMS_STATUS_REPORT, SMS_SUBMIT_REPORT). Their + message type is ambiguous and the ME may misinterpret them. + ++ gsmsmsd: reinitialize modem every hour or so (signal termination implemented) + ++ implement store, flush and spool options of gsmsmsd, + document them in man pages + ++ test case for COPS answer numeric operator name in quotation marks + (testparser.cc) + ++ retry when initializing TA (ATZ/ATE0 sequences) + ++ correctly parse malformed SMS PDUs without SCA with Ericsson phone, + introduce Capability object for that. Ericsson ID: + Manufacturer: ERICSSON + Model: 6050102 + Revision: 990225 1852 CXC112143 + Serial Number: 520001690279310 + ++ Determine CPMS number of parameters for CPMS command (Ericsson + phone/GM12 GSM modem): + AT+CPMS? + +CPMS: "ME",0,10,"ME",0,10 + AT+CPMS=? + +CPMS: ("ME","SM"),("ME","SM") + ++ accept string as numeric value when interpreting COPS=? response + (Ericsson phone + GSM12 GSM module) + ++ accept string as numeric value when interpreting COPS? response + (Ericsson phone + GSM12 GSM module) + ++ It would be nice if it was possible to send sms:es + via gsmsmsd as well, via a spool directory or a socket (or stdin, in which + case one can put another program in front of this program and then + feed it with outgoing messages any way one wants). That way the program + could be the gateway between programs and the sms network. Now one has + to stop gsmsmsd to send an sms and that's not so elegant or write + ones own program. + ++ gsmsmsd geht davon aus, das ein platz frei ist und benutzt nur diesen.... + Wenn also eine SMS kommt, dann zieht es Sie raus, und löscht den + Speicherplatz. + Wenn aber die Karte voll ist, passiert gar nichts. Für eine automatisierte + umgebung ist das schlecht. besser wäre es, bei startup von gsmsmsd alle + Speicherplätze abzufrühstücken, und die Action aufzurufen. + ++ Ein RING bringt den gsmsmsd ziemlich heftig aus dem Tritt. Hab jetzt ´ne + Rufumleitung eingebaut. + ++ Links section in homepage + ++ AT+CNMI=? liefert bei mir folgendes zurück: + +CNMI: (0-3),(0-3),(0-2),0,(0-1) + Parameter 4 () liefert also keine Liste sondern nur ein Int zurück, du + versuchts aber ein ( zu parsen. + Was sagt die ETSI-spec. dazu ?? Ist das konform ?? + ++ give name of command at beginning of synopsis in man pages + ++ list combinations of mobiles phones/GSM modems in the README + ++ test ALARM in case of timeout when writing or reading to TA + ++ install headers in gsmlib subdirectory + ++ RPM spec file + ++ test index changes for sorted phonebook -> write second test case + ++ sort phone numbers the same way in gsm_sorted_sms_store and + gsm_sorted_phonebook + ++ write glossary for all these nice abbreviations (TA, ME, SC, SME, TE) + ++ HAVE_VSNPRINTF instead of HAVE_VPRINTF + ++ internationalization of messages with GNU gettext. Files: + +gsm_at.cc +gsm_parser.cc +gsm_sorted_phonebook.cc + +gsm_error.cc +gsm_phonebook.cc +gsm_sorted_sms_store.cc + +gsm_event.cc +gsm_sms.cc +gsm_unix_serial.cc + +gsm_me_ta.cc +gsm_sms_codec.cc +gsm_util.cc + +gsm_nls.cc +gsm_sms_store.cc + +gsmctl.cc +gsmpb.cc +gsmsendsms.cc + +gsmsmsd.cc +gsmsmsstore.cc + ++ implement indexed phonebook ops in gsmpb.cc + ++ describe phonebook file format in gsmpb.man + ++ update list of compatible hardware in README + ++ all #include must be enclosed in #ifdef's + ++ check for getopt_long in configure + ++ remove asserts regarding lengths of numeric data types, put them +into configure script +(string) + ++ sort options in apps/*.cc alphabetically + ++ in gsm_sorted_sms_store compare telephone numbers numerically + ++ introduce -v option to gsmpb and gsmsmsstore to report execution +statistics (gives a nicer feeling to users) + ++ test new synchronization function in gsmpb program + ++ implement equality operator for SMSSToreEntry + ++ test 'make install' + ++ implement operations in the gsmctl program + ++ test operations in the gsmctl program + ++ document operations in the gsmctl program + ++ rewrite test cases (compare output) + ++ write gsm_sorted_sms_store module (along the lines of gsm_sorted_phonebook) + ++ complete gsmsmsstore program (using abovementioned modules) + +TODO low priority: + +- implement SMS text mode + +- The action command of gsmsmsd would be easier to make, if the program + sent the values in environment variables instead (except the user data + which could be sent on stdin). + ++ Upgrade to latest autoheader, autoconf, libtool + +- provide German translations for manual pages + +- organize doc subdirectory for translated READMEs, manual pages + ++ Win32 port + +- test: optimization when accessing phonebooks: use size information +available via AT command to stop reading entries known to be empty (I +cannot test this with my hardware since CPBS? is not fully supported) + +- make apps accept stdin or stdout + ++ maybe strip leading and trailing whitespace from phonebook entries +when reading them from ME/TA or file? (not done, perhaps users want to +achieve special effects with white space) + +- support international character sets (8-bit, 16-bit) in phonebook +operations (I'd like to have input from users who need this) + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/acconfig.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/acconfig.h new file mode 100644 index 0000000000..14ce58fbc3 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/acconfig.h @@ -0,0 +1,33 @@ +/* used by libtool*/ +#define PACKAGE 0 + +/* used by libtool*/ +#define VERSION 0 + +/* Define if getopt_long() available */ +#undef HAVE_GETOPT_LONG + +/* Define if alarm() available */ +#undef HAVE_ALARM + +/* Define if netinet/in.h header available */ +#undef HAVE_NETINET_IN_H + +/* Define if string.h header available */ +#undef HAVE_STRING_H + +/* Define for NLS */ +#undef ENABLE_NLS +#undef HAVE_CATGETS +#undef HAVE_GETTEXT +#undef HAVE_LC_MESSAGES +#undef HAVE_STPCPY + +/* Define LOCALEDIR */ +#define LOCALEDIR "/usr/share/locale" + +/* Define if libintl.h header available */ +#undef HAVE_LIBINTL_H + +/* Define if vsnprintf() function available */ +#undef HAVE_VSNPRINTF diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/acinclude.m4 b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/acinclude.m4 new file mode 100644 index 0000000000..e69de29bb2 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/aclocal.m4 b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/aclocal.m4 new file mode 100644 index 0000000000..8d27d03353 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/aclocal.m4 @@ -0,0 +1,9704 @@ +# generated automatically by aclocal 1.9.6 -*- Autoconf -*- + +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, +# 2005 Free Software Foundation, Inc. +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +# codeset.m4 serial AM1 (gettext-0.10.40) +dnl Copyright (C) 2000-2002 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. + +AC_DEFUN([AM_LANGINFO_CODESET], +[ + AC_CACHE_CHECK([for nl_langinfo and CODESET], am_cv_langinfo_codeset, + [AC_TRY_LINK([#include ], + [char* cs = nl_langinfo(CODESET);], + am_cv_langinfo_codeset=yes, + am_cv_langinfo_codeset=no) + ]) + if test $am_cv_langinfo_codeset = yes; then + AC_DEFINE(HAVE_LANGINFO_CODESET, 1, + [Define if you have and nl_langinfo(CODESET).]) + fi +]) + +# gettext.m4 serial 37 (gettext-0.14.4) +dnl Copyright (C) 1995-2005 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. +dnl +dnl This file can can be used in projects which are not available under +dnl the GNU General Public License or the GNU Library General Public +dnl License but which still want to provide support for the GNU gettext +dnl functionality. +dnl Please note that the actual code of the GNU gettext library is covered +dnl by the GNU Library General Public License, and the rest of the GNU +dnl gettext package package is covered by the GNU General Public License. +dnl They are *not* in the public domain. + +dnl Authors: +dnl Ulrich Drepper , 1995-2000. +dnl Bruno Haible , 2000-2003. + +dnl Macro to add for using GNU gettext. + +dnl Usage: AM_GNU_GETTEXT([INTLSYMBOL], [NEEDSYMBOL], [INTLDIR]). +dnl INTLSYMBOL can be one of 'external', 'no-libtool', 'use-libtool'. The +dnl default (if it is not specified or empty) is 'no-libtool'. +dnl INTLSYMBOL should be 'external' for packages with no intl directory, +dnl and 'no-libtool' or 'use-libtool' for packages with an intl directory. +dnl If INTLSYMBOL is 'use-libtool', then a libtool library +dnl $(top_builddir)/intl/libintl.la will be created (shared and/or static, +dnl depending on --{enable,disable}-{shared,static} and on the presence of +dnl AM-DISABLE-SHARED). If INTLSYMBOL is 'no-libtool', a static library +dnl $(top_builddir)/intl/libintl.a will be created. +dnl If NEEDSYMBOL is specified and is 'need-ngettext', then GNU gettext +dnl implementations (in libc or libintl) without the ngettext() function +dnl will be ignored. If NEEDSYMBOL is specified and is +dnl 'need-formatstring-macros', then GNU gettext implementations that don't +dnl support the ISO C 99 formatstring macros will be ignored. +dnl INTLDIR is used to find the intl libraries. If empty, +dnl the value `$(top_builddir)/intl/' is used. +dnl +dnl The result of the configuration is one of three cases: +dnl 1) GNU gettext, as included in the intl subdirectory, will be compiled +dnl and used. +dnl Catalog format: GNU --> install in $(datadir) +dnl Catalog extension: .mo after installation, .gmo in source tree +dnl 2) GNU gettext has been found in the system's C library. +dnl Catalog format: GNU --> install in $(datadir) +dnl Catalog extension: .mo after installation, .gmo in source tree +dnl 3) No internationalization, always use English msgid. +dnl Catalog format: none +dnl Catalog extension: none +dnl If INTLSYMBOL is 'external', only cases 2 and 3 can occur. +dnl The use of .gmo is historical (it was needed to avoid overwriting the +dnl GNU format catalogs when building on a platform with an X/Open gettext), +dnl but we keep it in order not to force irrelevant filename changes on the +dnl maintainers. +dnl +AC_DEFUN([AM_GNU_GETTEXT], +[ + dnl Argument checking. + ifelse([$1], [], , [ifelse([$1], [external], , [ifelse([$1], [no-libtool], , [ifelse([$1], [use-libtool], , + [errprint([ERROR: invalid first argument to AM_GNU_GETTEXT +])])])])]) + ifelse([$2], [], , [ifelse([$2], [need-ngettext], , [ifelse([$2], [need-formatstring-macros], , + [errprint([ERROR: invalid second argument to AM_GNU_GETTEXT +])])])]) + define([gt_included_intl], ifelse([$1], [external], [no], [yes])) + define([gt_libtool_suffix_prefix], ifelse([$1], [use-libtool], [l], [])) + + AC_REQUIRE([AM_PO_SUBDIRS])dnl + ifelse(gt_included_intl, yes, [ + AC_REQUIRE([AM_INTL_SUBDIR])dnl + ]) + + dnl Prerequisites of AC_LIB_LINKFLAGS_BODY. + AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) + AC_REQUIRE([AC_LIB_RPATH]) + + dnl Sometimes libintl requires libiconv, so first search for libiconv. + dnl Ideally we would do this search only after the + dnl if test "$USE_NLS" = "yes"; then + dnl if test "$gt_cv_func_gnugettext_libc" != "yes"; then + dnl tests. But if configure.in invokes AM_ICONV after AM_GNU_GETTEXT + dnl the configure script would need to contain the same shell code + dnl again, outside any 'if'. There are two solutions: + dnl - Invoke AM_ICONV_LINKFLAGS_BODY here, outside any 'if'. + dnl - Control the expansions in more detail using AC_PROVIDE_IFELSE. + dnl Since AC_PROVIDE_IFELSE is only in autoconf >= 2.52 and not + dnl documented, we avoid it. + ifelse(gt_included_intl, yes, , [ + AC_REQUIRE([AM_ICONV_LINKFLAGS_BODY]) + ]) + + dnl Sometimes, on MacOS X, libintl requires linking with CoreFoundation. + gt_INTL_MACOSX + + dnl Set USE_NLS. + AM_NLS + + ifelse(gt_included_intl, yes, [ + BUILD_INCLUDED_LIBINTL=no + USE_INCLUDED_LIBINTL=no + ]) + LIBINTL= + LTLIBINTL= + POSUB= + + dnl If we use NLS figure out what method + if test "$USE_NLS" = "yes"; then + gt_use_preinstalled_gnugettext=no + ifelse(gt_included_intl, yes, [ + AC_MSG_CHECKING([whether included gettext is requested]) + AC_ARG_WITH(included-gettext, + [ --with-included-gettext use the GNU gettext library included here], + nls_cv_force_use_gnu_gettext=$withval, + nls_cv_force_use_gnu_gettext=no) + AC_MSG_RESULT($nls_cv_force_use_gnu_gettext) + + nls_cv_use_gnu_gettext="$nls_cv_force_use_gnu_gettext" + if test "$nls_cv_force_use_gnu_gettext" != "yes"; then + ]) + dnl User does not insist on using GNU NLS library. Figure out what + dnl to use. If GNU gettext is available we use this. Else we have + dnl to fall back to GNU NLS library. + + dnl Add a version number to the cache macros. + define([gt_api_version], ifelse([$2], [need-formatstring-macros], 3, ifelse([$2], [need-ngettext], 2, 1))) + define([gt_cv_func_gnugettext_libc], [gt_cv_func_gnugettext]gt_api_version[_libc]) + define([gt_cv_func_gnugettext_libintl], [gt_cv_func_gnugettext]gt_api_version[_libintl]) + + AC_CACHE_CHECK([for GNU gettext in libc], gt_cv_func_gnugettext_libc, + [AC_TRY_LINK([#include +]ifelse([$2], [need-formatstring-macros], +[#ifndef __GNU_GETTEXT_SUPPORTED_REVISION +#define __GNU_GETTEXT_SUPPORTED_REVISION(major) ((major) == 0 ? 0 : -1) +#endif +changequote(,)dnl +typedef int array [2 * (__GNU_GETTEXT_SUPPORTED_REVISION(0) >= 1) - 1]; +changequote([,])dnl +], [])[extern int _nl_msg_cat_cntr; +extern int *_nl_domain_bindings;], + [bindtextdomain ("", ""); +return * gettext ("")]ifelse([$2], [need-ngettext], [ + * ngettext ("", "", 0)], [])[ + _nl_msg_cat_cntr + *_nl_domain_bindings], + gt_cv_func_gnugettext_libc=yes, + gt_cv_func_gnugettext_libc=no)]) + + if test "$gt_cv_func_gnugettext_libc" != "yes"; then + dnl Sometimes libintl requires libiconv, so first search for libiconv. + ifelse(gt_included_intl, yes, , [ + AM_ICONV_LINK + ]) + dnl Search for libintl and define LIBINTL, LTLIBINTL and INCINTL + dnl accordingly. Don't use AC_LIB_LINKFLAGS_BODY([intl],[iconv]) + dnl because that would add "-liconv" to LIBINTL and LTLIBINTL + dnl even if libiconv doesn't exist. + AC_LIB_LINKFLAGS_BODY([intl]) + AC_CACHE_CHECK([for GNU gettext in libintl], + gt_cv_func_gnugettext_libintl, + [gt_save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$CPPFLAGS $INCINTL" + gt_save_LIBS="$LIBS" + LIBS="$LIBS $LIBINTL" + dnl Now see whether libintl exists and does not depend on libiconv. + AC_TRY_LINK([#include +]ifelse([$2], [need-formatstring-macros], +[#ifndef __GNU_GETTEXT_SUPPORTED_REVISION +#define __GNU_GETTEXT_SUPPORTED_REVISION(major) ((major) == 0 ? 0 : -1) +#endif +changequote(,)dnl +typedef int array [2 * (__GNU_GETTEXT_SUPPORTED_REVISION(0) >= 1) - 1]; +changequote([,])dnl +], [])[extern int _nl_msg_cat_cntr; +extern +#ifdef __cplusplus +"C" +#endif +const char *_nl_expand_alias (const char *);], + [bindtextdomain ("", ""); +return * gettext ("")]ifelse([$2], [need-ngettext], [ + * ngettext ("", "", 0)], [])[ + _nl_msg_cat_cntr + *_nl_expand_alias ("")], + gt_cv_func_gnugettext_libintl=yes, + gt_cv_func_gnugettext_libintl=no) + dnl Now see whether libintl exists and depends on libiconv. + if test "$gt_cv_func_gnugettext_libintl" != yes && test -n "$LIBICONV"; then + LIBS="$LIBS $LIBICONV" + AC_TRY_LINK([#include +]ifelse([$2], [need-formatstring-macros], +[#ifndef __GNU_GETTEXT_SUPPORTED_REVISION +#define __GNU_GETTEXT_SUPPORTED_REVISION(major) ((major) == 0 ? 0 : -1) +#endif +changequote(,)dnl +typedef int array [2 * (__GNU_GETTEXT_SUPPORTED_REVISION(0) >= 1) - 1]; +changequote([,])dnl +], [])[extern int _nl_msg_cat_cntr; +extern +#ifdef __cplusplus +"C" +#endif +const char *_nl_expand_alias (const char *);], + [bindtextdomain ("", ""); +return * gettext ("")]ifelse([$2], [need-ngettext], [ + * ngettext ("", "", 0)], [])[ + _nl_msg_cat_cntr + *_nl_expand_alias ("")], + [LIBINTL="$LIBINTL $LIBICONV" + LTLIBINTL="$LTLIBINTL $LTLIBICONV" + gt_cv_func_gnugettext_libintl=yes + ]) + fi + CPPFLAGS="$gt_save_CPPFLAGS" + LIBS="$gt_save_LIBS"]) + fi + + dnl If an already present or preinstalled GNU gettext() is found, + dnl use it. But if this macro is used in GNU gettext, and GNU + dnl gettext is already preinstalled in libintl, we update this + dnl libintl. (Cf. the install rule in intl/Makefile.in.) + if test "$gt_cv_func_gnugettext_libc" = "yes" \ + || { test "$gt_cv_func_gnugettext_libintl" = "yes" \ + && test "$PACKAGE" != gettext-runtime \ + && test "$PACKAGE" != gettext-tools; }; then + gt_use_preinstalled_gnugettext=yes + else + dnl Reset the values set by searching for libintl. + LIBINTL= + LTLIBINTL= + INCINTL= + fi + + ifelse(gt_included_intl, yes, [ + if test "$gt_use_preinstalled_gnugettext" != "yes"; then + dnl GNU gettext is not found in the C library. + dnl Fall back on included GNU gettext library. + nls_cv_use_gnu_gettext=yes + fi + fi + + if test "$nls_cv_use_gnu_gettext" = "yes"; then + dnl Mark actions used to generate GNU NLS library. + BUILD_INCLUDED_LIBINTL=yes + USE_INCLUDED_LIBINTL=yes + LIBINTL="ifelse([$3],[],\${top_builddir}/intl,[$3])/libintl.[]gt_libtool_suffix_prefix[]a $LIBICONV" + LTLIBINTL="ifelse([$3],[],\${top_builddir}/intl,[$3])/libintl.[]gt_libtool_suffix_prefix[]a $LTLIBICONV" + LIBS=`echo " $LIBS " | sed -e 's/ -lintl / /' -e 's/^ //' -e 's/ $//'` + fi + + CATOBJEXT= + if test "$gt_use_preinstalled_gnugettext" = "yes" \ + || test "$nls_cv_use_gnu_gettext" = "yes"; then + dnl Mark actions to use GNU gettext tools. + CATOBJEXT=.gmo + fi + ]) + + if test -n "$INTL_MACOSX_LIBS"; then + if test "$gt_use_preinstalled_gnugettext" = "yes" \ + || test "$nls_cv_use_gnu_gettext" = "yes"; then + dnl Some extra flags are needed during linking. + LIBINTL="$LIBINTL $INTL_MACOSX_LIBS" + LTLIBINTL="$LTLIBINTL $INTL_MACOSX_LIBS" + fi + fi + + if test "$gt_use_preinstalled_gnugettext" = "yes" \ + || test "$nls_cv_use_gnu_gettext" = "yes"; then + AC_DEFINE(ENABLE_NLS, 1, + [Define to 1 if translation of program messages to the user's native language + is requested.]) + else + USE_NLS=no + fi + fi + + AC_MSG_CHECKING([whether to use NLS]) + AC_MSG_RESULT([$USE_NLS]) + if test "$USE_NLS" = "yes"; then + AC_MSG_CHECKING([where the gettext function comes from]) + if test "$gt_use_preinstalled_gnugettext" = "yes"; then + if test "$gt_cv_func_gnugettext_libintl" = "yes"; then + gt_source="external libintl" + else + gt_source="libc" + fi + else + gt_source="included intl directory" + fi + AC_MSG_RESULT([$gt_source]) + fi + + if test "$USE_NLS" = "yes"; then + + if test "$gt_use_preinstalled_gnugettext" = "yes"; then + if test "$gt_cv_func_gnugettext_libintl" = "yes"; then + AC_MSG_CHECKING([how to link with libintl]) + AC_MSG_RESULT([$LIBINTL]) + AC_LIB_APPENDTOVAR([CPPFLAGS], [$INCINTL]) + fi + + dnl For backward compatibility. Some packages may be using this. + AC_DEFINE(HAVE_GETTEXT, 1, + [Define if the GNU gettext() function is already present or preinstalled.]) + AC_DEFINE(HAVE_DCGETTEXT, 1, + [Define if the GNU dcgettext() function is already present or preinstalled.]) + fi + + dnl We need to process the po/ directory. + POSUB=po + fi + + ifelse(gt_included_intl, yes, [ + dnl If this is used in GNU gettext we have to set BUILD_INCLUDED_LIBINTL + dnl to 'yes' because some of the testsuite requires it. + if test "$PACKAGE" = gettext-runtime || test "$PACKAGE" = gettext-tools; then + BUILD_INCLUDED_LIBINTL=yes + fi + + dnl Make all variables we use known to autoconf. + AC_SUBST(BUILD_INCLUDED_LIBINTL) + AC_SUBST(USE_INCLUDED_LIBINTL) + AC_SUBST(CATOBJEXT) + + dnl For backward compatibility. Some configure.ins may be using this. + nls_cv_header_intl= + nls_cv_header_libgt= + + dnl For backward compatibility. Some Makefiles may be using this. + DATADIRNAME=share + AC_SUBST(DATADIRNAME) + + dnl For backward compatibility. Some Makefiles may be using this. + INSTOBJEXT=.mo + AC_SUBST(INSTOBJEXT) + + dnl For backward compatibility. Some Makefiles may be using this. + GENCAT=gencat + AC_SUBST(GENCAT) + + dnl For backward compatibility. Some Makefiles may be using this. + INTLOBJS= + if test "$USE_INCLUDED_LIBINTL" = yes; then + INTLOBJS="\$(GETTOBJS)" + fi + AC_SUBST(INTLOBJS) + + dnl Enable libtool support if the surrounding package wishes it. + INTL_LIBTOOL_SUFFIX_PREFIX=gt_libtool_suffix_prefix + AC_SUBST(INTL_LIBTOOL_SUFFIX_PREFIX) + ]) + + dnl For backward compatibility. Some Makefiles may be using this. + INTLLIBS="$LIBINTL" + AC_SUBST(INTLLIBS) + + dnl Make all documented variables known to autoconf. + AC_SUBST(LIBINTL) + AC_SUBST(LTLIBINTL) + AC_SUBST(POSUB) +]) + + +dnl Checks for all prerequisites of the intl subdirectory, +dnl except for INTL_LIBTOOL_SUFFIX_PREFIX (and possibly LIBTOOL), INTLOBJS, +dnl USE_INCLUDED_LIBINTL, BUILD_INCLUDED_LIBINTL. +AC_DEFUN([AM_INTL_SUBDIR], +[ + AC_REQUIRE([AC_PROG_INSTALL])dnl + AC_REQUIRE([AM_MKINSTALLDIRS])dnl + AC_REQUIRE([AC_PROG_CC])dnl + AC_REQUIRE([AC_CANONICAL_HOST])dnl + AC_REQUIRE([gt_GLIBC2])dnl + AC_REQUIRE([AC_PROG_RANLIB])dnl + AC_REQUIRE([AC_ISC_POSIX])dnl + AC_REQUIRE([AC_HEADER_STDC])dnl + AC_REQUIRE([AC_C_CONST])dnl + AC_REQUIRE([bh_C_SIGNED])dnl + AC_REQUIRE([AC_C_INLINE])dnl + AC_REQUIRE([AC_TYPE_OFF_T])dnl + AC_REQUIRE([AC_TYPE_SIZE_T])dnl + AC_REQUIRE([gl_AC_TYPE_LONG_LONG])dnl + AC_REQUIRE([gt_TYPE_LONGDOUBLE])dnl + AC_REQUIRE([gt_TYPE_WCHAR_T])dnl + AC_REQUIRE([gt_TYPE_WINT_T])dnl + AC_REQUIRE([gl_AC_HEADER_INTTYPES_H]) + AC_REQUIRE([gl_AC_HEADER_STDINT_H]) + AC_REQUIRE([gt_TYPE_INTMAX_T]) + AC_REQUIRE([gt_PRINTF_POSIX]) + AC_REQUIRE([AC_FUNC_ALLOCA])dnl + AC_REQUIRE([AC_FUNC_MMAP])dnl + AC_REQUIRE([gl_GLIBC21])dnl + AC_REQUIRE([gt_INTDIV0])dnl + AC_REQUIRE([gl_AC_TYPE_UINTMAX_T])dnl + AC_REQUIRE([gt_HEADER_INTTYPES_H])dnl + AC_REQUIRE([gt_INTTYPES_PRI])dnl + AC_REQUIRE([gl_XSIZE])dnl + AC_REQUIRE([gt_INTL_MACOSX])dnl + + AC_CHECK_TYPE([ptrdiff_t], , + [AC_DEFINE([ptrdiff_t], [long], + [Define as the type of the result of subtracting two pointers, if the system doesn't define it.]) + ]) + AC_CHECK_HEADERS([argz.h limits.h locale.h nl_types.h malloc.h stddef.h \ +stdlib.h string.h unistd.h sys/param.h]) + AC_CHECK_FUNCS([asprintf fwprintf getcwd getegid geteuid getgid getuid \ +mempcpy munmap putenv setenv setlocale snprintf stpcpy strcasecmp strdup \ +strtoul tsearch wcslen __argz_count __argz_stringify __argz_next \ +__fsetlocking]) + + dnl Use the _snprintf function only if it is declared (because on NetBSD it + dnl is defined as a weak alias of snprintf; we prefer to use the latter). + gt_CHECK_DECL(_snprintf, [#include ]) + gt_CHECK_DECL(_snwprintf, [#include ]) + + dnl Use the *_unlocked functions only if they are declared. + dnl (because some of them were defined without being declared in Solaris + dnl 2.5.1 but were removed in Solaris 2.6, whereas we want binaries built + dnl on Solaris 2.5.1 to run on Solaris 2.6). + dnl Don't use AC_CHECK_DECLS because it isn't supported in autoconf-2.13. + gt_CHECK_DECL(feof_unlocked, [#include ]) + gt_CHECK_DECL(fgets_unlocked, [#include ]) + gt_CHECK_DECL(getc_unlocked, [#include ]) + + case $gt_cv_func_printf_posix in + *yes) HAVE_POSIX_PRINTF=1 ;; + *) HAVE_POSIX_PRINTF=0 ;; + esac + AC_SUBST([HAVE_POSIX_PRINTF]) + if test "$ac_cv_func_asprintf" = yes; then + HAVE_ASPRINTF=1 + else + HAVE_ASPRINTF=0 + fi + AC_SUBST([HAVE_ASPRINTF]) + if test "$ac_cv_func_snprintf" = yes; then + HAVE_SNPRINTF=1 + else + HAVE_SNPRINTF=0 + fi + AC_SUBST([HAVE_SNPRINTF]) + if test "$ac_cv_func_wprintf" = yes; then + HAVE_WPRINTF=1 + else + HAVE_WPRINTF=0 + fi + AC_SUBST([HAVE_WPRINTF]) + + AM_ICONV + AM_LANGINFO_CODESET + if test $ac_cv_header_locale_h = yes; then + gt_LC_MESSAGES + fi + + if test -n "$INTL_MACOSX_LIBS"; then + CPPFLAGS="$CPPFLAGS -I/System/Library/Frameworks/CoreFoundation.framework/Headers" + fi + + dnl intl/plural.c is generated from intl/plural.y. It requires bison, + dnl because plural.y uses bison specific features. It requires at least + dnl bison-1.26 because earlier versions generate a plural.c that doesn't + dnl compile. + dnl bison is only needed for the maintainer (who touches plural.y). But in + dnl order to avoid separate Makefiles or --enable-maintainer-mode, we put + dnl the rule in general Makefile. Now, some people carelessly touch the + dnl files or have a broken "make" program, hence the plural.c rule will + dnl sometimes fire. To avoid an error, defines BISON to ":" if it is not + dnl present or too old. + AC_CHECK_PROGS([INTLBISON], [bison]) + if test -z "$INTLBISON"; then + ac_verc_fail=yes + else + dnl Found it, now check the version. + AC_MSG_CHECKING([version of bison]) +changequote(<<,>>)dnl + ac_prog_version=`$INTLBISON --version 2>&1 | sed -n 's/^.*GNU Bison.* \([0-9]*\.[0-9.]*\).*$/\1/p'` + case $ac_prog_version in + '') ac_prog_version="v. ?.??, bad"; ac_verc_fail=yes;; + 1.2[6-9]* | 1.[3-9][0-9]* | [2-9].*) +changequote([,])dnl + ac_prog_version="$ac_prog_version, ok"; ac_verc_fail=no;; + *) ac_prog_version="$ac_prog_version, bad"; ac_verc_fail=yes;; + esac + AC_MSG_RESULT([$ac_prog_version]) + fi + if test $ac_verc_fail = yes; then + INTLBISON=: + fi +]) + + +dnl Checks for special options needed on MacOS X. +dnl Defines INTL_MACOSX_LIBS. +AC_DEFUN([gt_INTL_MACOSX], +[ + dnl Check for API introduced in MacOS X 10.2. + AC_CACHE_CHECK([for CFPreferencesCopyAppValue], + gt_cv_func_CFPreferencesCopyAppValue, + [gt_save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$CPPFLAGS -I/System/Library/Frameworks/CoreFoundation.framework/Headers" + gt_save_LIBS="$LIBS" + LIBS="$LIBS -framework CoreFoundation" + AC_TRY_LINK([#include ], + [CFPreferencesCopyAppValue(NULL, NULL)], + [gt_cv_func_CFPreferencesCopyAppValue=yes], + [gt_cv_func_CFPreferencesCopyAppValue=no]) + CPPFLAGS="$gt_save_CPPFLAGS" + LIBS="$gt_save_LIBS"]) + if test $gt_cv_func_CFPreferencesCopyAppValue = yes; then + AC_DEFINE([HAVE_CFPREFERENCESCOPYAPPVALUE], 1, + [Define to 1 if you have the MacOS X function CFPreferencesCopyAppValue in the CoreFoundation framework.]) + fi + dnl Check for API introduced in MacOS X 10.3. + AC_CACHE_CHECK([for CFLocaleCopyCurrent], gt_cv_func_CFLocaleCopyCurrent, + [gt_save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$CPPFLAGS -I/System/Library/Frameworks/CoreFoundation.framework/Headers" + gt_save_LIBS="$LIBS" + LIBS="$LIBS -framework CoreFoundation" + AC_TRY_LINK([#include ], [CFLocaleCopyCurrent();], + [gt_cv_func_CFLocaleCopyCurrent=yes], + [gt_cv_func_CFLocaleCopyCurrent=no]) + CPPFLAGS="$gt_save_CPPFLAGS" + LIBS="$gt_save_LIBS"]) + if test $gt_cv_func_CFLocaleCopyCurrent = yes; then + AC_DEFINE([HAVE_CFLOCALECOPYCURRENT], 1, + [Define to 1 if you have the MacOS X function CFLocaleCopyCurrent in the CoreFoundation framework.]) + fi + INTL_MACOSX_LIBS= + if test $gt_cv_func_CFPreferencesCopyAppValue = yes || test $gt_cv_func_CFLocaleCopyCurrent = yes; then + INTL_MACOSX_LIBS="-Wl,-framework -Wl,CoreFoundation" + fi + AC_SUBST([INTL_MACOSX_LIBS]) +]) + + +dnl gt_CHECK_DECL(FUNC, INCLUDES) +dnl Check whether a function is declared. +AC_DEFUN([gt_CHECK_DECL], +[ + AC_CACHE_CHECK([whether $1 is declared], ac_cv_have_decl_$1, + [AC_TRY_COMPILE([$2], [ +#ifndef $1 + char *p = (char *) $1; +#endif +], ac_cv_have_decl_$1=yes, ac_cv_have_decl_$1=no)]) + if test $ac_cv_have_decl_$1 = yes; then + gt_value=1 + else + gt_value=0 + fi + AC_DEFINE_UNQUOTED([HAVE_DECL_]translit($1, [a-z], [A-Z]), [$gt_value], + [Define to 1 if you have the declaration of `$1', and to 0 if you don't.]) +]) + + +dnl Usage: AM_GNU_GETTEXT_VERSION([gettext-version]) +AC_DEFUN([AM_GNU_GETTEXT_VERSION], []) + +# glibc2.m4 serial 1 +dnl Copyright (C) 2000-2002, 2004 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +# Test for the GNU C Library, version 2.0 or newer. +# From Bruno Haible. + +AC_DEFUN([gt_GLIBC2], + [ + AC_CACHE_CHECK(whether we are using the GNU C Library 2 or newer, + ac_cv_gnu_library_2, + [AC_EGREP_CPP([Lucky GNU user], + [ +#include +#ifdef __GNU_LIBRARY__ + #if (__GLIBC__ >= 2) + Lucky GNU user + #endif +#endif + ], + ac_cv_gnu_library_2=yes, + ac_cv_gnu_library_2=no) + ] + ) + AC_SUBST(GLIBC2) + GLIBC2="$ac_cv_gnu_library_2" + ] +) + +# glibc21.m4 serial 3 +dnl Copyright (C) 2000-2002, 2004 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +# Test for the GNU C Library, version 2.1 or newer. +# From Bruno Haible. + +AC_DEFUN([gl_GLIBC21], + [ + AC_CACHE_CHECK(whether we are using the GNU C Library 2.1 or newer, + ac_cv_gnu_library_2_1, + [AC_EGREP_CPP([Lucky GNU user], + [ +#include +#ifdef __GNU_LIBRARY__ + #if (__GLIBC__ == 2 && __GLIBC_MINOR__ >= 1) || (__GLIBC__ > 2) + Lucky GNU user + #endif +#endif + ], + ac_cv_gnu_library_2_1=yes, + ac_cv_gnu_library_2_1=no) + ] + ) + AC_SUBST(GLIBC21) + GLIBC21="$ac_cv_gnu_library_2_1" + ] +) + +# iconv.m4 serial AM4 (gettext-0.11.3) +dnl Copyright (C) 2000-2002 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. + +AC_DEFUN([AM_ICONV_LINKFLAGS_BODY], +[ + dnl Prerequisites of AC_LIB_LINKFLAGS_BODY. + AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) + AC_REQUIRE([AC_LIB_RPATH]) + + dnl Search for libiconv and define LIBICONV, LTLIBICONV and INCICONV + dnl accordingly. + AC_LIB_LINKFLAGS_BODY([iconv]) +]) + +AC_DEFUN([AM_ICONV_LINK], +[ + dnl Some systems have iconv in libc, some have it in libiconv (OSF/1 and + dnl those with the standalone portable GNU libiconv installed). + + dnl Search for libiconv and define LIBICONV, LTLIBICONV and INCICONV + dnl accordingly. + AC_REQUIRE([AM_ICONV_LINKFLAGS_BODY]) + + dnl Add $INCICONV to CPPFLAGS before performing the following checks, + dnl because if the user has installed libiconv and not disabled its use + dnl via --without-libiconv-prefix, he wants to use it. The first + dnl AC_TRY_LINK will then fail, the second AC_TRY_LINK will succeed. + am_save_CPPFLAGS="$CPPFLAGS" + AC_LIB_APPENDTOVAR([CPPFLAGS], [$INCICONV]) + + AC_CACHE_CHECK(for iconv, am_cv_func_iconv, [ + am_cv_func_iconv="no, consider installing GNU libiconv" + am_cv_lib_iconv=no + AC_TRY_LINK([#include +#include ], + [iconv_t cd = iconv_open("",""); + iconv(cd,NULL,NULL,NULL,NULL); + iconv_close(cd);], + am_cv_func_iconv=yes) + if test "$am_cv_func_iconv" != yes; then + am_save_LIBS="$LIBS" + LIBS="$LIBS $LIBICONV" + AC_TRY_LINK([#include +#include ], + [iconv_t cd = iconv_open("",""); + iconv(cd,NULL,NULL,NULL,NULL); + iconv_close(cd);], + am_cv_lib_iconv=yes + am_cv_func_iconv=yes) + LIBS="$am_save_LIBS" + fi + ]) + if test "$am_cv_func_iconv" = yes; then + AC_DEFINE(HAVE_ICONV, 1, [Define if you have the iconv() function.]) + fi + if test "$am_cv_lib_iconv" = yes; then + AC_MSG_CHECKING([how to link with libiconv]) + AC_MSG_RESULT([$LIBICONV]) + else + dnl If $LIBICONV didn't lead to a usable library, we don't need $INCICONV + dnl either. + CPPFLAGS="$am_save_CPPFLAGS" + LIBICONV= + LTLIBICONV= + fi + AC_SUBST(LIBICONV) + AC_SUBST(LTLIBICONV) +]) + +AC_DEFUN([AM_ICONV], +[ + AM_ICONV_LINK + if test "$am_cv_func_iconv" = yes; then + AC_MSG_CHECKING([for iconv declaration]) + AC_CACHE_VAL(am_cv_proto_iconv, [ + AC_TRY_COMPILE([ +#include +#include +extern +#ifdef __cplusplus +"C" +#endif +#if defined(__STDC__) || defined(__cplusplus) +size_t iconv (iconv_t cd, char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft); +#else +size_t iconv(); +#endif +], [], am_cv_proto_iconv_arg1="", am_cv_proto_iconv_arg1="const") + am_cv_proto_iconv="extern size_t iconv (iconv_t cd, $am_cv_proto_iconv_arg1 char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft);"]) + am_cv_proto_iconv=`echo "[$]am_cv_proto_iconv" | tr -s ' ' | sed -e 's/( /(/'` + AC_MSG_RESULT([$]{ac_t:- + }[$]am_cv_proto_iconv) + AC_DEFINE_UNQUOTED(ICONV_CONST, $am_cv_proto_iconv_arg1, + [Define as const if the declaration of iconv() needs const.]) + fi +]) + +# intdiv0.m4 serial 1 (gettext-0.11.3) +dnl Copyright (C) 2002 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. + +AC_DEFUN([gt_INTDIV0], +[ + AC_REQUIRE([AC_PROG_CC])dnl + AC_REQUIRE([AC_CANONICAL_HOST])dnl + + AC_CACHE_CHECK([whether integer division by zero raises SIGFPE], + gt_cv_int_divbyzero_sigfpe, + [ + AC_TRY_RUN([ +#include +#include + +static void +#ifdef __cplusplus +sigfpe_handler (int sig) +#else +sigfpe_handler (sig) int sig; +#endif +{ + /* Exit with code 0 if SIGFPE, with code 1 if any other signal. */ + exit (sig != SIGFPE); +} + +int x = 1; +int y = 0; +int z; +int nan; + +int main () +{ + signal (SIGFPE, sigfpe_handler); +/* IRIX and AIX (when "xlc -qcheck" is used) yield signal SIGTRAP. */ +#if (defined (__sgi) || defined (_AIX)) && defined (SIGTRAP) + signal (SIGTRAP, sigfpe_handler); +#endif +/* Linux/SPARC yields signal SIGILL. */ +#if defined (__sparc__) && defined (__linux__) + signal (SIGILL, sigfpe_handler); +#endif + + z = x / y; + nan = y / y; + exit (1); +} +], gt_cv_int_divbyzero_sigfpe=yes, gt_cv_int_divbyzero_sigfpe=no, + [ + # Guess based on the CPU. + case "$host_cpu" in + alpha* | i[34567]86 | m68k | s390*) + gt_cv_int_divbyzero_sigfpe="guessing yes";; + *) + gt_cv_int_divbyzero_sigfpe="guessing no";; + esac + ]) + ]) + case "$gt_cv_int_divbyzero_sigfpe" in + *yes) value=1;; + *) value=0;; + esac + AC_DEFINE_UNQUOTED(INTDIV0_RAISES_SIGFPE, $value, + [Define if integer division by zero raises signal SIGFPE.]) +]) + +# intmax.m4 serial 2 (gettext-0.14.2) +dnl Copyright (C) 2002-2005 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. +dnl Test whether the system has the 'intmax_t' type, but don't attempt to +dnl find a replacement if it is lacking. + +AC_DEFUN([gt_TYPE_INTMAX_T], +[ + AC_REQUIRE([gl_AC_HEADER_INTTYPES_H]) + AC_REQUIRE([gl_AC_HEADER_STDINT_H]) + AC_CACHE_CHECK(for intmax_t, gt_cv_c_intmax_t, + [AC_TRY_COMPILE([ +#include +#include +#if HAVE_STDINT_H_WITH_UINTMAX +#include +#endif +#if HAVE_INTTYPES_H_WITH_UINTMAX +#include +#endif +], [intmax_t x = -1;], gt_cv_c_intmax_t=yes, gt_cv_c_intmax_t=no)]) + if test $gt_cv_c_intmax_t = yes; then + AC_DEFINE(HAVE_INTMAX_T, 1, + [Define if you have the 'intmax_t' type in or .]) + fi +]) + +# inttypes-pri.m4 serial 1 (gettext-0.11.4) +dnl Copyright (C) 1997-2002 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. + +# Define PRI_MACROS_BROKEN if exists and defines the PRI* +# macros to non-string values. This is the case on AIX 4.3.3. + +AC_DEFUN([gt_INTTYPES_PRI], +[ + AC_REQUIRE([gt_HEADER_INTTYPES_H]) + if test $gt_cv_header_inttypes_h = yes; then + AC_CACHE_CHECK([whether the inttypes.h PRIxNN macros are broken], + gt_cv_inttypes_pri_broken, + [ + AC_TRY_COMPILE([#include +#ifdef PRId32 +char *p = PRId32; +#endif +], [], gt_cv_inttypes_pri_broken=no, gt_cv_inttypes_pri_broken=yes) + ]) + fi + if test "$gt_cv_inttypes_pri_broken" = yes; then + AC_DEFINE_UNQUOTED(PRI_MACROS_BROKEN, 1, + [Define if exists and defines unusable PRI* macros.]) + fi +]) + +# inttypes.m4 serial 1 (gettext-0.11.4) +dnl Copyright (C) 1997-2002 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Paul Eggert. + +# Define HAVE_INTTYPES_H if exists and doesn't clash with +# . + +AC_DEFUN([gt_HEADER_INTTYPES_H], +[ + AC_CACHE_CHECK([for inttypes.h], gt_cv_header_inttypes_h, + [ + AC_TRY_COMPILE( + [#include +#include ], + [], gt_cv_header_inttypes_h=yes, gt_cv_header_inttypes_h=no) + ]) + if test $gt_cv_header_inttypes_h = yes; then + AC_DEFINE_UNQUOTED(HAVE_INTTYPES_H, 1, + [Define if exists and doesn't clash with .]) + fi +]) + +# inttypes_h.m4 serial 6 +dnl Copyright (C) 1997-2004 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Paul Eggert. + +# Define HAVE_INTTYPES_H_WITH_UINTMAX if exists, +# doesn't clash with , and declares uintmax_t. + +AC_DEFUN([gl_AC_HEADER_INTTYPES_H], +[ + AC_CACHE_CHECK([for inttypes.h], gl_cv_header_inttypes_h, + [AC_TRY_COMPILE( + [#include +#include ], + [uintmax_t i = (uintmax_t) -1;], + gl_cv_header_inttypes_h=yes, + gl_cv_header_inttypes_h=no)]) + if test $gl_cv_header_inttypes_h = yes; then + AC_DEFINE_UNQUOTED(HAVE_INTTYPES_H_WITH_UINTMAX, 1, + [Define if exists, doesn't clash with , + and declares uintmax_t. ]) + fi +]) + +# lcmessage.m4 serial 4 (gettext-0.14.2) +dnl Copyright (C) 1995-2002, 2004-2005 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. +dnl +dnl This file can can be used in projects which are not available under +dnl the GNU General Public License or the GNU Library General Public +dnl License but which still want to provide support for the GNU gettext +dnl functionality. +dnl Please note that the actual code of the GNU gettext library is covered +dnl by the GNU Library General Public License, and the rest of the GNU +dnl gettext package package is covered by the GNU General Public License. +dnl They are *not* in the public domain. + +dnl Authors: +dnl Ulrich Drepper , 1995. + +# Check whether LC_MESSAGES is available in . + +AC_DEFUN([gt_LC_MESSAGES], +[ + AC_CACHE_CHECK([for LC_MESSAGES], gt_cv_val_LC_MESSAGES, + [AC_TRY_LINK([#include ], [return LC_MESSAGES], + gt_cv_val_LC_MESSAGES=yes, gt_cv_val_LC_MESSAGES=no)]) + if test $gt_cv_val_LC_MESSAGES = yes; then + AC_DEFINE(HAVE_LC_MESSAGES, 1, + [Define if your file defines LC_MESSAGES.]) + fi +]) + +# lib-ld.m4 serial 3 (gettext-0.13) +dnl Copyright (C) 1996-2003 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl Subroutines of libtool.m4, +dnl with replacements s/AC_/AC_LIB/ and s/lt_cv/acl_cv/ to avoid collision +dnl with libtool.m4. + +dnl From libtool-1.4. Sets the variable with_gnu_ld to yes or no. +AC_DEFUN([AC_LIB_PROG_LD_GNU], +[AC_CACHE_CHECK([if the linker ($LD) is GNU ld], acl_cv_prog_gnu_ld, +[# I'd rather use --version here, but apparently some GNU ld's only accept -v. +case `$LD -v 2>&1 conf$$.sh + echo "exit 0" >>conf$$.sh + chmod +x conf$$.sh + if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then + PATH_SEPARATOR=';' + else + PATH_SEPARATOR=: + fi + rm -f conf$$.sh +fi +ac_prog=ld +if test "$GCC" = yes; then + # Check if gcc -print-prog-name=ld gives a path. + AC_MSG_CHECKING([for ld used by GCC]) + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [[\\/]* | [A-Za-z]:[\\/]*)] + [re_direlt='/[^/][^/]*/\.\./'] + # Canonicalize the path of ld + ac_prog=`echo $ac_prog| sed 's%\\\\%/%g'` + while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do + ac_prog=`echo $ac_prog| sed "s%$re_direlt%/%"` + done + test -z "$LD" && LD="$ac_prog" + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test "$with_gnu_ld" = yes; then + AC_MSG_CHECKING([for GNU ld]) +else + AC_MSG_CHECKING([for non-GNU ld]) +fi +AC_CACHE_VAL(acl_cv_path_LD, +[if test -z "$LD"; then + IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR-:}" + for ac_dir in $PATH; do + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + acl_cv_path_LD="$ac_dir/$ac_prog" + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some GNU ld's only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$acl_cv_path_LD" -v 2>&1 < /dev/null` in + *GNU* | *'with BFD'*) + test "$with_gnu_ld" != no && break ;; + *) + test "$with_gnu_ld" != yes && break ;; + esac + fi + done + IFS="$ac_save_ifs" +else + acl_cv_path_LD="$LD" # Let the user override the test with a path. +fi]) +LD="$acl_cv_path_LD" +if test -n "$LD"; then + AC_MSG_RESULT($LD) +else + AC_MSG_RESULT(no) +fi +test -z "$LD" && AC_MSG_ERROR([no acceptable ld found in \$PATH]) +AC_LIB_PROG_LD_GNU +]) + +# lib-link.m4 serial 6 (gettext-0.14.3) +dnl Copyright (C) 2001-2005 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. + +AC_PREREQ(2.50) + +dnl AC_LIB_LINKFLAGS(name [, dependencies]) searches for libname and +dnl the libraries corresponding to explicit and implicit dependencies. +dnl Sets and AC_SUBSTs the LIB${NAME} and LTLIB${NAME} variables and +dnl augments the CPPFLAGS variable. +AC_DEFUN([AC_LIB_LINKFLAGS], +[ + AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) + AC_REQUIRE([AC_LIB_RPATH]) + define([Name],[translit([$1],[./-], [___])]) + define([NAME],[translit([$1],[abcdefghijklmnopqrstuvwxyz./-], + [ABCDEFGHIJKLMNOPQRSTUVWXYZ___])]) + AC_CACHE_CHECK([how to link with lib[]$1], [ac_cv_lib[]Name[]_libs], [ + AC_LIB_LINKFLAGS_BODY([$1], [$2]) + ac_cv_lib[]Name[]_libs="$LIB[]NAME" + ac_cv_lib[]Name[]_ltlibs="$LTLIB[]NAME" + ac_cv_lib[]Name[]_cppflags="$INC[]NAME" + ]) + LIB[]NAME="$ac_cv_lib[]Name[]_libs" + LTLIB[]NAME="$ac_cv_lib[]Name[]_ltlibs" + INC[]NAME="$ac_cv_lib[]Name[]_cppflags" + AC_LIB_APPENDTOVAR([CPPFLAGS], [$INC]NAME) + AC_SUBST([LIB]NAME) + AC_SUBST([LTLIB]NAME) + dnl Also set HAVE_LIB[]NAME so that AC_LIB_HAVE_LINKFLAGS can reuse the + dnl results of this search when this library appears as a dependency. + HAVE_LIB[]NAME=yes + undefine([Name]) + undefine([NAME]) +]) + +dnl AC_LIB_HAVE_LINKFLAGS(name, dependencies, includes, testcode) +dnl searches for libname and the libraries corresponding to explicit and +dnl implicit dependencies, together with the specified include files and +dnl the ability to compile and link the specified testcode. If found, it +dnl sets and AC_SUBSTs HAVE_LIB${NAME}=yes and the LIB${NAME} and +dnl LTLIB${NAME} variables and augments the CPPFLAGS variable, and +dnl #defines HAVE_LIB${NAME} to 1. Otherwise, it sets and AC_SUBSTs +dnl HAVE_LIB${NAME}=no and LIB${NAME} and LTLIB${NAME} to empty. +AC_DEFUN([AC_LIB_HAVE_LINKFLAGS], +[ + AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) + AC_REQUIRE([AC_LIB_RPATH]) + define([Name],[translit([$1],[./-], [___])]) + define([NAME],[translit([$1],[abcdefghijklmnopqrstuvwxyz./-], + [ABCDEFGHIJKLMNOPQRSTUVWXYZ___])]) + + dnl Search for lib[]Name and define LIB[]NAME, LTLIB[]NAME and INC[]NAME + dnl accordingly. + AC_LIB_LINKFLAGS_BODY([$1], [$2]) + + dnl Add $INC[]NAME to CPPFLAGS before performing the following checks, + dnl because if the user has installed lib[]Name and not disabled its use + dnl via --without-lib[]Name-prefix, he wants to use it. + ac_save_CPPFLAGS="$CPPFLAGS" + AC_LIB_APPENDTOVAR([CPPFLAGS], [$INC]NAME) + + AC_CACHE_CHECK([for lib[]$1], [ac_cv_lib[]Name], [ + ac_save_LIBS="$LIBS" + LIBS="$LIBS $LIB[]NAME" + AC_TRY_LINK([$3], [$4], [ac_cv_lib[]Name=yes], [ac_cv_lib[]Name=no]) + LIBS="$ac_save_LIBS" + ]) + if test "$ac_cv_lib[]Name" = yes; then + HAVE_LIB[]NAME=yes + AC_DEFINE([HAVE_LIB]NAME, 1, [Define if you have the $1 library.]) + AC_MSG_CHECKING([how to link with lib[]$1]) + AC_MSG_RESULT([$LIB[]NAME]) + else + HAVE_LIB[]NAME=no + dnl If $LIB[]NAME didn't lead to a usable library, we don't need + dnl $INC[]NAME either. + CPPFLAGS="$ac_save_CPPFLAGS" + LIB[]NAME= + LTLIB[]NAME= + fi + AC_SUBST([HAVE_LIB]NAME) + AC_SUBST([LIB]NAME) + AC_SUBST([LTLIB]NAME) + undefine([Name]) + undefine([NAME]) +]) + +dnl Determine the platform dependent parameters needed to use rpath: +dnl libext, shlibext, hardcode_libdir_flag_spec, hardcode_libdir_separator, +dnl hardcode_direct, hardcode_minus_L. +AC_DEFUN([AC_LIB_RPATH], +[ + dnl Tell automake >= 1.10 to complain if config.rpath is missing. + m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([config.rpath])]) + AC_REQUIRE([AC_PROG_CC]) dnl we use $CC, $GCC, $LDFLAGS + AC_REQUIRE([AC_LIB_PROG_LD]) dnl we use $LD, $with_gnu_ld + AC_REQUIRE([AC_CANONICAL_HOST]) dnl we use $host + AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT]) dnl we use $ac_aux_dir + AC_CACHE_CHECK([for shared library run path origin], acl_cv_rpath, [ + CC="$CC" GCC="$GCC" LDFLAGS="$LDFLAGS" LD="$LD" with_gnu_ld="$with_gnu_ld" \ + ${CONFIG_SHELL-/bin/sh} "$ac_aux_dir/config.rpath" "$host" > conftest.sh + . ./conftest.sh + rm -f ./conftest.sh + acl_cv_rpath=done + ]) + wl="$acl_cv_wl" + libext="$acl_cv_libext" + shlibext="$acl_cv_shlibext" + hardcode_libdir_flag_spec="$acl_cv_hardcode_libdir_flag_spec" + hardcode_libdir_separator="$acl_cv_hardcode_libdir_separator" + hardcode_direct="$acl_cv_hardcode_direct" + hardcode_minus_L="$acl_cv_hardcode_minus_L" + dnl Determine whether the user wants rpath handling at all. + AC_ARG_ENABLE(rpath, + [ --disable-rpath do not hardcode runtime library paths], + :, enable_rpath=yes) +]) + +dnl AC_LIB_LINKFLAGS_BODY(name [, dependencies]) searches for libname and +dnl the libraries corresponding to explicit and implicit dependencies. +dnl Sets the LIB${NAME}, LTLIB${NAME} and INC${NAME} variables. +AC_DEFUN([AC_LIB_LINKFLAGS_BODY], +[ + define([NAME],[translit([$1],[abcdefghijklmnopqrstuvwxyz./-], + [ABCDEFGHIJKLMNOPQRSTUVWXYZ___])]) + dnl By default, look in $includedir and $libdir. + use_additional=yes + AC_LIB_WITH_FINAL_PREFIX([ + eval additional_includedir=\"$includedir\" + eval additional_libdir=\"$libdir\" + ]) + AC_LIB_ARG_WITH([lib$1-prefix], +[ --with-lib$1-prefix[=DIR] search for lib$1 in DIR/include and DIR/lib + --without-lib$1-prefix don't search for lib$1 in includedir and libdir], +[ + if test "X$withval" = "Xno"; then + use_additional=no + else + if test "X$withval" = "X"; then + AC_LIB_WITH_FINAL_PREFIX([ + eval additional_includedir=\"$includedir\" + eval additional_libdir=\"$libdir\" + ]) + else + additional_includedir="$withval/include" + additional_libdir="$withval/lib" + fi + fi +]) + dnl Search the library and its dependencies in $additional_libdir and + dnl $LDFLAGS. Using breadth-first-seach. + LIB[]NAME= + LTLIB[]NAME= + INC[]NAME= + rpathdirs= + ltrpathdirs= + names_already_handled= + names_next_round='$1 $2' + while test -n "$names_next_round"; do + names_this_round="$names_next_round" + names_next_round= + for name in $names_this_round; do + already_handled= + for n in $names_already_handled; do + if test "$n" = "$name"; then + already_handled=yes + break + fi + done + if test -z "$already_handled"; then + names_already_handled="$names_already_handled $name" + dnl See if it was already located by an earlier AC_LIB_LINKFLAGS + dnl or AC_LIB_HAVE_LINKFLAGS call. + uppername=`echo "$name" | sed -e 'y|abcdefghijklmnopqrstuvwxyz./-|ABCDEFGHIJKLMNOPQRSTUVWXYZ___|'` + eval value=\"\$HAVE_LIB$uppername\" + if test -n "$value"; then + if test "$value" = yes; then + eval value=\"\$LIB$uppername\" + test -z "$value" || LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$value" + eval value=\"\$LTLIB$uppername\" + test -z "$value" || LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }$value" + else + dnl An earlier call to AC_LIB_HAVE_LINKFLAGS has determined + dnl that this library doesn't exist. So just drop it. + : + fi + else + dnl Search the library lib$name in $additional_libdir and $LDFLAGS + dnl and the already constructed $LIBNAME/$LTLIBNAME. + found_dir= + found_la= + found_so= + found_a= + if test $use_additional = yes; then + if test -n "$shlibext" && test -f "$additional_libdir/lib$name.$shlibext"; then + found_dir="$additional_libdir" + found_so="$additional_libdir/lib$name.$shlibext" + if test -f "$additional_libdir/lib$name.la"; then + found_la="$additional_libdir/lib$name.la" + fi + else + if test -f "$additional_libdir/lib$name.$libext"; then + found_dir="$additional_libdir" + found_a="$additional_libdir/lib$name.$libext" + if test -f "$additional_libdir/lib$name.la"; then + found_la="$additional_libdir/lib$name.la" + fi + fi + fi + fi + if test "X$found_dir" = "X"; then + for x in $LDFLAGS $LTLIB[]NAME; do + AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) + case "$x" in + -L*) + dir=`echo "X$x" | sed -e 's/^X-L//'` + if test -n "$shlibext" && test -f "$dir/lib$name.$shlibext"; then + found_dir="$dir" + found_so="$dir/lib$name.$shlibext" + if test -f "$dir/lib$name.la"; then + found_la="$dir/lib$name.la" + fi + else + if test -f "$dir/lib$name.$libext"; then + found_dir="$dir" + found_a="$dir/lib$name.$libext" + if test -f "$dir/lib$name.la"; then + found_la="$dir/lib$name.la" + fi + fi + fi + ;; + esac + if test "X$found_dir" != "X"; then + break + fi + done + fi + if test "X$found_dir" != "X"; then + dnl Found the library. + LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-L$found_dir -l$name" + if test "X$found_so" != "X"; then + dnl Linking with a shared library. We attempt to hardcode its + dnl directory into the executable's runpath, unless it's the + dnl standard /usr/lib. + if test "$enable_rpath" = no || test "X$found_dir" = "X/usr/lib"; then + dnl No hardcoding is needed. + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" + else + dnl Use an explicit option to hardcode DIR into the resulting + dnl binary. + dnl Potentially add DIR to ltrpathdirs. + dnl The ltrpathdirs will be appended to $LTLIBNAME at the end. + haveit= + for x in $ltrpathdirs; do + if test "X$x" = "X$found_dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + ltrpathdirs="$ltrpathdirs $found_dir" + fi + dnl The hardcoding into $LIBNAME is system dependent. + if test "$hardcode_direct" = yes; then + dnl Using DIR/libNAME.so during linking hardcodes DIR into the + dnl resulting binary. + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" + else + if test -n "$hardcode_libdir_flag_spec" && test "$hardcode_minus_L" = no; then + dnl Use an explicit option to hardcode DIR into the resulting + dnl binary. + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" + dnl Potentially add DIR to rpathdirs. + dnl The rpathdirs will be appended to $LIBNAME at the end. + haveit= + for x in $rpathdirs; do + if test "X$x" = "X$found_dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + rpathdirs="$rpathdirs $found_dir" + fi + else + dnl Rely on "-L$found_dir". + dnl But don't add it if it's already contained in the LDFLAGS + dnl or the already constructed $LIBNAME + haveit= + for x in $LDFLAGS $LIB[]NAME; do + AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) + if test "X$x" = "X-L$found_dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$found_dir" + fi + if test "$hardcode_minus_L" != no; then + dnl FIXME: Not sure whether we should use + dnl "-L$found_dir -l$name" or "-L$found_dir $found_so" + dnl here. + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" + else + dnl We cannot use $hardcode_runpath_var and LD_RUN_PATH + dnl here, because this doesn't fit in flags passed to the + dnl compiler. So give up. No hardcoding. This affects only + dnl very old systems. + dnl FIXME: Not sure whether we should use + dnl "-L$found_dir -l$name" or "-L$found_dir $found_so" + dnl here. + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-l$name" + fi + fi + fi + fi + else + if test "X$found_a" != "X"; then + dnl Linking with a static library. + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_a" + else + dnl We shouldn't come here, but anyway it's good to have a + dnl fallback. + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$found_dir -l$name" + fi + fi + dnl Assume the include files are nearby. + additional_includedir= + case "$found_dir" in + */lib | */lib/) + basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e 's,/lib/*$,,'` + additional_includedir="$basedir/include" + ;; + esac + if test "X$additional_includedir" != "X"; then + dnl Potentially add $additional_includedir to $INCNAME. + dnl But don't add it + dnl 1. if it's the standard /usr/include, + dnl 2. if it's /usr/local/include and we are using GCC on Linux, + dnl 3. if it's already present in $CPPFLAGS or the already + dnl constructed $INCNAME, + dnl 4. if it doesn't exist as a directory. + if test "X$additional_includedir" != "X/usr/include"; then + haveit= + if test "X$additional_includedir" = "X/usr/local/include"; then + if test -n "$GCC"; then + case $host_os in + linux* | gnu* | k*bsd*-gnu) haveit=yes;; + esac + fi + fi + if test -z "$haveit"; then + for x in $CPPFLAGS $INC[]NAME; do + AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) + if test "X$x" = "X-I$additional_includedir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + if test -d "$additional_includedir"; then + dnl Really add $additional_includedir to $INCNAME. + INC[]NAME="${INC[]NAME}${INC[]NAME:+ }-I$additional_includedir" + fi + fi + fi + fi + fi + dnl Look for dependencies. + if test -n "$found_la"; then + dnl Read the .la file. It defines the variables + dnl dlname, library_names, old_library, dependency_libs, current, + dnl age, revision, installed, dlopen, dlpreopen, libdir. + save_libdir="$libdir" + case "$found_la" in + */* | *\\*) . "$found_la" ;; + *) . "./$found_la" ;; + esac + libdir="$save_libdir" + dnl We use only dependency_libs. + for dep in $dependency_libs; do + case "$dep" in + -L*) + additional_libdir=`echo "X$dep" | sed -e 's/^X-L//'` + dnl Potentially add $additional_libdir to $LIBNAME and $LTLIBNAME. + dnl But don't add it + dnl 1. if it's the standard /usr/lib, + dnl 2. if it's /usr/local/lib and we are using GCC on Linux, + dnl 3. if it's already present in $LDFLAGS or the already + dnl constructed $LIBNAME, + dnl 4. if it doesn't exist as a directory. + if test "X$additional_libdir" != "X/usr/lib"; then + haveit= + if test "X$additional_libdir" = "X/usr/local/lib"; then + if test -n "$GCC"; then + case $host_os in + linux* | gnu* | k*bsd*-gnu) haveit=yes;; + esac + fi + fi + if test -z "$haveit"; then + haveit= + for x in $LDFLAGS $LIB[]NAME; do + AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) + if test "X$x" = "X-L$additional_libdir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + if test -d "$additional_libdir"; then + dnl Really add $additional_libdir to $LIBNAME. + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$additional_libdir" + fi + fi + haveit= + for x in $LDFLAGS $LTLIB[]NAME; do + AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) + if test "X$x" = "X-L$additional_libdir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + if test -d "$additional_libdir"; then + dnl Really add $additional_libdir to $LTLIBNAME. + LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-L$additional_libdir" + fi + fi + fi + fi + ;; + -R*) + dir=`echo "X$dep" | sed -e 's/^X-R//'` + if test "$enable_rpath" != no; then + dnl Potentially add DIR to rpathdirs. + dnl The rpathdirs will be appended to $LIBNAME at the end. + haveit= + for x in $rpathdirs; do + if test "X$x" = "X$dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + rpathdirs="$rpathdirs $dir" + fi + dnl Potentially add DIR to ltrpathdirs. + dnl The ltrpathdirs will be appended to $LTLIBNAME at the end. + haveit= + for x in $ltrpathdirs; do + if test "X$x" = "X$dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + ltrpathdirs="$ltrpathdirs $dir" + fi + fi + ;; + -l*) + dnl Handle this in the next round. + names_next_round="$names_next_round "`echo "X$dep" | sed -e 's/^X-l//'` + ;; + *.la) + dnl Handle this in the next round. Throw away the .la's + dnl directory; it is already contained in a preceding -L + dnl option. + names_next_round="$names_next_round "`echo "X$dep" | sed -e 's,^X.*/,,' -e 's,^lib,,' -e 's,\.la$,,'` + ;; + *) + dnl Most likely an immediate library name. + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$dep" + LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }$dep" + ;; + esac + done + fi + else + dnl Didn't find the library; assume it is in the system directories + dnl known to the linker and runtime loader. (All the system + dnl directories known to the linker should also be known to the + dnl runtime loader, otherwise the system is severely misconfigured.) + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-l$name" + LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-l$name" + fi + fi + fi + done + done + if test "X$rpathdirs" != "X"; then + if test -n "$hardcode_libdir_separator"; then + dnl Weird platform: only the last -rpath option counts, the user must + dnl pass all path elements in one option. We can arrange that for a + dnl single library, but not when more than one $LIBNAMEs are used. + alldirs= + for found_dir in $rpathdirs; do + alldirs="${alldirs}${alldirs:+$hardcode_libdir_separator}$found_dir" + done + dnl Note: hardcode_libdir_flag_spec uses $libdir and $wl. + acl_save_libdir="$libdir" + libdir="$alldirs" + eval flag=\"$hardcode_libdir_flag_spec\" + libdir="$acl_save_libdir" + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$flag" + else + dnl The -rpath options are cumulative. + for found_dir in $rpathdirs; do + acl_save_libdir="$libdir" + libdir="$found_dir" + eval flag=\"$hardcode_libdir_flag_spec\" + libdir="$acl_save_libdir" + LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$flag" + done + fi + fi + if test "X$ltrpathdirs" != "X"; then + dnl When using libtool, the option that works for both libraries and + dnl executables is -R. The -R options are cumulative. + for found_dir in $ltrpathdirs; do + LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-R$found_dir" + done + fi +]) + +dnl AC_LIB_APPENDTOVAR(VAR, CONTENTS) appends the elements of CONTENTS to VAR, +dnl unless already present in VAR. +dnl Works only for CPPFLAGS, not for LIB* variables because that sometimes +dnl contains two or three consecutive elements that belong together. +AC_DEFUN([AC_LIB_APPENDTOVAR], +[ + for element in [$2]; do + haveit= + for x in $[$1]; do + AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) + if test "X$x" = "X$element"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + [$1]="${[$1]}${[$1]:+ }$element" + fi + done +]) + +# lib-prefix.m4 serial 4 (gettext-0.14.2) +dnl Copyright (C) 2001-2005 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. + +dnl AC_LIB_ARG_WITH is synonymous to AC_ARG_WITH in autoconf-2.13, and +dnl similar to AC_ARG_WITH in autoconf 2.52...2.57 except that is doesn't +dnl require excessive bracketing. +ifdef([AC_HELP_STRING], +[AC_DEFUN([AC_LIB_ARG_WITH], [AC_ARG_WITH([$1],[[$2]],[$3],[$4])])], +[AC_DEFUN([AC_][LIB_ARG_WITH], [AC_ARG_WITH([$1],[$2],[$3],[$4])])]) + +dnl AC_LIB_PREFIX adds to the CPPFLAGS and LDFLAGS the flags that are needed +dnl to access previously installed libraries. The basic assumption is that +dnl a user will want packages to use other packages he previously installed +dnl with the same --prefix option. +dnl This macro is not needed if only AC_LIB_LINKFLAGS is used to locate +dnl libraries, but is otherwise very convenient. +AC_DEFUN([AC_LIB_PREFIX], +[ + AC_BEFORE([$0], [AC_LIB_LINKFLAGS]) + AC_REQUIRE([AC_PROG_CC]) + AC_REQUIRE([AC_CANONICAL_HOST]) + AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) + dnl By default, look in $includedir and $libdir. + use_additional=yes + AC_LIB_WITH_FINAL_PREFIX([ + eval additional_includedir=\"$includedir\" + eval additional_libdir=\"$libdir\" + ]) + AC_LIB_ARG_WITH([lib-prefix], +[ --with-lib-prefix[=DIR] search for libraries in DIR/include and DIR/lib + --without-lib-prefix don't search for libraries in includedir and libdir], +[ + if test "X$withval" = "Xno"; then + use_additional=no + else + if test "X$withval" = "X"; then + AC_LIB_WITH_FINAL_PREFIX([ + eval additional_includedir=\"$includedir\" + eval additional_libdir=\"$libdir\" + ]) + else + additional_includedir="$withval/include" + additional_libdir="$withval/lib" + fi + fi +]) + if test $use_additional = yes; then + dnl Potentially add $additional_includedir to $CPPFLAGS. + dnl But don't add it + dnl 1. if it's the standard /usr/include, + dnl 2. if it's already present in $CPPFLAGS, + dnl 3. if it's /usr/local/include and we are using GCC on Linux, + dnl 4. if it doesn't exist as a directory. + if test "X$additional_includedir" != "X/usr/include"; then + haveit= + for x in $CPPFLAGS; do + AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) + if test "X$x" = "X-I$additional_includedir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + if test "X$additional_includedir" = "X/usr/local/include"; then + if test -n "$GCC"; then + case $host_os in + linux* | gnu* | k*bsd*-gnu) haveit=yes;; + esac + fi + fi + if test -z "$haveit"; then + if test -d "$additional_includedir"; then + dnl Really add $additional_includedir to $CPPFLAGS. + CPPFLAGS="${CPPFLAGS}${CPPFLAGS:+ }-I$additional_includedir" + fi + fi + fi + fi + dnl Potentially add $additional_libdir to $LDFLAGS. + dnl But don't add it + dnl 1. if it's the standard /usr/lib, + dnl 2. if it's already present in $LDFLAGS, + dnl 3. if it's /usr/local/lib and we are using GCC on Linux, + dnl 4. if it doesn't exist as a directory. + if test "X$additional_libdir" != "X/usr/lib"; then + haveit= + for x in $LDFLAGS; do + AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) + if test "X$x" = "X-L$additional_libdir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + if test "X$additional_libdir" = "X/usr/local/lib"; then + if test -n "$GCC"; then + case $host_os in + linux*) haveit=yes;; + esac + fi + fi + if test -z "$haveit"; then + if test -d "$additional_libdir"; then + dnl Really add $additional_libdir to $LDFLAGS. + LDFLAGS="${LDFLAGS}${LDFLAGS:+ }-L$additional_libdir" + fi + fi + fi + fi + fi +]) + +dnl AC_LIB_PREPARE_PREFIX creates variables acl_final_prefix, +dnl acl_final_exec_prefix, containing the values to which $prefix and +dnl $exec_prefix will expand at the end of the configure script. +AC_DEFUN([AC_LIB_PREPARE_PREFIX], +[ + dnl Unfortunately, prefix and exec_prefix get only finally determined + dnl at the end of configure. + if test "X$prefix" = "XNONE"; then + acl_final_prefix="$ac_default_prefix" + else + acl_final_prefix="$prefix" + fi + if test "X$exec_prefix" = "XNONE"; then + acl_final_exec_prefix='${prefix}' + else + acl_final_exec_prefix="$exec_prefix" + fi + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + eval acl_final_exec_prefix=\"$acl_final_exec_prefix\" + prefix="$acl_save_prefix" +]) + +dnl AC_LIB_WITH_FINAL_PREFIX([statement]) evaluates statement, with the +dnl variables prefix and exec_prefix bound to the values they will have +dnl at the end of the configure script. +AC_DEFUN([AC_LIB_WITH_FINAL_PREFIX], +[ + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + $1 + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" +]) + +# libtool.m4 - Configure libtool for the host system. -*-Autoconf-*- + +# serial 47 Debian 1.5.20-2 AC_PROG_LIBTOOL + + +# AC_PROVIDE_IFELSE(MACRO-NAME, IF-PROVIDED, IF-NOT-PROVIDED) +# ----------------------------------------------------------- +# If this macro is not defined by Autoconf, define it here. +m4_ifdef([AC_PROVIDE_IFELSE], + [], + [m4_define([AC_PROVIDE_IFELSE], + [m4_ifdef([AC_PROVIDE_$1], + [$2], [$3])])]) + + +# AC_PROG_LIBTOOL +# --------------- +AC_DEFUN([AC_PROG_LIBTOOL], +[AC_REQUIRE([_AC_PROG_LIBTOOL])dnl +dnl If AC_PROG_CXX has already been expanded, run AC_LIBTOOL_CXX +dnl immediately, otherwise, hook it in at the end of AC_PROG_CXX. + AC_PROVIDE_IFELSE([AC_PROG_CXX], + [AC_LIBTOOL_CXX], + [define([AC_PROG_CXX], defn([AC_PROG_CXX])[AC_LIBTOOL_CXX + ])]) +dnl And a similar setup for Fortran 77 support + AC_PROVIDE_IFELSE([AC_PROG_F77], + [AC_LIBTOOL_F77], + [define([AC_PROG_F77], defn([AC_PROG_F77])[AC_LIBTOOL_F77 +])]) + +dnl Quote A][M_PROG_GCJ so that aclocal doesn't bring it in needlessly. +dnl If either AC_PROG_GCJ or A][M_PROG_GCJ have already been expanded, run +dnl AC_LIBTOOL_GCJ immediately, otherwise, hook it in at the end of both. + AC_PROVIDE_IFELSE([AC_PROG_GCJ], + [AC_LIBTOOL_GCJ], + [AC_PROVIDE_IFELSE([A][M_PROG_GCJ], + [AC_LIBTOOL_GCJ], + [AC_PROVIDE_IFELSE([LT_AC_PROG_GCJ], + [AC_LIBTOOL_GCJ], + [ifdef([AC_PROG_GCJ], + [define([AC_PROG_GCJ], defn([AC_PROG_GCJ])[AC_LIBTOOL_GCJ])]) + ifdef([A][M_PROG_GCJ], + [define([A][M_PROG_GCJ], defn([A][M_PROG_GCJ])[AC_LIBTOOL_GCJ])]) + ifdef([LT_AC_PROG_GCJ], + [define([LT_AC_PROG_GCJ], + defn([LT_AC_PROG_GCJ])[AC_LIBTOOL_GCJ])])])]) +])])# AC_PROG_LIBTOOL + + +# _AC_PROG_LIBTOOL +# ---------------- +AC_DEFUN([_AC_PROG_LIBTOOL], +[AC_REQUIRE([AC_LIBTOOL_SETUP])dnl +AC_BEFORE([$0],[AC_LIBTOOL_CXX])dnl +AC_BEFORE([$0],[AC_LIBTOOL_F77])dnl +AC_BEFORE([$0],[AC_LIBTOOL_GCJ])dnl + +# This can be used to rebuild libtool when needed +LIBTOOL_DEPS="$ac_aux_dir/ltmain.sh" + +# Always use our own libtool. +LIBTOOL='$(SHELL) $(top_builddir)/libtool' +AC_SUBST(LIBTOOL)dnl + +# Prevent multiple expansion +define([AC_PROG_LIBTOOL], []) +])# _AC_PROG_LIBTOOL + + +# AC_LIBTOOL_SETUP +# ---------------- +AC_DEFUN([AC_LIBTOOL_SETUP], +[AC_PREREQ(2.50)dnl +AC_REQUIRE([AC_ENABLE_SHARED])dnl +AC_REQUIRE([AC_ENABLE_STATIC])dnl +AC_REQUIRE([AC_ENABLE_FAST_INSTALL])dnl +AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_REQUIRE([AC_CANONICAL_BUILD])dnl +AC_REQUIRE([AC_PROG_CC])dnl +AC_REQUIRE([AC_PROG_LD])dnl +AC_REQUIRE([AC_PROG_LD_RELOAD_FLAG])dnl +AC_REQUIRE([AC_PROG_NM])dnl + +AC_REQUIRE([AC_PROG_LN_S])dnl +AC_REQUIRE([AC_DEPLIBS_CHECK_METHOD])dnl +# Autoconf 2.13's AC_OBJEXT and AC_EXEEXT macros only works for C compilers! +AC_REQUIRE([AC_OBJEXT])dnl +AC_REQUIRE([AC_EXEEXT])dnl +dnl + +AC_LIBTOOL_SYS_MAX_CMD_LEN +AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE +AC_LIBTOOL_OBJDIR + +AC_REQUIRE([_LT_AC_SYS_COMPILER])dnl +_LT_AC_PROG_ECHO_BACKSLASH + +case $host_os in +aix3*) + # AIX sometimes has problems with the GCC collect2 program. For some + # reason, if we set the COLLECT_NAMES environment variable, the problems + # vanish in a puff of smoke. + if test "X${COLLECT_NAMES+set}" != Xset; then + COLLECT_NAMES= + export COLLECT_NAMES + fi + ;; +esac + +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +Xsed='sed -e 1s/^X//' +[sed_quote_subst='s/\([\\"\\`$\\\\]\)/\\\1/g'] + +# Same as above, but do not quote variable references. +[double_quote_subst='s/\([\\"\\`\\\\]\)/\\\1/g'] + +# Sed substitution to delay expansion of an escaped shell variable in a +# double_quote_subst'ed string. +delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' + +# Sed substitution to avoid accidental globbing in evaled expressions +no_glob_subst='s/\*/\\\*/g' + +# Constants: +rm="rm -f" + +# Global variables: +default_ofile=libtool +can_build_shared=yes + +# All known linkers require a `.a' archive for static linking (except MSVC, +# which needs '.lib'). +libext=a +ltmain="$ac_aux_dir/ltmain.sh" +ofile="$default_ofile" +with_gnu_ld="$lt_cv_prog_gnu_ld" + +AC_CHECK_TOOL(AR, ar, false) +AC_CHECK_TOOL(RANLIB, ranlib, :) +AC_CHECK_TOOL(STRIP, strip, :) + +old_CC="$CC" +old_CFLAGS="$CFLAGS" + +# Set sane defaults for various variables +test -z "$AR" && AR=ar +test -z "$AR_FLAGS" && AR_FLAGS=cru +test -z "$AS" && AS=as +test -z "$CC" && CC=cc +test -z "$LTCC" && LTCC=$CC +test -z "$DLLTOOL" && DLLTOOL=dlltool +test -z "$LD" && LD=ld +test -z "$LN_S" && LN_S="ln -s" +test -z "$MAGIC_CMD" && MAGIC_CMD=file +test -z "$NM" && NM=nm +test -z "$SED" && SED=sed +test -z "$OBJDUMP" && OBJDUMP=objdump +test -z "$RANLIB" && RANLIB=: +test -z "$STRIP" && STRIP=: +test -z "$ac_objext" && ac_objext=o + +# Determine commands to create old-style static archives. +old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs$old_deplibs' +old_postinstall_cmds='chmod 644 $oldlib' +old_postuninstall_cmds= + +if test -n "$RANLIB"; then + case $host_os in + openbsd*) + old_postinstall_cmds="\$RANLIB -t \$oldlib~$old_postinstall_cmds" + ;; + *) + old_postinstall_cmds="\$RANLIB \$oldlib~$old_postinstall_cmds" + ;; + esac + old_archive_cmds="$old_archive_cmds~\$RANLIB \$oldlib" +fi + +_LT_CC_BASENAME([$compiler]) + +# Only perform the check for file, if the check method requires it +case $deplibs_check_method in +file_magic*) + if test "$file_magic_cmd" = '$MAGIC_CMD'; then + AC_PATH_MAGIC + fi + ;; +esac + +AC_PROVIDE_IFELSE([AC_LIBTOOL_DLOPEN], enable_dlopen=yes, enable_dlopen=no) +AC_PROVIDE_IFELSE([AC_LIBTOOL_WIN32_DLL], +enable_win32_dll=yes, enable_win32_dll=no) + +AC_ARG_ENABLE([libtool-lock], + [AC_HELP_STRING([--disable-libtool-lock], + [avoid locking (might break parallel builds)])]) +test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes + +AC_ARG_WITH([pic], + [AC_HELP_STRING([--with-pic], + [try to use only PIC/non-PIC objects @<:@default=use both@:>@])], + [pic_mode="$withval"], + [pic_mode=default]) +test -z "$pic_mode" && pic_mode=default + +# Use C for the default configuration in the libtool script +tagname= +AC_LIBTOOL_LANG_C_CONFIG +_LT_AC_TAGCONFIG +])# AC_LIBTOOL_SETUP + + +# _LT_AC_SYS_COMPILER +# ------------------- +AC_DEFUN([_LT_AC_SYS_COMPILER], +[AC_REQUIRE([AC_PROG_CC])dnl + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# Allow CC to be a program name with arguments. +compiler=$CC +])# _LT_AC_SYS_COMPILER + + +# _LT_CC_BASENAME(CC) +# ------------------- +# Calculate cc_basename. Skip known compiler wrappers and cross-prefix. +AC_DEFUN([_LT_CC_BASENAME], +[for cc_temp in $1""; do + case $cc_temp in + compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;; + distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` +]) + + +# _LT_COMPILER_BOILERPLATE +# ------------------------ +# Check for compiler boilerplate output or warnings with +# the simple compiler test code. +AC_DEFUN([_LT_COMPILER_BOILERPLATE], +[ac_outfile=conftest.$ac_objext +printf "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$rm conftest* +])# _LT_COMPILER_BOILERPLATE + + +# _LT_LINKER_BOILERPLATE +# ---------------------- +# Check for linker boilerplate output or warnings with +# the simple link test code. +AC_DEFUN([_LT_LINKER_BOILERPLATE], +[ac_outfile=conftest.$ac_objext +printf "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$rm conftest* +])# _LT_LINKER_BOILERPLATE + + +# _LT_AC_SYS_LIBPATH_AIX +# ---------------------- +# Links a minimal program and checks the executable +# for the system default hardcoded library path. In most cases, +# this is /usr/lib:/lib, but when the MPI compilers are used +# the location of the communication and MPI libs are included too. +# If we don't find anything, use the default library path according +# to the aix ld manual. +AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX], +[AC_LINK_IFELSE(AC_LANG_PROGRAM,[ +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'`; fi],[]) +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi +])# _LT_AC_SYS_LIBPATH_AIX + + +# _LT_AC_SHELL_INIT(ARG) +# ---------------------- +AC_DEFUN([_LT_AC_SHELL_INIT], +[ifdef([AC_DIVERSION_NOTICE], + [AC_DIVERT_PUSH(AC_DIVERSION_NOTICE)], + [AC_DIVERT_PUSH(NOTICE)]) +$1 +AC_DIVERT_POP +])# _LT_AC_SHELL_INIT + + +# _LT_AC_PROG_ECHO_BACKSLASH +# -------------------------- +# Add some code to the start of the generated configure script which +# will find an echo command which doesn't interpret backslashes. +AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH], +[_LT_AC_SHELL_INIT([ +# Check that we are running under the correct shell. +SHELL=${CONFIG_SHELL-/bin/sh} + +case X$ECHO in +X*--fallback-echo) + # Remove one level of quotation (which was required for Make). + ECHO=`echo "$ECHO" | sed 's,\\\\\[$]\\[$]0,'[$]0','` + ;; +esac + +echo=${ECHO-echo} +if test "X[$]1" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift +elif test "X[$]1" = X--fallback-echo; then + # Avoid inline document here, it may be left over + : +elif test "X`($echo '\t') 2>/dev/null`" = 'X\t' ; then + # Yippee, $echo works! + : +else + # Restart under the correct shell. + exec $SHELL "[$]0" --no-reexec ${1+"[$]@"} +fi + +if test "X[$]1" = X--fallback-echo; then + # used as fallback echo + shift + cat </dev/null 2>&1 && unset CDPATH + +if test -z "$ECHO"; then +if test "X${echo_test_string+set}" != Xset; then +# find a string as large as possible, as long as the shell can cope with it + for cmd in 'sed 50q "[$]0"' 'sed 20q "[$]0"' 'sed 10q "[$]0"' 'sed 2q "[$]0"' 'echo test'; do + # expected sizes: less than 2Kb, 1Kb, 512 bytes, 16 bytes, ... + if (echo_test_string=`eval $cmd`) 2>/dev/null && + echo_test_string=`eval $cmd` && + (test "X$echo_test_string" = "X$echo_test_string") 2>/dev/null + then + break + fi + done +fi + +if test "X`($echo '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`($echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + : +else + # The Solaris, AIX, and Digital Unix default echo programs unquote + # backslashes. This makes it impossible to quote backslashes using + # echo "$something" | sed 's/\\/\\\\/g' + # + # So, first we look for a working echo in the user's PATH. + + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for dir in $PATH /usr/ucb; do + IFS="$lt_save_ifs" + if (test -f $dir/echo || test -f $dir/echo$ac_exeext) && + test "X`($dir/echo '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`($dir/echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + echo="$dir/echo" + break + fi + done + IFS="$lt_save_ifs" + + if test "X$echo" = Xecho; then + # We didn't find a better echo, so look for alternatives. + if test "X`(print -r '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`(print -r "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + # This shell has a builtin print -r that does the trick. + echo='print -r' + elif (test -f /bin/ksh || test -f /bin/ksh$ac_exeext) && + test "X$CONFIG_SHELL" != X/bin/ksh; then + # If we have ksh, try running configure again with it. + ORIGINAL_CONFIG_SHELL=${CONFIG_SHELL-/bin/sh} + export ORIGINAL_CONFIG_SHELL + CONFIG_SHELL=/bin/ksh + export CONFIG_SHELL + exec $CONFIG_SHELL "[$]0" --no-reexec ${1+"[$]@"} + else + # Try using printf. + echo='printf %s\n' + if test "X`($echo '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`($echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + # Cool, printf works + : + elif echo_testing_string=`($ORIGINAL_CONFIG_SHELL "[$]0" --fallback-echo '\t') 2>/dev/null` && + test "X$echo_testing_string" = 'X\t' && + echo_testing_string=`($ORIGINAL_CONFIG_SHELL "[$]0" --fallback-echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + CONFIG_SHELL=$ORIGINAL_CONFIG_SHELL + export CONFIG_SHELL + SHELL="$CONFIG_SHELL" + export SHELL + echo="$CONFIG_SHELL [$]0 --fallback-echo" + elif echo_testing_string=`($CONFIG_SHELL "[$]0" --fallback-echo '\t') 2>/dev/null` && + test "X$echo_testing_string" = 'X\t' && + echo_testing_string=`($CONFIG_SHELL "[$]0" --fallback-echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + echo="$CONFIG_SHELL [$]0 --fallback-echo" + else + # maybe with a smaller string... + prev=: + + for cmd in 'echo test' 'sed 2q "[$]0"' 'sed 10q "[$]0"' 'sed 20q "[$]0"' 'sed 50q "[$]0"'; do + if (test "X$echo_test_string" = "X`eval $cmd`") 2>/dev/null + then + break + fi + prev="$cmd" + done + + if test "$prev" != 'sed 50q "[$]0"'; then + echo_test_string=`eval $prev` + export echo_test_string + exec ${ORIGINAL_CONFIG_SHELL-${CONFIG_SHELL-/bin/sh}} "[$]0" ${1+"[$]@"} + else + # Oops. We lost completely, so just stick with echo. + echo=echo + fi + fi + fi + fi +fi +fi + +# Copy echo and quote the copy suitably for passing to libtool from +# the Makefile, instead of quoting the original, which is used later. +ECHO=$echo +if test "X$ECHO" = "X$CONFIG_SHELL [$]0 --fallback-echo"; then + ECHO="$CONFIG_SHELL \\\$\[$]0 --fallback-echo" +fi + +AC_SUBST(ECHO) +])])# _LT_AC_PROG_ECHO_BACKSLASH + + +# _LT_AC_LOCK +# ----------- +AC_DEFUN([_LT_AC_LOCK], +[AC_ARG_ENABLE([libtool-lock], + [AC_HELP_STRING([--disable-libtool-lock], + [avoid locking (might break parallel builds)])]) +test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes + +# Some flags need to be propagated to the compiler or linker for good +# libtool support. +case $host in +ia64-*-hpux*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + case `/usr/bin/file conftest.$ac_objext` in + *ELF-32*) + HPUX_IA64_MODE="32" + ;; + *ELF-64*) + HPUX_IA64_MODE="64" + ;; + esac + fi + rm -rf conftest* + ;; +*-*-irix6*) + # Find out which ABI we are using. + echo '[#]line __oline__ "configure"' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + if test "$lt_cv_prog_gnu_ld" = yes; then + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -melf32bsmip" + ;; + *N32*) + LD="${LD-ld} -melf32bmipn32" + ;; + *64-bit*) + LD="${LD-ld} -melf64bmip" + ;; + esac + else + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -32" + ;; + *N32*) + LD="${LD-ld} -n32" + ;; + *64-bit*) + LD="${LD-ld} -64" + ;; + esac + fi + fi + rm -rf conftest* + ;; + +x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*|s390*-*linux*|sparc*-*linux*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + case `/usr/bin/file conftest.o` in + *32-bit*) + case $host in + x86_64-*linux*) + LD="${LD-ld} -m elf_i386" + ;; + ppc64-*linux*|powerpc64-*linux*) + LD="${LD-ld} -m elf32ppclinux" + ;; + s390x-*linux*) + LD="${LD-ld} -m elf_s390" + ;; + sparc64-*linux*) + LD="${LD-ld} -m elf32_sparc" + ;; + esac + ;; + *64-bit*) + case $host in + x86_64-*linux*) + LD="${LD-ld} -m elf_x86_64" + ;; + ppc*-*linux*|powerpc*-*linux*) + LD="${LD-ld} -m elf64ppc" + ;; + s390*-*linux*) + LD="${LD-ld} -m elf64_s390" + ;; + sparc*-*linux*) + LD="${LD-ld} -m elf64_sparc" + ;; + esac + ;; + esac + fi + rm -rf conftest* + ;; + +*-*-sco3.2v5*) + # On SCO OpenServer 5, we need -belf to get full-featured binaries. + SAVE_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS -belf" + AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf, + [AC_LANG_PUSH(C) + AC_TRY_LINK([],[],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no]) + AC_LANG_POP]) + if test x"$lt_cv_cc_needs_belf" != x"yes"; then + # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf + CFLAGS="$SAVE_CFLAGS" + fi + ;; +AC_PROVIDE_IFELSE([AC_LIBTOOL_WIN32_DLL], +[*-*-cygwin* | *-*-mingw* | *-*-pw32*) + AC_CHECK_TOOL(DLLTOOL, dlltool, false) + AC_CHECK_TOOL(AS, as, false) + AC_CHECK_TOOL(OBJDUMP, objdump, false) + ;; + ]) +esac + +need_locks="$enable_libtool_lock" + +])# _LT_AC_LOCK + + +# AC_LIBTOOL_COMPILER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, +# [OUTPUT-FILE], [ACTION-SUCCESS], [ACTION-FAILURE]) +# ---------------------------------------------------------------- +# Check whether the given compiler option works +AC_DEFUN([AC_LIBTOOL_COMPILER_OPTION], +[AC_REQUIRE([LT_AC_PROG_SED]) +AC_CACHE_CHECK([$1], [$2], + [$2=no + ifelse([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4]) + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$3" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&AS_MESSAGE_LOG_FD + echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $echo "X$_lt_compiler_boilerplate" | $Xsed >conftest.exp + $SED '/^$/d' conftest.err >conftest.er2 + if test ! -s conftest.err || diff conftest.exp conftest.er2 >/dev/null; then + $2=yes + fi + fi + $rm conftest* +]) + +if test x"[$]$2" = xyes; then + ifelse([$5], , :, [$5]) +else + ifelse([$6], , :, [$6]) +fi +])# AC_LIBTOOL_COMPILER_OPTION + + +# AC_LIBTOOL_LINKER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, +# [ACTION-SUCCESS], [ACTION-FAILURE]) +# ------------------------------------------------------------ +# Check whether the given compiler option works +AC_DEFUN([AC_LIBTOOL_LINKER_OPTION], +[AC_CACHE_CHECK([$1], [$2], + [$2=no + save_LDFLAGS="$LDFLAGS" + LDFLAGS="$LDFLAGS $3" + printf "$lt_simple_link_test_code" > conftest.$ac_ext + if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then + # The linker can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + # Append any errors to the config.log. + cat conftest.err 1>&AS_MESSAGE_LOG_FD + $echo "X$_lt_linker_boilerplate" | $Xsed > conftest.exp + $SED '/^$/d' conftest.err >conftest.er2 + if diff conftest.exp conftest.er2 >/dev/null; then + $2=yes + fi + else + $2=yes + fi + fi + $rm conftest* + LDFLAGS="$save_LDFLAGS" +]) + +if test x"[$]$2" = xyes; then + ifelse([$4], , :, [$4]) +else + ifelse([$5], , :, [$5]) +fi +])# AC_LIBTOOL_LINKER_OPTION + + +# AC_LIBTOOL_SYS_MAX_CMD_LEN +# -------------------------- +AC_DEFUN([AC_LIBTOOL_SYS_MAX_CMD_LEN], +[# find the maximum length of command line arguments +AC_MSG_CHECKING([the maximum length of command line arguments]) +AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl + i=0 + teststring="ABCD" + + case $build_os in + msdosdjgpp*) + # On DJGPP, this test can blow up pretty badly due to problems in libc + # (any single argument exceeding 2000 bytes causes a buffer overrun + # during glob expansion). Even if it were fixed, the result of this + # check would be larger than it should be. + lt_cv_sys_max_cmd_len=12288; # 12K is about right + ;; + + gnu*) + # Under GNU Hurd, this test is not required because there is + # no limit to the length of command line arguments. + # Libtool will interpret -1 as no limit whatsoever + lt_cv_sys_max_cmd_len=-1; + ;; + + cygwin* | mingw*) + # On Win9x/ME, this test blows up -- it succeeds, but takes + # about 5 minutes as the teststring grows exponentially. + # Worse, since 9x/ME are not pre-emptively multitasking, + # you end up with a "frozen" computer, even though with patience + # the test eventually succeeds (with a max line length of 256k). + # Instead, let's just punt: use the minimum linelength reported by + # all of the supported platforms: 8192 (on NT/2K/XP). + lt_cv_sys_max_cmd_len=8192; + ;; + + amigaos*) + # On AmigaOS with pdksh, this test takes hours, literally. + # So we just punt and use a minimum line length of 8192. + lt_cv_sys_max_cmd_len=8192; + ;; + + netbsd* | freebsd* | openbsd* | darwin* | dragonfly*) + # This has been around since 386BSD, at least. Likely further. + if test -x /sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` + elif test -x /usr/sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` + else + lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs + fi + # And add a safety zone + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` + ;; + osf*) + # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure + # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not + # nice to cause kernel panics so lets avoid the loop below. + # First set a reasonable default. + lt_cv_sys_max_cmd_len=16384 + # + if test -x /sbin/sysconfig; then + case `/sbin/sysconfig -q proc exec_disable_arg_limit` in + *1*) lt_cv_sys_max_cmd_len=-1 ;; + esac + fi + ;; + *) + # If test is not a shell built-in, we'll probably end up computing a + # maximum length that is only half of the actual maximum length, but + # we can't tell. + SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} + while (test "X"`$SHELL [$]0 --fallback-echo "X$teststring" 2>/dev/null` \ + = "XX$teststring") >/dev/null 2>&1 && + new_result=`expr "X$teststring" : ".*" 2>&1` && + lt_cv_sys_max_cmd_len=$new_result && + test $i != 17 # 1/2 MB should be enough + do + i=`expr $i + 1` + teststring=$teststring$teststring + done + teststring= + # Add a significant safety factor because C++ compilers can tack on massive + # amounts of additional arguments before passing them to the linker. + # It appears as though 1/2 is a usable value. + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` + ;; + esac +]) +if test -n $lt_cv_sys_max_cmd_len ; then + AC_MSG_RESULT($lt_cv_sys_max_cmd_len) +else + AC_MSG_RESULT(none) +fi +])# AC_LIBTOOL_SYS_MAX_CMD_LEN + + +# _LT_AC_CHECK_DLFCN +# -------------------- +AC_DEFUN([_LT_AC_CHECK_DLFCN], +[AC_CHECK_HEADERS(dlfcn.h)dnl +])# _LT_AC_CHECK_DLFCN + + +# _LT_AC_TRY_DLOPEN_SELF (ACTION-IF-TRUE, ACTION-IF-TRUE-W-USCORE, +# ACTION-IF-FALSE, ACTION-IF-CROSS-COMPILING) +# ------------------------------------------------------------------ +AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF], +[AC_REQUIRE([_LT_AC_CHECK_DLFCN])dnl +if test "$cross_compiling" = yes; then : + [$4] +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext < +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +#ifdef __cplusplus +extern "C" void exit (int); +#endif + +void fnord() { int i=42;} +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + /* dlclose (self); */ + } + + exit (status); +}] +EOF + if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext} 2>/dev/null; then + (./conftest; exit; ) >&AS_MESSAGE_LOG_FD 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) $1 ;; + x$lt_dlneed_uscore) $2 ;; + x$lt_unknown|x*) $3 ;; + esac + else : + # compilation failed + $3 + fi +fi +rm -fr conftest* +])# _LT_AC_TRY_DLOPEN_SELF + + +# AC_LIBTOOL_DLOPEN_SELF +# ------------------- +AC_DEFUN([AC_LIBTOOL_DLOPEN_SELF], +[AC_REQUIRE([_LT_AC_CHECK_DLFCN])dnl +if test "x$enable_dlopen" != xyes; then + enable_dlopen=unknown + enable_dlopen_self=unknown + enable_dlopen_self_static=unknown +else + lt_cv_dlopen=no + lt_cv_dlopen_libs= + + case $host_os in + beos*) + lt_cv_dlopen="load_add_on" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ;; + + mingw* | pw32*) + lt_cv_dlopen="LoadLibrary" + lt_cv_dlopen_libs= + ;; + + cygwin*) + lt_cv_dlopen="dlopen" + lt_cv_dlopen_libs= + ;; + + darwin*) + # if libdl is installed we need to link against it + AC_CHECK_LIB([dl], [dlopen], + [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"],[ + lt_cv_dlopen="dyld" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ]) + ;; + + *) + AC_CHECK_FUNC([shl_load], + [lt_cv_dlopen="shl_load"], + [AC_CHECK_LIB([dld], [shl_load], + [lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-dld"], + [AC_CHECK_FUNC([dlopen], + [lt_cv_dlopen="dlopen"], + [AC_CHECK_LIB([dl], [dlopen], + [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"], + [AC_CHECK_LIB([svld], [dlopen], + [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld"], + [AC_CHECK_LIB([dld], [dld_link], + [lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-dld"]) + ]) + ]) + ]) + ]) + ]) + ;; + esac + + if test "x$lt_cv_dlopen" != xno; then + enable_dlopen=yes + else + enable_dlopen=no + fi + + case $lt_cv_dlopen in + dlopen) + save_CPPFLAGS="$CPPFLAGS" + test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" + + save_LDFLAGS="$LDFLAGS" + eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" + + save_LIBS="$LIBS" + LIBS="$lt_cv_dlopen_libs $LIBS" + + AC_CACHE_CHECK([whether a program can dlopen itself], + lt_cv_dlopen_self, [dnl + _LT_AC_TRY_DLOPEN_SELF( + lt_cv_dlopen_self=yes, lt_cv_dlopen_self=yes, + lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross) + ]) + + if test "x$lt_cv_dlopen_self" = xyes; then + LDFLAGS="$LDFLAGS $link_static_flag" + AC_CACHE_CHECK([whether a statically linked program can dlopen itself], + lt_cv_dlopen_self_static, [dnl + _LT_AC_TRY_DLOPEN_SELF( + lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=yes, + lt_cv_dlopen_self_static=no, lt_cv_dlopen_self_static=cross) + ]) + fi + + CPPFLAGS="$save_CPPFLAGS" + LDFLAGS="$save_LDFLAGS" + LIBS="$save_LIBS" + ;; + esac + + case $lt_cv_dlopen_self in + yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; + *) enable_dlopen_self=unknown ;; + esac + + case $lt_cv_dlopen_self_static in + yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; + *) enable_dlopen_self_static=unknown ;; + esac +fi +])# AC_LIBTOOL_DLOPEN_SELF + + +# AC_LIBTOOL_PROG_CC_C_O([TAGNAME]) +# --------------------------------- +# Check to see if options -c and -o are simultaneously supported by compiler +AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O], +[AC_REQUIRE([_LT_AC_SYS_COMPILER])dnl +AC_CACHE_CHECK([if $compiler supports -c -o file.$ac_objext], + [_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)], + [_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)=no + $rm -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&AS_MESSAGE_LOG_FD + echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $echo "X$_lt_compiler_boilerplate" | $Xsed > out/conftest.exp + $SED '/^$/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.err || diff out/conftest.exp out/conftest.er2 >/dev/null; then + _LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes + fi + fi + chmod u+w . 2>&AS_MESSAGE_LOG_FD + $rm conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $rm out/ii_files/* && rmdir out/ii_files + $rm out/* && rmdir out + cd .. + rmdir conftest + $rm conftest* +]) +])# AC_LIBTOOL_PROG_CC_C_O + + +# AC_LIBTOOL_SYS_HARD_LINK_LOCKS([TAGNAME]) +# ----------------------------------------- +# Check to see if we can do hard links to lock some files if needed +AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], +[AC_REQUIRE([_LT_AC_LOCK])dnl + +hard_links="nottested" +if test "$_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)" = no && test "$need_locks" != no; then + # do not overwrite the value of need_locks provided by the user + AC_MSG_CHECKING([if we can lock with hard links]) + hard_links=yes + $rm conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + AC_MSG_RESULT([$hard_links]) + if test "$hard_links" = no; then + AC_MSG_WARN([`$CC' does not support `-c -o', so `make -j' may be unsafe]) + need_locks=warn + fi +else + need_locks=no +fi +])# AC_LIBTOOL_SYS_HARD_LINK_LOCKS + + +# AC_LIBTOOL_OBJDIR +# ----------------- +AC_DEFUN([AC_LIBTOOL_OBJDIR], +[AC_CACHE_CHECK([for objdir], [lt_cv_objdir], +[rm -f .libs 2>/dev/null +mkdir .libs 2>/dev/null +if test -d .libs; then + lt_cv_objdir=.libs +else + # MS-DOS does not allow filenames that begin with a dot. + lt_cv_objdir=_libs +fi +rmdir .libs 2>/dev/null]) +objdir=$lt_cv_objdir +])# AC_LIBTOOL_OBJDIR + + +# AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH([TAGNAME]) +# ---------------------------------------------- +# Check hardcoding attributes. +AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], +[AC_MSG_CHECKING([how to hardcode library paths into programs]) +_LT_AC_TAGVAR(hardcode_action, $1)= +if test -n "$_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)" || \ + test -n "$_LT_AC_TAGVAR(runpath_var, $1)" || \ + test "X$_LT_AC_TAGVAR(hardcode_automatic, $1)" = "Xyes" ; then + + # We can hardcode non-existant directories. + if test "$_LT_AC_TAGVAR(hardcode_direct, $1)" != no && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, $1)" != no && + test "$_LT_AC_TAGVAR(hardcode_minus_L, $1)" != no; then + # Linking always hardcodes the temporary library directory. + _LT_AC_TAGVAR(hardcode_action, $1)=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + _LT_AC_TAGVAR(hardcode_action, $1)=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + _LT_AC_TAGVAR(hardcode_action, $1)=unsupported +fi +AC_MSG_RESULT([$_LT_AC_TAGVAR(hardcode_action, $1)]) + +if test "$_LT_AC_TAGVAR(hardcode_action, $1)" = relink; then + # Fast installation is not supported + enable_fast_install=no +elif test "$shlibpath_overrides_runpath" = yes || + test "$enable_shared" = no; then + # Fast installation is not necessary + enable_fast_install=needless +fi +])# AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH + + +# AC_LIBTOOL_SYS_LIB_STRIP +# ------------------------ +AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP], +[striplib= +old_striplib= +AC_MSG_CHECKING([whether stripping libraries is possible]) +if test -n "$STRIP" && $STRIP -V 2>&1 | grep "GNU strip" >/dev/null; then + test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" + test -z "$striplib" && striplib="$STRIP --strip-unneeded" + AC_MSG_RESULT([yes]) +else +# FIXME - insert some real tests, host_os isn't really good enough + case $host_os in + darwin*) + if test -n "$STRIP" ; then + striplib="$STRIP -x" + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no]) +fi + ;; + *) + AC_MSG_RESULT([no]) + ;; + esac +fi +])# AC_LIBTOOL_SYS_LIB_STRIP + + +# AC_LIBTOOL_SYS_DYNAMIC_LINKER +# ----------------------------- +# PORTME Fill in your ld.so characteristics +AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER], +[AC_MSG_CHECKING([dynamic linker characteristics]) +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext_cmds=".so" +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +if test "$GCC" = yes; then + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if echo "$sys_lib_search_path_spec" | grep ';' >/dev/null ; then + # if the path contains ";" then we assume it to be the separator + # otherwise default to the standard path separator (i.e. ":") - it is + # assumed that no part of a normal pathname contains ";" but that should + # okay in the real world where ";" in dirpaths is itself problematic. + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi +else + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +fi +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + +case $host_os in +aix3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='${libname}${release}${shared_ext}$major' + ;; + +aix4* | aix5*) + version_type=linux + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test "$host_cpu" = ia64; then + # AIX 5 supports IA64 + library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line `#! .'. This would cause the generated library to + # depend on `.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[[01]] | aix4.[[01]].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | ${CC} -E - | grep yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # AIX (on Power*) has no versioning support, so currently we can not hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + if test "$aix_use_runtimelinking" = yes; then + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + else + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='${libname}${release}.a $libname.a' + soname_spec='${libname}${release}${shared_ext}$major' + fi + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$echo "X$lib" | $Xsed -e '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; test $rm /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' + ;; + +beos*) + library_names_spec='${libname}${shared_ext}' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi[[45]]*) + version_type=linux + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32*) + version_type=windows + shrext_cmds=".dll" + need_version=no + need_lib_prefix=no + + case $GCC,$host_os in + yes,cygwin* | yes,mingw* | yes,pw32*) + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \${file}`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $rm \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" + ;; + mingw*) + # MinGW DLLs use traditional 'lib' prefix + soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if echo "$sys_lib_search_path_spec" | [grep ';[c-zC-Z]:/' >/dev/null]; then + # It is most probably a Windows format PATH printed by + # mingw gcc, but we are running on Cygwin. Gcc prints its search + # path with ; separators, and with drive letters. We can handle the + # drive letters (cygwin fileutils understands them), so leave them, + # especially as we might pass files found there to a mingw objdump, + # which wouldn't understand a cygwinified path. Ahh. + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + ;; + esac + ;; + + *) + library_names_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext} $libname.lib' + ;; + esac + dynamic_linker='Win32 ld.exe' + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext' + soname_spec='${libname}${release}${major}$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' + # Apple's gcc prints 'gcc -print-search-dirs' doesn't operate the same. + if test "$GCC" = yes; then + sys_lib_search_path_spec=`$CC -print-search-dirs | tr "\n" "$PATH_SEPARATOR" | sed -e 's/libraries:/@libraries:/' | tr "@" "\n" | grep "^libraries:" | sed -e "s/^libraries://" -e "s,=/,/,g" -e "s,$PATH_SEPARATOR, ,g" -e "s,.*,& /lib /usr/lib /usr/local/lib,g"` + else + sys_lib_search_path_spec='/lib /usr/lib /usr/local/lib' + fi + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd1*) + dynamic_linker=no + ;; + +kfreebsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='GNU ld.so' + ;; + +freebsd* | dragonfly*) + # DragonFly does not have aout. When/if they implement a new + # versioning mechanism, adjust this. + if test -x /usr/bin/objformat; then + objformat=`/usr/bin/objformat` + else + case $host_os in + freebsd[[123]]*) objformat=aout ;; + *) objformat=elf ;; + esac + fi + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[[01]]* | freebsdelf3.[[01]]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + *) # from 3.2 on + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + esac + ;; + +gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case $host_cpu in + ia64*) + shrext_cmds='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + if test "X$HPUX_IA64_MODE" = X32; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + fi + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + hppa*64*) + shrext_cmds='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext_cmds='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555. + postinstall_cmds='chmod 555 $lib' + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test "$lt_cv_prog_gnu_ld" = yes; then + version_type=linux + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" + sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +# This must be Linux ELF. +linux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # Append ld.so.conf contents to the search path + if test -f /etc/ld.so.conf; then + lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;/^$/d' | tr '\n' ' '` + sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" + fi + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsdelf*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='NetBSD ld.elf_so' + ;; + +knetbsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='GNU ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +nto-qnx*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +openbsd*) + version_type=sunos + need_lib_prefix=no + # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. + case $host_os in + openbsd3.3 | openbsd3.3.*) need_version=yes ;; + *) need_version=no ;; + esac + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + case $host_os in + openbsd2.[[89]] | openbsd2.[[89]].*) + shlibpath_overrides_runpath=no + ;; + *) + shlibpath_overrides_runpath=yes + ;; + esac + else + shlibpath_overrides_runpath=yes + fi + ;; + +os2*) + libname_spec='$name' + shrext_cmds=".dll" + need_lib_prefix=no + library_names_spec='$libname${shared_ext} $libname.a' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=LIBPATH + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" + ;; + +sco3.2v5*) + version_type=osf + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + ;; + +solaris*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test "$with_gnu_ld" = yes; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + export_dynamic_flag_spec='${wl}-Blargedynsym' + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec ;then + version_type=linux + library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' + soname_spec='$libname${shared_ext}.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +uts4*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +AC_MSG_RESULT([$dynamic_linker]) +test "$dynamic_linker" = no && can_build_shared=no +])# AC_LIBTOOL_SYS_DYNAMIC_LINKER + + +# _LT_AC_TAGCONFIG +# ---------------- +AC_DEFUN([_LT_AC_TAGCONFIG], +[AC_ARG_WITH([tags], + [AC_HELP_STRING([--with-tags@<:@=TAGS@:>@], + [include additional configurations @<:@automatic@:>@])], + [tagnames="$withval"]) + +if test -f "$ltmain" && test -n "$tagnames"; then + if test ! -f "${ofile}"; then + AC_MSG_WARN([output file `$ofile' does not exist]) + fi + + if test -z "$LTCC"; then + eval "`$SHELL ${ofile} --config | grep '^LTCC='`" + if test -z "$LTCC"; then + AC_MSG_WARN([output file `$ofile' does not look like a libtool script]) + else + AC_MSG_WARN([using `LTCC=$LTCC', extracted from `$ofile']) + fi + fi + + # Extract list of available tagged configurations in $ofile. + # Note that this assumes the entire list is on one line. + available_tags=`grep "^available_tags=" "${ofile}" | $SED -e 's/available_tags=\(.*$\)/\1/' -e 's/\"//g'` + + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for tagname in $tagnames; do + IFS="$lt_save_ifs" + # Check whether tagname contains only valid characters + case `$echo "X$tagname" | $Xsed -e 's:[[-_ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890,/]]::g'` in + "") ;; + *) AC_MSG_ERROR([invalid tag name: $tagname]) + ;; + esac + + if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$" < "${ofile}" > /dev/null + then + AC_MSG_ERROR([tag name \"$tagname\" already exists]) + fi + + # Update the list of available tags. + if test -n "$tagname"; then + echo appending configuration tag \"$tagname\" to $ofile + + case $tagname in + CXX) + if test -n "$CXX" && ( test "X$CXX" != "Xno" && + ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || + (test "X$CXX" != "Xg++"))) ; then + AC_LIBTOOL_LANG_CXX_CONFIG + else + tagname="" + fi + ;; + + F77) + if test -n "$F77" && test "X$F77" != "Xno"; then + AC_LIBTOOL_LANG_F77_CONFIG + else + tagname="" + fi + ;; + + GCJ) + if test -n "$GCJ" && test "X$GCJ" != "Xno"; then + AC_LIBTOOL_LANG_GCJ_CONFIG + else + tagname="" + fi + ;; + + RC) + AC_LIBTOOL_LANG_RC_CONFIG + ;; + + *) + AC_MSG_ERROR([Unsupported tag name: $tagname]) + ;; + esac + + # Append the new tag name to the list of available tags. + if test -n "$tagname" ; then + available_tags="$available_tags $tagname" + fi + fi + done + IFS="$lt_save_ifs" + + # Now substitute the updated list of available tags. + if eval "sed -e 's/^available_tags=.*\$/available_tags=\"$available_tags\"/' \"$ofile\" > \"${ofile}T\""; then + mv "${ofile}T" "$ofile" + chmod +x "$ofile" + else + rm -f "${ofile}T" + AC_MSG_ERROR([unable to update list of available tagged configurations.]) + fi +fi +])# _LT_AC_TAGCONFIG + + +# AC_LIBTOOL_DLOPEN +# ----------------- +# enable checks for dlopen support +AC_DEFUN([AC_LIBTOOL_DLOPEN], + [AC_BEFORE([$0],[AC_LIBTOOL_SETUP]) +])# AC_LIBTOOL_DLOPEN + + +# AC_LIBTOOL_WIN32_DLL +# -------------------- +# declare package support for building win32 DLLs +AC_DEFUN([AC_LIBTOOL_WIN32_DLL], +[AC_BEFORE([$0], [AC_LIBTOOL_SETUP]) +])# AC_LIBTOOL_WIN32_DLL + + +# AC_ENABLE_SHARED([DEFAULT]) +# --------------------------- +# implement the --enable-shared flag +# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. +AC_DEFUN([AC_ENABLE_SHARED], +[define([AC_ENABLE_SHARED_DEFAULT], ifelse($1, no, no, yes))dnl +AC_ARG_ENABLE([shared], + [AC_HELP_STRING([--enable-shared@<:@=PKGS@:>@], + [build shared libraries @<:@default=]AC_ENABLE_SHARED_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_shared=yes ;; + no) enable_shared=no ;; + *) + enable_shared=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_shared=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac], + [enable_shared=]AC_ENABLE_SHARED_DEFAULT) +])# AC_ENABLE_SHARED + + +# AC_DISABLE_SHARED +# ----------------- +#- set the default shared flag to --disable-shared +AC_DEFUN([AC_DISABLE_SHARED], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl +AC_ENABLE_SHARED(no) +])# AC_DISABLE_SHARED + + +# AC_ENABLE_STATIC([DEFAULT]) +# --------------------------- +# implement the --enable-static flag +# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. +AC_DEFUN([AC_ENABLE_STATIC], +[define([AC_ENABLE_STATIC_DEFAULT], ifelse($1, no, no, yes))dnl +AC_ARG_ENABLE([static], + [AC_HELP_STRING([--enable-static@<:@=PKGS@:>@], + [build static libraries @<:@default=]AC_ENABLE_STATIC_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_static=yes ;; + no) enable_static=no ;; + *) + enable_static=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_static=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac], + [enable_static=]AC_ENABLE_STATIC_DEFAULT) +])# AC_ENABLE_STATIC + + +# AC_DISABLE_STATIC +# ----------------- +# set the default static flag to --disable-static +AC_DEFUN([AC_DISABLE_STATIC], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl +AC_ENABLE_STATIC(no) +])# AC_DISABLE_STATIC + + +# AC_ENABLE_FAST_INSTALL([DEFAULT]) +# --------------------------------- +# implement the --enable-fast-install flag +# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. +AC_DEFUN([AC_ENABLE_FAST_INSTALL], +[define([AC_ENABLE_FAST_INSTALL_DEFAULT], ifelse($1, no, no, yes))dnl +AC_ARG_ENABLE([fast-install], + [AC_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@], + [optimize for fast installation @<:@default=]AC_ENABLE_FAST_INSTALL_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_fast_install=yes ;; + no) enable_fast_install=no ;; + *) + enable_fast_install=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_fast_install=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac], + [enable_fast_install=]AC_ENABLE_FAST_INSTALL_DEFAULT) +])# AC_ENABLE_FAST_INSTALL + + +# AC_DISABLE_FAST_INSTALL +# ----------------------- +# set the default to --disable-fast-install +AC_DEFUN([AC_DISABLE_FAST_INSTALL], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl +AC_ENABLE_FAST_INSTALL(no) +])# AC_DISABLE_FAST_INSTALL + + +# AC_LIBTOOL_PICMODE([MODE]) +# -------------------------- +# implement the --with-pic flag +# MODE is either `yes' or `no'. If omitted, it defaults to `both'. +AC_DEFUN([AC_LIBTOOL_PICMODE], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl +pic_mode=ifelse($#,1,$1,default) +])# AC_LIBTOOL_PICMODE + + +# AC_PROG_EGREP +# ------------- +# This is predefined starting with Autoconf 2.54, so this conditional +# definition can be removed once we require Autoconf 2.54 or later. +m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP], +[AC_CACHE_CHECK([for egrep], [ac_cv_prog_egrep], + [if echo a | (grep -E '(a|b)') >/dev/null 2>&1 + then ac_cv_prog_egrep='grep -E' + else ac_cv_prog_egrep='egrep' + fi]) + EGREP=$ac_cv_prog_egrep + AC_SUBST([EGREP]) +])]) + + +# AC_PATH_TOOL_PREFIX +# ------------------- +# find a file program which can recognise shared library +AC_DEFUN([AC_PATH_TOOL_PREFIX], +[AC_REQUIRE([AC_PROG_EGREP])dnl +AC_MSG_CHECKING([for $1]) +AC_CACHE_VAL(lt_cv_path_MAGIC_CMD, +[case $MAGIC_CMD in +[[\\/*] | ?:[\\/]*]) + lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. + ;; +*) + lt_save_MAGIC_CMD="$MAGIC_CMD" + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR +dnl $ac_dummy forces splitting on constant user-supplied paths. +dnl POSIX.2 word splitting is done only on the output of word expansions, +dnl not every word. This closes a longstanding sh security hole. + ac_dummy="ifelse([$2], , $PATH, [$2])" + for ac_dir in $ac_dummy; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/$1; then + lt_cv_path_MAGIC_CMD="$ac_dir/$1" + if test -n "$file_magic_test_file"; then + case $deplibs_check_method in + "file_magic "*) + file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` + MAGIC_CMD="$lt_cv_path_MAGIC_CMD" + if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | + $EGREP "$file_magic_regex" > /dev/null; then + : + else + cat <&2 + +*** Warning: the command libtool uses to detect shared libraries, +*** $file_magic_cmd, produces output that libtool cannot recognize. +*** The result is that libtool may fail to recognize shared libraries +*** as such. This will affect the creation of libtool libraries that +*** depend on shared libraries, but programs linked with such libtool +*** libraries will work regardless of this problem. Nevertheless, you +*** may want to report the problem to your system manager and/or to +*** bug-libtool@gnu.org + +EOF + fi ;; + esac + fi + break + fi + done + IFS="$lt_save_ifs" + MAGIC_CMD="$lt_save_MAGIC_CMD" + ;; +esac]) +MAGIC_CMD="$lt_cv_path_MAGIC_CMD" +if test -n "$MAGIC_CMD"; then + AC_MSG_RESULT($MAGIC_CMD) +else + AC_MSG_RESULT(no) +fi +])# AC_PATH_TOOL_PREFIX + + +# AC_PATH_MAGIC +# ------------- +# find a file program which can recognise a shared library +AC_DEFUN([AC_PATH_MAGIC], +[AC_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH) +if test -z "$lt_cv_path_MAGIC_CMD"; then + if test -n "$ac_tool_prefix"; then + AC_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH) + else + MAGIC_CMD=: + fi +fi +])# AC_PATH_MAGIC + + +# AC_PROG_LD +# ---------- +# find the pathname to the GNU or non-GNU linker +AC_DEFUN([AC_PROG_LD], +[AC_ARG_WITH([gnu-ld], + [AC_HELP_STRING([--with-gnu-ld], + [assume the C compiler uses GNU ld @<:@default=no@:>@])], + [test "$withval" = no || with_gnu_ld=yes], + [with_gnu_ld=no]) +AC_REQUIRE([LT_AC_PROG_SED])dnl +AC_REQUIRE([AC_PROG_CC])dnl +AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_REQUIRE([AC_CANONICAL_BUILD])dnl +ac_prog=ld +if test "$GCC" = yes; then + # Check if gcc -print-prog-name=ld gives a path. + AC_MSG_CHECKING([for ld used by $CC]) + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [[\\/]]* | ?:[[\\/]]*) + re_direlt='/[[^/]][[^/]]*/\.\./' + # Canonicalize the pathname of ld + ac_prog=`echo $ac_prog| $SED 's%\\\\%/%g'` + while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do + ac_prog=`echo $ac_prog| $SED "s%$re_direlt%/%"` + done + test -z "$LD" && LD="$ac_prog" + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test "$with_gnu_ld" = yes; then + AC_MSG_CHECKING([for GNU ld]) +else + AC_MSG_CHECKING([for non-GNU ld]) +fi +AC_CACHE_VAL(lt_cv_path_LD, +[if test -z "$LD"; then + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + lt_cv_path_LD="$ac_dir/$ac_prog" + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some variants of GNU ld only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$lt_cv_path_LD" -v 2>&1 &1 /dev/null; then + case $host_cpu in + i*86 ) + # Not sure whether the presence of OpenBSD here was a mistake. + # Let's accept both of them until this is cleared up. + lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[[3-9]]86 (compact )?demand paged shared library' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` + ;; + esac + else + lt_cv_deplibs_check_method=pass_all + fi + ;; + +gnu*) + lt_cv_deplibs_check_method=pass_all + ;; + +hpux10.20* | hpux11*) + lt_cv_file_magic_cmd=/usr/bin/file + case $host_cpu in + ia64*) + lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|ELF-[[0-9]][[0-9]]) shared object file - IA64' + lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so + ;; + hppa*64*) + [lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - PA-RISC [0-9].[0-9]'] + lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl + ;; + *) + lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|PA-RISC[[0-9]].[[0-9]]) shared library' + lt_cv_file_magic_test_file=/usr/lib/libc.sl + ;; + esac + ;; + +irix5* | irix6* | nonstopux*) + case $LD in + *-32|*"-32 ") libmagic=32-bit;; + *-n32|*"-n32 ") libmagic=N32;; + *-64|*"-64 ") libmagic=64-bit;; + *) libmagic=never-match;; + esac + lt_cv_deplibs_check_method=pass_all + ;; + +# This must be Linux ELF. +linux*) + lt_cv_deplibs_check_method=pass_all + ;; + +netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|_pic\.a)$' + fi + ;; + +newos6*) + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (executable|dynamic lib)' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=/usr/lib/libnls.so + ;; + +nto-qnx*) + lt_cv_deplibs_check_method=unknown + ;; + +openbsd*) + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|\.so|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' + fi + ;; + +osf3* | osf4* | osf5*) + lt_cv_deplibs_check_method=pass_all + ;; + +sco3.2v5*) + lt_cv_deplibs_check_method=pass_all + ;; + +solaris*) + lt_cv_deplibs_check_method=pass_all + ;; + +sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + case $host_vendor in + motorola) + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib) M[[0-9]][[0-9]]* Version [[0-9]]' + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` + ;; + ncr) + lt_cv_deplibs_check_method=pass_all + ;; + sequent) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )' + ;; + sni) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method="file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB dynamic lib" + lt_cv_file_magic_test_file=/lib/libc.so + ;; + siemens) + lt_cv_deplibs_check_method=pass_all + ;; + esac + ;; + +sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[[78]]* | unixware7* | sysv4*uw2*) + lt_cv_deplibs_check_method=pass_all + ;; +esac +]) +file_magic_cmd=$lt_cv_file_magic_cmd +deplibs_check_method=$lt_cv_deplibs_check_method +test -z "$deplibs_check_method" && deplibs_check_method=unknown +])# AC_DEPLIBS_CHECK_METHOD + + +# AC_PROG_NM +# ---------- +# find the pathname to a BSD-compatible name lister +AC_DEFUN([AC_PROG_NM], +[AC_CACHE_CHECK([for BSD-compatible nm], lt_cv_path_NM, +[if test -n "$NM"; then + # Let the user override the test. + lt_cv_path_NM="$NM" +else + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH /usr/ccs/bin /usr/ucb /bin; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + tmp_nm="$ac_dir/${ac_tool_prefix}nm" + if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then + # Check to see if the nm accepts a BSD-compat flag. + # Adding the `sed 1q' prevents false positives on HP-UX, which says: + # nm: unknown option "B" ignored + # Tru64's nm complains that /dev/null is an invalid object file + case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in + */dev/null* | *'Invalid file or object type'*) + lt_cv_path_NM="$tmp_nm -B" + break + ;; + *) + case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in + */dev/null*) + lt_cv_path_NM="$tmp_nm -p" + break + ;; + *) + lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but + continue # so that we can try to find one that supports BSD flags + ;; + esac + esac + fi + done + IFS="$lt_save_ifs" + test -z "$lt_cv_path_NM" && lt_cv_path_NM=nm +fi]) +NM="$lt_cv_path_NM" +])# AC_PROG_NM + + +# AC_CHECK_LIBM +# ------------- +# check for math library +AC_DEFUN([AC_CHECK_LIBM], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +LIBM= +case $host in +*-*-beos* | *-*-cygwin* | *-*-pw32* | *-*-darwin*) + # These system don't have libm, or don't need it + ;; +*-ncr-sysv4.3*) + AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM="-lmw") + AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm") + ;; +*) + AC_CHECK_LIB(m, cos, LIBM="-lm") + ;; +esac +])# AC_CHECK_LIBM + + +# AC_LIBLTDL_CONVENIENCE([DIRECTORY]) +# ----------------------------------- +# sets LIBLTDL to the link flags for the libltdl convenience library and +# LTDLINCL to the include flags for the libltdl header and adds +# --enable-ltdl-convenience to the configure arguments. Note that +# AC_CONFIG_SUBDIRS is not called here. If DIRECTORY is not provided, +# it is assumed to be `libltdl'. LIBLTDL will be prefixed with +# '${top_builddir}/' and LTDLINCL will be prefixed with '${top_srcdir}/' +# (note the single quotes!). If your package is not flat and you're not +# using automake, define top_builddir and top_srcdir appropriately in +# the Makefiles. +AC_DEFUN([AC_LIBLTDL_CONVENIENCE], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl + case $enable_ltdl_convenience in + no) AC_MSG_ERROR([this package needs a convenience libltdl]) ;; + "") enable_ltdl_convenience=yes + ac_configure_args="$ac_configure_args --enable-ltdl-convenience" ;; + esac + LIBLTDL='${top_builddir}/'ifelse($#,1,[$1],['libltdl'])/libltdlc.la + LTDLINCL='-I${top_srcdir}/'ifelse($#,1,[$1],['libltdl']) + # For backwards non-gettext consistent compatibility... + INCLTDL="$LTDLINCL" +])# AC_LIBLTDL_CONVENIENCE + + +# AC_LIBLTDL_INSTALLABLE([DIRECTORY]) +# ----------------------------------- +# sets LIBLTDL to the link flags for the libltdl installable library and +# LTDLINCL to the include flags for the libltdl header and adds +# --enable-ltdl-install to the configure arguments. Note that +# AC_CONFIG_SUBDIRS is not called here. If DIRECTORY is not provided, +# and an installed libltdl is not found, it is assumed to be `libltdl'. +# LIBLTDL will be prefixed with '${top_builddir}/'# and LTDLINCL with +# '${top_srcdir}/' (note the single quotes!). If your package is not +# flat and you're not using automake, define top_builddir and top_srcdir +# appropriately in the Makefiles. +# In the future, this macro may have to be called after AC_PROG_LIBTOOL. +AC_DEFUN([AC_LIBLTDL_INSTALLABLE], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl + AC_CHECK_LIB(ltdl, lt_dlinit, + [test x"$enable_ltdl_install" != xyes && enable_ltdl_install=no], + [if test x"$enable_ltdl_install" = xno; then + AC_MSG_WARN([libltdl not installed, but installation disabled]) + else + enable_ltdl_install=yes + fi + ]) + if test x"$enable_ltdl_install" = x"yes"; then + ac_configure_args="$ac_configure_args --enable-ltdl-install" + LIBLTDL='${top_builddir}/'ifelse($#,1,[$1],['libltdl'])/libltdl.la + LTDLINCL='-I${top_srcdir}/'ifelse($#,1,[$1],['libltdl']) + else + ac_configure_args="$ac_configure_args --enable-ltdl-install=no" + LIBLTDL="-lltdl" + LTDLINCL= + fi + # For backwards non-gettext consistent compatibility... + INCLTDL="$LTDLINCL" +])# AC_LIBLTDL_INSTALLABLE + + +# AC_LIBTOOL_CXX +# -------------- +# enable support for C++ libraries +AC_DEFUN([AC_LIBTOOL_CXX], +[AC_REQUIRE([_LT_AC_LANG_CXX]) +])# AC_LIBTOOL_CXX + + +# _LT_AC_LANG_CXX +# --------------- +AC_DEFUN([_LT_AC_LANG_CXX], +[AC_REQUIRE([AC_PROG_CXX]) +AC_REQUIRE([_LT_AC_PROG_CXXCPP]) +_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}CXX]) +])# _LT_AC_LANG_CXX + +# _LT_AC_PROG_CXXCPP +# --------------- +AC_DEFUN([_LT_AC_PROG_CXXCPP], +[ +AC_REQUIRE([AC_PROG_CXX]) +if test -n "$CXX" && ( test "X$CXX" != "Xno" && + ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || + (test "X$CXX" != "Xg++"))) ; then + AC_PROG_CXXCPP +fi +])# _LT_AC_PROG_CXXCPP + +# AC_LIBTOOL_F77 +# -------------- +# enable support for Fortran 77 libraries +AC_DEFUN([AC_LIBTOOL_F77], +[AC_REQUIRE([_LT_AC_LANG_F77]) +])# AC_LIBTOOL_F77 + + +# _LT_AC_LANG_F77 +# --------------- +AC_DEFUN([_LT_AC_LANG_F77], +[AC_REQUIRE([AC_PROG_F77]) +_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}F77]) +])# _LT_AC_LANG_F77 + + +# AC_LIBTOOL_GCJ +# -------------- +# enable support for GCJ libraries +AC_DEFUN([AC_LIBTOOL_GCJ], +[AC_REQUIRE([_LT_AC_LANG_GCJ]) +])# AC_LIBTOOL_GCJ + + +# _LT_AC_LANG_GCJ +# --------------- +AC_DEFUN([_LT_AC_LANG_GCJ], +[AC_PROVIDE_IFELSE([AC_PROG_GCJ],[], + [AC_PROVIDE_IFELSE([A][M_PROG_GCJ],[], + [AC_PROVIDE_IFELSE([LT_AC_PROG_GCJ],[], + [ifdef([AC_PROG_GCJ],[AC_REQUIRE([AC_PROG_GCJ])], + [ifdef([A][M_PROG_GCJ],[AC_REQUIRE([A][M_PROG_GCJ])], + [AC_REQUIRE([A][C_PROG_GCJ_OR_A][M_PROG_GCJ])])])])])]) +_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}GCJ]) +])# _LT_AC_LANG_GCJ + + +# AC_LIBTOOL_RC +# -------------- +# enable support for Windows resource files +AC_DEFUN([AC_LIBTOOL_RC], +[AC_REQUIRE([LT_AC_PROG_RC]) +_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}RC]) +])# AC_LIBTOOL_RC + + +# AC_LIBTOOL_LANG_C_CONFIG +# ------------------------ +# Ensure that the configuration vars for the C compiler are +# suitably defined. Those variables are subsequently used by +# AC_LIBTOOL_CONFIG to write the compiler configuration to `libtool'. +AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG], [_LT_AC_LANG_C_CONFIG]) +AC_DEFUN([_LT_AC_LANG_C_CONFIG], +[lt_save_CC="$CC" +AC_LANG_PUSH(C) + +# Source file extension for C test sources. +ac_ext=c + +# Object file extension for compiled C test sources. +objext=o +_LT_AC_TAGVAR(objext, $1)=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="int some_variable = 0;\n" + +# Code to be used in simple link tests +lt_simple_link_test_code='int main(){return(0);}\n' + +_LT_AC_SYS_COMPILER + +# save warnings/boilerplate of simple test code +_LT_COMPILER_BOILERPLATE +_LT_LINKER_BOILERPLATE + +# +# Check for any special shared library compilation flags. +# +_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)= +if test "$GCC" = no; then + case $host_os in + sco3.2v5*) + _LT_AC_TAGVAR(lt_prog_cc_shlib, $1)='-belf' + ;; + esac +fi +if test -n "$_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)"; then + AC_MSG_WARN([`$CC' requires `$_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)' to build shared libraries]) + if echo "$old_CC $old_CFLAGS " | grep "[[ ]]$_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)[[ ]]" >/dev/null; then : + else + AC_MSG_WARN([add `$_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)' to the CC or CFLAGS env variable and reconfigure]) + _LT_AC_TAGVAR(lt_cv_prog_cc_can_build_shared, $1)=no + fi +fi + + +# +# Check to make sure the static flag actually works. +# +AC_LIBTOOL_LINKER_OPTION([if $compiler static flag $_LT_AC_TAGVAR(lt_prog_compiler_static, $1) works], + _LT_AC_TAGVAR(lt_prog_compiler_static_works, $1), + $_LT_AC_TAGVAR(lt_prog_compiler_static, $1), + [], + [_LT_AC_TAGVAR(lt_prog_compiler_static, $1)=]) + + +AC_LIBTOOL_PROG_COMPILER_NO_RTTI($1) +AC_LIBTOOL_PROG_COMPILER_PIC($1) +AC_LIBTOOL_PROG_CC_C_O($1) +AC_LIBTOOL_SYS_HARD_LINK_LOCKS($1) +AC_LIBTOOL_PROG_LD_SHLIBS($1) +AC_LIBTOOL_SYS_DYNAMIC_LINKER($1) +AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH($1) +AC_LIBTOOL_SYS_LIB_STRIP +AC_LIBTOOL_DLOPEN_SELF($1) + +# Report which librarie types wil actually be built +AC_MSG_CHECKING([if libtool supports shared libraries]) +AC_MSG_RESULT([$can_build_shared]) + +AC_MSG_CHECKING([whether to build shared libraries]) +test "$can_build_shared" = "no" && enable_shared=no + +# On AIX, shared libraries and static libraries use the same namespace, and +# are all built from PIC. +case $host_os in +aix3*) + test "$enable_shared" = yes && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + +aix4* | aix5*) + if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then + test "$enable_shared" = yes && enable_static=no + fi + ;; +esac +AC_MSG_RESULT([$enable_shared]) + +AC_MSG_CHECKING([whether to build static libraries]) +# Make sure either enable_shared or enable_static is yes. +test "$enable_shared" = yes || enable_static=yes +AC_MSG_RESULT([$enable_static]) + +AC_LIBTOOL_CONFIG($1) + +AC_LANG_POP +CC="$lt_save_CC" +])# AC_LIBTOOL_LANG_C_CONFIG + + +# AC_LIBTOOL_LANG_CXX_CONFIG +# -------------------------- +# Ensure that the configuration vars for the C compiler are +# suitably defined. Those variables are subsequently used by +# AC_LIBTOOL_CONFIG to write the compiler configuration to `libtool'. +AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG], [_LT_AC_LANG_CXX_CONFIG(CXX)]) +AC_DEFUN([_LT_AC_LANG_CXX_CONFIG], +[AC_LANG_PUSH(C++) +AC_REQUIRE([AC_PROG_CXX]) +AC_REQUIRE([_LT_AC_PROG_CXXCPP]) + +_LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no +_LT_AC_TAGVAR(allow_undefined_flag, $1)= +_LT_AC_TAGVAR(always_export_symbols, $1)=no +_LT_AC_TAGVAR(archive_expsym_cmds, $1)= +_LT_AC_TAGVAR(export_dynamic_flag_spec, $1)= +_LT_AC_TAGVAR(hardcode_direct, $1)=no +_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)= +_LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)= +_LT_AC_TAGVAR(hardcode_libdir_separator, $1)= +_LT_AC_TAGVAR(hardcode_minus_L, $1)=no +_LT_AC_TAGVAR(hardcode_automatic, $1)=no +_LT_AC_TAGVAR(module_cmds, $1)= +_LT_AC_TAGVAR(module_expsym_cmds, $1)= +_LT_AC_TAGVAR(link_all_deplibs, $1)=unknown +_LT_AC_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds +_LT_AC_TAGVAR(no_undefined_flag, $1)= +_LT_AC_TAGVAR(whole_archive_flag_spec, $1)= +_LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=no + +# Dependencies to place before and after the object being linked: +_LT_AC_TAGVAR(predep_objects, $1)= +_LT_AC_TAGVAR(postdep_objects, $1)= +_LT_AC_TAGVAR(predeps, $1)= +_LT_AC_TAGVAR(postdeps, $1)= +_LT_AC_TAGVAR(compiler_lib_search_path, $1)= + +# Source file extension for C++ test sources. +ac_ext=cpp + +# Object file extension for compiled C++ test sources. +objext=o +_LT_AC_TAGVAR(objext, $1)=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="int some_variable = 0;\n" + +# Code to be used in simple link tests +lt_simple_link_test_code='int main(int, char *[]) { return(0); }\n' + +# ltmain only uses $CC for tagged configurations so make sure $CC is set. +_LT_AC_SYS_COMPILER + +# save warnings/boilerplate of simple test code +_LT_COMPILER_BOILERPLATE +_LT_LINKER_BOILERPLATE + +# Allow CC to be a program name with arguments. +lt_save_CC=$CC +lt_save_LD=$LD +lt_save_GCC=$GCC +GCC=$GXX +lt_save_with_gnu_ld=$with_gnu_ld +lt_save_path_LD=$lt_cv_path_LD +if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then + lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx +else + unset lt_cv_prog_gnu_ld +fi +if test -n "${lt_cv_path_LDCXX+set}"; then + lt_cv_path_LD=$lt_cv_path_LDCXX +else + unset lt_cv_path_LD +fi +test -z "${LDCXX+set}" || LD=$LDCXX +CC=${CXX-"c++"} +compiler=$CC +_LT_AC_TAGVAR(compiler, $1)=$CC +_LT_CC_BASENAME([$compiler]) + +# We don't want -fno-exception wen compiling C++ code, so set the +# no_builtin_flag separately +if test "$GXX" = yes; then + _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' +else + _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= +fi + +if test "$GXX" = yes; then + # Set up default GNU C++ configuration + + AC_PROG_LD + + # Check if GNU C++ uses GNU ld as the underlying linker, since the + # archiving commands below assume that GNU ld is being used. + if test "$with_gnu_ld" = yes; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + + # If archive_cmds runs LD, not CC, wlarc should be empty + # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to + # investigate it a little bit more. (MM) + wlarc='${wl}' + + # ancient GNU ld didn't support --whole-archive et. al. + if eval "`$CC -print-prog-name=ld` --help 2>&1" | \ + grep 'no-whole-archive' > /dev/null; then + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)= + fi + else + with_gnu_ld=no + wlarc= + + # A generic and very simple default shared library creation + # command for GNU C++ for the case where it uses the native + # linker, instead of GNU ld. If possible, this setting should + # overridden to take advantage of the native linker features on + # the platform it is being used on. + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + fi + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' + +else + GXX=no + with_gnu_ld=no + wlarc= +fi + +# PORTME: fill in a description of your system's C++ link characteristics +AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) +_LT_AC_TAGVAR(ld_shlibs, $1)=yes +case $host_os in + aix3*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + aix4* | aix5*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # need to do runtime linking. + case $host_os in aix4.[[23]]|aix4.[[23]].*|aix5*) + for ld_flag in $LDFLAGS; do + case $ld_flag in + *-brtl*) + aix_use_runtimelinking=yes + break + ;; + esac + done + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + _LT_AC_TAGVAR(archive_cmds, $1)='' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + + if test "$GXX" = yes; then + case $host_os in aix4.[[012]]|aix4.[[012]].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && \ + strings "$collect2name" | grep resolve_lib_name >/dev/null + then + # We have reworked collect2 + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + else + # We have old collect2 + _LT_AC_TAGVAR(hardcode_direct, $1)=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)= + fi + esac + shared_flag='-shared' + if test "$aix_use_runtimelinking" = yes; then + shared_flag="$shared_flag "'${wl}-G' + fi + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='${wl}-G' + else + shared_flag='${wl}-bM:SRE' + fi + fi + fi + + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to export. + _LT_AC_TAGVAR(always_export_symbols, $1)=yes + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + _LT_AC_TAGVAR(allow_undefined_flag, $1)='-berok' + # Determine the default libpath from the value encoded in an empty executable. + _LT_AC_SYS_LIBPATH_AIX + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib' + _LT_AC_TAGVAR(allow_undefined_flag, $1)="-z nodefs" + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an empty executable. + _LT_AC_SYS_LIBPATH_AIX + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + _LT_AC_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok' + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok' + # -bexpall does not export symbols beginning with underscore (_) + _LT_AC_TAGVAR(always_export_symbols, $1)=yes + # Exported symbols can be pulled into shared objects from archives + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=' ' + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes + # This is similar to how AIX traditionally builds its shared libraries. + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}-bE:$export_symbols ${wl}-bnoentry${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + chorus*) + case $cc_basename in + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + + cygwin* | mingw* | pw32*) + # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, + # as there is no search path for DLLs. + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_AC_TAGVAR(always_export_symbols, $1)=no + _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + + if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + darwin* | rhapsody*) + case $host_os in + rhapsody* | darwin1.[[012]]) + _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-undefined ${wl}suppress' + ;; + *) # Darwin 1.3 on + if test -z ${MACOSX_DEPLOYMENT_TARGET} ; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + else + case ${MACOSX_DEPLOYMENT_TARGET} in + 10.[[012]]) + _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + ;; + 10.*) + _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-undefined ${wl}dynamic_lookup' + ;; + esac + fi + ;; + esac + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_automatic, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=unsupported + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='' + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + + if test "$GXX" = yes ; then + lt_int_apple_cc_single_mod=no + output_verbose_link_cmd='echo' + if $CC -dumpspecs 2>&1 | $EGREP 'single_module' >/dev/null ; then + lt_int_apple_cc_single_mod=yes + fi + if test "X$lt_int_apple_cc_single_mod" = Xyes ; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -dynamiclib -single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -r -keep_private_externs -nostdlib -o ${lib}-master.o $libobjs~$CC -dynamiclib $allow_undefined_flag -o $lib ${lib}-master.o $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + fi + _LT_AC_TAGVAR(module_cmds, $1)='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + if test "X$lt_int_apple_cc_single_mod" = Xyes ; then + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -dynamiclib -single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + else + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -r -keep_private_externs -nostdlib -o ${lib}-master.o $libobjs~$CC -dynamiclib $allow_undefined_flag -o $lib ${lib}-master.o $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + fi + _LT_AC_TAGVAR(module_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + else + case $cc_basename in + xlc*) + output_verbose_link_cmd='echo' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj ${wl}-single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $verstring' + _LT_AC_TAGVAR(module_cmds, $1)='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj ${wl}-single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + _LT_AC_TAGVAR(module_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + ;; + *) + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + fi + ;; + + dgux*) + case $cc_basename in + ec++*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + ghcx*) + # Green Hills C++ Compiler + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + freebsd[[12]]*) + # C++ shared libraries reported to be fairly broken before switch to ELF + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + freebsd-elf*) + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + ;; + freebsd* | kfreebsd*-gnu | dragonfly*) + # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF + # conventions + _LT_AC_TAGVAR(ld_shlibs, $1)=yes + ;; + gnu*) + ;; + hpux9*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, + # but as the default + # location of the library. + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + aCC*) + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | grep "[[-]]L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes; then + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$CC -shared -nostdlib -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + hpux10*|hpux11*) + if test $with_gnu_ld = no; then + case $host_cpu in + hppa*64*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='+b $libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + ia64*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + ;; + *) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + ;; + esac + fi + case $host_cpu in + hppa*64*) + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + ia64*) + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, + # but as the default + # location of the library. + ;; + *) + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, + # but as the default + # location of the library. + ;; + esac + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + aCC*) + case $host_cpu in + hppa*64*|ia64*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname -o $lib $linker_flags $libobjs $deplibs' + ;; + *) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | grep "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes; then + if test $with_gnu_ld = no; then + case $host_cpu in + ia64*|hppa*64*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname -o $lib $linker_flags $libobjs $deplibs' + ;; + *) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + fi + else + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + irix5* | irix6*) + case $cc_basename in + CC*) + # SGI C++ + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + + # Archives containing C++ object files must be created using + # "CC -ar", where "CC" is the IRIX C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs' + ;; + *) + if test "$GXX" = yes; then + if test "$with_gnu_ld" = no; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` -o $lib' + fi + fi + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + ;; + esac + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + linux*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + _LT_AC_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | grep "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath,$libdir' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + + # Archives containing C++ object files must be created using + # "CC -Bstatic", where "CC" is the KAI C++ compiler. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' + ;; + icpc*) + # Intel C++ + with_gnu_ld=yes + # version 8.0 and above of icpc choke on multiply defined symbols + # if we add $predep_objects and $postdep_objects, however 7.1 and + # earlier do not add the objects themselves. + case `$CC -V 2>&1` in + *"Version 7."*) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + ;; + *) # Version 8.0 or newer + tmp_idyn= + case $host_cpu in + ia64*) tmp_idyn=' -i_dynamic';; + esac + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + ;; + esac + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive' + ;; + pgCC*) + # Portland Group C++ compiler + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' + ;; + cxx*) + # Compaq C++ + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib ${wl}-retain-symbols-file $wl$export_symbols' + + runpath_var=LD_RUN_PATH + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + esac + ;; + lynxos*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + m88k*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + mvs*) + case $cc_basename in + cxx*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' + wlarc= + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + fi + # Workaround some broken pre-1.5 toolchains + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' + ;; + openbsd2*) + # C++ shared libraries are fairly broken + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + openbsd*) + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file,$export_symbols -o $lib' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + fi + output_verbose_link_cmd='echo' + ;; + osf3*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + _LT_AC_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Archives containing C++ object files must be created using + # "CC -Bstatic", where "CC" is the KAI C++ compiler. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' + + ;; + RCC*) + # Rational C++ 2.4.1 + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + cxx*) + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && echo ${wl}-set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld" | grep -v "ld:"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' + + else + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + osf4* | osf5*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + _LT_AC_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Archives containing C++ object files must be created using + # the KAI C++ compiler. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -o $oldlib $oldobjs' + ;; + RCC*) + # Rational C++ 2.4.1 + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + cxx*) + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ + echo "-hidden">> $lib.exp~ + $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname -Wl,-input -Wl,$lib.exp `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib~ + $rm $lib.exp' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld" | grep -v "ld:"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' + + else + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + psos*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + sco*) + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + lcc*) + # Lucid + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + solaris*) + case $cc_basename in + CC*) + # Sun C++ 4.2, 5.x and Centerline C++ + _LT_AC_TAGVAR(archive_cmds_need_lc,$1)=yes + _LT_AC_TAGVAR(no_undefined_flag, $1)=' -zdefs' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -G${allow_undefined_flag} ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + case $host_os in + solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; + *) + # The C++ compiler is used as linker so we must use $wl + # flag to pass the commands to the underlying system + # linker. We must also pass each convience library through + # to the system linker between allextract/defaultextract. + # The C++ compiler will combine linker options so we + # cannot just pass the convience library names through + # without $wl. + # Supported since Solaris 2.6 (maybe 2.5.1?) + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}-z ${wl}defaultextract' + ;; + esac + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + + output_verbose_link_cmd='echo' + + # Archives containing C++ object files must be created using + # "CC -xar", where "CC" is the Sun C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' + ;; + gcx*) + # Green Hills C++ Compiler + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + + # The C++ compiler must be used to create the archive. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs' + ;; + *) + # GNU C++ compiler with Solaris linker + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + _LT_AC_TAGVAR(no_undefined_flag, $1)=' ${wl}-z ${wl}defs' + if $CC --version | grep -v '^2\.7' > /dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -shared -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd="$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\"" + else + # g++ 2.7 appears to require `-G' NOT `-shared' on this + # platform. + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd="$CC -G $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\"" + fi + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $wl$libdir' + fi + ;; + esac + ;; + sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[[78]]* | unixware7*) + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + ;; + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + vxworks*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; +esac +AC_MSG_RESULT([$_LT_AC_TAGVAR(ld_shlibs, $1)]) +test "$_LT_AC_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no + +_LT_AC_TAGVAR(GCC, $1)="$GXX" +_LT_AC_TAGVAR(LD, $1)="$LD" + +AC_LIBTOOL_POSTDEP_PREDEP($1) +AC_LIBTOOL_PROG_COMPILER_PIC($1) +AC_LIBTOOL_PROG_CC_C_O($1) +AC_LIBTOOL_SYS_HARD_LINK_LOCKS($1) +AC_LIBTOOL_PROG_LD_SHLIBS($1) +AC_LIBTOOL_SYS_DYNAMIC_LINKER($1) +AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH($1) +AC_LIBTOOL_SYS_LIB_STRIP +AC_LIBTOOL_DLOPEN_SELF($1) + +AC_LIBTOOL_CONFIG($1) + +AC_LANG_POP +CC=$lt_save_CC +LDCXX=$LD +LD=$lt_save_LD +GCC=$lt_save_GCC +with_gnu_ldcxx=$with_gnu_ld +with_gnu_ld=$lt_save_with_gnu_ld +lt_cv_path_LDCXX=$lt_cv_path_LD +lt_cv_path_LD=$lt_save_path_LD +lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld +lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld +])# AC_LIBTOOL_LANG_CXX_CONFIG + +# AC_LIBTOOL_POSTDEP_PREDEP([TAGNAME]) +# ------------------------ +# Figure out "hidden" library dependencies from verbose +# compiler output when linking a shared library. +# Parse the compiler output and extract the necessary +# objects, libraries and library flags. +AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP],[ +dnl we can't use the lt_simple_compile_test_code here, +dnl because it contains code intended for an executable, +dnl not a library. It's possible we should let each +dnl tag define a new lt_????_link_test_code variable, +dnl but it's only used here... +ifelse([$1],[],[cat > conftest.$ac_ext < conftest.$ac_ext < conftest.$ac_ext < conftest.$ac_ext <> "$cfgfile" +ifelse([$1], [], +[#! $SHELL + +# `$echo "$cfgfile" | sed 's%^.*/%%'` - Provide generalized library-building support services. +# Generated automatically by $PROGRAM (GNU $PACKAGE $VERSION$TIMESTAMP) +# NOTE: Changes made to this file will be lost: look at ltmain.sh. +# +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001 +# Free Software Foundation, Inc. +# +# This file is part of GNU Libtool: +# Originally by Gordon Matzigkeit , 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 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, 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. + +# A sed program that does not truncate output. +SED=$lt_SED + +# Sed that helps us avoid accidentally triggering echo(1) options like -n. +Xsed="$SED -e 1s/^X//" + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +# The names of the tagged configurations supported by this script. +available_tags= + +# ### BEGIN LIBTOOL CONFIG], +[# ### BEGIN LIBTOOL TAG CONFIG: $tagname]) + +# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: + +# Shell to use when invoking shell scripts. +SHELL=$lt_SHELL + +# Whether or not to build shared libraries. +build_libtool_libs=$enable_shared + +# Whether or not to build static libraries. +build_old_libs=$enable_static + +# Whether or not to add -lc for building shared libraries. +build_libtool_need_lc=$_LT_AC_TAGVAR(archive_cmds_need_lc, $1) + +# Whether or not to disallow shared libs when runtime libs are static +allow_libtool_libs_with_static_runtimes=$_LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1) + +# Whether or not to optimize for fast installation. +fast_install=$enable_fast_install + +# The host system. +host_alias=$host_alias +host=$host +host_os=$host_os + +# The build system. +build_alias=$build_alias +build=$build +build_os=$build_os + +# An echo program that does not interpret backslashes. +echo=$lt_echo + +# The archiver. +AR=$lt_AR +AR_FLAGS=$lt_AR_FLAGS + +# A C compiler. +LTCC=$lt_LTCC + +# A language-specific compiler. +CC=$lt_[]_LT_AC_TAGVAR(compiler, $1) + +# Is the compiler the GNU C compiler? +with_gcc=$_LT_AC_TAGVAR(GCC, $1) + +# An ERE matcher. +EGREP=$lt_EGREP + +# The linker used to build libraries. +LD=$lt_[]_LT_AC_TAGVAR(LD, $1) + +# Whether we need hard or soft links. +LN_S=$lt_LN_S + +# A BSD-compatible nm program. +NM=$lt_NM + +# A symbol stripping program +STRIP=$lt_STRIP + +# Used to examine libraries when file_magic_cmd begins "file" +MAGIC_CMD=$MAGIC_CMD + +# Used on cygwin: DLL creation program. +DLLTOOL="$DLLTOOL" + +# Used on cygwin: object dumper. +OBJDUMP="$OBJDUMP" + +# Used on cygwin: assembler. +AS="$AS" + +# The name of the directory that contains temporary libtool files. +objdir=$objdir + +# How to create reloadable object files. +reload_flag=$lt_reload_flag +reload_cmds=$lt_reload_cmds + +# How to pass a linker flag through the compiler. +wl=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_wl, $1) + +# Object file suffix (normally "o"). +objext="$ac_objext" + +# Old archive suffix (normally "a"). +libext="$libext" + +# Shared library suffix (normally ".so"). +shrext_cmds='$shrext_cmds' + +# Executable file suffix (normally ""). +exeext="$exeext" + +# Additional compiler flags for building library objects. +pic_flag=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_pic, $1) +pic_mode=$pic_mode + +# What is the maximum length of a command? +max_cmd_len=$lt_cv_sys_max_cmd_len + +# Does compiler simultaneously support -c and -o options? +compiler_c_o=$lt_[]_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1) + +# Must we lock files when doing compilation? +need_locks=$lt_need_locks + +# Do we need the lib prefix for modules? +need_lib_prefix=$need_lib_prefix + +# Do we need a version for libraries? +need_version=$need_version + +# Whether dlopen is supported. +dlopen_support=$enable_dlopen + +# Whether dlopen of programs is supported. +dlopen_self=$enable_dlopen_self + +# Whether dlopen of statically linked programs is supported. +dlopen_self_static=$enable_dlopen_self_static + +# Compiler flag to prevent dynamic linking. +link_static_flag=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_static, $1) + +# Compiler flag to turn off builtin functions. +no_builtin_flag=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) + +# Compiler flag to allow reflexive dlopens. +export_dynamic_flag_spec=$lt_[]_LT_AC_TAGVAR(export_dynamic_flag_spec, $1) + +# Compiler flag to generate shared objects directly from archives. +whole_archive_flag_spec=$lt_[]_LT_AC_TAGVAR(whole_archive_flag_spec, $1) + +# Compiler flag to generate thread-safe objects. +thread_safe_flag_spec=$lt_[]_LT_AC_TAGVAR(thread_safe_flag_spec, $1) + +# Library versioning type. +version_type=$version_type + +# Format of library name prefix. +libname_spec=$lt_libname_spec + +# List of archive names. First name is the real one, the rest are links. +# The last name is the one that the linker finds with -lNAME. +library_names_spec=$lt_library_names_spec + +# The coded name of the library, if different from the real name. +soname_spec=$lt_soname_spec + +# Commands used to build and install an old-style archive. +RANLIB=$lt_RANLIB +old_archive_cmds=$lt_[]_LT_AC_TAGVAR(old_archive_cmds, $1) +old_postinstall_cmds=$lt_old_postinstall_cmds +old_postuninstall_cmds=$lt_old_postuninstall_cmds + +# Create an old-style archive from a shared archive. +old_archive_from_new_cmds=$lt_[]_LT_AC_TAGVAR(old_archive_from_new_cmds, $1) + +# Create a temporary old-style archive to link instead of a shared archive. +old_archive_from_expsyms_cmds=$lt_[]_LT_AC_TAGVAR(old_archive_from_expsyms_cmds, $1) + +# Commands used to build and install a shared archive. +archive_cmds=$lt_[]_LT_AC_TAGVAR(archive_cmds, $1) +archive_expsym_cmds=$lt_[]_LT_AC_TAGVAR(archive_expsym_cmds, $1) +postinstall_cmds=$lt_postinstall_cmds +postuninstall_cmds=$lt_postuninstall_cmds + +# Commands used to build a loadable module (assumed same as above if empty) +module_cmds=$lt_[]_LT_AC_TAGVAR(module_cmds, $1) +module_expsym_cmds=$lt_[]_LT_AC_TAGVAR(module_expsym_cmds, $1) + +# Commands to strip libraries. +old_striplib=$lt_old_striplib +striplib=$lt_striplib + +# Dependencies to place before the objects being linked to create a +# shared library. +predep_objects=$lt_[]_LT_AC_TAGVAR(predep_objects, $1) + +# Dependencies to place after the objects being linked to create a +# shared library. +postdep_objects=$lt_[]_LT_AC_TAGVAR(postdep_objects, $1) + +# Dependencies to place before the objects being linked to create a +# shared library. +predeps=$lt_[]_LT_AC_TAGVAR(predeps, $1) + +# Dependencies to place after the objects being linked to create a +# shared library. +postdeps=$lt_[]_LT_AC_TAGVAR(postdeps, $1) + +# The library search path used internally by the compiler when linking +# a shared library. +compiler_lib_search_path=$lt_[]_LT_AC_TAGVAR(compiler_lib_search_path, $1) + +# Method to check whether dependent libraries are shared objects. +deplibs_check_method=$lt_deplibs_check_method + +# Command to use when deplibs_check_method == file_magic. +file_magic_cmd=$lt_file_magic_cmd + +# Flag that allows shared libraries with undefined symbols to be built. +allow_undefined_flag=$lt_[]_LT_AC_TAGVAR(allow_undefined_flag, $1) + +# Flag that forces no undefined symbols. +no_undefined_flag=$lt_[]_LT_AC_TAGVAR(no_undefined_flag, $1) + +# Commands used to finish a libtool library installation in a directory. +finish_cmds=$lt_finish_cmds + +# Same as above, but a single script fragment to be evaled but not shown. +finish_eval=$lt_finish_eval + +# Take the output of nm and produce a listing of raw symbols and C names. +global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe + +# Transform the output of nm in a proper C declaration +global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl + +# Transform the output of nm in a C name address pair +global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address + +# This is the shared library runtime path variable. +runpath_var=$runpath_var + +# This is the shared library path variable. +shlibpath_var=$shlibpath_var + +# Is shlibpath searched before the hard-coded library search path? +shlibpath_overrides_runpath=$shlibpath_overrides_runpath + +# How to hardcode a shared library path into an executable. +hardcode_action=$_LT_AC_TAGVAR(hardcode_action, $1) + +# Whether we should hardcode library paths into libraries. +hardcode_into_libs=$hardcode_into_libs + +# Flag to hardcode \$libdir into a binary during linking. +# This must work even if \$libdir does not exist. +hardcode_libdir_flag_spec=$lt_[]_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1) + +# If ld is used when linking, flag to hardcode \$libdir into +# a binary during linking. This must work even if \$libdir does +# not exist. +hardcode_libdir_flag_spec_ld=$lt_[]_LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1) + +# Whether we need a single -rpath flag with a separated argument. +hardcode_libdir_separator=$lt_[]_LT_AC_TAGVAR(hardcode_libdir_separator, $1) + +# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the +# resulting binary. +hardcode_direct=$_LT_AC_TAGVAR(hardcode_direct, $1) + +# Set to yes if using the -LDIR flag during linking hardcodes DIR into the +# resulting binary. +hardcode_minus_L=$_LT_AC_TAGVAR(hardcode_minus_L, $1) + +# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into +# the resulting binary. +hardcode_shlibpath_var=$_LT_AC_TAGVAR(hardcode_shlibpath_var, $1) + +# Set to yes if building a shared library automatically hardcodes DIR into the library +# and all subsequent libraries and executables linked against it. +hardcode_automatic=$_LT_AC_TAGVAR(hardcode_automatic, $1) + +# Variables whose values should be saved in libtool wrapper scripts and +# restored at relink time. +variables_saved_for_relink="$variables_saved_for_relink" + +# Whether libtool must link a program against all its dependency libraries. +link_all_deplibs=$_LT_AC_TAGVAR(link_all_deplibs, $1) + +# Compile-time system search path for libraries +sys_lib_search_path_spec=$lt_sys_lib_search_path_spec + +# Run-time system search path for libraries +sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec + +# Fix the shell variable \$srcfile for the compiler. +fix_srcfile_path="$_LT_AC_TAGVAR(fix_srcfile_path, $1)" + +# Set to yes if exported symbols are required. +always_export_symbols=$_LT_AC_TAGVAR(always_export_symbols, $1) + +# The commands to list exported symbols. +export_symbols_cmds=$lt_[]_LT_AC_TAGVAR(export_symbols_cmds, $1) + +# The commands to extract the exported symbol list from a shared archive. +extract_expsyms_cmds=$lt_extract_expsyms_cmds + +# Symbols that should not be listed in the preloaded symbols. +exclude_expsyms=$lt_[]_LT_AC_TAGVAR(exclude_expsyms, $1) + +# Symbols that must always be exported. +include_expsyms=$lt_[]_LT_AC_TAGVAR(include_expsyms, $1) + +ifelse([$1],[], +[# ### END LIBTOOL CONFIG], +[# ### END LIBTOOL TAG CONFIG: $tagname]) + +__EOF__ + +ifelse([$1],[], [ + case $host_os in + aix3*) + cat <<\EOF >> "$cfgfile" + +# AIX sometimes has problems with the GCC collect2 program. For some +# reason, if we set the COLLECT_NAMES environment variable, the problems +# vanish in a puff of smoke. +if test "X${COLLECT_NAMES+set}" != Xset; then + COLLECT_NAMES= + export COLLECT_NAMES +fi +EOF + ;; + esac + + # We use sed instead of cat because bash on DJGPP gets confused if + # if finds mixed CR/LF and LF-only lines. Since sed operates in + # text mode, it properly converts lines to CR/LF. This bash problem + # is reportedly fixed, but why not run on old versions too? + sed '$q' "$ltmain" >> "$cfgfile" || (rm -f "$cfgfile"; exit 1) + + mv -f "$cfgfile" "$ofile" || \ + (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") + chmod +x "$ofile" +]) +else + # If there is no Makefile yet, we rely on a make rule to execute + # `config.status --recheck' to rerun these tests and create the + # libtool script then. + ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'` + if test -f "$ltmain_in"; then + test -f Makefile && make "$ltmain" + fi +fi +])# AC_LIBTOOL_CONFIG + + +# AC_LIBTOOL_PROG_COMPILER_NO_RTTI([TAGNAME]) +# ------------------------------------------- +AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], +[AC_REQUIRE([_LT_AC_SYS_COMPILER])dnl + +_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= + +if test "$GCC" = yes; then + _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' + + AC_LIBTOOL_COMPILER_OPTION([if $compiler supports -fno-rtti -fno-exceptions], + lt_cv_prog_compiler_rtti_exceptions, + [-fno-rtti -fno-exceptions], [], + [_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)="$_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) -fno-rtti -fno-exceptions"]) +fi +])# AC_LIBTOOL_PROG_COMPILER_NO_RTTI + + +# AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE +# --------------------------------- +AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], +[AC_REQUIRE([AC_CANONICAL_HOST]) +AC_REQUIRE([AC_PROG_NM]) +AC_REQUIRE([AC_OBJEXT]) +# Check for command to grab the raw symbol name followed by C symbol from nm. +AC_MSG_CHECKING([command to parse $NM output from $compiler object]) +AC_CACHE_VAL([lt_cv_sys_global_symbol_pipe], +[ +# These are sane defaults that work on at least a few old systems. +# [They come from Ultrix. What could be older than Ultrix?!! ;)] + +# Character class describing NM global symbol codes. +symcode='[[BCDEGRST]]' + +# Regexp to match symbols that can be accessed directly from C. +sympat='\([[_A-Za-z]][[_A-Za-z0-9]]*\)' + +# Transform an extracted symbol line into a proper C declaration +lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^. .* \(.*\)$/extern int \1;/p'" + +# Transform an extracted symbol line into symbol name and symbol address +lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\) $/ {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode \([[^ ]]*\) \([[^ ]]*\)$/ {\"\2\", (lt_ptr) \&\2},/p'" + +# Define system-specific variables. +case $host_os in +aix*) + symcode='[[BCDT]]' + ;; +cygwin* | mingw* | pw32*) + symcode='[[ABCDGISTW]]' + ;; +hpux*) # Its linker distinguishes data from code symbols + if test "$host_cpu" = ia64; then + symcode='[[ABCDEGRST]]' + fi + lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'" + lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\) $/ {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/ {\"\2\", (lt_ptr) \&\2},/p'" + ;; +linux*) + if test "$host_cpu" = ia64; then + symcode='[[ABCDGIRSTW]]' + lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'" + lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\) $/ {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/ {\"\2\", (lt_ptr) \&\2},/p'" + fi + ;; +irix* | nonstopux*) + symcode='[[BCDEGRST]]' + ;; +osf*) + symcode='[[BCDEGQRST]]' + ;; +solaris* | sysv5*) + symcode='[[BDRT]]' + ;; +sysv4) + symcode='[[DFNSTU]]' + ;; +esac + +# Handle CRLF in mingw tool chain +opt_cr= +case $build_os in +mingw*) + opt_cr=`echo 'x\{0,1\}' | tr x '\015'` # option cr in regexp + ;; +esac + +# If we're using GNU nm, then use its standard symbol codes. +case `$NM -V 2>&1` in +*GNU* | *'with BFD'*) + symcode='[[ABCDGIRSTW]]' ;; +esac + +# Try without a prefix undercore, then with it. +for ac_symprfx in "" "_"; do + + # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. + symxfrm="\\1 $ac_symprfx\\2 \\2" + + # Write the raw and C identifiers. + lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[ ]]\($symcode$symcode*\)[[ ]][[ ]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" + + # Check to see that the pipe works correctly. + pipe_works=no + + rm -f conftest* + cat > conftest.$ac_ext < $nlist) && test -s "$nlist"; then + # Try sorting and uniquifying the output. + if sort "$nlist" | uniq > "$nlist"T; then + mv -f "$nlist"T "$nlist" + else + rm -f "$nlist"T + fi + + # Make sure that we snagged all the symbols we need. + if grep ' nm_test_var$' "$nlist" >/dev/null; then + if grep ' nm_test_func$' "$nlist" >/dev/null; then + cat < conftest.$ac_ext +#ifdef __cplusplus +extern "C" { +#endif + +EOF + # Now generate the symbol file. + eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | grep -v main >> conftest.$ac_ext' + + cat <> conftest.$ac_ext +#if defined (__STDC__) && __STDC__ +# define lt_ptr_t void * +#else +# define lt_ptr_t char * +# define const +#endif + +/* The mapping between symbol names and symbols. */ +const struct { + const char *name; + lt_ptr_t address; +} +lt_preloaded_symbols[[]] = +{ +EOF + $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/ {\"\2\", (lt_ptr_t) \&\2},/" < "$nlist" | grep -v main >> conftest.$ac_ext + cat <<\EOF >> conftest.$ac_ext + {0, (lt_ptr_t) 0} +}; + +#ifdef __cplusplus +} +#endif +EOF + # Now try linking the two files. + mv conftest.$ac_objext conftstm.$ac_objext + lt_save_LIBS="$LIBS" + lt_save_CFLAGS="$CFLAGS" + LIBS="conftstm.$ac_objext" + CFLAGS="$CFLAGS$_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)" + if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext}; then + pipe_works=yes + fi + LIBS="$lt_save_LIBS" + CFLAGS="$lt_save_CFLAGS" + else + echo "cannot find nm_test_func in $nlist" >&AS_MESSAGE_LOG_FD + fi + else + echo "cannot find nm_test_var in $nlist" >&AS_MESSAGE_LOG_FD + fi + else + echo "cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD + fi + else + echo "$progname: failed program was:" >&AS_MESSAGE_LOG_FD + cat conftest.$ac_ext >&5 + fi + rm -f conftest* conftst* + + # Do not use the global_symbol_pipe unless it works. + if test "$pipe_works" = yes; then + break + else + lt_cv_sys_global_symbol_pipe= + fi +done +]) +if test -z "$lt_cv_sys_global_symbol_pipe"; then + lt_cv_sys_global_symbol_to_cdecl= +fi +if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then + AC_MSG_RESULT(failed) +else + AC_MSG_RESULT(ok) +fi +]) # AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE + + +# AC_LIBTOOL_PROG_COMPILER_PIC([TAGNAME]) +# --------------------------------------- +AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC], +[_LT_AC_TAGVAR(lt_prog_compiler_wl, $1)= +_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= +_LT_AC_TAGVAR(lt_prog_compiler_static, $1)= + +AC_MSG_CHECKING([for $compiler option to produce PIC]) + ifelse([$1],[CXX],[ + # C++ specific cases for pic, static, wl, etc. + if test "$GXX" = yes; then + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + ;; + amigaos*) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' + ;; + beos* | cygwin* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + mingw* | os2* | pw32*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT' + ;; + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' + ;; + *djgpp*) + # DJGPP does not support shared libraries at all + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= + ;; + sysv4*MP*) + if test -d /usr/nec; then + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic + fi + ;; + hpux*) + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + else + case $host_os in + aix4* | aix5*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + else + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' + fi + ;; + chorus*) + case $cc_basename in + cxch68*) + # Green Hills C++ Compiler + # _LT_AC_TAGVAR(lt_prog_compiler_static, $1)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" + ;; + esac + ;; + darwin*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + case $cc_basename in + xlc*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-qnocommon' + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + ;; + esac + ;; + dgux*) + case $cc_basename in + ec++*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + ;; + ghcx*) + # Green Hills C++ Compiler + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + *) + ;; + esac + ;; + freebsd* | kfreebsd*-gnu | dragonfly*) + # FreeBSD uses GNU C++ + ;; + hpux9* | hpux10* | hpux11*) + case $cc_basename in + CC*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)="${ac_cv_prog_cc_wl}-a ${ac_cv_prog_cc_wl}archive" + if test "$host_cpu" != ia64; then + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + fi + ;; + aCC*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)="${ac_cv_prog_cc_wl}-a ${ac_cv_prog_cc_wl}archive" + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + ;; + esac + ;; + *) + ;; + esac + ;; + irix5* | irix6* | nonstopux*) + case $cc_basename in + CC*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + # CC pic flag -KPIC is the default. + ;; + *) + ;; + esac + ;; + linux*) + case $cc_basename in + KCC*) + # KAI C++ Compiler + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + icpc* | ecpc*) + # Intel C++ + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + pgCC*) + # Portland Group C++ compiler. + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + cxx*) + # Compaq C++ + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + *) + ;; + esac + ;; + lynxos*) + ;; + m88k*) + ;; + mvs*) + case $cc_basename in + cxx*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall' + ;; + *) + ;; + esac + ;; + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + ;; + osf3* | osf4* | osf5*) + case $cc_basename in + KCC*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' + ;; + RCC*) + # Rational C++ 2.4.1 + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + cxx*) + # Digital/Compaq C++ + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + *) + ;; + esac + ;; + psos*) + ;; + sco*) + case $cc_basename in + CC*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + *) + ;; + esac + ;; + solaris*) + case $cc_basename in + CC*) + # Sun C++ 4.2, 5.x and Centerline C++ + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' + ;; + gcx*) + # Green Hills C++ Compiler + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' + ;; + *) + ;; + esac + ;; + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + lcc*) + # Lucid + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + *) + ;; + esac + ;; + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + ;; + *) + ;; + esac + ;; + unixware*) + ;; + vxworks*) + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + ;; + esac + fi +], +[ + if test "$GCC" = yes; then + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + ;; + + amigaos*) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' + ;; + + beos* | cygwin* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + + mingw* | pw32* | os2*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT' + ;; + + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' + ;; + + msdosdjgpp*) + # Just because we use GCC doesn't mean we suddenly get shared libraries + # on systems that don't support them. + _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + enable_shared=no + ;; + + sysv4*MP*) + if test -d /usr/nec; then + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic + fi + ;; + + hpux*) + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + ;; + + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + else + # PORTME Check for flag to pass linker flags through the system compiler. + case $host_os in + aix*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + else + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' + fi + ;; + darwin*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + case $cc_basename in + xlc*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-qnocommon' + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + ;; + esac + ;; + + mingw* | pw32* | os2*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT' + ;; + + hpux9* | hpux10* | hpux11*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + ;; + esac + # Is there a better lt_prog_compiler_static that works with the bundled CC? + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive' + ;; + + irix5* | irix6* | nonstopux*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # PIC (with -KPIC) is the default. + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + + newsos6) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + linux*) + case $cc_basename in + icc* | ecc*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + pgcc* | pgf77* | pgf90* | pgf95*) + # Portland Group compilers (*not* the Pentium gcc compiler, + # which looks to be a dead project) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + ccc*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # All Alpha code is PIC. + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + esac + ;; + + osf3* | osf4* | osf5*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # All OSF/1 code is PIC. + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + + sco3.2v5*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-Kpic' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-dn' + ;; + + solaris*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + case $cc_basename in + f77* | f90* | f95*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ';; + *) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,';; + esac + ;; + + sunos4*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + sysv4*MP*) + if test -d /usr/nec ;then + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + ;; + + unicos*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + ;; + + uts4*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + *) + _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + ;; + esac + fi +]) +AC_MSG_RESULT([$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)]) + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)"; then + AC_LIBTOOL_COMPILER_OPTION([if $compiler PIC flag $_LT_AC_TAGVAR(lt_prog_compiler_pic, $1) works], + _LT_AC_TAGVAR(lt_prog_compiler_pic_works, $1), + [$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)ifelse([$1],[],[ -DPIC],[ifelse([$1],[CXX],[ -DPIC],[])])], [], + [case $_LT_AC_TAGVAR(lt_prog_compiler_pic, $1) in + "" | " "*) ;; + *) _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=" $_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)" ;; + esac], + [_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no]) +fi +case $host_os in + # For platforms which do not support PIC, -DPIC is meaningless: + *djgpp*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)="$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)ifelse([$1],[],[ -DPIC],[ifelse([$1],[CXX],[ -DPIC],[])])" + ;; +esac +]) + + +# AC_LIBTOOL_PROG_LD_SHLIBS([TAGNAME]) +# ------------------------------------ +# See if the linker supports building shared libraries. +AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS], +[AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) +ifelse([$1],[CXX],[ + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + case $host_os in + aix4* | aix5*) + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | grep 'GNU' > /dev/null; then + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' + else + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' + fi + ;; + pw32*) + _LT_AC_TAGVAR(export_symbols_cmds, $1)="$ltdll_cmds" + ;; + cygwin* | mingw*) + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]] /s/.* \([[^ ]]*\)/\1 DATA/;/^.* __nm__/s/^.* __nm__\([[^ ]]*\) [[^ ]]*/\1 DATA/;/^I /d;/^[[AITW]] /s/.* //'\'' | sort | uniq > $export_symbols' + ;; + linux*) + _LT_AC_TAGVAR(link_all_deplibs, $1)=no + ;; + *) + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + ;; + esac +],[ + runpath_var= + _LT_AC_TAGVAR(allow_undefined_flag, $1)= + _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=no + _LT_AC_TAGVAR(archive_cmds, $1)= + _LT_AC_TAGVAR(archive_expsym_cmds, $1)= + _LT_AC_TAGVAR(old_archive_From_new_cmds, $1)= + _LT_AC_TAGVAR(old_archive_from_expsyms_cmds, $1)= + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)= + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)= + _LT_AC_TAGVAR(thread_safe_flag_spec, $1)= + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)= + _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)= + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)= + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_minus_L, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=unsupported + _LT_AC_TAGVAR(link_all_deplibs, $1)=unknown + _LT_AC_TAGVAR(hardcode_automatic, $1)=no + _LT_AC_TAGVAR(module_cmds, $1)= + _LT_AC_TAGVAR(module_expsym_cmds, $1)= + _LT_AC_TAGVAR(always_export_symbols, $1)=no + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + # include_expsyms should be a list of space-separated symbols to be *always* + # included in the symbol list + _LT_AC_TAGVAR(include_expsyms, $1)= + # exclude_expsyms can be an extended regexp of symbols to exclude + # it will be wrapped by ` (' and `)$', so one must not match beginning or + # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', + # as well as any symbol that contains `d'. + _LT_AC_TAGVAR(exclude_expsyms, $1)="_GLOBAL_OFFSET_TABLE_" + # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out + # platforms (ab)use it in PIC code, but their linkers get confused if + # the symbol is explicitly referenced. Since portable code cannot + # rely on this symbol name, it's probably fine to never include it in + # preloaded symbol tables. + extract_expsyms_cmds= + # Just being paranoid about ensuring that cc_basename is set. + _LT_CC_BASENAME([$compiler]) + case $host_os in + cygwin* | mingw* | pw32*) + # FIXME: the MSVC++ port hasn't been tested in a loooong time + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + if test "$GCC" != yes; then + with_gnu_ld=no + fi + ;; + openbsd*) + with_gnu_ld=no + ;; + esac + + _LT_AC_TAGVAR(ld_shlibs, $1)=yes + if test "$with_gnu_ld" = yes; then + # If archive_cmds runs LD, not CC, wlarc should be empty + wlarc='${wl}' + + # Set some defaults for GNU ld with shared library support. These + # are reset later if shared libraries are not supported. Putting them + # here allows them to be overridden if necessary. + runpath_var=LD_RUN_PATH + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + # ancient GNU ld didn't support --whole-archive et. al. + if $LD --help 2>&1 | grep 'no-whole-archive' > /dev/null; then + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)= + fi + supports_anon_versioning=no + case `$LD -v 2>/dev/null` in + *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11 + *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... + *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... + *\ 2.11.*) ;; # other 2.11 versions + *) supports_anon_versioning=yes ;; + esac + + # See if GNU ld supports shared libraries. + case $host_os in + aix3* | aix4* | aix5*) + # On AIX/PPC, the GNU linker is very broken + if test "$host_cpu" != ia64; then + _LT_AC_TAGVAR(ld_shlibs, $1)=no + cat <&2 + +*** Warning: the GNU linker, at least up to release 2.9.1, is reported +*** to be unable to reliably create shared libraries on AIX. +*** Therefore, libtool is disabling shared libraries support. If you +*** really care for shared libraries, you may want to modify your PATH +*** so that a non-GNU linker is found, and then restart. + +EOF + fi + ;; + + amigaos*) + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + + # Samuel A. Falvo II reports + # that the semantics of dynamic libraries on AmigaOS, at least up + # to version 4, is to share data among multiple programs linked + # with the same dynamic library. Since this doesn't match the + # behavior of shared libraries on other platforms, we can't use + # them. + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + + beos*) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + cygwin* | mingw* | pw32*) + # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, + # as there is no search path for DLLs. + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_AC_TAGVAR(always_export_symbols, $1)=no + _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]] /s/.* \([[^ ]]*\)/\1 DATA/'\'' | $SED -e '\''/^[[AITW]] /s/.* //'\'' | sort | uniq > $export_symbols' + + if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + linux*) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + tmp_addflag= + case $cc_basename,$host_cpu in + pgcc*) # Portland Group C compiler + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag' + ;; + pgf77* | pgf90* | pgf95*) # Portland Group f77 and f90 compilers + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag -Mnomain' ;; + ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 + tmp_addflag=' -i_dynamic' ;; + efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 + tmp_addflag=' -i_dynamic -nofor_main' ;; + ifc* | ifort*) # Intel Fortran compiler + tmp_addflag=' -nofor_main' ;; + esac + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + + if test $supports_anon_versioning = yes; then + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + $echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC -shared'"$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' + fi + _LT_AC_TAGVAR(link_all_deplibs, $1)=no + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' + wlarc= + else + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + fi + ;; + + solaris* | sysv5*) + if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then + _LT_AC_TAGVAR(ld_shlibs, $1)=no + cat <&2 + +*** Warning: The releases 2.8.* of the GNU linker cannot reliably +*** create shared libraries on Solaris systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.9.1 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +EOF + elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + sunos4*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' + wlarc= + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + *) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + + if test "$_LT_AC_TAGVAR(ld_shlibs, $1)" = no; then + runpath_var= + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)= + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)= + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)= + fi + else + # PORTME fill in a description of your system's linker (not GNU ld) + case $host_os in + aix3*) + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_AC_TAGVAR(always_export_symbols, $1)=yes + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' + # Note: this linker hardcodes the directories in LIBPATH if there + # are no directories specified by -L. + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + if test "$GCC" = yes && test -z "$link_static_flag"; then + # Neither direct hardcoding nor static linking is supported with a + # broken collect2. + _LT_AC_TAGVAR(hardcode_direct, $1)=unsupported + fi + ;; + + aix4* | aix5*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | grep 'GNU' > /dev/null; then + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' + else + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' + fi + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # need to do runtime linking. + case $host_os in aix4.[[23]]|aix4.[[23]].*|aix5*) + for ld_flag in $LDFLAGS; do + if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then + aix_use_runtimelinking=yes + break + fi + done + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + _LT_AC_TAGVAR(archive_cmds, $1)='' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + + if test "$GCC" = yes; then + case $host_os in aix4.[[012]]|aix4.[[012]].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && \ + strings "$collect2name" | grep resolve_lib_name >/dev/null + then + # We have reworked collect2 + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + else + # We have old collect2 + _LT_AC_TAGVAR(hardcode_direct, $1)=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)= + fi + esac + shared_flag='-shared' + if test "$aix_use_runtimelinking" = yes; then + shared_flag="$shared_flag "'${wl}-G' + fi + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='${wl}-G' + else + shared_flag='${wl}-bM:SRE' + fi + fi + fi + + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to export. + _LT_AC_TAGVAR(always_export_symbols, $1)=yes + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + _LT_AC_TAGVAR(allow_undefined_flag, $1)='-berok' + # Determine the default libpath from the value encoded in an empty executable. + _LT_AC_SYS_LIBPATH_AIX + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib' + _LT_AC_TAGVAR(allow_undefined_flag, $1)="-z nodefs" + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an empty executable. + _LT_AC_SYS_LIBPATH_AIX + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + _LT_AC_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok' + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok' + # -bexpall does not export symbols beginning with underscore (_) + _LT_AC_TAGVAR(always_export_symbols, $1)=yes + # Exported symbols can be pulled into shared objects from archives + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=' ' + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes + # This is similar to how AIX traditionally builds its shared libraries. + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}-bE:$export_symbols ${wl}-bnoentry${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + + amigaos*) + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + # see comment about different semantics on the GNU ld section + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + + bsdi[[45]]*) + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)=-rdynamic + ;; + + cygwin* | mingw* | pw32*) + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=".dll" + # FIXME: Setting linknames here is a bad hack. + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `echo "$deplibs" | $SED -e '\''s/ -lc$//'\''` -link -dll~linknames=' + # The linker will automatically build a .lib file if we build a DLL. + _LT_AC_TAGVAR(old_archive_From_new_cmds, $1)='true' + # FIXME: Should let the user specify the lib program. + _LT_AC_TAGVAR(old_archive_cmds, $1)='lib /OUT:$oldlib$oldobjs$old_deplibs' + _LT_AC_TAGVAR(fix_srcfile_path, $1)='`cygpath -w "$srcfile"`' + _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + ;; + + darwin* | rhapsody*) + case $host_os in + rhapsody* | darwin1.[[012]]) + _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-undefined ${wl}suppress' + ;; + *) # Darwin 1.3 on + if test -z ${MACOSX_DEPLOYMENT_TARGET} ; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + else + case ${MACOSX_DEPLOYMENT_TARGET} in + 10.[[012]]) + _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + ;; + 10.*) + _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-undefined ${wl}dynamic_lookup' + ;; + esac + fi + ;; + esac + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_automatic, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=unsupported + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='' + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + if test "$GCC" = yes ; then + output_verbose_link_cmd='echo' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + _LT_AC_TAGVAR(module_cmds, $1)='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + _LT_AC_TAGVAR(module_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + else + case $cc_basename in + xlc*) + output_verbose_link_cmd='echo' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $verstring' + _LT_AC_TAGVAR(module_cmds, $1)='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + _LT_AC_TAGVAR(module_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + ;; + *) + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + fi + ;; + + dgux*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + freebsd1*) + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + + # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor + # support. Future versions do this automatically, but an explicit c++rt0.o + # does not break anything, and helps significantly (at the cost of a little + # extra space). + freebsd2.2*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + # Unfortunately, older versions of FreeBSD 2 do not have this feature. + freebsd2*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + # FreeBSD 3 and greater uses gcc -shared to do shared libraries. + freebsd* | kfreebsd*-gnu | dragonfly*) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -o $lib $libobjs $deplibs $compiler_flags' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + hpux9*) + if test "$GCC" = yes; then + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + ;; + + hpux10* | hpux11*) + if test "$GCC" = yes -a "$with_gnu_ld" = no; then + case $host_cpu in + hppa*64*|ia64*) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + else + case $host_cpu in + hppa*64*|ia64*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname -o $lib $libobjs $deplibs $linker_flags' + ;; + *) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' + ;; + esac + fi + if test "$with_gnu_ld" = no; then + case $host_cpu in + hppa*64*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='+b $libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + ia64*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + ;; + *) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + ;; + esac + fi + ;; + + irix5* | irix6* | nonstopux*) + if test "$GCC" = yes; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='-rpath $libdir' + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + ;; + + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out + else + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + newsos6) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + openbsd*) + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + else + case $host_os in + openbsd[[01]].* | openbsd2.[[0-7]] | openbsd2.[[0-7]].*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + ;; + *) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + ;; + esac + fi + ;; + + os2*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_AC_TAGVAR(archive_cmds, $1)='$echo "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$echo "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$echo DATA >> $output_objdir/$libname.def~$echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~$echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' + _LT_AC_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' + ;; + + osf3*) + if test "$GCC" = yes; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + + osf4* | osf5*) # as osf3* with the addition of -msym flag + if test "$GCC" = yes; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + else + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; echo "-hidden">> $lib.exp~ + $LD -shared${allow_undefined_flag} -input $lib.exp $linker_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib~$rm $lib.exp' + + # Both c and cxx compiler support -rpath directly + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + fi + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + + sco3.2v5*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport' + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ;; + + solaris*) + _LT_AC_TAGVAR(no_undefined_flag, $1)=' -z text' + if test "$GCC" = yes; then + wlarc='${wl}' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -shared ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$rm $lib.exp' + else + wlarc='' + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + case $host_os in + solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; + *) + # The compiler driver will combine linker options so we + # cannot just pass the convience library names through + # without $wl, iff we do not link with $LD. + # Luckily, gcc supports the same syntax we need for Sun Studio. + # Supported since Solaris 2.6 (maybe 2.5.1?) + case $wlarc in + '') + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' ;; + *) + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}-z ${wl}defaultextract' ;; + esac ;; + esac + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + ;; + + sunos4*) + if test "x$host_vendor" = xsequent; then + # Use $CC to link under sequent, because it throws in some extra .o + # files that make .init and .fini sections work. + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + sysv4) + case $host_vendor in + sni) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes # is this really true??? + ;; + siemens) + ## LD is ld it makes a PLAMLIB + ## CC just makes a GrossModule. + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(reload_cmds, $1)='$CC -r -o $output$reload_objs' + _LT_AC_TAGVAR(hardcode_direct, $1)=no + ;; + motorola) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_direct, $1)=no #Motorola manual says yes, but my tests say they lie + ;; + esac + runpath_var='LD_RUN_PATH' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + sysv4.3*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='-Bexport' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + _LT_AC_TAGVAR(ld_shlibs, $1)=yes + fi + ;; + + sysv4.2uw2*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_minus_L, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + hardcode_runpath_var=yes + runpath_var=LD_RUN_PATH + ;; + + sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[[78]]* | unixware7*) + _LT_AC_TAGVAR(no_undefined_flag, $1)='${wl}-z ${wl}text' + if test "$GCC" = yes; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + runpath_var='LD_RUN_PATH' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + sysv5*) + _LT_AC_TAGVAR(no_undefined_flag, $1)=' -z text' + # $CC -shared without GNU ld will not create a library from C++ + # object files and a static libstdc++, better avoid it by now + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)= + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + runpath_var='LD_RUN_PATH' + ;; + + uts4*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + *) + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + fi +]) +AC_MSG_RESULT([$_LT_AC_TAGVAR(ld_shlibs, $1)]) +test "$_LT_AC_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test "$GCC" = yes; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +# +# Do we need to explicitly link libc? +# +case "x$_LT_AC_TAGVAR(archive_cmds_need_lc, $1)" in +x|xyes) + # Assume -lc should be added + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes + + if test "$enable_shared" = yes && test "$GCC" = yes; then + case $_LT_AC_TAGVAR(archive_cmds, $1) in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + AC_MSG_CHECKING([whether -lc should be explicitly linked in]) + $rm conftest* + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + if AC_TRY_EVAL(ac_compile) 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$_LT_AC_TAGVAR(lt_prog_compiler_wl, $1) + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$_LT_AC_TAGVAR(allow_undefined_flag, $1) + _LT_AC_TAGVAR(allow_undefined_flag, $1)= + if AC_TRY_EVAL(_LT_AC_TAGVAR(archive_cmds, $1) 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1) + then + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + else + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes + fi + _LT_AC_TAGVAR(allow_undefined_flag, $1)=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $rm conftest* + AC_MSG_RESULT([$_LT_AC_TAGVAR(archive_cmds_need_lc, $1)]) + ;; + esac + fi + ;; +esac +])# AC_LIBTOOL_PROG_LD_SHLIBS + + +# _LT_AC_FILE_LTDLL_C +# ------------------- +# Be careful that the start marker always follows a newline. +AC_DEFUN([_LT_AC_FILE_LTDLL_C], [ +# /* ltdll.c starts here */ +# #define WIN32_LEAN_AND_MEAN +# #include +# #undef WIN32_LEAN_AND_MEAN +# #include +# +# #ifndef __CYGWIN__ +# # ifdef __CYGWIN32__ +# # define __CYGWIN__ __CYGWIN32__ +# # endif +# #endif +# +# #ifdef __cplusplus +# extern "C" { +# #endif +# BOOL APIENTRY DllMain (HINSTANCE hInst, DWORD reason, LPVOID reserved); +# #ifdef __cplusplus +# } +# #endif +# +# #ifdef __CYGWIN__ +# #include +# DECLARE_CYGWIN_DLL( DllMain ); +# #endif +# HINSTANCE __hDllInstance_base; +# +# BOOL APIENTRY +# DllMain (HINSTANCE hInst, DWORD reason, LPVOID reserved) +# { +# __hDllInstance_base = hInst; +# return TRUE; +# } +# /* ltdll.c ends here */ +])# _LT_AC_FILE_LTDLL_C + + +# _LT_AC_TAGVAR(VARNAME, [TAGNAME]) +# --------------------------------- +AC_DEFUN([_LT_AC_TAGVAR], [ifelse([$2], [], [$1], [$1_$2])]) + + +# old names +AC_DEFUN([AM_PROG_LIBTOOL], [AC_PROG_LIBTOOL]) +AC_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)]) +AC_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)]) +AC_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)]) +AC_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)]) +AC_DEFUN([AM_PROG_LD], [AC_PROG_LD]) +AC_DEFUN([AM_PROG_NM], [AC_PROG_NM]) + +# This is just to silence aclocal about the macro not being used +ifelse([AC_DISABLE_FAST_INSTALL]) + +AC_DEFUN([LT_AC_PROG_GCJ], +[AC_CHECK_TOOL(GCJ, gcj, no) + test "x${GCJFLAGS+set}" = xset || GCJFLAGS="-g -O2" + AC_SUBST(GCJFLAGS) +]) + +AC_DEFUN([LT_AC_PROG_RC], +[AC_CHECK_TOOL(RC, windres, no) +]) + +# NOTE: This macro has been submitted for inclusion into # +# GNU Autoconf as AC_PROG_SED. When it is available in # +# a released version of Autoconf we should remove this # +# macro and use it instead. # +# LT_AC_PROG_SED +# -------------- +# Check for a fully-functional sed program, that truncates +# as few characters as possible. Prefer GNU sed if found. +AC_DEFUN([LT_AC_PROG_SED], +[AC_MSG_CHECKING([for a sed that does not truncate output]) +AC_CACHE_VAL(lt_cv_path_SED, +[# Loop through the user's path and test for sed and gsed. +# Then use that list of sed's as ones to test for truncation. +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for lt_ac_prog in sed gsed; do + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then + lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext" + fi + done + done +done +lt_ac_max=0 +lt_ac_count=0 +# Add /usr/xpg4/bin/sed as it is typically found on Solaris +# along with /bin/sed that truncates output. +for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do + test ! -f $lt_ac_sed && continue + cat /dev/null > conftest.in + lt_ac_count=0 + echo $ECHO_N "0123456789$ECHO_C" >conftest.in + # Check for GNU sed and select it if it is found. + if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then + lt_cv_path_SED=$lt_ac_sed + break + fi + while true; do + cat conftest.in conftest.in >conftest.tmp + mv conftest.tmp conftest.in + cp conftest.in conftest.nl + echo >>conftest.nl + $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break + cmp -s conftest.out conftest.nl || break + # 10000 chars as input seems more than enough + test $lt_ac_count -gt 10 && break + lt_ac_count=`expr $lt_ac_count + 1` + if test $lt_ac_count -gt $lt_ac_max; then + lt_ac_max=$lt_ac_count + lt_cv_path_SED=$lt_ac_sed + fi + done +done +]) +SED=$lt_cv_path_SED +AC_MSG_RESULT([$SED]) +]) + +# longdouble.m4 serial 1 (gettext-0.12) +dnl Copyright (C) 2002-2003 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. +dnl Test whether the compiler supports the 'long double' type. +dnl Prerequisite: AC_PROG_CC + +AC_DEFUN([gt_TYPE_LONGDOUBLE], +[ + AC_CACHE_CHECK([for long double], gt_cv_c_long_double, + [if test "$GCC" = yes; then + gt_cv_c_long_double=yes + else + AC_TRY_COMPILE([ + /* The Stardent Vistra knows sizeof(long double), but does not support it. */ + long double foo = 0.0; + /* On Ultrix 4.3 cc, long double is 4 and double is 8. */ + int array [2*(sizeof(long double) >= sizeof(double)) - 1]; + ], , + gt_cv_c_long_double=yes, gt_cv_c_long_double=no) + fi]) + if test $gt_cv_c_long_double = yes; then + AC_DEFINE(HAVE_LONG_DOUBLE, 1, [Define if you have the 'long double' type.]) + fi +]) + +# longlong.m4 serial 5 +dnl Copyright (C) 1999-2004 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Paul Eggert. + +# Define HAVE_LONG_LONG if 'long long' works. + +AC_DEFUN([gl_AC_TYPE_LONG_LONG], +[ + AC_CACHE_CHECK([for long long], ac_cv_type_long_long, + [AC_TRY_LINK([long long ll = 1LL; int i = 63;], + [long long llmax = (long long) -1; + return ll << i | ll >> i | llmax / ll | llmax % ll;], + ac_cv_type_long_long=yes, + ac_cv_type_long_long=no)]) + if test $ac_cv_type_long_long = yes; then + AC_DEFINE(HAVE_LONG_LONG, 1, + [Define if you have the 'long long' type.]) + fi +]) + +# nls.m4 serial 2 (gettext-0.14.3) +dnl Copyright (C) 1995-2003, 2005 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. +dnl +dnl This file can can be used in projects which are not available under +dnl the GNU General Public License or the GNU Library General Public +dnl License but which still want to provide support for the GNU gettext +dnl functionality. +dnl Please note that the actual code of the GNU gettext library is covered +dnl by the GNU Library General Public License, and the rest of the GNU +dnl gettext package package is covered by the GNU General Public License. +dnl They are *not* in the public domain. + +dnl Authors: +dnl Ulrich Drepper , 1995-2000. +dnl Bruno Haible , 2000-2003. + +AC_PREREQ(2.50) + +AC_DEFUN([AM_NLS], +[ + AC_MSG_CHECKING([whether NLS is requested]) + dnl Default is enabled NLS + AC_ARG_ENABLE(nls, + [ --disable-nls do not use Native Language Support], + USE_NLS=$enableval, USE_NLS=yes) + AC_MSG_RESULT($USE_NLS) + AC_SUBST(USE_NLS) +]) + +AC_DEFUN([AM_MKINSTALLDIRS], +[ + dnl Tell automake >= 1.10 to complain if mkinstalldirs is missing. + m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([mkinstalldirs])]) + dnl If the AC_CONFIG_AUX_DIR macro for autoconf is used we possibly + dnl find the mkinstalldirs script in another subdir but $(top_srcdir). + dnl Try to locate it. + MKINSTALLDIRS= + if test -n "$ac_aux_dir"; then + case "$ac_aux_dir" in + /*) MKINSTALLDIRS="$ac_aux_dir/mkinstalldirs" ;; + *) MKINSTALLDIRS="\$(top_builddir)/$ac_aux_dir/mkinstalldirs" ;; + esac + fi + if test -z "$MKINSTALLDIRS"; then + MKINSTALLDIRS="\$(top_srcdir)/mkinstalldirs" + fi + AC_SUBST(MKINSTALLDIRS) +]) + +# po.m4 serial 7 (gettext-0.14.3) +dnl Copyright (C) 1995-2005 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. +dnl +dnl This file can can be used in projects which are not available under +dnl the GNU General Public License or the GNU Library General Public +dnl License but which still want to provide support for the GNU gettext +dnl functionality. +dnl Please note that the actual code of the GNU gettext library is covered +dnl by the GNU Library General Public License, and the rest of the GNU +dnl gettext package package is covered by the GNU General Public License. +dnl They are *not* in the public domain. + +dnl Authors: +dnl Ulrich Drepper , 1995-2000. +dnl Bruno Haible , 2000-2003. + +AC_PREREQ(2.50) + +dnl Checks for all prerequisites of the po subdirectory. +AC_DEFUN([AM_PO_SUBDIRS], +[ + AC_REQUIRE([AC_PROG_MAKE_SET])dnl + AC_REQUIRE([AC_PROG_INSTALL])dnl + AC_REQUIRE([AM_MKINSTALLDIRS])dnl + AC_REQUIRE([AM_NLS])dnl + + dnl Perform the following tests also if --disable-nls has been given, + dnl because they are needed for "make dist" to work. + + dnl Search for GNU msgfmt in the PATH. + dnl The first test excludes Solaris msgfmt and early GNU msgfmt versions. + dnl The second test excludes FreeBSD msgfmt. + AM_PATH_PROG_WITH_TEST(MSGFMT, msgfmt, + [$ac_dir/$ac_word --statistics /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1 && + (if $ac_dir/$ac_word --statistics /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi)], + :) + AC_PATH_PROG(GMSGFMT, gmsgfmt, $MSGFMT) + + dnl Search for GNU xgettext 0.12 or newer in the PATH. + dnl The first test excludes Solaris xgettext and early GNU xgettext versions. + dnl The second test excludes FreeBSD xgettext. + AM_PATH_PROG_WITH_TEST(XGETTEXT, xgettext, + [$ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1 && + (if $ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi)], + :) + dnl Remove leftover from FreeBSD xgettext call. + rm -f messages.po + + dnl Search for GNU msgmerge 0.11 or newer in the PATH. + AM_PATH_PROG_WITH_TEST(MSGMERGE, msgmerge, + [$ac_dir/$ac_word --update -q /dev/null /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1], :) + + dnl This could go away some day; the PATH_PROG_WITH_TEST already does it. + dnl Test whether we really found GNU msgfmt. + if test "$GMSGFMT" != ":"; then + dnl If it is no GNU msgfmt we define it as : so that the + dnl Makefiles still can work. + if $GMSGFMT --statistics /dev/null >/dev/null 2>&1 && + (if $GMSGFMT --statistics /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi); then + : ; + else + GMSGFMT=`echo "$GMSGFMT" | sed -e 's,^.*/,,'` + AC_MSG_RESULT( + [found $GMSGFMT program is not GNU msgfmt; ignore it]) + GMSGFMT=":" + fi + fi + + dnl This could go away some day; the PATH_PROG_WITH_TEST already does it. + dnl Test whether we really found GNU xgettext. + if test "$XGETTEXT" != ":"; then + dnl If it is no GNU xgettext we define it as : so that the + dnl Makefiles still can work. + if $XGETTEXT --omit-header --copyright-holder= --msgid-bugs-address= /dev/null >/dev/null 2>&1 && + (if $XGETTEXT --omit-header --copyright-holder= --msgid-bugs-address= /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi); then + : ; + else + AC_MSG_RESULT( + [found xgettext program is not GNU xgettext; ignore it]) + XGETTEXT=":" + fi + dnl Remove leftover from FreeBSD xgettext call. + rm -f messages.po + fi + + AC_OUTPUT_COMMANDS([ + for ac_file in $CONFIG_FILES; do + # Support "outfile[:infile[:infile...]]" + case "$ac_file" in + *:*) ac_file=`echo "$ac_file"|sed 's%:.*%%'` ;; + esac + # PO directories have a Makefile.in generated from Makefile.in.in. + case "$ac_file" in */Makefile.in) + # Adjust a relative srcdir. + ac_dir=`echo "$ac_file"|sed 's%/[^/][^/]*$%%'` + ac_dir_suffix="/`echo "$ac_dir"|sed 's%^\./%%'`" + ac_dots=`echo "$ac_dir_suffix"|sed 's%/[^/]*%../%g'` + # In autoconf-2.13 it is called $ac_given_srcdir. + # In autoconf-2.50 it is called $srcdir. + test -n "$ac_given_srcdir" || ac_given_srcdir="$srcdir" + case "$ac_given_srcdir" in + .) top_srcdir=`echo $ac_dots|sed 's%/$%%'` ;; + /*) top_srcdir="$ac_given_srcdir" ;; + *) top_srcdir="$ac_dots$ac_given_srcdir" ;; + esac + # Treat a directory as a PO directory if and only if it has a + # POTFILES.in file. This allows packages to have multiple PO + # directories under different names or in different locations. + if test -f "$ac_given_srcdir/$ac_dir/POTFILES.in"; then + rm -f "$ac_dir/POTFILES" + test -n "$as_me" && echo "$as_me: creating $ac_dir/POTFILES" || echo "creating $ac_dir/POTFILES" + cat "$ac_given_srcdir/$ac_dir/POTFILES.in" | sed -e "/^#/d" -e "/^[ ]*\$/d" -e "s,.*, $top_srcdir/& \\\\," | sed -e "\$s/\(.*\) \\\\/\1/" > "$ac_dir/POTFILES" + POMAKEFILEDEPS="POTFILES.in" + # ALL_LINGUAS, POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES depend + # on $ac_dir but don't depend on user-specified configuration + # parameters. + if test -f "$ac_given_srcdir/$ac_dir/LINGUAS"; then + # The LINGUAS file contains the set of available languages. + if test -n "$OBSOLETE_ALL_LINGUAS"; then + test -n "$as_me" && echo "$as_me: setting ALL_LINGUAS in configure.in is obsolete" || echo "setting ALL_LINGUAS in configure.in is obsolete" + fi + ALL_LINGUAS_=`sed -e "/^#/d" -e "s/#.*//" "$ac_given_srcdir/$ac_dir/LINGUAS"` + # Hide the ALL_LINGUAS assigment from automake. + eval 'ALL_LINGUAS''=$ALL_LINGUAS_' + POMAKEFILEDEPS="$POMAKEFILEDEPS LINGUAS" + else + # The set of available languages was given in configure.in. + eval 'ALL_LINGUAS''=$OBSOLETE_ALL_LINGUAS' + fi + # Compute POFILES + # as $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).po) + # Compute UPDATEPOFILES + # as $(foreach lang, $(ALL_LINGUAS), $(lang).po-update) + # Compute DUMMYPOFILES + # as $(foreach lang, $(ALL_LINGUAS), $(lang).nop) + # Compute GMOFILES + # as $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).gmo) + case "$ac_given_srcdir" in + .) srcdirpre= ;; + *) srcdirpre='$(srcdir)/' ;; + esac + POFILES= + UPDATEPOFILES= + DUMMYPOFILES= + GMOFILES= + for lang in $ALL_LINGUAS; do + POFILES="$POFILES $srcdirpre$lang.po" + UPDATEPOFILES="$UPDATEPOFILES $lang.po-update" + DUMMYPOFILES="$DUMMYPOFILES $lang.nop" + GMOFILES="$GMOFILES $srcdirpre$lang.gmo" + done + # CATALOGS depends on both $ac_dir and the user's LINGUAS + # environment variable. + INST_LINGUAS= + if test -n "$ALL_LINGUAS"; then + for presentlang in $ALL_LINGUAS; do + useit=no + if test "%UNSET%" != "$LINGUAS"; then + desiredlanguages="$LINGUAS" + else + desiredlanguages="$ALL_LINGUAS" + fi + for desiredlang in $desiredlanguages; do + # Use the presentlang catalog if desiredlang is + # a. equal to presentlang, or + # b. a variant of presentlang (because in this case, + # presentlang can be used as a fallback for messages + # which are not translated in the desiredlang catalog). + case "$desiredlang" in + "$presentlang"*) useit=yes;; + esac + done + if test $useit = yes; then + INST_LINGUAS="$INST_LINGUAS $presentlang" + fi + done + fi + CATALOGS= + if test -n "$INST_LINGUAS"; then + for lang in $INST_LINGUAS; do + CATALOGS="$CATALOGS $lang.gmo" + done + fi + test -n "$as_me" && echo "$as_me: creating $ac_dir/Makefile" || echo "creating $ac_dir/Makefile" + sed -e "/^POTFILES =/r $ac_dir/POTFILES" -e "/^# Makevars/r $ac_given_srcdir/$ac_dir/Makevars" -e "s|@POFILES@|$POFILES|g" -e "s|@UPDATEPOFILES@|$UPDATEPOFILES|g" -e "s|@DUMMYPOFILES@|$DUMMYPOFILES|g" -e "s|@GMOFILES@|$GMOFILES|g" -e "s|@CATALOGS@|$CATALOGS|g" -e "s|@POMAKEFILEDEPS@|$POMAKEFILEDEPS|g" "$ac_dir/Makefile.in" > "$ac_dir/Makefile" + for f in "$ac_given_srcdir/$ac_dir"/Rules-*; do + if test -f "$f"; then + case "$f" in + *.orig | *.bak | *~) ;; + *) cat "$f" >> "$ac_dir/Makefile" ;; + esac + fi + done + fi + ;; + esac + done], + [# Capture the value of obsolete ALL_LINGUAS because we need it to compute + # POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES, CATALOGS. But hide it + # from automake. + eval 'OBSOLETE_ALL_LINGUAS''="$ALL_LINGUAS"' + # Capture the value of LINGUAS because we need it to compute CATALOGS. + LINGUAS="${LINGUAS-%UNSET%}" + ]) +]) + +dnl Postprocesses a Makefile in a directory containing PO files. +AC_DEFUN([AM_POSTPROCESS_PO_MAKEFILE], +[ + # When this code is run, in config.status, two variables have already been + # set: + # - OBSOLETE_ALL_LINGUAS is the value of LINGUAS set in configure.in, + # - LINGUAS is the value of the environment variable LINGUAS at configure + # time. + +changequote(,)dnl + # Adjust a relative srcdir. + ac_dir=`echo "$ac_file"|sed 's%/[^/][^/]*$%%'` + ac_dir_suffix="/`echo "$ac_dir"|sed 's%^\./%%'`" + ac_dots=`echo "$ac_dir_suffix"|sed 's%/[^/]*%../%g'` + # In autoconf-2.13 it is called $ac_given_srcdir. + # In autoconf-2.50 it is called $srcdir. + test -n "$ac_given_srcdir" || ac_given_srcdir="$srcdir" + case "$ac_given_srcdir" in + .) top_srcdir=`echo $ac_dots|sed 's%/$%%'` ;; + /*) top_srcdir="$ac_given_srcdir" ;; + *) top_srcdir="$ac_dots$ac_given_srcdir" ;; + esac + + # Find a way to echo strings without interpreting backslash. + if test "X`(echo '\t') 2>/dev/null`" = 'X\t'; then + gt_echo='echo' + else + if test "X`(printf '%s\n' '\t') 2>/dev/null`" = 'X\t'; then + gt_echo='printf %s\n' + else + echo_func () { + cat < "$ac_file.tmp" + if grep -l '@TCLCATALOGS@' "$ac_file" > /dev/null; then + # Add dependencies that cannot be formulated as a simple suffix rule. + for lang in $ALL_LINGUAS; do + frobbedlang=`echo $lang | sed -e 's/\..*$//' -e 'y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/'` + cat >> "$ac_file.tmp" < /dev/null; then + # Add dependencies that cannot be formulated as a simple suffix rule. + for lang in $ALL_LINGUAS; do + frobbedlang=`echo $lang | sed -e 's/_/-/g' -e 's/^sr-CS/sr-SP/' -e 's/@latin$/-Latn/' -e 's/@cyrillic$/-Cyrl/' -e 's/^sr-SP$/sr-SP-Latn/' -e 's/^uz-UZ$/uz-UZ-Latn/'` + cat >> "$ac_file.tmp" <> "$ac_file.tmp" < +#include +/* The string "%2$d %1$d", with dollar characters protected from the shell's + dollar expansion (possibly an autoconf bug). */ +static char format[] = { '%', '2', '$', 'd', ' ', '%', '1', '$', 'd', '\0' }; +static char buf[100]; +int main () +{ + sprintf (buf, format, 33, 55); + return (strcmp (buf, "55 33") != 0); +}], gt_cv_func_printf_posix=yes, gt_cv_func_printf_posix=no, + [ + AC_EGREP_CPP(notposix, [ +#if defined __NetBSD__ || defined _MSC_VER || defined __MINGW32__ || defined __CYGWIN__ + notposix +#endif + ], gt_cv_func_printf_posix="guessing no", + gt_cv_func_printf_posix="guessing yes") + ]) + ]) + case $gt_cv_func_printf_posix in + *yes) + AC_DEFINE(HAVE_POSIX_PRINTF, 1, + [Define if your printf() function supports format strings with positions.]) + ;; + esac +]) + +# progtest.m4 serial 4 (gettext-0.14.2) +dnl Copyright (C) 1996-2003, 2005 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. +dnl +dnl This file can can be used in projects which are not available under +dnl the GNU General Public License or the GNU Library General Public +dnl License but which still want to provide support for the GNU gettext +dnl functionality. +dnl Please note that the actual code of the GNU gettext library is covered +dnl by the GNU Library General Public License, and the rest of the GNU +dnl gettext package package is covered by the GNU General Public License. +dnl They are *not* in the public domain. + +dnl Authors: +dnl Ulrich Drepper , 1996. + +AC_PREREQ(2.50) + +# Search path for a program which passes the given test. + +dnl AM_PATH_PROG_WITH_TEST(VARIABLE, PROG-TO-CHECK-FOR, +dnl TEST-PERFORMED-ON-FOUND_PROGRAM [, VALUE-IF-NOT-FOUND [, PATH]]) +AC_DEFUN([AM_PATH_PROG_WITH_TEST], +[ +# Prepare PATH_SEPARATOR. +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + echo "#! /bin/sh" >conf$$.sh + echo "exit 0" >>conf$$.sh + chmod +x conf$$.sh + if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then + PATH_SEPARATOR=';' + else + PATH_SEPARATOR=: + fi + rm -f conf$$.sh +fi + +# Find out how to test for executable files. Don't use a zero-byte file, +# as systems may use methods other than mode bits to determine executability. +cat >conf$$.file <<_ASEOF +#! /bin/sh +exit 0 +_ASEOF +chmod +x conf$$.file +if test -x conf$$.file >/dev/null 2>&1; then + ac_executable_p="test -x" +else + ac_executable_p="test -f" +fi +rm -f conf$$.file + +# Extract the first word of "$2", so it can be a program name with args. +set dummy $2; ac_word=[$]2 +AC_MSG_CHECKING([for $ac_word]) +AC_CACHE_VAL(ac_cv_path_$1, +[case "[$]$1" in + [[\\/]]* | ?:[[\\/]]*) + ac_cv_path_$1="[$]$1" # Let the user override the test with a path. + ;; + *) + ac_save_IFS="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in ifelse([$5], , $PATH, [$5]); do + IFS="$ac_save_IFS" + test -z "$ac_dir" && ac_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $ac_executable_p "$ac_dir/$ac_word$ac_exec_ext"; then + echo "$as_me: trying $ac_dir/$ac_word..." >&AS_MESSAGE_LOG_FD + if [$3]; then + ac_cv_path_$1="$ac_dir/$ac_word$ac_exec_ext" + break 2 + fi + fi + done + done + IFS="$ac_save_IFS" +dnl If no 4th arg is given, leave the cache variable unset, +dnl so AC_PATH_PROGS will keep looking. +ifelse([$4], , , [ test -z "[$]ac_cv_path_$1" && ac_cv_path_$1="$4" +])dnl + ;; +esac])dnl +$1="$ac_cv_path_$1" +if test ifelse([$4], , [-n "[$]$1"], ["[$]$1" != "$4"]); then + AC_MSG_RESULT([$]$1) +else + AC_MSG_RESULT(no) +fi +AC_SUBST($1)dnl +]) + +# signed.m4 serial 1 (gettext-0.10.40) +dnl Copyright (C) 2001-2002 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. + +AC_DEFUN([bh_C_SIGNED], +[ + AC_CACHE_CHECK([for signed], bh_cv_c_signed, + [AC_TRY_COMPILE(, [signed char x;], bh_cv_c_signed=yes, bh_cv_c_signed=no)]) + if test $bh_cv_c_signed = no; then + AC_DEFINE(signed, , + [Define to empty if the C compiler doesn't support this keyword.]) + fi +]) + +# size_max.m4 serial 2 +dnl Copyright (C) 2003 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. + +AC_DEFUN([gl_SIZE_MAX], +[ + AC_CHECK_HEADERS(stdint.h) + dnl First test whether the system already has SIZE_MAX. + AC_MSG_CHECKING([for SIZE_MAX]) + result= + AC_EGREP_CPP([Found it], [ +#include +#if HAVE_STDINT_H +#include +#endif +#ifdef SIZE_MAX +Found it +#endif +], result=yes) + if test -z "$result"; then + dnl Define it ourselves. Here we assume that the type 'size_t' is not wider + dnl than the type 'unsigned long'. + dnl The _AC_COMPUTE_INT macro works up to LONG_MAX, since it uses 'expr', + dnl which is guaranteed to work from LONG_MIN to LONG_MAX. + _AC_COMPUTE_INT([~(size_t)0 / 10], res_hi, + [#include ], result=?) + _AC_COMPUTE_INT([~(size_t)0 % 10], res_lo, + [#include ], result=?) + _AC_COMPUTE_INT([sizeof (size_t) <= sizeof (unsigned int)], fits_in_uint, + [#include ], result=?) + if test "$fits_in_uint" = 1; then + dnl Even though SIZE_MAX fits in an unsigned int, it must be of type + dnl 'unsigned long' if the type 'size_t' is the same as 'unsigned long'. + AC_TRY_COMPILE([#include + extern size_t foo; + extern unsigned long foo; + ], [], fits_in_uint=0) + fi + if test -z "$result"; then + if test "$fits_in_uint" = 1; then + result="$res_hi$res_lo"U + else + result="$res_hi$res_lo"UL + fi + else + dnl Shouldn't happen, but who knows... + result='~(size_t)0' + fi + fi + AC_MSG_RESULT([$result]) + if test "$result" != yes; then + AC_DEFINE_UNQUOTED([SIZE_MAX], [$result], + [Define as the maximum value of type 'size_t', if the system doesn't define it.]) + fi +]) + +# stdint_h.m4 serial 5 +dnl Copyright (C) 1997-2004 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Paul Eggert. + +# Define HAVE_STDINT_H_WITH_UINTMAX if exists, +# doesn't clash with , and declares uintmax_t. + +AC_DEFUN([gl_AC_HEADER_STDINT_H], +[ + AC_CACHE_CHECK([for stdint.h], gl_cv_header_stdint_h, + [AC_TRY_COMPILE( + [#include +#include ], + [uintmax_t i = (uintmax_t) -1;], + gl_cv_header_stdint_h=yes, + gl_cv_header_stdint_h=no)]) + if test $gl_cv_header_stdint_h = yes; then + AC_DEFINE_UNQUOTED(HAVE_STDINT_H_WITH_UINTMAX, 1, + [Define if exists, doesn't clash with , + and declares uintmax_t. ]) + fi +]) + +# uintmax_t.m4 serial 9 +dnl Copyright (C) 1997-2004 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Paul Eggert. + +AC_PREREQ(2.13) + +# Define uintmax_t to 'unsigned long' or 'unsigned long long' +# if it is not already defined in or . + +AC_DEFUN([gl_AC_TYPE_UINTMAX_T], +[ + AC_REQUIRE([gl_AC_HEADER_INTTYPES_H]) + AC_REQUIRE([gl_AC_HEADER_STDINT_H]) + if test $gl_cv_header_inttypes_h = no && test $gl_cv_header_stdint_h = no; then + AC_REQUIRE([gl_AC_TYPE_UNSIGNED_LONG_LONG]) + test $ac_cv_type_unsigned_long_long = yes \ + && ac_type='unsigned long long' \ + || ac_type='unsigned long' + AC_DEFINE_UNQUOTED(uintmax_t, $ac_type, + [Define to unsigned long or unsigned long long + if and don't define.]) + else + AC_DEFINE(HAVE_UINTMAX_T, 1, + [Define if you have the 'uintmax_t' type in or .]) + fi +]) + +# ulonglong.m4 serial 4 +dnl Copyright (C) 1999-2004 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Paul Eggert. + +# Define HAVE_UNSIGNED_LONG_LONG if 'unsigned long long' works. + +AC_DEFUN([gl_AC_TYPE_UNSIGNED_LONG_LONG], +[ + AC_CACHE_CHECK([for unsigned long long], ac_cv_type_unsigned_long_long, + [AC_TRY_LINK([unsigned long long ull = 1ULL; int i = 63;], + [unsigned long long ullmax = (unsigned long long) -1; + return ull << i | ull >> i | ullmax / ull | ullmax % ull;], + ac_cv_type_unsigned_long_long=yes, + ac_cv_type_unsigned_long_long=no)]) + if test $ac_cv_type_unsigned_long_long = yes; then + AC_DEFINE(HAVE_UNSIGNED_LONG_LONG, 1, + [Define if you have the 'unsigned long long' type.]) + fi +]) + +# wchar_t.m4 serial 1 (gettext-0.12) +dnl Copyright (C) 2002-2003 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. +dnl Test whether has the 'wchar_t' type. +dnl Prerequisite: AC_PROG_CC + +AC_DEFUN([gt_TYPE_WCHAR_T], +[ + AC_CACHE_CHECK([for wchar_t], gt_cv_c_wchar_t, + [AC_TRY_COMPILE([#include + wchar_t foo = (wchar_t)'\0';], , + gt_cv_c_wchar_t=yes, gt_cv_c_wchar_t=no)]) + if test $gt_cv_c_wchar_t = yes; then + AC_DEFINE(HAVE_WCHAR_T, 1, [Define if you have the 'wchar_t' type.]) + fi +]) + +# wint_t.m4 serial 1 (gettext-0.12) +dnl Copyright (C) 2003 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl From Bruno Haible. +dnl Test whether has the 'wint_t' type. +dnl Prerequisite: AC_PROG_CC + +AC_DEFUN([gt_TYPE_WINT_T], +[ + AC_CACHE_CHECK([for wint_t], gt_cv_c_wint_t, + [AC_TRY_COMPILE([#include + wint_t foo = (wchar_t)'\0';], , + gt_cv_c_wint_t=yes, gt_cv_c_wint_t=no)]) + if test $gt_cv_c_wint_t = yes; then + AC_DEFINE(HAVE_WINT_T, 1, [Define if you have the 'wint_t' type.]) + fi +]) + +# xsize.m4 serial 3 +dnl Copyright (C) 2003-2004 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +AC_DEFUN([gl_XSIZE], +[ + dnl Prerequisites of lib/xsize.h. + AC_REQUIRE([gl_SIZE_MAX]) + AC_REQUIRE([AC_C_INLINE]) + AC_CHECK_HEADERS(stdint.h) +]) + +# Copyright (C) 2002, 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_AUTOMAKE_VERSION(VERSION) +# ---------------------------- +# Automake X.Y traces this macro to ensure aclocal.m4 has been +# generated from the m4 files accompanying Automake X.Y. +AC_DEFUN([AM_AUTOMAKE_VERSION], [am__api_version="1.9"]) + +# AM_SET_CURRENT_AUTOMAKE_VERSION +# ------------------------------- +# Call AM_AUTOMAKE_VERSION so it can be traced. +# This function is AC_REQUIREd by AC_INIT_AUTOMAKE. +AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], + [AM_AUTOMAKE_VERSION([1.9.6])]) + +# AM_AUX_DIR_EXPAND -*- Autoconf -*- + +# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets +# $ac_aux_dir to `$srcdir/foo'. In other projects, it is set to +# `$srcdir', `$srcdir/..', or `$srcdir/../..'. +# +# Of course, Automake must honor this variable whenever it calls a +# tool from the auxiliary directory. The problem is that $srcdir (and +# therefore $ac_aux_dir as well) can be either absolute or relative, +# depending on how configure is run. This is pretty annoying, since +# it makes $ac_aux_dir quite unusable in subdirectories: in the top +# source directory, any form will work fine, but in subdirectories a +# relative path needs to be adjusted first. +# +# $ac_aux_dir/missing +# fails when called from a subdirectory if $ac_aux_dir is relative +# $top_srcdir/$ac_aux_dir/missing +# fails if $ac_aux_dir is absolute, +# fails when called from a subdirectory in a VPATH build with +# a relative $ac_aux_dir +# +# The reason of the latter failure is that $top_srcdir and $ac_aux_dir +# are both prefixed by $srcdir. In an in-source build this is usually +# harmless because $srcdir is `.', but things will broke when you +# start a VPATH build or use an absolute $srcdir. +# +# So we could use something similar to $top_srcdir/$ac_aux_dir/missing, +# iff we strip the leading $srcdir from $ac_aux_dir. That would be: +# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` +# and then we would define $MISSING as +# MISSING="\${SHELL} $am_aux_dir/missing" +# This will work as long as MISSING is not called from configure, because +# unfortunately $(top_srcdir) has no meaning in configure. +# However there are other variables, like CC, which are often used in +# configure, and could therefore not use this "fixed" $ac_aux_dir. +# +# Another solution, used here, is to always expand $ac_aux_dir to an +# absolute PATH. The drawback is that using absolute paths prevent a +# configured tree to be moved without reconfiguration. + +AC_DEFUN([AM_AUX_DIR_EXPAND], +[dnl Rely on autoconf to set up CDPATH properly. +AC_PREREQ([2.50])dnl +# expand $ac_aux_dir to an absolute path +am_aux_dir=`cd $ac_aux_dir && pwd` +]) + +# AM_CONDITIONAL -*- Autoconf -*- + +# Copyright (C) 1997, 2000, 2001, 2003, 2004, 2005 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 7 + +# AM_CONDITIONAL(NAME, SHELL-CONDITION) +# ------------------------------------- +# Define a conditional. +AC_DEFUN([AM_CONDITIONAL], +[AC_PREREQ(2.52)dnl + ifelse([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])], + [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl +AC_SUBST([$1_TRUE]) +AC_SUBST([$1_FALSE]) +if $2; then + $1_TRUE= + $1_FALSE='#' +else + $1_TRUE='#' + $1_FALSE= +fi +AC_CONFIG_COMMANDS_PRE( +[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then + AC_MSG_ERROR([[conditional "$1" was never defined. +Usually this means the macro was only invoked conditionally.]]) +fi])]) + + +# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 8 + +# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be +# written in clear, in which case automake, when reading aclocal.m4, +# will think it sees a *use*, and therefore will trigger all it's +# C support machinery. Also note that it means that autoscan, seeing +# CC etc. in the Makefile, will ask for an AC_PROG_CC use... + + +# _AM_DEPENDENCIES(NAME) +# ---------------------- +# See how the compiler implements dependency checking. +# NAME is "CC", "CXX", "GCJ", or "OBJC". +# We try a few techniques and use that to set a single cache variable. +# +# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was +# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular +# dependency, and given that the user is not expected to run this macro, +# just rely on AC_PROG_CC. +AC_DEFUN([_AM_DEPENDENCIES], +[AC_REQUIRE([AM_SET_DEPDIR])dnl +AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl +AC_REQUIRE([AM_MAKE_INCLUDE])dnl +AC_REQUIRE([AM_DEP_TRACK])dnl + +ifelse([$1], CC, [depcc="$CC" am_compiler_list=], + [$1], CXX, [depcc="$CXX" am_compiler_list=], + [$1], OBJC, [depcc="$OBJC" am_compiler_list='gcc3 gcc'], + [$1], GCJ, [depcc="$GCJ" am_compiler_list='gcc3 gcc'], + [depcc="$$1" am_compiler_list=]) + +AC_CACHE_CHECK([dependency style of $depcc], + [am_cv_$1_dependencies_compiler_type], +[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named `D' -- because `-MD' means `put the output + # in D'. + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_$1_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp` + fi + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with + # Solaris 8's {/usr,}/bin/sh. + touch sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + case $depmode in + nosideeffect) + # after this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + none) break ;; + esac + # We check with `-c' and `-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle `-M -o', and we need to detect this. + if depmode=$depmode \ + source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_$1_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_$1_dependencies_compiler_type=none +fi +]) +AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type]) +AM_CONDITIONAL([am__fastdep$1], [ + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_$1_dependencies_compiler_type" = gcc3]) +]) + + +# AM_SET_DEPDIR +# ------------- +# Choose a directory name for dependency files. +# This macro is AC_REQUIREd in _AM_DEPENDENCIES +AC_DEFUN([AM_SET_DEPDIR], +[AC_REQUIRE([AM_SET_LEADING_DOT])dnl +AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl +]) + + +# AM_DEP_TRACK +# ------------ +AC_DEFUN([AM_DEP_TRACK], +[AC_ARG_ENABLE(dependency-tracking, +[ --disable-dependency-tracking speeds up one-time build + --enable-dependency-tracking do not reject slow dependency extractors]) +if test "x$enable_dependency_tracking" != xno; then + am_depcomp="$ac_aux_dir/depcomp" + AMDEPBACKSLASH='\' +fi +AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno]) +AC_SUBST([AMDEPBACKSLASH]) +]) + +# Generate code to set up dependency tracking. -*- Autoconf -*- + +# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +#serial 3 + +# _AM_OUTPUT_DEPENDENCY_COMMANDS +# ------------------------------ +AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], +[for mf in $CONFIG_FILES; do + # Strip MF so we end up with the name of the file. + mf=`echo "$mf" | sed -e 's/:.*$//'` + # Check whether this is an Automake generated Makefile or not. + # We used to match only the files named `Makefile.in', but + # some people rename them; so instead we look at the file content. + # Grep'ing the first line is not enough: some people post-process + # each Makefile.in and add a new line on top of each file to say so. + # So let's grep whole file. + if grep '^#.*generated by automake' $mf > /dev/null 2>&1; then + dirpart=`AS_DIRNAME("$mf")` + else + continue + fi + # Extract the definition of DEPDIR, am__include, and am__quote + # from the Makefile without running `make'. + DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` + test -z "$DEPDIR" && continue + am__include=`sed -n 's/^am__include = //p' < "$mf"` + test -z "am__include" && continue + am__quote=`sed -n 's/^am__quote = //p' < "$mf"` + # When using ansi2knr, U may be empty or an underscore; expand it + U=`sed -n 's/^U = //p' < "$mf"` + # Find all dependency output files, they are included files with + # $(DEPDIR) in their names. We invoke sed twice because it is the + # simplest approach to changing $(DEPDIR) to its actual value in the + # expansion. + for file in `sed -n " + s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ + sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do + # Make sure the directory exists. + test -f "$dirpart/$file" && continue + fdir=`AS_DIRNAME(["$file"])` + AS_MKDIR_P([$dirpart/$fdir]) + # echo "creating $dirpart/$file" + echo '# dummy' > "$dirpart/$file" + done +done +])# _AM_OUTPUT_DEPENDENCY_COMMANDS + + +# AM_OUTPUT_DEPENDENCY_COMMANDS +# ----------------------------- +# This macro should only be invoked once -- use via AC_REQUIRE. +# +# This code is only required when automatic dependency tracking +# is enabled. FIXME. This creates each `.P' file that we will +# need in order to bootstrap the dependency handling code. +AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], +[AC_CONFIG_COMMANDS([depfiles], + [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], + [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"]) +]) + +# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 8 + +# AM_CONFIG_HEADER is obsolete. It has been replaced by AC_CONFIG_HEADERS. +AU_DEFUN([AM_CONFIG_HEADER], [AC_CONFIG_HEADERS($@)]) + +# Do all the work for Automake. -*- Autoconf -*- + +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 12 + +# This macro actually does too much. Some checks are only needed if +# your package does certain things. But this isn't really a big deal. + +# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]) +# AM_INIT_AUTOMAKE([OPTIONS]) +# ----------------------------------------------- +# The call with PACKAGE and VERSION arguments is the old style +# call (pre autoconf-2.50), which is being phased out. PACKAGE +# and VERSION should now be passed to AC_INIT and removed from +# the call to AM_INIT_AUTOMAKE. +# We support both call styles for the transition. After +# the next Automake release, Autoconf can make the AC_INIT +# arguments mandatory, and then we can depend on a new Autoconf +# release and drop the old call support. +AC_DEFUN([AM_INIT_AUTOMAKE], +[AC_PREREQ([2.58])dnl +dnl Autoconf wants to disallow AM_ names. We explicitly allow +dnl the ones we care about. +m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl +AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl +AC_REQUIRE([AC_PROG_INSTALL])dnl +# test to see if srcdir already configured +if test "`cd $srcdir && pwd`" != "`pwd`" && + test -f $srcdir/config.status; then + AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) +fi + +# test whether we have cygpath +if test -z "$CYGPATH_W"; then + if (cygpath --version) >/dev/null 2>/dev/null; then + CYGPATH_W='cygpath -w' + else + CYGPATH_W=echo + fi +fi +AC_SUBST([CYGPATH_W]) + +# Define the identity of the package. +dnl Distinguish between old-style and new-style calls. +m4_ifval([$2], +[m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl + AC_SUBST([PACKAGE], [$1])dnl + AC_SUBST([VERSION], [$2])], +[_AM_SET_OPTIONS([$1])dnl + AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl + AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl + +_AM_IF_OPTION([no-define],, +[AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package]) + AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package])])dnl + +# Some tools Automake needs. +AC_REQUIRE([AM_SANITY_CHECK])dnl +AC_REQUIRE([AC_ARG_PROGRAM])dnl +AM_MISSING_PROG(ACLOCAL, aclocal-${am__api_version}) +AM_MISSING_PROG(AUTOCONF, autoconf) +AM_MISSING_PROG(AUTOMAKE, automake-${am__api_version}) +AM_MISSING_PROG(AUTOHEADER, autoheader) +AM_MISSING_PROG(MAKEINFO, makeinfo) +AM_PROG_INSTALL_SH +AM_PROG_INSTALL_STRIP +AC_REQUIRE([AM_PROG_MKDIR_P])dnl +# We need awk for the "check" target. The system "awk" is bad on +# some platforms. +AC_REQUIRE([AC_PROG_AWK])dnl +AC_REQUIRE([AC_PROG_MAKE_SET])dnl +AC_REQUIRE([AM_SET_LEADING_DOT])dnl +_AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])], + [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])], + [_AM_PROG_TAR([v7])])]) +_AM_IF_OPTION([no-dependencies],, +[AC_PROVIDE_IFELSE([AC_PROG_CC], + [_AM_DEPENDENCIES(CC)], + [define([AC_PROG_CC], + defn([AC_PROG_CC])[_AM_DEPENDENCIES(CC)])])dnl +AC_PROVIDE_IFELSE([AC_PROG_CXX], + [_AM_DEPENDENCIES(CXX)], + [define([AC_PROG_CXX], + defn([AC_PROG_CXX])[_AM_DEPENDENCIES(CXX)])])dnl +]) +]) + + +# When config.status generates a header, we must update the stamp-h file. +# This file resides in the same directory as the config header +# that is generated. The stamp files are numbered to have different names. + +# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the +# loop where config.status creates the headers, so we can generate +# our stamp files there. +AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], +[# Compute $1's index in $config_headers. +_am_stamp_count=1 +for _am_header in $config_headers :; do + case $_am_header in + $1 | $1:* ) + break ;; + * ) + _am_stamp_count=`expr $_am_stamp_count + 1` ;; + esac +done +echo "timestamp for $1" >`AS_DIRNAME([$1])`/stamp-h[]$_am_stamp_count]) + +# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_PROG_INSTALL_SH +# ------------------ +# Define $install_sh. +AC_DEFUN([AM_PROG_INSTALL_SH], +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl +install_sh=${install_sh-"$am_aux_dir/install-sh"} +AC_SUBST(install_sh)]) + +# Copyright (C) 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 2 + +# Check whether the underlying file-system supports filenames +# with a leading dot. For instance MS-DOS doesn't. +AC_DEFUN([AM_SET_LEADING_DOT], +[rm -rf .tst 2>/dev/null +mkdir .tst 2>/dev/null +if test -d .tst; then + am__leading_dot=. +else + am__leading_dot=_ +fi +rmdir .tst 2>/dev/null +AC_SUBST([am__leading_dot])]) + +# Check to see how 'make' treats includes. -*- Autoconf -*- + +# Copyright (C) 2001, 2002, 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 3 + +# AM_MAKE_INCLUDE() +# ----------------- +# Check to see how make treats includes. +AC_DEFUN([AM_MAKE_INCLUDE], +[am_make=${MAKE-make} +cat > confinc << 'END' +am__doit: + @echo done +.PHONY: am__doit +END +# If we don't find an include directive, just comment out the code. +AC_MSG_CHECKING([for style of include used by $am_make]) +am__include="#" +am__quote= +_am_result=none +# First try GNU make style include. +echo "include confinc" > confmf +# We grep out `Entering directory' and `Leaving directory' +# messages which can occur if `w' ends up in MAKEFLAGS. +# In particular we don't look at `^make:' because GNU make might +# be invoked under some other name (usually "gmake"), in which +# case it prints its new name instead of `make'. +if test "`$am_make -s -f confmf 2> /dev/null | grep -v 'ing directory'`" = "done"; then + am__include=include + am__quote= + _am_result=GNU +fi +# Now try BSD make style include. +if test "$am__include" = "#"; then + echo '.include "confinc"' > confmf + if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then + am__include=.include + am__quote="\"" + _am_result=BSD + fi +fi +AC_SUBST([am__include]) +AC_SUBST([am__quote]) +AC_MSG_RESULT([$_am_result]) +rm -f confinc confmf +]) + +# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- + +# Copyright (C) 1997, 1999, 2000, 2001, 2003, 2005 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 4 + +# AM_MISSING_PROG(NAME, PROGRAM) +# ------------------------------ +AC_DEFUN([AM_MISSING_PROG], +[AC_REQUIRE([AM_MISSING_HAS_RUN]) +$1=${$1-"${am_missing_run}$2"} +AC_SUBST($1)]) + + +# AM_MISSING_HAS_RUN +# ------------------ +# Define MISSING if not defined so far and test if it supports --run. +# If it does, set am_missing_run to use it, otherwise, to nothing. +AC_DEFUN([AM_MISSING_HAS_RUN], +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl +test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing" +# Use eval to expand $SHELL +if eval "$MISSING --run true"; then + am_missing_run="$MISSING --run " +else + am_missing_run= + AC_MSG_WARN([`missing' script is too old or missing]) +fi +]) + +# Copyright (C) 2003, 2004, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_PROG_MKDIR_P +# --------------- +# Check whether `mkdir -p' is supported, fallback to mkinstalldirs otherwise. +# +# Automake 1.8 used `mkdir -m 0755 -p --' to ensure that directories +# created by `make install' are always world readable, even if the +# installer happens to have an overly restrictive umask (e.g. 077). +# This was a mistake. There are at least two reasons why we must not +# use `-m 0755': +# - it causes special bits like SGID to be ignored, +# - it may be too restrictive (some setups expect 775 directories). +# +# Do not use -m 0755 and let people choose whatever they expect by +# setting umask. +# +# We cannot accept any implementation of `mkdir' that recognizes `-p'. +# Some implementations (such as Solaris 8's) are not thread-safe: if a +# parallel make tries to run `mkdir -p a/b' and `mkdir -p a/c' +# concurrently, both version can detect that a/ is missing, but only +# one can create it and the other will error out. Consequently we +# restrict ourselves to GNU make (using the --version option ensures +# this.) +AC_DEFUN([AM_PROG_MKDIR_P], +[if mkdir -p --version . >/dev/null 2>&1 && test ! -d ./--version; then + # We used to keeping the `.' as first argument, in order to + # allow $(mkdir_p) to be used without argument. As in + # $(mkdir_p) $(somedir) + # where $(somedir) is conditionally defined. However this is wrong + # for two reasons: + # 1. if the package is installed by a user who cannot write `.' + # make install will fail, + # 2. the above comment should most certainly read + # $(mkdir_p) $(DESTDIR)$(somedir) + # so it does not work when $(somedir) is undefined and + # $(DESTDIR) is not. + # To support the latter case, we have to write + # test -z "$(somedir)" || $(mkdir_p) $(DESTDIR)$(somedir), + # so the `.' trick is pointless. + mkdir_p='mkdir -p --' +else + # On NextStep and OpenStep, the `mkdir' command does not + # recognize any option. It will interpret all options as + # directories to create, and then abort because `.' already + # exists. + for d in ./-p ./--version; + do + test -d $d && rmdir $d + done + # $(mkinstalldirs) is defined by Automake if mkinstalldirs exists. + if test -f "$ac_aux_dir/mkinstalldirs"; then + mkdir_p='$(mkinstalldirs)' + else + mkdir_p='$(install_sh) -d' + fi +fi +AC_SUBST([mkdir_p])]) + +# Helper functions for option handling. -*- Autoconf -*- + +# Copyright (C) 2001, 2002, 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 3 + +# _AM_MANGLE_OPTION(NAME) +# ----------------------- +AC_DEFUN([_AM_MANGLE_OPTION], +[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])]) + +# _AM_SET_OPTION(NAME) +# ------------------------------ +# Set option NAME. Presently that only means defining a flag for this option. +AC_DEFUN([_AM_SET_OPTION], +[m4_define(_AM_MANGLE_OPTION([$1]), 1)]) + +# _AM_SET_OPTIONS(OPTIONS) +# ---------------------------------- +# OPTIONS is a space-separated list of Automake options. +AC_DEFUN([_AM_SET_OPTIONS], +[AC_FOREACH([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])]) + +# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET]) +# ------------------------------------------- +# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. +AC_DEFUN([_AM_IF_OPTION], +[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) + +# Check to make sure that the build environment is sane. -*- Autoconf -*- + +# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 4 + +# AM_SANITY_CHECK +# --------------- +AC_DEFUN([AM_SANITY_CHECK], +[AC_MSG_CHECKING([whether build environment is sane]) +# Just in case +sleep 1 +echo timestamp > conftest.file +# Do `set' in a subshell so we don't clobber the current shell's +# arguments. Must try -L first in case configure is actually a +# symlink; some systems play weird games with the mod time of symlinks +# (eg FreeBSD returns the mod time of the symlink's containing +# directory). +if ( + set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null` + if test "$[*]" = "X"; then + # -L didn't work. + set X `ls -t $srcdir/configure conftest.file` + fi + rm -f conftest.file + if test "$[*]" != "X $srcdir/configure conftest.file" \ + && test "$[*]" != "X conftest.file $srcdir/configure"; then + + # If neither matched, then we have a broken ls. This can happen + # if, for instance, CONFIG_SHELL is bash and it inherits a + # broken ls alias from the environment. This has actually + # happened. Such a system could not be considered "sane". + AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken +alias in your environment]) + fi + + test "$[2]" = conftest.file + ) +then + # Ok. + : +else + AC_MSG_ERROR([newly created file is older than distributed files! +Check your system clock]) +fi +AC_MSG_RESULT(yes)]) + +# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_PROG_INSTALL_STRIP +# --------------------- +# One issue with vendor `install' (even GNU) is that you can't +# specify the program used to strip binaries. This is especially +# annoying in cross-compiling environments, where the build's strip +# is unlikely to handle the host's binaries. +# Fortunately install-sh will honor a STRIPPROG variable, so we +# always use install-sh in `make install-strip', and initialize +# STRIPPROG with the value of the STRIP variable (set by the user). +AC_DEFUN([AM_PROG_INSTALL_STRIP], +[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl +# Installed binaries are usually stripped using `strip' when the user +# run `make install-strip'. However `strip' might not be the right +# tool to use in cross-compilation environments, therefore Automake +# will honor the `STRIP' environment variable to overrule this program. +dnl Don't test for $cross_compiling = yes, because it might be `maybe'. +if test "$cross_compiling" != no; then + AC_CHECK_TOOL([STRIP], [strip], :) +fi +INSTALL_STRIP_PROGRAM="\${SHELL} \$(install_sh) -c -s" +AC_SUBST([INSTALL_STRIP_PROGRAM])]) + +# Check how to create a tarball. -*- Autoconf -*- + +# Copyright (C) 2004, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 2 + +# _AM_PROG_TAR(FORMAT) +# -------------------- +# Check how to create a tarball in format FORMAT. +# FORMAT should be one of `v7', `ustar', or `pax'. +# +# Substitute a variable $(am__tar) that is a command +# writing to stdout a FORMAT-tarball containing the directory +# $tardir. +# tardir=directory && $(am__tar) > result.tar +# +# Substitute a variable $(am__untar) that extract such +# a tarball read from stdin. +# $(am__untar) < result.tar +AC_DEFUN([_AM_PROG_TAR], +[# Always define AMTAR for backward compatibility. +AM_MISSING_PROG([AMTAR], [tar]) +m4_if([$1], [v7], + [am__tar='${AMTAR} chof - "$$tardir"'; am__untar='${AMTAR} xf -'], + [m4_case([$1], [ustar],, [pax],, + [m4_fatal([Unknown tar format])]) +AC_MSG_CHECKING([how to create a $1 tar archive]) +# Loop over all known methods to create a tar archive until one works. +_am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' +_am_tools=${am_cv_prog_tar_$1-$_am_tools} +# Do not fold the above two line into one, because Tru64 sh and +# Solaris sh will not grok spaces in the rhs of `-'. +for _am_tool in $_am_tools +do + case $_am_tool in + gnutar) + for _am_tar in tar gnutar gtar; + do + AM_RUN_LOG([$_am_tar --version]) && break + done + am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' + am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' + am__untar="$_am_tar -xf -" + ;; + plaintar) + # Must skip GNU tar: if it does not support --format= it doesn't create + # ustar tarball either. + (tar --version) >/dev/null 2>&1 && continue + am__tar='tar chf - "$$tardir"' + am__tar_='tar chf - "$tardir"' + am__untar='tar xf -' + ;; + pax) + am__tar='pax -L -x $1 -w "$$tardir"' + am__tar_='pax -L -x $1 -w "$tardir"' + am__untar='pax -r' + ;; + cpio) + am__tar='find "$$tardir" -print | cpio -o -H $1 -L' + am__tar_='find "$tardir" -print | cpio -o -H $1 -L' + am__untar='cpio -i -H $1 -d' + ;; + none) + am__tar=false + am__tar_=false + am__untar=false + ;; + esac + + # If the value was cached, stop now. We just wanted to have am__tar + # and am__untar set. + test -n "${am_cv_prog_tar_$1}" && break + + # tar/untar a dummy directory, and stop if the command works + rm -rf conftest.dir + mkdir conftest.dir + echo GrepMe > conftest.dir/file + AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) + rm -rf conftest.dir + if test -s conftest.tar; then + AM_RUN_LOG([$am__untar /dev/null 2>&1 && break + fi +done +rm -rf conftest.dir + +AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) +AC_MSG_RESULT([$am_cv_prog_tar_$1])]) +AC_SUBST([am__tar]) +AC_SUBST([am__untar]) +]) # _AM_PROG_TAR + +m4_include([acinclude.m4]) diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/Makefile.am b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/Makefile.am new file mode 100644 index 0000000000..eff2f893fc --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/Makefile.am @@ -0,0 +1,36 @@ +## Process this file with automake to produce Makefile.in +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: apps Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 5.6.1999 +# ************************************************************************* + +INCLUDES = -I.. + +bin_PROGRAMS = gsmsmsstore gsmctl gsmsmsd gsmpb gsmsendsms + +# build gsmsmsd from gsmsmsd.cc and libgsmme.la +gsmsmsd_SOURCES = gsmsmsd.cc +gsmsmsd_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build gsmpb from gsmpb.cc and libgsmme.la +gsmpb_SOURCES = gsmpb.cc +gsmpb_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build gsmctl from gsmctl.cc and libgsmme.la +gsmctl_SOURCES = gsmctl.cc +gsmctl_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build gsmsendsms from gsmsendsms.cc and libgsmme.la +gsmsendsms_SOURCES = gsmsendsms.cc +gsmsendsms_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build gsmsmsstore from gsmsmsstore.cc and libgsmme.la +gsmsmsstore_SOURCES = gsmsmsstore.cc +gsmsmsstore_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/Makefile.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/Makefile.in new file mode 100644 index 0000000000..c18e2df06b --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/Makefile.in @@ -0,0 +1,442 @@ +# Makefile.in generated by automake 1.6.3 from Makefile.am. +# @configure_input@ + +# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002 +# Free Software Foundation, Inc. +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +@SET_MAKE@ + +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: apps Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 5.6.1999 +# ************************************************************************* +SHELL = @SHELL@ + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ + +bindir = @bindir@ +sbindir = @sbindir@ +libexecdir = @libexecdir@ +datadir = @datadir@ +sysconfdir = @sysconfdir@ +sharedstatedir = @sharedstatedir@ +localstatedir = @localstatedir@ +libdir = @libdir@ +infodir = @infodir@ +mandir = @mandir@ +includedir = @includedir@ +oldincludedir = /usr/include +pkgdatadir = $(datadir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ +top_builddir = .. + +ACLOCAL = @ACLOCAL@ +AUTOCONF = @AUTOCONF@ +AUTOMAKE = @AUTOMAKE@ +AUTOHEADER = @AUTOHEADER@ + +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd +INSTALL = @INSTALL@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_DATA = @INSTALL_DATA@ +install_sh_DATA = $(install_sh) -c -m 644 +install_sh_PROGRAM = $(install_sh) -c +install_sh_SCRIPT = $(install_sh) -c +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +INSTALL_HEADER = $(INSTALL_DATA) +transform = @program_transform_name@ +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +host_alias = @host_alias@ +host_triplet = @host@ + +EXEEXT = @EXEEXT@ +OBJEXT = @OBJEXT@ +PATH_SEPARATOR = @PATH_SEPARATOR@ +AMTAR = @AMTAR@ +AS = @AS@ +AWK = @AWK@ +BUILD_INCLUDED_LIBINTL = @BUILD_INCLUDED_LIBINTL@ +CATOBJEXT = @CATOBJEXT@ +CC = @CC@ +CPP = @CPP@ +CXX = @CXX@ +DATADIRNAME = @DATADIRNAME@ +DEPDIR = @DEPDIR@ +DLLTOOL = @DLLTOOL@ +ECHO = @ECHO@ +GENCAT = @GENCAT@ +GLIBC21 = @GLIBC21@ +GMSGFMT = @GMSGFMT@ +GSM_VERSION = @GSM_VERSION@ +HAVE_LIB = @HAVE_LIB@ +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ +INSTOBJEXT = @INSTOBJEXT@ +INTLBISON = @INTLBISON@ +INTLLIBS = @INTLLIBS@ +INTLOBJS = @INTLOBJS@ +INTL_LIBTOOL_SUFFIX_PREFIX = @INTL_LIBTOOL_SUFFIX_PREFIX@ +LIB = @LIB@ +LIBICONV = @LIBICONV@ +LIBINTL = @LIBINTL@ +LIBTOOL = @LIBTOOL@ +LN_S = @LN_S@ +LTLIB = @LTLIB@ +LTLIBICONV = @LTLIBICONV@ +LTLIBINTL = @LTLIBINTL@ +MKINSTALLDIRS = @MKINSTALLDIRS@ +OBJDUMP = @OBJDUMP@ +PACKAGE = @PACKAGE@ +POSUB = @POSUB@ +RANLIB = @RANLIB@ +STRIP = @STRIP@ +USE_INCLUDED_LIBINTL = @USE_INCLUDED_LIBINTL@ +USE_NLS = @USE_NLS@ +VERSION = @VERSION@ +am__include = @am__include@ +am__quote = @am__quote@ +install_sh = @install_sh@ + +INCLUDES = -I.. + +bin_PROGRAMS = gsmsmsstore gsmctl gsmsmsd gsmpb gsmsendsms + +# build gsmsmsd from gsmsmsd.cc and libgsmme.la +gsmsmsd_SOURCES = gsmsmsd.cc +gsmsmsd_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build gsmpb from gsmpb.cc and libgsmme.la +gsmpb_SOURCES = gsmpb.cc +gsmpb_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build gsmctl from gsmctl.cc and libgsmme.la +gsmctl_SOURCES = gsmctl.cc +gsmctl_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build gsmsendsms from gsmsendsms.cc and libgsmme.la +gsmsendsms_SOURCES = gsmsendsms.cc +gsmsendsms_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build gsmsmsstore from gsmsmsstore.cc and libgsmme.la +gsmsmsstore_SOURCES = gsmsmsstore.cc +gsmsmsstore_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) +subdir = apps +mkinstalldirs = $(SHELL) $(top_srcdir)/scripts/mkinstalldirs +CONFIG_HEADER = $(top_builddir)/gsm_config.h +CONFIG_CLEAN_FILES = +bin_PROGRAMS = gsmsmsstore$(EXEEXT) gsmctl$(EXEEXT) gsmsmsd$(EXEEXT) \ + gsmpb$(EXEEXT) gsmsendsms$(EXEEXT) +PROGRAMS = $(bin_PROGRAMS) + +am_gsmctl_OBJECTS = gsmctl.$(OBJEXT) +gsmctl_OBJECTS = $(am_gsmctl_OBJECTS) +gsmctl_DEPENDENCIES = ../gsmlib/libgsmme.la +gsmctl_LDFLAGS = +am_gsmpb_OBJECTS = gsmpb.$(OBJEXT) +gsmpb_OBJECTS = $(am_gsmpb_OBJECTS) +gsmpb_DEPENDENCIES = ../gsmlib/libgsmme.la +gsmpb_LDFLAGS = +am_gsmsendsms_OBJECTS = gsmsendsms.$(OBJEXT) +gsmsendsms_OBJECTS = $(am_gsmsendsms_OBJECTS) +gsmsendsms_DEPENDENCIES = ../gsmlib/libgsmme.la +gsmsendsms_LDFLAGS = +am_gsmsmsd_OBJECTS = gsmsmsd.$(OBJEXT) +gsmsmsd_OBJECTS = $(am_gsmsmsd_OBJECTS) +gsmsmsd_DEPENDENCIES = ../gsmlib/libgsmme.la +gsmsmsd_LDFLAGS = +am_gsmsmsstore_OBJECTS = gsmsmsstore.$(OBJEXT) +gsmsmsstore_OBJECTS = $(am_gsmsmsstore_OBJECTS) +gsmsmsstore_DEPENDENCIES = ../gsmlib/libgsmme.la +gsmsmsstore_LDFLAGS = + +DEFS = @DEFS@ +DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) +CPPFLAGS = @CPPFLAGS@ +LDFLAGS = @LDFLAGS@ +LIBS = @LIBS@ +depcomp = $(SHELL) $(top_srcdir)/scripts/depcomp +am__depfiles_maybe = depfiles +@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/gsmctl.Po ./$(DEPDIR)/gsmpb.Po \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsmsendsms.Po ./$(DEPDIR)/gsmsmsd.Po \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsmsmsstore.Po +CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ + $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) +LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ + $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ + $(AM_CXXFLAGS) $(CXXFLAGS) +CXXLD = $(CXX) +CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ + $(AM_LDFLAGS) $(LDFLAGS) -o $@ +CXXFLAGS = @CXXFLAGS@ +DIST_SOURCES = $(gsmctl_SOURCES) $(gsmpb_SOURCES) $(gsmsendsms_SOURCES) \ + $(gsmsmsd_SOURCES) $(gsmsmsstore_SOURCES) +DIST_COMMON = Makefile.am Makefile.in +SOURCES = $(gsmctl_SOURCES) $(gsmpb_SOURCES) $(gsmsendsms_SOURCES) $(gsmsmsd_SOURCES) $(gsmsmsstore_SOURCES) + +all: all-am + +.SUFFIXES: +.SUFFIXES: .cc .lo .o .obj +$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4) + cd $(top_srcdir) && \ + $(AUTOMAKE) --gnu apps/Makefile +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe) +binPROGRAMS_INSTALL = $(INSTALL_PROGRAM) +install-binPROGRAMS: $(bin_PROGRAMS) + @$(NORMAL_INSTALL) + $(mkinstalldirs) $(DESTDIR)$(bindir) + @list='$(bin_PROGRAMS)'; for p in $$list; do \ + p1=`echo $$p|sed 's/$(EXEEXT)$$//'`; \ + if test -f $$p \ + || test -f $$p1 \ + ; then \ + f=`echo "$$p1" | sed 's,^.*/,,;$(transform);s/$$/$(EXEEXT)/'`; \ + echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) --mode=install $(binPROGRAMS_INSTALL) $$p $(DESTDIR)$(bindir)/$$f"; \ + $(INSTALL_PROGRAM_ENV) $(LIBTOOL) --mode=install $(binPROGRAMS_INSTALL) $$p $(DESTDIR)$(bindir)/$$f; \ + else :; fi; \ + done + +uninstall-binPROGRAMS: + @$(NORMAL_UNINSTALL) + @list='$(bin_PROGRAMS)'; for p in $$list; do \ + f=`echo "$$p" | sed 's,^.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/'`; \ + echo " rm -f $(DESTDIR)$(bindir)/$$f"; \ + rm -f $(DESTDIR)$(bindir)/$$f; \ + done + +clean-binPROGRAMS: + @list='$(bin_PROGRAMS)'; for p in $$list; do \ + f=`echo $$p|sed 's/$(EXEEXT)$$//'`; \ + echo " rm -f $$p $$f"; \ + rm -f $$p $$f ; \ + done +gsmctl$(EXEEXT): $(gsmctl_OBJECTS) $(gsmctl_DEPENDENCIES) + @rm -f gsmctl$(EXEEXT) + $(CXXLINK) $(gsmctl_LDFLAGS) $(gsmctl_OBJECTS) $(gsmctl_LDADD) $(LIBS) +gsmpb$(EXEEXT): $(gsmpb_OBJECTS) $(gsmpb_DEPENDENCIES) + @rm -f gsmpb$(EXEEXT) + $(CXXLINK) $(gsmpb_LDFLAGS) $(gsmpb_OBJECTS) $(gsmpb_LDADD) $(LIBS) +gsmsendsms$(EXEEXT): $(gsmsendsms_OBJECTS) $(gsmsendsms_DEPENDENCIES) + @rm -f gsmsendsms$(EXEEXT) + $(CXXLINK) $(gsmsendsms_LDFLAGS) $(gsmsendsms_OBJECTS) $(gsmsendsms_LDADD) $(LIBS) +gsmsmsd$(EXEEXT): $(gsmsmsd_OBJECTS) $(gsmsmsd_DEPENDENCIES) + @rm -f gsmsmsd$(EXEEXT) + $(CXXLINK) $(gsmsmsd_LDFLAGS) $(gsmsmsd_OBJECTS) $(gsmsmsd_LDADD) $(LIBS) +gsmsmsstore$(EXEEXT): $(gsmsmsstore_OBJECTS) $(gsmsmsstore_DEPENDENCIES) + @rm -f gsmsmsstore$(EXEEXT) + $(CXXLINK) $(gsmsmsstore_LDFLAGS) $(gsmsmsstore_OBJECTS) $(gsmsmsstore_LDADD) $(LIBS) + +mostlyclean-compile: + -rm -f *.$(OBJEXT) core *.core + +distclean-compile: + -rm -f *.tab.c + +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsmctl.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsmpb.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsmsendsms.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsmsmsd.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsmsmsstore.Po@am__quote@ + +distclean-depend: + -rm -rf ./$(DEPDIR) + +.cc.o: +@AMDEP_TRUE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(CXXCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$< + +.cc.obj: +@AMDEP_TRUE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(CXXCOMPILE) -c -o $@ `cygpath -w $<` + +.cc.lo: +@AMDEP_TRUE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(LTCXXCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$< +CXXDEPMODE = @CXXDEPMODE@ + +mostlyclean-libtool: + -rm -f *.lo + +clean-libtool: + -rm -rf .libs _libs + +distclean-libtool: + -rm -f libtool +uninstall-info-am: + +ETAGS = etags +ETAGSFLAGS = + +tags: TAGS + +ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | \ + $(AWK) ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + mkid -fID $$unique + +TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ + $(TAGS_FILES) $(LISP) + tags=; \ + here=`pwd`; \ + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | \ + $(AWK) ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + test -z "$(ETAGS_ARGS)$$tags$$unique" \ + || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ + $$tags $$unique + +GTAGS: + here=`$(am__cd) $(top_builddir) && pwd` \ + && cd $(top_srcdir) \ + && gtags -i $(GTAGS_ARGS) $$here + +distclean-tags: + -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) + +top_distdir = .. +distdir = $(top_distdir)/$(PACKAGE)-$(VERSION) + +distdir: $(DISTFILES) + @list='$(DISTFILES)'; for file in $$list; do \ + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ + dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \ + if test "$$dir" != "$$file" && test "$$dir" != "."; then \ + dir="/$$dir"; \ + $(mkinstalldirs) "$(distdir)$$dir"; \ + else \ + dir=''; \ + fi; \ + if test -d $$d/$$file; then \ + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ + cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ + fi; \ + cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ + else \ + test -f $(distdir)/$$file \ + || cp -p $$d/$$file $(distdir)/$$file \ + || exit 1; \ + fi; \ + done +check-am: all-am +check: check-am +all-am: Makefile $(PROGRAMS) + +installdirs: + $(mkinstalldirs) $(DESTDIR)$(bindir) + +install: install-am +install-exec: install-exec-am +install-data: install-data-am +uninstall: uninstall-am + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am + +installcheck: installcheck-am +install-strip: + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + INSTALL_STRIP_FLAG=-s \ + `test -z '$(STRIP)' || \ + echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -rm -f Makefile $(CONFIG_CLEAN_FILES) + +maintainer-clean-generic: + @echo "This command is intended for maintainers to use" + @echo "it deletes files that may require special tools to rebuild." +clean: clean-am + +clean-am: clean-binPROGRAMS clean-generic clean-libtool mostlyclean-am + +distclean: distclean-am + +distclean-am: clean-am distclean-compile distclean-depend \ + distclean-generic distclean-libtool distclean-tags + +dvi: dvi-am + +dvi-am: + +info: info-am + +info-am: + +install-data-am: + +install-exec-am: install-binPROGRAMS + +install-info: install-info-am + +install-man: + +installcheck-am: + +maintainer-clean: maintainer-clean-am + +maintainer-clean-am: distclean-am maintainer-clean-generic + +mostlyclean: mostlyclean-am + +mostlyclean-am: mostlyclean-compile mostlyclean-generic \ + mostlyclean-libtool + +uninstall-am: uninstall-binPROGRAMS uninstall-info-am + +.PHONY: GTAGS all all-am check check-am clean clean-binPROGRAMS \ + clean-generic clean-libtool distclean distclean-compile \ + distclean-depend distclean-generic distclean-libtool \ + distclean-tags distdir dvi dvi-am info info-am install \ + install-am install-binPROGRAMS install-data install-data-am \ + install-exec install-exec-am install-info install-info-am \ + install-man install-strip installcheck installcheck-am \ + installdirs maintainer-clean maintainer-clean-generic \ + mostlyclean mostlyclean-compile mostlyclean-generic \ + mostlyclean-libtool tags uninstall uninstall-am \ + uninstall-binPROGRAMS uninstall-info-am + +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmctl.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmctl.cc new file mode 100644 index 0000000000..df6fd28e1d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmctl.cc @@ -0,0 +1,635 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsmctl.cc +// * +// * Purpose: GSM mobile phone control program +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 11.7.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#if defined(HAVE_GETOPT_LONG) || defined(WIN32) +#include +#endif +#include +#include +#include +#include +#include +#include +#include +#ifdef WIN32 +#include +#else +#include +#include +#endif +#include + +using namespace std; +using namespace gsmlib; + +// my ME + +static MeTa *m; + +// information parameters + +enum InfoParameter {AllInfo, // print all info + MeInfo, // MeInfo must be first! + FunctionalityInfo, + OperatorInfo, + CurrentOperatorInfo, + FacilityLockStateInfo, + FacilityLockCapabilityInfo, + PasswordInfo, + PINInfo, + CLIPInfo, + CallForwardingInfo, + BatteryInfo, + BitErrorInfo, + SCAInfo, + CharSetInfo, + SignalInfo}; // SignalInfo must be last! + +// operation parameters + +// FIXME operations not implemented yet + +// options + +#ifdef HAVE_GETOPT_LONG +static struct option longOpts[] = +{ + {"xonxoff", no_argument, (int*)NULL, 'X'}, + {"operation", required_argument, (int*)NULL, 'o'}, + {"device", required_argument, (int*)NULL, 'd'}, + {"baudrate", required_argument, (int*)NULL, 'b'}, + {"init", required_argument, (int*)NULL, 'I'}, + {"help", no_argument, (int*)NULL, 'h'}, + {"version", no_argument, (int*)NULL, 'v'}, + {(char*)NULL, 0, (int*)NULL, 0} +}; +#else +#define getopt_long(argc, argv, options, longopts, indexptr) \ + getopt(argc, argv, options) +#endif + +// helper function, prints forwarding info + +void printForwardReason(string s, ForwardInfo &info) +{ + cout << s << " " + << (info._active ? _("active ") : _("inactive ")) + << _("number: ") << info._number + << _(" subaddr: ") << info._subAddr + << _(" time: ") << info._time << endl; +} + +// print information + +static void printInfo(InfoParameter ip) +{ + switch (ip) + { + case MeInfo: + { + MEInfo mei = m->getMEInfo(); + cout << _(" Manufacturer: ") << mei._manufacturer << endl + << _(" Model: ") << mei._model << endl + << _(" Revision: ") << mei._revision << endl + << _(" Serial Number: ") << mei._serialNumber << endl; + break; + } + case FunctionalityInfo: + { + try { + int fun; + fun = m->getFunctionalityLevel(); + cout << _(" Functionality Level: ") << fun << endl; + } catch (GsmException &x) { + cout << _(" Functionality Level: ") << _("unsupported") << endl; + } + break; + } + case OperatorInfo: + { + int count = 0; + vector opis = m->getAvailableOPInfo(); + for (vector::iterator i = opis.begin(); i != opis.end(); ++i) + { + cout << " Status: "); + switch (i->_status) + { + case UnknownOPStatus: cout << _("unknown"); break; + case CurrentOPStatus: cout << _("current"); break; + case AvailableOPStatus: cout << _("available"); break; + case ForbiddenOPStatus: cout << _("forbidden"); break; + } + cout << _(" Long name: '") << i->_longName << "' " + << _(" Short name: '") << i->_shortName << "' " + << _(" Numeric name: ") << i->_numericName << endl; + ++count; + } + break; + } + case CurrentOperatorInfo: + { + OPInfo opi = m->getCurrentOPInfo(); + cout << "" + << _(" Long name: '") << opi._longName << "' " + << _(" Short name: '") << opi._shortName << "' " + << _(" Numeric name: ") << opi._numericName + << _(" Mode: "); + switch (opi._mode) + { + case AutomaticOPMode: cout << _("automatic"); break; + case ManualOPMode: cout << _("manual"); break; + case DeregisterOPMode: cout << _("deregister"); break; + case ManualAutomaticOPMode: cout << _("manual/automatic"); break; + } + cout << endl; + break; + } + case FacilityLockStateInfo: + { + int count = 0; + vector fclc = m->getFacilityLockCapabilities(); + for (vector::iterator i = fclc.begin(); i != fclc.end(); ++i) + if (*i != "AB" && *i != "AG" && *i != "AC") + { + cout << " '" << *i << "'"; + try + { + if (m->getFacilityLockStatus(*i, VoiceFacility)) + cout << _(" Voice"); + } + catch (GsmException &e) + { + cout << _(" unknown"); + } + try + { + if (m->getFacilityLockStatus(*i, DataFacility)) + cout << _(" Data"); + } + catch (GsmException &e) + { + cout << _(" unknown"); + } + try + { + if (m->getFacilityLockStatus(*i, FaxFacility)) + cout << _(" Fax"); + } + catch (GsmException &e) + { + cout << _(" unknown"); + } + cout << endl; + ++count; + } + break; + } + case FacilityLockCapabilityInfo: + { + cout << " "; + vector fclc = m->getFacilityLockCapabilities(); + for (vector::iterator i = fclc.begin(); i != fclc.end(); ++i) + cout << "'" << *i << "' "; + cout << endl; + break; + } + case PasswordInfo: + { + vector pwi = m->getPasswords(); + int count = 0; + for (vector::iterator i = pwi.begin(); i != pwi.end(); ++i) + { + cout << " '" + << i->_facility << "' " << i->_maxPasswdLen << endl; + ++count; + } + break; + } + case PINInfo: + { + cout << " " << m->getPINStatus() << endl; + break; + } + case CLIPInfo: + { + cout << " " << (m->getNetworkCLIP() ? _("on") : _("off")) << endl; + break; + } + case CallForwardingInfo: + { + for (int r = 0; r < 4; ++r) + { + string text; + switch (r) + { + case 0: text = _("UnconditionalReason"); break; + case 1: text = _("MobileBusyReason"); break; + case 2: text = _("NoReplyReason"); break; + case 3: text = _("NotReachableReason"); break; + } + ForwardInfo voice, fax, data; + m->getCallForwardInfo((ForwardReason)r, voice, fax, data); + cout << " " + text + _(" Voice"), voice); + cout << " " + text + _(" Data"), data); + cout << " " + text + _(" Fax"), fax); + } + break; + } + case BatteryInfo: + { + cout << " "; + int bcs = m->getBatteryChargeStatus(); + switch (bcs) + { + case 0: cout << _("0 ME is powered by the battery") << endl; break; + case 1: cout << _("1 ME has a battery connected, but is not powered by it") + << endl; break; + case 2: cout << _("2 ME does not have a battery connected") << endl; break; + case 3: + cout << _("3 Recognized power fault, calls inhibited") << endl; + break; + } + cout << " " << m->getBatteryCharge() << endl; + break; + } + case BitErrorInfo: + { + cout << " " << m->getBitErrorRate() << endl; + break; + } + case SCAInfo: + { + cout << " " << m->getServiceCentreAddress() << endl; + break; + } + case CharSetInfo: + { + cout << " "; + vector cs = m->getSupportedCharSets(); + for (vector::iterator i = cs.begin(); i != cs.end(); ++i) + cout << "'" << *i << "' "; + cout << endl; + cout << " '" << m->getCurrentCharSet() << "'" << endl; + break; + } + case SignalInfo: + { + cout << " " << m->getSignalStrength() << endl; + break; + } + default: + assert(0); + break; + } +} + +// convert facility class string of the form "", "all", or any combination +// of "v" (voice), "d" (data), or "f" (fax) to numeric form + +FacilityClass strToFacilityClass(string facilityClassS) +{ + facilityClassS = lowercase(facilityClassS); + FacilityClass facilityClass = (FacilityClass)0; + if (facilityClassS == "all" || facilityClassS == "") + return (FacilityClass)ALL_FACILITIES; + + // OR in facility class bits + for (unsigned int i = 0; i < facilityClassS.length(); ++i) + if (facilityClassS[i] == 'v') + facilityClass = (FacilityClass)(facilityClass | VoiceFacility); + else if (facilityClassS[i] == 'd') + facilityClass = (FacilityClass)(facilityClass | DataFacility); + else if (facilityClassS[i] == 'f') + facilityClass = (FacilityClass)(facilityClass | FaxFacility); + else + throw GsmException( + stringPrintf(_("unknown facility class parameter '%c'"), + facilityClassS[i]), ParameterError); + + return facilityClass; +} + +// check if argc - optind is in range min..max +// throw exception otherwise + +void checkParamCount(int optind, int argc, int min, int max) +{ + int paramCount = argc - optind; + if (paramCount < min) + throw GsmException(stringPrintf(_("not enough parameters, minimum number " + "of parameters is %d"), min), + ParameterError); + else if (paramCount > max) + throw GsmException(stringPrintf(_("too many parameters, maximum number " + "of parameters is %d"), max), + ParameterError); +} + +// *** main program + +int main(int argc, char *argv[]) +{ + try + { + // handle command line options + string device = "/dev/mobilephone"; + string operation; + string baudrate; + string initString = DEFAULT_INIT_STRING; + bool swHandshake = false; + + int opt; + int dummy; + while((opt = getopt_long(argc, argv, "I:o:d:b:hvX", longOpts, &dummy)) + != -1) + switch (opt) + { + case 'X': + swHandshake = true; + break; + case 'I': + initString = optarg; + break; + case 'd': + device = optarg; + break; + case 'o': + operation = optarg; + break; + case 'b': + baudrate = optarg; + break; + case 'v': + cerr << argv[0] << stringPrintf(_(": version %s [compiled %s]"), + VERSION, __DATE__) << endl; + exit(0); + break; + case 'h': + cerr << argv[0] << _(": [-b baudrate][-d device][-h]" + "[-I init string][-o operation]\n" + " [-v][-X]{parameters}") << endl + << endl + << _(" -b, --baudrate baudrate to use for device " + "(default: 38400)") + << endl + << _(" -d, --device sets the destination device to " + "connect to") << endl + << _(" -h, --help prints this message") << endl + << _(" -I, --init device AT init sequence") << endl + << _(" -o, --operation operation to perform on the mobile \n" + " phone with the specified parameters") + << endl + << _(" -v, --version prints version and exits") << endl + << _(" -X, --xonxoff switch on software handshake") << endl + << endl + << _(" parameters parameters to use for the operation\n" + " (if an operation is given) or\n" + " a specification which kind of\n" + " information to read from the mobile " + "phone") + << endl << endl + << _("Refer to gsmctl(1) for details on the available parameters" + " and operations.") + << endl << endl; + exit(0); + break; + case '?': + throw GsmException(_("unknown option"), ParameterError); + break; + } + + // open the port and ME/TA + m = new MeTa(new +#ifdef WIN32 + Win32SerialPort +#else + UnixSerialPort +#endif + (device, + baudrate == "" ? + DEFAULT_BAUD_RATE : + baudRateStrToSpeed(baudrate), + initString, swHandshake)); + + if (operation == "") + { // process info parameters + for (int i = optind; i < argc; ++i) + { + string param = lowercase(argv[i]); + if (param == "all") + for (int ip = MeInfo; ip <= SignalInfo; ++ip) + printInfo((InfoParameter)ip); + else if (param == "me") + printInfo(MeInfo); + else if (param == "fun") + printInfo(FunctionalityInfo); + else if (param == "op") + printInfo(OperatorInfo); + else if (param == "currop") + printInfo(CurrentOperatorInfo); + else if (param == "flstat") + printInfo(FacilityLockStateInfo); + else if (param == "flcap") + printInfo(FacilityLockCapabilityInfo); + else if (param == "pw") + printInfo(PasswordInfo); + else if (param == "pin") + printInfo(PINInfo); + else if (param == "clip") + printInfo(CLIPInfo); + else if (param == "forw") + printInfo(CallForwardingInfo); + else if (param == "batt") + printInfo(BatteryInfo); + else if (param == "biterr") + printInfo(BitErrorInfo); + else if (param == "sig") + printInfo(SignalInfo); + else if (param == "sca") + printInfo(SCAInfo); + else if (param == "cset") + printInfo(CharSetInfo); + else + throw GsmException( + stringPrintf(_("unknown information parameter '%s'"), + param.c_str()), + ParameterError); + } + } + else + { // process operation + operation = lowercase(operation); + if (operation == "dial") + { + // dial: number + checkParamCount(optind, argc, 1, 1); + + m->dial(argv[optind]); + + // wait for keypress from stdin + char c; + read(1, &c, 1); + } + else if (operation == "on") + { + m->setFunctionalityLevel(1); + } + else if (operation == "off") + { + m->setFunctionalityLevel(0); + } + else if (operation == "pin") + { + // pin: PIN + checkParamCount(optind, argc, 1, 1); + + m->setPIN(argv[optind]); + } + else if (operation == "setop") + { + // setop: opmode numeric FIXME allow long and numeric too + checkParamCount(optind, argc, 2, 2); + string opmodeS = lowercase(argv[optind]); + OPModes opmode; + if (opmodeS == "automatic") + opmode = AutomaticOPMode; + else if (opmodeS == "manual") + opmode = ManualOPMode; + else if (opmodeS == "deregister") + opmode = DeregisterOPMode; + else if (opmodeS == "manualautomatic") + opmode = ManualAutomaticOPMode; + else + throw GsmException(stringPrintf(_("unknown opmode parameter '%s'"), + opmodeS.c_str()), ParameterError); + + m->setCurrentOPInfo(opmode, "" , "", checkNumber(argv[optind + 1])); + } + else if (operation == "lock") + { + // lock: facility [facilityclass] [passwd] + checkParamCount(optind, argc, 1, 3); + string passwd = (argc - optind == 3) ? + (string)argv[optind + 2] : (string)""; + + m->lockFacility(argv[optind], + (argc - optind >= 2) ? + strToFacilityClass(argv[optind + 1]) : + (FacilityClass)ALL_FACILITIES, + passwd); + } + else if (operation == "unlock") + { + // unlock: facility [facilityclass] [passwd] + checkParamCount(optind, argc, 1, 3); + string passwd = argc - optind == 3 ? argv[optind + 2] : ""; + + m->unlockFacility(argv[optind], + (argc - optind >= 2) ? + strToFacilityClass(argv[optind + 1]) : + (FacilityClass)ALL_FACILITIES, + passwd); + } + else if (operation == "setpw") + { + // set password: facility oldpasswd newpasswd + checkParamCount(optind, argc, 1, 3); + string oldPasswd = argc - optind >= 2 ? argv[optind + 1] : ""; + string newPasswd = argc - optind == 3 ? argv[optind + 2] : ""; + + m->setPassword(argv[optind], oldPasswd, newPasswd); + } + else if (operation == "forw") + { + // call forwarding: mode reason number [facilityclass] [forwardtime] + checkParamCount(optind, argc, 2, 5); + + // get optional parameters facility class and forwardtime + int forwardTime = argc - optind == 5 ? checkNumber(argv[optind + 4]) : + NOT_SET; + FacilityClass facilityClass = + argc - optind >= 4 ? strToFacilityClass(argv[optind + 3]) : + (FacilityClass)ALL_FACILITIES; + + // get forward reason + string reasonS = lowercase(argv[optind + 1]); + ForwardReason reason; + if (reasonS == "unconditional") + reason = UnconditionalReason; + else if (reasonS == "mobilebusy") + reason = MobileBusyReason; + else if (reasonS == "noreply") + reason = NoReplyReason; + else if (reasonS == "notreachable") + reason = NotReachableReason; + else if (reasonS == "all") + reason = AllReasons; + else if (reasonS == "allconditional") + reason = AllConditionalReasons; + else + throw GsmException( + stringPrintf(_("unknown forward reason parameter '%s'"), + reasonS.c_str()), ParameterError); + + // get mode + string modeS = lowercase(argv[optind]); + ForwardMode mode; + if (modeS == "disable") + mode = DisableMode; + else if (modeS == "enable") + mode = EnableMode; + else if (modeS == "register") + mode = RegistrationMode; + else if (modeS == "erase") + mode = ErasureMode; + else + throw GsmException( + stringPrintf(_("unknown forward mode parameter '%s'"), + modeS.c_str()), ParameterError); + + m->setCallForwarding(reason, mode, + (argc - optind >= 3) ? argv[optind + 2] : "", + "", // subaddr + facilityClass, forwardTime); + } + else if (operation == "setsca") + { + // set sca: number + checkParamCount(optind, argc, 1, 1); + m->setServiceCentreAddress(argv[optind]); + } + else if (operation == "cset") + { + // set charset: string + checkParamCount(optind, argc, 1, 1); + m->setCharSet(argv[optind]); + } + else + throw GsmException(stringPrintf(_("unknown operation '%s'"), + operation.c_str()), ParameterError); + } + } + catch (GsmException &ge) + { + cerr << argv[0] << _("[ERROR]: ") << ge.what() << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmpb.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmpb.cc new file mode 100644 index 0000000000..6196b717c2 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmpb.cc @@ -0,0 +1,507 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsmpb.cc +// * +// * Purpose: phonebook management program +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 24.6.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#ifdef WIN32 +#include +#else +#include +#include +#endif +#if defined(HAVE_GETOPT_LONG) || defined(WIN32) +#include +#endif +#include +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +#ifdef HAVE_GETOPT_LONG +static struct option longOpts[] = +{ + {"xonxoff", no_argument, (int*)NULL, 'X'}, + {"phonebook", required_argument, (int*)NULL, 'p'}, + {"init", required_argument, (int*)NULL, 'I'}, + {"destination", required_argument, (int*)NULL, 'd'}, + {"source", required_argument, (int*)NULL, 's'}, + {"destination-backend", required_argument, (int*)NULL, 'D'}, + {"source-backend", required_argument, (int*)NULL, 'S'}, + {"baudrate", required_argument, (int*)NULL, 'b'}, + {"charset", required_argument, (int*)NULL, 't'}, + {"copy", no_argument, (int*)NULL, 'c'}, + {"synchronize", no_argument, (int*)NULL, 'y'}, + {"help", no_argument, (int*)NULL, 'h'}, + {"version", no_argument, (int*)NULL, 'v'}, + {"verbose", no_argument, (int*)NULL, 'V'}, + {"indexed", no_argument, (int*)NULL, 'i'}, + {(char*)NULL, 0, (int*)NULL, 0} +}; +#else +#define getopt_long(argc, argv, options, longopts, indexptr) \ + getopt(argc, argv, options) +#endif + +// insert those entries from sourcePhonebook into destPhonebook +// that are not already present in destPhonebook + +void insertNotPresent(SortedPhonebookRef sourcePhonebook, + SortedPhonebookRef destPhonebook, + bool indexed, bool verbose) +{ + for (SortedPhonebookBase::iterator i = sourcePhonebook->begin(); + i != sourcePhonebook->end(); ++i) + { + pair range; + if (indexed) + { + int index = i->index(); + range = destPhonebook->equal_range(index); + } + else + { + string text = i->text(); + range = destPhonebook->equal_range(text); + } + + // do nothing if the entry is already present in the destination + bool alreadyPresent = false; + for (SortedPhonebookBase::iterator j = range.first; + j != range.second; ++j) + { + i->setUseIndex(indexed); + if (i->telephone() == j->telephone()) + { + alreadyPresent = true; + break; + } + } + // ... else insert it + if (! alreadyPresent) + { + if (verbose) + { + cout << stringPrintf(_("inserting '%s' tel# %s"), + i->text().c_str(), i->telephone().c_str()); + if (indexed) + cout << stringPrintf(_(" (index #%d)"), i->index()); + cout << endl; + } + i->setUseIndex(indexed); + destPhonebook->insert(*i); // insert + } + } +} + +// update those entries in destPhonebook, that +// - have the same name as one entry in destPhonebook +// - but have a different telephone number +// this is only done if the name in question is unique in the destPhonebook +// the case of several entries having the same in the sourcePhonebook +// is handled - only the first is considered for updating + +void updateEntries(SortedPhonebookRef sourcePhonebook, + SortedPhonebookRef destPhonebook, + bool verbose) +{ + bool firstLoop = true; + string lastText; + + for (SortedPhonebookBase::iterator i = sourcePhonebook->begin(); + i != sourcePhonebook->end(); ++i) + { + string text = i->text(); + if (! firstLoop && text != lastText) + { + pair range = + destPhonebook->equal_range(text); + + SortedPhonebookBase::iterator first = range.first; + if (first != destPhonebook->end() && range.second == ++first) + { // just one text in the destPhonebook + if (! (*range.first == *i)) // overwrite if different in destination + { + if (verbose) + cout << stringPrintf(_("updating '%s' tel# %s to new tel# %s"), + range.first->text().c_str(), + range.first->telephone().c_str(), + i->telephone().c_str()) + << endl; + + *range.first = *i; + } + } + lastText = text; + } + firstLoop = false; + } +} + +// the same but for indexed phonebooks + +void updateEntriesIndexed(SortedPhonebookRef sourcePhonebook, + SortedPhonebookRef destPhonebook, + bool verbose) +{ + for (SortedPhonebookBase::iterator i = sourcePhonebook->begin(); + i != sourcePhonebook->end(); ++i) + { + int index = i->index(); + + SortedPhonebookBase::iterator j = destPhonebook->find(index); + + if (j != destPhonebook->end()) + { // index present in the destPhonebook + if (! (*j == *i)) // overwrite if different in destination + { + if (verbose) + cout << stringPrintf(_("updating '%s' tel# %s to new tel# %s" + "(index %d)"), + j->text().c_str(), + j->telephone().c_str(), + i->telephone().c_str(), i->index()) + << endl; + + *j = *i; + } + } + } +} + +// delete those entries from destPhonebook, that are not present +// in sourcePhonebook + +void deleteNotPresent(SortedPhonebookRef sourcePhonebook, + SortedPhonebookRef destPhonebook, + bool indexed, bool verbose) +{ + for (SortedPhonebookBase::iterator i = destPhonebook->begin(); + i != destPhonebook->end(); ++i) + { + pair range; + if (indexed) + { + int index = i->index(); + range = sourcePhonebook->equal_range(index); + } + else + { + string text = i->text(); + range = sourcePhonebook->equal_range(text); + } + + bool found = false; + for (SortedPhonebookBase::iterator j = range.first; + j != range.second; ++j) + { + i->setUseIndex(indexed); + if (j->telephone() == i->telephone()) + { + found = true; + break; + } + } + if (! found) + { + if (verbose) + { + cout << stringPrintf(_("deleting '%s' tel# %s"), + i->text().c_str(), i->telephone().c_str()); + if (indexed) + cout << stringPrintf(_(" (index #%d)"), i->index()); + cout << endl; + } + destPhonebook->erase(i); +#ifdef BUGGY_MAP_ERASE + deleteNotPresent(sourcePhonebook, destPhonebook, indexed, verbose); + return; +#endif + } + } +} + +// *** main program + +int main(int argc, char *argv[]) +{ + try + { + // handle command line options + string destination; + string source; + string destinationBackend; + string sourceBackend; + string baudrate; + bool doSynchronize = true; + string phonebook; + SortedPhonebookRef sourcePhonebook, destPhonebook; + bool verbose = false; + bool indexed = false; + string initString = DEFAULT_INIT_STRING; + bool swHandshake = false; + string charSet; + Ref sourceMeTa, destMeTa; + + int opt; + int dummy; + while((opt = getopt_long(argc, argv, "I:p:s:d:b:cyhvViD:S:Xt:", longOpts, + &dummy)) + != -1) + switch (opt) + { + case 'X': + swHandshake = true; + break; + case 'I': + initString = optarg; + break; + case 'V': + verbose = true; + break; + case 'p': + phonebook = optarg; + break; + case 'd': + destination = optarg; + break; + case 's': + source = optarg; + break; + case 'D': + destinationBackend = optarg; + break; + case 'S': + sourceBackend = optarg; + break; + case 'b': + baudrate = optarg; + break; + case 't': + charSet = optarg; + break; + case 'c': + doSynchronize = false; + break; + case 'i': + indexed = true; + break; + case 'y': + doSynchronize = true; + break; + case 'v': + cerr << argv[0] << stringPrintf(_(": version %s [compiled %s]"), + VERSION, __DATE__) << endl; + exit(0); + break; + case 'h': + cerr << argv[0] << _(": [-b baudrate][-c][-d device or file][-h]" + "[-I init string]\n" + " [-p phonebook name][-s device or file]" + "[-t charset][-v]" + "[-V][-y][-X]") << endl + << endl + << _(" -b, --baudrate baudrate to use for device " + "(default: 38400)") + << endl + << _(" -c, --copy copy source entries to destination") + << endl + << _(" -d, --destination sets the destination device to " + "connect \n" + " to, or the file to write") << endl + << _(" -D, --destination-backend sets the destination backend") + << endl + << _(" -h, --help prints this message") << endl + << _(" -i, --index takes index positions into account") + << endl + << _(" -I, --init device AT init sequence") << endl + << _(" -p, --phonebook name of phonebook to use") << endl + << _(" -s, --source sets the source device to connect to,\n" + " or the file to read") << endl + << _(" -t, --charset sets the character set to use for\n" + " phonebook entries") << endl + << _(" -S, --source-backend sets the source backend") + << endl + << _(" -v, --version prints version and exits") << endl + << _(" -V, --verbose print detailed progress messages") + << endl + << _(" -X, --xonxoff switch on software handshake") << endl + << _(" -y, --synchronize synchronize destination with source\n" + " entries (destination is overwritten)\n" + " (see gsmpb(1) for details)") + << endl << endl; + exit(0); + break; + case '?': + throw GsmException(_("unknown option"), ParameterError); + break; + } + + // check if all parameters all present + if (destination == "" || source == "") + throw GsmException(_("both source and destination must be given"), + ParameterError); + + // start accessing source mobile phone or file + if (sourceBackend != "") + sourcePhonebook = + CustomPhonebookRegistry::createPhonebook(sourceBackend, source); + else if (source == "-") + sourcePhonebook = new SortedPhonebook(true, indexed); + else if (isFile(source)) + sourcePhonebook = new SortedPhonebook(source, indexed); + else + { + if (phonebook == "") + throw GsmException(_("phonebook name must be given"), ParameterError); + + sourceMeTa = new MeTa(new +#ifdef WIN32 + Win32SerialPort +#else + UnixSerialPort +#endif + (source, + baudrate == "" ? DEFAULT_BAUD_RATE : + baudRateStrToSpeed(baudrate), initString, + swHandshake)); + if (charSet != "") + sourceMeTa->setCharSet(charSet); + sourcePhonebook = + new SortedPhonebook(sourceMeTa->getPhonebook(phonebook)); + } + + // make sure destination.c_str file exists + if (destination != "") + { + try + { + ofstream f(destination.c_str(), ios::out | ios::app); + } + catch (exception) + { + } + } + + // start accessing destination mobile phone or file + if (destinationBackend != "") + destPhonebook = + CustomPhonebookRegistry::createPhonebook(destinationBackend, + destination); + else if (destination == "-") + destPhonebook = new SortedPhonebook(false, indexed); + else if (isFile(destination)) + destPhonebook = new SortedPhonebook(destination, indexed); + else + { + if (phonebook == "") + throw GsmException(_("phonebook name must be given"), ParameterError); + + destMeTa = new MeTa(new +#ifdef WIN32 + Win32SerialPort +#else + UnixSerialPort +#endif + (destination, + baudrate == "" ? DEFAULT_BAUD_RATE : + baudRateStrToSpeed(baudrate), initString, + swHandshake)); + if (charSet != "") + destMeTa->setCharSet(charSet); + PhonebookRef destPb = destMeTa->getPhonebook(phonebook); + + // check maximum lengths of source text and phonenumber when writing to + // mobile phone + unsigned int maxTextLen = destPb->getMaxTextLen(); + unsigned int maxTelLen = destPb->getMaxTelephoneLen(); + + for (SortedPhonebookBase::iterator i = sourcePhonebook->begin(); + i != sourcePhonebook->end(); ++i) + if (i->text().length() > maxTextLen) + throw GsmException( + stringPrintf(_("text '%s' is too large to fit into destination " + "(maximum size %d characters)"), + i->text().c_str(), maxTextLen), + ParameterError); + else if (i->telephone().length() > maxTelLen) + throw GsmException( + stringPrintf(_("phone number '%s' is too large to fit into " + "destination (maximum size %d characters)"), + i->telephone().c_str(), maxTelLen), + ParameterError); + + // read phonebook + destPhonebook = new SortedPhonebook(destPb); + } + + // now do the actual work + if (doSynchronize) + { // synchronizing + if (indexed) + { + sourcePhonebook->setSortOrder(ByIndex); + destPhonebook->setSortOrder(ByIndex); + // for an explanation see below + updateEntriesIndexed(sourcePhonebook, destPhonebook, verbose); + deleteNotPresent(sourcePhonebook, destPhonebook, true, verbose); + insertNotPresent(sourcePhonebook, destPhonebook, true, verbose); + } + else + { + sourcePhonebook->setSortOrder(ByText); + destPhonebook->setSortOrder(ByText); + // the following is done to avoid superfluous writes to the TA + // (that takes time) and keep updated (ie. telephone number changed) + // entries at the same place + // 1. update entries in place where just the number changed + updateEntries(sourcePhonebook, destPhonebook, verbose); + // 2. delete those that are not present anymore + deleteNotPresent(sourcePhonebook, destPhonebook, false, verbose); + // 3. insert the new ones + insertNotPresent(sourcePhonebook, destPhonebook, false, verbose); + } + } + else + { // copying + destPhonebook->clear(); + for (SortedPhonebookBase::iterator i = sourcePhonebook->begin(); + i != sourcePhonebook->end(); ++i) + { + if (verbose) + { + cout << stringPrintf(_("inserting '%s' tel# %s"), + i->text().c_str(), i->telephone().c_str()); + if (indexed) + cout << stringPrintf(_(" (index #%d)"), i->index()); + cout << endl; + } + destPhonebook->insert(*i); + } + } + } + catch (GsmException &ge) + { + cerr << argv[0] << _("[ERROR]: ") << ge.what() << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsendsms.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsendsms.cc new file mode 100644 index 0000000000..f6418842ac --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsendsms.cc @@ -0,0 +1,257 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsmsendsms.cc +// * +// * Purpose: GSM sms send program +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 16.7.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#ifdef WIN32 +#include +#else +#include +#include +#endif +#if defined(HAVE_GETOPT_LONG) || defined(WIN32) +#include +#endif +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +// options + +#ifdef HAVE_GETOPT_LONG +static struct option longOpts[] = +{ + {"requeststat", no_argument, (int*)NULL, 'r'}, + {"xonxoff", no_argument, (int*)NULL, 'X'}, + {"sca", required_argument, (int*)NULL, 'C'}, + {"device", required_argument, (int*)NULL, 'd'}, + {"init", required_argument, (int*)NULL, 'I'}, + {"concatenate", required_argument, (int*)NULL, 'c'}, + {"baudrate", required_argument, (int*)NULL, 'b'}, + {"test", no_argument, (int*)NULL, 't'}, + {"help", no_argument, (int*)NULL, 'h'}, + {"version", no_argument, (int*)NULL, 'v'}, + {(char*)NULL, 0, (int*)NULL, 0} +}; +#else +#define getopt_long(argc, argv, options, longopts, indexptr) \ + getopt(argc, argv, options) +#endif + +// convert /r and /n to CR and LF + +static string unescapeString(char *line) +{ + string result; + bool escaped = false; + int index = 0; + + while (line[index] != 0 && + line[index] != CR && line[index] != LF) + { + if (escaped) + { + escaped = false; + if (line[index] == 'r') + result += CR; + else if (line[index] == 'n') + result += LF; + else if (line[index] == '\\') + result += '\\'; + else + result += line[index]; + } + else + if (line[index] == '\\') + escaped = true; + else + result += line[index]; + + ++index; + } + return result; +} + +// *** main program + +int main(int argc, char *argv[]) +{ + try + { + // handle command line options + string device = "/dev/mobilephone"; + bool test = false; + string baudrate; + Ref at; + string initString = DEFAULT_INIT_STRING; + bool swHandshake = false; + bool requestStatusReport = false; + // service centre address (set on command line) + string serviceCentreAddress; + MeTa *m = NULL; + string concatenatedMessageIdStr; + int concatenatedMessageId = -1; + + int opt; + int dummy; + while((opt = getopt_long(argc, argv, "c:C:I:d:b:thvXr", longOpts, &dummy)) + != -1) + switch (opt) + { + case 'c': + concatenatedMessageIdStr = optarg; + break; + case 'C': + serviceCentreAddress = optarg; + break; + case 'X': + swHandshake = true; + break; + case 'I': + initString = optarg; + break; + case 'd': + device = optarg; + break; + case 'b': + baudrate = optarg; + break; + case 't': + test = true; + break; + case 'r': + requestStatusReport = true; + break; + case 'v': + cerr << argv[0] << stringPrintf(_(": version %s [compiled %s]"), + VERSION, __DATE__) << endl; + exit(0); + break; + case 'h': + cerr << argv[0] << _(": [-b baudrate][-c concatenatedID]" + "[-C sca][-d device][-h][-I init string]\n" + " [-t][-v][-X] phonenumber [text]") << endl + << endl + << _(" -b, --baudrate baudrate to use for device " + "(default: 38400)") + << endl + << _(" -c, --concatenate ID for concatenated SMS messages") + << endl + << _(" -C, --sca SMS service centre address") << endl + << _(" -d, --device sets the destination device to connect " + "to") << endl + << _(" -h, --help prints this message") << endl + << _(" -I, --init device AT init sequence") << endl + << _(" -r, --requeststat request SMS status report") << endl + << _(" -t, --test convert text to GSM alphabet and " + "vice\n" + " versa, no SMS message is sent") << endl + << _(" -v, --version prints version and exits") + << endl + << _(" -X, --xonxoff switch on software handshake") << endl + << endl + << _(" phonenumber recipient's phone number") << endl + << _(" text optional text of the SMS message\n" + " if omitted: read from stdin") + << endl << endl; + exit(0); + break; + case '?': + throw GsmException(_("unknown option"), ParameterError); + break; + } + + if (! test) + { + // open the port and ME/TA + Ref port = new +#ifdef WIN32 + Win32SerialPort +#else + UnixSerialPort +#endif + (device, + baudrate == "" ? DEFAULT_BAUD_RATE : + baudRateStrToSpeed(baudrate), + initString, swHandshake); + // switch message service level to 1 + // this enables acknowledgement PDUs + m = new MeTa(port); + m->setMessageService(1); + + at = new GsmAt(*m); + } + + // check parameters + if (optind == argc) + throw GsmException(_("phone number and text missing"), ParameterError); + + if (optind + 2 < argc) + throw GsmException(_("more than two parameters given"), ParameterError); + + if (concatenatedMessageIdStr != "") + concatenatedMessageId = checkNumber(concatenatedMessageIdStr); + + // get phone number + string phoneNumber = argv[optind]; + + // get text + string text; + if (optind + 1 == argc) + { // read from stdin + char s[1000]; + cin.get(s, 1000); + text = unescapeString(s); + if (text.length() > 160) + throw GsmException(_("text is larger than 160 characters"), + ParameterError); + } + else + text = argv[optind + 1]; + + if (test) + cout << gsmToLatin1(latin1ToGsm(text)) << endl; + else + { + // send SMS + Ref submitSMS = new SMSSubmitMessage(); + // set service centre address in new submit PDU if requested by user + if (serviceCentreAddress != "") + { + Address sca(serviceCentreAddress); + submitSMS->setServiceCentreAddress(sca); + } + submitSMS->setStatusReportRequest(requestStatusReport); + Address destAddr(phoneNumber); + submitSMS->setDestinationAddress(destAddr); + if (concatenatedMessageId == -1) + m->sendSMSs(submitSMS, text, true); + else + m->sendSMSs(submitSMS, text, false, concatenatedMessageId); + } + } + catch (GsmException &ge) + { + cerr << argv[0] << _("[ERROR]: ") << ge.what() << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsmsd.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsmsd.cc new file mode 100644 index 0000000000..e436546225 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsmsd.cc @@ -0,0 +1,719 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsmsmsd.cc +// * +// * Purpose: SMS receiver daemon +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 5.6.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include + +#ifdef WIN32 +#include +#include +#include +#define popen _popen +#define pclose _pclose +#else +#include +#include +#include +#include +#endif +#if defined(HAVE_GETOPT_LONG) || defined(WIN32) +#include +#endif + +#include +#include +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +#ifdef HAVE_GETOPT_LONG +static struct option longOpts[] = +{ + {"requeststat", no_argument, (int*)NULL, 'r'}, + {"direct", no_argument, (int*)NULL, 'D'}, + {"xonxoff", no_argument, (int*)NULL, 'X'}, + {"init", required_argument, (int*)NULL, 'I'}, + {"store", required_argument, (int*)NULL, 't'}, + {"device", required_argument, (int*)NULL, 'd'}, + {"spool", required_argument, (int*)NULL, 's'}, + {"sent", required_argument, (int*)NULL, 'S'}, + {"failed", required_argument, (int*)NULL, 'F'}, + {"priorities", required_argument, (int*)NULL, 'P'}, +#ifndef WIN32 + {"syslog", no_argument, (int*)NULL, 'L'}, +#endif + {"sca", required_argument, (int*)NULL, 'C'}, + {"flush", no_argument, (int*)NULL, 'f'}, + {"concatenate", required_argument, (int*)NULL, 'c'}, + {"action", required_argument, (int*)NULL, 'a'}, + {"baudrate", required_argument, (int*)NULL, 'b'}, + {"help", no_argument, (int*)NULL, 'h'}, + {"version", no_argument, (int*)NULL, 'v'}, + {(char*)NULL, 0, (int*)NULL, 0} +}; +#else +#define getopt_long(argc, argv, options, longopts, indexptr) \ + getopt(argc, argv, options) +#endif + +// my ME + +static MeTa *me = NULL; +string receiveStoreName; // store name for received SMSs + +// service centre address (set on command line) + +static string serviceCentreAddress; + +// ID if concatenated messages should be sent + +static int concatenatedMessageId = -1; + +// signal handler for terminate signal + +bool terminateSent = false; + +void terminateHandler(int signum) +{ + terminateSent = true; +} + +// local class to handle SMS events + +struct IncomingMessage +{ + // used if new message is put into store + int _index; // -1 means message want send directly + string _storeName; + // used if SMS message was sent directly to TA + SMSMessageRef _newSMSMessage; + // used if CB message was sent directly to TA + CBMessageRef _newCBMessage; + // used in both cases + GsmEvent::SMSMessageType _messageType; + + IncomingMessage() : _index(-1) {} +}; + +vector newMessages; + +class EventHandler : public GsmEvent +{ +public: + // inherited from GsmEvent + void SMSReception(SMSMessageRef newMessage, + SMSMessageType messageType); + void CBReception(CBMessageRef newMessage); + void SMSReceptionIndication(string storeName, unsigned int index, + SMSMessageType messageType); + + virtual ~EventHandler() {} +}; + +void EventHandler::SMSReception(SMSMessageRef newMessage, + SMSMessageType messageType) +{ + IncomingMessage m; + m._messageType = messageType; + m._newSMSMessage = newMessage; + newMessages.push_back(m); +} + +void EventHandler::CBReception(CBMessageRef newMessage) +{ + IncomingMessage m; + m._messageType = GsmEvent::CellBroadcastSMS; + m._newCBMessage = newMessage; + newMessages.push_back(m); +} + +void EventHandler::SMSReceptionIndication(string storeName, unsigned int index, + SMSMessageType messageType) +{ + IncomingMessage m; + m._index = index; + + if (receiveStoreName != "" && ( storeName == "MT" || storeName == "mt")) + m._storeName = receiveStoreName; + else + m._storeName = storeName; + + m._messageType = messageType; + newMessages.push_back(m); +} + +// execute action on string + +void doAction(string action, string result) +{ + if (action != "") + { + FILE *fd = popen(action.c_str(), "w"); + if (fd == NULL) + throw GsmException(stringPrintf(_("could not execute '%s'"), + action.c_str()), OSError); + fputs(result.c_str(), fd); + if (ferror(fd)) + throw GsmException(stringPrintf(_("error writing to '%s'"), + action.c_str()), OSError); + pclose(fd); + } + else + // default if no action: output on stdout + cout << result << endl; +} + +// send all SMS messages in spool dir + +bool requestStatusReport = false; + +void sendSMS(string spoolDirBase, string sentDirBase, string failedDirBase, + unsigned int priority, bool enableSyslog, Ref at) +{ + string spoolDir = spoolDirBase; + string sentDir = sentDirBase; + string failedDir = failedDirBase; + if ( priority >= 1 ) + { + spoolDir = spoolDirBase + stringPrintf(_("%d"),priority); + sentDir = sentDirBase + stringPrintf(_("%d"),priority); + failedDir = failedDirBase + stringPrintf(_("%d"),priority); + } + if ( priority > 1 ) + sendSMS(spoolDirBase, sentDirBase, failedDirBase, priority-1, enableSyslog, at); + if (spoolDirBase != "") + { + // look into spoolDir for any outgoing SMS that should be sent +#ifdef WIN32 + struct _finddata_t fileInfo; + long fileHandle; + string pattern = spoolDir + "\\*"; + fileHandle = _findfirst(pattern.c_str(), &fileInfo); + bool moreFiles = fileHandle != -1L; +#else + DIR *dir = opendir(spoolDir.c_str()); + if (dir == (DIR*)NULL) + throw GsmException( + stringPrintf(_("error when calling opendir('%s')" + "(errno: %d/%s)"), + spoolDir.c_str(), errno, strerror(errno)), + OSError); +#endif + +#ifdef WIN32 + while (moreFiles) + { + if (strcmp(fileInfo.name, ".") != 0 && + strcmp(fileInfo.name, "..") != 0) +#else + struct dirent *entry; + while ((entry = readdir(dir)) != (struct dirent*)NULL) + if (strcmp(entry->d_name, ".") != 0 && + strcmp(entry->d_name, "..") != 0) +#endif + { + if ( priority > 1 ) + sendSMS(spoolDirBase, sentDirBase, failedDirBase, priority-1, enableSyslog, at); + // read in file + // the first line is interpreted as the phone number + // the rest is the message +#ifdef WIN32 + string filename = spoolDir + "\\" + fileInfo.name; +#else + string filename = spoolDir + "/" + entry->d_name; +#endif + ifstream ifs(filename.c_str()); + if (! ifs) +#ifndef WIN32 + if (enableSyslog) + { + syslog(LOG_WARNING, "Could not open SMS spool file %s", + filename.c_str()); + if (failedDirBase != "") { + string failedfilename = failedDir + "/" + entry->d_name; + rename(filename.c_str(),failedfilename.c_str()); + } + continue; + } + else +#endif + throw GsmException( + stringPrintf(_("count not open SMS spool file %s"), + filename.c_str()), ParameterError); + char phoneBuf[1001]; + ifs.getline(phoneBuf, 1000); + for(int i=0;i<1000;i++) + if(phoneBuf[i]=='\t' || phoneBuf[i]==0) + { // ignore everything after a in the phone number + phoneBuf[i]=0; + break; + } + string text; + while (! ifs.eof()) + { + char c; + ifs.get(c); + text += c; + } + ifs.close(); + + // remove trailing newline/linefeed + while (text[text.length() - 1] == '\n' || + text[text.length() - 1] == '\r') + text = text.substr(0, text.length() - 1); + + // send the message + string phoneNumber(phoneBuf); + Ref submitSMS = new SMSSubmitMessage(); + // set service centre address in new submit PDU if requested by user + if (serviceCentreAddress != "") + { + Address sca(serviceCentreAddress); + submitSMS->setServiceCentreAddress(sca); + } + submitSMS->setStatusReportRequest(requestStatusReport); + Address destAddr(phoneNumber); + submitSMS->setDestinationAddress(destAddr); + try + { + if (concatenatedMessageId == -1) + me->sendSMSs(submitSMS, text, true); + else + { + // maximum for concatenatedMessageId is 255 + if (concatenatedMessageId > 256) + concatenatedMessageId = 0; + me->sendSMSs(submitSMS, text, false, concatenatedMessageId++); + } +#ifndef WIN32 + if (enableSyslog) + syslog(LOG_NOTICE, "Sent SMS to %s from file %s", phoneBuf, filename.c_str()); +#endif + if (sentDirBase != "") { +#ifdef WIN32 + string sentfilename = sentDir + "\\" + fileInfo.name; +#else + string sentfilename = sentDir + "/" + entry->d_name; +#endif + rename(filename.c_str(),sentfilename.c_str()); + } else { + unlink(filename.c_str()); + } + } + catch (GsmException &me) + { +#ifndef WIN32 + if (enableSyslog) + syslog(LOG_WARNING, "Failed sending SMS to %s from file %s: %s", phoneBuf, + filename.c_str(), me.what()); + else +#endif + cerr << "Failed sending SMS to " << phoneBuf << " from " + << filename << ": " << me.what() << endl; + if (failedDirBase != "") { +#ifdef WIN32 + string failedfilename = failedDir + "\\" + fileInfo.name; +#else + string failedfilename = failedDir + "/" + entry->d_name; +#endif + rename(filename.c_str(),failedfilename.c_str()); + } + } +#ifdef WIN32 + } + moreFiles = _findnext(fileHandle, &fileInfo) == 0; +#endif + } +#ifdef WIN32 + _findclose(fileHandle); +#else + closedir(dir); +#endif + } +} + +#ifndef WIN32 +void syslogExit(int exitcode, int *dummy) +{ + syslog(LOG_NOTICE, "exited (exit %d)",exitcode); +} +#endif + +// *** main program + +int main(int argc, char *argv[]) +{ + bool enableSyslog = false; + try + { + string device = "/dev/mobilephone"; + string action; + string baudrate; + bool enableSMS = true; + bool enableCB = true; + bool enableStat = true; + bool flushSMS = false; + bool onlyReceptionIndication = true; + string spoolDir; + string sentDir = ""; + string failedDir = ""; + unsigned int priorities = 0; + string initString = DEFAULT_INIT_STRING; + bool swHandshake = false; + string concatenatedMessageIdStr; + + int opt; + int dummy; + while((opt = getopt_long(argc, argv, "c:C:I:t:fd:a:b:hvs:S:F:P:LXDr", + longOpts, &dummy)) != -1) + switch (opt) + { + case 'c': + concatenatedMessageIdStr = optarg; + break; + case 'r': + requestStatusReport = true; + break; + case 'D': + onlyReceptionIndication = false; + break; + case 'X': + swHandshake = true; + break; + case 'I': + initString = optarg; + break; + case 't': + receiveStoreName = optarg; + break; + case 'd': + device = optarg; + break; + case 'C': + serviceCentreAddress = optarg; + break; + case 's': + spoolDir = optarg; + break; + case 'S': + sentDir = optarg; + break; + case 'F': + failedDir = optarg; + break; + case 'P': + priorities = abs(atoi(optarg)); + break; + case 'f': + flushSMS = true; + break; + case 'a': + action = optarg; + break; + case 'b': + baudrate = optarg; + break; + case 'v': + cerr << argv[0] << stringPrintf(_(": version %s [compiled %s]"), + VERSION, __DATE__) << endl; + exit(0); + break; + case 'h': + cerr << argv[0] << _(": [-a action][-b baudrate][-C sca][-d device]" + "[-f][-h][-I init string]\n" + " [-s spool dir][-t][-v]{sms_type}") + << endl << endl + << _(" -a, --action the action to execute when an SMS " + "arrives\n" + " (SMS is send to stdin of action)") + << endl + << _(" -b, --baudrate baudrate to use for device " + "(default: 38400)") + << endl + << _(" -c, --concatenate start ID for concatenated SMS messages") + << endl + << _(" -C, --sca SMS service centre address") << endl + << _(" -d, --device sets the device to connect to") << endl + << _(" -D, --direct enable direct routing of SMSs") << endl + << _(" -f, --flush flush SMS from store") << endl + << _(" -F, --failed directory to move failed SMS to,") << endl + << _(" if unset, the SMS will be deleted") << endl + << _(" -h, --help prints this message") << endl + << _(" -I, --init device AT init sequence") << endl +#ifndef WIN32 + << _(" -L, --syslog log errors and information to syslog") + << endl +#endif + << _(" -P, --priorities number of priority levels to use,") << endl + << _(" (default: none)") << endl + << _(" -r, --requeststat request SMS status report") << endl + << _(" -s, --spool spool directory for outgoing SMS") + << endl + << _(" -S, --sent directory to move sent SMS to,") << endl + << _(" if unset, the SMS will be deleted") << endl + << _(" -t, --store name of SMS store to use for flush\n" + " and/or temporary SMS storage") << endl + << endl + << _(" -v, --version prints version and exits") << endl + << _(" -X, --xonxoff switch on software handshake") << endl + << endl + << _(" sms_type may be any combination of") << endl << endl + << _(" sms, no_sms controls reception of normal SMS") + << endl + << _(" cb, no_cb controls reception of cell broadcast" + " messages") << endl + << _(" stat, no_stat controls reception of status reports") + << endl << endl + << _(" default is \"sms cb stat\"") << endl << endl + << _("If no action is given, the SMS is printed to stdout") + << endl << endl + << _("If -P is given, it activates the priority system and sets the") << endl + << _("number or levels to use. For every level, there must be directories") << endl + << _("named +.") << endl + << _("For example \"-P 2 -s queue -S send -F failed\" needs the following") <getSMSStore(receiveStoreName); + + for (SMSStore::iterator s = store->begin(); s != store->end(); ++s) + if (! s->empty()) + { + string result = _("Type of message: "); + switch (s->message()->messageType()) + { + case SMSMessage::SMS_DELIVER: + result += _("SMS message\n"); + break; + case SMSMessage::SMS_SUBMIT_REPORT: + result += _("submit report message\n"); + break; + case SMSMessage::SMS_STATUS_REPORT: + result += _("status report message\n"); + break; + } + result += s->message()->toString(); + doAction(action, result); + store->erase(s); + } + } + + // set default SMS store if -t option was given or + // read from ME otherwise + if (receiveStoreName == "") + { + string dummy1, dummy2; + me->getSMSStore(dummy1, dummy2, receiveStoreName ); + } + else + me->setSMSStore(receiveStoreName, 3); + + // switch message service level to 1 + // this enables SMS routing to TA + me->setMessageService(1); + + // switch on SMS routing + me->setSMSRoutingToTA(enableSMS, enableCB, enableStat, + onlyReceptionIndication); + + // register event handler to handle routed SMSs, CBMs, and status reports + me->setEventHandler(new EventHandler()); + + // wait for new messages + bool exitScheduled = false; + while (1) + { +#ifdef WIN32 + ::timeval timeoutVal; + timeoutVal.tv_sec = 5; + timeoutVal.tv_usec = 0; + me->waitEvent((gsmlib::timeval *)&timeoutVal); +#else + struct timeval timeoutVal; + timeoutVal.tv_sec = 5; + timeoutVal.tv_usec = 0; + me->waitEvent(&timeoutVal); +#endif + // if it returns, there was an event or a timeout + while (newMessages.size() > 0) + { + // get first new message and remove it from the vector + SMSMessageRef newSMSMessage = newMessages.begin()->_newSMSMessage; + CBMessageRef newCBMessage = newMessages.begin()->_newCBMessage; + GsmEvent::SMSMessageType messageType = + newMessages.begin()->_messageType; + int index = newMessages.begin()->_index; + string storeName = newMessages.begin()->_storeName; + newMessages.erase(newMessages.begin()); + + // process the new message + string result = _("Type of message: "); + switch (messageType) + { + case GsmEvent::NormalSMS: + result += _("SMS message\n"); + break; + case GsmEvent::CellBroadcastSMS: + result += _("cell broadcast message\n"); + break; + case GsmEvent::StatusReportSMS: + result += _("status report message\n"); + break; + } + if (! newSMSMessage.isnull()) + result += newSMSMessage->toString(); + else if (! newCBMessage.isnull()) + result += newCBMessage->toString(); + else + { + SMSStoreRef store = me->getSMSStore(storeName); + store->setCaching(false); + + if (messageType == GsmEvent::CellBroadcastSMS) + result += (*store.getptr())[index].cbMessage()->toString(); + else + result += (*store.getptr())[index].message()->toString(); + + store->erase(store->begin() + index); + } + + // call the action + doAction(action, result); + } + + // if no new SMS came in and program exit was scheduled, then exit + if (exitScheduled) + exit(0); + + // handle terminate signal + if (terminateSent) + { + exitScheduled = true; + // switch off SMS routing + try + { + me->setSMSRoutingToTA(false, false, false); + } + catch (GsmException &ge) + { + // some phones (e.g. Motorola Timeport 260) don't allow to switch + // off SMS routing which results in an error. Just ignore this. + } + // the AT sequences involved in switching of SMS routing + // may yield more SMS events, so go round the loop one more time + } + + // send spooled SMS + if (! terminateSent) + sendSMS(spoolDir, sentDir, failedDir, priorities, enableSyslog, me->getAt()); + } + } + catch (GsmException &ge) + { + cerr << argv[0] << _("[ERROR]: ") << ge.what() << endl; + if (ge.getErrorClass() == MeTaCapabilityError) + cerr << argv[0] << _("[ERROR]: ") + << _("(try setting sms_type, please refer to gsmsmsd manpage)") + << endl; + // switch off message routing, so that following invocations of gsmsmd + // are not swamped with message deliveries while they start up + if (me != NULL) + { + try + { + me->setSMSRoutingToTA(false, false, false); + } + catch (GsmException &ge) + { + // some phones (e.g. Motorola Timeport 260) don't allow to switch + // off SMS routing which results in an error. Just ignore this. + } + } + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsmsstore.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsmsstore.cc new file mode 100644 index 0000000000..e164aafebf --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/apps/gsmsmsstore.cc @@ -0,0 +1,439 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsmsmsstore.cc +// * +// * Purpose: SMS store management program +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 4.8.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#ifdef WIN32 +#include +#else +#include +#include +#endif +#if defined(HAVE_GETOPT_LONG) || defined(WIN32) +#include +#endif +#include +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +#ifdef HAVE_GETOPT_LONG +static struct option longOpts[] = +{ + {"xonxoff", no_argument, (int*)NULL, 'X'}, + {"init", required_argument, (int*)NULL, 'I'}, + {"store", required_argument, (int*)NULL, 't'}, + {"erase", no_argument, (int*)NULL, 'e'}, + {"add", no_argument, (int*)NULL, 'a'}, + {"list", no_argument, (int*)NULL, 'l'}, + {"destination", required_argument, (int*)NULL, 'd'}, + {"source", required_argument, (int*)NULL, 's'}, + {"baudrate", required_argument, (int*)NULL, 'b'}, + {"sca", required_argument, (int*)NULL, 'C'}, + {"copy", no_argument, (int*)NULL, 'c'}, + {"delete", no_argument, (int*)NULL, 'x'}, + {"backup", no_argument, (int*)NULL, 'k'}, + {"help", no_argument, (int*)NULL, 'h'}, + {"version", no_argument, (int*)NULL, 'v'}, + {"verbose", no_argument, (int*)NULL, 'V'}, + {(char*)NULL, 0, (int*)NULL, 0} +}; +#else +#define getopt_long(argc, argv, options, longopts, indexptr) \ + getopt(argc, argv, options) +#endif + +bool verbose = false; // true if --verbose option given + +// type of operation to perform + +enum Operation {CopyOp = 'c', BackupOp = 'k', DeleteOp = 'x', + AddOp = 'a', ListOp = 'l', NoOp = 0}; + +// aux function, insert entry only if not already present in dest + +void backup(SortedSMSStoreRef destStore, SMSStoreEntry &entry) +{ + // the following only works because we know that the default sort order + // is by date + assert(destStore->sortOrder() == ByDate); + + Timestamp date = entry.message()->serviceCentreTimestamp(); + pair range = + destStore->equal_range(date); + + for (SortedSMSStore::iterator j = range.first; + j != range.second; ++j) + if (entry == *j) + // do nothing if the entry is already present in the destination + return; + + if (verbose) + cout << stringPrintf(_("inserting entry #%d from source into destination"), + entry.index()) << endl + << entry.message()->toString(); + destStore->insert(entry); // insert +} + +// aux function, throw exception if operation != NoOp + +void checkNoOp(Operation operation, int opt) +{ + if (operation != NoOp) + throw GsmException(stringPrintf(_("incompatible options '%c' and '%c'"), + (char)operation, (char)opt), + ParameterError); +} + +// *** main program + +int main(int argc, char *argv[]) +{ + try + { + // handle command line options + string destination; + string source; + string baudrate; + string storeName; + char operation = NoOp; + SortedSMSStoreRef sourceStore, destStore; + bool useIndices = false; // use indices in delete, copy, backup op + string initString = DEFAULT_INIT_STRING; + bool swHandshake = false; + // service centre address (set on command line) + string serviceCentreAddress; + Ref sourceMeTa, destMeTa; + + int opt; + int dummy; + while((opt = getopt_long(argc, argv, "I:t:s:d:b:cxlakhvVXC:", + longOpts, &dummy)) + != -1) + switch (opt) + { + case 'C': + serviceCentreAddress = optarg; + break; + case 'X': + swHandshake = true; + break; + case 'I': + initString = optarg; + break; + case 'V': + verbose = true; + break; + case 't': + storeName = optarg; + break; + case 'd': + destination = optarg; + break; + case 's': + source = optarg; + break; + case 'b': + baudrate = optarg; + break; + case 'c': + checkNoOp((Operation)operation, opt); + operation = CopyOp; + break; + case 'x': + checkNoOp((Operation)operation, opt); + operation = DeleteOp; + break; + case 'l': + checkNoOp((Operation)operation, opt); + operation = ListOp; + break; + case 'a': + checkNoOp((Operation)operation, opt); + operation = AddOp; + break; + case 'k': + checkNoOp((Operation)operation, opt); + operation = BackupOp; + break; + case 'v': + cerr << argv[0] << stringPrintf(_(": version %s [compiled %s]"), + VERSION, __DATE__) << endl; + exit(0); + break; + case 'h': + cerr << argv[0] << _(": [-a][-b baudrate][-c][-C sca]" + "[-d device or file]\n" + " [-h][-I init string][-k][-l]" + "[-s device or file]" + "[-t SMS store name]\n [-v][-V][-x][-X]" + "{indices}|[phonenumber text]") << endl + << endl + << _(" -a, --add add new SMS submit message\n" + " (phonenumber and text) to destination") + << endl + << _(" -b, --baudrate baudrate to use for device " + "(default: 38400)") + << endl + << _(" -c, --copy copy source entries to destination\n" + " (if indices are given, " + "copy only these entries)") << endl + << _(" -C, --sca SMS service centre address") << endl + << _(" -d, --destination sets the destination device to\n" + " connect to, or the file to write to") + << endl + << _(" -h, --help prints this message") << endl + << _(" -I, --init device AT init sequence") << endl + << _(" -k, --backup backup new entries to destination\n" + " (if indices are given, " + "copy only these entries)") << endl + << _(" -l, --list list source to stdout") << endl + << _(" -s, --source sets the source device to connect to,\n" + " or the file to read") << endl + << _(" -t, --store name of SMS store to use") << endl + << _(" -v, --version prints version and exits") << endl + << _(" -V, --verbose print detailed progress messages") + << endl + << _(" -x, --delete delete entries denoted by indices") + << endl + << _(" -X, --xonxoff switch on software handshake") << endl + << endl; + exit(0); + break; + case '?': + throw GsmException(_("unknown option"), ParameterError); + break; + } + + // check if parameters are complete + if (operation == NoOp) + throw GsmException(_("no operation option given"), ParameterError); + if (operation == BackupOp || operation == CopyOp) + if (destination.length() == 0 || source.length() == 0) + throw GsmException(_("both source and destination required"), + ParameterError); + if (operation == ListOp) + { + if (destination.length() != 0) + throw GsmException(_("destination must not be given"), ParameterError); + if (source.length() == 0) + throw GsmException(_("source required"), ParameterError); + } + if (operation == AddOp || operation == DeleteOp) + { + if (source.length() != 0) + throw GsmException(_("source must not be given"), ParameterError); + if (destination.length() == 0) + throw GsmException(_("destination required"), ParameterError); + } + if (operation == CopyOp || operation == DeleteOp || operation == BackupOp) + { + // check if all indices are numbers + for (int i = optind; i < argc; ++i) + for (char *pp = argv[i]; *pp != 0; ++pp) + if (! isdigit(*pp)) + throw GsmException(stringPrintf(_("expected number, got '%s'"), + argv[i]), ParameterError); + useIndices = optind != argc; + } + else if (operation == AddOp) + { + if (optind + 2 < argc) + throw GsmException(_("more than two parameters given"), + ParameterError); + if (optind + 2 > argc) + throw GsmException(_("not enough parameters given"), + ParameterError); + } + else + if (optind != argc) + throw GsmException(_("unexpected parameters"), ParameterError); + + // start accessing source store or file if required by operation + if (operation == CopyOp || operation == BackupOp || operation == ListOp) + if (source == "-") + sourceStore = new SortedSMSStore(true); + else if (isFile(source)) + sourceStore = new SortedSMSStore(source); + else + { + if (storeName == "") + throw GsmException(_("store name must be given"), ParameterError); + + sourceMeTa = new MeTa(new +#ifdef WIN32 + Win32SerialPort +#else + UnixSerialPort +#endif + (source, + baudrate == "" ? DEFAULT_BAUD_RATE : + baudRateStrToSpeed(baudrate), initString, + swHandshake)); + sourceStore = new SortedSMSStore(sourceMeTa->getSMSStore(storeName)); + } + + // make sure destination file exists + if (destination != "") + { + try + { + ofstream f(destination.c_str(), ios::out | ios::app | ios::binary); + } + catch (exception) + { + } + } + + // start accessing destination destination store or file + if (operation == CopyOp || operation == BackupOp || operation == AddOp || + operation == DeleteOp) + if (destination == "-") + destStore = new SortedSMSStore(false); + else if (isFile(destination)) + destStore = new SortedSMSStore(destination); + else + { + if (storeName == "") + throw GsmException(_("store name must be given"), ParameterError); + + destMeTa = new MeTa(new +#ifdef WIN32 + Win32SerialPort +#else + UnixSerialPort +#endif + (destination, + baudrate == "" ? DEFAULT_BAUD_RATE : + baudRateStrToSpeed(baudrate), initString, + swHandshake)); + destStore = new SortedSMSStore(destMeTa->getSMSStore(storeName)); + } + + // now do the actual work + switch (operation) + { + case BackupOp: + { + sourceStore->setSortOrder(ByIndex); // needed in loop + + if (useIndices) + for (int i = optind; i < argc; ++i) + { + SortedSMSStore::iterator j = sourceStore->find(atoi(argv[i])); + if (j == sourceStore->end()) + throw GsmException(stringPrintf(_("no index '%s' in source"), + argv[i]), ParameterError); + backup(destStore, *j); + } + else + for (SortedSMSStore::iterator i = sourceStore->begin(); + i != sourceStore->end(); ++i) + backup(destStore, *i); + break; + } + case CopyOp: + { + destStore->clear(); + if (! useIndices) // copy all entries + { + for (SortedSMSStore::iterator i = sourceStore->begin(); + i != sourceStore->end(); ++i) + { + if (verbose) + cout << stringPrintf(_("inserting entry #%d from source " + "into destination"), i->index()) << endl + << i->message()->toString(); + destStore->insert(*i); + } + } + else // copy indexed entries + { + sourceStore->setSortOrder(ByIndex); // needed in loop + + for (int i = optind; i < argc; ++i) + { + SortedSMSStore::iterator j = sourceStore->find(atoi(argv[i])); + if (j == sourceStore->end()) + throw GsmException(stringPrintf(_("no index '%s' in source"), + argv[i]), ParameterError); + if (verbose) + cout << stringPrintf(_("inserting entry #%d from source into " + "destination"), j->index()) << endl + << j->message()->toString(); + destStore->insert(*j); + } + } + break; + } + case ListOp: + { + for (SortedSMSStore::iterator i = sourceStore->begin(); + i != sourceStore->end(); ++i) + cout << stringPrintf(_("index #%d"), i->index()) << endl + << i->message()->toString(); + break; + } + case AddOp: + { + SMSMessageRef sms = new SMSSubmitMessage(argv[optind + 1], argv[optind]); + // set service centre address in new submit PDU if requested by user + if (serviceCentreAddress != "") + { + Address sca(serviceCentreAddress); + sms->setServiceCentreAddress(sca); + } + if (verbose) + cout << _("inserting new entry into destination") << endl + << sms->toString(); + destStore->insert(sms); + break; + } + case DeleteOp: + { + destStore->setSortOrder(ByIndex); + for (int i = optind; i < argc; ++i) + { + int index = atoi(argv[i]); + if (verbose) + { + SortedSMSStore::iterator e = destStore->find(index); + if (e != destStore->end()) + cout << stringPrintf(_("deleting entry #%d from destination"), + index) << endl + << e->message()->toString(); + } + if (destStore->erase(index) != 1) + throw GsmException(stringPrintf(_("no index '%s' in destination"), + argv[i]), ParameterError); + } + break; + } + } + } + catch (GsmException &ge) + { + cerr << argv[0] << _("[ERROR]: ") << ge.what() << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/configure b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/configure new file mode 100755 index 0000000000..5918af81fb --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/configure @@ -0,0 +1,30623 @@ +#! /bin/sh +# Guess values for system-dependent variables and create Makefiles. +# Generated by GNU Autoconf 2.59. +# +# Copyright (C) 2003 Free Software Foundation, Inc. +# This configure script is free software; the Free Software Foundation +# gives unlimited permission to copy, distribute and modify it. +## --------------------- ## +## M4sh Initialization. ## +## --------------------- ## + +# Be Bourne compatible +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then + emulate sh + NULLCMD=: + # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which + # is contrary to our usage. Disable this feature. + alias -g '${1+"$@"}'='"$@"' +elif test -n "${BASH_VERSION+set}" && (set -o posix) >/dev/null 2>&1; then + set -o posix +fi +DUALCASE=1; export DUALCASE # for MKS sh + +# Support unset when possible. +if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then + as_unset=unset +else + as_unset=false +fi + + +# Work around bugs in pre-3.0 UWIN ksh. +$as_unset ENV MAIL MAILPATH +PS1='$ ' +PS2='> ' +PS4='+ ' + +# NLS nuisances. +for as_var in \ + LANG LANGUAGE LC_ADDRESS LC_ALL LC_COLLATE LC_CTYPE LC_IDENTIFICATION \ + LC_MEASUREMENT LC_MESSAGES LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER \ + LC_TELEPHONE LC_TIME +do + if (set +x; test -z "`(eval $as_var=C; export $as_var) 2>&1`"); then + eval $as_var=C; export $as_var + else + $as_unset $as_var + fi +done + +# Required to use basename. +if expr a : '\(a\)' >/dev/null 2>&1; then + as_expr=expr +else + as_expr=false +fi + +if (basename /) >/dev/null 2>&1 && test "X`basename / 2>&1`" = "X/"; then + as_basename=basename +else + as_basename=false +fi + + +# Name of the executable. +as_me=`$as_basename "$0" || +$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ + X"$0" : 'X\(//\)$' \| \ + X"$0" : 'X\(/\)$' \| \ + . : '\(.\)' 2>/dev/null || +echo X/"$0" | + sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/; q; } + /^X\/\(\/\/\)$/{ s//\1/; q; } + /^X\/\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + + +# PATH needs CR, and LINENO needs CR and PATH. +# Avoid depending upon Character Ranges. +as_cr_letters='abcdefghijklmnopqrstuvwxyz' +as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' +as_cr_Letters=$as_cr_letters$as_cr_LETTERS +as_cr_digits='0123456789' +as_cr_alnum=$as_cr_Letters$as_cr_digits + +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + echo "#! /bin/sh" >conf$$.sh + echo "exit 0" >>conf$$.sh + chmod +x conf$$.sh + if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then + PATH_SEPARATOR=';' + else + PATH_SEPARATOR=: + fi + rm -f conf$$.sh +fi + + + as_lineno_1=$LINENO + as_lineno_2=$LINENO + as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null` + test "x$as_lineno_1" != "x$as_lineno_2" && + test "x$as_lineno_3" = "x$as_lineno_2" || { + # Find who we are. Look in the path if we contain no path at all + # relative or not. + case $0 in + *[\\/]* ) as_myself=$0 ;; + *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break +done + + ;; + esac + # We did not find ourselves, most probably we were run as `sh COMMAND' + # in which case we are not to be found in the path. + if test "x$as_myself" = x; then + as_myself=$0 + fi + if test ! -f "$as_myself"; then + { echo "$as_me: error: cannot find myself; rerun with an absolute path" >&2 + { (exit 1); exit 1; }; } + fi + case $CONFIG_SHELL in + '') + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for as_base in sh bash ksh sh5; do + case $as_dir in + /*) + if ("$as_dir/$as_base" -c ' + as_lineno_1=$LINENO + as_lineno_2=$LINENO + as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null` + test "x$as_lineno_1" != "x$as_lineno_2" && + test "x$as_lineno_3" = "x$as_lineno_2" ') 2>/dev/null; then + $as_unset BASH_ENV || test "${BASH_ENV+set}" != set || { BASH_ENV=; export BASH_ENV; } + $as_unset ENV || test "${ENV+set}" != set || { ENV=; export ENV; } + CONFIG_SHELL=$as_dir/$as_base + export CONFIG_SHELL + exec "$CONFIG_SHELL" "$0" ${1+"$@"} + fi;; + esac + done +done +;; + esac + + # Create $as_me.lineno as a copy of $as_myself, but with $LINENO + # uniformly replaced by the line number. The first 'sed' inserts a + # line-number line before each line; the second 'sed' does the real + # work. The second script uses 'N' to pair each line-number line + # with the numbered line, and appends trailing '-' during + # substitution so that $LINENO is not a special case at line end. + # (Raja R Harinath suggested sed '=', and Paul Eggert wrote the + # second 'sed' script. Blame Lee E. McMahon for sed's syntax. :-) + sed '=' <$as_myself | + sed ' + N + s,$,-, + : loop + s,^\(['$as_cr_digits']*\)\(.*\)[$]LINENO\([^'$as_cr_alnum'_]\),\1\2\1\3, + t loop + s,-$,, + s,^['$as_cr_digits']*\n,, + ' >$as_me.lineno && + chmod +x $as_me.lineno || + { echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2 + { (exit 1); exit 1; }; } + + # Don't try to exec as it changes $[0], causing all sort of problems + # (the dirname of $[0] is not the place where we might find the + # original and so on. Autoconf is especially sensible to this). + . ./$as_me.lineno + # Exit status is that of the last command. + exit +} + + +case `echo "testing\c"; echo 1,2,3`,`echo -n testing; echo 1,2,3` in + *c*,-n*) ECHO_N= ECHO_C=' +' ECHO_T=' ' ;; + *c*,* ) ECHO_N=-n ECHO_C= ECHO_T= ;; + *) ECHO_N= ECHO_C='\c' ECHO_T= ;; +esac + +if expr a : '\(a\)' >/dev/null 2>&1; then + as_expr=expr +else + as_expr=false +fi + +rm -f conf$$ conf$$.exe conf$$.file +echo >conf$$.file +if ln -s conf$$.file conf$$ 2>/dev/null; then + # We could just check for DJGPP; but this test a) works b) is more generic + # and c) will remain valid once DJGPP supports symlinks (DJGPP 2.04). + if test -f conf$$.exe; then + # Don't use ln at all; we don't have any links + as_ln_s='cp -p' + else + as_ln_s='ln -s' + fi +elif ln conf$$.file conf$$ 2>/dev/null; then + as_ln_s=ln +else + as_ln_s='cp -p' +fi +rm -f conf$$ conf$$.exe conf$$.file + +if mkdir -p . 2>/dev/null; then + as_mkdir_p=: +else + test -d ./-p && rmdir ./-p + as_mkdir_p=false +fi + +as_executable_p="test -f" + +# Sed expression to map a string onto a valid CPP name. +as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" + +# Sed expression to map a string onto a valid variable name. +as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" + + +# IFS +# We need space, tab and new line, in precisely that order. +as_nl=' +' +IFS=" $as_nl" + +# CDPATH. +$as_unset CDPATH + + + +# Check that we are running under the correct shell. +SHELL=${CONFIG_SHELL-/bin/sh} + +case X$ECHO in +X*--fallback-echo) + # Remove one level of quotation (which was required for Make). + ECHO=`echo "$ECHO" | sed 's,\\\\\$\\$0,'$0','` + ;; +esac + +echo=${ECHO-echo} +if test "X$1" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift +elif test "X$1" = X--fallback-echo; then + # Avoid inline document here, it may be left over + : +elif test "X`($echo '\t') 2>/dev/null`" = 'X\t' ; then + # Yippee, $echo works! + : +else + # Restart under the correct shell. + exec $SHELL "$0" --no-reexec ${1+"$@"} +fi + +if test "X$1" = X--fallback-echo; then + # used as fallback echo + shift + cat </dev/null 2>&1 && unset CDPATH + +if test -z "$ECHO"; then +if test "X${echo_test_string+set}" != Xset; then +# find a string as large as possible, as long as the shell can cope with it + for cmd in 'sed 50q "$0"' 'sed 20q "$0"' 'sed 10q "$0"' 'sed 2q "$0"' 'echo test'; do + # expected sizes: less than 2Kb, 1Kb, 512 bytes, 16 bytes, ... + if (echo_test_string=`eval $cmd`) 2>/dev/null && + echo_test_string=`eval $cmd` && + (test "X$echo_test_string" = "X$echo_test_string") 2>/dev/null + then + break + fi + done +fi + +if test "X`($echo '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`($echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + : +else + # The Solaris, AIX, and Digital Unix default echo programs unquote + # backslashes. This makes it impossible to quote backslashes using + # echo "$something" | sed 's/\\/\\\\/g' + # + # So, first we look for a working echo in the user's PATH. + + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for dir in $PATH /usr/ucb; do + IFS="$lt_save_ifs" + if (test -f $dir/echo || test -f $dir/echo$ac_exeext) && + test "X`($dir/echo '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`($dir/echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + echo="$dir/echo" + break + fi + done + IFS="$lt_save_ifs" + + if test "X$echo" = Xecho; then + # We didn't find a better echo, so look for alternatives. + if test "X`(print -r '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`(print -r "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + # This shell has a builtin print -r that does the trick. + echo='print -r' + elif (test -f /bin/ksh || test -f /bin/ksh$ac_exeext) && + test "X$CONFIG_SHELL" != X/bin/ksh; then + # If we have ksh, try running configure again with it. + ORIGINAL_CONFIG_SHELL=${CONFIG_SHELL-/bin/sh} + export ORIGINAL_CONFIG_SHELL + CONFIG_SHELL=/bin/ksh + export CONFIG_SHELL + exec $CONFIG_SHELL "$0" --no-reexec ${1+"$@"} + else + # Try using printf. + echo='printf %s\n' + if test "X`($echo '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`($echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + # Cool, printf works + : + elif echo_testing_string=`($ORIGINAL_CONFIG_SHELL "$0" --fallback-echo '\t') 2>/dev/null` && + test "X$echo_testing_string" = 'X\t' && + echo_testing_string=`($ORIGINAL_CONFIG_SHELL "$0" --fallback-echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + CONFIG_SHELL=$ORIGINAL_CONFIG_SHELL + export CONFIG_SHELL + SHELL="$CONFIG_SHELL" + export SHELL + echo="$CONFIG_SHELL $0 --fallback-echo" + elif echo_testing_string=`($CONFIG_SHELL "$0" --fallback-echo '\t') 2>/dev/null` && + test "X$echo_testing_string" = 'X\t' && + echo_testing_string=`($CONFIG_SHELL "$0" --fallback-echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + echo="$CONFIG_SHELL $0 --fallback-echo" + else + # maybe with a smaller string... + prev=: + + for cmd in 'echo test' 'sed 2q "$0"' 'sed 10q "$0"' 'sed 20q "$0"' 'sed 50q "$0"'; do + if (test "X$echo_test_string" = "X`eval $cmd`") 2>/dev/null + then + break + fi + prev="$cmd" + done + + if test "$prev" != 'sed 50q "$0"'; then + echo_test_string=`eval $prev` + export echo_test_string + exec ${ORIGINAL_CONFIG_SHELL-${CONFIG_SHELL-/bin/sh}} "$0" ${1+"$@"} + else + # Oops. We lost completely, so just stick with echo. + echo=echo + fi + fi + fi + fi +fi +fi + +# Copy echo and quote the copy suitably for passing to libtool from +# the Makefile, instead of quoting the original, which is used later. +ECHO=$echo +if test "X$ECHO" = "X$CONFIG_SHELL $0 --fallback-echo"; then + ECHO="$CONFIG_SHELL \\\$\$0 --fallback-echo" +fi + + + + +tagnames=${tagnames+${tagnames},}CXX + +tagnames=${tagnames+${tagnames},}F77 + +# Name of the host. +# hostname on some systems (SVR3.2, Linux) returns a bogus exit status, +# so uname gets run too. +ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` + +exec 6>&1 + +# +# Initializations. +# +ac_default_prefix=/usr/local +ac_config_libobj_dir=. +cross_compiling=no +subdirs= +MFLAGS= +MAKEFLAGS= +SHELL=${CONFIG_SHELL-/bin/sh} + +# Maximum number of lines to put in a shell here document. +# This variable seems obsolete. It should probably be removed, and +# only ac_max_sed_lines should be used. +: ${ac_max_here_lines=38} + +# Identity of this package. +PACKAGE_NAME= +PACKAGE_TARNAME= +PACKAGE_VERSION= +PACKAGE_STRING= +PACKAGE_BUGREPORT= + +ac_unique_file="gsmlib/gsm_error.h" +# Factoring default headers for most tests. +ac_includes_default="\ +#include +#if HAVE_SYS_TYPES_H +# include +#endif +#if HAVE_SYS_STAT_H +# include +#endif +#if STDC_HEADERS +# include +# include +#else +# if HAVE_STDLIB_H +# include +# endif +#endif +#if HAVE_STRING_H +# if !STDC_HEADERS && HAVE_MEMORY_H +# include +# endif +# include +#endif +#if HAVE_STRINGS_H +# include +#endif +#if HAVE_INTTYPES_H +# include +#else +# if HAVE_STDINT_H +# include +# endif +#endif +#if HAVE_UNISTD_H +# include +#endif" + +ac_subst_vars='SHELL PATH_SEPARATOR PACKAGE_NAME PACKAGE_TARNAME PACKAGE_VERSION PACKAGE_STRING PACKAGE_BUGREPORT exec_prefix prefix program_transform_name bindir sbindir libexecdir datadir sysconfdir sharedstatedir localstatedir libdir includedir oldincludedir infodir mandir build_alias host_alias target_alias DEFS ECHO_C ECHO_N ECHO_T LIBS INSTALL_PROGRAM INSTALL_SCRIPT INSTALL_DATA CC CFLAGS LDFLAGS CPPFLAGS ac_ct_CC EXEEXT OBJEXT CYGPATH_W PACKAGE VERSION ACLOCAL AUTOCONF AUTOMAKE AUTOHEADER MAKEINFO install_sh STRIP ac_ct_STRIP INSTALL_STRIP_PROGRAM mkdir_p AWK SET_MAKE am__leading_dot AMTAR am__tar am__untar DEPDIR am__include am__quote AMDEP_TRUE AMDEP_FALSE AMDEPBACKSLASH CCDEPMODE am__fastdepCC_TRUE am__fastdepCC_FALSE build build_cpu build_vendor build_os host host_cpu host_vendor host_os EGREP LN_S ECHO AR ac_ct_AR RANLIB ac_ct_RANLIB CPP CXX CXXFLAGS ac_ct_CXX CXXDEPMODE am__fastdepCXX_TRUE am__fastdepCXX_FALSE CXXCPP F77 FFLAGS ac_ct_F77 LIBTOOL ALLOCA GSM_VERSION MKINSTALLDIRS USE_NLS MSGFMT GMSGFMT XGETTEXT MSGMERGE GLIBC2 GLIBC21 INTL_MACOSX_LIBS HAVE_POSIX_PRINTF HAVE_ASPRINTF HAVE_SNPRINTF HAVE_WPRINTF LIBICONV LTLIBICONV INTLBISON BUILD_INCLUDED_LIBINTL USE_INCLUDED_LIBINTL CATOBJEXT DATADIRNAME INSTOBJEXT GENCAT INTLOBJS INTL_LIBTOOL_SUFFIX_PREFIX INTLLIBS LIBINTL LTLIBINTL POSUB COMPILE_INTL_TRUE COMPILE_INTL_FALSE LIBOBJS LTLIBOBJS' +ac_subst_files='' + +# Initialize some variables set by options. +ac_init_help= +ac_init_version=false +# The variables have the same names as the options, with +# dashes changed to underlines. +cache_file=/dev/null +exec_prefix=NONE +no_create= +no_recursion= +prefix=NONE +program_prefix=NONE +program_suffix=NONE +program_transform_name=s,x,x, +silent= +site= +srcdir= +verbose= +x_includes=NONE +x_libraries=NONE + +# Installation directory options. +# These are left unexpanded so users can "make install exec_prefix=/foo" +# and all the variables that are supposed to be based on exec_prefix +# by default will actually change. +# Use braces instead of parens because sh, perl, etc. also accept them. +bindir='${exec_prefix}/bin' +sbindir='${exec_prefix}/sbin' +libexecdir='${exec_prefix}/libexec' +datadir='${prefix}/share' +sysconfdir='${prefix}/etc' +sharedstatedir='${prefix}/com' +localstatedir='${prefix}/var' +libdir='${exec_prefix}/lib' +includedir='${prefix}/include' +oldincludedir='/usr/include' +infodir='${prefix}/info' +mandir='${prefix}/man' + +ac_prev= +for ac_option +do + # If the previous option needs an argument, assign it. + if test -n "$ac_prev"; then + eval "$ac_prev=\$ac_option" + ac_prev= + continue + fi + + ac_optarg=`expr "x$ac_option" : 'x[^=]*=\(.*\)'` + + # Accept the important Cygnus configure options, so we can diagnose typos. + + case $ac_option in + + -bindir | --bindir | --bindi | --bind | --bin | --bi) + ac_prev=bindir ;; + -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) + bindir=$ac_optarg ;; + + -build | --build | --buil | --bui | --bu) + ac_prev=build_alias ;; + -build=* | --build=* | --buil=* | --bui=* | --bu=*) + build_alias=$ac_optarg ;; + + -cache-file | --cache-file | --cache-fil | --cache-fi \ + | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) + ac_prev=cache_file ;; + -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ + | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) + cache_file=$ac_optarg ;; + + --config-cache | -C) + cache_file=config.cache ;; + + -datadir | --datadir | --datadi | --datad | --data | --dat | --da) + ac_prev=datadir ;; + -datadir=* | --datadir=* | --datadi=* | --datad=* | --data=* | --dat=* \ + | --da=*) + datadir=$ac_optarg ;; + + -disable-* | --disable-*) + ac_feature=`expr "x$ac_option" : 'x-*disable-\(.*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_feature" : ".*[^-_$as_cr_alnum]" >/dev/null && + { echo "$as_me: error: invalid feature name: $ac_feature" >&2 + { (exit 1); exit 1; }; } + ac_feature=`echo $ac_feature | sed 's/-/_/g'` + eval "enable_$ac_feature=no" ;; + + -enable-* | --enable-*) + ac_feature=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_feature" : ".*[^-_$as_cr_alnum]" >/dev/null && + { echo "$as_me: error: invalid feature name: $ac_feature" >&2 + { (exit 1); exit 1; }; } + ac_feature=`echo $ac_feature | sed 's/-/_/g'` + case $ac_option in + *=*) ac_optarg=`echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"`;; + *) ac_optarg=yes ;; + esac + eval "enable_$ac_feature='$ac_optarg'" ;; + + -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ + | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ + | --exec | --exe | --ex) + ac_prev=exec_prefix ;; + -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ + | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ + | --exec=* | --exe=* | --ex=*) + exec_prefix=$ac_optarg ;; + + -gas | --gas | --ga | --g) + # Obsolete; use --with-gas. + with_gas=yes ;; + + -help | --help | --hel | --he | -h) + ac_init_help=long ;; + -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) + ac_init_help=recursive ;; + -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) + ac_init_help=short ;; + + -host | --host | --hos | --ho) + ac_prev=host_alias ;; + -host=* | --host=* | --hos=* | --ho=*) + host_alias=$ac_optarg ;; + + -includedir | --includedir | --includedi | --included | --include \ + | --includ | --inclu | --incl | --inc) + ac_prev=includedir ;; + -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ + | --includ=* | --inclu=* | --incl=* | --inc=*) + includedir=$ac_optarg ;; + + -infodir | --infodir | --infodi | --infod | --info | --inf) + ac_prev=infodir ;; + -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) + infodir=$ac_optarg ;; + + -libdir | --libdir | --libdi | --libd) + ac_prev=libdir ;; + -libdir=* | --libdir=* | --libdi=* | --libd=*) + libdir=$ac_optarg ;; + + -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ + | --libexe | --libex | --libe) + ac_prev=libexecdir ;; + -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ + | --libexe=* | --libex=* | --libe=*) + libexecdir=$ac_optarg ;; + + -localstatedir | --localstatedir | --localstatedi | --localstated \ + | --localstate | --localstat | --localsta | --localst \ + | --locals | --local | --loca | --loc | --lo) + ac_prev=localstatedir ;; + -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ + | --localstate=* | --localstat=* | --localsta=* | --localst=* \ + | --locals=* | --local=* | --loca=* | --loc=* | --lo=*) + localstatedir=$ac_optarg ;; + + -mandir | --mandir | --mandi | --mand | --man | --ma | --m) + ac_prev=mandir ;; + -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) + mandir=$ac_optarg ;; + + -nfp | --nfp | --nf) + # Obsolete; use --without-fp. + with_fp=no ;; + + -no-create | --no-create | --no-creat | --no-crea | --no-cre \ + | --no-cr | --no-c | -n) + no_create=yes ;; + + -no-recursion | --no-recursion | --no-recursio | --no-recursi \ + | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) + no_recursion=yes ;; + + -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ + | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ + | --oldin | --oldi | --old | --ol | --o) + ac_prev=oldincludedir ;; + -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ + | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ + | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) + oldincludedir=$ac_optarg ;; + + -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) + ac_prev=prefix ;; + -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) + prefix=$ac_optarg ;; + + -program-prefix | --program-prefix | --program-prefi | --program-pref \ + | --program-pre | --program-pr | --program-p) + ac_prev=program_prefix ;; + -program-prefix=* | --program-prefix=* | --program-prefi=* \ + | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) + program_prefix=$ac_optarg ;; + + -program-suffix | --program-suffix | --program-suffi | --program-suff \ + | --program-suf | --program-su | --program-s) + ac_prev=program_suffix ;; + -program-suffix=* | --program-suffix=* | --program-suffi=* \ + | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) + program_suffix=$ac_optarg ;; + + -program-transform-name | --program-transform-name \ + | --program-transform-nam | --program-transform-na \ + | --program-transform-n | --program-transform- \ + | --program-transform | --program-transfor \ + | --program-transfo | --program-transf \ + | --program-trans | --program-tran \ + | --progr-tra | --program-tr | --program-t) + ac_prev=program_transform_name ;; + -program-transform-name=* | --program-transform-name=* \ + | --program-transform-nam=* | --program-transform-na=* \ + | --program-transform-n=* | --program-transform-=* \ + | --program-transform=* | --program-transfor=* \ + | --program-transfo=* | --program-transf=* \ + | --program-trans=* | --program-tran=* \ + | --progr-tra=* | --program-tr=* | --program-t=*) + program_transform_name=$ac_optarg ;; + + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil) + silent=yes ;; + + -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) + ac_prev=sbindir ;; + -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ + | --sbi=* | --sb=*) + sbindir=$ac_optarg ;; + + -sharedstatedir | --sharedstatedir | --sharedstatedi \ + | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ + | --sharedst | --shareds | --shared | --share | --shar \ + | --sha | --sh) + ac_prev=sharedstatedir ;; + -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ + | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ + | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ + | --sha=* | --sh=*) + sharedstatedir=$ac_optarg ;; + + -site | --site | --sit) + ac_prev=site ;; + -site=* | --site=* | --sit=*) + site=$ac_optarg ;; + + -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) + ac_prev=srcdir ;; + -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) + srcdir=$ac_optarg ;; + + -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ + | --syscon | --sysco | --sysc | --sys | --sy) + ac_prev=sysconfdir ;; + -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ + | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) + sysconfdir=$ac_optarg ;; + + -target | --target | --targe | --targ | --tar | --ta | --t) + ac_prev=target_alias ;; + -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) + target_alias=$ac_optarg ;; + + -v | -verbose | --verbose | --verbos | --verbo | --verb) + verbose=yes ;; + + -version | --version | --versio | --versi | --vers | -V) + ac_init_version=: ;; + + -with-* | --with-*) + ac_package=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_package" : ".*[^-_$as_cr_alnum]" >/dev/null && + { echo "$as_me: error: invalid package name: $ac_package" >&2 + { (exit 1); exit 1; }; } + ac_package=`echo $ac_package| sed 's/-/_/g'` + case $ac_option in + *=*) ac_optarg=`echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"`;; + *) ac_optarg=yes ;; + esac + eval "with_$ac_package='$ac_optarg'" ;; + + -without-* | --without-*) + ac_package=`expr "x$ac_option" : 'x-*without-\(.*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_package" : ".*[^-_$as_cr_alnum]" >/dev/null && + { echo "$as_me: error: invalid package name: $ac_package" >&2 + { (exit 1); exit 1; }; } + ac_package=`echo $ac_package | sed 's/-/_/g'` + eval "with_$ac_package=no" ;; + + --x) + # Obsolete; use --with-x. + with_x=yes ;; + + -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ + | --x-incl | --x-inc | --x-in | --x-i) + ac_prev=x_includes ;; + -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ + | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) + x_includes=$ac_optarg ;; + + -x-libraries | --x-libraries | --x-librarie | --x-librari \ + | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) + ac_prev=x_libraries ;; + -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ + | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) + x_libraries=$ac_optarg ;; + + -*) { echo "$as_me: error: unrecognized option: $ac_option +Try \`$0 --help' for more information." >&2 + { (exit 1); exit 1; }; } + ;; + + *=*) + ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` + # Reject names that are not valid shell variable names. + expr "x$ac_envvar" : ".*[^_$as_cr_alnum]" >/dev/null && + { echo "$as_me: error: invalid variable name: $ac_envvar" >&2 + { (exit 1); exit 1; }; } + ac_optarg=`echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` + eval "$ac_envvar='$ac_optarg'" + export $ac_envvar ;; + + *) + # FIXME: should be removed in autoconf 3.0. + echo "$as_me: WARNING: you should use --build, --host, --target" >&2 + expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && + echo "$as_me: WARNING: invalid host type: $ac_option" >&2 + : ${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option} + ;; + + esac +done + +if test -n "$ac_prev"; then + ac_option=--`echo $ac_prev | sed 's/_/-/g'` + { echo "$as_me: error: missing argument to $ac_option" >&2 + { (exit 1); exit 1; }; } +fi + +# Be sure to have absolute paths. +for ac_var in exec_prefix prefix +do + eval ac_val=$`echo $ac_var` + case $ac_val in + [\\/$]* | ?:[\\/]* | NONE | '' ) ;; + *) { echo "$as_me: error: expected an absolute directory name for --$ac_var: $ac_val" >&2 + { (exit 1); exit 1; }; };; + esac +done + +# Be sure to have absolute paths. +for ac_var in bindir sbindir libexecdir datadir sysconfdir sharedstatedir \ + localstatedir libdir includedir oldincludedir infodir mandir +do + eval ac_val=$`echo $ac_var` + case $ac_val in + [\\/$]* | ?:[\\/]* ) ;; + *) { echo "$as_me: error: expected an absolute directory name for --$ac_var: $ac_val" >&2 + { (exit 1); exit 1; }; };; + esac +done + +# There might be people who depend on the old broken behavior: `$host' +# used to hold the argument of --host etc. +# FIXME: To remove some day. +build=$build_alias +host=$host_alias +target=$target_alias + +# FIXME: To remove some day. +if test "x$host_alias" != x; then + if test "x$build_alias" = x; then + cross_compiling=maybe + echo "$as_me: WARNING: If you wanted to set the --build type, don't use --host. + If a cross compiler is detected then cross compile mode will be used." >&2 + elif test "x$build_alias" != "x$host_alias"; then + cross_compiling=yes + fi +fi + +ac_tool_prefix= +test -n "$host_alias" && ac_tool_prefix=$host_alias- + +test "$silent" = yes && exec 6>/dev/null + + +# Find the source files, if location was not specified. +if test -z "$srcdir"; then + ac_srcdir_defaulted=yes + # Try the directory containing this script, then its parent. + ac_confdir=`(dirname "$0") 2>/dev/null || +$as_expr X"$0" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$0" : 'X\(//\)[^/]' \| \ + X"$0" : 'X\(//\)$' \| \ + X"$0" : 'X\(/\)' \| \ + . : '\(.\)' 2>/dev/null || +echo X"$0" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } + /^X\(\/\/\)[^/].*/{ s//\1/; q; } + /^X\(\/\/\)$/{ s//\1/; q; } + /^X\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + srcdir=$ac_confdir + if test ! -r $srcdir/$ac_unique_file; then + srcdir=.. + fi +else + ac_srcdir_defaulted=no +fi +if test ! -r $srcdir/$ac_unique_file; then + if test "$ac_srcdir_defaulted" = yes; then + { echo "$as_me: error: cannot find sources ($ac_unique_file) in $ac_confdir or .." >&2 + { (exit 1); exit 1; }; } + else + { echo "$as_me: error: cannot find sources ($ac_unique_file) in $srcdir" >&2 + { (exit 1); exit 1; }; } + fi +fi +(cd $srcdir && test -r ./$ac_unique_file) 2>/dev/null || + { echo "$as_me: error: sources are in $srcdir, but \`cd $srcdir' does not work" >&2 + { (exit 1); exit 1; }; } +srcdir=`echo "$srcdir" | sed 's%\([^\\/]\)[\\/]*$%\1%'` +ac_env_build_alias_set=${build_alias+set} +ac_env_build_alias_value=$build_alias +ac_cv_env_build_alias_set=${build_alias+set} +ac_cv_env_build_alias_value=$build_alias +ac_env_host_alias_set=${host_alias+set} +ac_env_host_alias_value=$host_alias +ac_cv_env_host_alias_set=${host_alias+set} +ac_cv_env_host_alias_value=$host_alias +ac_env_target_alias_set=${target_alias+set} +ac_env_target_alias_value=$target_alias +ac_cv_env_target_alias_set=${target_alias+set} +ac_cv_env_target_alias_value=$target_alias +ac_env_CC_set=${CC+set} +ac_env_CC_value=$CC +ac_cv_env_CC_set=${CC+set} +ac_cv_env_CC_value=$CC +ac_env_CFLAGS_set=${CFLAGS+set} +ac_env_CFLAGS_value=$CFLAGS +ac_cv_env_CFLAGS_set=${CFLAGS+set} +ac_cv_env_CFLAGS_value=$CFLAGS +ac_env_LDFLAGS_set=${LDFLAGS+set} +ac_env_LDFLAGS_value=$LDFLAGS +ac_cv_env_LDFLAGS_set=${LDFLAGS+set} +ac_cv_env_LDFLAGS_value=$LDFLAGS +ac_env_CPPFLAGS_set=${CPPFLAGS+set} +ac_env_CPPFLAGS_value=$CPPFLAGS +ac_cv_env_CPPFLAGS_set=${CPPFLAGS+set} +ac_cv_env_CPPFLAGS_value=$CPPFLAGS +ac_env_CPP_set=${CPP+set} +ac_env_CPP_value=$CPP +ac_cv_env_CPP_set=${CPP+set} +ac_cv_env_CPP_value=$CPP +ac_env_CXX_set=${CXX+set} +ac_env_CXX_value=$CXX +ac_cv_env_CXX_set=${CXX+set} +ac_cv_env_CXX_value=$CXX +ac_env_CXXFLAGS_set=${CXXFLAGS+set} +ac_env_CXXFLAGS_value=$CXXFLAGS +ac_cv_env_CXXFLAGS_set=${CXXFLAGS+set} +ac_cv_env_CXXFLAGS_value=$CXXFLAGS +ac_env_CXXCPP_set=${CXXCPP+set} +ac_env_CXXCPP_value=$CXXCPP +ac_cv_env_CXXCPP_set=${CXXCPP+set} +ac_cv_env_CXXCPP_value=$CXXCPP +ac_env_F77_set=${F77+set} +ac_env_F77_value=$F77 +ac_cv_env_F77_set=${F77+set} +ac_cv_env_F77_value=$F77 +ac_env_FFLAGS_set=${FFLAGS+set} +ac_env_FFLAGS_value=$FFLAGS +ac_cv_env_FFLAGS_set=${FFLAGS+set} +ac_cv_env_FFLAGS_value=$FFLAGS + +# +# Report the --help message. +# +if test "$ac_init_help" = "long"; then + # Omit some internal or obsolete options to make the list less imposing. + # This message is too long to be a string in the A/UX 3.1 sh. + cat <<_ACEOF +\`configure' configures this package to adapt to many kinds of systems. + +Usage: $0 [OPTION]... [VAR=VALUE]... + +To assign environment variables (e.g., CC, CFLAGS...), specify them as +VAR=VALUE. See below for descriptions of some of the useful variables. + +Defaults for the options are specified in brackets. + +Configuration: + -h, --help display this help and exit + --help=short display options specific to this package + --help=recursive display the short help of all the included packages + -V, --version display version information and exit + -q, --quiet, --silent do not print \`checking...' messages + --cache-file=FILE cache test results in FILE [disabled] + -C, --config-cache alias for \`--cache-file=config.cache' + -n, --no-create do not create output files + --srcdir=DIR find the sources in DIR [configure dir or \`..'] + +_ACEOF + + cat <<_ACEOF +Installation directories: + --prefix=PREFIX install architecture-independent files in PREFIX + [$ac_default_prefix] + --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX + [PREFIX] + +By default, \`make install' will install all the files in +\`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify +an installation prefix other than \`$ac_default_prefix' using \`--prefix', +for instance \`--prefix=\$HOME'. + +For better control, use the options below. + +Fine tuning of the installation directories: + --bindir=DIR user executables [EPREFIX/bin] + --sbindir=DIR system admin executables [EPREFIX/sbin] + --libexecdir=DIR program executables [EPREFIX/libexec] + --datadir=DIR read-only architecture-independent data [PREFIX/share] + --sysconfdir=DIR read-only single-machine data [PREFIX/etc] + --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] + --localstatedir=DIR modifiable single-machine data [PREFIX/var] + --libdir=DIR object code libraries [EPREFIX/lib] + --includedir=DIR C header files [PREFIX/include] + --oldincludedir=DIR C header files for non-gcc [/usr/include] + --infodir=DIR info documentation [PREFIX/info] + --mandir=DIR man documentation [PREFIX/man] +_ACEOF + + cat <<\_ACEOF + +Program names: + --program-prefix=PREFIX prepend PREFIX to installed program names + --program-suffix=SUFFIX append SUFFIX to installed program names + --program-transform-name=PROGRAM run sed PROGRAM on installed program names + +System types: + --build=BUILD configure for building on BUILD [guessed] + --host=HOST cross-compile to build programs to run on HOST [BUILD] +_ACEOF +fi + +if test -n "$ac_init_help"; then + + cat <<\_ACEOF + +Optional Features: + --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) + --enable-FEATURE[=ARG] include FEATURE [ARG=yes] + --disable-dependency-tracking speeds up one-time build + --enable-dependency-tracking do not reject slow dependency extractors + --enable-shared[=PKGS] + build shared libraries [default=yes] + --enable-static[=PKGS] + build static libraries [default=yes] + --enable-fast-install[=PKGS] + optimize for fast installation [default=yes] + --disable-libtool-lock avoid locking (might break parallel builds) + --disable-nls do not use Native Language Support + --disable-rpath do not hardcode runtime library paths + +Optional Packages: + --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] + --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) + --with-gnu-ld assume the C compiler uses GNU ld [default=no] + --with-pic try to use only PIC/non-PIC objects [default=use + both] + --with-tags[=TAGS] + include additional configurations [automatic] + --with-gnu-ld assume the C compiler uses GNU ld default=no + --with-libiconv-prefix[=DIR] search for libiconv in DIR/include and DIR/lib + --without-libiconv-prefix don't search for libiconv in includedir and libdir + --with-included-gettext use the GNU gettext library included here + --with-libintl-prefix[=DIR] search for libintl in DIR/include and DIR/lib + --without-libintl-prefix don't search for libintl in includedir and libdir + +Some influential environment variables: + CC C compiler command + CFLAGS C compiler flags + LDFLAGS linker flags, e.g. -L if you have libraries in a + nonstandard directory + CPPFLAGS C/C++ preprocessor flags, e.g. -I if you have + headers in a nonstandard directory + CPP C preprocessor + CXX C++ compiler command + CXXFLAGS C++ compiler flags + CXXCPP C++ preprocessor + F77 Fortran 77 compiler command + FFLAGS Fortran 77 compiler flags + +Use these variables to override the choices made by `configure' or to help +it to find libraries and programs with nonstandard names/locations. + +_ACEOF +fi + +if test "$ac_init_help" = "recursive"; then + # If there are subdirs, report their specific --help. + ac_popdir=`pwd` + for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue + test -d $ac_dir || continue + ac_builddir=. + +if test "$ac_dir" != .; then + ac_dir_suffix=/`echo "$ac_dir" | sed 's,^\.[\\/],,'` + # A "../" for each directory in $ac_dir_suffix. + ac_top_builddir=`echo "$ac_dir_suffix" | sed 's,/[^\\/]*,../,g'` +else + ac_dir_suffix= ac_top_builddir= +fi + +case $srcdir in + .) # No --srcdir option. We are building in place. + ac_srcdir=. + if test -z "$ac_top_builddir"; then + ac_top_srcdir=. + else + ac_top_srcdir=`echo $ac_top_builddir | sed 's,/$,,'` + fi ;; + [\\/]* | ?:[\\/]* ) # Absolute path. + ac_srcdir=$srcdir$ac_dir_suffix; + ac_top_srcdir=$srcdir ;; + *) # Relative path. + ac_srcdir=$ac_top_builddir$srcdir$ac_dir_suffix + ac_top_srcdir=$ac_top_builddir$srcdir ;; +esac + +# Do not use `cd foo && pwd` to compute absolute paths, because +# the directories may not exist. +case `pwd` in +.) ac_abs_builddir="$ac_dir";; +*) + case "$ac_dir" in + .) ac_abs_builddir=`pwd`;; + [\\/]* | ?:[\\/]* ) ac_abs_builddir="$ac_dir";; + *) ac_abs_builddir=`pwd`/"$ac_dir";; + esac;; +esac +case $ac_abs_builddir in +.) ac_abs_top_builddir=${ac_top_builddir}.;; +*) + case ${ac_top_builddir}. in + .) ac_abs_top_builddir=$ac_abs_builddir;; + [\\/]* | ?:[\\/]* ) ac_abs_top_builddir=${ac_top_builddir}.;; + *) ac_abs_top_builddir=$ac_abs_builddir/${ac_top_builddir}.;; + esac;; +esac +case $ac_abs_builddir in +.) ac_abs_srcdir=$ac_srcdir;; +*) + case $ac_srcdir in + .) ac_abs_srcdir=$ac_abs_builddir;; + [\\/]* | ?:[\\/]* ) ac_abs_srcdir=$ac_srcdir;; + *) ac_abs_srcdir=$ac_abs_builddir/$ac_srcdir;; + esac;; +esac +case $ac_abs_builddir in +.) ac_abs_top_srcdir=$ac_top_srcdir;; +*) + case $ac_top_srcdir in + .) ac_abs_top_srcdir=$ac_abs_builddir;; + [\\/]* | ?:[\\/]* ) ac_abs_top_srcdir=$ac_top_srcdir;; + *) ac_abs_top_srcdir=$ac_abs_builddir/$ac_top_srcdir;; + esac;; +esac + + cd $ac_dir + # Check for guested configure; otherwise get Cygnus style configure. + if test -f $ac_srcdir/configure.gnu; then + echo + $SHELL $ac_srcdir/configure.gnu --help=recursive + elif test -f $ac_srcdir/configure; then + echo + $SHELL $ac_srcdir/configure --help=recursive + elif test -f $ac_srcdir/configure.ac || + test -f $ac_srcdir/configure.in; then + echo + $ac_configure --help + else + echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2 + fi + cd "$ac_popdir" + done +fi + +test -n "$ac_init_help" && exit 0 +if $ac_init_version; then + cat <<\_ACEOF + +Copyright (C) 2003 Free Software Foundation, Inc. +This configure script is free software; the Free Software Foundation +gives unlimited permission to copy, distribute and modify it. +_ACEOF + exit 0 +fi +exec 5>config.log +cat >&5 <<_ACEOF +This file contains any messages produced by compilers while +running configure, to aid debugging if configure makes a mistake. + +It was created by $as_me, which was +generated by GNU Autoconf 2.59. Invocation command line was + + $ $0 $@ + +_ACEOF +{ +cat <<_ASUNAME +## --------- ## +## Platform. ## +## --------- ## + +hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` +uname -m = `(uname -m) 2>/dev/null || echo unknown` +uname -r = `(uname -r) 2>/dev/null || echo unknown` +uname -s = `(uname -s) 2>/dev/null || echo unknown` +uname -v = `(uname -v) 2>/dev/null || echo unknown` + +/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` +/bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` + +/bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` +/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` +/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` +hostinfo = `(hostinfo) 2>/dev/null || echo unknown` +/bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` +/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` +/bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` + +_ASUNAME + +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + echo "PATH: $as_dir" +done + +} >&5 + +cat >&5 <<_ACEOF + + +## ----------- ## +## Core tests. ## +## ----------- ## + +_ACEOF + + +# Keep a trace of the command line. +# Strip out --no-create and --no-recursion so they do not pile up. +# Strip out --silent because we don't want to record it for future runs. +# Also quote any args containing shell meta-characters. +# Make two passes to allow for proper duplicate-argument suppression. +ac_configure_args= +ac_configure_args0= +ac_configure_args1= +ac_sep= +ac_must_keep_next=false +for ac_pass in 1 2 +do + for ac_arg + do + case $ac_arg in + -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil) + continue ;; + *" "*|*" "*|*[\[\]\~\#\$\^\&\*\(\)\{\}\\\|\;\<\>\?\"\']*) + ac_arg=`echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; + esac + case $ac_pass in + 1) ac_configure_args0="$ac_configure_args0 '$ac_arg'" ;; + 2) + ac_configure_args1="$ac_configure_args1 '$ac_arg'" + if test $ac_must_keep_next = true; then + ac_must_keep_next=false # Got value, back to normal. + else + case $ac_arg in + *=* | --config-cache | -C | -disable-* | --disable-* \ + | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ + | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ + | -with-* | --with-* | -without-* | --without-* | --x) + case "$ac_configure_args0 " in + "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; + esac + ;; + -* ) ac_must_keep_next=true ;; + esac + fi + ac_configure_args="$ac_configure_args$ac_sep'$ac_arg'" + # Get rid of the leading space. + ac_sep=" " + ;; + esac + done +done +$as_unset ac_configure_args0 || test "${ac_configure_args0+set}" != set || { ac_configure_args0=; export ac_configure_args0; } +$as_unset ac_configure_args1 || test "${ac_configure_args1+set}" != set || { ac_configure_args1=; export ac_configure_args1; } + +# When interrupted or exit'd, cleanup temporary files, and complete +# config.log. We remove comments because anyway the quotes in there +# would cause problems or look ugly. +# WARNING: Be sure not to use single quotes in there, as some shells, +# such as our DU 5.0 friend, will then `close' the trap. +trap 'exit_status=$? + # Save into config.log some information that might help in debugging. + { + echo + + cat <<\_ASBOX +## ---------------- ## +## Cache variables. ## +## ---------------- ## +_ASBOX + echo + # The following way of writing the cache mishandles newlines in values, +{ + (set) 2>&1 | + case `(ac_space='"'"' '"'"'; set | grep ac_space) 2>&1` in + *ac_space=\ *) + sed -n \ + "s/'"'"'/'"'"'\\\\'"'"''"'"'/g; + s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='"'"'\\2'"'"'/p" + ;; + *) + sed -n \ + "s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1=\\2/p" + ;; + esac; +} + echo + + cat <<\_ASBOX +## ----------------- ## +## Output variables. ## +## ----------------- ## +_ASBOX + echo + for ac_var in $ac_subst_vars + do + eval ac_val=$`echo $ac_var` + echo "$ac_var='"'"'$ac_val'"'"'" + done | sort + echo + + if test -n "$ac_subst_files"; then + cat <<\_ASBOX +## ------------- ## +## Output files. ## +## ------------- ## +_ASBOX + echo + for ac_var in $ac_subst_files + do + eval ac_val=$`echo $ac_var` + echo "$ac_var='"'"'$ac_val'"'"'" + done | sort + echo + fi + + if test -s confdefs.h; then + cat <<\_ASBOX +## ----------- ## +## confdefs.h. ## +## ----------- ## +_ASBOX + echo + sed "/^$/d" confdefs.h | sort + echo + fi + test "$ac_signal" != 0 && + echo "$as_me: caught signal $ac_signal" + echo "$as_me: exit $exit_status" + } >&5 + rm -f core *.core && + rm -rf conftest* confdefs* conf$$* $ac_clean_files && + exit $exit_status + ' 0 +for ac_signal in 1 2 13 15; do + trap 'ac_signal='$ac_signal'; { (exit 1); exit 1; }' $ac_signal +done +ac_signal=0 + +# confdefs.h avoids OS command line length limits that DEFS can exceed. +rm -rf conftest* confdefs.h +# AIX cpp loses on an empty file, so make sure it contains at least a newline. +echo >confdefs.h + +# Predefined preprocessor variables. + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_NAME "$PACKAGE_NAME" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_TARNAME "$PACKAGE_TARNAME" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_VERSION "$PACKAGE_VERSION" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_STRING "$PACKAGE_STRING" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT" +_ACEOF + + +# Let the site file select an alternate cache file if it wants to. +# Prefer explicitly selected file to automatically selected ones. +if test -z "$CONFIG_SITE"; then + if test "x$prefix" != xNONE; then + CONFIG_SITE="$prefix/share/config.site $prefix/etc/config.site" + else + CONFIG_SITE="$ac_default_prefix/share/config.site $ac_default_prefix/etc/config.site" + fi +fi +for ac_site_file in $CONFIG_SITE; do + if test -r "$ac_site_file"; then + { echo "$as_me:$LINENO: loading site script $ac_site_file" >&5 +echo "$as_me: loading site script $ac_site_file" >&6;} + sed 's/^/| /' "$ac_site_file" >&5 + . "$ac_site_file" + fi +done + +if test -r "$cache_file"; then + # Some versions of bash will fail to source /dev/null (special + # files actually), so we avoid doing that. + if test -f "$cache_file"; then + { echo "$as_me:$LINENO: loading cache $cache_file" >&5 +echo "$as_me: loading cache $cache_file" >&6;} + case $cache_file in + [\\/]* | ?:[\\/]* ) . $cache_file;; + *) . ./$cache_file;; + esac + fi +else + { echo "$as_me:$LINENO: creating cache $cache_file" >&5 +echo "$as_me: creating cache $cache_file" >&6;} + >$cache_file +fi + +# Check that the precious variables saved in the cache have kept the same +# value. +ac_cache_corrupted=false +for ac_var in `(set) 2>&1 | + sed -n 's/^ac_env_\([a-zA-Z_0-9]*\)_set=.*/\1/p'`; do + eval ac_old_set=\$ac_cv_env_${ac_var}_set + eval ac_new_set=\$ac_env_${ac_var}_set + eval ac_old_val="\$ac_cv_env_${ac_var}_value" + eval ac_new_val="\$ac_env_${ac_var}_value" + case $ac_old_set,$ac_new_set in + set,) + { echo "$as_me:$LINENO: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 +echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} + ac_cache_corrupted=: ;; + ,set) + { echo "$as_me:$LINENO: error: \`$ac_var' was not set in the previous run" >&5 +echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} + ac_cache_corrupted=: ;; + ,);; + *) + if test "x$ac_old_val" != "x$ac_new_val"; then + { echo "$as_me:$LINENO: error: \`$ac_var' has changed since the previous run:" >&5 +echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} + { echo "$as_me:$LINENO: former value: $ac_old_val" >&5 +echo "$as_me: former value: $ac_old_val" >&2;} + { echo "$as_me:$LINENO: current value: $ac_new_val" >&5 +echo "$as_me: current value: $ac_new_val" >&2;} + ac_cache_corrupted=: + fi;; + esac + # Pass precious variables to config.status. + if test "$ac_new_set" = set; then + case $ac_new_val in + *" "*|*" "*|*[\[\]\~\#\$\^\&\*\(\)\{\}\\\|\;\<\>\?\"\']*) + ac_arg=$ac_var=`echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; + *) ac_arg=$ac_var=$ac_new_val ;; + esac + case " $ac_configure_args " in + *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. + *) ac_configure_args="$ac_configure_args '$ac_arg'" ;; + esac + fi +done +if $ac_cache_corrupted; then + { echo "$as_me:$LINENO: error: changes in the environment can compromise the build" >&5 +echo "$as_me: error: changes in the environment can compromise the build" >&2;} + { { echo "$as_me:$LINENO: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&5 +echo "$as_me: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&2;} + { (exit 1); exit 1; }; } +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + + + + + + + + + + + + + + + + + + + +ac_aux_dir= +for ac_dir in scripts $srcdir/scripts; do + if test -f $ac_dir/install-sh; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/install-sh -c" + break + elif test -f $ac_dir/install.sh; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/install.sh -c" + break + elif test -f $ac_dir/shtool; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/shtool install -c" + break + fi +done +if test -z "$ac_aux_dir"; then + { { echo "$as_me:$LINENO: error: cannot find install-sh or install.sh in scripts $srcdir/scripts" >&5 +echo "$as_me: error: cannot find install-sh or install.sh in scripts $srcdir/scripts" >&2;} + { (exit 1); exit 1; }; } +fi +ac_config_guess="$SHELL $ac_aux_dir/config.guess" +ac_config_sub="$SHELL $ac_aux_dir/config.sub" +ac_configure="$SHELL $ac_aux_dir/configure" # This should be Cygnus configure. + +# Find a good install program. We prefer a C program (faster), +# so one script is as good as another. But avoid the broken or +# incompatible versions: +# SysV /etc/install, /usr/sbin/install +# SunOS /usr/etc/install +# IRIX /sbin/install +# AIX /bin/install +# AmigaOS /C/install, which installs bootblocks on floppy discs +# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag +# AFS /usr/afsws/bin/install, which mishandles nonexistent args +# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" +# OS/2's system install, which has a completely different semantic +# ./install, which can be erroneously created by make from ./install.sh. +echo "$as_me:$LINENO: checking for a BSD-compatible install" >&5 +echo $ECHO_N "checking for a BSD-compatible install... $ECHO_C" >&6 +if test -z "$INSTALL"; then +if test "${ac_cv_path_install+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + # Account for people who put trailing slashes in PATH elements. +case $as_dir/ in + ./ | .// | /cC/* | \ + /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ + ?:\\/os2\\/install\\/* | ?:\\/OS2\\/INSTALL\\/* | \ + /usr/ucb/* ) ;; + *) + # OSF1 and SCO ODT 3.0 have their own names for install. + # Don't use installbsd from OSF since it installs stuff as root + # by default. + for ac_prog in ginstall scoinst install; do + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then + if test $ac_prog = install && + grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then + # AIX install. It has an incompatible calling convention. + : + elif test $ac_prog = install && + grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then + # program-specific install script used by HP pwplus--don't use. + : + else + ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" + break 3 + fi + fi + done + done + ;; +esac +done + + +fi + if test "${ac_cv_path_install+set}" = set; then + INSTALL=$ac_cv_path_install + else + # As a last resort, use the slow shell script. We don't cache a + # path for INSTALL within a source directory, because that will + # break other packages using the cache if that directory is + # removed, or if the path is relative. + INSTALL=$ac_install_sh + fi +fi +echo "$as_me:$LINENO: result: $INSTALL" >&5 +echo "${ECHO_T}$INSTALL" >&6 + +# Use test -z because SunOS4 sh mishandles braces in ${var-val}. +# It thinks the first close brace ends the variable substitution. +test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' + +test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' + +test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. +set dummy ${ac_tool_prefix}gcc; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_CC+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CC="${ac_tool_prefix}gcc" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + echo "$as_me:$LINENO: result: $CC" >&5 +echo "${ECHO_T}$CC" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + +fi +if test -z "$ac_cv_prog_CC"; then + ac_ct_CC=$CC + # Extract the first word of "gcc", so it can be a program name with args. +set dummy gcc; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_CC="gcc" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 +echo "${ECHO_T}$ac_ct_CC" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + CC=$ac_ct_CC +else + CC="$ac_cv_prog_CC" +fi + +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. +set dummy ${ac_tool_prefix}cc; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_CC+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CC="${ac_tool_prefix}cc" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + echo "$as_me:$LINENO: result: $CC" >&5 +echo "${ECHO_T}$CC" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + +fi +if test -z "$ac_cv_prog_CC"; then + ac_ct_CC=$CC + # Extract the first word of "cc", so it can be a program name with args. +set dummy cc; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_CC="cc" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 +echo "${ECHO_T}$ac_ct_CC" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + CC=$ac_ct_CC +else + CC="$ac_cv_prog_CC" +fi + +fi +if test -z "$CC"; then + # Extract the first word of "cc", so it can be a program name with args. +set dummy cc; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_CC+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else + ac_prog_rejected=no +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then + ac_prog_rejected=yes + continue + fi + ac_cv_prog_CC="cc" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +if test $ac_prog_rejected = yes; then + # We found a bogon in the path, so make sure we never use it. + set dummy $ac_cv_prog_CC + shift + if test $# != 0; then + # We chose a different compiler from the bogus one. + # However, it has the same basename, so the bogon will be chosen + # first if we set CC to just the basename; use the full file name. + shift + ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" + fi +fi +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + echo "$as_me:$LINENO: result: $CC" >&5 +echo "${ECHO_T}$CC" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + +fi +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + for ac_prog in cl + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_CC+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CC="$ac_tool_prefix$ac_prog" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + echo "$as_me:$LINENO: result: $CC" >&5 +echo "${ECHO_T}$CC" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + test -n "$CC" && break + done +fi +if test -z "$CC"; then + ac_ct_CC=$CC + for ac_prog in cl +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_CC="$ac_prog" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 +echo "${ECHO_T}$ac_ct_CC" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + test -n "$ac_ct_CC" && break +done + + CC=$ac_ct_CC +fi + +fi + + +test -z "$CC" && { { echo "$as_me:$LINENO: error: no acceptable C compiler found in \$PATH +See \`config.log' for more details." >&5 +echo "$as_me: error: no acceptable C compiler found in \$PATH +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } + +# Provide some information about the compiler. +echo "$as_me:$LINENO:" \ + "checking for C compiler version" >&5 +ac_compiler=`set X $ac_compile; echo $2` +{ (eval echo "$as_me:$LINENO: \"$ac_compiler --version &5\"") >&5 + (eval $ac_compiler --version &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (eval echo "$as_me:$LINENO: \"$ac_compiler -v &5\"") >&5 + (eval $ac_compiler -v &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (eval echo "$as_me:$LINENO: \"$ac_compiler -V &5\"") >&5 + (eval $ac_compiler -V &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +ac_clean_files_save=$ac_clean_files +ac_clean_files="$ac_clean_files a.out a.exe b.out" +# Try to create an executable without -o first, disregard a.out. +# It will help us diagnose broken compilers, and finding out an intuition +# of exeext. +echo "$as_me:$LINENO: checking for C compiler default output file name" >&5 +echo $ECHO_N "checking for C compiler default output file name... $ECHO_C" >&6 +ac_link_default=`echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` +if { (eval echo "$as_me:$LINENO: \"$ac_link_default\"") >&5 + (eval $ac_link_default) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + # Find the output, starting from the most likely. This scheme is +# not robust to junk in `.', hence go to wildcards (a.*) only as a last +# resort. + +# Be careful to initialize this variable, since it used to be cached. +# Otherwise an old cache value of `no' led to `EXEEXT = no' in a Makefile. +ac_cv_exeext= +# b.out is created by i960 compilers. +for ac_file in a_out.exe a.exe conftest.exe a.out conftest a.* conftest.* b.out +do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.o | *.obj ) + ;; + conftest.$ac_ext ) + # This is the source file. + ;; + [ab].out ) + # We found the default executable, but exeext='' is most + # certainly right. + break;; + *.* ) + ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + # FIXME: I believe we export ac_cv_exeext for Libtool, + # but it would be cool to find out if it's true. Does anybody + # maintain Libtool? --akim. + export ac_cv_exeext + break;; + * ) + break;; + esac +done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { echo "$as_me:$LINENO: error: C compiler cannot create executables +See \`config.log' for more details." >&5 +echo "$as_me: error: C compiler cannot create executables +See \`config.log' for more details." >&2;} + { (exit 77); exit 77; }; } +fi + +ac_exeext=$ac_cv_exeext +echo "$as_me:$LINENO: result: $ac_file" >&5 +echo "${ECHO_T}$ac_file" >&6 + +# Check the compiler produces executables we can run. If not, either +# the compiler is broken, or we cross compile. +echo "$as_me:$LINENO: checking whether the C compiler works" >&5 +echo $ECHO_N "checking whether the C compiler works... $ECHO_C" >&6 +# FIXME: These cross compiler hacks should be removed for Autoconf 3.0 +# If not cross compiling, check that we can run a simple program. +if test "$cross_compiling" != yes; then + if { ac_try='./$ac_file' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + cross_compiling=no + else + if test "$cross_compiling" = maybe; then + cross_compiling=yes + else + { { echo "$as_me:$LINENO: error: cannot run C compiled programs. +If you meant to cross compile, use \`--host'. +See \`config.log' for more details." >&5 +echo "$as_me: error: cannot run C compiled programs. +If you meant to cross compile, use \`--host'. +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } + fi + fi +fi +echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 + +rm -f a.out a.exe conftest$ac_cv_exeext b.out +ac_clean_files=$ac_clean_files_save +# Check the compiler produces executables we can run. If not, either +# the compiler is broken, or we cross compile. +echo "$as_me:$LINENO: checking whether we are cross compiling" >&5 +echo $ECHO_N "checking whether we are cross compiling... $ECHO_C" >&6 +echo "$as_me:$LINENO: result: $cross_compiling" >&5 +echo "${ECHO_T}$cross_compiling" >&6 + +echo "$as_me:$LINENO: checking for suffix of executables" >&5 +echo $ECHO_N "checking for suffix of executables... $ECHO_C" >&6 +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + # If both `conftest.exe' and `conftest' are `present' (well, observable) +# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will +# work properly (i.e., refer to `conftest.exe'), while it won't with +# `rm'. +for ac_file in conftest.exe conftest conftest.*; do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.o | *.obj ) ;; + *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + export ac_cv_exeext + break;; + * ) break;; + esac +done +else + { { echo "$as_me:$LINENO: error: cannot compute suffix of executables: cannot compile and link +See \`config.log' for more details." >&5 +echo "$as_me: error: cannot compute suffix of executables: cannot compile and link +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } +fi + +rm -f conftest$ac_cv_exeext +echo "$as_me:$LINENO: result: $ac_cv_exeext" >&5 +echo "${ECHO_T}$ac_cv_exeext" >&6 + +rm -f conftest.$ac_ext +EXEEXT=$ac_cv_exeext +ac_exeext=$EXEEXT +echo "$as_me:$LINENO: checking for suffix of object files" >&5 +echo $ECHO_N "checking for suffix of object files... $ECHO_C" >&6 +if test "${ac_cv_objext+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.o conftest.obj +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + for ac_file in `(ls conftest.o conftest.obj; ls conftest.*) 2>/dev/null`; do + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg ) ;; + *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` + break;; + esac +done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { echo "$as_me:$LINENO: error: cannot compute suffix of object files: cannot compile +See \`config.log' for more details." >&5 +echo "$as_me: error: cannot compute suffix of object files: cannot compile +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } +fi + +rm -f conftest.$ac_cv_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_objext" >&5 +echo "${ECHO_T}$ac_cv_objext" >&6 +OBJEXT=$ac_cv_objext +ac_objext=$OBJEXT +echo "$as_me:$LINENO: checking whether we are using the GNU C compiler" >&5 +echo $ECHO_N "checking whether we are using the GNU C compiler... $ECHO_C" >&6 +if test "${ac_cv_c_compiler_gnu+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_compiler_gnu=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_compiler_gnu=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_c_compiler_gnu=$ac_compiler_gnu + +fi +echo "$as_me:$LINENO: result: $ac_cv_c_compiler_gnu" >&5 +echo "${ECHO_T}$ac_cv_c_compiler_gnu" >&6 +GCC=`test $ac_compiler_gnu = yes && echo yes` +ac_test_CFLAGS=${CFLAGS+set} +ac_save_CFLAGS=$CFLAGS +CFLAGS="-g" +echo "$as_me:$LINENO: checking whether $CC accepts -g" >&5 +echo $ECHO_N "checking whether $CC accepts -g... $ECHO_C" >&6 +if test "${ac_cv_prog_cc_g+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_prog_cc_g=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_prog_cc_g=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_prog_cc_g" >&5 +echo "${ECHO_T}$ac_cv_prog_cc_g" >&6 +if test "$ac_test_CFLAGS" = set; then + CFLAGS=$ac_save_CFLAGS +elif test $ac_cv_prog_cc_g = yes; then + if test "$GCC" = yes; then + CFLAGS="-g -O2" + else + CFLAGS="-g" + fi +else + if test "$GCC" = yes; then + CFLAGS="-O2" + else + CFLAGS= + fi +fi +echo "$as_me:$LINENO: checking for $CC option to accept ANSI C" >&5 +echo $ECHO_N "checking for $CC option to accept ANSI C... $ECHO_C" >&6 +if test "${ac_cv_prog_cc_stdc+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_cv_prog_cc_stdc=no +ac_save_CC=$CC +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +#include +#include +/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ +struct buf { int x; }; +FILE * (*rcsopen) (struct buf *, struct stat *, int); +static char *e (p, i) + char **p; + int i; +{ + return p[i]; +} +static char *f (char * (*g) (char **, int), char **p, ...) +{ + char *s; + va_list v; + va_start (v,p); + s = g (p, va_arg (v,int)); + va_end (v); + return s; +} + +/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has + function prototypes and stuff, but not '\xHH' hex character constants. + These don't provoke an error unfortunately, instead are silently treated + as 'x'. The following induces an error, until -std1 is added to get + proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an + array size at least. It's necessary to write '\x00'==0 to get something + that's true only with -std1. */ +int osf4_cc_array ['\x00' == 0 ? 1 : -1]; + +int test (int i, double x); +struct s1 {int (*f) (int a);}; +struct s2 {int (*f) (double a);}; +int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); +int argc; +char **argv; +int +main () +{ +return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; + ; + return 0; +} +_ACEOF +# Don't try gcc -ansi; that turns off useful extensions and +# breaks some systems' header files. +# AIX -qlanglvl=ansi +# Ultrix and OSF/1 -std1 +# HP-UX 10.20 and later -Ae +# HP-UX older versions -Aa -D_HPUX_SOURCE +# SVR4 -Xc -D__EXTENSIONS__ +for ac_arg in "" -qlanglvl=ansi -std1 -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" +do + CC="$ac_save_CC $ac_arg" + rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_prog_cc_stdc=$ac_arg +break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext +done +rm -f conftest.$ac_ext conftest.$ac_objext +CC=$ac_save_CC + +fi + +case "x$ac_cv_prog_cc_stdc" in + x|xno) + echo "$as_me:$LINENO: result: none needed" >&5 +echo "${ECHO_T}none needed" >&6 ;; + *) + echo "$as_me:$LINENO: result: $ac_cv_prog_cc_stdc" >&5 +echo "${ECHO_T}$ac_cv_prog_cc_stdc" >&6 + CC="$CC $ac_cv_prog_cc_stdc" ;; +esac + +# Some people use a C++ compiler to compile C. Since we use `exit', +# in C++ we need to declare it. In case someone uses the same compiler +# for both compiling C and C++ we need to have the C++ compiler decide +# the declaration of exit, since it's the most demanding environment. +cat >conftest.$ac_ext <<_ACEOF +#ifndef __cplusplus + choke me +#endif +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + for ac_declaration in \ + '' \ + 'extern "C" void std::exit (int) throw (); using std::exit;' \ + 'extern "C" void std::exit (int); using std::exit;' \ + 'extern "C" void exit (int) throw ();' \ + 'extern "C" void exit (int);' \ + 'void exit (int);' +do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_declaration +#include +int +main () +{ +exit (42); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + : +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +continue +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_declaration +int +main () +{ +exit (42); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +done +rm -f conftest* +if test -n "$ac_declaration"; then + echo '#ifdef __cplusplus' >>confdefs.h + echo $ac_declaration >>confdefs.h + echo '#endif' >>confdefs.h +fi + +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + + +echo "$as_me:$LINENO: checking for textdomain in -lintl" >&5 +echo $ECHO_N "checking for textdomain in -lintl... $ECHO_C" >&6 +if test "${ac_cv_lib_intl_textdomain+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lintl $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char textdomain (); +int +main () +{ +textdomain (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_intl_textdomain=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_intl_textdomain=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_intl_textdomain" >&5 +echo "${ECHO_T}$ac_cv_lib_intl_textdomain" >&6 +if test $ac_cv_lib_intl_textdomain = yes; then + cat >>confdefs.h <<_ACEOF +#define HAVE_LIBINTL 1 +_ACEOF + + LIBS="-lintl $LIBS" + +fi + + + ac_config_headers="$ac_config_headers gsm_config.h" + + +am__api_version="1.9" +echo "$as_me:$LINENO: checking whether build environment is sane" >&5 +echo $ECHO_N "checking whether build environment is sane... $ECHO_C" >&6 +# Just in case +sleep 1 +echo timestamp > conftest.file +# Do `set' in a subshell so we don't clobber the current shell's +# arguments. Must try -L first in case configure is actually a +# symlink; some systems play weird games with the mod time of symlinks +# (eg FreeBSD returns the mod time of the symlink's containing +# directory). +if ( + set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null` + if test "$*" = "X"; then + # -L didn't work. + set X `ls -t $srcdir/configure conftest.file` + fi + rm -f conftest.file + if test "$*" != "X $srcdir/configure conftest.file" \ + && test "$*" != "X conftest.file $srcdir/configure"; then + + # If neither matched, then we have a broken ls. This can happen + # if, for instance, CONFIG_SHELL is bash and it inherits a + # broken ls alias from the environment. This has actually + # happened. Such a system could not be considered "sane". + { { echo "$as_me:$LINENO: error: ls -t appears to fail. Make sure there is not a broken +alias in your environment" >&5 +echo "$as_me: error: ls -t appears to fail. Make sure there is not a broken +alias in your environment" >&2;} + { (exit 1); exit 1; }; } + fi + + test "$2" = conftest.file + ) +then + # Ok. + : +else + { { echo "$as_me:$LINENO: error: newly created file is older than distributed files! +Check your system clock" >&5 +echo "$as_me: error: newly created file is older than distributed files! +Check your system clock" >&2;} + { (exit 1); exit 1; }; } +fi +echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 +test "$program_prefix" != NONE && + program_transform_name="s,^,$program_prefix,;$program_transform_name" +# Use a double $ so make ignores it. +test "$program_suffix" != NONE && + program_transform_name="s,\$,$program_suffix,;$program_transform_name" +# Double any \ or $. echo might interpret backslashes. +# By default was `s,x,x', remove it if useless. +cat <<\_ACEOF >conftest.sed +s/[\\$]/&&/g;s/;s,x,x,$// +_ACEOF +program_transform_name=`echo $program_transform_name | sed -f conftest.sed` +rm conftest.sed + +# expand $ac_aux_dir to an absolute path +am_aux_dir=`cd $ac_aux_dir && pwd` + +test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing" +# Use eval to expand $SHELL +if eval "$MISSING --run true"; then + am_missing_run="$MISSING --run " +else + am_missing_run= + { echo "$as_me:$LINENO: WARNING: \`missing' script is too old or missing" >&5 +echo "$as_me: WARNING: \`missing' script is too old or missing" >&2;} +fi + +if mkdir -p --version . >/dev/null 2>&1 && test ! -d ./--version; then + # We used to keeping the `.' as first argument, in order to + # allow $(mkdir_p) to be used without argument. As in + # $(mkdir_p) $(somedir) + # where $(somedir) is conditionally defined. However this is wrong + # for two reasons: + # 1. if the package is installed by a user who cannot write `.' + # make install will fail, + # 2. the above comment should most certainly read + # $(mkdir_p) $(DESTDIR)$(somedir) + # so it does not work when $(somedir) is undefined and + # $(DESTDIR) is not. + # To support the latter case, we have to write + # test -z "$(somedir)" || $(mkdir_p) $(DESTDIR)$(somedir), + # so the `.' trick is pointless. + mkdir_p='mkdir -p --' +else + # On NextStep and OpenStep, the `mkdir' command does not + # recognize any option. It will interpret all options as + # directories to create, and then abort because `.' already + # exists. + for d in ./-p ./--version; + do + test -d $d && rmdir $d + done + # $(mkinstalldirs) is defined by Automake if mkinstalldirs exists. + if test -f "$ac_aux_dir/mkinstalldirs"; then + mkdir_p='$(mkinstalldirs)' + else + mkdir_p='$(install_sh) -d' + fi +fi + +for ac_prog in gawk mawk nawk awk +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_AWK+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$AWK"; then + ac_cv_prog_AWK="$AWK" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_AWK="$ac_prog" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +AWK=$ac_cv_prog_AWK +if test -n "$AWK"; then + echo "$as_me:$LINENO: result: $AWK" >&5 +echo "${ECHO_T}$AWK" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + test -n "$AWK" && break +done + +echo "$as_me:$LINENO: checking whether ${MAKE-make} sets \$(MAKE)" >&5 +echo $ECHO_N "checking whether ${MAKE-make} sets \$(MAKE)... $ECHO_C" >&6 +set dummy ${MAKE-make}; ac_make=`echo "$2" | sed 'y,:./+-,___p_,'` +if eval "test \"\${ac_cv_prog_make_${ac_make}_set+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.make <<\_ACEOF +all: + @echo 'ac_maketemp="$(MAKE)"' +_ACEOF +# GNU make sometimes prints "make[1]: Entering...", which would confuse us. +eval `${MAKE-make} -f conftest.make 2>/dev/null | grep temp=` +if test -n "$ac_maketemp"; then + eval ac_cv_prog_make_${ac_make}_set=yes +else + eval ac_cv_prog_make_${ac_make}_set=no +fi +rm -f conftest.make +fi +if eval "test \"`echo '$ac_cv_prog_make_'${ac_make}_set`\" = yes"; then + echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 + SET_MAKE= +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 + SET_MAKE="MAKE=${MAKE-make}" +fi + +rm -rf .tst 2>/dev/null +mkdir .tst 2>/dev/null +if test -d .tst; then + am__leading_dot=. +else + am__leading_dot=_ +fi +rmdir .tst 2>/dev/null + +DEPDIR="${am__leading_dot}deps" + + ac_config_commands="$ac_config_commands depfiles" + + +am_make=${MAKE-make} +cat > confinc << 'END' +am__doit: + @echo done +.PHONY: am__doit +END +# If we don't find an include directive, just comment out the code. +echo "$as_me:$LINENO: checking for style of include used by $am_make" >&5 +echo $ECHO_N "checking for style of include used by $am_make... $ECHO_C" >&6 +am__include="#" +am__quote= +_am_result=none +# First try GNU make style include. +echo "include confinc" > confmf +# We grep out `Entering directory' and `Leaving directory' +# messages which can occur if `w' ends up in MAKEFLAGS. +# In particular we don't look at `^make:' because GNU make might +# be invoked under some other name (usually "gmake"), in which +# case it prints its new name instead of `make'. +if test "`$am_make -s -f confmf 2> /dev/null | grep -v 'ing directory'`" = "done"; then + am__include=include + am__quote= + _am_result=GNU +fi +# Now try BSD make style include. +if test "$am__include" = "#"; then + echo '.include "confinc"' > confmf + if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then + am__include=.include + am__quote="\"" + _am_result=BSD + fi +fi + + +echo "$as_me:$LINENO: result: $_am_result" >&5 +echo "${ECHO_T}$_am_result" >&6 +rm -f confinc confmf + +# Check whether --enable-dependency-tracking or --disable-dependency-tracking was given. +if test "${enable_dependency_tracking+set}" = set; then + enableval="$enable_dependency_tracking" + +fi; +if test "x$enable_dependency_tracking" != xno; then + am_depcomp="$ac_aux_dir/depcomp" + AMDEPBACKSLASH='\' +fi + + +if test "x$enable_dependency_tracking" != xno; then + AMDEP_TRUE= + AMDEP_FALSE='#' +else + AMDEP_TRUE='#' + AMDEP_FALSE= +fi + + + +# test to see if srcdir already configured +if test "`cd $srcdir && pwd`" != "`pwd`" && + test -f $srcdir/config.status; then + { { echo "$as_me:$LINENO: error: source directory already configured; run \"make distclean\" there first" >&5 +echo "$as_me: error: source directory already configured; run \"make distclean\" there first" >&2;} + { (exit 1); exit 1; }; } +fi + +# test whether we have cygpath +if test -z "$CYGPATH_W"; then + if (cygpath --version) >/dev/null 2>/dev/null; then + CYGPATH_W='cygpath -w' + else + CYGPATH_W=echo + fi +fi + + +# Define the identity of the package. + PACKAGE=gsmlib + VERSION=1.10 + + +cat >>confdefs.h <<_ACEOF +#define PACKAGE "$PACKAGE" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define VERSION "$VERSION" +_ACEOF + +# Some tools Automake needs. + +ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} + + +AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"} + + +AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"} + + +AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"} + + +MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} + +install_sh=${install_sh-"$am_aux_dir/install-sh"} + +# Installed binaries are usually stripped using `strip' when the user +# run `make install-strip'. However `strip' might not be the right +# tool to use in cross-compilation environments, therefore Automake +# will honor the `STRIP' environment variable to overrule this program. +if test "$cross_compiling" != no; then + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. +set dummy ${ac_tool_prefix}strip; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_STRIP+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$STRIP"; then + ac_cv_prog_STRIP="$STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_STRIP="${ac_tool_prefix}strip" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +STRIP=$ac_cv_prog_STRIP +if test -n "$STRIP"; then + echo "$as_me:$LINENO: result: $STRIP" >&5 +echo "${ECHO_T}$STRIP" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + +fi +if test -z "$ac_cv_prog_STRIP"; then + ac_ct_STRIP=$STRIP + # Extract the first word of "strip", so it can be a program name with args. +set dummy strip; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$ac_ct_STRIP"; then + ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_STRIP="strip" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + + test -z "$ac_cv_prog_ac_ct_STRIP" && ac_cv_prog_ac_ct_STRIP=":" +fi +fi +ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP +if test -n "$ac_ct_STRIP"; then + echo "$as_me:$LINENO: result: $ac_ct_STRIP" >&5 +echo "${ECHO_T}$ac_ct_STRIP" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + STRIP=$ac_ct_STRIP +else + STRIP="$ac_cv_prog_STRIP" +fi + +fi +INSTALL_STRIP_PROGRAM="\${SHELL} \$(install_sh) -c -s" + +# We need awk for the "check" target. The system "awk" is bad on +# some platforms. +# Always define AMTAR for backward compatibility. + +AMTAR=${AMTAR-"${am_missing_run}tar"} + +am__tar='${AMTAR} chof - "$$tardir"'; am__untar='${AMTAR} xf -' + + + + +depcc="$CC" am_compiler_list= + +echo "$as_me:$LINENO: checking dependency style of $depcc" >&5 +echo $ECHO_N "checking dependency style of $depcc... $ECHO_C" >&6 +if test "${am_cv_CC_dependencies_compiler_type+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named `D' -- because `-MD' means `put the output + # in D'. + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_CC_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` + fi + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with + # Solaris 8's {/usr,}/bin/sh. + touch sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + case $depmode in + nosideeffect) + # after this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + none) break ;; + esac + # We check with `-c' and `-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle `-M -o', and we need to detect this. + if depmode=$depmode \ + source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_CC_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_CC_dependencies_compiler_type=none +fi + +fi +echo "$as_me:$LINENO: result: $am_cv_CC_dependencies_compiler_type" >&5 +echo "${ECHO_T}$am_cv_CC_dependencies_compiler_type" >&6 +CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type + + + +if + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then + am__fastdepCC_TRUE= + am__fastdepCC_FALSE='#' +else + am__fastdepCC_TRUE='#' + am__fastdepCC_FALSE= +fi + + + + +# Check whether --enable-shared or --disable-shared was given. +if test "${enable_shared+set}" = set; then + enableval="$enable_shared" + p=${PACKAGE-default} + case $enableval in + yes) enable_shared=yes ;; + no) enable_shared=no ;; + *) + enable_shared=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_shared=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac +else + enable_shared=yes +fi; + + +if test "$CXXFLAGS" = ""; then + CXXFLAGS="-O2" +fi + + + +if test x"`egrep _REENTRANT /usr/include/features.h`" != x; then + CXXFLAGS="-D_REENTRANT $CXXFLAGS" + CFLAGS="-D_REENTRANT $CFLAGS" +fi + +CXXFLAGS="-Wall $CXXFLAGS" + +# Check whether --enable-static or --disable-static was given. +if test "${enable_static+set}" = set; then + enableval="$enable_static" + p=${PACKAGE-default} + case $enableval in + yes) enable_static=yes ;; + no) enable_static=no ;; + *) + enable_static=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_static=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac +else + enable_static=yes +fi; + +# Check whether --enable-fast-install or --disable-fast-install was given. +if test "${enable_fast_install+set}" = set; then + enableval="$enable_fast_install" + p=${PACKAGE-default} + case $enableval in + yes) enable_fast_install=yes ;; + no) enable_fast_install=no ;; + *) + enable_fast_install=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_fast_install=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac +else + enable_fast_install=yes +fi; + +# Make sure we can run config.sub. +$ac_config_sub sun4 >/dev/null 2>&1 || + { { echo "$as_me:$LINENO: error: cannot run $ac_config_sub" >&5 +echo "$as_me: error: cannot run $ac_config_sub" >&2;} + { (exit 1); exit 1; }; } + +echo "$as_me:$LINENO: checking build system type" >&5 +echo $ECHO_N "checking build system type... $ECHO_C" >&6 +if test "${ac_cv_build+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_cv_build_alias=$build_alias +test -z "$ac_cv_build_alias" && + ac_cv_build_alias=`$ac_config_guess` +test -z "$ac_cv_build_alias" && + { { echo "$as_me:$LINENO: error: cannot guess build type; you must specify one" >&5 +echo "$as_me: error: cannot guess build type; you must specify one" >&2;} + { (exit 1); exit 1; }; } +ac_cv_build=`$ac_config_sub $ac_cv_build_alias` || + { { echo "$as_me:$LINENO: error: $ac_config_sub $ac_cv_build_alias failed" >&5 +echo "$as_me: error: $ac_config_sub $ac_cv_build_alias failed" >&2;} + { (exit 1); exit 1; }; } + +fi +echo "$as_me:$LINENO: result: $ac_cv_build" >&5 +echo "${ECHO_T}$ac_cv_build" >&6 +build=$ac_cv_build +build_cpu=`echo $ac_cv_build | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'` +build_vendor=`echo $ac_cv_build | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\2/'` +build_os=`echo $ac_cv_build | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'` + + +echo "$as_me:$LINENO: checking host system type" >&5 +echo $ECHO_N "checking host system type... $ECHO_C" >&6 +if test "${ac_cv_host+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_cv_host_alias=$host_alias +test -z "$ac_cv_host_alias" && + ac_cv_host_alias=$ac_cv_build_alias +ac_cv_host=`$ac_config_sub $ac_cv_host_alias` || + { { echo "$as_me:$LINENO: error: $ac_config_sub $ac_cv_host_alias failed" >&5 +echo "$as_me: error: $ac_config_sub $ac_cv_host_alias failed" >&2;} + { (exit 1); exit 1; }; } + +fi +echo "$as_me:$LINENO: result: $ac_cv_host" >&5 +echo "${ECHO_T}$ac_cv_host" >&6 +host=$ac_cv_host +host_cpu=`echo $ac_cv_host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'` +host_vendor=`echo $ac_cv_host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\2/'` +host_os=`echo $ac_cv_host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'` + + +echo "$as_me:$LINENO: checking for a sed that does not truncate output" >&5 +echo $ECHO_N "checking for a sed that does not truncate output... $ECHO_C" >&6 +if test "${lt_cv_path_SED+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + # Loop through the user's path and test for sed and gsed. +# Then use that list of sed's as ones to test for truncation. +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for lt_ac_prog in sed gsed; do + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then + lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext" + fi + done + done +done +lt_ac_max=0 +lt_ac_count=0 +# Add /usr/xpg4/bin/sed as it is typically found on Solaris +# along with /bin/sed that truncates output. +for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do + test ! -f $lt_ac_sed && continue + cat /dev/null > conftest.in + lt_ac_count=0 + echo $ECHO_N "0123456789$ECHO_C" >conftest.in + # Check for GNU sed and select it if it is found. + if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then + lt_cv_path_SED=$lt_ac_sed + break + fi + while true; do + cat conftest.in conftest.in >conftest.tmp + mv conftest.tmp conftest.in + cp conftest.in conftest.nl + echo >>conftest.nl + $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break + cmp -s conftest.out conftest.nl || break + # 10000 chars as input seems more than enough + test $lt_ac_count -gt 10 && break + lt_ac_count=`expr $lt_ac_count + 1` + if test $lt_ac_count -gt $lt_ac_max; then + lt_ac_max=$lt_ac_count + lt_cv_path_SED=$lt_ac_sed + fi + done +done + +fi + +SED=$lt_cv_path_SED +echo "$as_me:$LINENO: result: $SED" >&5 +echo "${ECHO_T}$SED" >&6 + +echo "$as_me:$LINENO: checking for egrep" >&5 +echo $ECHO_N "checking for egrep... $ECHO_C" >&6 +if test "${ac_cv_prog_egrep+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if echo a | (grep -E '(a|b)') >/dev/null 2>&1 + then ac_cv_prog_egrep='grep -E' + else ac_cv_prog_egrep='egrep' + fi +fi +echo "$as_me:$LINENO: result: $ac_cv_prog_egrep" >&5 +echo "${ECHO_T}$ac_cv_prog_egrep" >&6 + EGREP=$ac_cv_prog_egrep + + + +# Check whether --with-gnu-ld or --without-gnu-ld was given. +if test "${with_gnu_ld+set}" = set; then + withval="$with_gnu_ld" + test "$withval" = no || with_gnu_ld=yes +else + with_gnu_ld=no +fi; +ac_prog=ld +if test "$GCC" = yes; then + # Check if gcc -print-prog-name=ld gives a path. + echo "$as_me:$LINENO: checking for ld used by $CC" >&5 +echo $ECHO_N "checking for ld used by $CC... $ECHO_C" >&6 + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [\\/]* | ?:[\\/]*) + re_direlt='/[^/][^/]*/\.\./' + # Canonicalize the pathname of ld + ac_prog=`echo $ac_prog| $SED 's%\\\\%/%g'` + while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do + ac_prog=`echo $ac_prog| $SED "s%$re_direlt%/%"` + done + test -z "$LD" && LD="$ac_prog" + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test "$with_gnu_ld" = yes; then + echo "$as_me:$LINENO: checking for GNU ld" >&5 +echo $ECHO_N "checking for GNU ld... $ECHO_C" >&6 +else + echo "$as_me:$LINENO: checking for non-GNU ld" >&5 +echo $ECHO_N "checking for non-GNU ld... $ECHO_C" >&6 +fi +if test "${lt_cv_path_LD+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -z "$LD"; then + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + lt_cv_path_LD="$ac_dir/$ac_prog" + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some variants of GNU ld only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$lt_cv_path_LD" -v 2>&1 &5 +echo "${ECHO_T}$LD" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi +test -z "$LD" && { { echo "$as_me:$LINENO: error: no acceptable ld found in \$PATH" >&5 +echo "$as_me: error: no acceptable ld found in \$PATH" >&2;} + { (exit 1); exit 1; }; } +echo "$as_me:$LINENO: checking if the linker ($LD) is GNU ld" >&5 +echo $ECHO_N "checking if the linker ($LD) is GNU ld... $ECHO_C" >&6 +if test "${lt_cv_prog_gnu_ld+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + # I'd rather use --version here, but apparently some GNU lds only accept -v. +case `$LD -v 2>&1 &5 +echo "${ECHO_T}$lt_cv_prog_gnu_ld" >&6 +with_gnu_ld=$lt_cv_prog_gnu_ld + + +echo "$as_me:$LINENO: checking for $LD option to reload object files" >&5 +echo $ECHO_N "checking for $LD option to reload object files... $ECHO_C" >&6 +if test "${lt_cv_ld_reload_flag+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_cv_ld_reload_flag='-r' +fi +echo "$as_me:$LINENO: result: $lt_cv_ld_reload_flag" >&5 +echo "${ECHO_T}$lt_cv_ld_reload_flag" >&6 +reload_flag=$lt_cv_ld_reload_flag +case $reload_flag in +"" | " "*) ;; +*) reload_flag=" $reload_flag" ;; +esac +reload_cmds='$LD$reload_flag -o $output$reload_objs' +case $host_os in + darwin*) + if test "$GCC" = yes; then + reload_cmds='$CC -nostdlib ${wl}-r -o $output$reload_objs' + else + reload_cmds='$LD$reload_flag -o $output$reload_objs' + fi + ;; +esac + +echo "$as_me:$LINENO: checking for BSD-compatible nm" >&5 +echo $ECHO_N "checking for BSD-compatible nm... $ECHO_C" >&6 +if test "${lt_cv_path_NM+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$NM"; then + # Let the user override the test. + lt_cv_path_NM="$NM" +else + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH /usr/ccs/bin /usr/ucb /bin; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + tmp_nm="$ac_dir/${ac_tool_prefix}nm" + if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then + # Check to see if the nm accepts a BSD-compat flag. + # Adding the `sed 1q' prevents false positives on HP-UX, which says: + # nm: unknown option "B" ignored + # Tru64's nm complains that /dev/null is an invalid object file + case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in + */dev/null* | *'Invalid file or object type'*) + lt_cv_path_NM="$tmp_nm -B" + break + ;; + *) + case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in + */dev/null*) + lt_cv_path_NM="$tmp_nm -p" + break + ;; + *) + lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but + continue # so that we can try to find one that supports BSD flags + ;; + esac + esac + fi + done + IFS="$lt_save_ifs" + test -z "$lt_cv_path_NM" && lt_cv_path_NM=nm +fi +fi +echo "$as_me:$LINENO: result: $lt_cv_path_NM" >&5 +echo "${ECHO_T}$lt_cv_path_NM" >&6 +NM="$lt_cv_path_NM" + +echo "$as_me:$LINENO: checking whether ln -s works" >&5 +echo $ECHO_N "checking whether ln -s works... $ECHO_C" >&6 +LN_S=$as_ln_s +if test "$LN_S" = "ln -s"; then + echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 +else + echo "$as_me:$LINENO: result: no, using $LN_S" >&5 +echo "${ECHO_T}no, using $LN_S" >&6 +fi + +echo "$as_me:$LINENO: checking how to recognise dependent libraries" >&5 +echo $ECHO_N "checking how to recognise dependent libraries... $ECHO_C" >&6 +if test "${lt_cv_deplibs_check_method+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_cv_file_magic_cmd='$MAGIC_CMD' +lt_cv_file_magic_test_file= +lt_cv_deplibs_check_method='unknown' +# Need to set the preceding variable on all platforms that support +# interlibrary dependencies. +# 'none' -- dependencies not supported. +# `unknown' -- same as none, but documents that we really don't know. +# 'pass_all' -- all dependencies passed with no checks. +# 'test_compile' -- check by making test program. +# 'file_magic [[regex]]' -- check by looking for files in library path +# which responds to the $file_magic_cmd with a given extended regex. +# If you have `file' or equivalent on your system and you're not sure +# whether `pass_all' will *always* work, you probably want this one. + +case $host_os in +aix4* | aix5*) + lt_cv_deplibs_check_method=pass_all + ;; + +beos*) + lt_cv_deplibs_check_method=pass_all + ;; + +bsdi[45]*) + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib)' + lt_cv_file_magic_cmd='/usr/bin/file -L' + lt_cv_file_magic_test_file=/shlib/libc.so + ;; + +cygwin*) + # func_win32_libid is a shell function defined in ltmain.sh + lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' + lt_cv_file_magic_cmd='func_win32_libid' + ;; + +mingw* | pw32*) + # Base MSYS/MinGW do not provide the 'file' command needed by + # func_win32_libid shell function, so use a weaker test based on 'objdump'. + lt_cv_deplibs_check_method='file_magic file format pei*-i386(.*architecture: i386)?' + lt_cv_file_magic_cmd='$OBJDUMP -f' + ;; + +darwin* | rhapsody*) + lt_cv_deplibs_check_method=pass_all + ;; + +freebsd* | kfreebsd*-gnu | dragonfly*) + if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then + case $host_cpu in + i*86 ) + # Not sure whether the presence of OpenBSD here was a mistake. + # Let's accept both of them until this is cleared up. + lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[3-9]86 (compact )?demand paged shared library' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` + ;; + esac + else + lt_cv_deplibs_check_method=pass_all + fi + ;; + +gnu*) + lt_cv_deplibs_check_method=pass_all + ;; + +hpux10.20* | hpux11*) + lt_cv_file_magic_cmd=/usr/bin/file + case $host_cpu in + ia64*) + lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - IA64' + lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so + ;; + hppa*64*) + lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - PA-RISC [0-9].[0-9]' + lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl + ;; + *) + lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|PA-RISC[0-9].[0-9]) shared library' + lt_cv_file_magic_test_file=/usr/lib/libc.sl + ;; + esac + ;; + +irix5* | irix6* | nonstopux*) + case $LD in + *-32|*"-32 ") libmagic=32-bit;; + *-n32|*"-n32 ") libmagic=N32;; + *-64|*"-64 ") libmagic=64-bit;; + *) libmagic=never-match;; + esac + lt_cv_deplibs_check_method=pass_all + ;; + +# This must be Linux ELF. +linux*) + lt_cv_deplibs_check_method=pass_all + ;; + +netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|_pic\.a)$' + fi + ;; + +newos6*) + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (executable|dynamic lib)' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=/usr/lib/libnls.so + ;; + +nto-qnx*) + lt_cv_deplibs_check_method=unknown + ;; + +openbsd*) + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|\.so|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' + fi + ;; + +osf3* | osf4* | osf5*) + lt_cv_deplibs_check_method=pass_all + ;; + +sco3.2v5*) + lt_cv_deplibs_check_method=pass_all + ;; + +solaris*) + lt_cv_deplibs_check_method=pass_all + ;; + +sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + case $host_vendor in + motorola) + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib) M[0-9][0-9]* Version [0-9]' + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` + ;; + ncr) + lt_cv_deplibs_check_method=pass_all + ;; + sequent) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [LM]SB (shared object|dynamic lib )' + ;; + sni) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method="file_magic ELF [0-9][0-9]*-bit [LM]SB dynamic lib" + lt_cv_file_magic_test_file=/lib/libc.so + ;; + siemens) + lt_cv_deplibs_check_method=pass_all + ;; + esac + ;; + +sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[78]* | unixware7* | sysv4*uw2*) + lt_cv_deplibs_check_method=pass_all + ;; +esac + +fi +echo "$as_me:$LINENO: result: $lt_cv_deplibs_check_method" >&5 +echo "${ECHO_T}$lt_cv_deplibs_check_method" >&6 +file_magic_cmd=$lt_cv_file_magic_cmd +deplibs_check_method=$lt_cv_deplibs_check_method +test -z "$deplibs_check_method" && deplibs_check_method=unknown + + + + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# Allow CC to be a program name with arguments. +compiler=$CC + +# Check whether --enable-libtool-lock or --disable-libtool-lock was given. +if test "${enable_libtool_lock+set}" = set; then + enableval="$enable_libtool_lock" + +fi; +test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes + +# Some flags need to be propagated to the compiler or linker for good +# libtool support. +case $host in +ia64-*-hpux*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + case `/usr/bin/file conftest.$ac_objext` in + *ELF-32*) + HPUX_IA64_MODE="32" + ;; + *ELF-64*) + HPUX_IA64_MODE="64" + ;; + esac + fi + rm -rf conftest* + ;; +*-*-irix6*) + # Find out which ABI we are using. + echo '#line 3740 "configure"' > conftest.$ac_ext + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + if test "$lt_cv_prog_gnu_ld" = yes; then + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -melf32bsmip" + ;; + *N32*) + LD="${LD-ld} -melf32bmipn32" + ;; + *64-bit*) + LD="${LD-ld} -melf64bmip" + ;; + esac + else + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -32" + ;; + *N32*) + LD="${LD-ld} -n32" + ;; + *64-bit*) + LD="${LD-ld} -64" + ;; + esac + fi + fi + rm -rf conftest* + ;; + +x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*|s390*-*linux*|sparc*-*linux*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + case `/usr/bin/file conftest.o` in + *32-bit*) + case $host in + x86_64-*linux*) + LD="${LD-ld} -m elf_i386" + ;; + ppc64-*linux*|powerpc64-*linux*) + LD="${LD-ld} -m elf32ppclinux" + ;; + s390x-*linux*) + LD="${LD-ld} -m elf_s390" + ;; + sparc64-*linux*) + LD="${LD-ld} -m elf32_sparc" + ;; + esac + ;; + *64-bit*) + case $host in + x86_64-*linux*) + LD="${LD-ld} -m elf_x86_64" + ;; + ppc*-*linux*|powerpc*-*linux*) + LD="${LD-ld} -m elf64ppc" + ;; + s390*-*linux*) + LD="${LD-ld} -m elf64_s390" + ;; + sparc*-*linux*) + LD="${LD-ld} -m elf64_sparc" + ;; + esac + ;; + esac + fi + rm -rf conftest* + ;; + +*-*-sco3.2v5*) + # On SCO OpenServer 5, we need -belf to get full-featured binaries. + SAVE_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS -belf" + echo "$as_me:$LINENO: checking whether the C compiler needs -belf" >&5 +echo $ECHO_N "checking whether the C compiler needs -belf... $ECHO_C" >&6 +if test "${lt_cv_cc_needs_belf+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + lt_cv_cc_needs_belf=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +lt_cv_cc_needs_belf=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +fi +echo "$as_me:$LINENO: result: $lt_cv_cc_needs_belf" >&5 +echo "${ECHO_T}$lt_cv_cc_needs_belf" >&6 + if test x"$lt_cv_cc_needs_belf" != x"yes"; then + # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf + CFLAGS="$SAVE_CFLAGS" + fi + ;; + +esac + +need_locks="$enable_libtool_lock" + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +echo "$as_me:$LINENO: checking how to run the C preprocessor" >&5 +echo $ECHO_N "checking how to run the C preprocessor... $ECHO_C" >&6 +# On Suns, sometimes $CPP names a directory. +if test -n "$CPP" && test -d "$CPP"; then + CPP= +fi +if test -z "$CPP"; then + if test "${ac_cv_prog_CPP+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + # Double quotes because CPP needs to be expanded + for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" + do + ac_preproc_ok=false +for ac_c_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + : +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether non-existent headers + # can be detected and how. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + # Broken: success on invalid input. +continue +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then + break +fi + + done + ac_cv_prog_CPP=$CPP + +fi + CPP=$ac_cv_prog_CPP +else + ac_cv_prog_CPP=$CPP +fi +echo "$as_me:$LINENO: result: $CPP" >&5 +echo "${ECHO_T}$CPP" >&6 +ac_preproc_ok=false +for ac_c_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + : +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether non-existent headers + # can be detected and how. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + # Broken: success on invalid input. +continue +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then + : +else + { { echo "$as_me:$LINENO: error: C preprocessor \"$CPP\" fails sanity check +See \`config.log' for more details." >&5 +echo "$as_me: error: C preprocessor \"$CPP\" fails sanity check +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +echo "$as_me:$LINENO: checking for ANSI C header files" >&5 +echo $ECHO_N "checking for ANSI C header files... $ECHO_C" >&6 +if test "${ac_cv_header_stdc+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +#include +#include + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_header_stdc=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_header_stdc=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + +if test $ac_cv_header_stdc = yes; then + # SunOS 4.x string.h does not declare mem*, contrary to ANSI. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "memchr" >/dev/null 2>&1; then + : +else + ac_cv_header_stdc=no +fi +rm -f conftest* + +fi + +if test $ac_cv_header_stdc = yes; then + # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "free" >/dev/null 2>&1; then + : +else + ac_cv_header_stdc=no +fi +rm -f conftest* + +fi + +if test $ac_cv_header_stdc = yes; then + # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. + if test "$cross_compiling" = yes; then + : +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#if ((' ' & 0x0FF) == 0x020) +# define ISLOWER(c) ('a' <= (c) && (c) <= 'z') +# define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) +#else +# define ISLOWER(c) \ + (('a' <= (c) && (c) <= 'i') \ + || ('j' <= (c) && (c) <= 'r') \ + || ('s' <= (c) && (c) <= 'z')) +# define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) +#endif + +#define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) +int +main () +{ + int i; + for (i = 0; i < 256; i++) + if (XOR (islower (i), ISLOWER (i)) + || toupper (i) != TOUPPER (i)) + exit(2); + exit (0); +} +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + : +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +ac_cv_header_stdc=no +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +fi +fi +echo "$as_me:$LINENO: result: $ac_cv_header_stdc" >&5 +echo "${ECHO_T}$ac_cv_header_stdc" >&6 +if test $ac_cv_header_stdc = yes; then + +cat >>confdefs.h <<\_ACEOF +#define STDC_HEADERS 1 +_ACEOF + +fi + +# On IRIX 5.3, sys/types and inttypes.h are conflicting. + + + + + + + + + +for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \ + inttypes.h stdint.h unistd.h +do +as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` +echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default + +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + eval "$as_ac_Header=yes" +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +eval "$as_ac_Header=no" +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 +if test `eval echo '${'$as_ac_Header'}'` = yes; then + cat >>confdefs.h <<_ACEOF +#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + + +for ac_header in dlfcn.h +do +as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 +else + # Is the header compilable? +echo "$as_me:$LINENO: checking $ac_header usability" >&5 +echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_header_compiler=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_header_compiler=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 +echo "${ECHO_T}$ac_header_compiler" >&6 + +# Is the header present? +echo "$as_me:$LINENO: checking $ac_header presence" >&5 +echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include <$ac_header> +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + ac_header_preproc=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_preproc=no +fi +rm -f conftest.err conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 +echo "${ECHO_T}$ac_header_preproc" >&6 + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in + yes:no: ) + { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 +echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} + ac_header_preproc=yes + ;; + no:yes:* ) + { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 +echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 +echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 +echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 +echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 +echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} + ( + cat <<\_ASBOX +## ------------------------------------------ ## +## Report this to the AC_PACKAGE_NAME lists. ## +## ------------------------------------------ ## +_ASBOX + ) | + sed "s/^/$as_me: WARNING: /" >&2 + ;; +esac +echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + eval "$as_ac_Header=\$ac_header_preproc" +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 + +fi +if test `eval echo '${'$as_ac_Header'}'` = yes; then + cat >>confdefs.h <<_ACEOF +#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + +ac_ext=cc +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu +if test -n "$ac_tool_prefix"; then + for ac_prog in $CCC g++ c++ gpp aCC CC cxx cc++ cl FCC KCC RCC xlC_r xlC + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_CXX+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$CXX"; then + ac_cv_prog_CXX="$CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CXX="$ac_tool_prefix$ac_prog" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +CXX=$ac_cv_prog_CXX +if test -n "$CXX"; then + echo "$as_me:$LINENO: result: $CXX" >&5 +echo "${ECHO_T}$CXX" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + test -n "$CXX" && break + done +fi +if test -z "$CXX"; then + ac_ct_CXX=$CXX + for ac_prog in $CCC g++ c++ gpp aCC CC cxx cc++ cl FCC KCC RCC xlC_r xlC +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_ac_ct_CXX+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$ac_ct_CXX"; then + ac_cv_prog_ac_ct_CXX="$ac_ct_CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_CXX="$ac_prog" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +ac_ct_CXX=$ac_cv_prog_ac_ct_CXX +if test -n "$ac_ct_CXX"; then + echo "$as_me:$LINENO: result: $ac_ct_CXX" >&5 +echo "${ECHO_T}$ac_ct_CXX" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + test -n "$ac_ct_CXX" && break +done +test -n "$ac_ct_CXX" || ac_ct_CXX="g++" + + CXX=$ac_ct_CXX +fi + + +# Provide some information about the compiler. +echo "$as_me:$LINENO:" \ + "checking for C++ compiler version" >&5 +ac_compiler=`set X $ac_compile; echo $2` +{ (eval echo "$as_me:$LINENO: \"$ac_compiler --version &5\"") >&5 + (eval $ac_compiler --version &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (eval echo "$as_me:$LINENO: \"$ac_compiler -v &5\"") >&5 + (eval $ac_compiler -v &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (eval echo "$as_me:$LINENO: \"$ac_compiler -V &5\"") >&5 + (eval $ac_compiler -V &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + +echo "$as_me:$LINENO: checking whether we are using the GNU C++ compiler" >&5 +echo $ECHO_N "checking whether we are using the GNU C++ compiler... $ECHO_C" >&6 +if test "${ac_cv_cxx_compiler_gnu+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_compiler_gnu=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_compiler_gnu=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_cxx_compiler_gnu=$ac_compiler_gnu + +fi +echo "$as_me:$LINENO: result: $ac_cv_cxx_compiler_gnu" >&5 +echo "${ECHO_T}$ac_cv_cxx_compiler_gnu" >&6 +GXX=`test $ac_compiler_gnu = yes && echo yes` +ac_test_CXXFLAGS=${CXXFLAGS+set} +ac_save_CXXFLAGS=$CXXFLAGS +CXXFLAGS="-g" +echo "$as_me:$LINENO: checking whether $CXX accepts -g" >&5 +echo $ECHO_N "checking whether $CXX accepts -g... $ECHO_C" >&6 +if test "${ac_cv_prog_cxx_g+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_prog_cxx_g=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_prog_cxx_g=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_prog_cxx_g" >&5 +echo "${ECHO_T}$ac_cv_prog_cxx_g" >&6 +if test "$ac_test_CXXFLAGS" = set; then + CXXFLAGS=$ac_save_CXXFLAGS +elif test $ac_cv_prog_cxx_g = yes; then + if test "$GXX" = yes; then + CXXFLAGS="-g -O2" + else + CXXFLAGS="-g" + fi +else + if test "$GXX" = yes; then + CXXFLAGS="-O2" + else + CXXFLAGS= + fi +fi +for ac_declaration in \ + '' \ + 'extern "C" void std::exit (int) throw (); using std::exit;' \ + 'extern "C" void std::exit (int); using std::exit;' \ + 'extern "C" void exit (int) throw ();' \ + 'extern "C" void exit (int);' \ + 'void exit (int);' +do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_declaration +#include +int +main () +{ +exit (42); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + : +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +continue +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_declaration +int +main () +{ +exit (42); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +done +rm -f conftest* +if test -n "$ac_declaration"; then + echo '#ifdef __cplusplus' >>confdefs.h + echo $ac_declaration >>confdefs.h + echo '#endif' >>confdefs.h +fi + +ac_ext=cc +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + +depcc="$CXX" am_compiler_list= + +echo "$as_me:$LINENO: checking dependency style of $depcc" >&5 +echo $ECHO_N "checking dependency style of $depcc... $ECHO_C" >&6 +if test "${am_cv_CXX_dependencies_compiler_type+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named `D' -- because `-MD' means `put the output + # in D'. + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_CXX_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` + fi + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with + # Solaris 8's {/usr,}/bin/sh. + touch sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + case $depmode in + nosideeffect) + # after this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + none) break ;; + esac + # We check with `-c' and `-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle `-M -o', and we need to detect this. + if depmode=$depmode \ + source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_CXX_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_CXX_dependencies_compiler_type=none +fi + +fi +echo "$as_me:$LINENO: result: $am_cv_CXX_dependencies_compiler_type" >&5 +echo "${ECHO_T}$am_cv_CXX_dependencies_compiler_type" >&6 +CXXDEPMODE=depmode=$am_cv_CXX_dependencies_compiler_type + + + +if + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_CXX_dependencies_compiler_type" = gcc3; then + am__fastdepCXX_TRUE= + am__fastdepCXX_FALSE='#' +else + am__fastdepCXX_TRUE='#' + am__fastdepCXX_FALSE= +fi + + + + +if test -n "$CXX" && ( test "X$CXX" != "Xno" && + ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || + (test "X$CXX" != "Xg++"))) ; then + ac_ext=cc +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu +echo "$as_me:$LINENO: checking how to run the C++ preprocessor" >&5 +echo $ECHO_N "checking how to run the C++ preprocessor... $ECHO_C" >&6 +if test -z "$CXXCPP"; then + if test "${ac_cv_prog_CXXCPP+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + # Double quotes because CXXCPP needs to be expanded + for CXXCPP in "$CXX -E" "/lib/cpp" + do + ac_preproc_ok=false +for ac_cxx_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_cxx_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_cxx_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + : +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether non-existent headers + # can be detected and how. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_cxx_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_cxx_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + # Broken: success on invalid input. +continue +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then + break +fi + + done + ac_cv_prog_CXXCPP=$CXXCPP + +fi + CXXCPP=$ac_cv_prog_CXXCPP +else + ac_cv_prog_CXXCPP=$CXXCPP +fi +echo "$as_me:$LINENO: result: $CXXCPP" >&5 +echo "${ECHO_T}$CXXCPP" >&6 +ac_preproc_ok=false +for ac_cxx_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_cxx_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_cxx_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + : +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether non-existent headers + # can be detected and how. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_cxx_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_cxx_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + # Broken: success on invalid input. +continue +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then + : +else + { { echo "$as_me:$LINENO: error: C++ preprocessor \"$CXXCPP\" fails sanity check +See \`config.log' for more details." >&5 +echo "$as_me: error: C++ preprocessor \"$CXXCPP\" fails sanity check +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } +fi + +ac_ext=cc +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + +fi + + +ac_ext=f +ac_compile='$F77 -c $FFLAGS conftest.$ac_ext >&5' +ac_link='$F77 -o conftest$ac_exeext $FFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_f77_compiler_gnu +if test -n "$ac_tool_prefix"; then + for ac_prog in g77 f77 xlf frt pgf77 fort77 fl32 af77 f90 xlf90 pgf90 epcf90 f95 fort xlf95 ifc efc pgf95 lf95 gfortran + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_F77+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$F77"; then + ac_cv_prog_F77="$F77" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_F77="$ac_tool_prefix$ac_prog" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +F77=$ac_cv_prog_F77 +if test -n "$F77"; then + echo "$as_me:$LINENO: result: $F77" >&5 +echo "${ECHO_T}$F77" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + test -n "$F77" && break + done +fi +if test -z "$F77"; then + ac_ct_F77=$F77 + for ac_prog in g77 f77 xlf frt pgf77 fort77 fl32 af77 f90 xlf90 pgf90 epcf90 f95 fort xlf95 ifc efc pgf95 lf95 gfortran +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_ac_ct_F77+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$ac_ct_F77"; then + ac_cv_prog_ac_ct_F77="$ac_ct_F77" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_F77="$ac_prog" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +ac_ct_F77=$ac_cv_prog_ac_ct_F77 +if test -n "$ac_ct_F77"; then + echo "$as_me:$LINENO: result: $ac_ct_F77" >&5 +echo "${ECHO_T}$ac_ct_F77" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + test -n "$ac_ct_F77" && break +done + + F77=$ac_ct_F77 +fi + + +# Provide some information about the compiler. +echo "$as_me:5311:" \ + "checking for Fortran 77 compiler version" >&5 +ac_compiler=`set X $ac_compile; echo $2` +{ (eval echo "$as_me:$LINENO: \"$ac_compiler --version &5\"") >&5 + (eval $ac_compiler --version &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (eval echo "$as_me:$LINENO: \"$ac_compiler -v &5\"") >&5 + (eval $ac_compiler -v &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (eval echo "$as_me:$LINENO: \"$ac_compiler -V &5\"") >&5 + (eval $ac_compiler -V &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +rm -f a.out + +# If we don't use `.F' as extension, the preprocessor is not run on the +# input file. (Note that this only needs to work for GNU compilers.) +ac_save_ext=$ac_ext +ac_ext=F +echo "$as_me:$LINENO: checking whether we are using the GNU Fortran 77 compiler" >&5 +echo $ECHO_N "checking whether we are using the GNU Fortran 77 compiler... $ECHO_C" >&6 +if test "${ac_cv_f77_compiler_gnu+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF + program main +#ifndef __GNUC__ + choke me +#endif + + end +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_f77_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_compiler_gnu=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_compiler_gnu=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_f77_compiler_gnu=$ac_compiler_gnu + +fi +echo "$as_me:$LINENO: result: $ac_cv_f77_compiler_gnu" >&5 +echo "${ECHO_T}$ac_cv_f77_compiler_gnu" >&6 +ac_ext=$ac_save_ext +ac_test_FFLAGS=${FFLAGS+set} +ac_save_FFLAGS=$FFLAGS +FFLAGS= +echo "$as_me:$LINENO: checking whether $F77 accepts -g" >&5 +echo $ECHO_N "checking whether $F77 accepts -g... $ECHO_C" >&6 +if test "${ac_cv_prog_f77_g+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + FFLAGS=-g +cat >conftest.$ac_ext <<_ACEOF + program main + + end +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_f77_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_prog_f77_g=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_prog_f77_g=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + +fi +echo "$as_me:$LINENO: result: $ac_cv_prog_f77_g" >&5 +echo "${ECHO_T}$ac_cv_prog_f77_g" >&6 +if test "$ac_test_FFLAGS" = set; then + FFLAGS=$ac_save_FFLAGS +elif test $ac_cv_prog_f77_g = yes; then + if test "x$ac_cv_f77_compiler_gnu" = xyes; then + FFLAGS="-g -O2" + else + FFLAGS="-g" + fi +else + if test "x$ac_cv_f77_compiler_gnu" = xyes; then + FFLAGS="-O2" + else + FFLAGS= + fi +fi + +G77=`test $ac_compiler_gnu = yes && echo yes` +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + + +# Autoconf 2.13's AC_OBJEXT and AC_EXEEXT macros only works for C compilers! + +# find the maximum length of command line arguments +echo "$as_me:$LINENO: checking the maximum length of command line arguments" >&5 +echo $ECHO_N "checking the maximum length of command line arguments... $ECHO_C" >&6 +if test "${lt_cv_sys_max_cmd_len+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + i=0 + teststring="ABCD" + + case $build_os in + msdosdjgpp*) + # On DJGPP, this test can blow up pretty badly due to problems in libc + # (any single argument exceeding 2000 bytes causes a buffer overrun + # during glob expansion). Even if it were fixed, the result of this + # check would be larger than it should be. + lt_cv_sys_max_cmd_len=12288; # 12K is about right + ;; + + gnu*) + # Under GNU Hurd, this test is not required because there is + # no limit to the length of command line arguments. + # Libtool will interpret -1 as no limit whatsoever + lt_cv_sys_max_cmd_len=-1; + ;; + + cygwin* | mingw*) + # On Win9x/ME, this test blows up -- it succeeds, but takes + # about 5 minutes as the teststring grows exponentially. + # Worse, since 9x/ME are not pre-emptively multitasking, + # you end up with a "frozen" computer, even though with patience + # the test eventually succeeds (with a max line length of 256k). + # Instead, let's just punt: use the minimum linelength reported by + # all of the supported platforms: 8192 (on NT/2K/XP). + lt_cv_sys_max_cmd_len=8192; + ;; + + amigaos*) + # On AmigaOS with pdksh, this test takes hours, literally. + # So we just punt and use a minimum line length of 8192. + lt_cv_sys_max_cmd_len=8192; + ;; + + netbsd* | freebsd* | openbsd* | darwin* | dragonfly*) + # This has been around since 386BSD, at least. Likely further. + if test -x /sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` + elif test -x /usr/sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` + else + lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs + fi + # And add a safety zone + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` + ;; + osf*) + # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure + # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not + # nice to cause kernel panics so lets avoid the loop below. + # First set a reasonable default. + lt_cv_sys_max_cmd_len=16384 + # + if test -x /sbin/sysconfig; then + case `/sbin/sysconfig -q proc exec_disable_arg_limit` in + *1*) lt_cv_sys_max_cmd_len=-1 ;; + esac + fi + ;; + *) + # If test is not a shell built-in, we'll probably end up computing a + # maximum length that is only half of the actual maximum length, but + # we can't tell. + SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} + while (test "X"`$SHELL $0 --fallback-echo "X$teststring" 2>/dev/null` \ + = "XX$teststring") >/dev/null 2>&1 && + new_result=`expr "X$teststring" : ".*" 2>&1` && + lt_cv_sys_max_cmd_len=$new_result && + test $i != 17 # 1/2 MB should be enough + do + i=`expr $i + 1` + teststring=$teststring$teststring + done + teststring= + # Add a significant safety factor because C++ compilers can tack on massive + # amounts of additional arguments before passing them to the linker. + # It appears as though 1/2 is a usable value. + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` + ;; + esac + +fi + +if test -n $lt_cv_sys_max_cmd_len ; then + echo "$as_me:$LINENO: result: $lt_cv_sys_max_cmd_len" >&5 +echo "${ECHO_T}$lt_cv_sys_max_cmd_len" >&6 +else + echo "$as_me:$LINENO: result: none" >&5 +echo "${ECHO_T}none" >&6 +fi + + + + +# Check for command to grab the raw symbol name followed by C symbol from nm. +echo "$as_me:$LINENO: checking command to parse $NM output from $compiler object" >&5 +echo $ECHO_N "checking command to parse $NM output from $compiler object... $ECHO_C" >&6 +if test "${lt_cv_sys_global_symbol_pipe+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + +# These are sane defaults that work on at least a few old systems. +# [They come from Ultrix. What could be older than Ultrix?!! ;)] + +# Character class describing NM global symbol codes. +symcode='[BCDEGRST]' + +# Regexp to match symbols that can be accessed directly from C. +sympat='\([_A-Za-z][_A-Za-z0-9]*\)' + +# Transform an extracted symbol line into a proper C declaration +lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^. .* \(.*\)$/extern int \1;/p'" + +# Transform an extracted symbol line into symbol name and symbol address +lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([^ ]*\) $/ {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode \([^ ]*\) \([^ ]*\)$/ {\"\2\", (lt_ptr) \&\2},/p'" + +# Define system-specific variables. +case $host_os in +aix*) + symcode='[BCDT]' + ;; +cygwin* | mingw* | pw32*) + symcode='[ABCDGISTW]' + ;; +hpux*) # Its linker distinguishes data from code symbols + if test "$host_cpu" = ia64; then + symcode='[ABCDEGRST]' + fi + lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'" + lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([^ ]*\) $/ {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/ {\"\2\", (lt_ptr) \&\2},/p'" + ;; +linux*) + if test "$host_cpu" = ia64; then + symcode='[ABCDGIRSTW]' + lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'" + lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([^ ]*\) $/ {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/ {\"\2\", (lt_ptr) \&\2},/p'" + fi + ;; +irix* | nonstopux*) + symcode='[BCDEGRST]' + ;; +osf*) + symcode='[BCDEGQRST]' + ;; +solaris* | sysv5*) + symcode='[BDRT]' + ;; +sysv4) + symcode='[DFNSTU]' + ;; +esac + +# Handle CRLF in mingw tool chain +opt_cr= +case $build_os in +mingw*) + opt_cr=`echo 'x\{0,1\}' | tr x '\015'` # option cr in regexp + ;; +esac + +# If we're using GNU nm, then use its standard symbol codes. +case `$NM -V 2>&1` in +*GNU* | *'with BFD'*) + symcode='[ABCDGIRSTW]' ;; +esac + +# Try without a prefix undercore, then with it. +for ac_symprfx in "" "_"; do + + # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. + symxfrm="\\1 $ac_symprfx\\2 \\2" + + # Write the raw and C identifiers. + lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[ ]\($symcode$symcode*\)[ ][ ]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" + + # Check to see that the pipe works correctly. + pipe_works=no + + rm -f conftest* + cat > conftest.$ac_ext <&5 + (eval $ac_compile) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + # Now try to grab the symbols. + nlist=conftest.nm + if { (eval echo "$as_me:$LINENO: \"$NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $nlist\"") >&5 + (eval $NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $nlist) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s "$nlist"; then + # Try sorting and uniquifying the output. + if sort "$nlist" | uniq > "$nlist"T; then + mv -f "$nlist"T "$nlist" + else + rm -f "$nlist"T + fi + + # Make sure that we snagged all the symbols we need. + if grep ' nm_test_var$' "$nlist" >/dev/null; then + if grep ' nm_test_func$' "$nlist" >/dev/null; then + cat < conftest.$ac_ext +#ifdef __cplusplus +extern "C" { +#endif + +EOF + # Now generate the symbol file. + eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | grep -v main >> conftest.$ac_ext' + + cat <> conftest.$ac_ext +#if defined (__STDC__) && __STDC__ +# define lt_ptr_t void * +#else +# define lt_ptr_t char * +# define const +#endif + +/* The mapping between symbol names and symbols. */ +const struct { + const char *name; + lt_ptr_t address; +} +lt_preloaded_symbols[] = +{ +EOF + $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/ {\"\2\", (lt_ptr_t) \&\2},/" < "$nlist" | grep -v main >> conftest.$ac_ext + cat <<\EOF >> conftest.$ac_ext + {0, (lt_ptr_t) 0} +}; + +#ifdef __cplusplus +} +#endif +EOF + # Now try linking the two files. + mv conftest.$ac_objext conftstm.$ac_objext + lt_save_LIBS="$LIBS" + lt_save_CFLAGS="$CFLAGS" + LIBS="conftstm.$ac_objext" + CFLAGS="$CFLAGS$lt_prog_compiler_no_builtin_flag" + if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s conftest${ac_exeext}; then + pipe_works=yes + fi + LIBS="$lt_save_LIBS" + CFLAGS="$lt_save_CFLAGS" + else + echo "cannot find nm_test_func in $nlist" >&5 + fi + else + echo "cannot find nm_test_var in $nlist" >&5 + fi + else + echo "cannot run $lt_cv_sys_global_symbol_pipe" >&5 + fi + else + echo "$progname: failed program was:" >&5 + cat conftest.$ac_ext >&5 + fi + rm -f conftest* conftst* + + # Do not use the global_symbol_pipe unless it works. + if test "$pipe_works" = yes; then + break + else + lt_cv_sys_global_symbol_pipe= + fi +done + +fi + +if test -z "$lt_cv_sys_global_symbol_pipe"; then + lt_cv_sys_global_symbol_to_cdecl= +fi +if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then + echo "$as_me:$LINENO: result: failed" >&5 +echo "${ECHO_T}failed" >&6 +else + echo "$as_me:$LINENO: result: ok" >&5 +echo "${ECHO_T}ok" >&6 +fi + +echo "$as_me:$LINENO: checking for objdir" >&5 +echo $ECHO_N "checking for objdir... $ECHO_C" >&6 +if test "${lt_cv_objdir+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + rm -f .libs 2>/dev/null +mkdir .libs 2>/dev/null +if test -d .libs; then + lt_cv_objdir=.libs +else + # MS-DOS does not allow filenames that begin with a dot. + lt_cv_objdir=_libs +fi +rmdir .libs 2>/dev/null +fi +echo "$as_me:$LINENO: result: $lt_cv_objdir" >&5 +echo "${ECHO_T}$lt_cv_objdir" >&6 +objdir=$lt_cv_objdir + + + + + +case $host_os in +aix3*) + # AIX sometimes has problems with the GCC collect2 program. For some + # reason, if we set the COLLECT_NAMES environment variable, the problems + # vanish in a puff of smoke. + if test "X${COLLECT_NAMES+set}" != Xset; then + COLLECT_NAMES= + export COLLECT_NAMES + fi + ;; +esac + +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +Xsed='sed -e 1s/^X//' +sed_quote_subst='s/\([\\"\\`$\\\\]\)/\\\1/g' + +# Same as above, but do not quote variable references. +double_quote_subst='s/\([\\"\\`\\\\]\)/\\\1/g' + +# Sed substitution to delay expansion of an escaped shell variable in a +# double_quote_subst'ed string. +delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' + +# Sed substitution to avoid accidental globbing in evaled expressions +no_glob_subst='s/\*/\\\*/g' + +# Constants: +rm="rm -f" + +# Global variables: +default_ofile=libtool +can_build_shared=yes + +# All known linkers require a `.a' archive for static linking (except MSVC, +# which needs '.lib'). +libext=a +ltmain="$ac_aux_dir/ltmain.sh" +ofile="$default_ofile" +with_gnu_ld="$lt_cv_prog_gnu_ld" + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}ar", so it can be a program name with args. +set dummy ${ac_tool_prefix}ar; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_AR+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$AR"; then + ac_cv_prog_AR="$AR" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_AR="${ac_tool_prefix}ar" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +AR=$ac_cv_prog_AR +if test -n "$AR"; then + echo "$as_me:$LINENO: result: $AR" >&5 +echo "${ECHO_T}$AR" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + +fi +if test -z "$ac_cv_prog_AR"; then + ac_ct_AR=$AR + # Extract the first word of "ar", so it can be a program name with args. +set dummy ar; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_ac_ct_AR+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$ac_ct_AR"; then + ac_cv_prog_ac_ct_AR="$ac_ct_AR" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_AR="ar" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + + test -z "$ac_cv_prog_ac_ct_AR" && ac_cv_prog_ac_ct_AR="false" +fi +fi +ac_ct_AR=$ac_cv_prog_ac_ct_AR +if test -n "$ac_ct_AR"; then + echo "$as_me:$LINENO: result: $ac_ct_AR" >&5 +echo "${ECHO_T}$ac_ct_AR" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + AR=$ac_ct_AR +else + AR="$ac_cv_prog_AR" +fi + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. +set dummy ${ac_tool_prefix}ranlib; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_RANLIB+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$RANLIB"; then + ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +RANLIB=$ac_cv_prog_RANLIB +if test -n "$RANLIB"; then + echo "$as_me:$LINENO: result: $RANLIB" >&5 +echo "${ECHO_T}$RANLIB" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + +fi +if test -z "$ac_cv_prog_RANLIB"; then + ac_ct_RANLIB=$RANLIB + # Extract the first word of "ranlib", so it can be a program name with args. +set dummy ranlib; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_ac_ct_RANLIB+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$ac_ct_RANLIB"; then + ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_RANLIB="ranlib" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + + test -z "$ac_cv_prog_ac_ct_RANLIB" && ac_cv_prog_ac_ct_RANLIB=":" +fi +fi +ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB +if test -n "$ac_ct_RANLIB"; then + echo "$as_me:$LINENO: result: $ac_ct_RANLIB" >&5 +echo "${ECHO_T}$ac_ct_RANLIB" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + RANLIB=$ac_ct_RANLIB +else + RANLIB="$ac_cv_prog_RANLIB" +fi + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. +set dummy ${ac_tool_prefix}strip; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_STRIP+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$STRIP"; then + ac_cv_prog_STRIP="$STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_STRIP="${ac_tool_prefix}strip" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +STRIP=$ac_cv_prog_STRIP +if test -n "$STRIP"; then + echo "$as_me:$LINENO: result: $STRIP" >&5 +echo "${ECHO_T}$STRIP" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + +fi +if test -z "$ac_cv_prog_STRIP"; then + ac_ct_STRIP=$STRIP + # Extract the first word of "strip", so it can be a program name with args. +set dummy strip; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$ac_ct_STRIP"; then + ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_STRIP="strip" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + + test -z "$ac_cv_prog_ac_ct_STRIP" && ac_cv_prog_ac_ct_STRIP=":" +fi +fi +ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP +if test -n "$ac_ct_STRIP"; then + echo "$as_me:$LINENO: result: $ac_ct_STRIP" >&5 +echo "${ECHO_T}$ac_ct_STRIP" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + STRIP=$ac_ct_STRIP +else + STRIP="$ac_cv_prog_STRIP" +fi + + +old_CC="$CC" +old_CFLAGS="$CFLAGS" + +# Set sane defaults for various variables +test -z "$AR" && AR=ar +test -z "$AR_FLAGS" && AR_FLAGS=cru +test -z "$AS" && AS=as +test -z "$CC" && CC=cc +test -z "$LTCC" && LTCC=$CC +test -z "$DLLTOOL" && DLLTOOL=dlltool +test -z "$LD" && LD=ld +test -z "$LN_S" && LN_S="ln -s" +test -z "$MAGIC_CMD" && MAGIC_CMD=file +test -z "$NM" && NM=nm +test -z "$SED" && SED=sed +test -z "$OBJDUMP" && OBJDUMP=objdump +test -z "$RANLIB" && RANLIB=: +test -z "$STRIP" && STRIP=: +test -z "$ac_objext" && ac_objext=o + +# Determine commands to create old-style static archives. +old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs$old_deplibs' +old_postinstall_cmds='chmod 644 $oldlib' +old_postuninstall_cmds= + +if test -n "$RANLIB"; then + case $host_os in + openbsd*) + old_postinstall_cmds="\$RANLIB -t \$oldlib~$old_postinstall_cmds" + ;; + *) + old_postinstall_cmds="\$RANLIB \$oldlib~$old_postinstall_cmds" + ;; + esac + old_archive_cmds="$old_archive_cmds~\$RANLIB \$oldlib" +fi + +for cc_temp in $compiler""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` + + +# Only perform the check for file, if the check method requires it +case $deplibs_check_method in +file_magic*) + if test "$file_magic_cmd" = '$MAGIC_CMD'; then + echo "$as_me:$LINENO: checking for ${ac_tool_prefix}file" >&5 +echo $ECHO_N "checking for ${ac_tool_prefix}file... $ECHO_C" >&6 +if test "${lt_cv_path_MAGIC_CMD+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + case $MAGIC_CMD in +[\\/*] | ?:[\\/]*) + lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. + ;; +*) + lt_save_MAGIC_CMD="$MAGIC_CMD" + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" + for ac_dir in $ac_dummy; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/${ac_tool_prefix}file; then + lt_cv_path_MAGIC_CMD="$ac_dir/${ac_tool_prefix}file" + if test -n "$file_magic_test_file"; then + case $deplibs_check_method in + "file_magic "*) + file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` + MAGIC_CMD="$lt_cv_path_MAGIC_CMD" + if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | + $EGREP "$file_magic_regex" > /dev/null; then + : + else + cat <&2 + +*** Warning: the command libtool uses to detect shared libraries, +*** $file_magic_cmd, produces output that libtool cannot recognize. +*** The result is that libtool may fail to recognize shared libraries +*** as such. This will affect the creation of libtool libraries that +*** depend on shared libraries, but programs linked with such libtool +*** libraries will work regardless of this problem. Nevertheless, you +*** may want to report the problem to your system manager and/or to +*** bug-libtool@gnu.org + +EOF + fi ;; + esac + fi + break + fi + done + IFS="$lt_save_ifs" + MAGIC_CMD="$lt_save_MAGIC_CMD" + ;; +esac +fi + +MAGIC_CMD="$lt_cv_path_MAGIC_CMD" +if test -n "$MAGIC_CMD"; then + echo "$as_me:$LINENO: result: $MAGIC_CMD" >&5 +echo "${ECHO_T}$MAGIC_CMD" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + +if test -z "$lt_cv_path_MAGIC_CMD"; then + if test -n "$ac_tool_prefix"; then + echo "$as_me:$LINENO: checking for file" >&5 +echo $ECHO_N "checking for file... $ECHO_C" >&6 +if test "${lt_cv_path_MAGIC_CMD+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + case $MAGIC_CMD in +[\\/*] | ?:[\\/]*) + lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. + ;; +*) + lt_save_MAGIC_CMD="$MAGIC_CMD" + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" + for ac_dir in $ac_dummy; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/file; then + lt_cv_path_MAGIC_CMD="$ac_dir/file" + if test -n "$file_magic_test_file"; then + case $deplibs_check_method in + "file_magic "*) + file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` + MAGIC_CMD="$lt_cv_path_MAGIC_CMD" + if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | + $EGREP "$file_magic_regex" > /dev/null; then + : + else + cat <&2 + +*** Warning: the command libtool uses to detect shared libraries, +*** $file_magic_cmd, produces output that libtool cannot recognize. +*** The result is that libtool may fail to recognize shared libraries +*** as such. This will affect the creation of libtool libraries that +*** depend on shared libraries, but programs linked with such libtool +*** libraries will work regardless of this problem. Nevertheless, you +*** may want to report the problem to your system manager and/or to +*** bug-libtool@gnu.org + +EOF + fi ;; + esac + fi + break + fi + done + IFS="$lt_save_ifs" + MAGIC_CMD="$lt_save_MAGIC_CMD" + ;; +esac +fi + +MAGIC_CMD="$lt_cv_path_MAGIC_CMD" +if test -n "$MAGIC_CMD"; then + echo "$as_me:$LINENO: result: $MAGIC_CMD" >&5 +echo "${ECHO_T}$MAGIC_CMD" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + else + MAGIC_CMD=: + fi +fi + + fi + ;; +esac + +enable_dlopen=no +enable_win32_dll=no + +# Check whether --enable-libtool-lock or --disable-libtool-lock was given. +if test "${enable_libtool_lock+set}" = set; then + enableval="$enable_libtool_lock" + +fi; +test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes + + +# Check whether --with-pic or --without-pic was given. +if test "${with_pic+set}" = set; then + withval="$with_pic" + pic_mode="$withval" +else + pic_mode=default +fi; +test -z "$pic_mode" && pic_mode=default + +# Use C for the default configuration in the libtool script +tagname= +lt_save_CC="$CC" +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +# Source file extension for C test sources. +ac_ext=c + +# Object file extension for compiled C test sources. +objext=o +objext=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="int some_variable = 0;\n" + +# Code to be used in simple link tests +lt_simple_link_test_code='int main(){return(0);}\n' + + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# Allow CC to be a program name with arguments. +compiler=$CC + + +# save warnings/boilerplate of simple test code +ac_outfile=conftest.$ac_objext +printf "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$rm conftest* + +ac_outfile=conftest.$ac_objext +printf "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$rm conftest* + + +# +# Check for any special shared library compilation flags. +# +lt_prog_cc_shlib= +if test "$GCC" = no; then + case $host_os in + sco3.2v5*) + lt_prog_cc_shlib='-belf' + ;; + esac +fi +if test -n "$lt_prog_cc_shlib"; then + { echo "$as_me:$LINENO: WARNING: \`$CC' requires \`$lt_prog_cc_shlib' to build shared libraries" >&5 +echo "$as_me: WARNING: \`$CC' requires \`$lt_prog_cc_shlib' to build shared libraries" >&2;} + if echo "$old_CC $old_CFLAGS " | grep "[ ]$lt_prog_cc_shlib[ ]" >/dev/null; then : + else + { echo "$as_me:$LINENO: WARNING: add \`$lt_prog_cc_shlib' to the CC or CFLAGS env variable and reconfigure" >&5 +echo "$as_me: WARNING: add \`$lt_prog_cc_shlib' to the CC or CFLAGS env variable and reconfigure" >&2;} + lt_cv_prog_cc_can_build_shared=no + fi +fi + + +# +# Check to make sure the static flag actually works. +# +echo "$as_me:$LINENO: checking if $compiler static flag $lt_prog_compiler_static works" >&5 +echo $ECHO_N "checking if $compiler static flag $lt_prog_compiler_static works... $ECHO_C" >&6 +if test "${lt_prog_compiler_static_works+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_prog_compiler_static_works=no + save_LDFLAGS="$LDFLAGS" + LDFLAGS="$LDFLAGS $lt_prog_compiler_static" + printf "$lt_simple_link_test_code" > conftest.$ac_ext + if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then + # The linker can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + # Append any errors to the config.log. + cat conftest.err 1>&5 + $echo "X$_lt_linker_boilerplate" | $Xsed > conftest.exp + $SED '/^$/d' conftest.err >conftest.er2 + if diff conftest.exp conftest.er2 >/dev/null; then + lt_prog_compiler_static_works=yes + fi + else + lt_prog_compiler_static_works=yes + fi + fi + $rm conftest* + LDFLAGS="$save_LDFLAGS" + +fi +echo "$as_me:$LINENO: result: $lt_prog_compiler_static_works" >&5 +echo "${ECHO_T}$lt_prog_compiler_static_works" >&6 + +if test x"$lt_prog_compiler_static_works" = xyes; then + : +else + lt_prog_compiler_static= +fi + + + + +lt_prog_compiler_no_builtin_flag= + +if test "$GCC" = yes; then + lt_prog_compiler_no_builtin_flag=' -fno-builtin' + + +echo "$as_me:$LINENO: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 +echo $ECHO_N "checking if $compiler supports -fno-rtti -fno-exceptions... $ECHO_C" >&6 +if test "${lt_cv_prog_compiler_rtti_exceptions+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_cv_prog_compiler_rtti_exceptions=no + ac_outfile=conftest.$ac_objext + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="-fno-rtti -fno-exceptions" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:6407: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:6411: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $echo "X$_lt_compiler_boilerplate" | $Xsed >conftest.exp + $SED '/^$/d' conftest.err >conftest.er2 + if test ! -s conftest.err || diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_rtti_exceptions=yes + fi + fi + $rm conftest* + +fi +echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_rtti_exceptions" >&5 +echo "${ECHO_T}$lt_cv_prog_compiler_rtti_exceptions" >&6 + +if test x"$lt_cv_prog_compiler_rtti_exceptions" = xyes; then + lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions" +else + : +fi + +fi + +lt_prog_compiler_wl= +lt_prog_compiler_pic= +lt_prog_compiler_static= + +echo "$as_me:$LINENO: checking for $compiler option to produce PIC" >&5 +echo $ECHO_N "checking for $compiler option to produce PIC... $ECHO_C" >&6 + + if test "$GCC" = yes; then + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_static='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static='-Bstatic' + fi + ;; + + amigaos*) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4' + ;; + + beos* | cygwin* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + + mingw* | pw32* | os2*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + lt_prog_compiler_pic='-DDLL_EXPORT' + ;; + + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + lt_prog_compiler_pic='-fno-common' + ;; + + msdosdjgpp*) + # Just because we use GCC doesn't mean we suddenly get shared libraries + # on systems that don't support them. + lt_prog_compiler_can_build_shared=no + enable_shared=no + ;; + + sysv4*MP*) + if test -d /usr/nec; then + lt_prog_compiler_pic=-Kconform_pic + fi + ;; + + hpux*) + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic='-fPIC' + ;; + esac + ;; + + *) + lt_prog_compiler_pic='-fPIC' + ;; + esac + else + # PORTME Check for flag to pass linker flags through the system compiler. + case $host_os in + aix*) + lt_prog_compiler_wl='-Wl,' + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static='-Bstatic' + else + lt_prog_compiler_static='-bnso -bI:/lib/syscalls.exp' + fi + ;; + darwin*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + case $cc_basename in + xlc*) + lt_prog_compiler_pic='-qnocommon' + lt_prog_compiler_wl='-Wl,' + ;; + esac + ;; + + mingw* | pw32* | os2*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + lt_prog_compiler_pic='-DDLL_EXPORT' + ;; + + hpux9* | hpux10* | hpux11*) + lt_prog_compiler_wl='-Wl,' + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic='+Z' + ;; + esac + # Is there a better lt_prog_compiler_static that works with the bundled CC? + lt_prog_compiler_static='${wl}-a ${wl}archive' + ;; + + irix5* | irix6* | nonstopux*) + lt_prog_compiler_wl='-Wl,' + # PIC (with -KPIC) is the default. + lt_prog_compiler_static='-non_shared' + ;; + + newsos6) + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + ;; + + linux*) + case $cc_basename in + icc* | ecc*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-static' + ;; + pgcc* | pgf77* | pgf90* | pgf95*) + # Portland Group compilers (*not* the Pentium gcc compiler, + # which looks to be a dead project) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-fpic' + lt_prog_compiler_static='-Bstatic' + ;; + ccc*) + lt_prog_compiler_wl='-Wl,' + # All Alpha code is PIC. + lt_prog_compiler_static='-non_shared' + ;; + esac + ;; + + osf3* | osf4* | osf5*) + lt_prog_compiler_wl='-Wl,' + # All OSF/1 code is PIC. + lt_prog_compiler_static='-non_shared' + ;; + + sco3.2v5*) + lt_prog_compiler_pic='-Kpic' + lt_prog_compiler_static='-dn' + ;; + + solaris*) + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + case $cc_basename in + f77* | f90* | f95*) + lt_prog_compiler_wl='-Qoption ld ';; + *) + lt_prog_compiler_wl='-Wl,';; + esac + ;; + + sunos4*) + lt_prog_compiler_wl='-Qoption ld ' + lt_prog_compiler_pic='-PIC' + lt_prog_compiler_static='-Bstatic' + ;; + + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + ;; + + sysv4*MP*) + if test -d /usr/nec ;then + lt_prog_compiler_pic='-Kconform_pic' + lt_prog_compiler_static='-Bstatic' + fi + ;; + + unicos*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_can_build_shared=no + ;; + + uts4*) + lt_prog_compiler_pic='-pic' + lt_prog_compiler_static='-Bstatic' + ;; + + *) + lt_prog_compiler_can_build_shared=no + ;; + esac + fi + +echo "$as_me:$LINENO: result: $lt_prog_compiler_pic" >&5 +echo "${ECHO_T}$lt_prog_compiler_pic" >&6 + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$lt_prog_compiler_pic"; then + +echo "$as_me:$LINENO: checking if $compiler PIC flag $lt_prog_compiler_pic works" >&5 +echo $ECHO_N "checking if $compiler PIC flag $lt_prog_compiler_pic works... $ECHO_C" >&6 +if test "${lt_prog_compiler_pic_works+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_prog_compiler_pic_works=no + ac_outfile=conftest.$ac_objext + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$lt_prog_compiler_pic -DPIC" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:6669: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:6673: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $echo "X$_lt_compiler_boilerplate" | $Xsed >conftest.exp + $SED '/^$/d' conftest.err >conftest.er2 + if test ! -s conftest.err || diff conftest.exp conftest.er2 >/dev/null; then + lt_prog_compiler_pic_works=yes + fi + fi + $rm conftest* + +fi +echo "$as_me:$LINENO: result: $lt_prog_compiler_pic_works" >&5 +echo "${ECHO_T}$lt_prog_compiler_pic_works" >&6 + +if test x"$lt_prog_compiler_pic_works" = xyes; then + case $lt_prog_compiler_pic in + "" | " "*) ;; + *) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;; + esac +else + lt_prog_compiler_pic= + lt_prog_compiler_can_build_shared=no +fi + +fi +case $host_os in + # For platforms which do not support PIC, -DPIC is meaningless: + *djgpp*) + lt_prog_compiler_pic= + ;; + *) + lt_prog_compiler_pic="$lt_prog_compiler_pic -DPIC" + ;; +esac + +echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 +echo $ECHO_N "checking if $compiler supports -c -o file.$ac_objext... $ECHO_C" >&6 +if test "${lt_cv_prog_compiler_c_o+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_cv_prog_compiler_c_o=no + $rm -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:6731: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:6735: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $echo "X$_lt_compiler_boilerplate" | $Xsed > out/conftest.exp + $SED '/^$/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.err || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o=yes + fi + fi + chmod u+w . 2>&5 + $rm conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $rm out/ii_files/* && rmdir out/ii_files + $rm out/* && rmdir out + cd .. + rmdir conftest + $rm conftest* + +fi +echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o" >&5 +echo "${ECHO_T}$lt_cv_prog_compiler_c_o" >&6 + + +hard_links="nottested" +if test "$lt_cv_prog_compiler_c_o" = no && test "$need_locks" != no; then + # do not overwrite the value of need_locks provided by the user + echo "$as_me:$LINENO: checking if we can lock with hard links" >&5 +echo $ECHO_N "checking if we can lock with hard links... $ECHO_C" >&6 + hard_links=yes + $rm conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + echo "$as_me:$LINENO: result: $hard_links" >&5 +echo "${ECHO_T}$hard_links" >&6 + if test "$hard_links" = no; then + { echo "$as_me:$LINENO: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 +echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} + need_locks=warn + fi +else + need_locks=no +fi + +echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 +echo $ECHO_N "checking whether the $compiler linker ($LD) supports shared libraries... $ECHO_C" >&6 + + runpath_var= + allow_undefined_flag= + enable_shared_with_static_runtimes=no + archive_cmds= + archive_expsym_cmds= + old_archive_From_new_cmds= + old_archive_from_expsyms_cmds= + export_dynamic_flag_spec= + whole_archive_flag_spec= + thread_safe_flag_spec= + hardcode_libdir_flag_spec= + hardcode_libdir_flag_spec_ld= + hardcode_libdir_separator= + hardcode_direct=no + hardcode_minus_L=no + hardcode_shlibpath_var=unsupported + link_all_deplibs=unknown + hardcode_automatic=no + module_cmds= + module_expsym_cmds= + always_export_symbols=no + export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + # include_expsyms should be a list of space-separated symbols to be *always* + # included in the symbol list + include_expsyms= + # exclude_expsyms can be an extended regexp of symbols to exclude + # it will be wrapped by ` (' and `)$', so one must not match beginning or + # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', + # as well as any symbol that contains `d'. + exclude_expsyms="_GLOBAL_OFFSET_TABLE_" + # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out + # platforms (ab)use it in PIC code, but their linkers get confused if + # the symbol is explicitly referenced. Since portable code cannot + # rely on this symbol name, it's probably fine to never include it in + # preloaded symbol tables. + extract_expsyms_cmds= + # Just being paranoid about ensuring that cc_basename is set. + for cc_temp in $compiler""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` + + case $host_os in + cygwin* | mingw* | pw32*) + # FIXME: the MSVC++ port hasn't been tested in a loooong time + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + if test "$GCC" != yes; then + with_gnu_ld=no + fi + ;; + openbsd*) + with_gnu_ld=no + ;; + esac + + ld_shlibs=yes + if test "$with_gnu_ld" = yes; then + # If archive_cmds runs LD, not CC, wlarc should be empty + wlarc='${wl}' + + # Set some defaults for GNU ld with shared library support. These + # are reset later if shared libraries are not supported. Putting them + # here allows them to be overridden if necessary. + runpath_var=LD_RUN_PATH + hardcode_libdir_flag_spec='${wl}--rpath ${wl}$libdir' + export_dynamic_flag_spec='${wl}--export-dynamic' + # ancient GNU ld didn't support --whole-archive et. al. + if $LD --help 2>&1 | grep 'no-whole-archive' > /dev/null; then + whole_archive_flag_spec="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + whole_archive_flag_spec= + fi + supports_anon_versioning=no + case `$LD -v 2>/dev/null` in + *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11 + *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... + *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... + *\ 2.11.*) ;; # other 2.11 versions + *) supports_anon_versioning=yes ;; + esac + + # See if GNU ld supports shared libraries. + case $host_os in + aix3* | aix4* | aix5*) + # On AIX/PPC, the GNU linker is very broken + if test "$host_cpu" != ia64; then + ld_shlibs=no + cat <&2 + +*** Warning: the GNU linker, at least up to release 2.9.1, is reported +*** to be unable to reliably create shared libraries on AIX. +*** Therefore, libtool is disabling shared libraries support. If you +*** really care for shared libraries, you may want to modify your PATH +*** so that a non-GNU linker is found, and then restart. + +EOF + fi + ;; + + amigaos*) + archive_cmds='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + + # Samuel A. Falvo II reports + # that the semantics of dynamic libraries on AmigaOS, at least up + # to version 4, is to share data among multiple programs linked + # with the same dynamic library. Since this doesn't match the + # behavior of shared libraries on other platforms, we can't use + # them. + ld_shlibs=no + ;; + + beos*) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + allow_undefined_flag=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + else + ld_shlibs=no + fi + ;; + + cygwin* | mingw* | pw32*) + # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless, + # as there is no search path for DLLs. + hardcode_libdir_flag_spec='-L$libdir' + allow_undefined_flag=unsupported + always_export_symbols=no + enable_shared_with_static_runtimes=yes + export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS] /s/.* \([^ ]*\)/\1 DATA/'\'' | $SED -e '\''/^[AITW] /s/.* //'\'' | sort | uniq > $export_symbols' + + if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + archive_expsym_cmds='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + else + ld_shlibs=no + fi + ;; + + linux*) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + tmp_addflag= + case $cc_basename,$host_cpu in + pgcc*) # Portland Group C compiler + whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag' + ;; + pgf77* | pgf90* | pgf95*) # Portland Group f77 and f90 compilers + whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag -Mnomain' ;; + ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 + tmp_addflag=' -i_dynamic' ;; + efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 + tmp_addflag=' -i_dynamic -nofor_main' ;; + ifc* | ifort*) # Intel Fortran compiler + tmp_addflag=' -nofor_main' ;; + esac + archive_cmds='$CC -shared'"$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + + if test $supports_anon_versioning = yes; then + archive_expsym_cmds='$echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + $echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC -shared'"$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' + fi + link_all_deplibs=no + else + ld_shlibs=no + fi + ;; + + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' + wlarc= + else + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + fi + ;; + + solaris* | sysv5*) + if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then + ld_shlibs=no + cat <&2 + +*** Warning: The releases 2.8.* of the GNU linker cannot reliably +*** create shared libraries on Solaris systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.9.1 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +EOF + elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs=no + fi + ;; + + sunos4*) + archive_cmds='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' + wlarc= + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + *) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs=no + fi + ;; + esac + + if test "$ld_shlibs" = no; then + runpath_var= + hardcode_libdir_flag_spec= + export_dynamic_flag_spec= + whole_archive_flag_spec= + fi + else + # PORTME fill in a description of your system's linker (not GNU ld) + case $host_os in + aix3*) + allow_undefined_flag=unsupported + always_export_symbols=yes + archive_expsym_cmds='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' + # Note: this linker hardcodes the directories in LIBPATH if there + # are no directories specified by -L. + hardcode_minus_L=yes + if test "$GCC" = yes && test -z "$link_static_flag"; then + # Neither direct hardcoding nor static linking is supported with a + # broken collect2. + hardcode_direct=unsupported + fi + ;; + + aix4* | aix5*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | grep 'GNU' > /dev/null; then + export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' + else + export_symbols_cmds='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' + fi + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # need to do runtime linking. + case $host_os in aix4.[23]|aix4.[23].*|aix5*) + for ld_flag in $LDFLAGS; do + if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then + aix_use_runtimelinking=yes + break + fi + done + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + archive_cmds='' + hardcode_direct=yes + hardcode_libdir_separator=':' + link_all_deplibs=yes + + if test "$GCC" = yes; then + case $host_os in aix4.[012]|aix4.[012].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && \ + strings "$collect2name" | grep resolve_lib_name >/dev/null + then + # We have reworked collect2 + hardcode_direct=yes + else + # We have old collect2 + hardcode_direct=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + hardcode_minus_L=yes + hardcode_libdir_flag_spec='-L$libdir' + hardcode_libdir_separator= + fi + esac + shared_flag='-shared' + if test "$aix_use_runtimelinking" = yes; then + shared_flag="$shared_flag "'${wl}-G' + fi + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='${wl}-G' + else + shared_flag='${wl}-bM:SRE' + fi + fi + fi + + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to export. + always_export_symbols=yes + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + allow_undefined_flag='-berok' + # Determine the default libpath from the value encoded in an empty executable. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'`; fi +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" + archive_expsym_cmds="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib' + allow_undefined_flag="-z nodefs" + archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an empty executable. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'`; fi +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + no_undefined_flag=' ${wl}-bernotok' + allow_undefined_flag=' ${wl}-berok' + # -bexpall does not export symbols beginning with underscore (_) + always_export_symbols=yes + # Exported symbols can be pulled into shared objects from archives + whole_archive_flag_spec=' ' + archive_cmds_need_lc=yes + # This is similar to how AIX traditionally builds its shared libraries. + archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}-bE:$export_symbols ${wl}-bnoentry${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + + amigaos*) + archive_cmds='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + # see comment about different semantics on the GNU ld section + ld_shlibs=no + ;; + + bsdi[45]*) + export_dynamic_flag_spec=-rdynamic + ;; + + cygwin* | mingw* | pw32*) + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + hardcode_libdir_flag_spec=' ' + allow_undefined_flag=unsupported + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=".dll" + # FIXME: Setting linknames here is a bad hack. + archive_cmds='$CC -o $lib $libobjs $compiler_flags `echo "$deplibs" | $SED -e '\''s/ -lc$//'\''` -link -dll~linknames=' + # The linker will automatically build a .lib file if we build a DLL. + old_archive_From_new_cmds='true' + # FIXME: Should let the user specify the lib program. + old_archive_cmds='lib /OUT:$oldlib$oldobjs$old_deplibs' + fix_srcfile_path='`cygpath -w "$srcfile"`' + enable_shared_with_static_runtimes=yes + ;; + + darwin* | rhapsody*) + case $host_os in + rhapsody* | darwin1.[012]) + allow_undefined_flag='${wl}-undefined ${wl}suppress' + ;; + *) # Darwin 1.3 on + if test -z ${MACOSX_DEPLOYMENT_TARGET} ; then + allow_undefined_flag='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + else + case ${MACOSX_DEPLOYMENT_TARGET} in + 10.[012]) + allow_undefined_flag='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + ;; + 10.*) + allow_undefined_flag='${wl}-undefined ${wl}dynamic_lookup' + ;; + esac + fi + ;; + esac + archive_cmds_need_lc=no + hardcode_direct=no + hardcode_automatic=yes + hardcode_shlibpath_var=unsupported + whole_archive_flag_spec='' + link_all_deplibs=yes + if test "$GCC" = yes ; then + output_verbose_link_cmd='echo' + archive_cmds='$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + module_cmds='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + archive_expsym_cmds='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + module_expsym_cmds='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + else + case $cc_basename in + xlc*) + output_verbose_link_cmd='echo' + archive_cmds='$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $verstring' + module_cmds='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + archive_expsym_cmds='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + module_expsym_cmds='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + ;; + *) + ld_shlibs=no + ;; + esac + fi + ;; + + dgux*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_shlibpath_var=no + ;; + + freebsd1*) + ld_shlibs=no + ;; + + # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor + # support. Future versions do this automatically, but an explicit c++rt0.o + # does not break anything, and helps significantly (at the cost of a little + # extra space). + freebsd2.2*) + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + # Unfortunately, older versions of FreeBSD 2 do not have this feature. + freebsd2*) + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=yes + hardcode_minus_L=yes + hardcode_shlibpath_var=no + ;; + + # FreeBSD 3 and greater uses gcc -shared to do shared libraries. + freebsd* | kfreebsd*-gnu | dragonfly*) + archive_cmds='$CC -shared -o $lib $libobjs $deplibs $compiler_flags' + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + hpux9*) + if test "$GCC" = yes; then + archive_cmds='$rm $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + archive_cmds='$rm $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + fi + hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' + hardcode_libdir_separator=: + hardcode_direct=yes + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L=yes + export_dynamic_flag_spec='${wl}-E' + ;; + + hpux10* | hpux11*) + if test "$GCC" = yes -a "$with_gnu_ld" = no; then + case $host_cpu in + hppa*64*|ia64*) + archive_cmds='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + archive_cmds='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + else + case $host_cpu in + hppa*64*|ia64*) + archive_cmds='$LD -b +h $soname -o $lib $libobjs $deplibs $linker_flags' + ;; + *) + archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' + ;; + esac + fi + if test "$with_gnu_ld" = no; then + case $host_cpu in + hppa*64*) + hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' + hardcode_libdir_flag_spec_ld='+b $libdir' + hardcode_libdir_separator=: + hardcode_direct=no + hardcode_shlibpath_var=no + ;; + ia64*) + hardcode_libdir_flag_spec='-L$libdir' + hardcode_direct=no + hardcode_shlibpath_var=no + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L=yes + ;; + *) + hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' + hardcode_libdir_separator=: + hardcode_direct=yes + export_dynamic_flag_spec='${wl}-E' + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L=yes + ;; + esac + fi + ;; + + irix5* | irix6* | nonstopux*) + if test "$GCC" = yes; then + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + archive_cmds='$LD -shared $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + hardcode_libdir_flag_spec_ld='-rpath $libdir' + fi + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + link_all_deplibs=yes + ;; + + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out + else + archive_cmds='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF + fi + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + newsos6) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=yes + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + hardcode_shlibpath_var=no + ;; + + openbsd*) + hardcode_direct=yes + hardcode_shlibpath_var=no + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' + hardcode_libdir_flag_spec='${wl}-rpath,$libdir' + export_dynamic_flag_spec='${wl}-E' + else + case $host_os in + openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*) + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec='-R$libdir' + ;; + *) + archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + hardcode_libdir_flag_spec='${wl}-rpath,$libdir' + ;; + esac + fi + ;; + + os2*) + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + allow_undefined_flag=unsupported + archive_cmds='$echo "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$echo "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$echo DATA >> $output_objdir/$libname.def~$echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~$echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' + old_archive_From_new_cmds='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' + ;; + + osf3*) + if test "$GCC" = yes; then + allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + allow_undefined_flag=' -expect_unresolved \*' + archive_cmds='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + fi + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + ;; + + osf4* | osf5*) # as osf3* with the addition of -msym flag + if test "$GCC" = yes; then + allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + else + allow_undefined_flag=' -expect_unresolved \*' + archive_cmds='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + archive_expsym_cmds='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; echo "-hidden">> $lib.exp~ + $LD -shared${allow_undefined_flag} -input $lib.exp $linker_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib~$rm $lib.exp' + + # Both c and cxx compiler support -rpath directly + hardcode_libdir_flag_spec='-rpath $libdir' + fi + hardcode_libdir_separator=: + ;; + + sco3.2v5*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var=no + export_dynamic_flag_spec='${wl}-Bexport' + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ;; + + solaris*) + no_undefined_flag=' -z text' + if test "$GCC" = yes; then + wlarc='${wl}' + archive_cmds='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -shared ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$rm $lib.exp' + else + wlarc='' + archive_cmds='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + archive_expsym_cmds='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' + fi + hardcode_libdir_flag_spec='-R$libdir' + hardcode_shlibpath_var=no + case $host_os in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) + # The compiler driver will combine linker options so we + # cannot just pass the convience library names through + # without $wl, iff we do not link with $LD. + # Luckily, gcc supports the same syntax we need for Sun Studio. + # Supported since Solaris 2.6 (maybe 2.5.1?) + case $wlarc in + '') + whole_archive_flag_spec='-z allextract$convenience -z defaultextract' ;; + *) + whole_archive_flag_spec='${wl}-z ${wl}allextract`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}-z ${wl}defaultextract' ;; + esac ;; + esac + link_all_deplibs=yes + ;; + + sunos4*) + if test "x$host_vendor" = xsequent; then + # Use $CC to link under sequent, because it throws in some extra .o + # files that make .init and .fini sections work. + archive_cmds='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' + fi + hardcode_libdir_flag_spec='-L$libdir' + hardcode_direct=yes + hardcode_minus_L=yes + hardcode_shlibpath_var=no + ;; + + sysv4) + case $host_vendor in + sni) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=yes # is this really true??? + ;; + siemens) + ## LD is ld it makes a PLAMLIB + ## CC just makes a GrossModule. + archive_cmds='$LD -G -o $lib $libobjs $deplibs $linker_flags' + reload_cmds='$CC -r -o $output$reload_objs' + hardcode_direct=no + ;; + motorola) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=no #Motorola manual says yes, but my tests say they lie + ;; + esac + runpath_var='LD_RUN_PATH' + hardcode_shlibpath_var=no + ;; + + sysv4.3*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var=no + export_dynamic_flag_spec='-Bexport' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var=no + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ld_shlibs=yes + fi + ;; + + sysv4.2uw2*) + archive_cmds='$LD -G -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=yes + hardcode_minus_L=no + hardcode_shlibpath_var=no + hardcode_runpath_var=yes + runpath_var=LD_RUN_PATH + ;; + + sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[78]* | unixware7*) + no_undefined_flag='${wl}-z ${wl}text' + if test "$GCC" = yes; then + archive_cmds='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds='$CC -G ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + runpath_var='LD_RUN_PATH' + hardcode_shlibpath_var=no + ;; + + sysv5*) + no_undefined_flag=' -z text' + # $CC -shared without GNU ld will not create a library from C++ + # object files and a static libstdc++, better avoid it by now + archive_cmds='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + archive_expsym_cmds='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' + hardcode_libdir_flag_spec= + hardcode_shlibpath_var=no + runpath_var='LD_RUN_PATH' + ;; + + uts4*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_shlibpath_var=no + ;; + + *) + ld_shlibs=no + ;; + esac + fi + +echo "$as_me:$LINENO: result: $ld_shlibs" >&5 +echo "${ECHO_T}$ld_shlibs" >&6 +test "$ld_shlibs" = no && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test "$GCC" = yes; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +# +# Do we need to explicitly link libc? +# +case "x$archive_cmds_need_lc" in +x|xyes) + # Assume -lc should be added + archive_cmds_need_lc=yes + + if test "$enable_shared" = yes && test "$GCC" = yes; then + case $archive_cmds in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + echo "$as_me:$LINENO: checking whether -lc should be explicitly linked in" >&5 +echo $ECHO_N "checking whether -lc should be explicitly linked in... $ECHO_C" >&6 + $rm conftest* + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$lt_prog_compiler_wl + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$allow_undefined_flag + allow_undefined_flag= + if { (eval echo "$as_me:$LINENO: \"$archive_cmds 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1\"") >&5 + (eval $archive_cmds 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + then + archive_cmds_need_lc=no + else + archive_cmds_need_lc=yes + fi + allow_undefined_flag=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $rm conftest* + echo "$as_me:$LINENO: result: $archive_cmds_need_lc" >&5 +echo "${ECHO_T}$archive_cmds_need_lc" >&6 + ;; + esac + fi + ;; +esac + +echo "$as_me:$LINENO: checking dynamic linker characteristics" >&5 +echo $ECHO_N "checking dynamic linker characteristics... $ECHO_C" >&6 +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext_cmds=".so" +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +if test "$GCC" = yes; then + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if echo "$sys_lib_search_path_spec" | grep ';' >/dev/null ; then + # if the path contains ";" then we assume it to be the separator + # otherwise default to the standard path separator (i.e. ":") - it is + # assumed that no part of a normal pathname contains ";" but that should + # okay in the real world where ";" in dirpaths is itself problematic. + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi +else + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +fi +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + +case $host_os in +aix3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='${libname}${release}${shared_ext}$major' + ;; + +aix4* | aix5*) + version_type=linux + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test "$host_cpu" = ia64; then + # AIX 5 supports IA64 + library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line `#! .'. This would cause the generated library to + # depend on `.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[01] | aix4.[01].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | ${CC} -E - | grep yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # AIX (on Power*) has no versioning support, so currently we can not hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + if test "$aix_use_runtimelinking" = yes; then + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + else + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='${libname}${release}.a $libname.a' + soname_spec='${libname}${release}${shared_ext}$major' + fi + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$echo "X$lib" | $Xsed -e '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $rm /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' + ;; + +beos*) + library_names_spec='${libname}${shared_ext}' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi[45]*) + version_type=linux + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32*) + version_type=windows + shrext_cmds=".dll" + need_version=no + need_lib_prefix=no + + case $GCC,$host_os in + yes,cygwin* | yes,mingw* | yes,pw32*) + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \${file}`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $rm \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" + ;; + mingw*) + # MinGW DLLs use traditional 'lib' prefix + soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if echo "$sys_lib_search_path_spec" | grep ';[c-zC-Z]:/' >/dev/null; then + # It is most probably a Windows format PATH printed by + # mingw gcc, but we are running on Cygwin. Gcc prints its search + # path with ; separators, and with drive letters. We can handle the + # drive letters (cygwin fileutils understands them), so leave them, + # especially as we might pass files found there to a mingw objdump, + # which wouldn't understand a cygwinified path. Ahh. + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + ;; + esac + ;; + + *) + library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib' + ;; + esac + dynamic_linker='Win32 ld.exe' + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext' + soname_spec='${libname}${release}${major}$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' + # Apple's gcc prints 'gcc -print-search-dirs' doesn't operate the same. + if test "$GCC" = yes; then + sys_lib_search_path_spec=`$CC -print-search-dirs | tr "\n" "$PATH_SEPARATOR" | sed -e 's/libraries:/@libraries:/' | tr "@" "\n" | grep "^libraries:" | sed -e "s/^libraries://" -e "s,=/,/,g" -e "s,$PATH_SEPARATOR, ,g" -e "s,.*,& /lib /usr/lib /usr/local/lib,g"` + else + sys_lib_search_path_spec='/lib /usr/lib /usr/local/lib' + fi + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd1*) + dynamic_linker=no + ;; + +kfreebsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='GNU ld.so' + ;; + +freebsd* | dragonfly*) + # DragonFly does not have aout. When/if they implement a new + # versioning mechanism, adjust this. + if test -x /usr/bin/objformat; then + objformat=`/usr/bin/objformat` + else + case $host_os in + freebsd[123]*) objformat=aout ;; + *) objformat=elf ;; + esac + fi + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[01]* | freebsdelf3.[01]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + *) # from 3.2 on + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + esac + ;; + +gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case $host_cpu in + ia64*) + shrext_cmds='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + if test "X$HPUX_IA64_MODE" = X32; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + fi + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + hppa*64*) + shrext_cmds='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext_cmds='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555. + postinstall_cmds='chmod 555 $lib' + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test "$lt_cv_prog_gnu_ld" = yes; then + version_type=linux + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" + sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +# This must be Linux ELF. +linux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # Append ld.so.conf contents to the search path + if test -f /etc/ld.so.conf; then + lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;/^$/d' | tr '\n' ' '` + sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" + fi + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsdelf*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='NetBSD ld.elf_so' + ;; + +knetbsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='GNU ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +nto-qnx*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +openbsd*) + version_type=sunos + need_lib_prefix=no + # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. + case $host_os in + openbsd3.3 | openbsd3.3.*) need_version=yes ;; + *) need_version=no ;; + esac + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + case $host_os in + openbsd2.[89] | openbsd2.[89].*) + shlibpath_overrides_runpath=no + ;; + *) + shlibpath_overrides_runpath=yes + ;; + esac + else + shlibpath_overrides_runpath=yes + fi + ;; + +os2*) + libname_spec='$name' + shrext_cmds=".dll" + need_lib_prefix=no + library_names_spec='$libname${shared_ext} $libname.a' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=LIBPATH + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" + ;; + +sco3.2v5*) + version_type=osf + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + ;; + +solaris*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test "$with_gnu_ld" = yes; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + export_dynamic_flag_spec='${wl}-Blargedynsym' + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec ;then + version_type=linux + library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' + soname_spec='$libname${shared_ext}.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +uts4*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +echo "$as_me:$LINENO: result: $dynamic_linker" >&5 +echo "${ECHO_T}$dynamic_linker" >&6 +test "$dynamic_linker" = no && can_build_shared=no + +echo "$as_me:$LINENO: checking how to hardcode library paths into programs" >&5 +echo $ECHO_N "checking how to hardcode library paths into programs... $ECHO_C" >&6 +hardcode_action= +if test -n "$hardcode_libdir_flag_spec" || \ + test -n "$runpath_var" || \ + test "X$hardcode_automatic" = "Xyes" ; then + + # We can hardcode non-existant directories. + if test "$hardcode_direct" != no && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, )" != no && + test "$hardcode_minus_L" != no; then + # Linking always hardcodes the temporary library directory. + hardcode_action=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + hardcode_action=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + hardcode_action=unsupported +fi +echo "$as_me:$LINENO: result: $hardcode_action" >&5 +echo "${ECHO_T}$hardcode_action" >&6 + +if test "$hardcode_action" = relink; then + # Fast installation is not supported + enable_fast_install=no +elif test "$shlibpath_overrides_runpath" = yes || + test "$enable_shared" = no; then + # Fast installation is not necessary + enable_fast_install=needless +fi + +striplib= +old_striplib= +echo "$as_me:$LINENO: checking whether stripping libraries is possible" >&5 +echo $ECHO_N "checking whether stripping libraries is possible... $ECHO_C" >&6 +if test -n "$STRIP" && $STRIP -V 2>&1 | grep "GNU strip" >/dev/null; then + test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" + test -z "$striplib" && striplib="$STRIP --strip-unneeded" + echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 +else +# FIXME - insert some real tests, host_os isn't really good enough + case $host_os in + darwin*) + if test -n "$STRIP" ; then + striplib="$STRIP -x" + echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 + else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + ;; + *) + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 + ;; + esac +fi + +if test "x$enable_dlopen" != xyes; then + enable_dlopen=unknown + enable_dlopen_self=unknown + enable_dlopen_self_static=unknown +else + lt_cv_dlopen=no + lt_cv_dlopen_libs= + + case $host_os in + beos*) + lt_cv_dlopen="load_add_on" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ;; + + mingw* | pw32*) + lt_cv_dlopen="LoadLibrary" + lt_cv_dlopen_libs= + ;; + + cygwin*) + lt_cv_dlopen="dlopen" + lt_cv_dlopen_libs= + ;; + + darwin*) + # if libdl is installed we need to link against it + echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5 +echo $ECHO_N "checking for dlopen in -ldl... $ECHO_C" >&6 +if test "${ac_cv_lib_dl_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldl $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +int +main () +{ +dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dl_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dl_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5 +echo "${ECHO_T}$ac_cv_lib_dl_dlopen" >&6 +if test $ac_cv_lib_dl_dlopen = yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" +else + + lt_cv_dlopen="dyld" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + +fi + + ;; + + *) + echo "$as_me:$LINENO: checking for shl_load" >&5 +echo $ECHO_N "checking for shl_load... $ECHO_C" >&6 +if test "${ac_cv_func_shl_load+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define shl_load to an innocuous variant, in case declares shl_load. + For example, HP-UX 11i declares gettimeofday. */ +#define shl_load innocuous_shl_load + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char shl_load (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef shl_load + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +{ +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char shl_load (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_shl_load) || defined (__stub___shl_load) +choke me +#else +char (*f) () = shl_load; +#endif +#ifdef __cplusplus +} +#endif + +int +main () +{ +return f != shl_load; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_func_shl_load=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_func_shl_load=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_func_shl_load" >&5 +echo "${ECHO_T}$ac_cv_func_shl_load" >&6 +if test $ac_cv_func_shl_load = yes; then + lt_cv_dlopen="shl_load" +else + echo "$as_me:$LINENO: checking for shl_load in -ldld" >&5 +echo $ECHO_N "checking for shl_load in -ldld... $ECHO_C" >&6 +if test "${ac_cv_lib_dld_shl_load+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char shl_load (); +int +main () +{ +shl_load (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dld_shl_load=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dld_shl_load=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dld_shl_load" >&5 +echo "${ECHO_T}$ac_cv_lib_dld_shl_load" >&6 +if test $ac_cv_lib_dld_shl_load = yes; then + lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-dld" +else + echo "$as_me:$LINENO: checking for dlopen" >&5 +echo $ECHO_N "checking for dlopen... $ECHO_C" >&6 +if test "${ac_cv_func_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define dlopen to an innocuous variant, in case declares dlopen. + For example, HP-UX 11i declares gettimeofday. */ +#define dlopen innocuous_dlopen + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char dlopen (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef dlopen + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +{ +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_dlopen) || defined (__stub___dlopen) +choke me +#else +char (*f) () = dlopen; +#endif +#ifdef __cplusplus +} +#endif + +int +main () +{ +return f != dlopen; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_func_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_func_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_func_dlopen" >&5 +echo "${ECHO_T}$ac_cv_func_dlopen" >&6 +if test $ac_cv_func_dlopen = yes; then + lt_cv_dlopen="dlopen" +else + echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5 +echo $ECHO_N "checking for dlopen in -ldl... $ECHO_C" >&6 +if test "${ac_cv_lib_dl_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldl $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +int +main () +{ +dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dl_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dl_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5 +echo "${ECHO_T}$ac_cv_lib_dl_dlopen" >&6 +if test $ac_cv_lib_dl_dlopen = yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" +else + echo "$as_me:$LINENO: checking for dlopen in -lsvld" >&5 +echo $ECHO_N "checking for dlopen in -lsvld... $ECHO_C" >&6 +if test "${ac_cv_lib_svld_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lsvld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +int +main () +{ +dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_svld_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_svld_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_svld_dlopen" >&5 +echo "${ECHO_T}$ac_cv_lib_svld_dlopen" >&6 +if test $ac_cv_lib_svld_dlopen = yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld" +else + echo "$as_me:$LINENO: checking for dld_link in -ldld" >&5 +echo $ECHO_N "checking for dld_link in -ldld... $ECHO_C" >&6 +if test "${ac_cv_lib_dld_dld_link+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dld_link (); +int +main () +{ +dld_link (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dld_dld_link=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dld_dld_link=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dld_dld_link" >&5 +echo "${ECHO_T}$ac_cv_lib_dld_dld_link" >&6 +if test $ac_cv_lib_dld_dld_link = yes; then + lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-dld" +fi + + +fi + + +fi + + +fi + + +fi + + +fi + + ;; + esac + + if test "x$lt_cv_dlopen" != xno; then + enable_dlopen=yes + else + enable_dlopen=no + fi + + case $lt_cv_dlopen in + dlopen) + save_CPPFLAGS="$CPPFLAGS" + test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" + + save_LDFLAGS="$LDFLAGS" + eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" + + save_LIBS="$LIBS" + LIBS="$lt_cv_dlopen_libs $LIBS" + + echo "$as_me:$LINENO: checking whether a program can dlopen itself" >&5 +echo $ECHO_N "checking whether a program can dlopen itself... $ECHO_C" >&6 +if test "${lt_cv_dlopen_self+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$cross_compiling" = yes; then : + lt_cv_dlopen_self=cross +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext < +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +#ifdef __cplusplus +extern "C" void exit (int); +#endif + +void fnord() { int i=42;} +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + /* dlclose (self); */ + } + + exit (status); +} +EOF + if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then + (./conftest; exit; ) >&5 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;; + x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;; + x$lt_unknown|x*) lt_cv_dlopen_self=no ;; + esac + else : + # compilation failed + lt_cv_dlopen_self=no + fi +fi +rm -fr conftest* + + +fi +echo "$as_me:$LINENO: result: $lt_cv_dlopen_self" >&5 +echo "${ECHO_T}$lt_cv_dlopen_self" >&6 + + if test "x$lt_cv_dlopen_self" = xyes; then + LDFLAGS="$LDFLAGS $link_static_flag" + echo "$as_me:$LINENO: checking whether a statically linked program can dlopen itself" >&5 +echo $ECHO_N "checking whether a statically linked program can dlopen itself... $ECHO_C" >&6 +if test "${lt_cv_dlopen_self_static+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$cross_compiling" = yes; then : + lt_cv_dlopen_self_static=cross +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext < +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +#ifdef __cplusplus +extern "C" void exit (int); +#endif + +void fnord() { int i=42;} +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + /* dlclose (self); */ + } + + exit (status); +} +EOF + if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then + (./conftest; exit; ) >&5 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;; + x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;; + x$lt_unknown|x*) lt_cv_dlopen_self_static=no ;; + esac + else : + # compilation failed + lt_cv_dlopen_self_static=no + fi +fi +rm -fr conftest* + + +fi +echo "$as_me:$LINENO: result: $lt_cv_dlopen_self_static" >&5 +echo "${ECHO_T}$lt_cv_dlopen_self_static" >&6 + fi + + CPPFLAGS="$save_CPPFLAGS" + LDFLAGS="$save_LDFLAGS" + LIBS="$save_LIBS" + ;; + esac + + case $lt_cv_dlopen_self in + yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; + *) enable_dlopen_self=unknown ;; + esac + + case $lt_cv_dlopen_self_static in + yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; + *) enable_dlopen_self_static=unknown ;; + esac +fi + + +# Report which librarie types wil actually be built +echo "$as_me:$LINENO: checking if libtool supports shared libraries" >&5 +echo $ECHO_N "checking if libtool supports shared libraries... $ECHO_C" >&6 +echo "$as_me:$LINENO: result: $can_build_shared" >&5 +echo "${ECHO_T}$can_build_shared" >&6 + +echo "$as_me:$LINENO: checking whether to build shared libraries" >&5 +echo $ECHO_N "checking whether to build shared libraries... $ECHO_C" >&6 +test "$can_build_shared" = "no" && enable_shared=no + +# On AIX, shared libraries and static libraries use the same namespace, and +# are all built from PIC. +case $host_os in +aix3*) + test "$enable_shared" = yes && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + +aix4* | aix5*) + if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then + test "$enable_shared" = yes && enable_static=no + fi + ;; +esac +echo "$as_me:$LINENO: result: $enable_shared" >&5 +echo "${ECHO_T}$enable_shared" >&6 + +echo "$as_me:$LINENO: checking whether to build static libraries" >&5 +echo $ECHO_N "checking whether to build static libraries... $ECHO_C" >&6 +# Make sure either enable_shared or enable_static is yes. +test "$enable_shared" = yes || enable_static=yes +echo "$as_me:$LINENO: result: $enable_static" >&5 +echo "${ECHO_T}$enable_static" >&6 + +# The else clause should only fire when bootstrapping the +# libtool distribution, otherwise you forgot to ship ltmain.sh +# with your package, and you will get complaints that there are +# no rules to generate ltmain.sh. +if test -f "$ltmain"; then + # See if we are running on zsh, and set the options which allow our commands through + # without removal of \ escapes. + if test -n "${ZSH_VERSION+set}" ; then + setopt NO_GLOB_SUBST + fi + # Now quote all the things that may contain metacharacters while being + # careful not to overquote the AC_SUBSTed values. We take copies of the + # variables and quote the copies for generation of the libtool script. + for var in echo old_CC old_CFLAGS AR AR_FLAGS EGREP RANLIB LN_S LTCC NM \ + SED SHELL STRIP \ + libname_spec library_names_spec soname_spec extract_expsyms_cmds \ + old_striplib striplib file_magic_cmd finish_cmds finish_eval \ + deplibs_check_method reload_flag reload_cmds need_locks \ + lt_cv_sys_global_symbol_pipe lt_cv_sys_global_symbol_to_cdecl \ + lt_cv_sys_global_symbol_to_c_name_address \ + sys_lib_search_path_spec sys_lib_dlsearch_path_spec \ + old_postinstall_cmds old_postuninstall_cmds \ + compiler \ + CC \ + LD \ + lt_prog_compiler_wl \ + lt_prog_compiler_pic \ + lt_prog_compiler_static \ + lt_prog_compiler_no_builtin_flag \ + export_dynamic_flag_spec \ + thread_safe_flag_spec \ + whole_archive_flag_spec \ + enable_shared_with_static_runtimes \ + old_archive_cmds \ + old_archive_from_new_cmds \ + predep_objects \ + postdep_objects \ + predeps \ + postdeps \ + compiler_lib_search_path \ + archive_cmds \ + archive_expsym_cmds \ + postinstall_cmds \ + postuninstall_cmds \ + old_archive_from_expsyms_cmds \ + allow_undefined_flag \ + no_undefined_flag \ + export_symbols_cmds \ + hardcode_libdir_flag_spec \ + hardcode_libdir_flag_spec_ld \ + hardcode_libdir_separator \ + hardcode_automatic \ + module_cmds \ + module_expsym_cmds \ + lt_cv_prog_compiler_c_o \ + exclude_expsyms \ + include_expsyms; do + + case $var in + old_archive_cmds | \ + old_archive_from_new_cmds | \ + archive_cmds | \ + archive_expsym_cmds | \ + module_cmds | \ + module_expsym_cmds | \ + old_archive_from_expsyms_cmds | \ + export_symbols_cmds | \ + extract_expsyms_cmds | reload_cmds | finish_cmds | \ + postinstall_cmds | postuninstall_cmds | \ + old_postinstall_cmds | old_postuninstall_cmds | \ + sys_lib_search_path_spec | sys_lib_dlsearch_path_spec) + # Double-quote double-evaled strings. + eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\"" + ;; + *) + eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\"" + ;; + esac + done + + case $lt_echo in + *'\$0 --fallback-echo"') + lt_echo=`$echo "X$lt_echo" | $Xsed -e 's/\\\\\\\$0 --fallback-echo"$/$0 --fallback-echo"/'` + ;; + esac + +cfgfile="${ofile}T" + trap "$rm \"$cfgfile\"; exit 1" 1 2 15 + $rm -f "$cfgfile" + { echo "$as_me:$LINENO: creating $ofile" >&5 +echo "$as_me: creating $ofile" >&6;} + + cat <<__EOF__ >> "$cfgfile" +#! $SHELL + +# `$echo "$cfgfile" | sed 's%^.*/%%'` - Provide generalized library-building support services. +# Generated automatically by $PROGRAM (GNU $PACKAGE $VERSION$TIMESTAMP) +# NOTE: Changes made to this file will be lost: look at ltmain.sh. +# +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001 +# Free Software Foundation, Inc. +# +# This file is part of GNU Libtool: +# Originally by Gordon Matzigkeit , 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 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, 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. + +# A sed program that does not truncate output. +SED=$lt_SED + +# Sed that helps us avoid accidentally triggering echo(1) options like -n. +Xsed="$SED -e 1s/^X//" + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +# The names of the tagged configurations supported by this script. +available_tags= + +# ### BEGIN LIBTOOL CONFIG + +# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: + +# Shell to use when invoking shell scripts. +SHELL=$lt_SHELL + +# Whether or not to build shared libraries. +build_libtool_libs=$enable_shared + +# Whether or not to build static libraries. +build_old_libs=$enable_static + +# Whether or not to add -lc for building shared libraries. +build_libtool_need_lc=$archive_cmds_need_lc + +# Whether or not to disallow shared libs when runtime libs are static +allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes + +# Whether or not to optimize for fast installation. +fast_install=$enable_fast_install + +# The host system. +host_alias=$host_alias +host=$host +host_os=$host_os + +# The build system. +build_alias=$build_alias +build=$build +build_os=$build_os + +# An echo program that does not interpret backslashes. +echo=$lt_echo + +# The archiver. +AR=$lt_AR +AR_FLAGS=$lt_AR_FLAGS + +# A C compiler. +LTCC=$lt_LTCC + +# A language-specific compiler. +CC=$lt_compiler + +# Is the compiler the GNU C compiler? +with_gcc=$GCC + +# An ERE matcher. +EGREP=$lt_EGREP + +# The linker used to build libraries. +LD=$lt_LD + +# Whether we need hard or soft links. +LN_S=$lt_LN_S + +# A BSD-compatible nm program. +NM=$lt_NM + +# A symbol stripping program +STRIP=$lt_STRIP + +# Used to examine libraries when file_magic_cmd begins "file" +MAGIC_CMD=$MAGIC_CMD + +# Used on cygwin: DLL creation program. +DLLTOOL="$DLLTOOL" + +# Used on cygwin: object dumper. +OBJDUMP="$OBJDUMP" + +# Used on cygwin: assembler. +AS="$AS" + +# The name of the directory that contains temporary libtool files. +objdir=$objdir + +# How to create reloadable object files. +reload_flag=$lt_reload_flag +reload_cmds=$lt_reload_cmds + +# How to pass a linker flag through the compiler. +wl=$lt_lt_prog_compiler_wl + +# Object file suffix (normally "o"). +objext="$ac_objext" + +# Old archive suffix (normally "a"). +libext="$libext" + +# Shared library suffix (normally ".so"). +shrext_cmds='$shrext_cmds' + +# Executable file suffix (normally ""). +exeext="$exeext" + +# Additional compiler flags for building library objects. +pic_flag=$lt_lt_prog_compiler_pic +pic_mode=$pic_mode + +# What is the maximum length of a command? +max_cmd_len=$lt_cv_sys_max_cmd_len + +# Does compiler simultaneously support -c and -o options? +compiler_c_o=$lt_lt_cv_prog_compiler_c_o + +# Must we lock files when doing compilation? +need_locks=$lt_need_locks + +# Do we need the lib prefix for modules? +need_lib_prefix=$need_lib_prefix + +# Do we need a version for libraries? +need_version=$need_version + +# Whether dlopen is supported. +dlopen_support=$enable_dlopen + +# Whether dlopen of programs is supported. +dlopen_self=$enable_dlopen_self + +# Whether dlopen of statically linked programs is supported. +dlopen_self_static=$enable_dlopen_self_static + +# Compiler flag to prevent dynamic linking. +link_static_flag=$lt_lt_prog_compiler_static + +# Compiler flag to turn off builtin functions. +no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag + +# Compiler flag to allow reflexive dlopens. +export_dynamic_flag_spec=$lt_export_dynamic_flag_spec + +# Compiler flag to generate shared objects directly from archives. +whole_archive_flag_spec=$lt_whole_archive_flag_spec + +# Compiler flag to generate thread-safe objects. +thread_safe_flag_spec=$lt_thread_safe_flag_spec + +# Library versioning type. +version_type=$version_type + +# Format of library name prefix. +libname_spec=$lt_libname_spec + +# List of archive names. First name is the real one, the rest are links. +# The last name is the one that the linker finds with -lNAME. +library_names_spec=$lt_library_names_spec + +# The coded name of the library, if different from the real name. +soname_spec=$lt_soname_spec + +# Commands used to build and install an old-style archive. +RANLIB=$lt_RANLIB +old_archive_cmds=$lt_old_archive_cmds +old_postinstall_cmds=$lt_old_postinstall_cmds +old_postuninstall_cmds=$lt_old_postuninstall_cmds + +# Create an old-style archive from a shared archive. +old_archive_from_new_cmds=$lt_old_archive_from_new_cmds + +# Create a temporary old-style archive to link instead of a shared archive. +old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds + +# Commands used to build and install a shared archive. +archive_cmds=$lt_archive_cmds +archive_expsym_cmds=$lt_archive_expsym_cmds +postinstall_cmds=$lt_postinstall_cmds +postuninstall_cmds=$lt_postuninstall_cmds + +# Commands used to build a loadable module (assumed same as above if empty) +module_cmds=$lt_module_cmds +module_expsym_cmds=$lt_module_expsym_cmds + +# Commands to strip libraries. +old_striplib=$lt_old_striplib +striplib=$lt_striplib + +# Dependencies to place before the objects being linked to create a +# shared library. +predep_objects=$lt_predep_objects + +# Dependencies to place after the objects being linked to create a +# shared library. +postdep_objects=$lt_postdep_objects + +# Dependencies to place before the objects being linked to create a +# shared library. +predeps=$lt_predeps + +# Dependencies to place after the objects being linked to create a +# shared library. +postdeps=$lt_postdeps + +# The library search path used internally by the compiler when linking +# a shared library. +compiler_lib_search_path=$lt_compiler_lib_search_path + +# Method to check whether dependent libraries are shared objects. +deplibs_check_method=$lt_deplibs_check_method + +# Command to use when deplibs_check_method == file_magic. +file_magic_cmd=$lt_file_magic_cmd + +# Flag that allows shared libraries with undefined symbols to be built. +allow_undefined_flag=$lt_allow_undefined_flag + +# Flag that forces no undefined symbols. +no_undefined_flag=$lt_no_undefined_flag + +# Commands used to finish a libtool library installation in a directory. +finish_cmds=$lt_finish_cmds + +# Same as above, but a single script fragment to be evaled but not shown. +finish_eval=$lt_finish_eval + +# Take the output of nm and produce a listing of raw symbols and C names. +global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe + +# Transform the output of nm in a proper C declaration +global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl + +# Transform the output of nm in a C name address pair +global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address + +# This is the shared library runtime path variable. +runpath_var=$runpath_var + +# This is the shared library path variable. +shlibpath_var=$shlibpath_var + +# Is shlibpath searched before the hard-coded library search path? +shlibpath_overrides_runpath=$shlibpath_overrides_runpath + +# How to hardcode a shared library path into an executable. +hardcode_action=$hardcode_action + +# Whether we should hardcode library paths into libraries. +hardcode_into_libs=$hardcode_into_libs + +# Flag to hardcode \$libdir into a binary during linking. +# This must work even if \$libdir does not exist. +hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec + +# If ld is used when linking, flag to hardcode \$libdir into +# a binary during linking. This must work even if \$libdir does +# not exist. +hardcode_libdir_flag_spec_ld=$lt_hardcode_libdir_flag_spec_ld + +# Whether we need a single -rpath flag with a separated argument. +hardcode_libdir_separator=$lt_hardcode_libdir_separator + +# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the +# resulting binary. +hardcode_direct=$hardcode_direct + +# Set to yes if using the -LDIR flag during linking hardcodes DIR into the +# resulting binary. +hardcode_minus_L=$hardcode_minus_L + +# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into +# the resulting binary. +hardcode_shlibpath_var=$hardcode_shlibpath_var + +# Set to yes if building a shared library automatically hardcodes DIR into the library +# and all subsequent libraries and executables linked against it. +hardcode_automatic=$hardcode_automatic + +# Variables whose values should be saved in libtool wrapper scripts and +# restored at relink time. +variables_saved_for_relink="$variables_saved_for_relink" + +# Whether libtool must link a program against all its dependency libraries. +link_all_deplibs=$link_all_deplibs + +# Compile-time system search path for libraries +sys_lib_search_path_spec=$lt_sys_lib_search_path_spec + +# Run-time system search path for libraries +sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec + +# Fix the shell variable \$srcfile for the compiler. +fix_srcfile_path="$fix_srcfile_path" + +# Set to yes if exported symbols are required. +always_export_symbols=$always_export_symbols + +# The commands to list exported symbols. +export_symbols_cmds=$lt_export_symbols_cmds + +# The commands to extract the exported symbol list from a shared archive. +extract_expsyms_cmds=$lt_extract_expsyms_cmds + +# Symbols that should not be listed in the preloaded symbols. +exclude_expsyms=$lt_exclude_expsyms + +# Symbols that must always be exported. +include_expsyms=$lt_include_expsyms + +# ### END LIBTOOL CONFIG + +__EOF__ + + + case $host_os in + aix3*) + cat <<\EOF >> "$cfgfile" + +# AIX sometimes has problems with the GCC collect2 program. For some +# reason, if we set the COLLECT_NAMES environment variable, the problems +# vanish in a puff of smoke. +if test "X${COLLECT_NAMES+set}" != Xset; then + COLLECT_NAMES= + export COLLECT_NAMES +fi +EOF + ;; + esac + + # We use sed instead of cat because bash on DJGPP gets confused if + # if finds mixed CR/LF and LF-only lines. Since sed operates in + # text mode, it properly converts lines to CR/LF. This bash problem + # is reportedly fixed, but why not run on old versions too? + sed '$q' "$ltmain" >> "$cfgfile" || (rm -f "$cfgfile"; exit 1) + + mv -f "$cfgfile" "$ofile" || \ + (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") + chmod +x "$ofile" + +else + # If there is no Makefile yet, we rely on a make rule to execute + # `config.status --recheck' to rerun these tests and create the + # libtool script then. + ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'` + if test -f "$ltmain_in"; then + test -f Makefile && make "$ltmain" + fi +fi + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +CC="$lt_save_CC" + + +# Check whether --with-tags or --without-tags was given. +if test "${with_tags+set}" = set; then + withval="$with_tags" + tagnames="$withval" +fi; + +if test -f "$ltmain" && test -n "$tagnames"; then + if test ! -f "${ofile}"; then + { echo "$as_me:$LINENO: WARNING: output file \`$ofile' does not exist" >&5 +echo "$as_me: WARNING: output file \`$ofile' does not exist" >&2;} + fi + + if test -z "$LTCC"; then + eval "`$SHELL ${ofile} --config | grep '^LTCC='`" + if test -z "$LTCC"; then + { echo "$as_me:$LINENO: WARNING: output file \`$ofile' does not look like a libtool script" >&5 +echo "$as_me: WARNING: output file \`$ofile' does not look like a libtool script" >&2;} + else + { echo "$as_me:$LINENO: WARNING: using \`LTCC=$LTCC', extracted from \`$ofile'" >&5 +echo "$as_me: WARNING: using \`LTCC=$LTCC', extracted from \`$ofile'" >&2;} + fi + fi + + # Extract list of available tagged configurations in $ofile. + # Note that this assumes the entire list is on one line. + available_tags=`grep "^available_tags=" "${ofile}" | $SED -e 's/available_tags=\(.*$\)/\1/' -e 's/\"//g'` + + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for tagname in $tagnames; do + IFS="$lt_save_ifs" + # Check whether tagname contains only valid characters + case `$echo "X$tagname" | $Xsed -e 's:[-_ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890,/]::g'` in + "") ;; + *) { { echo "$as_me:$LINENO: error: invalid tag name: $tagname" >&5 +echo "$as_me: error: invalid tag name: $tagname" >&2;} + { (exit 1); exit 1; }; } + ;; + esac + + if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$" < "${ofile}" > /dev/null + then + { { echo "$as_me:$LINENO: error: tag name \"$tagname\" already exists" >&5 +echo "$as_me: error: tag name \"$tagname\" already exists" >&2;} + { (exit 1); exit 1; }; } + fi + + # Update the list of available tags. + if test -n "$tagname"; then + echo appending configuration tag \"$tagname\" to $ofile + + case $tagname in + CXX) + if test -n "$CXX" && ( test "X$CXX" != "Xno" && + ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) || + (test "X$CXX" != "Xg++"))) ; then + ac_ext=cc +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + + + + +archive_cmds_need_lc_CXX=no +allow_undefined_flag_CXX= +always_export_symbols_CXX=no +archive_expsym_cmds_CXX= +export_dynamic_flag_spec_CXX= +hardcode_direct_CXX=no +hardcode_libdir_flag_spec_CXX= +hardcode_libdir_flag_spec_ld_CXX= +hardcode_libdir_separator_CXX= +hardcode_minus_L_CXX=no +hardcode_automatic_CXX=no +module_cmds_CXX= +module_expsym_cmds_CXX= +link_all_deplibs_CXX=unknown +old_archive_cmds_CXX=$old_archive_cmds +no_undefined_flag_CXX= +whole_archive_flag_spec_CXX= +enable_shared_with_static_runtimes_CXX=no + +# Dependencies to place before and after the object being linked: +predep_objects_CXX= +postdep_objects_CXX= +predeps_CXX= +postdeps_CXX= +compiler_lib_search_path_CXX= + +# Source file extension for C++ test sources. +ac_ext=cpp + +# Object file extension for compiled C++ test sources. +objext=o +objext_CXX=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="int some_variable = 0;\n" + +# Code to be used in simple link tests +lt_simple_link_test_code='int main(int, char *) { return(0); }\n' + +# ltmain only uses $CC for tagged configurations so make sure $CC is set. + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# Allow CC to be a program name with arguments. +compiler=$CC + + +# save warnings/boilerplate of simple test code +ac_outfile=conftest.$ac_objext +printf "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$rm conftest* + +ac_outfile=conftest.$ac_objext +printf "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$rm conftest* + + +# Allow CC to be a program name with arguments. +lt_save_CC=$CC +lt_save_LD=$LD +lt_save_GCC=$GCC +GCC=$GXX +lt_save_with_gnu_ld=$with_gnu_ld +lt_save_path_LD=$lt_cv_path_LD +if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then + lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx +else + unset lt_cv_prog_gnu_ld +fi +if test -n "${lt_cv_path_LDCXX+set}"; then + lt_cv_path_LD=$lt_cv_path_LDCXX +else + unset lt_cv_path_LD +fi +test -z "${LDCXX+set}" || LD=$LDCXX +CC=${CXX-"c++"} +compiler=$CC +compiler_CXX=$CC +for cc_temp in $compiler""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` + + +# We don't want -fno-exception wen compiling C++ code, so set the +# no_builtin_flag separately +if test "$GXX" = yes; then + lt_prog_compiler_no_builtin_flag_CXX=' -fno-builtin' +else + lt_prog_compiler_no_builtin_flag_CXX= +fi + +if test "$GXX" = yes; then + # Set up default GNU C++ configuration + + +# Check whether --with-gnu-ld or --without-gnu-ld was given. +if test "${with_gnu_ld+set}" = set; then + withval="$with_gnu_ld" + test "$withval" = no || with_gnu_ld=yes +else + with_gnu_ld=no +fi; +ac_prog=ld +if test "$GCC" = yes; then + # Check if gcc -print-prog-name=ld gives a path. + echo "$as_me:$LINENO: checking for ld used by $CC" >&5 +echo $ECHO_N "checking for ld used by $CC... $ECHO_C" >&6 + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [\\/]* | ?:[\\/]*) + re_direlt='/[^/][^/]*/\.\./' + # Canonicalize the pathname of ld + ac_prog=`echo $ac_prog| $SED 's%\\\\%/%g'` + while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do + ac_prog=`echo $ac_prog| $SED "s%$re_direlt%/%"` + done + test -z "$LD" && LD="$ac_prog" + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test "$with_gnu_ld" = yes; then + echo "$as_me:$LINENO: checking for GNU ld" >&5 +echo $ECHO_N "checking for GNU ld... $ECHO_C" >&6 +else + echo "$as_me:$LINENO: checking for non-GNU ld" >&5 +echo $ECHO_N "checking for non-GNU ld... $ECHO_C" >&6 +fi +if test "${lt_cv_path_LD+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -z "$LD"; then + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + lt_cv_path_LD="$ac_dir/$ac_prog" + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some variants of GNU ld only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$lt_cv_path_LD" -v 2>&1 &5 +echo "${ECHO_T}$LD" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi +test -z "$LD" && { { echo "$as_me:$LINENO: error: no acceptable ld found in \$PATH" >&5 +echo "$as_me: error: no acceptable ld found in \$PATH" >&2;} + { (exit 1); exit 1; }; } +echo "$as_me:$LINENO: checking if the linker ($LD) is GNU ld" >&5 +echo $ECHO_N "checking if the linker ($LD) is GNU ld... $ECHO_C" >&6 +if test "${lt_cv_prog_gnu_ld+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + # I'd rather use --version here, but apparently some GNU lds only accept -v. +case `$LD -v 2>&1 &5 +echo "${ECHO_T}$lt_cv_prog_gnu_ld" >&6 +with_gnu_ld=$lt_cv_prog_gnu_ld + + + + # Check if GNU C++ uses GNU ld as the underlying linker, since the + # archiving commands below assume that GNU ld is being used. + if test "$with_gnu_ld" = yes; then + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + + hardcode_libdir_flag_spec_CXX='${wl}--rpath ${wl}$libdir' + export_dynamic_flag_spec_CXX='${wl}--export-dynamic' + + # If archive_cmds runs LD, not CC, wlarc should be empty + # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to + # investigate it a little bit more. (MM) + wlarc='${wl}' + + # ancient GNU ld didn't support --whole-archive et. al. + if eval "`$CC -print-prog-name=ld` --help 2>&1" | \ + grep 'no-whole-archive' > /dev/null; then + whole_archive_flag_spec_CXX="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + whole_archive_flag_spec_CXX= + fi + else + with_gnu_ld=no + wlarc= + + # A generic and very simple default shared library creation + # command for GNU C++ for the case where it uses the native + # linker, instead of GNU ld. If possible, this setting should + # overridden to take advantage of the native linker features on + # the platform it is being used on. + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + fi + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' + +else + GXX=no + with_gnu_ld=no + wlarc= +fi + +# PORTME: fill in a description of your system's C++ link characteristics +echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 +echo $ECHO_N "checking whether the $compiler linker ($LD) supports shared libraries... $ECHO_C" >&6 +ld_shlibs_CXX=yes +case $host_os in + aix3*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + aix4* | aix5*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # need to do runtime linking. + case $host_os in aix4.[23]|aix4.[23].*|aix5*) + for ld_flag in $LDFLAGS; do + case $ld_flag in + *-brtl*) + aix_use_runtimelinking=yes + break + ;; + esac + done + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + archive_cmds_CXX='' + hardcode_direct_CXX=yes + hardcode_libdir_separator_CXX=':' + link_all_deplibs_CXX=yes + + if test "$GXX" = yes; then + case $host_os in aix4.[012]|aix4.[012].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && \ + strings "$collect2name" | grep resolve_lib_name >/dev/null + then + # We have reworked collect2 + hardcode_direct_CXX=yes + else + # We have old collect2 + hardcode_direct_CXX=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + hardcode_minus_L_CXX=yes + hardcode_libdir_flag_spec_CXX='-L$libdir' + hardcode_libdir_separator_CXX= + fi + esac + shared_flag='-shared' + if test "$aix_use_runtimelinking" = yes; then + shared_flag="$shared_flag "'${wl}-G' + fi + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='${wl}-G' + else + shared_flag='${wl}-bM:SRE' + fi + fi + fi + + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to export. + always_export_symbols_CXX=yes + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + allow_undefined_flag_CXX='-berok' + # Determine the default libpath from the value encoded in an empty executable. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'`; fi +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec_CXX='${wl}-blibpath:$libdir:'"$aix_libpath" + + archive_expsym_cmds_CXX="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + hardcode_libdir_flag_spec_CXX='${wl}-R $libdir:/usr/lib:/lib' + allow_undefined_flag_CXX="-z nodefs" + archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an empty executable. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'`; fi +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec_CXX='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + no_undefined_flag_CXX=' ${wl}-bernotok' + allow_undefined_flag_CXX=' ${wl}-berok' + # -bexpall does not export symbols beginning with underscore (_) + always_export_symbols_CXX=yes + # Exported symbols can be pulled into shared objects from archives + whole_archive_flag_spec_CXX=' ' + archive_cmds_need_lc_CXX=yes + # This is similar to how AIX traditionally builds its shared libraries. + archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}-bE:$export_symbols ${wl}-bnoentry${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + chorus*) + case $cc_basename in + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + + + cygwin* | mingw* | pw32*) + # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, CXX) is actually meaningless, + # as there is no search path for DLLs. + hardcode_libdir_flag_spec_CXX='-L$libdir' + allow_undefined_flag_CXX=unsupported + always_export_symbols_CXX=no + enable_shared_with_static_runtimes_CXX=yes + + if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + archive_expsym_cmds_CXX='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + else + ld_shlibs_CXX=no + fi + ;; + darwin* | rhapsody*) + case $host_os in + rhapsody* | darwin1.[012]) + allow_undefined_flag_CXX='${wl}-undefined ${wl}suppress' + ;; + *) # Darwin 1.3 on + if test -z ${MACOSX_DEPLOYMENT_TARGET} ; then + allow_undefined_flag_CXX='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + else + case ${MACOSX_DEPLOYMENT_TARGET} in + 10.[012]) + allow_undefined_flag_CXX='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + ;; + 10.*) + allow_undefined_flag_CXX='${wl}-undefined ${wl}dynamic_lookup' + ;; + esac + fi + ;; + esac + archive_cmds_need_lc_CXX=no + hardcode_direct_CXX=no + hardcode_automatic_CXX=yes + hardcode_shlibpath_var_CXX=unsupported + whole_archive_flag_spec_CXX='' + link_all_deplibs_CXX=yes + + if test "$GXX" = yes ; then + lt_int_apple_cc_single_mod=no + output_verbose_link_cmd='echo' + if $CC -dumpspecs 2>&1 | $EGREP 'single_module' >/dev/null ; then + lt_int_apple_cc_single_mod=yes + fi + if test "X$lt_int_apple_cc_single_mod" = Xyes ; then + archive_cmds_CXX='$CC -dynamiclib -single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + else + archive_cmds_CXX='$CC -r -keep_private_externs -nostdlib -o ${lib}-master.o $libobjs~$CC -dynamiclib $allow_undefined_flag -o $lib ${lib}-master.o $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + fi + module_cmds_CXX='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + if test "X$lt_int_apple_cc_single_mod" = Xyes ; then + archive_expsym_cmds_CXX='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -dynamiclib -single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + else + archive_expsym_cmds_CXX='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -r -keep_private_externs -nostdlib -o ${lib}-master.o $libobjs~$CC -dynamiclib $allow_undefined_flag -o $lib ${lib}-master.o $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + fi + module_expsym_cmds_CXX='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + else + case $cc_basename in + xlc*) + output_verbose_link_cmd='echo' + archive_cmds_CXX='$CC -qmkshrobj ${wl}-single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $verstring' + module_cmds_CXX='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + archive_expsym_cmds_CXX='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj ${wl}-single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + module_expsym_cmds_CXX='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + ;; + *) + ld_shlibs_CXX=no + ;; + esac + fi + ;; + + dgux*) + case $cc_basename in + ec++*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + ghcx*) + # Green Hills C++ Compiler + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + freebsd[12]*) + # C++ shared libraries reported to be fairly broken before switch to ELF + ld_shlibs_CXX=no + ;; + freebsd-elf*) + archive_cmds_need_lc_CXX=no + ;; + freebsd* | kfreebsd*-gnu | dragonfly*) + # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF + # conventions + ld_shlibs_CXX=yes + ;; + gnu*) + ;; + hpux9*) + hardcode_libdir_flag_spec_CXX='${wl}+b ${wl}$libdir' + hardcode_libdir_separator_CXX=: + export_dynamic_flag_spec_CXX='${wl}-E' + hardcode_direct_CXX=yes + hardcode_minus_L_CXX=yes # Not in the search PATH, + # but as the default + # location of the library. + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + aCC*) + archive_cmds_CXX='$rm $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | grep "[-]L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes; then + archive_cmds_CXX='$rm $output_objdir/$soname~$CC -shared -nostdlib -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + fi + ;; + esac + ;; + hpux10*|hpux11*) + if test $with_gnu_ld = no; then + case $host_cpu in + hppa*64*) + hardcode_libdir_flag_spec_CXX='${wl}+b ${wl}$libdir' + hardcode_libdir_flag_spec_ld_CXX='+b $libdir' + hardcode_libdir_separator_CXX=: + ;; + ia64*) + hardcode_libdir_flag_spec_CXX='-L$libdir' + ;; + *) + hardcode_libdir_flag_spec_CXX='${wl}+b ${wl}$libdir' + hardcode_libdir_separator_CXX=: + export_dynamic_flag_spec_CXX='${wl}-E' + ;; + esac + fi + case $host_cpu in + hppa*64*) + hardcode_direct_CXX=no + hardcode_shlibpath_var_CXX=no + ;; + ia64*) + hardcode_direct_CXX=no + hardcode_shlibpath_var_CXX=no + hardcode_minus_L_CXX=yes # Not in the search PATH, + # but as the default + # location of the library. + ;; + *) + hardcode_direct_CXX=yes + hardcode_minus_L_CXX=yes # Not in the search PATH, + # but as the default + # location of the library. + ;; + esac + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + aCC*) + case $host_cpu in + hppa*64*|ia64*) + archive_cmds_CXX='$LD -b +h $soname -o $lib $linker_flags $libobjs $deplibs' + ;; + *) + archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | grep "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes; then + if test $with_gnu_ld = no; then + case $host_cpu in + ia64*|hppa*64*) + archive_cmds_CXX='$LD -b +h $soname -o $lib $linker_flags $libobjs $deplibs' + ;; + *) + archive_cmds_CXX='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + fi + else + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + fi + ;; + esac + ;; + irix5* | irix6*) + case $cc_basename in + CC*) + # SGI C++ + archive_cmds_CXX='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + + # Archives containing C++ object files must be created using + # "CC -ar", where "CC" is the IRIX C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + old_archive_cmds_CXX='$CC -ar -WR,-u -o $oldlib $oldobjs' + ;; + *) + if test "$GXX" = yes; then + if test "$with_gnu_ld" = no; then + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` -o $lib' + fi + fi + link_all_deplibs_CXX=yes + ;; + esac + hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_CXX=: + ;; + linux*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + archive_expsym_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | grep "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + + hardcode_libdir_flag_spec_CXX='${wl}--rpath,$libdir' + export_dynamic_flag_spec_CXX='${wl}--export-dynamic' + + # Archives containing C++ object files must be created using + # "CC -Bstatic", where "CC" is the KAI C++ compiler. + old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' + ;; + icpc*) + # Intel C++ + with_gnu_ld=yes + # version 8.0 and above of icpc choke on multiply defined symbols + # if we add $predep_objects and $postdep_objects, however 7.1 and + # earlier do not add the objects themselves. + case `$CC -V 2>&1` in + *"Version 7."*) + archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + ;; + *) # Version 8.0 or newer + tmp_idyn= + case $host_cpu in + ia64*) tmp_idyn=' -i_dynamic';; + esac + archive_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + ;; + esac + archive_cmds_need_lc_CXX=no + hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' + export_dynamic_flag_spec_CXX='${wl}--export-dynamic' + whole_archive_flag_spec_CXX='${wl}--whole-archive$convenience ${wl}--no-whole-archive' + ;; + pgCC*) + # Portland Group C++ compiler + archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib' + + hardcode_libdir_flag_spec_CXX='${wl}--rpath ${wl}$libdir' + export_dynamic_flag_spec_CXX='${wl}--export-dynamic' + whole_archive_flag_spec_CXX='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' + ;; + cxx*) + # Compaq C++ + archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib ${wl}-retain-symbols-file $wl$export_symbols' + + runpath_var=LD_RUN_PATH + hardcode_libdir_flag_spec_CXX='-rpath $libdir' + hardcode_libdir_separator_CXX=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + esac + ;; + lynxos*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + m88k*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + mvs*) + case $cc_basename in + cxx*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + archive_cmds_CXX='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' + wlarc= + hardcode_libdir_flag_spec_CXX='-R$libdir' + hardcode_direct_CXX=yes + hardcode_shlibpath_var_CXX=no + fi + # Workaround some broken pre-1.5 toolchains + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' + ;; + openbsd2*) + # C++ shared libraries are fairly broken + ld_shlibs_CXX=no + ;; + openbsd*) + hardcode_direct_CXX=yes + hardcode_shlibpath_var_CXX=no + archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file,$export_symbols -o $lib' + export_dynamic_flag_spec_CXX='${wl}-E' + whole_archive_flag_spec_CXX="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + fi + output_verbose_link_cmd='echo' + ;; + osf3*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + + hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' + hardcode_libdir_separator_CXX=: + + # Archives containing C++ object files must be created using + # "CC -Bstatic", where "CC" is the KAI C++ compiler. + old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' + + ;; + RCC*) + # Rational C++ 2.4.1 + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + cxx*) + allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds_CXX='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && echo ${wl}-set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + + hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_CXX=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld" | grep -v "ld:"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds_CXX='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + + hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_CXX=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' + + else + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + fi + ;; + esac + ;; + osf4* | osf5*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + + hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir' + hardcode_libdir_separator_CXX=: + + # Archives containing C++ object files must be created using + # the KAI C++ compiler. + old_archive_cmds_CXX='$CC -o $oldlib $oldobjs' + ;; + RCC*) + # Rational C++ 2.4.1 + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + cxx*) + allow_undefined_flag_CXX=' -expect_unresolved \*' + archive_cmds_CXX='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + archive_expsym_cmds_CXX='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ + echo "-hidden">> $lib.exp~ + $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname -Wl,-input -Wl,$lib.exp `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib~ + $rm $lib.exp' + + hardcode_libdir_flag_spec_CXX='-rpath $libdir' + hardcode_libdir_separator_CXX=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld" | grep -v "ld:"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds_CXX='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + + hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_CXX=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' + + else + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + fi + ;; + esac + ;; + psos*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + sco*) + archive_cmds_need_lc_CXX=no + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + lcc*) + # Lucid + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + solaris*) + case $cc_basename in + CC*) + # Sun C++ 4.2, 5.x and Centerline C++ + archive_cmds_need_lc_CXX=yes + no_undefined_flag_CXX=' -zdefs' + archive_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + archive_expsym_cmds_CXX='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -G${allow_undefined_flag} ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' + + hardcode_libdir_flag_spec_CXX='-R$libdir' + hardcode_shlibpath_var_CXX=no + case $host_os in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) + # The C++ compiler is used as linker so we must use $wl + # flag to pass the commands to the underlying system + # linker. We must also pass each convience library through + # to the system linker between allextract/defaultextract. + # The C++ compiler will combine linker options so we + # cannot just pass the convience library names through + # without $wl. + # Supported since Solaris 2.6 (maybe 2.5.1?) + whole_archive_flag_spec_CXX='${wl}-z ${wl}allextract`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}-z ${wl}defaultextract' + ;; + esac + link_all_deplibs_CXX=yes + + output_verbose_link_cmd='echo' + + # Archives containing C++ object files must be created using + # "CC -xar", where "CC" is the Sun C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + old_archive_cmds_CXX='$CC -xar -o $oldlib $oldobjs' + ;; + gcx*) + # Green Hills C++ Compiler + archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + + # The C++ compiler must be used to create the archive. + old_archive_cmds_CXX='$CC $LDFLAGS -archive -o $oldlib $oldobjs' + ;; + *) + # GNU C++ compiler with Solaris linker + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + no_undefined_flag_CXX=' ${wl}-z ${wl}defs' + if $CC --version | grep -v '^2\.7' > /dev/null; then + archive_cmds_CXX='$CC -shared -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + archive_expsym_cmds_CXX='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -shared -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd="$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\"" + else + # g++ 2.7 appears to require `-G' NOT `-shared' on this + # platform. + archive_cmds_CXX='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + archive_expsym_cmds_CXX='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd="$CC -G $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\"" + fi + + hardcode_libdir_flag_spec_CXX='${wl}-R $wl$libdir' + fi + ;; + esac + ;; + sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[78]* | unixware7*) + archive_cmds_need_lc_CXX=no + ;; + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + vxworks*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; +esac +echo "$as_me:$LINENO: result: $ld_shlibs_CXX" >&5 +echo "${ECHO_T}$ld_shlibs_CXX" >&6 +test "$ld_shlibs_CXX" = no && can_build_shared=no + +GCC_CXX="$GXX" +LD_CXX="$LD" + + +cat > conftest.$ac_ext <&5 + (eval $ac_compile) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + # Parse the compiler output and extract the necessary + # objects, libraries and library flags. + + # Sentinel used to keep track of whether or not we are before + # the conftest object file. + pre_test_object_deps_done=no + + # The `*' in the case matches for architectures that use `case' in + # $output_verbose_cmd can trigger glob expansion during the loop + # eval without this substitution. + output_verbose_link_cmd=`$echo "X$output_verbose_link_cmd" | $Xsed -e "$no_glob_subst"` + + for p in `eval $output_verbose_link_cmd`; do + case $p in + + -L* | -R* | -l*) + # Some compilers place space between "-{L,R}" and the path. + # Remove the space. + if test $p = "-L" \ + || test $p = "-R"; then + prev=$p + continue + else + prev= + fi + + if test "$pre_test_object_deps_done" = no; then + case $p in + -L* | -R*) + # Internal compiler library paths should come after those + # provided the user. The postdeps already come after the + # user supplied libs so there is no need to process them. + if test -z "$compiler_lib_search_path_CXX"; then + compiler_lib_search_path_CXX="${prev}${p}" + else + compiler_lib_search_path_CXX="${compiler_lib_search_path_CXX} ${prev}${p}" + fi + ;; + # The "-l" case would never come before the object being + # linked, so don't bother handling this case. + esac + else + if test -z "$postdeps_CXX"; then + postdeps_CXX="${prev}${p}" + else + postdeps_CXX="${postdeps_CXX} ${prev}${p}" + fi + fi + ;; + + *.$objext) + # This assumes that the test object file only shows up + # once in the compiler output. + if test "$p" = "conftest.$objext"; then + pre_test_object_deps_done=yes + continue + fi + + if test "$pre_test_object_deps_done" = no; then + if test -z "$predep_objects_CXX"; then + predep_objects_CXX="$p" + else + predep_objects_CXX="$predep_objects_CXX $p" + fi + else + if test -z "$postdep_objects_CXX"; then + postdep_objects_CXX="$p" + else + postdep_objects_CXX="$postdep_objects_CXX $p" + fi + fi + ;; + + *) ;; # Ignore the rest. + + esac + done + + # Clean up. + rm -f a.out a.exe +else + echo "libtool.m4: error: problem compiling CXX test program" +fi + +$rm -f confest.$objext + +# PORTME: override above test on systems where it is broken +case $host_os in +solaris*) + case $cc_basename in + CC*) + # Adding this requires a known-good setup of shared libraries for + # Sun compiler versions before 5.6, else PIC objects from an old + # archive will be linked into the output, leading to subtle bugs. + postdeps_CXX='-lCstd -lCrun' + ;; + esac +esac + + +case " $postdeps_CXX " in +*" -lc "*) archive_cmds_need_lc_CXX=no ;; +esac + +lt_prog_compiler_wl_CXX= +lt_prog_compiler_pic_CXX= +lt_prog_compiler_static_CXX= + +echo "$as_me:$LINENO: checking for $compiler option to produce PIC" >&5 +echo $ECHO_N "checking for $compiler option to produce PIC... $ECHO_C" >&6 + + # C++ specific cases for pic, static, wl, etc. + if test "$GXX" = yes; then + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static_CXX='-Bstatic' + fi + ;; + amigaos*) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + lt_prog_compiler_pic_CXX='-m68020 -resident32 -malways-restore-a4' + ;; + beos* | cygwin* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + mingw* | os2* | pw32*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + lt_prog_compiler_pic_CXX='-DDLL_EXPORT' + ;; + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + lt_prog_compiler_pic_CXX='-fno-common' + ;; + *djgpp*) + # DJGPP does not support shared libraries at all + lt_prog_compiler_pic_CXX= + ;; + sysv4*MP*) + if test -d /usr/nec; then + lt_prog_compiler_pic_CXX=-Kconform_pic + fi + ;; + hpux*) + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + ;; + *) + lt_prog_compiler_pic_CXX='-fPIC' + ;; + esac + ;; + *) + lt_prog_compiler_pic_CXX='-fPIC' + ;; + esac + else + case $host_os in + aix4* | aix5*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static_CXX='-Bstatic' + else + lt_prog_compiler_static_CXX='-bnso -bI:/lib/syscalls.exp' + fi + ;; + chorus*) + case $cc_basename in + cxch68*) + # Green Hills C++ Compiler + # _LT_AC_TAGVAR(lt_prog_compiler_static, CXX)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" + ;; + esac + ;; + darwin*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + case $cc_basename in + xlc*) + lt_prog_compiler_pic_CXX='-qnocommon' + lt_prog_compiler_wl_CXX='-Wl,' + ;; + esac + ;; + dgux*) + case $cc_basename in + ec++*) + lt_prog_compiler_pic_CXX='-KPIC' + ;; + ghcx*) + # Green Hills C++ Compiler + lt_prog_compiler_pic_CXX='-pic' + ;; + *) + ;; + esac + ;; + freebsd* | kfreebsd*-gnu | dragonfly*) + # FreeBSD uses GNU C++ + ;; + hpux9* | hpux10* | hpux11*) + case $cc_basename in + CC*) + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX="${ac_cv_prog_cc_wl}-a ${ac_cv_prog_cc_wl}archive" + if test "$host_cpu" != ia64; then + lt_prog_compiler_pic_CXX='+Z' + fi + ;; + aCC*) + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX="${ac_cv_prog_cc_wl}-a ${ac_cv_prog_cc_wl}archive" + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic_CXX='+Z' + ;; + esac + ;; + *) + ;; + esac + ;; + irix5* | irix6* | nonstopux*) + case $cc_basename in + CC*) + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX='-non_shared' + # CC pic flag -KPIC is the default. + ;; + *) + ;; + esac + ;; + linux*) + case $cc_basename in + KCC*) + # KAI C++ Compiler + lt_prog_compiler_wl_CXX='--backend -Wl,' + lt_prog_compiler_pic_CXX='-fPIC' + ;; + icpc* | ecpc*) + # Intel C++ + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-KPIC' + lt_prog_compiler_static_CXX='-static' + ;; + pgCC*) + # Portland Group C++ compiler. + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-fpic' + lt_prog_compiler_static_CXX='-Bstatic' + ;; + cxx*) + # Compaq C++ + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + lt_prog_compiler_pic_CXX= + lt_prog_compiler_static_CXX='-non_shared' + ;; + *) + ;; + esac + ;; + lynxos*) + ;; + m88k*) + ;; + mvs*) + case $cc_basename in + cxx*) + lt_prog_compiler_pic_CXX='-W c,exportall' + ;; + *) + ;; + esac + ;; + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + ;; + osf3* | osf4* | osf5*) + case $cc_basename in + KCC*) + lt_prog_compiler_wl_CXX='--backend -Wl,' + ;; + RCC*) + # Rational C++ 2.4.1 + lt_prog_compiler_pic_CXX='-pic' + ;; + cxx*) + # Digital/Compaq C++ + lt_prog_compiler_wl_CXX='-Wl,' + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + lt_prog_compiler_pic_CXX= + lt_prog_compiler_static_CXX='-non_shared' + ;; + *) + ;; + esac + ;; + psos*) + ;; + sco*) + case $cc_basename in + CC*) + lt_prog_compiler_pic_CXX='-fPIC' + ;; + *) + ;; + esac + ;; + solaris*) + case $cc_basename in + CC*) + # Sun C++ 4.2, 5.x and Centerline C++ + lt_prog_compiler_pic_CXX='-KPIC' + lt_prog_compiler_static_CXX='-Bstatic' + lt_prog_compiler_wl_CXX='-Qoption ld ' + ;; + gcx*) + # Green Hills C++ Compiler + lt_prog_compiler_pic_CXX='-PIC' + ;; + *) + ;; + esac + ;; + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + lt_prog_compiler_pic_CXX='-pic' + lt_prog_compiler_static_CXX='-Bstatic' + ;; + lcc*) + # Lucid + lt_prog_compiler_pic_CXX='-pic' + ;; + *) + ;; + esac + ;; + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + lt_prog_compiler_pic_CXX='-KPIC' + ;; + *) + ;; + esac + ;; + unixware*) + ;; + vxworks*) + ;; + *) + lt_prog_compiler_can_build_shared_CXX=no + ;; + esac + fi + +echo "$as_me:$LINENO: result: $lt_prog_compiler_pic_CXX" >&5 +echo "${ECHO_T}$lt_prog_compiler_pic_CXX" >&6 + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$lt_prog_compiler_pic_CXX"; then + +echo "$as_me:$LINENO: checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works" >&5 +echo $ECHO_N "checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works... $ECHO_C" >&6 +if test "${lt_prog_compiler_pic_works_CXX+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_prog_compiler_pic_works_CXX=no + ac_outfile=conftest.$ac_objext + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$lt_prog_compiler_pic_CXX -DPIC" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:11334: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:11338: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $echo "X$_lt_compiler_boilerplate" | $Xsed >conftest.exp + $SED '/^$/d' conftest.err >conftest.er2 + if test ! -s conftest.err || diff conftest.exp conftest.er2 >/dev/null; then + lt_prog_compiler_pic_works_CXX=yes + fi + fi + $rm conftest* + +fi +echo "$as_me:$LINENO: result: $lt_prog_compiler_pic_works_CXX" >&5 +echo "${ECHO_T}$lt_prog_compiler_pic_works_CXX" >&6 + +if test x"$lt_prog_compiler_pic_works_CXX" = xyes; then + case $lt_prog_compiler_pic_CXX in + "" | " "*) ;; + *) lt_prog_compiler_pic_CXX=" $lt_prog_compiler_pic_CXX" ;; + esac +else + lt_prog_compiler_pic_CXX= + lt_prog_compiler_can_build_shared_CXX=no +fi + +fi +case $host_os in + # For platforms which do not support PIC, -DPIC is meaningless: + *djgpp*) + lt_prog_compiler_pic_CXX= + ;; + *) + lt_prog_compiler_pic_CXX="$lt_prog_compiler_pic_CXX -DPIC" + ;; +esac + +echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 +echo $ECHO_N "checking if $compiler supports -c -o file.$ac_objext... $ECHO_C" >&6 +if test "${lt_cv_prog_compiler_c_o_CXX+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_cv_prog_compiler_c_o_CXX=no + $rm -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:11396: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:11400: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $echo "X$_lt_compiler_boilerplate" | $Xsed > out/conftest.exp + $SED '/^$/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.err || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o_CXX=yes + fi + fi + chmod u+w . 2>&5 + $rm conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $rm out/ii_files/* && rmdir out/ii_files + $rm out/* && rmdir out + cd .. + rmdir conftest + $rm conftest* + +fi +echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o_CXX" >&5 +echo "${ECHO_T}$lt_cv_prog_compiler_c_o_CXX" >&6 + + +hard_links="nottested" +if test "$lt_cv_prog_compiler_c_o_CXX" = no && test "$need_locks" != no; then + # do not overwrite the value of need_locks provided by the user + echo "$as_me:$LINENO: checking if we can lock with hard links" >&5 +echo $ECHO_N "checking if we can lock with hard links... $ECHO_C" >&6 + hard_links=yes + $rm conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + echo "$as_me:$LINENO: result: $hard_links" >&5 +echo "${ECHO_T}$hard_links" >&6 + if test "$hard_links" = no; then + { echo "$as_me:$LINENO: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 +echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} + need_locks=warn + fi +else + need_locks=no +fi + +echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 +echo $ECHO_N "checking whether the $compiler linker ($LD) supports shared libraries... $ECHO_C" >&6 + + export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + case $host_os in + aix4* | aix5*) + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | grep 'GNU' > /dev/null; then + export_symbols_cmds_CXX='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' + else + export_symbols_cmds_CXX='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' + fi + ;; + pw32*) + export_symbols_cmds_CXX="$ltdll_cmds" + ;; + cygwin* | mingw*) + export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS] /s/.* \([^ ]*\)/\1 DATA/;/^.* __nm__/s/^.* __nm__\([^ ]*\) [^ ]*/\1 DATA/;/^I /d;/^[AITW] /s/.* //'\'' | sort | uniq > $export_symbols' + ;; + linux*) + link_all_deplibs_CXX=no + ;; + *) + export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + ;; + esac + +echo "$as_me:$LINENO: result: $ld_shlibs_CXX" >&5 +echo "${ECHO_T}$ld_shlibs_CXX" >&6 +test "$ld_shlibs_CXX" = no && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test "$GCC" = yes; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +# +# Do we need to explicitly link libc? +# +case "x$archive_cmds_need_lc_CXX" in +x|xyes) + # Assume -lc should be added + archive_cmds_need_lc_CXX=yes + + if test "$enable_shared" = yes && test "$GCC" = yes; then + case $archive_cmds_CXX in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + echo "$as_me:$LINENO: checking whether -lc should be explicitly linked in" >&5 +echo $ECHO_N "checking whether -lc should be explicitly linked in... $ECHO_C" >&6 + $rm conftest* + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$lt_prog_compiler_wl_CXX + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$allow_undefined_flag_CXX + allow_undefined_flag_CXX= + if { (eval echo "$as_me:$LINENO: \"$archive_cmds_CXX 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1\"") >&5 + (eval $archive_cmds_CXX 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + then + archive_cmds_need_lc_CXX=no + else + archive_cmds_need_lc_CXX=yes + fi + allow_undefined_flag_CXX=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $rm conftest* + echo "$as_me:$LINENO: result: $archive_cmds_need_lc_CXX" >&5 +echo "${ECHO_T}$archive_cmds_need_lc_CXX" >&6 + ;; + esac + fi + ;; +esac + +echo "$as_me:$LINENO: checking dynamic linker characteristics" >&5 +echo $ECHO_N "checking dynamic linker characteristics... $ECHO_C" >&6 +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext_cmds=".so" +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +if test "$GCC" = yes; then + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if echo "$sys_lib_search_path_spec" | grep ';' >/dev/null ; then + # if the path contains ";" then we assume it to be the separator + # otherwise default to the standard path separator (i.e. ":") - it is + # assumed that no part of a normal pathname contains ";" but that should + # okay in the real world where ";" in dirpaths is itself problematic. + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi +else + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +fi +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + +case $host_os in +aix3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='${libname}${release}${shared_ext}$major' + ;; + +aix4* | aix5*) + version_type=linux + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test "$host_cpu" = ia64; then + # AIX 5 supports IA64 + library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line `#! .'. This would cause the generated library to + # depend on `.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[01] | aix4.[01].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | ${CC} -E - | grep yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # AIX (on Power*) has no versioning support, so currently we can not hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + if test "$aix_use_runtimelinking" = yes; then + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + else + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='${libname}${release}.a $libname.a' + soname_spec='${libname}${release}${shared_ext}$major' + fi + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$echo "X$lib" | $Xsed -e '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $rm /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' + ;; + +beos*) + library_names_spec='${libname}${shared_ext}' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi[45]*) + version_type=linux + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32*) + version_type=windows + shrext_cmds=".dll" + need_version=no + need_lib_prefix=no + + case $GCC,$host_os in + yes,cygwin* | yes,mingw* | yes,pw32*) + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \${file}`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $rm \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" + ;; + mingw*) + # MinGW DLLs use traditional 'lib' prefix + soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if echo "$sys_lib_search_path_spec" | grep ';[c-zC-Z]:/' >/dev/null; then + # It is most probably a Windows format PATH printed by + # mingw gcc, but we are running on Cygwin. Gcc prints its search + # path with ; separators, and with drive letters. We can handle the + # drive letters (cygwin fileutils understands them), so leave them, + # especially as we might pass files found there to a mingw objdump, + # which wouldn't understand a cygwinified path. Ahh. + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + ;; + esac + ;; + + *) + library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib' + ;; + esac + dynamic_linker='Win32 ld.exe' + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext' + soname_spec='${libname}${release}${major}$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' + # Apple's gcc prints 'gcc -print-search-dirs' doesn't operate the same. + if test "$GCC" = yes; then + sys_lib_search_path_spec=`$CC -print-search-dirs | tr "\n" "$PATH_SEPARATOR" | sed -e 's/libraries:/@libraries:/' | tr "@" "\n" | grep "^libraries:" | sed -e "s/^libraries://" -e "s,=/,/,g" -e "s,$PATH_SEPARATOR, ,g" -e "s,.*,& /lib /usr/lib /usr/local/lib,g"` + else + sys_lib_search_path_spec='/lib /usr/lib /usr/local/lib' + fi + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd1*) + dynamic_linker=no + ;; + +kfreebsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='GNU ld.so' + ;; + +freebsd* | dragonfly*) + # DragonFly does not have aout. When/if they implement a new + # versioning mechanism, adjust this. + if test -x /usr/bin/objformat; then + objformat=`/usr/bin/objformat` + else + case $host_os in + freebsd[123]*) objformat=aout ;; + *) objformat=elf ;; + esac + fi + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[01]* | freebsdelf3.[01]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + *) # from 3.2 on + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + esac + ;; + +gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case $host_cpu in + ia64*) + shrext_cmds='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + if test "X$HPUX_IA64_MODE" = X32; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + fi + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + hppa*64*) + shrext_cmds='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext_cmds='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555. + postinstall_cmds='chmod 555 $lib' + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test "$lt_cv_prog_gnu_ld" = yes; then + version_type=linux + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" + sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +# This must be Linux ELF. +linux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # Append ld.so.conf contents to the search path + if test -f /etc/ld.so.conf; then + lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;/^$/d' | tr '\n' ' '` + sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" + fi + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsdelf*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='NetBSD ld.elf_so' + ;; + +knetbsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='GNU ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +nto-qnx*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +openbsd*) + version_type=sunos + need_lib_prefix=no + # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. + case $host_os in + openbsd3.3 | openbsd3.3.*) need_version=yes ;; + *) need_version=no ;; + esac + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + case $host_os in + openbsd2.[89] | openbsd2.[89].*) + shlibpath_overrides_runpath=no + ;; + *) + shlibpath_overrides_runpath=yes + ;; + esac + else + shlibpath_overrides_runpath=yes + fi + ;; + +os2*) + libname_spec='$name' + shrext_cmds=".dll" + need_lib_prefix=no + library_names_spec='$libname${shared_ext} $libname.a' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=LIBPATH + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" + ;; + +sco3.2v5*) + version_type=osf + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + ;; + +solaris*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test "$with_gnu_ld" = yes; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + export_dynamic_flag_spec='${wl}-Blargedynsym' + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec ;then + version_type=linux + library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' + soname_spec='$libname${shared_ext}.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +uts4*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +echo "$as_me:$LINENO: result: $dynamic_linker" >&5 +echo "${ECHO_T}$dynamic_linker" >&6 +test "$dynamic_linker" = no && can_build_shared=no + +echo "$as_me:$LINENO: checking how to hardcode library paths into programs" >&5 +echo $ECHO_N "checking how to hardcode library paths into programs... $ECHO_C" >&6 +hardcode_action_CXX= +if test -n "$hardcode_libdir_flag_spec_CXX" || \ + test -n "$runpath_var_CXX" || \ + test "X$hardcode_automatic_CXX" = "Xyes" ; then + + # We can hardcode non-existant directories. + if test "$hardcode_direct_CXX" != no && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, CXX)" != no && + test "$hardcode_minus_L_CXX" != no; then + # Linking always hardcodes the temporary library directory. + hardcode_action_CXX=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + hardcode_action_CXX=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + hardcode_action_CXX=unsupported +fi +echo "$as_me:$LINENO: result: $hardcode_action_CXX" >&5 +echo "${ECHO_T}$hardcode_action_CXX" >&6 + +if test "$hardcode_action_CXX" = relink; then + # Fast installation is not supported + enable_fast_install=no +elif test "$shlibpath_overrides_runpath" = yes || + test "$enable_shared" = no; then + # Fast installation is not necessary + enable_fast_install=needless +fi + +striplib= +old_striplib= +echo "$as_me:$LINENO: checking whether stripping libraries is possible" >&5 +echo $ECHO_N "checking whether stripping libraries is possible... $ECHO_C" >&6 +if test -n "$STRIP" && $STRIP -V 2>&1 | grep "GNU strip" >/dev/null; then + test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" + test -z "$striplib" && striplib="$STRIP --strip-unneeded" + echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 +else +# FIXME - insert some real tests, host_os isn't really good enough + case $host_os in + darwin*) + if test -n "$STRIP" ; then + striplib="$STRIP -x" + echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 + else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + ;; + *) + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 + ;; + esac +fi + +if test "x$enable_dlopen" != xyes; then + enable_dlopen=unknown + enable_dlopen_self=unknown + enable_dlopen_self_static=unknown +else + lt_cv_dlopen=no + lt_cv_dlopen_libs= + + case $host_os in + beos*) + lt_cv_dlopen="load_add_on" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ;; + + mingw* | pw32*) + lt_cv_dlopen="LoadLibrary" + lt_cv_dlopen_libs= + ;; + + cygwin*) + lt_cv_dlopen="dlopen" + lt_cv_dlopen_libs= + ;; + + darwin*) + # if libdl is installed we need to link against it + echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5 +echo $ECHO_N "checking for dlopen in -ldl... $ECHO_C" >&6 +if test "${ac_cv_lib_dl_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldl $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +int +main () +{ +dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dl_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dl_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5 +echo "${ECHO_T}$ac_cv_lib_dl_dlopen" >&6 +if test $ac_cv_lib_dl_dlopen = yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" +else + + lt_cv_dlopen="dyld" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + +fi + + ;; + + *) + echo "$as_me:$LINENO: checking for shl_load" >&5 +echo $ECHO_N "checking for shl_load... $ECHO_C" >&6 +if test "${ac_cv_func_shl_load+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define shl_load to an innocuous variant, in case declares shl_load. + For example, HP-UX 11i declares gettimeofday. */ +#define shl_load innocuous_shl_load + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char shl_load (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef shl_load + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +{ +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char shl_load (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_shl_load) || defined (__stub___shl_load) +choke me +#else +char (*f) () = shl_load; +#endif +#ifdef __cplusplus +} +#endif + +int +main () +{ +return f != shl_load; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_func_shl_load=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_func_shl_load=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_func_shl_load" >&5 +echo "${ECHO_T}$ac_cv_func_shl_load" >&6 +if test $ac_cv_func_shl_load = yes; then + lt_cv_dlopen="shl_load" +else + echo "$as_me:$LINENO: checking for shl_load in -ldld" >&5 +echo $ECHO_N "checking for shl_load in -ldld... $ECHO_C" >&6 +if test "${ac_cv_lib_dld_shl_load+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char shl_load (); +int +main () +{ +shl_load (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dld_shl_load=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dld_shl_load=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dld_shl_load" >&5 +echo "${ECHO_T}$ac_cv_lib_dld_shl_load" >&6 +if test $ac_cv_lib_dld_shl_load = yes; then + lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-dld" +else + echo "$as_me:$LINENO: checking for dlopen" >&5 +echo $ECHO_N "checking for dlopen... $ECHO_C" >&6 +if test "${ac_cv_func_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define dlopen to an innocuous variant, in case declares dlopen. + For example, HP-UX 11i declares gettimeofday. */ +#define dlopen innocuous_dlopen + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char dlopen (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef dlopen + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +{ +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_dlopen) || defined (__stub___dlopen) +choke me +#else +char (*f) () = dlopen; +#endif +#ifdef __cplusplus +} +#endif + +int +main () +{ +return f != dlopen; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_func_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_func_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_func_dlopen" >&5 +echo "${ECHO_T}$ac_cv_func_dlopen" >&6 +if test $ac_cv_func_dlopen = yes; then + lt_cv_dlopen="dlopen" +else + echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5 +echo $ECHO_N "checking for dlopen in -ldl... $ECHO_C" >&6 +if test "${ac_cv_lib_dl_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldl $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +int +main () +{ +dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dl_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dl_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5 +echo "${ECHO_T}$ac_cv_lib_dl_dlopen" >&6 +if test $ac_cv_lib_dl_dlopen = yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" +else + echo "$as_me:$LINENO: checking for dlopen in -lsvld" >&5 +echo $ECHO_N "checking for dlopen in -lsvld... $ECHO_C" >&6 +if test "${ac_cv_lib_svld_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lsvld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +int +main () +{ +dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_svld_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_svld_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_svld_dlopen" >&5 +echo "${ECHO_T}$ac_cv_lib_svld_dlopen" >&6 +if test $ac_cv_lib_svld_dlopen = yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld" +else + echo "$as_me:$LINENO: checking for dld_link in -ldld" >&5 +echo $ECHO_N "checking for dld_link in -ldld... $ECHO_C" >&6 +if test "${ac_cv_lib_dld_dld_link+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dld_link (); +int +main () +{ +dld_link (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dld_dld_link=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dld_dld_link=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dld_dld_link" >&5 +echo "${ECHO_T}$ac_cv_lib_dld_dld_link" >&6 +if test $ac_cv_lib_dld_dld_link = yes; then + lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-dld" +fi + + +fi + + +fi + + +fi + + +fi + + +fi + + ;; + esac + + if test "x$lt_cv_dlopen" != xno; then + enable_dlopen=yes + else + enable_dlopen=no + fi + + case $lt_cv_dlopen in + dlopen) + save_CPPFLAGS="$CPPFLAGS" + test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" + + save_LDFLAGS="$LDFLAGS" + eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" + + save_LIBS="$LIBS" + LIBS="$lt_cv_dlopen_libs $LIBS" + + echo "$as_me:$LINENO: checking whether a program can dlopen itself" >&5 +echo $ECHO_N "checking whether a program can dlopen itself... $ECHO_C" >&6 +if test "${lt_cv_dlopen_self+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$cross_compiling" = yes; then : + lt_cv_dlopen_self=cross +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext < +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +#ifdef __cplusplus +extern "C" void exit (int); +#endif + +void fnord() { int i=42;} +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + /* dlclose (self); */ + } + + exit (status); +} +EOF + if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then + (./conftest; exit; ) >&5 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;; + x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;; + x$lt_unknown|x*) lt_cv_dlopen_self=no ;; + esac + else : + # compilation failed + lt_cv_dlopen_self=no + fi +fi +rm -fr conftest* + + +fi +echo "$as_me:$LINENO: result: $lt_cv_dlopen_self" >&5 +echo "${ECHO_T}$lt_cv_dlopen_self" >&6 + + if test "x$lt_cv_dlopen_self" = xyes; then + LDFLAGS="$LDFLAGS $link_static_flag" + echo "$as_me:$LINENO: checking whether a statically linked program can dlopen itself" >&5 +echo $ECHO_N "checking whether a statically linked program can dlopen itself... $ECHO_C" >&6 +if test "${lt_cv_dlopen_self_static+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$cross_compiling" = yes; then : + lt_cv_dlopen_self_static=cross +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext < +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +#ifdef __cplusplus +extern "C" void exit (int); +#endif + +void fnord() { int i=42;} +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + /* dlclose (self); */ + } + + exit (status); +} +EOF + if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then + (./conftest; exit; ) >&5 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;; + x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;; + x$lt_unknown|x*) lt_cv_dlopen_self_static=no ;; + esac + else : + # compilation failed + lt_cv_dlopen_self_static=no + fi +fi +rm -fr conftest* + + +fi +echo "$as_me:$LINENO: result: $lt_cv_dlopen_self_static" >&5 +echo "${ECHO_T}$lt_cv_dlopen_self_static" >&6 + fi + + CPPFLAGS="$save_CPPFLAGS" + LDFLAGS="$save_LDFLAGS" + LIBS="$save_LIBS" + ;; + esac + + case $lt_cv_dlopen_self in + yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; + *) enable_dlopen_self=unknown ;; + esac + + case $lt_cv_dlopen_self_static in + yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; + *) enable_dlopen_self_static=unknown ;; + esac +fi + + +# The else clause should only fire when bootstrapping the +# libtool distribution, otherwise you forgot to ship ltmain.sh +# with your package, and you will get complaints that there are +# no rules to generate ltmain.sh. +if test -f "$ltmain"; then + # See if we are running on zsh, and set the options which allow our commands through + # without removal of \ escapes. + if test -n "${ZSH_VERSION+set}" ; then + setopt NO_GLOB_SUBST + fi + # Now quote all the things that may contain metacharacters while being + # careful not to overquote the AC_SUBSTed values. We take copies of the + # variables and quote the copies for generation of the libtool script. + for var in echo old_CC old_CFLAGS AR AR_FLAGS EGREP RANLIB LN_S LTCC NM \ + SED SHELL STRIP \ + libname_spec library_names_spec soname_spec extract_expsyms_cmds \ + old_striplib striplib file_magic_cmd finish_cmds finish_eval \ + deplibs_check_method reload_flag reload_cmds need_locks \ + lt_cv_sys_global_symbol_pipe lt_cv_sys_global_symbol_to_cdecl \ + lt_cv_sys_global_symbol_to_c_name_address \ + sys_lib_search_path_spec sys_lib_dlsearch_path_spec \ + old_postinstall_cmds old_postuninstall_cmds \ + compiler_CXX \ + CC_CXX \ + LD_CXX \ + lt_prog_compiler_wl_CXX \ + lt_prog_compiler_pic_CXX \ + lt_prog_compiler_static_CXX \ + lt_prog_compiler_no_builtin_flag_CXX \ + export_dynamic_flag_spec_CXX \ + thread_safe_flag_spec_CXX \ + whole_archive_flag_spec_CXX \ + enable_shared_with_static_runtimes_CXX \ + old_archive_cmds_CXX \ + old_archive_from_new_cmds_CXX \ + predep_objects_CXX \ + postdep_objects_CXX \ + predeps_CXX \ + postdeps_CXX \ + compiler_lib_search_path_CXX \ + archive_cmds_CXX \ + archive_expsym_cmds_CXX \ + postinstall_cmds_CXX \ + postuninstall_cmds_CXX \ + old_archive_from_expsyms_cmds_CXX \ + allow_undefined_flag_CXX \ + no_undefined_flag_CXX \ + export_symbols_cmds_CXX \ + hardcode_libdir_flag_spec_CXX \ + hardcode_libdir_flag_spec_ld_CXX \ + hardcode_libdir_separator_CXX \ + hardcode_automatic_CXX \ + module_cmds_CXX \ + module_expsym_cmds_CXX \ + lt_cv_prog_compiler_c_o_CXX \ + exclude_expsyms_CXX \ + include_expsyms_CXX; do + + case $var in + old_archive_cmds_CXX | \ + old_archive_from_new_cmds_CXX | \ + archive_cmds_CXX | \ + archive_expsym_cmds_CXX | \ + module_cmds_CXX | \ + module_expsym_cmds_CXX | \ + old_archive_from_expsyms_cmds_CXX | \ + export_symbols_cmds_CXX | \ + extract_expsyms_cmds | reload_cmds | finish_cmds | \ + postinstall_cmds | postuninstall_cmds | \ + old_postinstall_cmds | old_postuninstall_cmds | \ + sys_lib_search_path_spec | sys_lib_dlsearch_path_spec) + # Double-quote double-evaled strings. + eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\"" + ;; + *) + eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\"" + ;; + esac + done + + case $lt_echo in + *'\$0 --fallback-echo"') + lt_echo=`$echo "X$lt_echo" | $Xsed -e 's/\\\\\\\$0 --fallback-echo"$/$0 --fallback-echo"/'` + ;; + esac + +cfgfile="$ofile" + + cat <<__EOF__ >> "$cfgfile" +# ### BEGIN LIBTOOL TAG CONFIG: $tagname + +# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: + +# Shell to use when invoking shell scripts. +SHELL=$lt_SHELL + +# Whether or not to build shared libraries. +build_libtool_libs=$enable_shared + +# Whether or not to build static libraries. +build_old_libs=$enable_static + +# Whether or not to add -lc for building shared libraries. +build_libtool_need_lc=$archive_cmds_need_lc_CXX + +# Whether or not to disallow shared libs when runtime libs are static +allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_CXX + +# Whether or not to optimize for fast installation. +fast_install=$enable_fast_install + +# The host system. +host_alias=$host_alias +host=$host +host_os=$host_os + +# The build system. +build_alias=$build_alias +build=$build +build_os=$build_os + +# An echo program that does not interpret backslashes. +echo=$lt_echo + +# The archiver. +AR=$lt_AR +AR_FLAGS=$lt_AR_FLAGS + +# A C compiler. +LTCC=$lt_LTCC + +# A language-specific compiler. +CC=$lt_compiler_CXX + +# Is the compiler the GNU C compiler? +with_gcc=$GCC_CXX + +# An ERE matcher. +EGREP=$lt_EGREP + +# The linker used to build libraries. +LD=$lt_LD_CXX + +# Whether we need hard or soft links. +LN_S=$lt_LN_S + +# A BSD-compatible nm program. +NM=$lt_NM + +# A symbol stripping program +STRIP=$lt_STRIP + +# Used to examine libraries when file_magic_cmd begins "file" +MAGIC_CMD=$MAGIC_CMD + +# Used on cygwin: DLL creation program. +DLLTOOL="$DLLTOOL" + +# Used on cygwin: object dumper. +OBJDUMP="$OBJDUMP" + +# Used on cygwin: assembler. +AS="$AS" + +# The name of the directory that contains temporary libtool files. +objdir=$objdir + +# How to create reloadable object files. +reload_flag=$lt_reload_flag +reload_cmds=$lt_reload_cmds + +# How to pass a linker flag through the compiler. +wl=$lt_lt_prog_compiler_wl_CXX + +# Object file suffix (normally "o"). +objext="$ac_objext" + +# Old archive suffix (normally "a"). +libext="$libext" + +# Shared library suffix (normally ".so"). +shrext_cmds='$shrext_cmds' + +# Executable file suffix (normally ""). +exeext="$exeext" + +# Additional compiler flags for building library objects. +pic_flag=$lt_lt_prog_compiler_pic_CXX +pic_mode=$pic_mode + +# What is the maximum length of a command? +max_cmd_len=$lt_cv_sys_max_cmd_len + +# Does compiler simultaneously support -c and -o options? +compiler_c_o=$lt_lt_cv_prog_compiler_c_o_CXX + +# Must we lock files when doing compilation? +need_locks=$lt_need_locks + +# Do we need the lib prefix for modules? +need_lib_prefix=$need_lib_prefix + +# Do we need a version for libraries? +need_version=$need_version + +# Whether dlopen is supported. +dlopen_support=$enable_dlopen + +# Whether dlopen of programs is supported. +dlopen_self=$enable_dlopen_self + +# Whether dlopen of statically linked programs is supported. +dlopen_self_static=$enable_dlopen_self_static + +# Compiler flag to prevent dynamic linking. +link_static_flag=$lt_lt_prog_compiler_static_CXX + +# Compiler flag to turn off builtin functions. +no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_CXX + +# Compiler flag to allow reflexive dlopens. +export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_CXX + +# Compiler flag to generate shared objects directly from archives. +whole_archive_flag_spec=$lt_whole_archive_flag_spec_CXX + +# Compiler flag to generate thread-safe objects. +thread_safe_flag_spec=$lt_thread_safe_flag_spec_CXX + +# Library versioning type. +version_type=$version_type + +# Format of library name prefix. +libname_spec=$lt_libname_spec + +# List of archive names. First name is the real one, the rest are links. +# The last name is the one that the linker finds with -lNAME. +library_names_spec=$lt_library_names_spec + +# The coded name of the library, if different from the real name. +soname_spec=$lt_soname_spec + +# Commands used to build and install an old-style archive. +RANLIB=$lt_RANLIB +old_archive_cmds=$lt_old_archive_cmds_CXX +old_postinstall_cmds=$lt_old_postinstall_cmds +old_postuninstall_cmds=$lt_old_postuninstall_cmds + +# Create an old-style archive from a shared archive. +old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_CXX + +# Create a temporary old-style archive to link instead of a shared archive. +old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_CXX + +# Commands used to build and install a shared archive. +archive_cmds=$lt_archive_cmds_CXX +archive_expsym_cmds=$lt_archive_expsym_cmds_CXX +postinstall_cmds=$lt_postinstall_cmds +postuninstall_cmds=$lt_postuninstall_cmds + +# Commands used to build a loadable module (assumed same as above if empty) +module_cmds=$lt_module_cmds_CXX +module_expsym_cmds=$lt_module_expsym_cmds_CXX + +# Commands to strip libraries. +old_striplib=$lt_old_striplib +striplib=$lt_striplib + +# Dependencies to place before the objects being linked to create a +# shared library. +predep_objects=$lt_predep_objects_CXX + +# Dependencies to place after the objects being linked to create a +# shared library. +postdep_objects=$lt_postdep_objects_CXX + +# Dependencies to place before the objects being linked to create a +# shared library. +predeps=$lt_predeps_CXX + +# Dependencies to place after the objects being linked to create a +# shared library. +postdeps=$lt_postdeps_CXX + +# The library search path used internally by the compiler when linking +# a shared library. +compiler_lib_search_path=$lt_compiler_lib_search_path_CXX + +# Method to check whether dependent libraries are shared objects. +deplibs_check_method=$lt_deplibs_check_method + +# Command to use when deplibs_check_method == file_magic. +file_magic_cmd=$lt_file_magic_cmd + +# Flag that allows shared libraries with undefined symbols to be built. +allow_undefined_flag=$lt_allow_undefined_flag_CXX + +# Flag that forces no undefined symbols. +no_undefined_flag=$lt_no_undefined_flag_CXX + +# Commands used to finish a libtool library installation in a directory. +finish_cmds=$lt_finish_cmds + +# Same as above, but a single script fragment to be evaled but not shown. +finish_eval=$lt_finish_eval + +# Take the output of nm and produce a listing of raw symbols and C names. +global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe + +# Transform the output of nm in a proper C declaration +global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl + +# Transform the output of nm in a C name address pair +global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address + +# This is the shared library runtime path variable. +runpath_var=$runpath_var + +# This is the shared library path variable. +shlibpath_var=$shlibpath_var + +# Is shlibpath searched before the hard-coded library search path? +shlibpath_overrides_runpath=$shlibpath_overrides_runpath + +# How to hardcode a shared library path into an executable. +hardcode_action=$hardcode_action_CXX + +# Whether we should hardcode library paths into libraries. +hardcode_into_libs=$hardcode_into_libs + +# Flag to hardcode \$libdir into a binary during linking. +# This must work even if \$libdir does not exist. +hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_CXX + +# If ld is used when linking, flag to hardcode \$libdir into +# a binary during linking. This must work even if \$libdir does +# not exist. +hardcode_libdir_flag_spec_ld=$lt_hardcode_libdir_flag_spec_ld_CXX + +# Whether we need a single -rpath flag with a separated argument. +hardcode_libdir_separator=$lt_hardcode_libdir_separator_CXX + +# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the +# resulting binary. +hardcode_direct=$hardcode_direct_CXX + +# Set to yes if using the -LDIR flag during linking hardcodes DIR into the +# resulting binary. +hardcode_minus_L=$hardcode_minus_L_CXX + +# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into +# the resulting binary. +hardcode_shlibpath_var=$hardcode_shlibpath_var_CXX + +# Set to yes if building a shared library automatically hardcodes DIR into the library +# and all subsequent libraries and executables linked against it. +hardcode_automatic=$hardcode_automatic_CXX + +# Variables whose values should be saved in libtool wrapper scripts and +# restored at relink time. +variables_saved_for_relink="$variables_saved_for_relink" + +# Whether libtool must link a program against all its dependency libraries. +link_all_deplibs=$link_all_deplibs_CXX + +# Compile-time system search path for libraries +sys_lib_search_path_spec=$lt_sys_lib_search_path_spec + +# Run-time system search path for libraries +sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec + +# Fix the shell variable \$srcfile for the compiler. +fix_srcfile_path="$fix_srcfile_path_CXX" + +# Set to yes if exported symbols are required. +always_export_symbols=$always_export_symbols_CXX + +# The commands to list exported symbols. +export_symbols_cmds=$lt_export_symbols_cmds_CXX + +# The commands to extract the exported symbol list from a shared archive. +extract_expsyms_cmds=$lt_extract_expsyms_cmds + +# Symbols that should not be listed in the preloaded symbols. +exclude_expsyms=$lt_exclude_expsyms_CXX + +# Symbols that must always be exported. +include_expsyms=$lt_include_expsyms_CXX + +# ### END LIBTOOL TAG CONFIG: $tagname + +__EOF__ + + +else + # If there is no Makefile yet, we rely on a make rule to execute + # `config.status --recheck' to rerun these tests and create the + # libtool script then. + ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'` + if test -f "$ltmain_in"; then + test -f Makefile && make "$ltmain" + fi +fi + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +CC=$lt_save_CC +LDCXX=$LD +LD=$lt_save_LD +GCC=$lt_save_GCC +with_gnu_ldcxx=$with_gnu_ld +with_gnu_ld=$lt_save_with_gnu_ld +lt_cv_path_LDCXX=$lt_cv_path_LD +lt_cv_path_LD=$lt_save_path_LD +lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld +lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld + + else + tagname="" + fi + ;; + + F77) + if test -n "$F77" && test "X$F77" != "Xno"; then + +ac_ext=f +ac_compile='$F77 -c $FFLAGS conftest.$ac_ext >&5' +ac_link='$F77 -o conftest$ac_exeext $FFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_f77_compiler_gnu + + +archive_cmds_need_lc_F77=no +allow_undefined_flag_F77= +always_export_symbols_F77=no +archive_expsym_cmds_F77= +export_dynamic_flag_spec_F77= +hardcode_direct_F77=no +hardcode_libdir_flag_spec_F77= +hardcode_libdir_flag_spec_ld_F77= +hardcode_libdir_separator_F77= +hardcode_minus_L_F77=no +hardcode_automatic_F77=no +module_cmds_F77= +module_expsym_cmds_F77= +link_all_deplibs_F77=unknown +old_archive_cmds_F77=$old_archive_cmds +no_undefined_flag_F77= +whole_archive_flag_spec_F77= +enable_shared_with_static_runtimes_F77=no + +# Source file extension for f77 test sources. +ac_ext=f + +# Object file extension for compiled f77 test sources. +objext=o +objext_F77=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code=" subroutine t\n return\n end\n" + +# Code to be used in simple link tests +lt_simple_link_test_code=" program t\n end\n" + +# ltmain only uses $CC for tagged configurations so make sure $CC is set. + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# Allow CC to be a program name with arguments. +compiler=$CC + + +# save warnings/boilerplate of simple test code +ac_outfile=conftest.$ac_objext +printf "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$rm conftest* + +ac_outfile=conftest.$ac_objext +printf "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$rm conftest* + + +# Allow CC to be a program name with arguments. +lt_save_CC="$CC" +CC=${F77-"f77"} +compiler=$CC +compiler_F77=$CC +for cc_temp in $compiler""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` + + +echo "$as_me:$LINENO: checking if libtool supports shared libraries" >&5 +echo $ECHO_N "checking if libtool supports shared libraries... $ECHO_C" >&6 +echo "$as_me:$LINENO: result: $can_build_shared" >&5 +echo "${ECHO_T}$can_build_shared" >&6 + +echo "$as_me:$LINENO: checking whether to build shared libraries" >&5 +echo $ECHO_N "checking whether to build shared libraries... $ECHO_C" >&6 +test "$can_build_shared" = "no" && enable_shared=no + +# On AIX, shared libraries and static libraries use the same namespace, and +# are all built from PIC. +case $host_os in +aix3*) + test "$enable_shared" = yes && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; +aix4* | aix5*) + if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then + test "$enable_shared" = yes && enable_static=no + fi + ;; +esac +echo "$as_me:$LINENO: result: $enable_shared" >&5 +echo "${ECHO_T}$enable_shared" >&6 + +echo "$as_me:$LINENO: checking whether to build static libraries" >&5 +echo $ECHO_N "checking whether to build static libraries... $ECHO_C" >&6 +# Make sure either enable_shared or enable_static is yes. +test "$enable_shared" = yes || enable_static=yes +echo "$as_me:$LINENO: result: $enable_static" >&5 +echo "${ECHO_T}$enable_static" >&6 + +test "$ld_shlibs_F77" = no && can_build_shared=no + +GCC_F77="$G77" +LD_F77="$LD" + +lt_prog_compiler_wl_F77= +lt_prog_compiler_pic_F77= +lt_prog_compiler_static_F77= + +echo "$as_me:$LINENO: checking for $compiler option to produce PIC" >&5 +echo $ECHO_N "checking for $compiler option to produce PIC... $ECHO_C" >&6 + + if test "$GCC" = yes; then + lt_prog_compiler_wl_F77='-Wl,' + lt_prog_compiler_static_F77='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static_F77='-Bstatic' + fi + ;; + + amigaos*) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + lt_prog_compiler_pic_F77='-m68020 -resident32 -malways-restore-a4' + ;; + + beos* | cygwin* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + + mingw* | pw32* | os2*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + lt_prog_compiler_pic_F77='-DDLL_EXPORT' + ;; + + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + lt_prog_compiler_pic_F77='-fno-common' + ;; + + msdosdjgpp*) + # Just because we use GCC doesn't mean we suddenly get shared libraries + # on systems that don't support them. + lt_prog_compiler_can_build_shared_F77=no + enable_shared=no + ;; + + sysv4*MP*) + if test -d /usr/nec; then + lt_prog_compiler_pic_F77=-Kconform_pic + fi + ;; + + hpux*) + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic_F77='-fPIC' + ;; + esac + ;; + + *) + lt_prog_compiler_pic_F77='-fPIC' + ;; + esac + else + # PORTME Check for flag to pass linker flags through the system compiler. + case $host_os in + aix*) + lt_prog_compiler_wl_F77='-Wl,' + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static_F77='-Bstatic' + else + lt_prog_compiler_static_F77='-bnso -bI:/lib/syscalls.exp' + fi + ;; + darwin*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + case $cc_basename in + xlc*) + lt_prog_compiler_pic_F77='-qnocommon' + lt_prog_compiler_wl_F77='-Wl,' + ;; + esac + ;; + + mingw* | pw32* | os2*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + lt_prog_compiler_pic_F77='-DDLL_EXPORT' + ;; + + hpux9* | hpux10* | hpux11*) + lt_prog_compiler_wl_F77='-Wl,' + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic_F77='+Z' + ;; + esac + # Is there a better lt_prog_compiler_static that works with the bundled CC? + lt_prog_compiler_static_F77='${wl}-a ${wl}archive' + ;; + + irix5* | irix6* | nonstopux*) + lt_prog_compiler_wl_F77='-Wl,' + # PIC (with -KPIC) is the default. + lt_prog_compiler_static_F77='-non_shared' + ;; + + newsos6) + lt_prog_compiler_pic_F77='-KPIC' + lt_prog_compiler_static_F77='-Bstatic' + ;; + + linux*) + case $cc_basename in + icc* | ecc*) + lt_prog_compiler_wl_F77='-Wl,' + lt_prog_compiler_pic_F77='-KPIC' + lt_prog_compiler_static_F77='-static' + ;; + pgcc* | pgf77* | pgf90* | pgf95*) + # Portland Group compilers (*not* the Pentium gcc compiler, + # which looks to be a dead project) + lt_prog_compiler_wl_F77='-Wl,' + lt_prog_compiler_pic_F77='-fpic' + lt_prog_compiler_static_F77='-Bstatic' + ;; + ccc*) + lt_prog_compiler_wl_F77='-Wl,' + # All Alpha code is PIC. + lt_prog_compiler_static_F77='-non_shared' + ;; + esac + ;; + + osf3* | osf4* | osf5*) + lt_prog_compiler_wl_F77='-Wl,' + # All OSF/1 code is PIC. + lt_prog_compiler_static_F77='-non_shared' + ;; + + sco3.2v5*) + lt_prog_compiler_pic_F77='-Kpic' + lt_prog_compiler_static_F77='-dn' + ;; + + solaris*) + lt_prog_compiler_pic_F77='-KPIC' + lt_prog_compiler_static_F77='-Bstatic' + case $cc_basename in + f77* | f90* | f95*) + lt_prog_compiler_wl_F77='-Qoption ld ';; + *) + lt_prog_compiler_wl_F77='-Wl,';; + esac + ;; + + sunos4*) + lt_prog_compiler_wl_F77='-Qoption ld ' + lt_prog_compiler_pic_F77='-PIC' + lt_prog_compiler_static_F77='-Bstatic' + ;; + + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + lt_prog_compiler_wl_F77='-Wl,' + lt_prog_compiler_pic_F77='-KPIC' + lt_prog_compiler_static_F77='-Bstatic' + ;; + + sysv4*MP*) + if test -d /usr/nec ;then + lt_prog_compiler_pic_F77='-Kconform_pic' + lt_prog_compiler_static_F77='-Bstatic' + fi + ;; + + unicos*) + lt_prog_compiler_wl_F77='-Wl,' + lt_prog_compiler_can_build_shared_F77=no + ;; + + uts4*) + lt_prog_compiler_pic_F77='-pic' + lt_prog_compiler_static_F77='-Bstatic' + ;; + + *) + lt_prog_compiler_can_build_shared_F77=no + ;; + esac + fi + +echo "$as_me:$LINENO: result: $lt_prog_compiler_pic_F77" >&5 +echo "${ECHO_T}$lt_prog_compiler_pic_F77" >&6 + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$lt_prog_compiler_pic_F77"; then + +echo "$as_me:$LINENO: checking if $compiler PIC flag $lt_prog_compiler_pic_F77 works" >&5 +echo $ECHO_N "checking if $compiler PIC flag $lt_prog_compiler_pic_F77 works... $ECHO_C" >&6 +if test "${lt_prog_compiler_pic_works_F77+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_prog_compiler_pic_works_F77=no + ac_outfile=conftest.$ac_objext + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$lt_prog_compiler_pic_F77" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:13764: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:13768: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $echo "X$_lt_compiler_boilerplate" | $Xsed >conftest.exp + $SED '/^$/d' conftest.err >conftest.er2 + if test ! -s conftest.err || diff conftest.exp conftest.er2 >/dev/null; then + lt_prog_compiler_pic_works_F77=yes + fi + fi + $rm conftest* + +fi +echo "$as_me:$LINENO: result: $lt_prog_compiler_pic_works_F77" >&5 +echo "${ECHO_T}$lt_prog_compiler_pic_works_F77" >&6 + +if test x"$lt_prog_compiler_pic_works_F77" = xyes; then + case $lt_prog_compiler_pic_F77 in + "" | " "*) ;; + *) lt_prog_compiler_pic_F77=" $lt_prog_compiler_pic_F77" ;; + esac +else + lt_prog_compiler_pic_F77= + lt_prog_compiler_can_build_shared_F77=no +fi + +fi +case $host_os in + # For platforms which do not support PIC, -DPIC is meaningless: + *djgpp*) + lt_prog_compiler_pic_F77= + ;; + *) + lt_prog_compiler_pic_F77="$lt_prog_compiler_pic_F77" + ;; +esac + +echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 +echo $ECHO_N "checking if $compiler supports -c -o file.$ac_objext... $ECHO_C" >&6 +if test "${lt_cv_prog_compiler_c_o_F77+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_cv_prog_compiler_c_o_F77=no + $rm -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:13826: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:13830: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $echo "X$_lt_compiler_boilerplate" | $Xsed > out/conftest.exp + $SED '/^$/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.err || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o_F77=yes + fi + fi + chmod u+w . 2>&5 + $rm conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $rm out/ii_files/* && rmdir out/ii_files + $rm out/* && rmdir out + cd .. + rmdir conftest + $rm conftest* + +fi +echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o_F77" >&5 +echo "${ECHO_T}$lt_cv_prog_compiler_c_o_F77" >&6 + + +hard_links="nottested" +if test "$lt_cv_prog_compiler_c_o_F77" = no && test "$need_locks" != no; then + # do not overwrite the value of need_locks provided by the user + echo "$as_me:$LINENO: checking if we can lock with hard links" >&5 +echo $ECHO_N "checking if we can lock with hard links... $ECHO_C" >&6 + hard_links=yes + $rm conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + echo "$as_me:$LINENO: result: $hard_links" >&5 +echo "${ECHO_T}$hard_links" >&6 + if test "$hard_links" = no; then + { echo "$as_me:$LINENO: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 +echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} + need_locks=warn + fi +else + need_locks=no +fi + +echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 +echo $ECHO_N "checking whether the $compiler linker ($LD) supports shared libraries... $ECHO_C" >&6 + + runpath_var= + allow_undefined_flag_F77= + enable_shared_with_static_runtimes_F77=no + archive_cmds_F77= + archive_expsym_cmds_F77= + old_archive_From_new_cmds_F77= + old_archive_from_expsyms_cmds_F77= + export_dynamic_flag_spec_F77= + whole_archive_flag_spec_F77= + thread_safe_flag_spec_F77= + hardcode_libdir_flag_spec_F77= + hardcode_libdir_flag_spec_ld_F77= + hardcode_libdir_separator_F77= + hardcode_direct_F77=no + hardcode_minus_L_F77=no + hardcode_shlibpath_var_F77=unsupported + link_all_deplibs_F77=unknown + hardcode_automatic_F77=no + module_cmds_F77= + module_expsym_cmds_F77= + always_export_symbols_F77=no + export_symbols_cmds_F77='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + # include_expsyms should be a list of space-separated symbols to be *always* + # included in the symbol list + include_expsyms_F77= + # exclude_expsyms can be an extended regexp of symbols to exclude + # it will be wrapped by ` (' and `)$', so one must not match beginning or + # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', + # as well as any symbol that contains `d'. + exclude_expsyms_F77="_GLOBAL_OFFSET_TABLE_" + # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out + # platforms (ab)use it in PIC code, but their linkers get confused if + # the symbol is explicitly referenced. Since portable code cannot + # rely on this symbol name, it's probably fine to never include it in + # preloaded symbol tables. + extract_expsyms_cmds= + # Just being paranoid about ensuring that cc_basename is set. + for cc_temp in $compiler""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` + + case $host_os in + cygwin* | mingw* | pw32*) + # FIXME: the MSVC++ port hasn't been tested in a loooong time + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + if test "$GCC" != yes; then + with_gnu_ld=no + fi + ;; + openbsd*) + with_gnu_ld=no + ;; + esac + + ld_shlibs_F77=yes + if test "$with_gnu_ld" = yes; then + # If archive_cmds runs LD, not CC, wlarc should be empty + wlarc='${wl}' + + # Set some defaults for GNU ld with shared library support. These + # are reset later if shared libraries are not supported. Putting them + # here allows them to be overridden if necessary. + runpath_var=LD_RUN_PATH + hardcode_libdir_flag_spec_F77='${wl}--rpath ${wl}$libdir' + export_dynamic_flag_spec_F77='${wl}--export-dynamic' + # ancient GNU ld didn't support --whole-archive et. al. + if $LD --help 2>&1 | grep 'no-whole-archive' > /dev/null; then + whole_archive_flag_spec_F77="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + whole_archive_flag_spec_F77= + fi + supports_anon_versioning=no + case `$LD -v 2>/dev/null` in + *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11 + *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... + *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... + *\ 2.11.*) ;; # other 2.11 versions + *) supports_anon_versioning=yes ;; + esac + + # See if GNU ld supports shared libraries. + case $host_os in + aix3* | aix4* | aix5*) + # On AIX/PPC, the GNU linker is very broken + if test "$host_cpu" != ia64; then + ld_shlibs_F77=no + cat <&2 + +*** Warning: the GNU linker, at least up to release 2.9.1, is reported +*** to be unable to reliably create shared libraries on AIX. +*** Therefore, libtool is disabling shared libraries support. If you +*** really care for shared libraries, you may want to modify your PATH +*** so that a non-GNU linker is found, and then restart. + +EOF + fi + ;; + + amigaos*) + archive_cmds_F77='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec_F77='-L$libdir' + hardcode_minus_L_F77=yes + + # Samuel A. Falvo II reports + # that the semantics of dynamic libraries on AmigaOS, at least up + # to version 4, is to share data among multiple programs linked + # with the same dynamic library. Since this doesn't match the + # behavior of shared libraries on other platforms, we can't use + # them. + ld_shlibs_F77=no + ;; + + beos*) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + allow_undefined_flag_F77=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + archive_cmds_F77='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + else + ld_shlibs_F77=no + fi + ;; + + cygwin* | mingw* | pw32*) + # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, F77) is actually meaningless, + # as there is no search path for DLLs. + hardcode_libdir_flag_spec_F77='-L$libdir' + allow_undefined_flag_F77=unsupported + always_export_symbols_F77=no + enable_shared_with_static_runtimes_F77=yes + export_symbols_cmds_F77='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS] /s/.* \([^ ]*\)/\1 DATA/'\'' | $SED -e '\''/^[AITW] /s/.* //'\'' | sort | uniq > $export_symbols' + + if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then + archive_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + archive_expsym_cmds_F77='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + else + ld_shlibs_F77=no + fi + ;; + + linux*) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + tmp_addflag= + case $cc_basename,$host_cpu in + pgcc*) # Portland Group C compiler + whole_archive_flag_spec_F77='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag' + ;; + pgf77* | pgf90* | pgf95*) # Portland Group f77 and f90 compilers + whole_archive_flag_spec_F77='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag -Mnomain' ;; + ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 + tmp_addflag=' -i_dynamic' ;; + efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 + tmp_addflag=' -i_dynamic -nofor_main' ;; + ifc* | ifort*) # Intel Fortran compiler + tmp_addflag=' -nofor_main' ;; + esac + archive_cmds_F77='$CC -shared'"$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + + if test $supports_anon_versioning = yes; then + archive_expsym_cmds_F77='$echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + $echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC -shared'"$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' + fi + link_all_deplibs_F77=no + else + ld_shlibs_F77=no + fi + ;; + + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + archive_cmds_F77='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' + wlarc= + else + archive_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + fi + ;; + + solaris* | sysv5*) + if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then + ld_shlibs_F77=no + cat <&2 + +*** Warning: The releases 2.8.* of the GNU linker cannot reliably +*** create shared libraries on Solaris systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.9.1 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +EOF + elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + archive_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs_F77=no + fi + ;; + + sunos4*) + archive_cmds_F77='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' + wlarc= + hardcode_direct_F77=yes + hardcode_shlibpath_var_F77=no + ;; + + *) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + archive_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs_F77=no + fi + ;; + esac + + if test "$ld_shlibs_F77" = no; then + runpath_var= + hardcode_libdir_flag_spec_F77= + export_dynamic_flag_spec_F77= + whole_archive_flag_spec_F77= + fi + else + # PORTME fill in a description of your system's linker (not GNU ld) + case $host_os in + aix3*) + allow_undefined_flag_F77=unsupported + always_export_symbols_F77=yes + archive_expsym_cmds_F77='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' + # Note: this linker hardcodes the directories in LIBPATH if there + # are no directories specified by -L. + hardcode_minus_L_F77=yes + if test "$GCC" = yes && test -z "$link_static_flag"; then + # Neither direct hardcoding nor static linking is supported with a + # broken collect2. + hardcode_direct_F77=unsupported + fi + ;; + + aix4* | aix5*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | grep 'GNU' > /dev/null; then + export_symbols_cmds_F77='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' + else + export_symbols_cmds_F77='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' + fi + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # need to do runtime linking. + case $host_os in aix4.[23]|aix4.[23].*|aix5*) + for ld_flag in $LDFLAGS; do + if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then + aix_use_runtimelinking=yes + break + fi + done + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + archive_cmds_F77='' + hardcode_direct_F77=yes + hardcode_libdir_separator_F77=':' + link_all_deplibs_F77=yes + + if test "$GCC" = yes; then + case $host_os in aix4.[012]|aix4.[012].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && \ + strings "$collect2name" | grep resolve_lib_name >/dev/null + then + # We have reworked collect2 + hardcode_direct_F77=yes + else + # We have old collect2 + hardcode_direct_F77=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + hardcode_minus_L_F77=yes + hardcode_libdir_flag_spec_F77='-L$libdir' + hardcode_libdir_separator_F77= + fi + esac + shared_flag='-shared' + if test "$aix_use_runtimelinking" = yes; then + shared_flag="$shared_flag "'${wl}-G' + fi + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='${wl}-G' + else + shared_flag='${wl}-bM:SRE' + fi + fi + fi + + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to export. + always_export_symbols_F77=yes + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + allow_undefined_flag_F77='-berok' + # Determine the default libpath from the value encoded in an empty executable. + cat >conftest.$ac_ext <<_ACEOF + program main + + end +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_f77_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'`; fi +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec_F77='${wl}-blibpath:$libdir:'"$aix_libpath" + archive_expsym_cmds_F77="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + hardcode_libdir_flag_spec_F77='${wl}-R $libdir:/usr/lib:/lib' + allow_undefined_flag_F77="-z nodefs" + archive_expsym_cmds_F77="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an empty executable. + cat >conftest.$ac_ext <<_ACEOF + program main + + end +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_f77_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'`; fi +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec_F77='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + no_undefined_flag_F77=' ${wl}-bernotok' + allow_undefined_flag_F77=' ${wl}-berok' + # -bexpall does not export symbols beginning with underscore (_) + always_export_symbols_F77=yes + # Exported symbols can be pulled into shared objects from archives + whole_archive_flag_spec_F77=' ' + archive_cmds_need_lc_F77=yes + # This is similar to how AIX traditionally builds its shared libraries. + archive_expsym_cmds_F77="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}-bE:$export_symbols ${wl}-bnoentry${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + + amigaos*) + archive_cmds_F77='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec_F77='-L$libdir' + hardcode_minus_L_F77=yes + # see comment about different semantics on the GNU ld section + ld_shlibs_F77=no + ;; + + bsdi[45]*) + export_dynamic_flag_spec_F77=-rdynamic + ;; + + cygwin* | mingw* | pw32*) + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + hardcode_libdir_flag_spec_F77=' ' + allow_undefined_flag_F77=unsupported + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=".dll" + # FIXME: Setting linknames here is a bad hack. + archive_cmds_F77='$CC -o $lib $libobjs $compiler_flags `echo "$deplibs" | $SED -e '\''s/ -lc$//'\''` -link -dll~linknames=' + # The linker will automatically build a .lib file if we build a DLL. + old_archive_From_new_cmds_F77='true' + # FIXME: Should let the user specify the lib program. + old_archive_cmds_F77='lib /OUT:$oldlib$oldobjs$old_deplibs' + fix_srcfile_path_F77='`cygpath -w "$srcfile"`' + enable_shared_with_static_runtimes_F77=yes + ;; + + darwin* | rhapsody*) + case $host_os in + rhapsody* | darwin1.[012]) + allow_undefined_flag_F77='${wl}-undefined ${wl}suppress' + ;; + *) # Darwin 1.3 on + if test -z ${MACOSX_DEPLOYMENT_TARGET} ; then + allow_undefined_flag_F77='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + else + case ${MACOSX_DEPLOYMENT_TARGET} in + 10.[012]) + allow_undefined_flag_F77='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + ;; + 10.*) + allow_undefined_flag_F77='${wl}-undefined ${wl}dynamic_lookup' + ;; + esac + fi + ;; + esac + archive_cmds_need_lc_F77=no + hardcode_direct_F77=no + hardcode_automatic_F77=yes + hardcode_shlibpath_var_F77=unsupported + whole_archive_flag_spec_F77='' + link_all_deplibs_F77=yes + if test "$GCC" = yes ; then + output_verbose_link_cmd='echo' + archive_cmds_F77='$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + module_cmds_F77='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + archive_expsym_cmds_F77='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + module_expsym_cmds_F77='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + else + case $cc_basename in + xlc*) + output_verbose_link_cmd='echo' + archive_cmds_F77='$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $verstring' + module_cmds_F77='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + archive_expsym_cmds_F77='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + module_expsym_cmds_F77='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + ;; + *) + ld_shlibs_F77=no + ;; + esac + fi + ;; + + dgux*) + archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec_F77='-L$libdir' + hardcode_shlibpath_var_F77=no + ;; + + freebsd1*) + ld_shlibs_F77=no + ;; + + # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor + # support. Future versions do this automatically, but an explicit c++rt0.o + # does not break anything, and helps significantly (at the cost of a little + # extra space). + freebsd2.2*) + archive_cmds_F77='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' + hardcode_libdir_flag_spec_F77='-R$libdir' + hardcode_direct_F77=yes + hardcode_shlibpath_var_F77=no + ;; + + # Unfortunately, older versions of FreeBSD 2 do not have this feature. + freebsd2*) + archive_cmds_F77='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct_F77=yes + hardcode_minus_L_F77=yes + hardcode_shlibpath_var_F77=no + ;; + + # FreeBSD 3 and greater uses gcc -shared to do shared libraries. + freebsd* | kfreebsd*-gnu | dragonfly*) + archive_cmds_F77='$CC -shared -o $lib $libobjs $deplibs $compiler_flags' + hardcode_libdir_flag_spec_F77='-R$libdir' + hardcode_direct_F77=yes + hardcode_shlibpath_var_F77=no + ;; + + hpux9*) + if test "$GCC" = yes; then + archive_cmds_F77='$rm $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + archive_cmds_F77='$rm $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + fi + hardcode_libdir_flag_spec_F77='${wl}+b ${wl}$libdir' + hardcode_libdir_separator_F77=: + hardcode_direct_F77=yes + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L_F77=yes + export_dynamic_flag_spec_F77='${wl}-E' + ;; + + hpux10* | hpux11*) + if test "$GCC" = yes -a "$with_gnu_ld" = no; then + case $host_cpu in + hppa*64*|ia64*) + archive_cmds_F77='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + archive_cmds_F77='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + else + case $host_cpu in + hppa*64*|ia64*) + archive_cmds_F77='$LD -b +h $soname -o $lib $libobjs $deplibs $linker_flags' + ;; + *) + archive_cmds_F77='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' + ;; + esac + fi + if test "$with_gnu_ld" = no; then + case $host_cpu in + hppa*64*) + hardcode_libdir_flag_spec_F77='${wl}+b ${wl}$libdir' + hardcode_libdir_flag_spec_ld_F77='+b $libdir' + hardcode_libdir_separator_F77=: + hardcode_direct_F77=no + hardcode_shlibpath_var_F77=no + ;; + ia64*) + hardcode_libdir_flag_spec_F77='-L$libdir' + hardcode_direct_F77=no + hardcode_shlibpath_var_F77=no + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L_F77=yes + ;; + *) + hardcode_libdir_flag_spec_F77='${wl}+b ${wl}$libdir' + hardcode_libdir_separator_F77=: + hardcode_direct_F77=yes + export_dynamic_flag_spec_F77='${wl}-E' + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L_F77=yes + ;; + esac + fi + ;; + + irix5* | irix6* | nonstopux*) + if test "$GCC" = yes; then + archive_cmds_F77='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + archive_cmds_F77='$LD -shared $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + hardcode_libdir_flag_spec_ld_F77='-rpath $libdir' + fi + hardcode_libdir_flag_spec_F77='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_F77=: + link_all_deplibs_F77=yes + ;; + + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + archive_cmds_F77='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out + else + archive_cmds_F77='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF + fi + hardcode_libdir_flag_spec_F77='-R$libdir' + hardcode_direct_F77=yes + hardcode_shlibpath_var_F77=no + ;; + + newsos6) + archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct_F77=yes + hardcode_libdir_flag_spec_F77='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_F77=: + hardcode_shlibpath_var_F77=no + ;; + + openbsd*) + hardcode_direct_F77=yes + hardcode_shlibpath_var_F77=no + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + archive_cmds_F77='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_F77='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' + hardcode_libdir_flag_spec_F77='${wl}-rpath,$libdir' + export_dynamic_flag_spec_F77='${wl}-E' + else + case $host_os in + openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*) + archive_cmds_F77='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec_F77='-R$libdir' + ;; + *) + archive_cmds_F77='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + hardcode_libdir_flag_spec_F77='${wl}-rpath,$libdir' + ;; + esac + fi + ;; + + os2*) + hardcode_libdir_flag_spec_F77='-L$libdir' + hardcode_minus_L_F77=yes + allow_undefined_flag_F77=unsupported + archive_cmds_F77='$echo "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$echo "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$echo DATA >> $output_objdir/$libname.def~$echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~$echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' + old_archive_From_new_cmds_F77='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' + ;; + + osf3*) + if test "$GCC" = yes; then + allow_undefined_flag_F77=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds_F77='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + allow_undefined_flag_F77=' -expect_unresolved \*' + archive_cmds_F77='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + fi + hardcode_libdir_flag_spec_F77='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_F77=: + ;; + + osf4* | osf5*) # as osf3* with the addition of -msym flag + if test "$GCC" = yes; then + allow_undefined_flag_F77=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds_F77='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + hardcode_libdir_flag_spec_F77='${wl}-rpath ${wl}$libdir' + else + allow_undefined_flag_F77=' -expect_unresolved \*' + archive_cmds_F77='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + archive_expsym_cmds_F77='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; echo "-hidden">> $lib.exp~ + $LD -shared${allow_undefined_flag} -input $lib.exp $linker_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib~$rm $lib.exp' + + # Both c and cxx compiler support -rpath directly + hardcode_libdir_flag_spec_F77='-rpath $libdir' + fi + hardcode_libdir_separator_F77=: + ;; + + sco3.2v5*) + archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var_F77=no + export_dynamic_flag_spec_F77='${wl}-Bexport' + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ;; + + solaris*) + no_undefined_flag_F77=' -z text' + if test "$GCC" = yes; then + wlarc='${wl}' + archive_cmds_F77='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_F77='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -shared ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$rm $lib.exp' + else + wlarc='' + archive_cmds_F77='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + archive_expsym_cmds_F77='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' + fi + hardcode_libdir_flag_spec_F77='-R$libdir' + hardcode_shlibpath_var_F77=no + case $host_os in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) + # The compiler driver will combine linker options so we + # cannot just pass the convience library names through + # without $wl, iff we do not link with $LD. + # Luckily, gcc supports the same syntax we need for Sun Studio. + # Supported since Solaris 2.6 (maybe 2.5.1?) + case $wlarc in + '') + whole_archive_flag_spec_F77='-z allextract$convenience -z defaultextract' ;; + *) + whole_archive_flag_spec_F77='${wl}-z ${wl}allextract`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}-z ${wl}defaultextract' ;; + esac ;; + esac + link_all_deplibs_F77=yes + ;; + + sunos4*) + if test "x$host_vendor" = xsequent; then + # Use $CC to link under sequent, because it throws in some extra .o + # files that make .init and .fini sections work. + archive_cmds_F77='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds_F77='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' + fi + hardcode_libdir_flag_spec_F77='-L$libdir' + hardcode_direct_F77=yes + hardcode_minus_L_F77=yes + hardcode_shlibpath_var_F77=no + ;; + + sysv4) + case $host_vendor in + sni) + archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct_F77=yes # is this really true??? + ;; + siemens) + ## LD is ld it makes a PLAMLIB + ## CC just makes a GrossModule. + archive_cmds_F77='$LD -G -o $lib $libobjs $deplibs $linker_flags' + reload_cmds_F77='$CC -r -o $output$reload_objs' + hardcode_direct_F77=no + ;; + motorola) + archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct_F77=no #Motorola manual says yes, but my tests say they lie + ;; + esac + runpath_var='LD_RUN_PATH' + hardcode_shlibpath_var_F77=no + ;; + + sysv4.3*) + archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var_F77=no + export_dynamic_flag_spec_F77='-Bexport' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var_F77=no + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ld_shlibs_F77=yes + fi + ;; + + sysv4.2uw2*) + archive_cmds_F77='$LD -G -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct_F77=yes + hardcode_minus_L_F77=no + hardcode_shlibpath_var_F77=no + hardcode_runpath_var=yes + runpath_var=LD_RUN_PATH + ;; + + sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[78]* | unixware7*) + no_undefined_flag_F77='${wl}-z ${wl}text' + if test "$GCC" = yes; then + archive_cmds_F77='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds_F77='$CC -G ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + runpath_var='LD_RUN_PATH' + hardcode_shlibpath_var_F77=no + ;; + + sysv5*) + no_undefined_flag_F77=' -z text' + # $CC -shared without GNU ld will not create a library from C++ + # object files and a static libstdc++, better avoid it by now + archive_cmds_F77='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + archive_expsym_cmds_F77='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' + hardcode_libdir_flag_spec_F77= + hardcode_shlibpath_var_F77=no + runpath_var='LD_RUN_PATH' + ;; + + uts4*) + archive_cmds_F77='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec_F77='-L$libdir' + hardcode_shlibpath_var_F77=no + ;; + + *) + ld_shlibs_F77=no + ;; + esac + fi + +echo "$as_me:$LINENO: result: $ld_shlibs_F77" >&5 +echo "${ECHO_T}$ld_shlibs_F77" >&6 +test "$ld_shlibs_F77" = no && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test "$GCC" = yes; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +# +# Do we need to explicitly link libc? +# +case "x$archive_cmds_need_lc_F77" in +x|xyes) + # Assume -lc should be added + archive_cmds_need_lc_F77=yes + + if test "$enable_shared" = yes && test "$GCC" = yes; then + case $archive_cmds_F77 in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + echo "$as_me:$LINENO: checking whether -lc should be explicitly linked in" >&5 +echo $ECHO_N "checking whether -lc should be explicitly linked in... $ECHO_C" >&6 + $rm conftest* + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$lt_prog_compiler_wl_F77 + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$allow_undefined_flag_F77 + allow_undefined_flag_F77= + if { (eval echo "$as_me:$LINENO: \"$archive_cmds_F77 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1\"") >&5 + (eval $archive_cmds_F77 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + then + archive_cmds_need_lc_F77=no + else + archive_cmds_need_lc_F77=yes + fi + allow_undefined_flag_F77=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $rm conftest* + echo "$as_me:$LINENO: result: $archive_cmds_need_lc_F77" >&5 +echo "${ECHO_T}$archive_cmds_need_lc_F77" >&6 + ;; + esac + fi + ;; +esac + +echo "$as_me:$LINENO: checking dynamic linker characteristics" >&5 +echo $ECHO_N "checking dynamic linker characteristics... $ECHO_C" >&6 +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext_cmds=".so" +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +if test "$GCC" = yes; then + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if echo "$sys_lib_search_path_spec" | grep ';' >/dev/null ; then + # if the path contains ";" then we assume it to be the separator + # otherwise default to the standard path separator (i.e. ":") - it is + # assumed that no part of a normal pathname contains ";" but that should + # okay in the real world where ";" in dirpaths is itself problematic. + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi +else + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +fi +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + +case $host_os in +aix3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='${libname}${release}${shared_ext}$major' + ;; + +aix4* | aix5*) + version_type=linux + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test "$host_cpu" = ia64; then + # AIX 5 supports IA64 + library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line `#! .'. This would cause the generated library to + # depend on `.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[01] | aix4.[01].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | ${CC} -E - | grep yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # AIX (on Power*) has no versioning support, so currently we can not hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + if test "$aix_use_runtimelinking" = yes; then + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + else + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='${libname}${release}.a $libname.a' + soname_spec='${libname}${release}${shared_ext}$major' + fi + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$echo "X$lib" | $Xsed -e '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $rm /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' + ;; + +beos*) + library_names_spec='${libname}${shared_ext}' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi[45]*) + version_type=linux + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32*) + version_type=windows + shrext_cmds=".dll" + need_version=no + need_lib_prefix=no + + case $GCC,$host_os in + yes,cygwin* | yes,mingw* | yes,pw32*) + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \${file}`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $rm \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" + ;; + mingw*) + # MinGW DLLs use traditional 'lib' prefix + soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if echo "$sys_lib_search_path_spec" | grep ';[c-zC-Z]:/' >/dev/null; then + # It is most probably a Windows format PATH printed by + # mingw gcc, but we are running on Cygwin. Gcc prints its search + # path with ; separators, and with drive letters. We can handle the + # drive letters (cygwin fileutils understands them), so leave them, + # especially as we might pass files found there to a mingw objdump, + # which wouldn't understand a cygwinified path. Ahh. + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + ;; + esac + ;; + + *) + library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib' + ;; + esac + dynamic_linker='Win32 ld.exe' + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext' + soname_spec='${libname}${release}${major}$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' + # Apple's gcc prints 'gcc -print-search-dirs' doesn't operate the same. + if test "$GCC" = yes; then + sys_lib_search_path_spec=`$CC -print-search-dirs | tr "\n" "$PATH_SEPARATOR" | sed -e 's/libraries:/@libraries:/' | tr "@" "\n" | grep "^libraries:" | sed -e "s/^libraries://" -e "s,=/,/,g" -e "s,$PATH_SEPARATOR, ,g" -e "s,.*,& /lib /usr/lib /usr/local/lib,g"` + else + sys_lib_search_path_spec='/lib /usr/lib /usr/local/lib' + fi + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd1*) + dynamic_linker=no + ;; + +kfreebsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='GNU ld.so' + ;; + +freebsd* | dragonfly*) + # DragonFly does not have aout. When/if they implement a new + # versioning mechanism, adjust this. + if test -x /usr/bin/objformat; then + objformat=`/usr/bin/objformat` + else + case $host_os in + freebsd[123]*) objformat=aout ;; + *) objformat=elf ;; + esac + fi + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[01]* | freebsdelf3.[01]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + *) # from 3.2 on + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + esac + ;; + +gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case $host_cpu in + ia64*) + shrext_cmds='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + if test "X$HPUX_IA64_MODE" = X32; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + fi + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + hppa*64*) + shrext_cmds='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext_cmds='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555. + postinstall_cmds='chmod 555 $lib' + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test "$lt_cv_prog_gnu_ld" = yes; then + version_type=linux + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" + sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +# This must be Linux ELF. +linux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # Append ld.so.conf contents to the search path + if test -f /etc/ld.so.conf; then + lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;/^$/d' | tr '\n' ' '` + sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" + fi + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsdelf*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='NetBSD ld.elf_so' + ;; + +knetbsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='GNU ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +nto-qnx*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +openbsd*) + version_type=sunos + need_lib_prefix=no + # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. + case $host_os in + openbsd3.3 | openbsd3.3.*) need_version=yes ;; + *) need_version=no ;; + esac + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + case $host_os in + openbsd2.[89] | openbsd2.[89].*) + shlibpath_overrides_runpath=no + ;; + *) + shlibpath_overrides_runpath=yes + ;; + esac + else + shlibpath_overrides_runpath=yes + fi + ;; + +os2*) + libname_spec='$name' + shrext_cmds=".dll" + need_lib_prefix=no + library_names_spec='$libname${shared_ext} $libname.a' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=LIBPATH + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" + ;; + +sco3.2v5*) + version_type=osf + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + ;; + +solaris*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test "$with_gnu_ld" = yes; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + export_dynamic_flag_spec='${wl}-Blargedynsym' + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec ;then + version_type=linux + library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' + soname_spec='$libname${shared_ext}.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +uts4*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +echo "$as_me:$LINENO: result: $dynamic_linker" >&5 +echo "${ECHO_T}$dynamic_linker" >&6 +test "$dynamic_linker" = no && can_build_shared=no + +echo "$as_me:$LINENO: checking how to hardcode library paths into programs" >&5 +echo $ECHO_N "checking how to hardcode library paths into programs... $ECHO_C" >&6 +hardcode_action_F77= +if test -n "$hardcode_libdir_flag_spec_F77" || \ + test -n "$runpath_var_F77" || \ + test "X$hardcode_automatic_F77" = "Xyes" ; then + + # We can hardcode non-existant directories. + if test "$hardcode_direct_F77" != no && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, F77)" != no && + test "$hardcode_minus_L_F77" != no; then + # Linking always hardcodes the temporary library directory. + hardcode_action_F77=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + hardcode_action_F77=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + hardcode_action_F77=unsupported +fi +echo "$as_me:$LINENO: result: $hardcode_action_F77" >&5 +echo "${ECHO_T}$hardcode_action_F77" >&6 + +if test "$hardcode_action_F77" = relink; then + # Fast installation is not supported + enable_fast_install=no +elif test "$shlibpath_overrides_runpath" = yes || + test "$enable_shared" = no; then + # Fast installation is not necessary + enable_fast_install=needless +fi + +striplib= +old_striplib= +echo "$as_me:$LINENO: checking whether stripping libraries is possible" >&5 +echo $ECHO_N "checking whether stripping libraries is possible... $ECHO_C" >&6 +if test -n "$STRIP" && $STRIP -V 2>&1 | grep "GNU strip" >/dev/null; then + test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" + test -z "$striplib" && striplib="$STRIP --strip-unneeded" + echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 +else +# FIXME - insert some real tests, host_os isn't really good enough + case $host_os in + darwin*) + if test -n "$STRIP" ; then + striplib="$STRIP -x" + echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 + else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + ;; + *) + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 + ;; + esac +fi + + + +# The else clause should only fire when bootstrapping the +# libtool distribution, otherwise you forgot to ship ltmain.sh +# with your package, and you will get complaints that there are +# no rules to generate ltmain.sh. +if test -f "$ltmain"; then + # See if we are running on zsh, and set the options which allow our commands through + # without removal of \ escapes. + if test -n "${ZSH_VERSION+set}" ; then + setopt NO_GLOB_SUBST + fi + # Now quote all the things that may contain metacharacters while being + # careful not to overquote the AC_SUBSTed values. We take copies of the + # variables and quote the copies for generation of the libtool script. + for var in echo old_CC old_CFLAGS AR AR_FLAGS EGREP RANLIB LN_S LTCC NM \ + SED SHELL STRIP \ + libname_spec library_names_spec soname_spec extract_expsyms_cmds \ + old_striplib striplib file_magic_cmd finish_cmds finish_eval \ + deplibs_check_method reload_flag reload_cmds need_locks \ + lt_cv_sys_global_symbol_pipe lt_cv_sys_global_symbol_to_cdecl \ + lt_cv_sys_global_symbol_to_c_name_address \ + sys_lib_search_path_spec sys_lib_dlsearch_path_spec \ + old_postinstall_cmds old_postuninstall_cmds \ + compiler_F77 \ + CC_F77 \ + LD_F77 \ + lt_prog_compiler_wl_F77 \ + lt_prog_compiler_pic_F77 \ + lt_prog_compiler_static_F77 \ + lt_prog_compiler_no_builtin_flag_F77 \ + export_dynamic_flag_spec_F77 \ + thread_safe_flag_spec_F77 \ + whole_archive_flag_spec_F77 \ + enable_shared_with_static_runtimes_F77 \ + old_archive_cmds_F77 \ + old_archive_from_new_cmds_F77 \ + predep_objects_F77 \ + postdep_objects_F77 \ + predeps_F77 \ + postdeps_F77 \ + compiler_lib_search_path_F77 \ + archive_cmds_F77 \ + archive_expsym_cmds_F77 \ + postinstall_cmds_F77 \ + postuninstall_cmds_F77 \ + old_archive_from_expsyms_cmds_F77 \ + allow_undefined_flag_F77 \ + no_undefined_flag_F77 \ + export_symbols_cmds_F77 \ + hardcode_libdir_flag_spec_F77 \ + hardcode_libdir_flag_spec_ld_F77 \ + hardcode_libdir_separator_F77 \ + hardcode_automatic_F77 \ + module_cmds_F77 \ + module_expsym_cmds_F77 \ + lt_cv_prog_compiler_c_o_F77 \ + exclude_expsyms_F77 \ + include_expsyms_F77; do + + case $var in + old_archive_cmds_F77 | \ + old_archive_from_new_cmds_F77 | \ + archive_cmds_F77 | \ + archive_expsym_cmds_F77 | \ + module_cmds_F77 | \ + module_expsym_cmds_F77 | \ + old_archive_from_expsyms_cmds_F77 | \ + export_symbols_cmds_F77 | \ + extract_expsyms_cmds | reload_cmds | finish_cmds | \ + postinstall_cmds | postuninstall_cmds | \ + old_postinstall_cmds | old_postuninstall_cmds | \ + sys_lib_search_path_spec | sys_lib_dlsearch_path_spec) + # Double-quote double-evaled strings. + eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\"" + ;; + *) + eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\"" + ;; + esac + done + + case $lt_echo in + *'\$0 --fallback-echo"') + lt_echo=`$echo "X$lt_echo" | $Xsed -e 's/\\\\\\\$0 --fallback-echo"$/$0 --fallback-echo"/'` + ;; + esac + +cfgfile="$ofile" + + cat <<__EOF__ >> "$cfgfile" +# ### BEGIN LIBTOOL TAG CONFIG: $tagname + +# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: + +# Shell to use when invoking shell scripts. +SHELL=$lt_SHELL + +# Whether or not to build shared libraries. +build_libtool_libs=$enable_shared + +# Whether or not to build static libraries. +build_old_libs=$enable_static + +# Whether or not to add -lc for building shared libraries. +build_libtool_need_lc=$archive_cmds_need_lc_F77 + +# Whether or not to disallow shared libs when runtime libs are static +allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_F77 + +# Whether or not to optimize for fast installation. +fast_install=$enable_fast_install + +# The host system. +host_alias=$host_alias +host=$host +host_os=$host_os + +# The build system. +build_alias=$build_alias +build=$build +build_os=$build_os + +# An echo program that does not interpret backslashes. +echo=$lt_echo + +# The archiver. +AR=$lt_AR +AR_FLAGS=$lt_AR_FLAGS + +# A C compiler. +LTCC=$lt_LTCC + +# A language-specific compiler. +CC=$lt_compiler_F77 + +# Is the compiler the GNU C compiler? +with_gcc=$GCC_F77 + +# An ERE matcher. +EGREP=$lt_EGREP + +# The linker used to build libraries. +LD=$lt_LD_F77 + +# Whether we need hard or soft links. +LN_S=$lt_LN_S + +# A BSD-compatible nm program. +NM=$lt_NM + +# A symbol stripping program +STRIP=$lt_STRIP + +# Used to examine libraries when file_magic_cmd begins "file" +MAGIC_CMD=$MAGIC_CMD + +# Used on cygwin: DLL creation program. +DLLTOOL="$DLLTOOL" + +# Used on cygwin: object dumper. +OBJDUMP="$OBJDUMP" + +# Used on cygwin: assembler. +AS="$AS" + +# The name of the directory that contains temporary libtool files. +objdir=$objdir + +# How to create reloadable object files. +reload_flag=$lt_reload_flag +reload_cmds=$lt_reload_cmds + +# How to pass a linker flag through the compiler. +wl=$lt_lt_prog_compiler_wl_F77 + +# Object file suffix (normally "o"). +objext="$ac_objext" + +# Old archive suffix (normally "a"). +libext="$libext" + +# Shared library suffix (normally ".so"). +shrext_cmds='$shrext_cmds' + +# Executable file suffix (normally ""). +exeext="$exeext" + +# Additional compiler flags for building library objects. +pic_flag=$lt_lt_prog_compiler_pic_F77 +pic_mode=$pic_mode + +# What is the maximum length of a command? +max_cmd_len=$lt_cv_sys_max_cmd_len + +# Does compiler simultaneously support -c and -o options? +compiler_c_o=$lt_lt_cv_prog_compiler_c_o_F77 + +# Must we lock files when doing compilation? +need_locks=$lt_need_locks + +# Do we need the lib prefix for modules? +need_lib_prefix=$need_lib_prefix + +# Do we need a version for libraries? +need_version=$need_version + +# Whether dlopen is supported. +dlopen_support=$enable_dlopen + +# Whether dlopen of programs is supported. +dlopen_self=$enable_dlopen_self + +# Whether dlopen of statically linked programs is supported. +dlopen_self_static=$enable_dlopen_self_static + +# Compiler flag to prevent dynamic linking. +link_static_flag=$lt_lt_prog_compiler_static_F77 + +# Compiler flag to turn off builtin functions. +no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_F77 + +# Compiler flag to allow reflexive dlopens. +export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_F77 + +# Compiler flag to generate shared objects directly from archives. +whole_archive_flag_spec=$lt_whole_archive_flag_spec_F77 + +# Compiler flag to generate thread-safe objects. +thread_safe_flag_spec=$lt_thread_safe_flag_spec_F77 + +# Library versioning type. +version_type=$version_type + +# Format of library name prefix. +libname_spec=$lt_libname_spec + +# List of archive names. First name is the real one, the rest are links. +# The last name is the one that the linker finds with -lNAME. +library_names_spec=$lt_library_names_spec + +# The coded name of the library, if different from the real name. +soname_spec=$lt_soname_spec + +# Commands used to build and install an old-style archive. +RANLIB=$lt_RANLIB +old_archive_cmds=$lt_old_archive_cmds_F77 +old_postinstall_cmds=$lt_old_postinstall_cmds +old_postuninstall_cmds=$lt_old_postuninstall_cmds + +# Create an old-style archive from a shared archive. +old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_F77 + +# Create a temporary old-style archive to link instead of a shared archive. +old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_F77 + +# Commands used to build and install a shared archive. +archive_cmds=$lt_archive_cmds_F77 +archive_expsym_cmds=$lt_archive_expsym_cmds_F77 +postinstall_cmds=$lt_postinstall_cmds +postuninstall_cmds=$lt_postuninstall_cmds + +# Commands used to build a loadable module (assumed same as above if empty) +module_cmds=$lt_module_cmds_F77 +module_expsym_cmds=$lt_module_expsym_cmds_F77 + +# Commands to strip libraries. +old_striplib=$lt_old_striplib +striplib=$lt_striplib + +# Dependencies to place before the objects being linked to create a +# shared library. +predep_objects=$lt_predep_objects_F77 + +# Dependencies to place after the objects being linked to create a +# shared library. +postdep_objects=$lt_postdep_objects_F77 + +# Dependencies to place before the objects being linked to create a +# shared library. +predeps=$lt_predeps_F77 + +# Dependencies to place after the objects being linked to create a +# shared library. +postdeps=$lt_postdeps_F77 + +# The library search path used internally by the compiler when linking +# a shared library. +compiler_lib_search_path=$lt_compiler_lib_search_path_F77 + +# Method to check whether dependent libraries are shared objects. +deplibs_check_method=$lt_deplibs_check_method + +# Command to use when deplibs_check_method == file_magic. +file_magic_cmd=$lt_file_magic_cmd + +# Flag that allows shared libraries with undefined symbols to be built. +allow_undefined_flag=$lt_allow_undefined_flag_F77 + +# Flag that forces no undefined symbols. +no_undefined_flag=$lt_no_undefined_flag_F77 + +# Commands used to finish a libtool library installation in a directory. +finish_cmds=$lt_finish_cmds + +# Same as above, but a single script fragment to be evaled but not shown. +finish_eval=$lt_finish_eval + +# Take the output of nm and produce a listing of raw symbols and C names. +global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe + +# Transform the output of nm in a proper C declaration +global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl + +# Transform the output of nm in a C name address pair +global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address + +# This is the shared library runtime path variable. +runpath_var=$runpath_var + +# This is the shared library path variable. +shlibpath_var=$shlibpath_var + +# Is shlibpath searched before the hard-coded library search path? +shlibpath_overrides_runpath=$shlibpath_overrides_runpath + +# How to hardcode a shared library path into an executable. +hardcode_action=$hardcode_action_F77 + +# Whether we should hardcode library paths into libraries. +hardcode_into_libs=$hardcode_into_libs + +# Flag to hardcode \$libdir into a binary during linking. +# This must work even if \$libdir does not exist. +hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_F77 + +# If ld is used when linking, flag to hardcode \$libdir into +# a binary during linking. This must work even if \$libdir does +# not exist. +hardcode_libdir_flag_spec_ld=$lt_hardcode_libdir_flag_spec_ld_F77 + +# Whether we need a single -rpath flag with a separated argument. +hardcode_libdir_separator=$lt_hardcode_libdir_separator_F77 + +# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the +# resulting binary. +hardcode_direct=$hardcode_direct_F77 + +# Set to yes if using the -LDIR flag during linking hardcodes DIR into the +# resulting binary. +hardcode_minus_L=$hardcode_minus_L_F77 + +# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into +# the resulting binary. +hardcode_shlibpath_var=$hardcode_shlibpath_var_F77 + +# Set to yes if building a shared library automatically hardcodes DIR into the library +# and all subsequent libraries and executables linked against it. +hardcode_automatic=$hardcode_automatic_F77 + +# Variables whose values should be saved in libtool wrapper scripts and +# restored at relink time. +variables_saved_for_relink="$variables_saved_for_relink" + +# Whether libtool must link a program against all its dependency libraries. +link_all_deplibs=$link_all_deplibs_F77 + +# Compile-time system search path for libraries +sys_lib_search_path_spec=$lt_sys_lib_search_path_spec + +# Run-time system search path for libraries +sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec + +# Fix the shell variable \$srcfile for the compiler. +fix_srcfile_path="$fix_srcfile_path_F77" + +# Set to yes if exported symbols are required. +always_export_symbols=$always_export_symbols_F77 + +# The commands to list exported symbols. +export_symbols_cmds=$lt_export_symbols_cmds_F77 + +# The commands to extract the exported symbol list from a shared archive. +extract_expsyms_cmds=$lt_extract_expsyms_cmds + +# Symbols that should not be listed in the preloaded symbols. +exclude_expsyms=$lt_exclude_expsyms_F77 + +# Symbols that must always be exported. +include_expsyms=$lt_include_expsyms_F77 + +# ### END LIBTOOL TAG CONFIG: $tagname + +__EOF__ + + +else + # If there is no Makefile yet, we rely on a make rule to execute + # `config.status --recheck' to rerun these tests and create the + # libtool script then. + ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'` + if test -f "$ltmain_in"; then + test -f Makefile && make "$ltmain" + fi +fi + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +CC="$lt_save_CC" + + else + tagname="" + fi + ;; + + GCJ) + if test -n "$GCJ" && test "X$GCJ" != "Xno"; then + + + +# Source file extension for Java test sources. +ac_ext=java + +# Object file extension for compiled Java test sources. +objext=o +objext_GCJ=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="class foo {}\n" + +# Code to be used in simple link tests +lt_simple_link_test_code='public class conftest { public static void main(String[] argv) {}; }\n' + +# ltmain only uses $CC for tagged configurations so make sure $CC is set. + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# Allow CC to be a program name with arguments. +compiler=$CC + + +# save warnings/boilerplate of simple test code +ac_outfile=conftest.$ac_objext +printf "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$rm conftest* + +ac_outfile=conftest.$ac_objext +printf "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$rm conftest* + + +# Allow CC to be a program name with arguments. +lt_save_CC="$CC" +CC=${GCJ-"gcj"} +compiler=$CC +compiler_GCJ=$CC +for cc_temp in $compiler""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` + + +# GCJ did not exist at the time GCC didn't implicitly link libc in. +archive_cmds_need_lc_GCJ=no + +old_archive_cmds_GCJ=$old_archive_cmds + + +lt_prog_compiler_no_builtin_flag_GCJ= + +if test "$GCC" = yes; then + lt_prog_compiler_no_builtin_flag_GCJ=' -fno-builtin' + + +echo "$as_me:$LINENO: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 +echo $ECHO_N "checking if $compiler supports -fno-rtti -fno-exceptions... $ECHO_C" >&6 +if test "${lt_cv_prog_compiler_rtti_exceptions+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_cv_prog_compiler_rtti_exceptions=no + ac_outfile=conftest.$ac_objext + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="-fno-rtti -fno-exceptions" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:15967: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:15971: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $echo "X$_lt_compiler_boilerplate" | $Xsed >conftest.exp + $SED '/^$/d' conftest.err >conftest.er2 + if test ! -s conftest.err || diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_rtti_exceptions=yes + fi + fi + $rm conftest* + +fi +echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_rtti_exceptions" >&5 +echo "${ECHO_T}$lt_cv_prog_compiler_rtti_exceptions" >&6 + +if test x"$lt_cv_prog_compiler_rtti_exceptions" = xyes; then + lt_prog_compiler_no_builtin_flag_GCJ="$lt_prog_compiler_no_builtin_flag_GCJ -fno-rtti -fno-exceptions" +else + : +fi + +fi + +lt_prog_compiler_wl_GCJ= +lt_prog_compiler_pic_GCJ= +lt_prog_compiler_static_GCJ= + +echo "$as_me:$LINENO: checking for $compiler option to produce PIC" >&5 +echo $ECHO_N "checking for $compiler option to produce PIC... $ECHO_C" >&6 + + if test "$GCC" = yes; then + lt_prog_compiler_wl_GCJ='-Wl,' + lt_prog_compiler_static_GCJ='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static_GCJ='-Bstatic' + fi + ;; + + amigaos*) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + lt_prog_compiler_pic_GCJ='-m68020 -resident32 -malways-restore-a4' + ;; + + beos* | cygwin* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + + mingw* | pw32* | os2*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + lt_prog_compiler_pic_GCJ='-DDLL_EXPORT' + ;; + + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + lt_prog_compiler_pic_GCJ='-fno-common' + ;; + + msdosdjgpp*) + # Just because we use GCC doesn't mean we suddenly get shared libraries + # on systems that don't support them. + lt_prog_compiler_can_build_shared_GCJ=no + enable_shared=no + ;; + + sysv4*MP*) + if test -d /usr/nec; then + lt_prog_compiler_pic_GCJ=-Kconform_pic + fi + ;; + + hpux*) + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic_GCJ='-fPIC' + ;; + esac + ;; + + *) + lt_prog_compiler_pic_GCJ='-fPIC' + ;; + esac + else + # PORTME Check for flag to pass linker flags through the system compiler. + case $host_os in + aix*) + lt_prog_compiler_wl_GCJ='-Wl,' + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static_GCJ='-Bstatic' + else + lt_prog_compiler_static_GCJ='-bnso -bI:/lib/syscalls.exp' + fi + ;; + darwin*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + case $cc_basename in + xlc*) + lt_prog_compiler_pic_GCJ='-qnocommon' + lt_prog_compiler_wl_GCJ='-Wl,' + ;; + esac + ;; + + mingw* | pw32* | os2*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + lt_prog_compiler_pic_GCJ='-DDLL_EXPORT' + ;; + + hpux9* | hpux10* | hpux11*) + lt_prog_compiler_wl_GCJ='-Wl,' + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic_GCJ='+Z' + ;; + esac + # Is there a better lt_prog_compiler_static that works with the bundled CC? + lt_prog_compiler_static_GCJ='${wl}-a ${wl}archive' + ;; + + irix5* | irix6* | nonstopux*) + lt_prog_compiler_wl_GCJ='-Wl,' + # PIC (with -KPIC) is the default. + lt_prog_compiler_static_GCJ='-non_shared' + ;; + + newsos6) + lt_prog_compiler_pic_GCJ='-KPIC' + lt_prog_compiler_static_GCJ='-Bstatic' + ;; + + linux*) + case $cc_basename in + icc* | ecc*) + lt_prog_compiler_wl_GCJ='-Wl,' + lt_prog_compiler_pic_GCJ='-KPIC' + lt_prog_compiler_static_GCJ='-static' + ;; + pgcc* | pgf77* | pgf90* | pgf95*) + # Portland Group compilers (*not* the Pentium gcc compiler, + # which looks to be a dead project) + lt_prog_compiler_wl_GCJ='-Wl,' + lt_prog_compiler_pic_GCJ='-fpic' + lt_prog_compiler_static_GCJ='-Bstatic' + ;; + ccc*) + lt_prog_compiler_wl_GCJ='-Wl,' + # All Alpha code is PIC. + lt_prog_compiler_static_GCJ='-non_shared' + ;; + esac + ;; + + osf3* | osf4* | osf5*) + lt_prog_compiler_wl_GCJ='-Wl,' + # All OSF/1 code is PIC. + lt_prog_compiler_static_GCJ='-non_shared' + ;; + + sco3.2v5*) + lt_prog_compiler_pic_GCJ='-Kpic' + lt_prog_compiler_static_GCJ='-dn' + ;; + + solaris*) + lt_prog_compiler_pic_GCJ='-KPIC' + lt_prog_compiler_static_GCJ='-Bstatic' + case $cc_basename in + f77* | f90* | f95*) + lt_prog_compiler_wl_GCJ='-Qoption ld ';; + *) + lt_prog_compiler_wl_GCJ='-Wl,';; + esac + ;; + + sunos4*) + lt_prog_compiler_wl_GCJ='-Qoption ld ' + lt_prog_compiler_pic_GCJ='-PIC' + lt_prog_compiler_static_GCJ='-Bstatic' + ;; + + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + lt_prog_compiler_wl_GCJ='-Wl,' + lt_prog_compiler_pic_GCJ='-KPIC' + lt_prog_compiler_static_GCJ='-Bstatic' + ;; + + sysv4*MP*) + if test -d /usr/nec ;then + lt_prog_compiler_pic_GCJ='-Kconform_pic' + lt_prog_compiler_static_GCJ='-Bstatic' + fi + ;; + + unicos*) + lt_prog_compiler_wl_GCJ='-Wl,' + lt_prog_compiler_can_build_shared_GCJ=no + ;; + + uts4*) + lt_prog_compiler_pic_GCJ='-pic' + lt_prog_compiler_static_GCJ='-Bstatic' + ;; + + *) + lt_prog_compiler_can_build_shared_GCJ=no + ;; + esac + fi + +echo "$as_me:$LINENO: result: $lt_prog_compiler_pic_GCJ" >&5 +echo "${ECHO_T}$lt_prog_compiler_pic_GCJ" >&6 + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$lt_prog_compiler_pic_GCJ"; then + +echo "$as_me:$LINENO: checking if $compiler PIC flag $lt_prog_compiler_pic_GCJ works" >&5 +echo $ECHO_N "checking if $compiler PIC flag $lt_prog_compiler_pic_GCJ works... $ECHO_C" >&6 +if test "${lt_prog_compiler_pic_works_GCJ+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_prog_compiler_pic_works_GCJ=no + ac_outfile=conftest.$ac_objext + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$lt_prog_compiler_pic_GCJ" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:16229: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:16233: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $echo "X$_lt_compiler_boilerplate" | $Xsed >conftest.exp + $SED '/^$/d' conftest.err >conftest.er2 + if test ! -s conftest.err || diff conftest.exp conftest.er2 >/dev/null; then + lt_prog_compiler_pic_works_GCJ=yes + fi + fi + $rm conftest* + +fi +echo "$as_me:$LINENO: result: $lt_prog_compiler_pic_works_GCJ" >&5 +echo "${ECHO_T}$lt_prog_compiler_pic_works_GCJ" >&6 + +if test x"$lt_prog_compiler_pic_works_GCJ" = xyes; then + case $lt_prog_compiler_pic_GCJ in + "" | " "*) ;; + *) lt_prog_compiler_pic_GCJ=" $lt_prog_compiler_pic_GCJ" ;; + esac +else + lt_prog_compiler_pic_GCJ= + lt_prog_compiler_can_build_shared_GCJ=no +fi + +fi +case $host_os in + # For platforms which do not support PIC, -DPIC is meaningless: + *djgpp*) + lt_prog_compiler_pic_GCJ= + ;; + *) + lt_prog_compiler_pic_GCJ="$lt_prog_compiler_pic_GCJ" + ;; +esac + +echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5 +echo $ECHO_N "checking if $compiler supports -c -o file.$ac_objext... $ECHO_C" >&6 +if test "${lt_cv_prog_compiler_c_o_GCJ+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + lt_cv_prog_compiler_c_o_GCJ=no + $rm -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:16291: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:16295: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $echo "X$_lt_compiler_boilerplate" | $Xsed > out/conftest.exp + $SED '/^$/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.err || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o_GCJ=yes + fi + fi + chmod u+w . 2>&5 + $rm conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $rm out/ii_files/* && rmdir out/ii_files + $rm out/* && rmdir out + cd .. + rmdir conftest + $rm conftest* + +fi +echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o_GCJ" >&5 +echo "${ECHO_T}$lt_cv_prog_compiler_c_o_GCJ" >&6 + + +hard_links="nottested" +if test "$lt_cv_prog_compiler_c_o_GCJ" = no && test "$need_locks" != no; then + # do not overwrite the value of need_locks provided by the user + echo "$as_me:$LINENO: checking if we can lock with hard links" >&5 +echo $ECHO_N "checking if we can lock with hard links... $ECHO_C" >&6 + hard_links=yes + $rm conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + echo "$as_me:$LINENO: result: $hard_links" >&5 +echo "${ECHO_T}$hard_links" >&6 + if test "$hard_links" = no; then + { echo "$as_me:$LINENO: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5 +echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;} + need_locks=warn + fi +else + need_locks=no +fi + +echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5 +echo $ECHO_N "checking whether the $compiler linker ($LD) supports shared libraries... $ECHO_C" >&6 + + runpath_var= + allow_undefined_flag_GCJ= + enable_shared_with_static_runtimes_GCJ=no + archive_cmds_GCJ= + archive_expsym_cmds_GCJ= + old_archive_From_new_cmds_GCJ= + old_archive_from_expsyms_cmds_GCJ= + export_dynamic_flag_spec_GCJ= + whole_archive_flag_spec_GCJ= + thread_safe_flag_spec_GCJ= + hardcode_libdir_flag_spec_GCJ= + hardcode_libdir_flag_spec_ld_GCJ= + hardcode_libdir_separator_GCJ= + hardcode_direct_GCJ=no + hardcode_minus_L_GCJ=no + hardcode_shlibpath_var_GCJ=unsupported + link_all_deplibs_GCJ=unknown + hardcode_automatic_GCJ=no + module_cmds_GCJ= + module_expsym_cmds_GCJ= + always_export_symbols_GCJ=no + export_symbols_cmds_GCJ='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + # include_expsyms should be a list of space-separated symbols to be *always* + # included in the symbol list + include_expsyms_GCJ= + # exclude_expsyms can be an extended regexp of symbols to exclude + # it will be wrapped by ` (' and `)$', so one must not match beginning or + # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', + # as well as any symbol that contains `d'. + exclude_expsyms_GCJ="_GLOBAL_OFFSET_TABLE_" + # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out + # platforms (ab)use it in PIC code, but their linkers get confused if + # the symbol is explicitly referenced. Since portable code cannot + # rely on this symbol name, it's probably fine to never include it in + # preloaded symbol tables. + extract_expsyms_cmds= + # Just being paranoid about ensuring that cc_basename is set. + for cc_temp in $compiler""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` + + case $host_os in + cygwin* | mingw* | pw32*) + # FIXME: the MSVC++ port hasn't been tested in a loooong time + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + if test "$GCC" != yes; then + with_gnu_ld=no + fi + ;; + openbsd*) + with_gnu_ld=no + ;; + esac + + ld_shlibs_GCJ=yes + if test "$with_gnu_ld" = yes; then + # If archive_cmds runs LD, not CC, wlarc should be empty + wlarc='${wl}' + + # Set some defaults for GNU ld with shared library support. These + # are reset later if shared libraries are not supported. Putting them + # here allows them to be overridden if necessary. + runpath_var=LD_RUN_PATH + hardcode_libdir_flag_spec_GCJ='${wl}--rpath ${wl}$libdir' + export_dynamic_flag_spec_GCJ='${wl}--export-dynamic' + # ancient GNU ld didn't support --whole-archive et. al. + if $LD --help 2>&1 | grep 'no-whole-archive' > /dev/null; then + whole_archive_flag_spec_GCJ="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + whole_archive_flag_spec_GCJ= + fi + supports_anon_versioning=no + case `$LD -v 2>/dev/null` in + *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11 + *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... + *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... + *\ 2.11.*) ;; # other 2.11 versions + *) supports_anon_versioning=yes ;; + esac + + # See if GNU ld supports shared libraries. + case $host_os in + aix3* | aix4* | aix5*) + # On AIX/PPC, the GNU linker is very broken + if test "$host_cpu" != ia64; then + ld_shlibs_GCJ=no + cat <&2 + +*** Warning: the GNU linker, at least up to release 2.9.1, is reported +*** to be unable to reliably create shared libraries on AIX. +*** Therefore, libtool is disabling shared libraries support. If you +*** really care for shared libraries, you may want to modify your PATH +*** so that a non-GNU linker is found, and then restart. + +EOF + fi + ;; + + amigaos*) + archive_cmds_GCJ='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec_GCJ='-L$libdir' + hardcode_minus_L_GCJ=yes + + # Samuel A. Falvo II reports + # that the semantics of dynamic libraries on AmigaOS, at least up + # to version 4, is to share data among multiple programs linked + # with the same dynamic library. Since this doesn't match the + # behavior of shared libraries on other platforms, we can't use + # them. + ld_shlibs_GCJ=no + ;; + + beos*) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + allow_undefined_flag_GCJ=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + archive_cmds_GCJ='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + else + ld_shlibs_GCJ=no + fi + ;; + + cygwin* | mingw* | pw32*) + # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, GCJ) is actually meaningless, + # as there is no search path for DLLs. + hardcode_libdir_flag_spec_GCJ='-L$libdir' + allow_undefined_flag_GCJ=unsupported + always_export_symbols_GCJ=no + enable_shared_with_static_runtimes_GCJ=yes + export_symbols_cmds_GCJ='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS] /s/.* \([^ ]*\)/\1 DATA/'\'' | $SED -e '\''/^[AITW] /s/.* //'\'' | sort | uniq > $export_symbols' + + if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then + archive_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + archive_expsym_cmds_GCJ='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + else + ld_shlibs_GCJ=no + fi + ;; + + linux*) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + tmp_addflag= + case $cc_basename,$host_cpu in + pgcc*) # Portland Group C compiler + whole_archive_flag_spec_GCJ='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag' + ;; + pgf77* | pgf90* | pgf95*) # Portland Group f77 and f90 compilers + whole_archive_flag_spec_GCJ='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}--no-whole-archive' + tmp_addflag=' $pic_flag -Mnomain' ;; + ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 + tmp_addflag=' -i_dynamic' ;; + efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 + tmp_addflag=' -i_dynamic -nofor_main' ;; + ifc* | ifort*) # Intel Fortran compiler + tmp_addflag=' -nofor_main' ;; + esac + archive_cmds_GCJ='$CC -shared'"$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + + if test $supports_anon_versioning = yes; then + archive_expsym_cmds_GCJ='$echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + $echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC -shared'"$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib' + fi + link_all_deplibs_GCJ=no + else + ld_shlibs_GCJ=no + fi + ;; + + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + archive_cmds_GCJ='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' + wlarc= + else + archive_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + fi + ;; + + solaris* | sysv5*) + if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then + ld_shlibs_GCJ=no + cat <&2 + +*** Warning: The releases 2.8.* of the GNU linker cannot reliably +*** create shared libraries on Solaris systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.9.1 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +EOF + elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + archive_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs_GCJ=no + fi + ;; + + sunos4*) + archive_cmds_GCJ='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' + wlarc= + hardcode_direct_GCJ=yes + hardcode_shlibpath_var_GCJ=no + ;; + + *) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + archive_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs_GCJ=no + fi + ;; + esac + + if test "$ld_shlibs_GCJ" = no; then + runpath_var= + hardcode_libdir_flag_spec_GCJ= + export_dynamic_flag_spec_GCJ= + whole_archive_flag_spec_GCJ= + fi + else + # PORTME fill in a description of your system's linker (not GNU ld) + case $host_os in + aix3*) + allow_undefined_flag_GCJ=unsupported + always_export_symbols_GCJ=yes + archive_expsym_cmds_GCJ='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' + # Note: this linker hardcodes the directories in LIBPATH if there + # are no directories specified by -L. + hardcode_minus_L_GCJ=yes + if test "$GCC" = yes && test -z "$link_static_flag"; then + # Neither direct hardcoding nor static linking is supported with a + # broken collect2. + hardcode_direct_GCJ=unsupported + fi + ;; + + aix4* | aix5*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | grep 'GNU' > /dev/null; then + export_symbols_cmds_GCJ='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' + else + export_symbols_cmds_GCJ='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$2 == "T") || (\$2 == "D") || (\$2 == "B")) && (substr(\$3,1,1) != ".")) { print \$3 } }'\'' | sort -u > $export_symbols' + fi + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # need to do runtime linking. + case $host_os in aix4.[23]|aix4.[23].*|aix5*) + for ld_flag in $LDFLAGS; do + if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then + aix_use_runtimelinking=yes + break + fi + done + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + archive_cmds_GCJ='' + hardcode_direct_GCJ=yes + hardcode_libdir_separator_GCJ=':' + link_all_deplibs_GCJ=yes + + if test "$GCC" = yes; then + case $host_os in aix4.[012]|aix4.[012].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && \ + strings "$collect2name" | grep resolve_lib_name >/dev/null + then + # We have reworked collect2 + hardcode_direct_GCJ=yes + else + # We have old collect2 + hardcode_direct_GCJ=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + hardcode_minus_L_GCJ=yes + hardcode_libdir_flag_spec_GCJ='-L$libdir' + hardcode_libdir_separator_GCJ= + fi + esac + shared_flag='-shared' + if test "$aix_use_runtimelinking" = yes; then + shared_flag="$shared_flag "'${wl}-G' + fi + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='${wl}-G' + else + shared_flag='${wl}-bM:SRE' + fi + fi + fi + + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to export. + always_export_symbols_GCJ=yes + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + allow_undefined_flag_GCJ='-berok' + # Determine the default libpath from the value encoded in an empty executable. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'`; fi +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec_GCJ='${wl}-blibpath:$libdir:'"$aix_libpath" + archive_expsym_cmds_GCJ="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + hardcode_libdir_flag_spec_GCJ='${wl}-R $libdir:/usr/lib:/lib' + allow_undefined_flag_GCJ="-z nodefs" + archive_expsym_cmds_GCJ="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an empty executable. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'`; fi +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi + + hardcode_libdir_flag_spec_GCJ='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + no_undefined_flag_GCJ=' ${wl}-bernotok' + allow_undefined_flag_GCJ=' ${wl}-berok' + # -bexpall does not export symbols beginning with underscore (_) + always_export_symbols_GCJ=yes + # Exported symbols can be pulled into shared objects from archives + whole_archive_flag_spec_GCJ=' ' + archive_cmds_need_lc_GCJ=yes + # This is similar to how AIX traditionally builds its shared libraries. + archive_expsym_cmds_GCJ="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}-bE:$export_symbols ${wl}-bnoentry${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + + amigaos*) + archive_cmds_GCJ='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec_GCJ='-L$libdir' + hardcode_minus_L_GCJ=yes + # see comment about different semantics on the GNU ld section + ld_shlibs_GCJ=no + ;; + + bsdi[45]*) + export_dynamic_flag_spec_GCJ=-rdynamic + ;; + + cygwin* | mingw* | pw32*) + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + hardcode_libdir_flag_spec_GCJ=' ' + allow_undefined_flag_GCJ=unsupported + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=".dll" + # FIXME: Setting linknames here is a bad hack. + archive_cmds_GCJ='$CC -o $lib $libobjs $compiler_flags `echo "$deplibs" | $SED -e '\''s/ -lc$//'\''` -link -dll~linknames=' + # The linker will automatically build a .lib file if we build a DLL. + old_archive_From_new_cmds_GCJ='true' + # FIXME: Should let the user specify the lib program. + old_archive_cmds_GCJ='lib /OUT:$oldlib$oldobjs$old_deplibs' + fix_srcfile_path_GCJ='`cygpath -w "$srcfile"`' + enable_shared_with_static_runtimes_GCJ=yes + ;; + + darwin* | rhapsody*) + case $host_os in + rhapsody* | darwin1.[012]) + allow_undefined_flag_GCJ='${wl}-undefined ${wl}suppress' + ;; + *) # Darwin 1.3 on + if test -z ${MACOSX_DEPLOYMENT_TARGET} ; then + allow_undefined_flag_GCJ='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + else + case ${MACOSX_DEPLOYMENT_TARGET} in + 10.[012]) + allow_undefined_flag_GCJ='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' + ;; + 10.*) + allow_undefined_flag_GCJ='${wl}-undefined ${wl}dynamic_lookup' + ;; + esac + fi + ;; + esac + archive_cmds_need_lc_GCJ=no + hardcode_direct_GCJ=no + hardcode_automatic_GCJ=yes + hardcode_shlibpath_var_GCJ=unsupported + whole_archive_flag_spec_GCJ='' + link_all_deplibs_GCJ=yes + if test "$GCC" = yes ; then + output_verbose_link_cmd='echo' + archive_cmds_GCJ='$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + module_cmds_GCJ='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + archive_expsym_cmds_GCJ='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + module_expsym_cmds_GCJ='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + else + case $cc_basename in + xlc*) + output_verbose_link_cmd='echo' + archive_cmds_GCJ='$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $verstring' + module_cmds_GCJ='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin lds + archive_expsym_cmds_GCJ='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + module_expsym_cmds_GCJ='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + ;; + *) + ld_shlibs_GCJ=no + ;; + esac + fi + ;; + + dgux*) + archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec_GCJ='-L$libdir' + hardcode_shlibpath_var_GCJ=no + ;; + + freebsd1*) + ld_shlibs_GCJ=no + ;; + + # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor + # support. Future versions do this automatically, but an explicit c++rt0.o + # does not break anything, and helps significantly (at the cost of a little + # extra space). + freebsd2.2*) + archive_cmds_GCJ='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' + hardcode_libdir_flag_spec_GCJ='-R$libdir' + hardcode_direct_GCJ=yes + hardcode_shlibpath_var_GCJ=no + ;; + + # Unfortunately, older versions of FreeBSD 2 do not have this feature. + freebsd2*) + archive_cmds_GCJ='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct_GCJ=yes + hardcode_minus_L_GCJ=yes + hardcode_shlibpath_var_GCJ=no + ;; + + # FreeBSD 3 and greater uses gcc -shared to do shared libraries. + freebsd* | kfreebsd*-gnu | dragonfly*) + archive_cmds_GCJ='$CC -shared -o $lib $libobjs $deplibs $compiler_flags' + hardcode_libdir_flag_spec_GCJ='-R$libdir' + hardcode_direct_GCJ=yes + hardcode_shlibpath_var_GCJ=no + ;; + + hpux9*) + if test "$GCC" = yes; then + archive_cmds_GCJ='$rm $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + archive_cmds_GCJ='$rm $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + fi + hardcode_libdir_flag_spec_GCJ='${wl}+b ${wl}$libdir' + hardcode_libdir_separator_GCJ=: + hardcode_direct_GCJ=yes + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L_GCJ=yes + export_dynamic_flag_spec_GCJ='${wl}-E' + ;; + + hpux10* | hpux11*) + if test "$GCC" = yes -a "$with_gnu_ld" = no; then + case $host_cpu in + hppa*64*|ia64*) + archive_cmds_GCJ='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + archive_cmds_GCJ='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + else + case $host_cpu in + hppa*64*|ia64*) + archive_cmds_GCJ='$LD -b +h $soname -o $lib $libobjs $deplibs $linker_flags' + ;; + *) + archive_cmds_GCJ='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' + ;; + esac + fi + if test "$with_gnu_ld" = no; then + case $host_cpu in + hppa*64*) + hardcode_libdir_flag_spec_GCJ='${wl}+b ${wl}$libdir' + hardcode_libdir_flag_spec_ld_GCJ='+b $libdir' + hardcode_libdir_separator_GCJ=: + hardcode_direct_GCJ=no + hardcode_shlibpath_var_GCJ=no + ;; + ia64*) + hardcode_libdir_flag_spec_GCJ='-L$libdir' + hardcode_direct_GCJ=no + hardcode_shlibpath_var_GCJ=no + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L_GCJ=yes + ;; + *) + hardcode_libdir_flag_spec_GCJ='${wl}+b ${wl}$libdir' + hardcode_libdir_separator_GCJ=: + hardcode_direct_GCJ=yes + export_dynamic_flag_spec_GCJ='${wl}-E' + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L_GCJ=yes + ;; + esac + fi + ;; + + irix5* | irix6* | nonstopux*) + if test "$GCC" = yes; then + archive_cmds_GCJ='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + archive_cmds_GCJ='$LD -shared $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + hardcode_libdir_flag_spec_ld_GCJ='-rpath $libdir' + fi + hardcode_libdir_flag_spec_GCJ='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_GCJ=: + link_all_deplibs_GCJ=yes + ;; + + netbsd* | netbsdelf*-gnu | knetbsd*-gnu) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + archive_cmds_GCJ='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out + else + archive_cmds_GCJ='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF + fi + hardcode_libdir_flag_spec_GCJ='-R$libdir' + hardcode_direct_GCJ=yes + hardcode_shlibpath_var_GCJ=no + ;; + + newsos6) + archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct_GCJ=yes + hardcode_libdir_flag_spec_GCJ='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_GCJ=: + hardcode_shlibpath_var_GCJ=no + ;; + + openbsd*) + hardcode_direct_GCJ=yes + hardcode_shlibpath_var_GCJ=no + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + archive_cmds_GCJ='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_GCJ='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols' + hardcode_libdir_flag_spec_GCJ='${wl}-rpath,$libdir' + export_dynamic_flag_spec_GCJ='${wl}-E' + else + case $host_os in + openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*) + archive_cmds_GCJ='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec_GCJ='-R$libdir' + ;; + *) + archive_cmds_GCJ='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + hardcode_libdir_flag_spec_GCJ='${wl}-rpath,$libdir' + ;; + esac + fi + ;; + + os2*) + hardcode_libdir_flag_spec_GCJ='-L$libdir' + hardcode_minus_L_GCJ=yes + allow_undefined_flag_GCJ=unsupported + archive_cmds_GCJ='$echo "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$echo "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$echo DATA >> $output_objdir/$libname.def~$echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~$echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' + old_archive_From_new_cmds_GCJ='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' + ;; + + osf3*) + if test "$GCC" = yes; then + allow_undefined_flag_GCJ=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds_GCJ='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + allow_undefined_flag_GCJ=' -expect_unresolved \*' + archive_cmds_GCJ='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + fi + hardcode_libdir_flag_spec_GCJ='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator_GCJ=: + ;; + + osf4* | osf5*) # as osf3* with the addition of -msym flag + if test "$GCC" = yes; then + allow_undefined_flag_GCJ=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds_GCJ='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + hardcode_libdir_flag_spec_GCJ='${wl}-rpath ${wl}$libdir' + else + allow_undefined_flag_GCJ=' -expect_unresolved \*' + archive_cmds_GCJ='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + archive_expsym_cmds_GCJ='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; echo "-hidden">> $lib.exp~ + $LD -shared${allow_undefined_flag} -input $lib.exp $linker_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib~$rm $lib.exp' + + # Both c and cxx compiler support -rpath directly + hardcode_libdir_flag_spec_GCJ='-rpath $libdir' + fi + hardcode_libdir_separator_GCJ=: + ;; + + sco3.2v5*) + archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var_GCJ=no + export_dynamic_flag_spec_GCJ='${wl}-Bexport' + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ;; + + solaris*) + no_undefined_flag_GCJ=' -z text' + if test "$GCC" = yes; then + wlarc='${wl}' + archive_cmds_GCJ='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_GCJ='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -shared ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$rm $lib.exp' + else + wlarc='' + archive_cmds_GCJ='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + archive_expsym_cmds_GCJ='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' + fi + hardcode_libdir_flag_spec_GCJ='-R$libdir' + hardcode_shlibpath_var_GCJ=no + case $host_os in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) + # The compiler driver will combine linker options so we + # cannot just pass the convience library names through + # without $wl, iff we do not link with $LD. + # Luckily, gcc supports the same syntax we need for Sun Studio. + # Supported since Solaris 2.6 (maybe 2.5.1?) + case $wlarc in + '') + whole_archive_flag_spec_GCJ='-z allextract$convenience -z defaultextract' ;; + *) + whole_archive_flag_spec_GCJ='${wl}-z ${wl}allextract`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}-z ${wl}defaultextract' ;; + esac ;; + esac + link_all_deplibs_GCJ=yes + ;; + + sunos4*) + if test "x$host_vendor" = xsequent; then + # Use $CC to link under sequent, because it throws in some extra .o + # files that make .init and .fini sections work. + archive_cmds_GCJ='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds_GCJ='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' + fi + hardcode_libdir_flag_spec_GCJ='-L$libdir' + hardcode_direct_GCJ=yes + hardcode_minus_L_GCJ=yes + hardcode_shlibpath_var_GCJ=no + ;; + + sysv4) + case $host_vendor in + sni) + archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct_GCJ=yes # is this really true??? + ;; + siemens) + ## LD is ld it makes a PLAMLIB + ## CC just makes a GrossModule. + archive_cmds_GCJ='$LD -G -o $lib $libobjs $deplibs $linker_flags' + reload_cmds_GCJ='$CC -r -o $output$reload_objs' + hardcode_direct_GCJ=no + ;; + motorola) + archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct_GCJ=no #Motorola manual says yes, but my tests say they lie + ;; + esac + runpath_var='LD_RUN_PATH' + hardcode_shlibpath_var_GCJ=no + ;; + + sysv4.3*) + archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var_GCJ=no + export_dynamic_flag_spec_GCJ='-Bexport' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var_GCJ=no + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ld_shlibs_GCJ=yes + fi + ;; + + sysv4.2uw2*) + archive_cmds_GCJ='$LD -G -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct_GCJ=yes + hardcode_minus_L_GCJ=no + hardcode_shlibpath_var_GCJ=no + hardcode_runpath_var=yes + runpath_var=LD_RUN_PATH + ;; + + sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[78]* | unixware7*) + no_undefined_flag_GCJ='${wl}-z ${wl}text' + if test "$GCC" = yes; then + archive_cmds_GCJ='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds_GCJ='$CC -G ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + runpath_var='LD_RUN_PATH' + hardcode_shlibpath_var_GCJ=no + ;; + + sysv5*) + no_undefined_flag_GCJ=' -z text' + # $CC -shared without GNU ld will not create a library from C++ + # object files and a static libstdc++, better avoid it by now + archive_cmds_GCJ='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + archive_expsym_cmds_GCJ='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' + hardcode_libdir_flag_spec_GCJ= + hardcode_shlibpath_var_GCJ=no + runpath_var='LD_RUN_PATH' + ;; + + uts4*) + archive_cmds_GCJ='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec_GCJ='-L$libdir' + hardcode_shlibpath_var_GCJ=no + ;; + + *) + ld_shlibs_GCJ=no + ;; + esac + fi + +echo "$as_me:$LINENO: result: $ld_shlibs_GCJ" >&5 +echo "${ECHO_T}$ld_shlibs_GCJ" >&6 +test "$ld_shlibs_GCJ" = no && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test "$GCC" = yes; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +# +# Do we need to explicitly link libc? +# +case "x$archive_cmds_need_lc_GCJ" in +x|xyes) + # Assume -lc should be added + archive_cmds_need_lc_GCJ=yes + + if test "$enable_shared" = yes && test "$GCC" = yes; then + case $archive_cmds_GCJ in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + echo "$as_me:$LINENO: checking whether -lc should be explicitly linked in" >&5 +echo $ECHO_N "checking whether -lc should be explicitly linked in... $ECHO_C" >&6 + $rm conftest* + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$lt_prog_compiler_wl_GCJ + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$allow_undefined_flag_GCJ + allow_undefined_flag_GCJ= + if { (eval echo "$as_me:$LINENO: \"$archive_cmds_GCJ 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1\"") >&5 + (eval $archive_cmds_GCJ 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + then + archive_cmds_need_lc_GCJ=no + else + archive_cmds_need_lc_GCJ=yes + fi + allow_undefined_flag_GCJ=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $rm conftest* + echo "$as_me:$LINENO: result: $archive_cmds_need_lc_GCJ" >&5 +echo "${ECHO_T}$archive_cmds_need_lc_GCJ" >&6 + ;; + esac + fi + ;; +esac + +echo "$as_me:$LINENO: checking dynamic linker characteristics" >&5 +echo $ECHO_N "checking dynamic linker characteristics... $ECHO_C" >&6 +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext_cmds=".so" +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +if test "$GCC" = yes; then + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if echo "$sys_lib_search_path_spec" | grep ';' >/dev/null ; then + # if the path contains ";" then we assume it to be the separator + # otherwise default to the standard path separator (i.e. ":") - it is + # assumed that no part of a normal pathname contains ";" but that should + # okay in the real world where ";" in dirpaths is itself problematic. + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi +else + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +fi +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + +case $host_os in +aix3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='${libname}${release}${shared_ext}$major' + ;; + +aix4* | aix5*) + version_type=linux + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test "$host_cpu" = ia64; then + # AIX 5 supports IA64 + library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line `#! .'. This would cause the generated library to + # depend on `.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[01] | aix4.[01].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | ${CC} -E - | grep yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # AIX (on Power*) has no versioning support, so currently we can not hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + if test "$aix_use_runtimelinking" = yes; then + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + else + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='${libname}${release}.a $libname.a' + soname_spec='${libname}${release}${shared_ext}$major' + fi + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$echo "X$lib" | $Xsed -e '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $rm /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' + ;; + +beos*) + library_names_spec='${libname}${shared_ext}' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi[45]*) + version_type=linux + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32*) + version_type=windows + shrext_cmds=".dll" + need_version=no + need_lib_prefix=no + + case $GCC,$host_os in + yes,cygwin* | yes,mingw* | yes,pw32*) + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \${file}`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $rm \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" + ;; + mingw*) + # MinGW DLLs use traditional 'lib' prefix + soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if echo "$sys_lib_search_path_spec" | grep ';[c-zC-Z]:/' >/dev/null; then + # It is most probably a Windows format PATH printed by + # mingw gcc, but we are running on Cygwin. Gcc prints its search + # path with ; separators, and with drive letters. We can handle the + # drive letters (cygwin fileutils understands them), so leave them, + # especially as we might pass files found there to a mingw objdump, + # which wouldn't understand a cygwinified path. Ahh. + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + ;; + esac + ;; + + *) + library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib' + ;; + esac + dynamic_linker='Win32 ld.exe' + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext' + soname_spec='${libname}${release}${major}$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' + # Apple's gcc prints 'gcc -print-search-dirs' doesn't operate the same. + if test "$GCC" = yes; then + sys_lib_search_path_spec=`$CC -print-search-dirs | tr "\n" "$PATH_SEPARATOR" | sed -e 's/libraries:/@libraries:/' | tr "@" "\n" | grep "^libraries:" | sed -e "s/^libraries://" -e "s,=/,/,g" -e "s,$PATH_SEPARATOR, ,g" -e "s,.*,& /lib /usr/lib /usr/local/lib,g"` + else + sys_lib_search_path_spec='/lib /usr/lib /usr/local/lib' + fi + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd1*) + dynamic_linker=no + ;; + +kfreebsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='GNU ld.so' + ;; + +freebsd* | dragonfly*) + # DragonFly does not have aout. When/if they implement a new + # versioning mechanism, adjust this. + if test -x /usr/bin/objformat; then + objformat=`/usr/bin/objformat` + else + case $host_os in + freebsd[123]*) objformat=aout ;; + *) objformat=elf ;; + esac + fi + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[01]* | freebsdelf3.[01]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + *) # from 3.2 on + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + esac + ;; + +gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case $host_cpu in + ia64*) + shrext_cmds='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + if test "X$HPUX_IA64_MODE" = X32; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + fi + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + hppa*64*) + shrext_cmds='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext_cmds='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555. + postinstall_cmds='chmod 555 $lib' + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test "$lt_cv_prog_gnu_ld" = yes; then + version_type=linux + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" + sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +# This must be Linux ELF. +linux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # Append ld.so.conf contents to the search path + if test -f /etc/ld.so.conf; then + lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;/^$/d' | tr '\n' ' '` + sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" + fi + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsdelf*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='NetBSD ld.elf_so' + ;; + +knetbsd*-gnu) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='GNU ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +nto-qnx*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +openbsd*) + version_type=sunos + need_lib_prefix=no + # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs. + case $host_os in + openbsd3.3 | openbsd3.3.*) need_version=yes ;; + *) need_version=no ;; + esac + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + case $host_os in + openbsd2.[89] | openbsd2.[89].*) + shlibpath_overrides_runpath=no + ;; + *) + shlibpath_overrides_runpath=yes + ;; + esac + else + shlibpath_overrides_runpath=yes + fi + ;; + +os2*) + libname_spec='$name' + shrext_cmds=".dll" + need_lib_prefix=no + library_names_spec='$libname${shared_ext} $libname.a' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=LIBPATH + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" + ;; + +sco3.2v5*) + version_type=osf + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + ;; + +solaris*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test "$with_gnu_ld" = yes; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + export_dynamic_flag_spec='${wl}-Blargedynsym' + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec ;then + version_type=linux + library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' + soname_spec='$libname${shared_ext}.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +uts4*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +echo "$as_me:$LINENO: result: $dynamic_linker" >&5 +echo "${ECHO_T}$dynamic_linker" >&6 +test "$dynamic_linker" = no && can_build_shared=no + +echo "$as_me:$LINENO: checking how to hardcode library paths into programs" >&5 +echo $ECHO_N "checking how to hardcode library paths into programs... $ECHO_C" >&6 +hardcode_action_GCJ= +if test -n "$hardcode_libdir_flag_spec_GCJ" || \ + test -n "$runpath_var_GCJ" || \ + test "X$hardcode_automatic_GCJ" = "Xyes" ; then + + # We can hardcode non-existant directories. + if test "$hardcode_direct_GCJ" != no && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, GCJ)" != no && + test "$hardcode_minus_L_GCJ" != no; then + # Linking always hardcodes the temporary library directory. + hardcode_action_GCJ=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + hardcode_action_GCJ=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + hardcode_action_GCJ=unsupported +fi +echo "$as_me:$LINENO: result: $hardcode_action_GCJ" >&5 +echo "${ECHO_T}$hardcode_action_GCJ" >&6 + +if test "$hardcode_action_GCJ" = relink; then + # Fast installation is not supported + enable_fast_install=no +elif test "$shlibpath_overrides_runpath" = yes || + test "$enable_shared" = no; then + # Fast installation is not necessary + enable_fast_install=needless +fi + +striplib= +old_striplib= +echo "$as_me:$LINENO: checking whether stripping libraries is possible" >&5 +echo $ECHO_N "checking whether stripping libraries is possible... $ECHO_C" >&6 +if test -n "$STRIP" && $STRIP -V 2>&1 | grep "GNU strip" >/dev/null; then + test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" + test -z "$striplib" && striplib="$STRIP --strip-unneeded" + echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 +else +# FIXME - insert some real tests, host_os isn't really good enough + case $host_os in + darwin*) + if test -n "$STRIP" ; then + striplib="$STRIP -x" + echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6 + else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + ;; + *) + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 + ;; + esac +fi + +if test "x$enable_dlopen" != xyes; then + enable_dlopen=unknown + enable_dlopen_self=unknown + enable_dlopen_self_static=unknown +else + lt_cv_dlopen=no + lt_cv_dlopen_libs= + + case $host_os in + beos*) + lt_cv_dlopen="load_add_on" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ;; + + mingw* | pw32*) + lt_cv_dlopen="LoadLibrary" + lt_cv_dlopen_libs= + ;; + + cygwin*) + lt_cv_dlopen="dlopen" + lt_cv_dlopen_libs= + ;; + + darwin*) + # if libdl is installed we need to link against it + echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5 +echo $ECHO_N "checking for dlopen in -ldl... $ECHO_C" >&6 +if test "${ac_cv_lib_dl_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldl $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +int +main () +{ +dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dl_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dl_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5 +echo "${ECHO_T}$ac_cv_lib_dl_dlopen" >&6 +if test $ac_cv_lib_dl_dlopen = yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" +else + + lt_cv_dlopen="dyld" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + +fi + + ;; + + *) + echo "$as_me:$LINENO: checking for shl_load" >&5 +echo $ECHO_N "checking for shl_load... $ECHO_C" >&6 +if test "${ac_cv_func_shl_load+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define shl_load to an innocuous variant, in case declares shl_load. + For example, HP-UX 11i declares gettimeofday. */ +#define shl_load innocuous_shl_load + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char shl_load (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef shl_load + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +{ +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char shl_load (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_shl_load) || defined (__stub___shl_load) +choke me +#else +char (*f) () = shl_load; +#endif +#ifdef __cplusplus +} +#endif + +int +main () +{ +return f != shl_load; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_func_shl_load=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_func_shl_load=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_func_shl_load" >&5 +echo "${ECHO_T}$ac_cv_func_shl_load" >&6 +if test $ac_cv_func_shl_load = yes; then + lt_cv_dlopen="shl_load" +else + echo "$as_me:$LINENO: checking for shl_load in -ldld" >&5 +echo $ECHO_N "checking for shl_load in -ldld... $ECHO_C" >&6 +if test "${ac_cv_lib_dld_shl_load+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char shl_load (); +int +main () +{ +shl_load (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dld_shl_load=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dld_shl_load=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dld_shl_load" >&5 +echo "${ECHO_T}$ac_cv_lib_dld_shl_load" >&6 +if test $ac_cv_lib_dld_shl_load = yes; then + lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-dld" +else + echo "$as_me:$LINENO: checking for dlopen" >&5 +echo $ECHO_N "checking for dlopen... $ECHO_C" >&6 +if test "${ac_cv_func_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define dlopen to an innocuous variant, in case declares dlopen. + For example, HP-UX 11i declares gettimeofday. */ +#define dlopen innocuous_dlopen + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char dlopen (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef dlopen + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +{ +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_dlopen) || defined (__stub___dlopen) +choke me +#else +char (*f) () = dlopen; +#endif +#ifdef __cplusplus +} +#endif + +int +main () +{ +return f != dlopen; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_func_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_func_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_func_dlopen" >&5 +echo "${ECHO_T}$ac_cv_func_dlopen" >&6 +if test $ac_cv_func_dlopen = yes; then + lt_cv_dlopen="dlopen" +else + echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5 +echo $ECHO_N "checking for dlopen in -ldl... $ECHO_C" >&6 +if test "${ac_cv_lib_dl_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldl $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +int +main () +{ +dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dl_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dl_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5 +echo "${ECHO_T}$ac_cv_lib_dl_dlopen" >&6 +if test $ac_cv_lib_dl_dlopen = yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" +else + echo "$as_me:$LINENO: checking for dlopen in -lsvld" >&5 +echo $ECHO_N "checking for dlopen in -lsvld... $ECHO_C" >&6 +if test "${ac_cv_lib_svld_dlopen+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lsvld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dlopen (); +int +main () +{ +dlopen (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_svld_dlopen=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_svld_dlopen=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_svld_dlopen" >&5 +echo "${ECHO_T}$ac_cv_lib_svld_dlopen" >&6 +if test $ac_cv_lib_svld_dlopen = yes; then + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld" +else + echo "$as_me:$LINENO: checking for dld_link in -ldld" >&5 +echo $ECHO_N "checking for dld_link in -ldld... $ECHO_C" >&6 +if test "${ac_cv_lib_dld_dld_link+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldld $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char dld_link (); +int +main () +{ +dld_link (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_dld_dld_link=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_dld_dld_link=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_dld_dld_link" >&5 +echo "${ECHO_T}$ac_cv_lib_dld_dld_link" >&6 +if test $ac_cv_lib_dld_dld_link = yes; then + lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-dld" +fi + + +fi + + +fi + + +fi + + +fi + + +fi + + ;; + esac + + if test "x$lt_cv_dlopen" != xno; then + enable_dlopen=yes + else + enable_dlopen=no + fi + + case $lt_cv_dlopen in + dlopen) + save_CPPFLAGS="$CPPFLAGS" + test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" + + save_LDFLAGS="$LDFLAGS" + eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" + + save_LIBS="$LIBS" + LIBS="$lt_cv_dlopen_libs $LIBS" + + echo "$as_me:$LINENO: checking whether a program can dlopen itself" >&5 +echo $ECHO_N "checking whether a program can dlopen itself... $ECHO_C" >&6 +if test "${lt_cv_dlopen_self+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$cross_compiling" = yes; then : + lt_cv_dlopen_self=cross +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext < +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +#ifdef __cplusplus +extern "C" void exit (int); +#endif + +void fnord() { int i=42;} +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + /* dlclose (self); */ + } + + exit (status); +} +EOF + if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then + (./conftest; exit; ) >&5 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;; + x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;; + x$lt_unknown|x*) lt_cv_dlopen_self=no ;; + esac + else : + # compilation failed + lt_cv_dlopen_self=no + fi +fi +rm -fr conftest* + + +fi +echo "$as_me:$LINENO: result: $lt_cv_dlopen_self" >&5 +echo "${ECHO_T}$lt_cv_dlopen_self" >&6 + + if test "x$lt_cv_dlopen_self" = xyes; then + LDFLAGS="$LDFLAGS $link_static_flag" + echo "$as_me:$LINENO: checking whether a statically linked program can dlopen itself" >&5 +echo $ECHO_N "checking whether a statically linked program can dlopen itself... $ECHO_C" >&6 +if test "${lt_cv_dlopen_self_static+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$cross_compiling" = yes; then : + lt_cv_dlopen_self_static=cross +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext < +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +#ifdef __cplusplus +extern "C" void exit (int); +#endif + +void fnord() { int i=42;} +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + /* dlclose (self); */ + } + + exit (status); +} +EOF + if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then + (./conftest; exit; ) >&5 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;; + x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;; + x$lt_unknown|x*) lt_cv_dlopen_self_static=no ;; + esac + else : + # compilation failed + lt_cv_dlopen_self_static=no + fi +fi +rm -fr conftest* + + +fi +echo "$as_me:$LINENO: result: $lt_cv_dlopen_self_static" >&5 +echo "${ECHO_T}$lt_cv_dlopen_self_static" >&6 + fi + + CPPFLAGS="$save_CPPFLAGS" + LDFLAGS="$save_LDFLAGS" + LIBS="$save_LIBS" + ;; + esac + + case $lt_cv_dlopen_self in + yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; + *) enable_dlopen_self=unknown ;; + esac + + case $lt_cv_dlopen_self_static in + yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; + *) enable_dlopen_self_static=unknown ;; + esac +fi + + +# The else clause should only fire when bootstrapping the +# libtool distribution, otherwise you forgot to ship ltmain.sh +# with your package, and you will get complaints that there are +# no rules to generate ltmain.sh. +if test -f "$ltmain"; then + # See if we are running on zsh, and set the options which allow our commands through + # without removal of \ escapes. + if test -n "${ZSH_VERSION+set}" ; then + setopt NO_GLOB_SUBST + fi + # Now quote all the things that may contain metacharacters while being + # careful not to overquote the AC_SUBSTed values. We take copies of the + # variables and quote the copies for generation of the libtool script. + for var in echo old_CC old_CFLAGS AR AR_FLAGS EGREP RANLIB LN_S LTCC NM \ + SED SHELL STRIP \ + libname_spec library_names_spec soname_spec extract_expsyms_cmds \ + old_striplib striplib file_magic_cmd finish_cmds finish_eval \ + deplibs_check_method reload_flag reload_cmds need_locks \ + lt_cv_sys_global_symbol_pipe lt_cv_sys_global_symbol_to_cdecl \ + lt_cv_sys_global_symbol_to_c_name_address \ + sys_lib_search_path_spec sys_lib_dlsearch_path_spec \ + old_postinstall_cmds old_postuninstall_cmds \ + compiler_GCJ \ + CC_GCJ \ + LD_GCJ \ + lt_prog_compiler_wl_GCJ \ + lt_prog_compiler_pic_GCJ \ + lt_prog_compiler_static_GCJ \ + lt_prog_compiler_no_builtin_flag_GCJ \ + export_dynamic_flag_spec_GCJ \ + thread_safe_flag_spec_GCJ \ + whole_archive_flag_spec_GCJ \ + enable_shared_with_static_runtimes_GCJ \ + old_archive_cmds_GCJ \ + old_archive_from_new_cmds_GCJ \ + predep_objects_GCJ \ + postdep_objects_GCJ \ + predeps_GCJ \ + postdeps_GCJ \ + compiler_lib_search_path_GCJ \ + archive_cmds_GCJ \ + archive_expsym_cmds_GCJ \ + postinstall_cmds_GCJ \ + postuninstall_cmds_GCJ \ + old_archive_from_expsyms_cmds_GCJ \ + allow_undefined_flag_GCJ \ + no_undefined_flag_GCJ \ + export_symbols_cmds_GCJ \ + hardcode_libdir_flag_spec_GCJ \ + hardcode_libdir_flag_spec_ld_GCJ \ + hardcode_libdir_separator_GCJ \ + hardcode_automatic_GCJ \ + module_cmds_GCJ \ + module_expsym_cmds_GCJ \ + lt_cv_prog_compiler_c_o_GCJ \ + exclude_expsyms_GCJ \ + include_expsyms_GCJ; do + + case $var in + old_archive_cmds_GCJ | \ + old_archive_from_new_cmds_GCJ | \ + archive_cmds_GCJ | \ + archive_expsym_cmds_GCJ | \ + module_cmds_GCJ | \ + module_expsym_cmds_GCJ | \ + old_archive_from_expsyms_cmds_GCJ | \ + export_symbols_cmds_GCJ | \ + extract_expsyms_cmds | reload_cmds | finish_cmds | \ + postinstall_cmds | postuninstall_cmds | \ + old_postinstall_cmds | old_postuninstall_cmds | \ + sys_lib_search_path_spec | sys_lib_dlsearch_path_spec) + # Double-quote double-evaled strings. + eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\"" + ;; + *) + eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\"" + ;; + esac + done + + case $lt_echo in + *'\$0 --fallback-echo"') + lt_echo=`$echo "X$lt_echo" | $Xsed -e 's/\\\\\\\$0 --fallback-echo"$/$0 --fallback-echo"/'` + ;; + esac + +cfgfile="$ofile" + + cat <<__EOF__ >> "$cfgfile" +# ### BEGIN LIBTOOL TAG CONFIG: $tagname + +# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: + +# Shell to use when invoking shell scripts. +SHELL=$lt_SHELL + +# Whether or not to build shared libraries. +build_libtool_libs=$enable_shared + +# Whether or not to build static libraries. +build_old_libs=$enable_static + +# Whether or not to add -lc for building shared libraries. +build_libtool_need_lc=$archive_cmds_need_lc_GCJ + +# Whether or not to disallow shared libs when runtime libs are static +allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_GCJ + +# Whether or not to optimize for fast installation. +fast_install=$enable_fast_install + +# The host system. +host_alias=$host_alias +host=$host +host_os=$host_os + +# The build system. +build_alias=$build_alias +build=$build +build_os=$build_os + +# An echo program that does not interpret backslashes. +echo=$lt_echo + +# The archiver. +AR=$lt_AR +AR_FLAGS=$lt_AR_FLAGS + +# A C compiler. +LTCC=$lt_LTCC + +# A language-specific compiler. +CC=$lt_compiler_GCJ + +# Is the compiler the GNU C compiler? +with_gcc=$GCC_GCJ + +# An ERE matcher. +EGREP=$lt_EGREP + +# The linker used to build libraries. +LD=$lt_LD_GCJ + +# Whether we need hard or soft links. +LN_S=$lt_LN_S + +# A BSD-compatible nm program. +NM=$lt_NM + +# A symbol stripping program +STRIP=$lt_STRIP + +# Used to examine libraries when file_magic_cmd begins "file" +MAGIC_CMD=$MAGIC_CMD + +# Used on cygwin: DLL creation program. +DLLTOOL="$DLLTOOL" + +# Used on cygwin: object dumper. +OBJDUMP="$OBJDUMP" + +# Used on cygwin: assembler. +AS="$AS" + +# The name of the directory that contains temporary libtool files. +objdir=$objdir + +# How to create reloadable object files. +reload_flag=$lt_reload_flag +reload_cmds=$lt_reload_cmds + +# How to pass a linker flag through the compiler. +wl=$lt_lt_prog_compiler_wl_GCJ + +# Object file suffix (normally "o"). +objext="$ac_objext" + +# Old archive suffix (normally "a"). +libext="$libext" + +# Shared library suffix (normally ".so"). +shrext_cmds='$shrext_cmds' + +# Executable file suffix (normally ""). +exeext="$exeext" + +# Additional compiler flags for building library objects. +pic_flag=$lt_lt_prog_compiler_pic_GCJ +pic_mode=$pic_mode + +# What is the maximum length of a command? +max_cmd_len=$lt_cv_sys_max_cmd_len + +# Does compiler simultaneously support -c and -o options? +compiler_c_o=$lt_lt_cv_prog_compiler_c_o_GCJ + +# Must we lock files when doing compilation? +need_locks=$lt_need_locks + +# Do we need the lib prefix for modules? +need_lib_prefix=$need_lib_prefix + +# Do we need a version for libraries? +need_version=$need_version + +# Whether dlopen is supported. +dlopen_support=$enable_dlopen + +# Whether dlopen of programs is supported. +dlopen_self=$enable_dlopen_self + +# Whether dlopen of statically linked programs is supported. +dlopen_self_static=$enable_dlopen_self_static + +# Compiler flag to prevent dynamic linking. +link_static_flag=$lt_lt_prog_compiler_static_GCJ + +# Compiler flag to turn off builtin functions. +no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_GCJ + +# Compiler flag to allow reflexive dlopens. +export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_GCJ + +# Compiler flag to generate shared objects directly from archives. +whole_archive_flag_spec=$lt_whole_archive_flag_spec_GCJ + +# Compiler flag to generate thread-safe objects. +thread_safe_flag_spec=$lt_thread_safe_flag_spec_GCJ + +# Library versioning type. +version_type=$version_type + +# Format of library name prefix. +libname_spec=$lt_libname_spec + +# List of archive names. First name is the real one, the rest are links. +# The last name is the one that the linker finds with -lNAME. +library_names_spec=$lt_library_names_spec + +# The coded name of the library, if different from the real name. +soname_spec=$lt_soname_spec + +# Commands used to build and install an old-style archive. +RANLIB=$lt_RANLIB +old_archive_cmds=$lt_old_archive_cmds_GCJ +old_postinstall_cmds=$lt_old_postinstall_cmds +old_postuninstall_cmds=$lt_old_postuninstall_cmds + +# Create an old-style archive from a shared archive. +old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_GCJ + +# Create a temporary old-style archive to link instead of a shared archive. +old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_GCJ + +# Commands used to build and install a shared archive. +archive_cmds=$lt_archive_cmds_GCJ +archive_expsym_cmds=$lt_archive_expsym_cmds_GCJ +postinstall_cmds=$lt_postinstall_cmds +postuninstall_cmds=$lt_postuninstall_cmds + +# Commands used to build a loadable module (assumed same as above if empty) +module_cmds=$lt_module_cmds_GCJ +module_expsym_cmds=$lt_module_expsym_cmds_GCJ + +# Commands to strip libraries. +old_striplib=$lt_old_striplib +striplib=$lt_striplib + +# Dependencies to place before the objects being linked to create a +# shared library. +predep_objects=$lt_predep_objects_GCJ + +# Dependencies to place after the objects being linked to create a +# shared library. +postdep_objects=$lt_postdep_objects_GCJ + +# Dependencies to place before the objects being linked to create a +# shared library. +predeps=$lt_predeps_GCJ + +# Dependencies to place after the objects being linked to create a +# shared library. +postdeps=$lt_postdeps_GCJ + +# The library search path used internally by the compiler when linking +# a shared library. +compiler_lib_search_path=$lt_compiler_lib_search_path_GCJ + +# Method to check whether dependent libraries are shared objects. +deplibs_check_method=$lt_deplibs_check_method + +# Command to use when deplibs_check_method == file_magic. +file_magic_cmd=$lt_file_magic_cmd + +# Flag that allows shared libraries with undefined symbols to be built. +allow_undefined_flag=$lt_allow_undefined_flag_GCJ + +# Flag that forces no undefined symbols. +no_undefined_flag=$lt_no_undefined_flag_GCJ + +# Commands used to finish a libtool library installation in a directory. +finish_cmds=$lt_finish_cmds + +# Same as above, but a single script fragment to be evaled but not shown. +finish_eval=$lt_finish_eval + +# Take the output of nm and produce a listing of raw symbols and C names. +global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe + +# Transform the output of nm in a proper C declaration +global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl + +# Transform the output of nm in a C name address pair +global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address + +# This is the shared library runtime path variable. +runpath_var=$runpath_var + +# This is the shared library path variable. +shlibpath_var=$shlibpath_var + +# Is shlibpath searched before the hard-coded library search path? +shlibpath_overrides_runpath=$shlibpath_overrides_runpath + +# How to hardcode a shared library path into an executable. +hardcode_action=$hardcode_action_GCJ + +# Whether we should hardcode library paths into libraries. +hardcode_into_libs=$hardcode_into_libs + +# Flag to hardcode \$libdir into a binary during linking. +# This must work even if \$libdir does not exist. +hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_GCJ + +# If ld is used when linking, flag to hardcode \$libdir into +# a binary during linking. This must work even if \$libdir does +# not exist. +hardcode_libdir_flag_spec_ld=$lt_hardcode_libdir_flag_spec_ld_GCJ + +# Whether we need a single -rpath flag with a separated argument. +hardcode_libdir_separator=$lt_hardcode_libdir_separator_GCJ + +# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the +# resulting binary. +hardcode_direct=$hardcode_direct_GCJ + +# Set to yes if using the -LDIR flag during linking hardcodes DIR into the +# resulting binary. +hardcode_minus_L=$hardcode_minus_L_GCJ + +# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into +# the resulting binary. +hardcode_shlibpath_var=$hardcode_shlibpath_var_GCJ + +# Set to yes if building a shared library automatically hardcodes DIR into the library +# and all subsequent libraries and executables linked against it. +hardcode_automatic=$hardcode_automatic_GCJ + +# Variables whose values should be saved in libtool wrapper scripts and +# restored at relink time. +variables_saved_for_relink="$variables_saved_for_relink" + +# Whether libtool must link a program against all its dependency libraries. +link_all_deplibs=$link_all_deplibs_GCJ + +# Compile-time system search path for libraries +sys_lib_search_path_spec=$lt_sys_lib_search_path_spec + +# Run-time system search path for libraries +sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec + +# Fix the shell variable \$srcfile for the compiler. +fix_srcfile_path="$fix_srcfile_path_GCJ" + +# Set to yes if exported symbols are required. +always_export_symbols=$always_export_symbols_GCJ + +# The commands to list exported symbols. +export_symbols_cmds=$lt_export_symbols_cmds_GCJ + +# The commands to extract the exported symbol list from a shared archive. +extract_expsyms_cmds=$lt_extract_expsyms_cmds + +# Symbols that should not be listed in the preloaded symbols. +exclude_expsyms=$lt_exclude_expsyms_GCJ + +# Symbols that must always be exported. +include_expsyms=$lt_include_expsyms_GCJ + +# ### END LIBTOOL TAG CONFIG: $tagname + +__EOF__ + + +else + # If there is no Makefile yet, we rely on a make rule to execute + # `config.status --recheck' to rerun these tests and create the + # libtool script then. + ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'` + if test -f "$ltmain_in"; then + test -f Makefile && make "$ltmain" + fi +fi + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +CC="$lt_save_CC" + + else + tagname="" + fi + ;; + + RC) + + + +# Source file extension for RC test sources. +ac_ext=rc + +# Object file extension for compiled RC test sources. +objext=o +objext_RC=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }\n' + +# Code to be used in simple link tests +lt_simple_link_test_code="$lt_simple_compile_test_code" + +# ltmain only uses $CC for tagged configurations so make sure $CC is set. + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# Allow CC to be a program name with arguments. +compiler=$CC + + +# save warnings/boilerplate of simple test code +ac_outfile=conftest.$ac_objext +printf "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$rm conftest* + +ac_outfile=conftest.$ac_objext +printf "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$rm conftest* + + +# Allow CC to be a program name with arguments. +lt_save_CC="$CC" +CC=${RC-"windres"} +compiler=$CC +compiler_RC=$CC +for cc_temp in $compiler""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac +done +cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"` + +lt_cv_prog_compiler_c_o_RC=yes + +# The else clause should only fire when bootstrapping the +# libtool distribution, otherwise you forgot to ship ltmain.sh +# with your package, and you will get complaints that there are +# no rules to generate ltmain.sh. +if test -f "$ltmain"; then + # See if we are running on zsh, and set the options which allow our commands through + # without removal of \ escapes. + if test -n "${ZSH_VERSION+set}" ; then + setopt NO_GLOB_SUBST + fi + # Now quote all the things that may contain metacharacters while being + # careful not to overquote the AC_SUBSTed values. We take copies of the + # variables and quote the copies for generation of the libtool script. + for var in echo old_CC old_CFLAGS AR AR_FLAGS EGREP RANLIB LN_S LTCC NM \ + SED SHELL STRIP \ + libname_spec library_names_spec soname_spec extract_expsyms_cmds \ + old_striplib striplib file_magic_cmd finish_cmds finish_eval \ + deplibs_check_method reload_flag reload_cmds need_locks \ + lt_cv_sys_global_symbol_pipe lt_cv_sys_global_symbol_to_cdecl \ + lt_cv_sys_global_symbol_to_c_name_address \ + sys_lib_search_path_spec sys_lib_dlsearch_path_spec \ + old_postinstall_cmds old_postuninstall_cmds \ + compiler_RC \ + CC_RC \ + LD_RC \ + lt_prog_compiler_wl_RC \ + lt_prog_compiler_pic_RC \ + lt_prog_compiler_static_RC \ + lt_prog_compiler_no_builtin_flag_RC \ + export_dynamic_flag_spec_RC \ + thread_safe_flag_spec_RC \ + whole_archive_flag_spec_RC \ + enable_shared_with_static_runtimes_RC \ + old_archive_cmds_RC \ + old_archive_from_new_cmds_RC \ + predep_objects_RC \ + postdep_objects_RC \ + predeps_RC \ + postdeps_RC \ + compiler_lib_search_path_RC \ + archive_cmds_RC \ + archive_expsym_cmds_RC \ + postinstall_cmds_RC \ + postuninstall_cmds_RC \ + old_archive_from_expsyms_cmds_RC \ + allow_undefined_flag_RC \ + no_undefined_flag_RC \ + export_symbols_cmds_RC \ + hardcode_libdir_flag_spec_RC \ + hardcode_libdir_flag_spec_ld_RC \ + hardcode_libdir_separator_RC \ + hardcode_automatic_RC \ + module_cmds_RC \ + module_expsym_cmds_RC \ + lt_cv_prog_compiler_c_o_RC \ + exclude_expsyms_RC \ + include_expsyms_RC; do + + case $var in + old_archive_cmds_RC | \ + old_archive_from_new_cmds_RC | \ + archive_cmds_RC | \ + archive_expsym_cmds_RC | \ + module_cmds_RC | \ + module_expsym_cmds_RC | \ + old_archive_from_expsyms_cmds_RC | \ + export_symbols_cmds_RC | \ + extract_expsyms_cmds | reload_cmds | finish_cmds | \ + postinstall_cmds | postuninstall_cmds | \ + old_postinstall_cmds | old_postuninstall_cmds | \ + sys_lib_search_path_spec | sys_lib_dlsearch_path_spec) + # Double-quote double-evaled strings. + eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\"" + ;; + *) + eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\"" + ;; + esac + done + + case $lt_echo in + *'\$0 --fallback-echo"') + lt_echo=`$echo "X$lt_echo" | $Xsed -e 's/\\\\\\\$0 --fallback-echo"$/$0 --fallback-echo"/'` + ;; + esac + +cfgfile="$ofile" + + cat <<__EOF__ >> "$cfgfile" +# ### BEGIN LIBTOOL TAG CONFIG: $tagname + +# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: + +# Shell to use when invoking shell scripts. +SHELL=$lt_SHELL + +# Whether or not to build shared libraries. +build_libtool_libs=$enable_shared + +# Whether or not to build static libraries. +build_old_libs=$enable_static + +# Whether or not to add -lc for building shared libraries. +build_libtool_need_lc=$archive_cmds_need_lc_RC + +# Whether or not to disallow shared libs when runtime libs are static +allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_RC + +# Whether or not to optimize for fast installation. +fast_install=$enable_fast_install + +# The host system. +host_alias=$host_alias +host=$host +host_os=$host_os + +# The build system. +build_alias=$build_alias +build=$build +build_os=$build_os + +# An echo program that does not interpret backslashes. +echo=$lt_echo + +# The archiver. +AR=$lt_AR +AR_FLAGS=$lt_AR_FLAGS + +# A C compiler. +LTCC=$lt_LTCC + +# A language-specific compiler. +CC=$lt_compiler_RC + +# Is the compiler the GNU C compiler? +with_gcc=$GCC_RC + +# An ERE matcher. +EGREP=$lt_EGREP + +# The linker used to build libraries. +LD=$lt_LD_RC + +# Whether we need hard or soft links. +LN_S=$lt_LN_S + +# A BSD-compatible nm program. +NM=$lt_NM + +# A symbol stripping program +STRIP=$lt_STRIP + +# Used to examine libraries when file_magic_cmd begins "file" +MAGIC_CMD=$MAGIC_CMD + +# Used on cygwin: DLL creation program. +DLLTOOL="$DLLTOOL" + +# Used on cygwin: object dumper. +OBJDUMP="$OBJDUMP" + +# Used on cygwin: assembler. +AS="$AS" + +# The name of the directory that contains temporary libtool files. +objdir=$objdir + +# How to create reloadable object files. +reload_flag=$lt_reload_flag +reload_cmds=$lt_reload_cmds + +# How to pass a linker flag through the compiler. +wl=$lt_lt_prog_compiler_wl_RC + +# Object file suffix (normally "o"). +objext="$ac_objext" + +# Old archive suffix (normally "a"). +libext="$libext" + +# Shared library suffix (normally ".so"). +shrext_cmds='$shrext_cmds' + +# Executable file suffix (normally ""). +exeext="$exeext" + +# Additional compiler flags for building library objects. +pic_flag=$lt_lt_prog_compiler_pic_RC +pic_mode=$pic_mode + +# What is the maximum length of a command? +max_cmd_len=$lt_cv_sys_max_cmd_len + +# Does compiler simultaneously support -c and -o options? +compiler_c_o=$lt_lt_cv_prog_compiler_c_o_RC + +# Must we lock files when doing compilation? +need_locks=$lt_need_locks + +# Do we need the lib prefix for modules? +need_lib_prefix=$need_lib_prefix + +# Do we need a version for libraries? +need_version=$need_version + +# Whether dlopen is supported. +dlopen_support=$enable_dlopen + +# Whether dlopen of programs is supported. +dlopen_self=$enable_dlopen_self + +# Whether dlopen of statically linked programs is supported. +dlopen_self_static=$enable_dlopen_self_static + +# Compiler flag to prevent dynamic linking. +link_static_flag=$lt_lt_prog_compiler_static_RC + +# Compiler flag to turn off builtin functions. +no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_RC + +# Compiler flag to allow reflexive dlopens. +export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_RC + +# Compiler flag to generate shared objects directly from archives. +whole_archive_flag_spec=$lt_whole_archive_flag_spec_RC + +# Compiler flag to generate thread-safe objects. +thread_safe_flag_spec=$lt_thread_safe_flag_spec_RC + +# Library versioning type. +version_type=$version_type + +# Format of library name prefix. +libname_spec=$lt_libname_spec + +# List of archive names. First name is the real one, the rest are links. +# The last name is the one that the linker finds with -lNAME. +library_names_spec=$lt_library_names_spec + +# The coded name of the library, if different from the real name. +soname_spec=$lt_soname_spec + +# Commands used to build and install an old-style archive. +RANLIB=$lt_RANLIB +old_archive_cmds=$lt_old_archive_cmds_RC +old_postinstall_cmds=$lt_old_postinstall_cmds +old_postuninstall_cmds=$lt_old_postuninstall_cmds + +# Create an old-style archive from a shared archive. +old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_RC + +# Create a temporary old-style archive to link instead of a shared archive. +old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_RC + +# Commands used to build and install a shared archive. +archive_cmds=$lt_archive_cmds_RC +archive_expsym_cmds=$lt_archive_expsym_cmds_RC +postinstall_cmds=$lt_postinstall_cmds +postuninstall_cmds=$lt_postuninstall_cmds + +# Commands used to build a loadable module (assumed same as above if empty) +module_cmds=$lt_module_cmds_RC +module_expsym_cmds=$lt_module_expsym_cmds_RC + +# Commands to strip libraries. +old_striplib=$lt_old_striplib +striplib=$lt_striplib + +# Dependencies to place before the objects being linked to create a +# shared library. +predep_objects=$lt_predep_objects_RC + +# Dependencies to place after the objects being linked to create a +# shared library. +postdep_objects=$lt_postdep_objects_RC + +# Dependencies to place before the objects being linked to create a +# shared library. +predeps=$lt_predeps_RC + +# Dependencies to place after the objects being linked to create a +# shared library. +postdeps=$lt_postdeps_RC + +# The library search path used internally by the compiler when linking +# a shared library. +compiler_lib_search_path=$lt_compiler_lib_search_path_RC + +# Method to check whether dependent libraries are shared objects. +deplibs_check_method=$lt_deplibs_check_method + +# Command to use when deplibs_check_method == file_magic. +file_magic_cmd=$lt_file_magic_cmd + +# Flag that allows shared libraries with undefined symbols to be built. +allow_undefined_flag=$lt_allow_undefined_flag_RC + +# Flag that forces no undefined symbols. +no_undefined_flag=$lt_no_undefined_flag_RC + +# Commands used to finish a libtool library installation in a directory. +finish_cmds=$lt_finish_cmds + +# Same as above, but a single script fragment to be evaled but not shown. +finish_eval=$lt_finish_eval + +# Take the output of nm and produce a listing of raw symbols and C names. +global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe + +# Transform the output of nm in a proper C declaration +global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl + +# Transform the output of nm in a C name address pair +global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address + +# This is the shared library runtime path variable. +runpath_var=$runpath_var + +# This is the shared library path variable. +shlibpath_var=$shlibpath_var + +# Is shlibpath searched before the hard-coded library search path? +shlibpath_overrides_runpath=$shlibpath_overrides_runpath + +# How to hardcode a shared library path into an executable. +hardcode_action=$hardcode_action_RC + +# Whether we should hardcode library paths into libraries. +hardcode_into_libs=$hardcode_into_libs + +# Flag to hardcode \$libdir into a binary during linking. +# This must work even if \$libdir does not exist. +hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_RC + +# If ld is used when linking, flag to hardcode \$libdir into +# a binary during linking. This must work even if \$libdir does +# not exist. +hardcode_libdir_flag_spec_ld=$lt_hardcode_libdir_flag_spec_ld_RC + +# Whether we need a single -rpath flag with a separated argument. +hardcode_libdir_separator=$lt_hardcode_libdir_separator_RC + +# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the +# resulting binary. +hardcode_direct=$hardcode_direct_RC + +# Set to yes if using the -LDIR flag during linking hardcodes DIR into the +# resulting binary. +hardcode_minus_L=$hardcode_minus_L_RC + +# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into +# the resulting binary. +hardcode_shlibpath_var=$hardcode_shlibpath_var_RC + +# Set to yes if building a shared library automatically hardcodes DIR into the library +# and all subsequent libraries and executables linked against it. +hardcode_automatic=$hardcode_automatic_RC + +# Variables whose values should be saved in libtool wrapper scripts and +# restored at relink time. +variables_saved_for_relink="$variables_saved_for_relink" + +# Whether libtool must link a program against all its dependency libraries. +link_all_deplibs=$link_all_deplibs_RC + +# Compile-time system search path for libraries +sys_lib_search_path_spec=$lt_sys_lib_search_path_spec + +# Run-time system search path for libraries +sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec + +# Fix the shell variable \$srcfile for the compiler. +fix_srcfile_path="$fix_srcfile_path_RC" + +# Set to yes if exported symbols are required. +always_export_symbols=$always_export_symbols_RC + +# The commands to list exported symbols. +export_symbols_cmds=$lt_export_symbols_cmds_RC + +# The commands to extract the exported symbol list from a shared archive. +extract_expsyms_cmds=$lt_extract_expsyms_cmds + +# Symbols that should not be listed in the preloaded symbols. +exclude_expsyms=$lt_exclude_expsyms_RC + +# Symbols that must always be exported. +include_expsyms=$lt_include_expsyms_RC + +# ### END LIBTOOL TAG CONFIG: $tagname + +__EOF__ + + +else + # If there is no Makefile yet, we rely on a make rule to execute + # `config.status --recheck' to rerun these tests and create the + # libtool script then. + ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'` + if test -f "$ltmain_in"; then + test -f Makefile && make "$ltmain" + fi +fi + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +CC="$lt_save_CC" + + ;; + + *) + { { echo "$as_me:$LINENO: error: Unsupported tag name: $tagname" >&5 +echo "$as_me: error: Unsupported tag name: $tagname" >&2;} + { (exit 1); exit 1; }; } + ;; + esac + + # Append the new tag name to the list of available tags. + if test -n "$tagname" ; then + available_tags="$available_tags $tagname" + fi + fi + done + IFS="$lt_save_ifs" + + # Now substitute the updated list of available tags. + if eval "sed -e 's/^available_tags=.*\$/available_tags=\"$available_tags\"/' \"$ofile\" > \"${ofile}T\""; then + mv "${ofile}T" "$ofile" + chmod +x "$ofile" + else + rm -f "${ofile}T" + { { echo "$as_me:$LINENO: error: unable to update list of available tagged configurations." >&5 +echo "$as_me: error: unable to update list of available tagged configurations." >&2;} + { (exit 1); exit 1; }; } + fi +fi + + + +# This can be used to rebuild libtool when needed +LIBTOOL_DEPS="$ac_aux_dir/ltmain.sh" + +# Always use our own libtool. +LIBTOOL='$(SHELL) $(top_builddir)/libtool' + +# Prevent multiple expansion + + + + + + + + + + + + + + + + + + + + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +echo "$as_me:$LINENO: checking how to run the C preprocessor" >&5 +echo $ECHO_N "checking how to run the C preprocessor... $ECHO_C" >&6 +# On Suns, sometimes $CPP names a directory. +if test -n "$CPP" && test -d "$CPP"; then + CPP= +fi +if test -z "$CPP"; then + if test "${ac_cv_prog_CPP+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + # Double quotes because CPP needs to be expanded + for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" + do + ac_preproc_ok=false +for ac_c_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + : +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether non-existent headers + # can be detected and how. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + # Broken: success on invalid input. +continue +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then + break +fi + + done + ac_cv_prog_CPP=$CPP + +fi + CPP=$ac_cv_prog_CPP +else + ac_cv_prog_CPP=$CPP +fi +echo "$as_me:$LINENO: result: $CPP" >&5 +echo "${ECHO_T}$CPP" >&6 +ac_preproc_ok=false +for ac_c_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + : +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.$ac_ext + + # OK, works on sane cases. Now check whether non-existent headers + # can be detected and how. + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + # Broken: success on invalid input. +continue +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.err conftest.$ac_ext +if $ac_preproc_ok; then + : +else + { { echo "$as_me:$LINENO: error: C preprocessor \"$CPP\" fails sanity check +See \`config.log' for more details." >&5 +echo "$as_me: error: C preprocessor \"$CPP\" fails sanity check +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +ac_ext=cc +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu +if test -n "$ac_tool_prefix"; then + for ac_prog in $CCC g++ c++ gpp aCC CC cxx cc++ cl FCC KCC RCC xlC_r xlC + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_CXX+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$CXX"; then + ac_cv_prog_CXX="$CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CXX="$ac_tool_prefix$ac_prog" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +CXX=$ac_cv_prog_CXX +if test -n "$CXX"; then + echo "$as_me:$LINENO: result: $CXX" >&5 +echo "${ECHO_T}$CXX" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + test -n "$CXX" && break + done +fi +if test -z "$CXX"; then + ac_ct_CXX=$CXX + for ac_prog in $CCC g++ c++ gpp aCC CC cxx cc++ cl FCC KCC RCC xlC_r xlC +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_ac_ct_CXX+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$ac_ct_CXX"; then + ac_cv_prog_ac_ct_CXX="$ac_ct_CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_CXX="$ac_prog" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +ac_ct_CXX=$ac_cv_prog_ac_ct_CXX +if test -n "$ac_ct_CXX"; then + echo "$as_me:$LINENO: result: $ac_ct_CXX" >&5 +echo "${ECHO_T}$ac_ct_CXX" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + test -n "$ac_ct_CXX" && break +done +test -n "$ac_ct_CXX" || ac_ct_CXX="g++" + + CXX=$ac_ct_CXX +fi + + +# Provide some information about the compiler. +echo "$as_me:$LINENO:" \ + "checking for C++ compiler version" >&5 +ac_compiler=`set X $ac_compile; echo $2` +{ (eval echo "$as_me:$LINENO: \"$ac_compiler --version &5\"") >&5 + (eval $ac_compiler --version &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (eval echo "$as_me:$LINENO: \"$ac_compiler -v &5\"") >&5 + (eval $ac_compiler -v &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } +{ (eval echo "$as_me:$LINENO: \"$ac_compiler -V &5\"") >&5 + (eval $ac_compiler -V &5) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + +echo "$as_me:$LINENO: checking whether we are using the GNU C++ compiler" >&5 +echo $ECHO_N "checking whether we are using the GNU C++ compiler... $ECHO_C" >&6 +if test "${ac_cv_cxx_compiler_gnu+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_compiler_gnu=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_compiler_gnu=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_cxx_compiler_gnu=$ac_compiler_gnu + +fi +echo "$as_me:$LINENO: result: $ac_cv_cxx_compiler_gnu" >&5 +echo "${ECHO_T}$ac_cv_cxx_compiler_gnu" >&6 +GXX=`test $ac_compiler_gnu = yes && echo yes` +ac_test_CXXFLAGS=${CXXFLAGS+set} +ac_save_CXXFLAGS=$CXXFLAGS +CXXFLAGS="-g" +echo "$as_me:$LINENO: checking whether $CXX accepts -g" >&5 +echo $ECHO_N "checking whether $CXX accepts -g... $ECHO_C" >&6 +if test "${ac_cv_prog_cxx_g+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_prog_cxx_g=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_prog_cxx_g=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_prog_cxx_g" >&5 +echo "${ECHO_T}$ac_cv_prog_cxx_g" >&6 +if test "$ac_test_CXXFLAGS" = set; then + CXXFLAGS=$ac_save_CXXFLAGS +elif test $ac_cv_prog_cxx_g = yes; then + if test "$GXX" = yes; then + CXXFLAGS="-g -O2" + else + CXXFLAGS="-g" + fi +else + if test "$GXX" = yes; then + CXXFLAGS="-O2" + else + CXXFLAGS= + fi +fi +for ac_declaration in \ + '' \ + 'extern "C" void std::exit (int) throw (); using std::exit;' \ + 'extern "C" void std::exit (int); using std::exit;' \ + 'extern "C" void exit (int) throw ();' \ + 'extern "C" void exit (int);' \ + 'void exit (int);' +do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_declaration +#include +int +main () +{ +exit (42); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + : +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +continue +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_declaration +int +main () +{ +exit (42); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_cxx_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +done +rm -f conftest* +if test -n "$ac_declaration"; then + echo '#ifdef __cplusplus' >>confdefs.h + echo $ac_declaration >>confdefs.h + echo '#endif' >>confdefs.h +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +depcc="$CXX" am_compiler_list= + +echo "$as_me:$LINENO: checking dependency style of $depcc" >&5 +echo $ECHO_N "checking dependency style of $depcc... $ECHO_C" >&6 +if test "${am_cv_CXX_dependencies_compiler_type+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named `D' -- because `-MD' means `put the output + # in D'. + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_CXX_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` + fi + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with + # Solaris 8's {/usr,}/bin/sh. + touch sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + case $depmode in + nosideeffect) + # after this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + none) break ;; + esac + # We check with `-c' and `-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle `-M -o', and we need to detect this. + if depmode=$depmode \ + source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_CXX_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_CXX_dependencies_compiler_type=none +fi + +fi +echo "$as_me:$LINENO: result: $am_cv_CXX_dependencies_compiler_type" >&5 +echo "${ECHO_T}$am_cv_CXX_dependencies_compiler_type" >&6 +CXXDEPMODE=depmode=$am_cv_CXX_dependencies_compiler_type + + + +if + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_CXX_dependencies_compiler_type" = gcc3; then + am__fastdepCXX_TRUE= + am__fastdepCXX_FALSE='#' +else + am__fastdepCXX_TRUE='#' + am__fastdepCXX_FALSE= +fi + + + +if test "$cross_compiling" = yes; then + { { echo "$as_me:$LINENO: error: cannot run test program while cross compiling +See \`config.log' for more details." >&5 +echo "$as_me: error: cannot run test program while cross compiling +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#include +main() +{ +#if defined(__GNUC__) && \ + ! (__GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 95)) + return 1; +#endif + return 0; +} + +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + : +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +echo "need at least gcc 2.95 to compile correctly" +exit 1 +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi + +# The Ultrix 4.2 mips builtin alloca declared by alloca.h only works +# for constant arguments. Useless! +echo "$as_me:$LINENO: checking for working alloca.h" >&5 +echo $ECHO_N "checking for working alloca.h... $ECHO_C" >&6 +if test "${ac_cv_working_alloca_h+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +char *p = (char *) alloca (2 * sizeof (int)); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_working_alloca_h=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_working_alloca_h=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_working_alloca_h" >&5 +echo "${ECHO_T}$ac_cv_working_alloca_h" >&6 +if test $ac_cv_working_alloca_h = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_ALLOCA_H 1 +_ACEOF + +fi + +echo "$as_me:$LINENO: checking for alloca" >&5 +echo $ECHO_N "checking for alloca... $ECHO_C" >&6 +if test "${ac_cv_func_alloca_works+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifdef __GNUC__ +# define alloca __builtin_alloca +#else +# ifdef _MSC_VER +# include +# define alloca _alloca +# else +# if HAVE_ALLOCA_H +# include +# else +# ifdef _AIX + #pragma alloca +# else +# ifndef alloca /* predefined by HP cc +Olibcalls */ +char *alloca (); +# endif +# endif +# endif +# endif +#endif + +int +main () +{ +char *p = (char *) alloca (1); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_func_alloca_works=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_func_alloca_works=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_func_alloca_works" >&5 +echo "${ECHO_T}$ac_cv_func_alloca_works" >&6 + +if test $ac_cv_func_alloca_works = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_ALLOCA 1 +_ACEOF + +else + # The SVR3 libPW and SVR4 libucb both contain incompatible functions +# that cause trouble. Some versions do not even contain alloca or +# contain a buggy version. If you still want to use their alloca, +# use ar to extract alloca.o from them instead of compiling alloca.c. + +ALLOCA=alloca.$ac_objext + +cat >>confdefs.h <<\_ACEOF +#define C_ALLOCA 1 +_ACEOF + + +echo "$as_me:$LINENO: checking whether \`alloca.c' needs Cray hooks" >&5 +echo $ECHO_N "checking whether \`alloca.c' needs Cray hooks... $ECHO_C" >&6 +if test "${ac_cv_os_cray+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#if defined(CRAY) && ! defined(CRAY2) +webecray +#else +wenotbecray +#endif + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "webecray" >/dev/null 2>&1; then + ac_cv_os_cray=yes +else + ac_cv_os_cray=no +fi +rm -f conftest* + +fi +echo "$as_me:$LINENO: result: $ac_cv_os_cray" >&5 +echo "${ECHO_T}$ac_cv_os_cray" >&6 +if test $ac_cv_os_cray = yes; then + for ac_func in _getb67 GETB67 getb67; do + as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh` +echo "$as_me:$LINENO: checking for $ac_func" >&5 +echo $ECHO_N "checking for $ac_func... $ECHO_C" >&6 +if eval "test \"\${$as_ac_var+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define $ac_func to an innocuous variant, in case declares $ac_func. + For example, HP-UX 11i declares gettimeofday. */ +#define $ac_func innocuous_$ac_func + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char $ac_func (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef $ac_func + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +{ +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char $ac_func (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_$ac_func) || defined (__stub___$ac_func) +choke me +#else +char (*f) () = $ac_func; +#endif +#ifdef __cplusplus +} +#endif + +int +main () +{ +return f != $ac_func; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + eval "$as_ac_var=yes" +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +eval "$as_ac_var=no" +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_var'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_var'}'`" >&6 +if test `eval echo '${'$as_ac_var'}'` = yes; then + +cat >>confdefs.h <<_ACEOF +#define CRAY_STACKSEG_END $ac_func +_ACEOF + + break +fi + + done +fi + +echo "$as_me:$LINENO: checking stack direction for C alloca" >&5 +echo $ECHO_N "checking stack direction for C alloca... $ECHO_C" >&6 +if test "${ac_cv_c_stack_direction+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$cross_compiling" = yes; then + ac_cv_c_stack_direction=0 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +int +find_stack_direction () +{ + static char *addr = 0; + auto char dummy; + if (addr == 0) + { + addr = &dummy; + return find_stack_direction (); + } + else + return (&dummy > addr) ? 1 : -1; +} + +int +main () +{ + exit (find_stack_direction () < 0); +} +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_c_stack_direction=1 +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +ac_cv_c_stack_direction=-1 +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +fi +echo "$as_me:$LINENO: result: $ac_cv_c_stack_direction" >&5 +echo "${ECHO_T}$ac_cv_c_stack_direction" >&6 + +cat >>confdefs.h <<_ACEOF +#define STACK_DIRECTION $ac_cv_c_stack_direction +_ACEOF + + +fi + + +echo "$as_me:$LINENO: checking for getopt_long in -lc" >&5 +echo $ECHO_N "checking for getopt_long in -lc... $ECHO_C" >&6 +if test "${ac_cv_lib_c_getopt_long+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lc $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char getopt_long (); +int +main () +{ +getopt_long (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_c_getopt_long=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_c_getopt_long=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_c_getopt_long" >&5 +echo "${ECHO_T}$ac_cv_lib_c_getopt_long" >&6 +if test $ac_cv_lib_c_getopt_long = yes; then + cat >>confdefs.h <<\_ACEOF +#define HAVE_GETOPT_LONG 1 +_ACEOF + +fi + + +echo "$as_me:$LINENO: checking for alarm in -lc" >&5 +echo $ECHO_N "checking for alarm in -lc... $ECHO_C" >&6 +if test "${ac_cv_lib_c_alarm+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lc $LIBS" +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char alarm (); +int +main () +{ +alarm (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_lib_c_alarm=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_lib_c_alarm=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_lib_c_alarm" >&5 +echo "${ECHO_T}$ac_cv_lib_c_alarm" >&6 +if test $ac_cv_lib_c_alarm = yes; then + cat >>confdefs.h <<\_ACEOF +#define HAVE_ALARM 1 +_ACEOF + +fi + + + +for ac_header in netinet/in.h +do +as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 +else + # Is the header compilable? +echo "$as_me:$LINENO: checking $ac_header usability" >&5 +echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_header_compiler=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_header_compiler=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 +echo "${ECHO_T}$ac_header_compiler" >&6 + +# Is the header present? +echo "$as_me:$LINENO: checking $ac_header presence" >&5 +echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include <$ac_header> +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + ac_header_preproc=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_preproc=no +fi +rm -f conftest.err conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 +echo "${ECHO_T}$ac_header_preproc" >&6 + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in + yes:no: ) + { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 +echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} + ac_header_preproc=yes + ;; + no:yes:* ) + { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 +echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 +echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 +echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 +echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 +echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} + ( + cat <<\_ASBOX +## ------------------------------------------ ## +## Report this to the AC_PACKAGE_NAME lists. ## +## ------------------------------------------ ## +_ASBOX + ) | + sed "s/^/$as_me: WARNING: /" >&2 + ;; +esac +echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + eval "$as_ac_Header=\$ac_header_preproc" +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 + +fi +if test `eval echo '${'$as_ac_Header'}'` = yes; then + cat >>confdefs.h <<_ACEOF +#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + + +for ac_header in string.h +do +as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 +else + # Is the header compilable? +echo "$as_me:$LINENO: checking $ac_header usability" >&5 +echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_header_compiler=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_header_compiler=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 +echo "${ECHO_T}$ac_header_compiler" >&6 + +# Is the header present? +echo "$as_me:$LINENO: checking $ac_header presence" >&5 +echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include <$ac_header> +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + ac_header_preproc=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_preproc=no +fi +rm -f conftest.err conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 +echo "${ECHO_T}$ac_header_preproc" >&6 + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in + yes:no: ) + { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 +echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} + ac_header_preproc=yes + ;; + no:yes:* ) + { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 +echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 +echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 +echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 +echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 +echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} + ( + cat <<\_ASBOX +## ------------------------------------------ ## +## Report this to the AC_PACKAGE_NAME lists. ## +## ------------------------------------------ ## +_ASBOX + ) | + sed "s/^/$as_me: WARNING: /" >&2 + ;; +esac +echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + eval "$as_ac_Header=\$ac_header_preproc" +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 + +fi +if test `eval echo '${'$as_ac_Header'}'` = yes; then + cat >>confdefs.h <<_ACEOF +#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + + +for ac_header in libintl.h +do +as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 +else + # Is the header compilable? +echo "$as_me:$LINENO: checking $ac_header usability" >&5 +echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_header_compiler=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_header_compiler=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 +echo "${ECHO_T}$ac_header_compiler" >&6 + +# Is the header present? +echo "$as_me:$LINENO: checking $ac_header presence" >&5 +echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include <$ac_header> +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + ac_header_preproc=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_preproc=no +fi +rm -f conftest.err conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 +echo "${ECHO_T}$ac_header_preproc" >&6 + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in + yes:no: ) + { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 +echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} + ac_header_preproc=yes + ;; + no:yes:* ) + { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 +echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 +echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 +echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 +echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 +echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} + ( + cat <<\_ASBOX +## ------------------------------------------ ## +## Report this to the AC_PACKAGE_NAME lists. ## +## ------------------------------------------ ## +_ASBOX + ) | + sed "s/^/$as_me: WARNING: /" >&2 + ;; +esac +echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + eval "$as_ac_Header=\$ac_header_preproc" +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 + +fi +if test `eval echo '${'$as_ac_Header'}'` = yes; then + cat >>confdefs.h <<_ACEOF +#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + +echo "$as_me:$LINENO: checking for an ANSI C-conforming const" >&5 +echo $ECHO_N "checking for an ANSI C-conforming const... $ECHO_C" >&6 +if test "${ac_cv_c_const+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ +/* FIXME: Include the comments suggested by Paul. */ +#ifndef __cplusplus + /* Ultrix mips cc rejects this. */ + typedef int charset[2]; + const charset x; + /* SunOS 4.1.1 cc rejects this. */ + char const *const *ccp; + char **p; + /* NEC SVR4.0.2 mips cc rejects this. */ + struct point {int x, y;}; + static struct point const zero = {0,0}; + /* AIX XL C 1.02.0.0 rejects this. + It does not let you subtract one const X* pointer from another in + an arm of an if-expression whose if-part is not a constant + expression */ + const char *g = "string"; + ccp = &g + (g ? g-g : 0); + /* HPUX 7.0 cc rejects these. */ + ++ccp; + p = (char**) ccp; + ccp = (char const *const *) p; + { /* SCO 3.2v4 cc rejects this. */ + char *t; + char const *s = 0 ? (char *) 0 : (char const *) 0; + + *t++ = 0; + } + { /* Someone thinks the Sun supposedly-ANSI compiler will reject this. */ + int x[] = {25, 17}; + const int *foo = &x[0]; + ++foo; + } + { /* Sun SC1.0 ANSI compiler rejects this -- but not the above. */ + typedef const int *iptr; + iptr p = 0; + ++p; + } + { /* AIX XL C 1.02.0.0 rejects this saying + "k.c", line 2.27: 1506-025 (S) Operand must be a modifiable lvalue. */ + struct s { int j; const int *ap[3]; }; + struct s *b; b->j = 5; + } + { /* ULTRIX-32 V3.1 (Rev 9) vcc rejects this */ + const int foo = 10; + } +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_c_const=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_c_const=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_c_const" >&5 +echo "${ECHO_T}$ac_cv_c_const" >&6 +if test $ac_cv_c_const = no; then + +cat >>confdefs.h <<\_ACEOF +#define const +_ACEOF + +fi + + +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "vsnprintf" >/dev/null 2>&1; then + cat >>confdefs.h <<\_ACEOF +#define HAVE_VSNPRINTF 1 +_ACEOF + +fi +rm -f conftest* + + +echo "$as_me:$LINENO: checking for unsigned short int" >&5 +echo $ECHO_N "checking for unsigned short int... $ECHO_C" >&6 +if test "${ac_cv_type_unsigned_short_int+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +if ((unsigned short int *) 0) + return 0; +if (sizeof (unsigned short int)) + return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_type_unsigned_short_int=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_type_unsigned_short_int=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_type_unsigned_short_int" >&5 +echo "${ECHO_T}$ac_cv_type_unsigned_short_int" >&6 + +echo "$as_me:$LINENO: checking size of unsigned short int" >&5 +echo $ECHO_N "checking size of unsigned short int... $ECHO_C" >&6 +if test "${ac_cv_sizeof_unsigned_short_int+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$ac_cv_type_unsigned_short_int" = yes; then + # The cast to unsigned long works around a bug in the HP C Compiler + # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects + # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. + # This bug is HP SR number 8606223364. + if test "$cross_compiling" = yes; then + # Depending upon the size, compute the lo and hi bounds. +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned short int))) >= 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=0 ac_mid=0 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned short int))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr $ac_mid + 1` + if test $ac_lo -le $ac_mid; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned short int))) < 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=-1 ac_mid=-1 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned short int))) >= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_hi=`expr '(' $ac_mid ')' - 1` + if test $ac_mid -le $ac_hi; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo= ac_hi= +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +# Binary search between lo and hi bounds. +while test "x$ac_lo" != "x$ac_hi"; do + ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned short int))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr '(' $ac_mid ')' + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +done +case $ac_lo in +?*) ac_cv_sizeof_unsigned_short_int=$ac_lo;; +'') { { echo "$as_me:$LINENO: error: cannot compute sizeof (unsigned short int), 77 +See \`config.log' for more details." >&5 +echo "$as_me: error: cannot compute sizeof (unsigned short int), 77 +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } ;; +esac +else + if test "$cross_compiling" = yes; then + { { echo "$as_me:$LINENO: error: internal error: not reached in cross-compile" >&5 +echo "$as_me: error: internal error: not reached in cross-compile" >&2;} + { (exit 1); exit 1; }; } +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +long longval () { return (long) (sizeof (unsigned short int)); } +unsigned long ulongval () { return (long) (sizeof (unsigned short int)); } +#include +#include +int +main () +{ + + FILE *f = fopen ("conftest.val", "w"); + if (! f) + exit (1); + if (((long) (sizeof (unsigned short int))) < 0) + { + long i = longval (); + if (i != ((long) (sizeof (unsigned short int)))) + exit (1); + fprintf (f, "%ld\n", i); + } + else + { + unsigned long i = ulongval (); + if (i != ((long) (sizeof (unsigned short int)))) + exit (1); + fprintf (f, "%lu\n", i); + } + exit (ferror (f) || fclose (f) != 0); + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_sizeof_unsigned_short_int=`cat conftest.val` +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +{ { echo "$as_me:$LINENO: error: cannot compute sizeof (unsigned short int), 77 +See \`config.log' for more details." >&5 +echo "$as_me: error: cannot compute sizeof (unsigned short int), 77 +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +fi +rm -f conftest.val +else + ac_cv_sizeof_unsigned_short_int=0 +fi +fi +echo "$as_me:$LINENO: result: $ac_cv_sizeof_unsigned_short_int" >&5 +echo "${ECHO_T}$ac_cv_sizeof_unsigned_short_int" >&6 +cat >>confdefs.h <<_ACEOF +#define SIZEOF_UNSIGNED_SHORT_INT $ac_cv_sizeof_unsigned_short_int +_ACEOF + + +echo "$as_me:$LINENO: checking for unsigned long int" >&5 +echo $ECHO_N "checking for unsigned long int... $ECHO_C" >&6 +if test "${ac_cv_type_unsigned_long_int+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +if ((unsigned long int *) 0) + return 0; +if (sizeof (unsigned long int)) + return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_type_unsigned_long_int=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_type_unsigned_long_int=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_type_unsigned_long_int" >&5 +echo "${ECHO_T}$ac_cv_type_unsigned_long_int" >&6 + +echo "$as_me:$LINENO: checking size of unsigned long int" >&5 +echo $ECHO_N "checking size of unsigned long int... $ECHO_C" >&6 +if test "${ac_cv_sizeof_unsigned_long_int+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$ac_cv_type_unsigned_long_int" = yes; then + # The cast to unsigned long works around a bug in the HP C Compiler + # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects + # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. + # This bug is HP SR number 8606223364. + if test "$cross_compiling" = yes; then + # Depending upon the size, compute the lo and hi bounds. +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned long int))) >= 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=0 ac_mid=0 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned long int))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr $ac_mid + 1` + if test $ac_lo -le $ac_mid; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned long int))) < 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=-1 ac_mid=-1 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned long int))) >= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_hi=`expr '(' $ac_mid ')' - 1` + if test $ac_mid -le $ac_hi; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo= ac_hi= +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +# Binary search between lo and hi bounds. +while test "x$ac_lo" != "x$ac_hi"; do + ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned long int))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr '(' $ac_mid ')' + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +done +case $ac_lo in +?*) ac_cv_sizeof_unsigned_long_int=$ac_lo;; +'') { { echo "$as_me:$LINENO: error: cannot compute sizeof (unsigned long int), 77 +See \`config.log' for more details." >&5 +echo "$as_me: error: cannot compute sizeof (unsigned long int), 77 +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } ;; +esac +else + if test "$cross_compiling" = yes; then + { { echo "$as_me:$LINENO: error: internal error: not reached in cross-compile" >&5 +echo "$as_me: error: internal error: not reached in cross-compile" >&2;} + { (exit 1); exit 1; }; } +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +long longval () { return (long) (sizeof (unsigned long int)); } +unsigned long ulongval () { return (long) (sizeof (unsigned long int)); } +#include +#include +int +main () +{ + + FILE *f = fopen ("conftest.val", "w"); + if (! f) + exit (1); + if (((long) (sizeof (unsigned long int))) < 0) + { + long i = longval (); + if (i != ((long) (sizeof (unsigned long int)))) + exit (1); + fprintf (f, "%ld\n", i); + } + else + { + unsigned long i = ulongval (); + if (i != ((long) (sizeof (unsigned long int)))) + exit (1); + fprintf (f, "%lu\n", i); + } + exit (ferror (f) || fclose (f) != 0); + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_sizeof_unsigned_long_int=`cat conftest.val` +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +{ { echo "$as_me:$LINENO: error: cannot compute sizeof (unsigned long int), 77 +See \`config.log' for more details." >&5 +echo "$as_me: error: cannot compute sizeof (unsigned long int), 77 +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +fi +rm -f conftest.val +else + ac_cv_sizeof_unsigned_long_int=0 +fi +fi +echo "$as_me:$LINENO: result: $ac_cv_sizeof_unsigned_long_int" >&5 +echo "${ECHO_T}$ac_cv_sizeof_unsigned_long_int" >&6 +cat >>confdefs.h <<_ACEOF +#define SIZEOF_UNSIGNED_LONG_INT $ac_cv_sizeof_unsigned_long_int +_ACEOF + + +echo "$as_me:$LINENO: checking for unsigned int" >&5 +echo $ECHO_N "checking for unsigned int... $ECHO_C" >&6 +if test "${ac_cv_type_unsigned_int+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +if ((unsigned int *) 0) + return 0; +if (sizeof (unsigned int)) + return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_type_unsigned_int=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_type_unsigned_int=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_type_unsigned_int" >&5 +echo "${ECHO_T}$ac_cv_type_unsigned_int" >&6 + +echo "$as_me:$LINENO: checking size of unsigned int" >&5 +echo $ECHO_N "checking size of unsigned int... $ECHO_C" >&6 +if test "${ac_cv_sizeof_unsigned_int+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$ac_cv_type_unsigned_int" = yes; then + # The cast to unsigned long works around a bug in the HP C Compiler + # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects + # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. + # This bug is HP SR number 8606223364. + if test "$cross_compiling" = yes; then + # Depending upon the size, compute the lo and hi bounds. +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned int))) >= 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=0 ac_mid=0 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned int))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr $ac_mid + 1` + if test $ac_lo -le $ac_mid; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned int))) < 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=-1 ac_mid=-1 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned int))) >= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_hi=`expr '(' $ac_mid ')' - 1` + if test $ac_mid -le $ac_hi; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo= ac_hi= +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +# Binary search between lo and hi bounds. +while test "x$ac_lo" != "x$ac_hi"; do + ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !(((long) (sizeof (unsigned int))) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr '(' $ac_mid ')' + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +done +case $ac_lo in +?*) ac_cv_sizeof_unsigned_int=$ac_lo;; +'') { { echo "$as_me:$LINENO: error: cannot compute sizeof (unsigned int), 77 +See \`config.log' for more details." >&5 +echo "$as_me: error: cannot compute sizeof (unsigned int), 77 +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } ;; +esac +else + if test "$cross_compiling" = yes; then + { { echo "$as_me:$LINENO: error: internal error: not reached in cross-compile" >&5 +echo "$as_me: error: internal error: not reached in cross-compile" >&2;} + { (exit 1); exit 1; }; } +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +long longval () { return (long) (sizeof (unsigned int)); } +unsigned long ulongval () { return (long) (sizeof (unsigned int)); } +#include +#include +int +main () +{ + + FILE *f = fopen ("conftest.val", "w"); + if (! f) + exit (1); + if (((long) (sizeof (unsigned int))) < 0) + { + long i = longval (); + if (i != ((long) (sizeof (unsigned int)))) + exit (1); + fprintf (f, "%ld\n", i); + } + else + { + unsigned long i = ulongval (); + if (i != ((long) (sizeof (unsigned int)))) + exit (1); + fprintf (f, "%lu\n", i); + } + exit (ferror (f) || fclose (f) != 0); + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_sizeof_unsigned_int=`cat conftest.val` +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +{ { echo "$as_me:$LINENO: error: cannot compute sizeof (unsigned int), 77 +See \`config.log' for more details." >&5 +echo "$as_me: error: cannot compute sizeof (unsigned int), 77 +See \`config.log' for more details." >&2;} + { (exit 1); exit 1; }; } +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +fi +rm -f conftest.val +else + ac_cv_sizeof_unsigned_int=0 +fi +fi +echo "$as_me:$LINENO: result: $ac_cv_sizeof_unsigned_int" >&5 +echo "${ECHO_T}$ac_cv_sizeof_unsigned_int" >&6 +cat >>confdefs.h <<_ACEOF +#define SIZEOF_UNSIGNED_INT $ac_cv_sizeof_unsigned_int +_ACEOF + + + +GSM_VERSION="1:4:0" + + +LINGUAS="de" +ALL_LINGUAS=$LINGUAS + + + MKINSTALLDIRS= + if test -n "$ac_aux_dir"; then + case "$ac_aux_dir" in + /*) MKINSTALLDIRS="$ac_aux_dir/mkinstalldirs" ;; + *) MKINSTALLDIRS="\$(top_builddir)/$ac_aux_dir/mkinstalldirs" ;; + esac + fi + if test -z "$MKINSTALLDIRS"; then + MKINSTALLDIRS="\$(top_srcdir)/mkinstalldirs" + fi + + + + echo "$as_me:$LINENO: checking whether NLS is requested" >&5 +echo $ECHO_N "checking whether NLS is requested... $ECHO_C" >&6 + # Check whether --enable-nls or --disable-nls was given. +if test "${enable_nls+set}" = set; then + enableval="$enable_nls" + USE_NLS=$enableval +else + USE_NLS=yes +fi; + echo "$as_me:$LINENO: result: $USE_NLS" >&5 +echo "${ECHO_T}$USE_NLS" >&6 + + + + + + +# Prepare PATH_SEPARATOR. +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + echo "#! /bin/sh" >conf$$.sh + echo "exit 0" >>conf$$.sh + chmod +x conf$$.sh + if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then + PATH_SEPARATOR=';' + else + PATH_SEPARATOR=: + fi + rm -f conf$$.sh +fi + +# Find out how to test for executable files. Don't use a zero-byte file, +# as systems may use methods other than mode bits to determine executability. +cat >conf$$.file <<_ASEOF +#! /bin/sh +exit 0 +_ASEOF +chmod +x conf$$.file +if test -x conf$$.file >/dev/null 2>&1; then + ac_executable_p="test -x" +else + ac_executable_p="test -f" +fi +rm -f conf$$.file + +# Extract the first word of "msgfmt", so it can be a program name with args. +set dummy msgfmt; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_path_MSGFMT+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + case "$MSGFMT" in + [\\/]* | ?:[\\/]*) + ac_cv_path_MSGFMT="$MSGFMT" # Let the user override the test with a path. + ;; + *) + ac_save_IFS="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS="$ac_save_IFS" + test -z "$ac_dir" && ac_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $ac_executable_p "$ac_dir/$ac_word$ac_exec_ext"; then + echo "$as_me: trying $ac_dir/$ac_word..." >&5 + if $ac_dir/$ac_word --statistics /dev/null >&5 2>&1 && + (if $ac_dir/$ac_word --statistics /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi); then + ac_cv_path_MSGFMT="$ac_dir/$ac_word$ac_exec_ext" + break 2 + fi + fi + done + done + IFS="$ac_save_IFS" + test -z "$ac_cv_path_MSGFMT" && ac_cv_path_MSGFMT=":" + ;; +esac +fi +MSGFMT="$ac_cv_path_MSGFMT" +if test "$MSGFMT" != ":"; then + echo "$as_me:$LINENO: result: $MSGFMT" >&5 +echo "${ECHO_T}$MSGFMT" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + # Extract the first word of "gmsgfmt", so it can be a program name with args. +set dummy gmsgfmt; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_path_GMSGFMT+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + case $GMSGFMT in + [\\/]* | ?:[\\/]*) + ac_cv_path_GMSGFMT="$GMSGFMT" # Let the user override the test with a path. + ;; + *) + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_path_GMSGFMT="$as_dir/$ac_word$ac_exec_ext" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + + test -z "$ac_cv_path_GMSGFMT" && ac_cv_path_GMSGFMT="$MSGFMT" + ;; +esac +fi +GMSGFMT=$ac_cv_path_GMSGFMT + +if test -n "$GMSGFMT"; then + echo "$as_me:$LINENO: result: $GMSGFMT" >&5 +echo "${ECHO_T}$GMSGFMT" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + + +# Prepare PATH_SEPARATOR. +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + echo "#! /bin/sh" >conf$$.sh + echo "exit 0" >>conf$$.sh + chmod +x conf$$.sh + if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then + PATH_SEPARATOR=';' + else + PATH_SEPARATOR=: + fi + rm -f conf$$.sh +fi + +# Find out how to test for executable files. Don't use a zero-byte file, +# as systems may use methods other than mode bits to determine executability. +cat >conf$$.file <<_ASEOF +#! /bin/sh +exit 0 +_ASEOF +chmod +x conf$$.file +if test -x conf$$.file >/dev/null 2>&1; then + ac_executable_p="test -x" +else + ac_executable_p="test -f" +fi +rm -f conf$$.file + +# Extract the first word of "xgettext", so it can be a program name with args. +set dummy xgettext; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_path_XGETTEXT+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + case "$XGETTEXT" in + [\\/]* | ?:[\\/]*) + ac_cv_path_XGETTEXT="$XGETTEXT" # Let the user override the test with a path. + ;; + *) + ac_save_IFS="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS="$ac_save_IFS" + test -z "$ac_dir" && ac_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $ac_executable_p "$ac_dir/$ac_word$ac_exec_ext"; then + echo "$as_me: trying $ac_dir/$ac_word..." >&5 + if $ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null >&5 2>&1 && + (if $ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi); then + ac_cv_path_XGETTEXT="$ac_dir/$ac_word$ac_exec_ext" + break 2 + fi + fi + done + done + IFS="$ac_save_IFS" + test -z "$ac_cv_path_XGETTEXT" && ac_cv_path_XGETTEXT=":" + ;; +esac +fi +XGETTEXT="$ac_cv_path_XGETTEXT" +if test "$XGETTEXT" != ":"; then + echo "$as_me:$LINENO: result: $XGETTEXT" >&5 +echo "${ECHO_T}$XGETTEXT" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + rm -f messages.po + + +# Prepare PATH_SEPARATOR. +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + echo "#! /bin/sh" >conf$$.sh + echo "exit 0" >>conf$$.sh + chmod +x conf$$.sh + if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then + PATH_SEPARATOR=';' + else + PATH_SEPARATOR=: + fi + rm -f conf$$.sh +fi + +# Find out how to test for executable files. Don't use a zero-byte file, +# as systems may use methods other than mode bits to determine executability. +cat >conf$$.file <<_ASEOF +#! /bin/sh +exit 0 +_ASEOF +chmod +x conf$$.file +if test -x conf$$.file >/dev/null 2>&1; then + ac_executable_p="test -x" +else + ac_executable_p="test -f" +fi +rm -f conf$$.file + +# Extract the first word of "msgmerge", so it can be a program name with args. +set dummy msgmerge; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_path_MSGMERGE+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + case "$MSGMERGE" in + [\\/]* | ?:[\\/]*) + ac_cv_path_MSGMERGE="$MSGMERGE" # Let the user override the test with a path. + ;; + *) + ac_save_IFS="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS="$ac_save_IFS" + test -z "$ac_dir" && ac_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $ac_executable_p "$ac_dir/$ac_word$ac_exec_ext"; then + echo "$as_me: trying $ac_dir/$ac_word..." >&5 + if $ac_dir/$ac_word --update -q /dev/null /dev/null >&5 2>&1; then + ac_cv_path_MSGMERGE="$ac_dir/$ac_word$ac_exec_ext" + break 2 + fi + fi + done + done + IFS="$ac_save_IFS" + test -z "$ac_cv_path_MSGMERGE" && ac_cv_path_MSGMERGE=":" + ;; +esac +fi +MSGMERGE="$ac_cv_path_MSGMERGE" +if test "$MSGMERGE" != ":"; then + echo "$as_me:$LINENO: result: $MSGMERGE" >&5 +echo "${ECHO_T}$MSGMERGE" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + + if test "$GMSGFMT" != ":"; then + if $GMSGFMT --statistics /dev/null >/dev/null 2>&1 && + (if $GMSGFMT --statistics /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi); then + : ; + else + GMSGFMT=`echo "$GMSGFMT" | sed -e 's,^.*/,,'` + echo "$as_me:$LINENO: result: found $GMSGFMT program is not GNU msgfmt; ignore it" >&5 +echo "${ECHO_T}found $GMSGFMT program is not GNU msgfmt; ignore it" >&6 + GMSGFMT=":" + fi + fi + + if test "$XGETTEXT" != ":"; then + if $XGETTEXT --omit-header --copyright-holder= --msgid-bugs-address= /dev/null >/dev/null 2>&1 && + (if $XGETTEXT --omit-header --copyright-holder= --msgid-bugs-address= /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi); then + : ; + else + echo "$as_me:$LINENO: result: found xgettext program is not GNU xgettext; ignore it" >&5 +echo "${ECHO_T}found xgettext program is not GNU xgettext; ignore it" >&6 + XGETTEXT=":" + fi + rm -f messages.po + fi + + ac_config_commands="$ac_config_commands default-1" + + + + echo "$as_me:$LINENO: checking whether we are using the GNU C Library 2 or newer" >&5 +echo $ECHO_N "checking whether we are using the GNU C Library 2 or newer... $ECHO_C" >&6 +if test "${ac_cv_gnu_library_2+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#include +#ifdef __GNU_LIBRARY__ + #if (__GLIBC__ >= 2) + Lucky GNU user + #endif +#endif + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "Lucky GNU user" >/dev/null 2>&1; then + ac_cv_gnu_library_2=yes +else + ac_cv_gnu_library_2=no +fi +rm -f conftest* + + + +fi +echo "$as_me:$LINENO: result: $ac_cv_gnu_library_2" >&5 +echo "${ECHO_T}$ac_cv_gnu_library_2" >&6 + + GLIBC2="$ac_cv_gnu_library_2" + + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. +set dummy ${ac_tool_prefix}ranlib; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_RANLIB+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$RANLIB"; then + ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +RANLIB=$ac_cv_prog_RANLIB +if test -n "$RANLIB"; then + echo "$as_me:$LINENO: result: $RANLIB" >&5 +echo "${ECHO_T}$RANLIB" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + +fi +if test -z "$ac_cv_prog_RANLIB"; then + ac_ct_RANLIB=$RANLIB + # Extract the first word of "ranlib", so it can be a program name with args. +set dummy ranlib; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_ac_ct_RANLIB+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$ac_ct_RANLIB"; then + ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_RANLIB="ranlib" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + + test -z "$ac_cv_prog_ac_ct_RANLIB" && ac_cv_prog_ac_ct_RANLIB=":" +fi +fi +ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB +if test -n "$ac_ct_RANLIB"; then + echo "$as_me:$LINENO: result: $ac_ct_RANLIB" >&5 +echo "${ECHO_T}$ac_ct_RANLIB" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + RANLIB=$ac_ct_RANLIB +else + RANLIB="$ac_cv_prog_RANLIB" +fi + +echo "$as_me:$LINENO: checking for library containing strerror" >&5 +echo $ECHO_N "checking for library containing strerror... $ECHO_C" >&6 +if test "${ac_cv_search_strerror+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_func_search_save_LIBS=$LIBS +ac_cv_search_strerror=no +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char strerror (); +int +main () +{ +strerror (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_search_strerror="none required" +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +if test "$ac_cv_search_strerror" = no; then + for ac_lib in cposix; do + LIBS="-l$ac_lib $ac_func_search_save_LIBS" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char strerror (); +int +main () +{ +strerror (); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_search_strerror="-l$ac_lib" +break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + done +fi +LIBS=$ac_func_search_save_LIBS +fi +echo "$as_me:$LINENO: result: $ac_cv_search_strerror" >&5 +echo "${ECHO_T}$ac_cv_search_strerror" >&6 +if test "$ac_cv_search_strerror" != no; then + test "$ac_cv_search_strerror" = "none required" || LIBS="$ac_cv_search_strerror $LIBS" + +fi + + + echo "$as_me:$LINENO: checking for signed" >&5 +echo $ECHO_N "checking for signed... $ECHO_C" >&6 +if test "${bh_cv_c_signed+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +int +main () +{ +signed char x; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + bh_cv_c_signed=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +bh_cv_c_signed=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $bh_cv_c_signed" >&5 +echo "${ECHO_T}$bh_cv_c_signed" >&6 + if test $bh_cv_c_signed = no; then + +cat >>confdefs.h <<\_ACEOF +#define signed +_ACEOF + + fi + +echo "$as_me:$LINENO: checking for inline" >&5 +echo $ECHO_N "checking for inline... $ECHO_C" >&6 +if test "${ac_cv_c_inline+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + ac_cv_c_inline=no +for ac_kw in inline __inline__ __inline; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#ifndef __cplusplus +typedef int foo_t; +static $ac_kw foo_t static_foo () {return 0; } +$ac_kw foo_t foo () {return 0; } +#endif + +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_c_inline=$ac_kw; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +done + +fi +echo "$as_me:$LINENO: result: $ac_cv_c_inline" >&5 +echo "${ECHO_T}$ac_cv_c_inline" >&6 + + +case $ac_cv_c_inline in + inline | yes) ;; + *) + case $ac_cv_c_inline in + no) ac_val=;; + *) ac_val=$ac_cv_c_inline;; + esac + cat >>confdefs.h <<_ACEOF +#ifndef __cplusplus +#define inline $ac_val +#endif +_ACEOF + ;; +esac + +echo "$as_me:$LINENO: checking for off_t" >&5 +echo $ECHO_N "checking for off_t... $ECHO_C" >&6 +if test "${ac_cv_type_off_t+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +if ((off_t *) 0) + return 0; +if (sizeof (off_t)) + return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_type_off_t=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_type_off_t=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_type_off_t" >&5 +echo "${ECHO_T}$ac_cv_type_off_t" >&6 +if test $ac_cv_type_off_t = yes; then + : +else + +cat >>confdefs.h <<_ACEOF +#define off_t long +_ACEOF + +fi + +echo "$as_me:$LINENO: checking for size_t" >&5 +echo $ECHO_N "checking for size_t... $ECHO_C" >&6 +if test "${ac_cv_type_size_t+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +if ((size_t *) 0) + return 0; +if (sizeof (size_t)) + return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_type_size_t=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_type_size_t=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_type_size_t" >&5 +echo "${ECHO_T}$ac_cv_type_size_t" >&6 +if test $ac_cv_type_size_t = yes; then + : +else + +cat >>confdefs.h <<_ACEOF +#define size_t unsigned +_ACEOF + +fi + + + echo "$as_me:$LINENO: checking for long long" >&5 +echo $ECHO_N "checking for long long... $ECHO_C" >&6 +if test "${ac_cv_type_long_long+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +long long ll = 1LL; int i = 63; +int +main () +{ +long long llmax = (long long) -1; + return ll << i | ll >> i | llmax / ll | llmax % ll; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_type_long_long=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_type_long_long=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_type_long_long" >&5 +echo "${ECHO_T}$ac_cv_type_long_long" >&6 + if test $ac_cv_type_long_long = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_LONG_LONG 1 +_ACEOF + + fi + + + echo "$as_me:$LINENO: checking for long double" >&5 +echo $ECHO_N "checking for long double... $ECHO_C" >&6 +if test "${gt_cv_c_long_double+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$GCC" = yes; then + gt_cv_c_long_double=yes + else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + + /* The Stardent Vistra knows sizeof(long double), but does not support it. */ + long double foo = 0.0; + /* On Ultrix 4.3 cc, long double is 4 and double is 8. */ + int array [2*(sizeof(long double) >= sizeof(double)) - 1]; + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_c_long_double=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_c_long_double=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + fi +fi +echo "$as_me:$LINENO: result: $gt_cv_c_long_double" >&5 +echo "${ECHO_T}$gt_cv_c_long_double" >&6 + if test $gt_cv_c_long_double = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_LONG_DOUBLE 1 +_ACEOF + + fi + + + echo "$as_me:$LINENO: checking for wchar_t" >&5 +echo $ECHO_N "checking for wchar_t... $ECHO_C" >&6 +if test "${gt_cv_c_wchar_t+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + wchar_t foo = (wchar_t)'\0'; +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_c_wchar_t=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_c_wchar_t=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $gt_cv_c_wchar_t" >&5 +echo "${ECHO_T}$gt_cv_c_wchar_t" >&6 + if test $gt_cv_c_wchar_t = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_WCHAR_T 1 +_ACEOF + + fi + + + echo "$as_me:$LINENO: checking for wint_t" >&5 +echo $ECHO_N "checking for wint_t... $ECHO_C" >&6 +if test "${gt_cv_c_wint_t+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + wint_t foo = (wchar_t)'\0'; +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_c_wint_t=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_c_wint_t=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $gt_cv_c_wint_t" >&5 +echo "${ECHO_T}$gt_cv_c_wint_t" >&6 + if test $gt_cv_c_wint_t = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_WINT_T 1 +_ACEOF + + fi + + + echo "$as_me:$LINENO: checking for inttypes.h" >&5 +echo $ECHO_N "checking for inttypes.h... $ECHO_C" >&6 +if test "${gl_cv_header_inttypes_h+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +int +main () +{ +uintmax_t i = (uintmax_t) -1; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gl_cv_header_inttypes_h=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gl_cv_header_inttypes_h=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $gl_cv_header_inttypes_h" >&5 +echo "${ECHO_T}$gl_cv_header_inttypes_h" >&6 + if test $gl_cv_header_inttypes_h = yes; then + +cat >>confdefs.h <<_ACEOF +#define HAVE_INTTYPES_H_WITH_UINTMAX 1 +_ACEOF + + fi + + + echo "$as_me:$LINENO: checking for stdint.h" >&5 +echo $ECHO_N "checking for stdint.h... $ECHO_C" >&6 +if test "${gl_cv_header_stdint_h+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +int +main () +{ +uintmax_t i = (uintmax_t) -1; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gl_cv_header_stdint_h=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gl_cv_header_stdint_h=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $gl_cv_header_stdint_h" >&5 +echo "${ECHO_T}$gl_cv_header_stdint_h" >&6 + if test $gl_cv_header_stdint_h = yes; then + +cat >>confdefs.h <<_ACEOF +#define HAVE_STDINT_H_WITH_UINTMAX 1 +_ACEOF + + fi + + + + + echo "$as_me:$LINENO: checking for intmax_t" >&5 +echo $ECHO_N "checking for intmax_t... $ECHO_C" >&6 +if test "${gt_cv_c_intmax_t+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#include +#include +#if HAVE_STDINT_H_WITH_UINTMAX +#include +#endif +#if HAVE_INTTYPES_H_WITH_UINTMAX +#include +#endif + +int +main () +{ +intmax_t x = -1; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_c_intmax_t=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_c_intmax_t=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $gt_cv_c_intmax_t" >&5 +echo "${ECHO_T}$gt_cv_c_intmax_t" >&6 + if test $gt_cv_c_intmax_t = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_INTMAX_T 1 +_ACEOF + + fi + + + + echo "$as_me:$LINENO: checking whether printf() supports POSIX/XSI format strings" >&5 +echo $ECHO_N "checking whether printf() supports POSIX/XSI format strings... $ECHO_C" >&6 +if test "${gt_cv_func_printf_posix+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + + if test "$cross_compiling" = yes; then + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#if defined __NetBSD__ || defined _MSC_VER || defined __MINGW32__ || defined __CYGWIN__ + notposix +#endif + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "notposix" >/dev/null 2>&1; then + gt_cv_func_printf_posix="guessing no" +else + gt_cv_func_printf_posix="guessing yes" +fi +rm -f conftest* + + +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#include +#include +/* The string "%2$d %1$d", with dollar characters protected from the shell's + dollar expansion (possibly an autoconf bug). */ +static char format[] = { '%', '2', '$', 'd', ' ', '%', '1', '$', 'd', '\0' }; +static char buf[100]; +int main () +{ + sprintf (buf, format, 33, 55); + return (strcmp (buf, "55 33") != 0); +} +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_func_printf_posix=yes +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +gt_cv_func_printf_posix=no +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi + +fi +echo "$as_me:$LINENO: result: $gt_cv_func_printf_posix" >&5 +echo "${ECHO_T}$gt_cv_func_printf_posix" >&6 + case $gt_cv_func_printf_posix in + *yes) + +cat >>confdefs.h <<\_ACEOF +#define HAVE_POSIX_PRINTF 1 +_ACEOF + + ;; + esac + + + +for ac_header in stdlib.h unistd.h +do +as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 +else + # Is the header compilable? +echo "$as_me:$LINENO: checking $ac_header usability" >&5 +echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_header_compiler=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_header_compiler=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 +echo "${ECHO_T}$ac_header_compiler" >&6 + +# Is the header present? +echo "$as_me:$LINENO: checking $ac_header presence" >&5 +echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include <$ac_header> +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + ac_header_preproc=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_preproc=no +fi +rm -f conftest.err conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 +echo "${ECHO_T}$ac_header_preproc" >&6 + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in + yes:no: ) + { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 +echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} + ac_header_preproc=yes + ;; + no:yes:* ) + { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 +echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 +echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 +echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 +echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 +echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} + ( + cat <<\_ASBOX +## ------------------------------------------ ## +## Report this to the AC_PACKAGE_NAME lists. ## +## ------------------------------------------ ## +_ASBOX + ) | + sed "s/^/$as_me: WARNING: /" >&2 + ;; +esac +echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + eval "$as_ac_Header=\$ac_header_preproc" +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 + +fi +if test `eval echo '${'$as_ac_Header'}'` = yes; then + cat >>confdefs.h <<_ACEOF +#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + +for ac_func in getpagesize +do +as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh` +echo "$as_me:$LINENO: checking for $ac_func" >&5 +echo $ECHO_N "checking for $ac_func... $ECHO_C" >&6 +if eval "test \"\${$as_ac_var+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define $ac_func to an innocuous variant, in case declares $ac_func. + For example, HP-UX 11i declares gettimeofday. */ +#define $ac_func innocuous_$ac_func + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char $ac_func (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef $ac_func + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +{ +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char $ac_func (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_$ac_func) || defined (__stub___$ac_func) +choke me +#else +char (*f) () = $ac_func; +#endif +#ifdef __cplusplus +} +#endif + +int +main () +{ +return f != $ac_func; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + eval "$as_ac_var=yes" +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +eval "$as_ac_var=no" +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_var'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_var'}'`" >&6 +if test `eval echo '${'$as_ac_var'}'` = yes; then + cat >>confdefs.h <<_ACEOF +#define `echo "HAVE_$ac_func" | $as_tr_cpp` 1 +_ACEOF + +fi +done + +echo "$as_me:$LINENO: checking for working mmap" >&5 +echo $ECHO_N "checking for working mmap... $ECHO_C" >&6 +if test "${ac_cv_func_mmap_fixed_mapped+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test "$cross_compiling" = yes; then + ac_cv_func_mmap_fixed_mapped=no +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +/* malloc might have been renamed as rpl_malloc. */ +#undef malloc + +/* Thanks to Mike Haertel and Jim Avera for this test. + Here is a matrix of mmap possibilities: + mmap private not fixed + mmap private fixed at somewhere currently unmapped + mmap private fixed at somewhere already mapped + mmap shared not fixed + mmap shared fixed at somewhere currently unmapped + mmap shared fixed at somewhere already mapped + For private mappings, we should verify that changes cannot be read() + back from the file, nor mmap's back from the file at a different + address. (There have been systems where private was not correctly + implemented like the infamous i386 svr4.0, and systems where the + VM page cache was not coherent with the file system buffer cache + like early versions of FreeBSD and possibly contemporary NetBSD.) + For shared mappings, we should conversely verify that changes get + propagated back to all the places they're supposed to be. + + Grep wants private fixed already mapped. + The main things grep needs to know about mmap are: + * does it exist and is it safe to write into the mmap'd area + * how to use it (BSD variants) */ + +#include +#include + +#if !STDC_HEADERS && !HAVE_STDLIB_H +char *malloc (); +#endif + +/* This mess was copied from the GNU getpagesize.h. */ +#if !HAVE_GETPAGESIZE +/* Assume that all systems that can run configure have sys/param.h. */ +# if !HAVE_SYS_PARAM_H +# define HAVE_SYS_PARAM_H 1 +# endif + +# ifdef _SC_PAGESIZE +# define getpagesize() sysconf(_SC_PAGESIZE) +# else /* no _SC_PAGESIZE */ +# if HAVE_SYS_PARAM_H +# include +# ifdef EXEC_PAGESIZE +# define getpagesize() EXEC_PAGESIZE +# else /* no EXEC_PAGESIZE */ +# ifdef NBPG +# define getpagesize() NBPG * CLSIZE +# ifndef CLSIZE +# define CLSIZE 1 +# endif /* no CLSIZE */ +# else /* no NBPG */ +# ifdef NBPC +# define getpagesize() NBPC +# else /* no NBPC */ +# ifdef PAGESIZE +# define getpagesize() PAGESIZE +# endif /* PAGESIZE */ +# endif /* no NBPC */ +# endif /* no NBPG */ +# endif /* no EXEC_PAGESIZE */ +# else /* no HAVE_SYS_PARAM_H */ +# define getpagesize() 8192 /* punt totally */ +# endif /* no HAVE_SYS_PARAM_H */ +# endif /* no _SC_PAGESIZE */ + +#endif /* no HAVE_GETPAGESIZE */ + +int +main () +{ + char *data, *data2, *data3; + int i, pagesize; + int fd; + + pagesize = getpagesize (); + + /* First, make a file with some known garbage in it. */ + data = (char *) malloc (pagesize); + if (!data) + exit (1); + for (i = 0; i < pagesize; ++i) + *(data + i) = rand (); + umask (0); + fd = creat ("conftest.mmap", 0600); + if (fd < 0) + exit (1); + if (write (fd, data, pagesize) != pagesize) + exit (1); + close (fd); + + /* Next, try to mmap the file at a fixed address which already has + something else allocated at it. If we can, also make sure that + we see the same garbage. */ + fd = open ("conftest.mmap", O_RDWR); + if (fd < 0) + exit (1); + data2 = (char *) malloc (2 * pagesize); + if (!data2) + exit (1); + data2 += (pagesize - ((long) data2 & (pagesize - 1))) & (pagesize - 1); + if (data2 != mmap (data2, pagesize, PROT_READ | PROT_WRITE, + MAP_PRIVATE | MAP_FIXED, fd, 0L)) + exit (1); + for (i = 0; i < pagesize; ++i) + if (*(data + i) != *(data2 + i)) + exit (1); + + /* Finally, make sure that changes to the mapped area do not + percolate back to the file as seen by read(). (This is a bug on + some variants of i386 svr4.0.) */ + for (i = 0; i < pagesize; ++i) + *(data2 + i) = *(data2 + i) + 1; + data3 = (char *) malloc (pagesize); + if (!data3) + exit (1); + if (read (fd, data3, pagesize) != pagesize) + exit (1); + for (i = 0; i < pagesize; ++i) + if (*(data + i) != *(data3 + i)) + exit (1); + close (fd); + exit (0); +} +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_func_mmap_fixed_mapped=yes +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +ac_cv_func_mmap_fixed_mapped=no +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +fi +echo "$as_me:$LINENO: result: $ac_cv_func_mmap_fixed_mapped" >&5 +echo "${ECHO_T}$ac_cv_func_mmap_fixed_mapped" >&6 +if test $ac_cv_func_mmap_fixed_mapped = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_MMAP 1 +_ACEOF + +fi +rm -f conftest.mmap + + + echo "$as_me:$LINENO: checking whether we are using the GNU C Library 2.1 or newer" >&5 +echo $ECHO_N "checking whether we are using the GNU C Library 2.1 or newer... $ECHO_C" >&6 +if test "${ac_cv_gnu_library_2_1+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#include +#ifdef __GNU_LIBRARY__ + #if (__GLIBC__ == 2 && __GLIBC_MINOR__ >= 1) || (__GLIBC__ > 2) + Lucky GNU user + #endif +#endif + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "Lucky GNU user" >/dev/null 2>&1; then + ac_cv_gnu_library_2_1=yes +else + ac_cv_gnu_library_2_1=no +fi +rm -f conftest* + + + +fi +echo "$as_me:$LINENO: result: $ac_cv_gnu_library_2_1" >&5 +echo "${ECHO_T}$ac_cv_gnu_library_2_1" >&6 + + GLIBC21="$ac_cv_gnu_library_2_1" + + + + + echo "$as_me:$LINENO: checking whether integer division by zero raises SIGFPE" >&5 +echo $ECHO_N "checking whether integer division by zero raises SIGFPE... $ECHO_C" >&6 +if test "${gt_cv_int_divbyzero_sigfpe+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + + if test "$cross_compiling" = yes; then + + # Guess based on the CPU. + case "$host_cpu" in + alpha* | i3456786 | m68k | s390*) + gt_cv_int_divbyzero_sigfpe="guessing yes";; + *) + gt_cv_int_divbyzero_sigfpe="guessing no";; + esac + +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#include +#include + +static void +#ifdef __cplusplus +sigfpe_handler (int sig) +#else +sigfpe_handler (sig) int sig; +#endif +{ + /* Exit with code 0 if SIGFPE, with code 1 if any other signal. */ + exit (sig != SIGFPE); +} + +int x = 1; +int y = 0; +int z; +int nan; + +int main () +{ + signal (SIGFPE, sigfpe_handler); +/* IRIX and AIX (when "xlc -qcheck" is used) yield signal SIGTRAP. */ +#if (defined (__sgi) || defined (_AIX)) && defined (SIGTRAP) + signal (SIGTRAP, sigfpe_handler); +#endif +/* Linux/SPARC yields signal SIGILL. */ +#if defined (__sparc__) && defined (__linux__) + signal (SIGILL, sigfpe_handler); +#endif + + z = x / y; + nan = y / y; + exit (1); +} + +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_int_divbyzero_sigfpe=yes +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +gt_cv_int_divbyzero_sigfpe=no +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi + +fi +echo "$as_me:$LINENO: result: $gt_cv_int_divbyzero_sigfpe" >&5 +echo "${ECHO_T}$gt_cv_int_divbyzero_sigfpe" >&6 + case "$gt_cv_int_divbyzero_sigfpe" in + *yes) value=1;; + *) value=0;; + esac + +cat >>confdefs.h <<_ACEOF +#define INTDIV0_RAISES_SIGFPE $value +_ACEOF + + + + echo "$as_me:$LINENO: checking for unsigned long long" >&5 +echo $ECHO_N "checking for unsigned long long... $ECHO_C" >&6 +if test "${ac_cv_type_unsigned_long_long+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +unsigned long long ull = 1ULL; int i = 63; +int +main () +{ +unsigned long long ullmax = (unsigned long long) -1; + return ull << i | ull >> i | ullmax / ull | ullmax % ull; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_type_unsigned_long_long=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_type_unsigned_long_long=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_type_unsigned_long_long" >&5 +echo "${ECHO_T}$ac_cv_type_unsigned_long_long" >&6 + if test $ac_cv_type_unsigned_long_long = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_UNSIGNED_LONG_LONG 1 +_ACEOF + + fi + + + + + if test $gl_cv_header_inttypes_h = no && test $gl_cv_header_stdint_h = no; then + + test $ac_cv_type_unsigned_long_long = yes \ + && ac_type='unsigned long long' \ + || ac_type='unsigned long' + +cat >>confdefs.h <<_ACEOF +#define uintmax_t $ac_type +_ACEOF + + else + +cat >>confdefs.h <<\_ACEOF +#define HAVE_UINTMAX_T 1 +_ACEOF + + fi + + + echo "$as_me:$LINENO: checking for inttypes.h" >&5 +echo $ECHO_N "checking for inttypes.h... $ECHO_C" >&6 +if test "${gt_cv_header_inttypes_h+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_header_inttypes_h=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_header_inttypes_h=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + +fi +echo "$as_me:$LINENO: result: $gt_cv_header_inttypes_h" >&5 +echo "${ECHO_T}$gt_cv_header_inttypes_h" >&6 + if test $gt_cv_header_inttypes_h = yes; then + +cat >>confdefs.h <<_ACEOF +#define HAVE_INTTYPES_H 1 +_ACEOF + + fi + + + + if test $gt_cv_header_inttypes_h = yes; then + echo "$as_me:$LINENO: checking whether the inttypes.h PRIxNN macros are broken" >&5 +echo $ECHO_N "checking whether the inttypes.h PRIxNN macros are broken... $ECHO_C" >&6 +if test "${gt_cv_inttypes_pri_broken+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#ifdef PRId32 +char *p = PRId32; +#endif + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_inttypes_pri_broken=no +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_inttypes_pri_broken=yes +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + +fi +echo "$as_me:$LINENO: result: $gt_cv_inttypes_pri_broken" >&5 +echo "${ECHO_T}$gt_cv_inttypes_pri_broken" >&6 + fi + if test "$gt_cv_inttypes_pri_broken" = yes; then + +cat >>confdefs.h <<_ACEOF +#define PRI_MACROS_BROKEN 1 +_ACEOF + + fi + + + +for ac_header in stdint.h +do +as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 +else + # Is the header compilable? +echo "$as_me:$LINENO: checking $ac_header usability" >&5 +echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_header_compiler=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_header_compiler=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 +echo "${ECHO_T}$ac_header_compiler" >&6 + +# Is the header present? +echo "$as_me:$LINENO: checking $ac_header presence" >&5 +echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include <$ac_header> +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + ac_header_preproc=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_preproc=no +fi +rm -f conftest.err conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 +echo "${ECHO_T}$ac_header_preproc" >&6 + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in + yes:no: ) + { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 +echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} + ac_header_preproc=yes + ;; + no:yes:* ) + { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 +echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 +echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 +echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 +echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 +echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} + ( + cat <<\_ASBOX +## ------------------------------------------ ## +## Report this to the AC_PACKAGE_NAME lists. ## +## ------------------------------------------ ## +_ASBOX + ) | + sed "s/^/$as_me: WARNING: /" >&2 + ;; +esac +echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + eval "$as_ac_Header=\$ac_header_preproc" +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 + +fi +if test `eval echo '${'$as_ac_Header'}'` = yes; then + cat >>confdefs.h <<_ACEOF +#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + echo "$as_me:$LINENO: checking for SIZE_MAX" >&5 +echo $ECHO_N "checking for SIZE_MAX... $ECHO_C" >&6 + result= + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#include +#if HAVE_STDINT_H +#include +#endif +#ifdef SIZE_MAX +Found it +#endif + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "Found it" >/dev/null 2>&1; then + result=yes +fi +rm -f conftest* + + if test -z "$result"; then + if test "$cross_compiling" = yes; then + # Depending upon the size, compute the lo and hi bounds. +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((~(size_t)0 / 10) >= 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=0 ac_mid=0 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((~(size_t)0 / 10) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr $ac_mid + 1` + if test $ac_lo -le $ac_mid; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((~(size_t)0 / 10) < 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=-1 ac_mid=-1 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((~(size_t)0 / 10) >= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_hi=`expr '(' $ac_mid ')' - 1` + if test $ac_mid -le $ac_hi; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo= ac_hi= +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +# Binary search between lo and hi bounds. +while test "x$ac_lo" != "x$ac_hi"; do + ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((~(size_t)0 / 10) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr '(' $ac_mid ')' + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +done +case $ac_lo in +?*) res_hi=$ac_lo;; +'') result=? ;; +esac +else + if test "$cross_compiling" = yes; then + { { echo "$as_me:$LINENO: error: internal error: not reached in cross-compile" >&5 +echo "$as_me: error: internal error: not reached in cross-compile" >&2;} + { (exit 1); exit 1; }; } +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +long longval () { return ~(size_t)0 / 10; } +unsigned long ulongval () { return ~(size_t)0 / 10; } +#include +#include +int +main () +{ + + FILE *f = fopen ("conftest.val", "w"); + if (! f) + exit (1); + if ((~(size_t)0 / 10) < 0) + { + long i = longval (); + if (i != (~(size_t)0 / 10)) + exit (1); + fprintf (f, "%ld\n", i); + } + else + { + unsigned long i = ulongval (); + if (i != (~(size_t)0 / 10)) + exit (1); + fprintf (f, "%lu\n", i); + } + exit (ferror (f) || fclose (f) != 0); + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + res_hi=`cat conftest.val` +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +result=? +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +fi +rm -f conftest.val + if test "$cross_compiling" = yes; then + # Depending upon the size, compute the lo and hi bounds. +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((~(size_t)0 % 10) >= 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=0 ac_mid=0 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((~(size_t)0 % 10) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr $ac_mid + 1` + if test $ac_lo -le $ac_mid; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((~(size_t)0 % 10) < 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=-1 ac_mid=-1 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((~(size_t)0 % 10) >= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_hi=`expr '(' $ac_mid ')' - 1` + if test $ac_mid -le $ac_hi; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo= ac_hi= +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +# Binary search between lo and hi bounds. +while test "x$ac_lo" != "x$ac_hi"; do + ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((~(size_t)0 % 10) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr '(' $ac_mid ')' + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +done +case $ac_lo in +?*) res_lo=$ac_lo;; +'') result=? ;; +esac +else + if test "$cross_compiling" = yes; then + { { echo "$as_me:$LINENO: error: internal error: not reached in cross-compile" >&5 +echo "$as_me: error: internal error: not reached in cross-compile" >&2;} + { (exit 1); exit 1; }; } +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +long longval () { return ~(size_t)0 % 10; } +unsigned long ulongval () { return ~(size_t)0 % 10; } +#include +#include +int +main () +{ + + FILE *f = fopen ("conftest.val", "w"); + if (! f) + exit (1); + if ((~(size_t)0 % 10) < 0) + { + long i = longval (); + if (i != (~(size_t)0 % 10)) + exit (1); + fprintf (f, "%ld\n", i); + } + else + { + unsigned long i = ulongval (); + if (i != (~(size_t)0 % 10)) + exit (1); + fprintf (f, "%lu\n", i); + } + exit (ferror (f) || fclose (f) != 0); + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + res_lo=`cat conftest.val` +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +result=? +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +fi +rm -f conftest.val + if test "$cross_compiling" = yes; then + # Depending upon the size, compute the lo and hi bounds. +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((sizeof (size_t) <= sizeof (unsigned int)) >= 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=0 ac_mid=0 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((sizeof (size_t) <= sizeof (unsigned int)) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr $ac_mid + 1` + if test $ac_lo -le $ac_mid; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((sizeof (size_t) <= sizeof (unsigned int)) < 0)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=-1 ac_mid=-1 + while :; do + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((sizeof (size_t) <= sizeof (unsigned int)) >= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_lo=$ac_mid; break +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_hi=`expr '(' $ac_mid ')' - 1` + if test $ac_mid -le $ac_hi; then + ac_lo= ac_hi= + break + fi + ac_mid=`expr 2 '*' $ac_mid` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + done +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo= ac_hi= +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +# Binary search between lo and hi bounds. +while test "x$ac_lo" != "x$ac_hi"; do + ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +static int test_array [1 - 2 * !((sizeof (size_t) <= sizeof (unsigned int)) <= $ac_mid)]; +test_array [0] = 0 + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_hi=$ac_mid +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_lo=`expr '(' $ac_mid ')' + 1` +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +done +case $ac_lo in +?*) fits_in_uint=$ac_lo;; +'') result=? ;; +esac +else + if test "$cross_compiling" = yes; then + { { echo "$as_me:$LINENO: error: internal error: not reached in cross-compile" >&5 +echo "$as_me: error: internal error: not reached in cross-compile" >&2;} + { (exit 1); exit 1; }; } +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +long longval () { return sizeof (size_t) <= sizeof (unsigned int); } +unsigned long ulongval () { return sizeof (size_t) <= sizeof (unsigned int); } +#include +#include +int +main () +{ + + FILE *f = fopen ("conftest.val", "w"); + if (! f) + exit (1); + if ((sizeof (size_t) <= sizeof (unsigned int)) < 0) + { + long i = longval (); + if (i != (sizeof (size_t) <= sizeof (unsigned int))) + exit (1); + fprintf (f, "%ld\n", i); + } + else + { + unsigned long i = ulongval (); + if (i != (sizeof (size_t) <= sizeof (unsigned int))) + exit (1); + fprintf (f, "%lu\n", i); + } + exit (ferror (f) || fclose (f) != 0); + + ; + return 0; +} +_ACEOF +rm -f conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { ac_try='./conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + fits_in_uint=`cat conftest.val` +else + echo "$as_me: program exited with status $ac_status" >&5 +echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +( exit $ac_status ) +result=? +fi +rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext +fi +fi +rm -f conftest.val + if test "$fits_in_uint" = 1; then + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include + extern size_t foo; + extern unsigned long foo; + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + fits_in_uint=0 +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + fi + if test -z "$result"; then + if test "$fits_in_uint" = 1; then + result="$res_hi$res_lo"U + else + result="$res_hi$res_lo"UL + fi + else + result='~(size_t)0' + fi + fi + echo "$as_me:$LINENO: result: $result" >&5 +echo "${ECHO_T}$result" >&6 + if test "$result" != yes; then + +cat >>confdefs.h <<_ACEOF +#define SIZE_MAX $result +_ACEOF + + fi + + + + + +for ac_header in stdint.h +do +as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 +else + # Is the header compilable? +echo "$as_me:$LINENO: checking $ac_header usability" >&5 +echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_header_compiler=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_header_compiler=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 +echo "${ECHO_T}$ac_header_compiler" >&6 + +# Is the header present? +echo "$as_me:$LINENO: checking $ac_header presence" >&5 +echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include <$ac_header> +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + ac_header_preproc=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_preproc=no +fi +rm -f conftest.err conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 +echo "${ECHO_T}$ac_header_preproc" >&6 + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in + yes:no: ) + { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 +echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} + ac_header_preproc=yes + ;; + no:yes:* ) + { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 +echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 +echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 +echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 +echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 +echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} + ( + cat <<\_ASBOX +## ------------------------------------------ ## +## Report this to the AC_PACKAGE_NAME lists. ## +## ------------------------------------------ ## +_ASBOX + ) | + sed "s/^/$as_me: WARNING: /" >&2 + ;; +esac +echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + eval "$as_ac_Header=\$ac_header_preproc" +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 + +fi +if test `eval echo '${'$as_ac_Header'}'` = yes; then + cat >>confdefs.h <<_ACEOF +#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + + + echo "$as_me:$LINENO: checking for CFPreferencesCopyAppValue" >&5 +echo $ECHO_N "checking for CFPreferencesCopyAppValue... $ECHO_C" >&6 +if test "${gt_cv_func_CFPreferencesCopyAppValue+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + gt_save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$CPPFLAGS -I/System/Library/Frameworks/CoreFoundation.framework/Headers" + gt_save_LIBS="$LIBS" + LIBS="$LIBS -framework CoreFoundation" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +CFPreferencesCopyAppValue(NULL, NULL) + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_func_CFPreferencesCopyAppValue=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_func_CFPreferencesCopyAppValue=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + CPPFLAGS="$gt_save_CPPFLAGS" + LIBS="$gt_save_LIBS" +fi +echo "$as_me:$LINENO: result: $gt_cv_func_CFPreferencesCopyAppValue" >&5 +echo "${ECHO_T}$gt_cv_func_CFPreferencesCopyAppValue" >&6 + if test $gt_cv_func_CFPreferencesCopyAppValue = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_CFPREFERENCESCOPYAPPVALUE 1 +_ACEOF + + fi + echo "$as_me:$LINENO: checking for CFLocaleCopyCurrent" >&5 +echo $ECHO_N "checking for CFLocaleCopyCurrent... $ECHO_C" >&6 +if test "${gt_cv_func_CFLocaleCopyCurrent+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + gt_save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$CPPFLAGS -I/System/Library/Frameworks/CoreFoundation.framework/Headers" + gt_save_LIBS="$LIBS" + LIBS="$LIBS -framework CoreFoundation" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +CFLocaleCopyCurrent(); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_func_CFLocaleCopyCurrent=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_func_CFLocaleCopyCurrent=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + CPPFLAGS="$gt_save_CPPFLAGS" + LIBS="$gt_save_LIBS" +fi +echo "$as_me:$LINENO: result: $gt_cv_func_CFLocaleCopyCurrent" >&5 +echo "${ECHO_T}$gt_cv_func_CFLocaleCopyCurrent" >&6 + if test $gt_cv_func_CFLocaleCopyCurrent = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_CFLOCALECOPYCURRENT 1 +_ACEOF + + fi + INTL_MACOSX_LIBS= + if test $gt_cv_func_CFPreferencesCopyAppValue = yes || test $gt_cv_func_CFLocaleCopyCurrent = yes; then + INTL_MACOSX_LIBS="-Wl,-framework -Wl,CoreFoundation" + fi + + + + if test "X$prefix" = "XNONE"; then + acl_final_prefix="$ac_default_prefix" + else + acl_final_prefix="$prefix" + fi + if test "X$exec_prefix" = "XNONE"; then + acl_final_exec_prefix='${prefix}' + else + acl_final_exec_prefix="$exec_prefix" + fi + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + eval acl_final_exec_prefix=\"$acl_final_exec_prefix\" + prefix="$acl_save_prefix" + + +# Check whether --with-gnu-ld or --without-gnu-ld was given. +if test "${with_gnu_ld+set}" = set; then + withval="$with_gnu_ld" + test "$withval" = no || with_gnu_ld=yes +else + with_gnu_ld=no +fi; +# Prepare PATH_SEPARATOR. +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + echo "#! /bin/sh" >conf$$.sh + echo "exit 0" >>conf$$.sh + chmod +x conf$$.sh + if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then + PATH_SEPARATOR=';' + else + PATH_SEPARATOR=: + fi + rm -f conf$$.sh +fi +ac_prog=ld +if test "$GCC" = yes; then + # Check if gcc -print-prog-name=ld gives a path. + echo "$as_me:$LINENO: checking for ld used by GCC" >&5 +echo $ECHO_N "checking for ld used by GCC... $ECHO_C" >&6 + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [\\/]* | [A-Za-z]:[\\/]*) + re_direlt='/[^/][^/]*/\.\./' + # Canonicalize the path of ld + ac_prog=`echo $ac_prog| sed 's%\\\\%/%g'` + while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do + ac_prog=`echo $ac_prog| sed "s%$re_direlt%/%"` + done + test -z "$LD" && LD="$ac_prog" + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test "$with_gnu_ld" = yes; then + echo "$as_me:$LINENO: checking for GNU ld" >&5 +echo $ECHO_N "checking for GNU ld... $ECHO_C" >&6 +else + echo "$as_me:$LINENO: checking for non-GNU ld" >&5 +echo $ECHO_N "checking for non-GNU ld... $ECHO_C" >&6 +fi +if test "${acl_cv_path_LD+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -z "$LD"; then + IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR-:}" + for ac_dir in $PATH; do + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + acl_cv_path_LD="$ac_dir/$ac_prog" + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some GNU ld's only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$acl_cv_path_LD" -v 2>&1 < /dev/null` in + *GNU* | *'with BFD'*) + test "$with_gnu_ld" != no && break ;; + *) + test "$with_gnu_ld" != yes && break ;; + esac + fi + done + IFS="$ac_save_ifs" +else + acl_cv_path_LD="$LD" # Let the user override the test with a path. +fi +fi + +LD="$acl_cv_path_LD" +if test -n "$LD"; then + echo "$as_me:$LINENO: result: $LD" >&5 +echo "${ECHO_T}$LD" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi +test -z "$LD" && { { echo "$as_me:$LINENO: error: no acceptable ld found in \$PATH" >&5 +echo "$as_me: error: no acceptable ld found in \$PATH" >&2;} + { (exit 1); exit 1; }; } +echo "$as_me:$LINENO: checking if the linker ($LD) is GNU ld" >&5 +echo $ECHO_N "checking if the linker ($LD) is GNU ld... $ECHO_C" >&6 +if test "${acl_cv_prog_gnu_ld+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + # I'd rather use --version here, but apparently some GNU ld's only accept -v. +case `$LD -v 2>&1 &5 +echo "${ECHO_T}$acl_cv_prog_gnu_ld" >&6 +with_gnu_ld=$acl_cv_prog_gnu_ld + + + + + echo "$as_me:$LINENO: checking for shared library run path origin" >&5 +echo $ECHO_N "checking for shared library run path origin... $ECHO_C" >&6 +if test "${acl_cv_rpath+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + + CC="$CC" GCC="$GCC" LDFLAGS="$LDFLAGS" LD="$LD" with_gnu_ld="$with_gnu_ld" \ + ${CONFIG_SHELL-/bin/sh} "$ac_aux_dir/config.rpath" "$host" > conftest.sh + . ./conftest.sh + rm -f ./conftest.sh + acl_cv_rpath=done + +fi +echo "$as_me:$LINENO: result: $acl_cv_rpath" >&5 +echo "${ECHO_T}$acl_cv_rpath" >&6 + wl="$acl_cv_wl" + libext="$acl_cv_libext" + shlibext="$acl_cv_shlibext" + hardcode_libdir_flag_spec="$acl_cv_hardcode_libdir_flag_spec" + hardcode_libdir_separator="$acl_cv_hardcode_libdir_separator" + hardcode_direct="$acl_cv_hardcode_direct" + hardcode_minus_L="$acl_cv_hardcode_minus_L" + # Check whether --enable-rpath or --disable-rpath was given. +if test "${enable_rpath+set}" = set; then + enableval="$enable_rpath" + : +else + enable_rpath=yes +fi; + + + + + + + + use_additional=yes + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + + eval additional_includedir=\"$includedir\" + eval additional_libdir=\"$libdir\" + + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + +# Check whether --with-libiconv-prefix or --without-libiconv-prefix was given. +if test "${with_libiconv_prefix+set}" = set; then + withval="$with_libiconv_prefix" + + if test "X$withval" = "Xno"; then + use_additional=no + else + if test "X$withval" = "X"; then + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + + eval additional_includedir=\"$includedir\" + eval additional_libdir=\"$libdir\" + + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + else + additional_includedir="$withval/include" + additional_libdir="$withval/lib" + fi + fi + +fi; + LIBICONV= + LTLIBICONV= + INCICONV= + rpathdirs= + ltrpathdirs= + names_already_handled= + names_next_round='iconv ' + while test -n "$names_next_round"; do + names_this_round="$names_next_round" + names_next_round= + for name in $names_this_round; do + already_handled= + for n in $names_already_handled; do + if test "$n" = "$name"; then + already_handled=yes + break + fi + done + if test -z "$already_handled"; then + names_already_handled="$names_already_handled $name" + uppername=`echo "$name" | sed -e 'y|abcdefghijklmnopqrstuvwxyz./-|ABCDEFGHIJKLMNOPQRSTUVWXYZ___|'` + eval value=\"\$HAVE_LIB$uppername\" + if test -n "$value"; then + if test "$value" = yes; then + eval value=\"\$LIB$uppername\" + test -z "$value" || LIBICONV="${LIBICONV}${LIBICONV:+ }$value" + eval value=\"\$LTLIB$uppername\" + test -z "$value" || LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }$value" + else + : + fi + else + found_dir= + found_la= + found_so= + found_a= + if test $use_additional = yes; then + if test -n "$shlibext" && test -f "$additional_libdir/lib$name.$shlibext"; then + found_dir="$additional_libdir" + found_so="$additional_libdir/lib$name.$shlibext" + if test -f "$additional_libdir/lib$name.la"; then + found_la="$additional_libdir/lib$name.la" + fi + else + if test -f "$additional_libdir/lib$name.$libext"; then + found_dir="$additional_libdir" + found_a="$additional_libdir/lib$name.$libext" + if test -f "$additional_libdir/lib$name.la"; then + found_la="$additional_libdir/lib$name.la" + fi + fi + fi + fi + if test "X$found_dir" = "X"; then + for x in $LDFLAGS $LTLIBICONV; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + case "$x" in + -L*) + dir=`echo "X$x" | sed -e 's/^X-L//'` + if test -n "$shlibext" && test -f "$dir/lib$name.$shlibext"; then + found_dir="$dir" + found_so="$dir/lib$name.$shlibext" + if test -f "$dir/lib$name.la"; then + found_la="$dir/lib$name.la" + fi + else + if test -f "$dir/lib$name.$libext"; then + found_dir="$dir" + found_a="$dir/lib$name.$libext" + if test -f "$dir/lib$name.la"; then + found_la="$dir/lib$name.la" + fi + fi + fi + ;; + esac + if test "X$found_dir" != "X"; then + break + fi + done + fi + if test "X$found_dir" != "X"; then + LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }-L$found_dir -l$name" + if test "X$found_so" != "X"; then + if test "$enable_rpath" = no || test "X$found_dir" = "X/usr/lib"; then + LIBICONV="${LIBICONV}${LIBICONV:+ }$found_so" + else + haveit= + for x in $ltrpathdirs; do + if test "X$x" = "X$found_dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + ltrpathdirs="$ltrpathdirs $found_dir" + fi + if test "$hardcode_direct" = yes; then + LIBICONV="${LIBICONV}${LIBICONV:+ }$found_so" + else + if test -n "$hardcode_libdir_flag_spec" && test "$hardcode_minus_L" = no; then + LIBICONV="${LIBICONV}${LIBICONV:+ }$found_so" + haveit= + for x in $rpathdirs; do + if test "X$x" = "X$found_dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + rpathdirs="$rpathdirs $found_dir" + fi + else + haveit= + for x in $LDFLAGS $LIBICONV; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + if test "X$x" = "X-L$found_dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + LIBICONV="${LIBICONV}${LIBICONV:+ }-L$found_dir" + fi + if test "$hardcode_minus_L" != no; then + LIBICONV="${LIBICONV}${LIBICONV:+ }$found_so" + else + LIBICONV="${LIBICONV}${LIBICONV:+ }-l$name" + fi + fi + fi + fi + else + if test "X$found_a" != "X"; then + LIBICONV="${LIBICONV}${LIBICONV:+ }$found_a" + else + LIBICONV="${LIBICONV}${LIBICONV:+ }-L$found_dir -l$name" + fi + fi + additional_includedir= + case "$found_dir" in + */lib | */lib/) + basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e 's,/lib/*$,,'` + additional_includedir="$basedir/include" + ;; + esac + if test "X$additional_includedir" != "X"; then + if test "X$additional_includedir" != "X/usr/include"; then + haveit= + if test "X$additional_includedir" = "X/usr/local/include"; then + if test -n "$GCC"; then + case $host_os in + linux* | gnu* | k*bsd*-gnu) haveit=yes;; + esac + fi + fi + if test -z "$haveit"; then + for x in $CPPFLAGS $INCICONV; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + if test "X$x" = "X-I$additional_includedir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + if test -d "$additional_includedir"; then + INCICONV="${INCICONV}${INCICONV:+ }-I$additional_includedir" + fi + fi + fi + fi + fi + if test -n "$found_la"; then + save_libdir="$libdir" + case "$found_la" in + */* | *\\*) . "$found_la" ;; + *) . "./$found_la" ;; + esac + libdir="$save_libdir" + for dep in $dependency_libs; do + case "$dep" in + -L*) + additional_libdir=`echo "X$dep" | sed -e 's/^X-L//'` + if test "X$additional_libdir" != "X/usr/lib"; then + haveit= + if test "X$additional_libdir" = "X/usr/local/lib"; then + if test -n "$GCC"; then + case $host_os in + linux* | gnu* | k*bsd*-gnu) haveit=yes;; + esac + fi + fi + if test -z "$haveit"; then + haveit= + for x in $LDFLAGS $LIBICONV; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + if test "X$x" = "X-L$additional_libdir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + if test -d "$additional_libdir"; then + LIBICONV="${LIBICONV}${LIBICONV:+ }-L$additional_libdir" + fi + fi + haveit= + for x in $LDFLAGS $LTLIBICONV; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + if test "X$x" = "X-L$additional_libdir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + if test -d "$additional_libdir"; then + LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }-L$additional_libdir" + fi + fi + fi + fi + ;; + -R*) + dir=`echo "X$dep" | sed -e 's/^X-R//'` + if test "$enable_rpath" != no; then + haveit= + for x in $rpathdirs; do + if test "X$x" = "X$dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + rpathdirs="$rpathdirs $dir" + fi + haveit= + for x in $ltrpathdirs; do + if test "X$x" = "X$dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + ltrpathdirs="$ltrpathdirs $dir" + fi + fi + ;; + -l*) + names_next_round="$names_next_round "`echo "X$dep" | sed -e 's/^X-l//'` + ;; + *.la) + names_next_round="$names_next_round "`echo "X$dep" | sed -e 's,^X.*/,,' -e 's,^lib,,' -e 's,\.la$,,'` + ;; + *) + LIBICONV="${LIBICONV}${LIBICONV:+ }$dep" + LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }$dep" + ;; + esac + done + fi + else + LIBICONV="${LIBICONV}${LIBICONV:+ }-l$name" + LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }-l$name" + fi + fi + fi + done + done + if test "X$rpathdirs" != "X"; then + if test -n "$hardcode_libdir_separator"; then + alldirs= + for found_dir in $rpathdirs; do + alldirs="${alldirs}${alldirs:+$hardcode_libdir_separator}$found_dir" + done + acl_save_libdir="$libdir" + libdir="$alldirs" + eval flag=\"$hardcode_libdir_flag_spec\" + libdir="$acl_save_libdir" + LIBICONV="${LIBICONV}${LIBICONV:+ }$flag" + else + for found_dir in $rpathdirs; do + acl_save_libdir="$libdir" + libdir="$found_dir" + eval flag=\"$hardcode_libdir_flag_spec\" + libdir="$acl_save_libdir" + LIBICONV="${LIBICONV}${LIBICONV:+ }$flag" + done + fi + fi + if test "X$ltrpathdirs" != "X"; then + for found_dir in $ltrpathdirs; do + LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }-R$found_dir" + done + fi + + + + + + + + + echo "$as_me:$LINENO: checking for ptrdiff_t" >&5 +echo $ECHO_N "checking for ptrdiff_t... $ECHO_C" >&6 +if test "${ac_cv_type_ptrdiff_t+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +if ((ptrdiff_t *) 0) + return 0; +if (sizeof (ptrdiff_t)) + return 0; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_type_ptrdiff_t=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_type_ptrdiff_t=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_type_ptrdiff_t" >&5 +echo "${ECHO_T}$ac_cv_type_ptrdiff_t" >&6 +if test $ac_cv_type_ptrdiff_t = yes; then + : +else + +cat >>confdefs.h <<\_ACEOF +#define ptrdiff_t long +_ACEOF + + +fi + + + + + + + + + + + +for ac_header in argz.h limits.h locale.h nl_types.h malloc.h stddef.h \ +stdlib.h string.h unistd.h sys/param.h +do +as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 +else + # Is the header compilable? +echo "$as_me:$LINENO: checking $ac_header usability" >&5 +echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +$ac_includes_default +#include <$ac_header> +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_header_compiler=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_header_compiler=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 +echo "${ECHO_T}$ac_header_compiler" >&6 + +# Is the header present? +echo "$as_me:$LINENO: checking $ac_header presence" >&5 +echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6 +cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include <$ac_header> +_ACEOF +if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 + (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } >/dev/null; then + if test -s conftest.err; then + ac_cpp_err=$ac_c_preproc_warn_flag + ac_cpp_err=$ac_cpp_err$ac_c_werror_flag + else + ac_cpp_err= + fi +else + ac_cpp_err=yes +fi +if test -z "$ac_cpp_err"; then + ac_header_preproc=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_header_preproc=no +fi +rm -f conftest.err conftest.$ac_ext +echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 +echo "${ECHO_T}$ac_header_preproc" >&6 + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in + yes:no: ) + { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 +echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} + ac_header_preproc=yes + ;; + no:yes:* ) + { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 +echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 +echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 +echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 +echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 +echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} + { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 +echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} + ( + cat <<\_ASBOX +## ------------------------------------------ ## +## Report this to the AC_PACKAGE_NAME lists. ## +## ------------------------------------------ ## +_ASBOX + ) | + sed "s/^/$as_me: WARNING: /" >&2 + ;; +esac +echo "$as_me:$LINENO: checking for $ac_header" >&5 +echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 +if eval "test \"\${$as_ac_Header+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + eval "$as_ac_Header=\$ac_header_preproc" +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 + +fi +if test `eval echo '${'$as_ac_Header'}'` = yes; then + cat >>confdefs.h <<_ACEOF +#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + + + + + + + + + + + + + + + + + + + + + + + +for ac_func in asprintf fwprintf getcwd getegid geteuid getgid getuid \ +mempcpy munmap putenv setenv setlocale snprintf stpcpy strcasecmp strdup \ +strtoul tsearch wcslen __argz_count __argz_stringify __argz_next \ +__fsetlocking +do +as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh` +echo "$as_me:$LINENO: checking for $ac_func" >&5 +echo $ECHO_N "checking for $ac_func... $ECHO_C" >&6 +if eval "test \"\${$as_ac_var+set}\" = set"; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +/* Define $ac_func to an innocuous variant, in case declares $ac_func. + For example, HP-UX 11i declares gettimeofday. */ +#define $ac_func innocuous_$ac_func + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char $ac_func (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef $ac_func + +/* Override any gcc2 internal prototype to avoid an error. */ +#ifdef __cplusplus +extern "C" +{ +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char $ac_func (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_$ac_func) || defined (__stub___$ac_func) +choke me +#else +char (*f) () = $ac_func; +#endif +#ifdef __cplusplus +} +#endif + +int +main () +{ +return f != $ac_func; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + eval "$as_ac_var=yes" +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +eval "$as_ac_var=no" +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_var'}'`" >&5 +echo "${ECHO_T}`eval echo '${'$as_ac_var'}'`" >&6 +if test `eval echo '${'$as_ac_var'}'` = yes; then + cat >>confdefs.h <<_ACEOF +#define `echo "HAVE_$ac_func" | $as_tr_cpp` 1 +_ACEOF + +fi +done + + + + echo "$as_me:$LINENO: checking whether _snprintf is declared" >&5 +echo $ECHO_N "checking whether _snprintf is declared... $ECHO_C" >&6 +if test "${ac_cv_have_decl__snprintf+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ + +#ifndef _snprintf + char *p = (char *) _snprintf; +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_have_decl__snprintf=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_have_decl__snprintf=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_have_decl__snprintf" >&5 +echo "${ECHO_T}$ac_cv_have_decl__snprintf" >&6 + if test $ac_cv_have_decl__snprintf = yes; then + gt_value=1 + else + gt_value=0 + fi + +cat >>confdefs.h <<_ACEOF +#define HAVE_DECL__SNPRINTF $gt_value +_ACEOF + + + + echo "$as_me:$LINENO: checking whether _snwprintf is declared" >&5 +echo $ECHO_N "checking whether _snwprintf is declared... $ECHO_C" >&6 +if test "${ac_cv_have_decl__snwprintf+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ + +#ifndef _snwprintf + char *p = (char *) _snwprintf; +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_have_decl__snwprintf=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_have_decl__snwprintf=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_have_decl__snwprintf" >&5 +echo "${ECHO_T}$ac_cv_have_decl__snwprintf" >&6 + if test $ac_cv_have_decl__snwprintf = yes; then + gt_value=1 + else + gt_value=0 + fi + +cat >>confdefs.h <<_ACEOF +#define HAVE_DECL__SNWPRINTF $gt_value +_ACEOF + + + + + echo "$as_me:$LINENO: checking whether feof_unlocked is declared" >&5 +echo $ECHO_N "checking whether feof_unlocked is declared... $ECHO_C" >&6 +if test "${ac_cv_have_decl_feof_unlocked+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ + +#ifndef feof_unlocked + char *p = (char *) feof_unlocked; +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_have_decl_feof_unlocked=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_have_decl_feof_unlocked=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_have_decl_feof_unlocked" >&5 +echo "${ECHO_T}$ac_cv_have_decl_feof_unlocked" >&6 + if test $ac_cv_have_decl_feof_unlocked = yes; then + gt_value=1 + else + gt_value=0 + fi + +cat >>confdefs.h <<_ACEOF +#define HAVE_DECL_FEOF_UNLOCKED $gt_value +_ACEOF + + + + echo "$as_me:$LINENO: checking whether fgets_unlocked is declared" >&5 +echo $ECHO_N "checking whether fgets_unlocked is declared... $ECHO_C" >&6 +if test "${ac_cv_have_decl_fgets_unlocked+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ + +#ifndef fgets_unlocked + char *p = (char *) fgets_unlocked; +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_have_decl_fgets_unlocked=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_have_decl_fgets_unlocked=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_have_decl_fgets_unlocked" >&5 +echo "${ECHO_T}$ac_cv_have_decl_fgets_unlocked" >&6 + if test $ac_cv_have_decl_fgets_unlocked = yes; then + gt_value=1 + else + gt_value=0 + fi + +cat >>confdefs.h <<_ACEOF +#define HAVE_DECL_FGETS_UNLOCKED $gt_value +_ACEOF + + + + echo "$as_me:$LINENO: checking whether getc_unlocked is declared" >&5 +echo $ECHO_N "checking whether getc_unlocked is declared... $ECHO_C" >&6 +if test "${ac_cv_have_decl_getc_unlocked+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ + +#ifndef getc_unlocked + char *p = (char *) getc_unlocked; +#endif + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + ac_cv_have_decl_getc_unlocked=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +ac_cv_have_decl_getc_unlocked=no +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $ac_cv_have_decl_getc_unlocked" >&5 +echo "${ECHO_T}$ac_cv_have_decl_getc_unlocked" >&6 + if test $ac_cv_have_decl_getc_unlocked = yes; then + gt_value=1 + else + gt_value=0 + fi + +cat >>confdefs.h <<_ACEOF +#define HAVE_DECL_GETC_UNLOCKED $gt_value +_ACEOF + + + + case $gt_cv_func_printf_posix in + *yes) HAVE_POSIX_PRINTF=1 ;; + *) HAVE_POSIX_PRINTF=0 ;; + esac + + if test "$ac_cv_func_asprintf" = yes; then + HAVE_ASPRINTF=1 + else + HAVE_ASPRINTF=0 + fi + + if test "$ac_cv_func_snprintf" = yes; then + HAVE_SNPRINTF=1 + else + HAVE_SNPRINTF=0 + fi + + if test "$ac_cv_func_wprintf" = yes; then + HAVE_WPRINTF=1 + else + HAVE_WPRINTF=0 + fi + + + + + + + + am_save_CPPFLAGS="$CPPFLAGS" + + for element in $INCICONV; do + haveit= + for x in $CPPFLAGS; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + if test "X$x" = "X$element"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + CPPFLAGS="${CPPFLAGS}${CPPFLAGS:+ }$element" + fi + done + + + echo "$as_me:$LINENO: checking for iconv" >&5 +echo $ECHO_N "checking for iconv... $ECHO_C" >&6 +if test "${am_cv_func_iconv+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + + am_cv_func_iconv="no, consider installing GNU libiconv" + am_cv_lib_iconv=no + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +int +main () +{ +iconv_t cd = iconv_open("",""); + iconv(cd,NULL,NULL,NULL,NULL); + iconv_close(cd); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + am_cv_func_iconv=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + if test "$am_cv_func_iconv" != yes; then + am_save_LIBS="$LIBS" + LIBS="$LIBS $LIBICONV" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +#include +int +main () +{ +iconv_t cd = iconv_open("",""); + iconv(cd,NULL,NULL,NULL,NULL); + iconv_close(cd); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + am_cv_lib_iconv=yes + am_cv_func_iconv=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + LIBS="$am_save_LIBS" + fi + +fi +echo "$as_me:$LINENO: result: $am_cv_func_iconv" >&5 +echo "${ECHO_T}$am_cv_func_iconv" >&6 + if test "$am_cv_func_iconv" = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_ICONV 1 +_ACEOF + + fi + if test "$am_cv_lib_iconv" = yes; then + echo "$as_me:$LINENO: checking how to link with libiconv" >&5 +echo $ECHO_N "checking how to link with libiconv... $ECHO_C" >&6 + echo "$as_me:$LINENO: result: $LIBICONV" >&5 +echo "${ECHO_T}$LIBICONV" >&6 + else + CPPFLAGS="$am_save_CPPFLAGS" + LIBICONV= + LTLIBICONV= + fi + + + + if test "$am_cv_func_iconv" = yes; then + echo "$as_me:$LINENO: checking for iconv declaration" >&5 +echo $ECHO_N "checking for iconv declaration... $ECHO_C" >&6 + if test "${am_cv_proto_iconv+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ + +#include +#include +extern +#ifdef __cplusplus +"C" +#endif +#if defined(__STDC__) || defined(__cplusplus) +size_t iconv (iconv_t cd, char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft); +#else +size_t iconv(); +#endif + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 + (eval $ac_compile) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest.$ac_objext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + am_cv_proto_iconv_arg1="" +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +am_cv_proto_iconv_arg1="const" +fi +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext + am_cv_proto_iconv="extern size_t iconv (iconv_t cd, $am_cv_proto_iconv_arg1 char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft);" +fi + + am_cv_proto_iconv=`echo "$am_cv_proto_iconv" | tr -s ' ' | sed -e 's/( /(/'` + echo "$as_me:$LINENO: result: ${ac_t:- + }$am_cv_proto_iconv" >&5 +echo "${ECHO_T}${ac_t:- + }$am_cv_proto_iconv" >&6 + +cat >>confdefs.h <<_ACEOF +#define ICONV_CONST $am_cv_proto_iconv_arg1 +_ACEOF + + fi + + + echo "$as_me:$LINENO: checking for nl_langinfo and CODESET" >&5 +echo $ECHO_N "checking for nl_langinfo and CODESET... $ECHO_C" >&6 +if test "${am_cv_langinfo_codeset+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +char* cs = nl_langinfo(CODESET); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + am_cv_langinfo_codeset=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +am_cv_langinfo_codeset=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + +fi +echo "$as_me:$LINENO: result: $am_cv_langinfo_codeset" >&5 +echo "${ECHO_T}$am_cv_langinfo_codeset" >&6 + if test $am_cv_langinfo_codeset = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_LANGINFO_CODESET 1 +_ACEOF + + fi + + if test $ac_cv_header_locale_h = yes; then + + echo "$as_me:$LINENO: checking for LC_MESSAGES" >&5 +echo $ECHO_N "checking for LC_MESSAGES... $ECHO_C" >&6 +if test "${gt_cv_val_LC_MESSAGES+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +return LC_MESSAGES + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_val_LC_MESSAGES=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_val_LC_MESSAGES=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $gt_cv_val_LC_MESSAGES" >&5 +echo "${ECHO_T}$gt_cv_val_LC_MESSAGES" >&6 + if test $gt_cv_val_LC_MESSAGES = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_LC_MESSAGES 1 +_ACEOF + + fi + + fi + + if test -n "$INTL_MACOSX_LIBS"; then + CPPFLAGS="$CPPFLAGS -I/System/Library/Frameworks/CoreFoundation.framework/Headers" + fi + + for ac_prog in bison +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 +if test "${ac_cv_prog_INTLBISON+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + if test -n "$INTLBISON"; then + ac_cv_prog_INTLBISON="$INTLBISON" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_INTLBISON="$ac_prog" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done + +fi +fi +INTLBISON=$ac_cv_prog_INTLBISON +if test -n "$INTLBISON"; then + echo "$as_me:$LINENO: result: $INTLBISON" >&5 +echo "${ECHO_T}$INTLBISON" >&6 +else + echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6 +fi + + test -n "$INTLBISON" && break +done + + if test -z "$INTLBISON"; then + ac_verc_fail=yes + else + echo "$as_me:$LINENO: checking version of bison" >&5 +echo $ECHO_N "checking version of bison... $ECHO_C" >&6 + ac_prog_version=`$INTLBISON --version 2>&1 | sed -n 's/^.*GNU Bison.* \([0-9]*\.[0-9.]*\).*$/\1/p'` + case $ac_prog_version in + '') ac_prog_version="v. ?.??, bad"; ac_verc_fail=yes;; + 1.2[6-9]* | 1.[3-9][0-9]* | [2-9].*) + ac_prog_version="$ac_prog_version, ok"; ac_verc_fail=no;; + *) ac_prog_version="$ac_prog_version, bad"; ac_verc_fail=yes;; + esac + echo "$as_me:$LINENO: result: $ac_prog_version" >&5 +echo "${ECHO_T}$ac_prog_version" >&6 + fi + if test $ac_verc_fail = yes; then + INTLBISON=: + fi + + + + + + + + + + + + + + + + + echo "$as_me:$LINENO: checking for CFPreferencesCopyAppValue" >&5 +echo $ECHO_N "checking for CFPreferencesCopyAppValue... $ECHO_C" >&6 +if test "${gt_cv_func_CFPreferencesCopyAppValue+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + gt_save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$CPPFLAGS -I/System/Library/Frameworks/CoreFoundation.framework/Headers" + gt_save_LIBS="$LIBS" + LIBS="$LIBS -framework CoreFoundation" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +CFPreferencesCopyAppValue(NULL, NULL) + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_func_CFPreferencesCopyAppValue=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_func_CFPreferencesCopyAppValue=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + CPPFLAGS="$gt_save_CPPFLAGS" + LIBS="$gt_save_LIBS" +fi +echo "$as_me:$LINENO: result: $gt_cv_func_CFPreferencesCopyAppValue" >&5 +echo "${ECHO_T}$gt_cv_func_CFPreferencesCopyAppValue" >&6 + if test $gt_cv_func_CFPreferencesCopyAppValue = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_CFPREFERENCESCOPYAPPVALUE 1 +_ACEOF + + fi + echo "$as_me:$LINENO: checking for CFLocaleCopyCurrent" >&5 +echo $ECHO_N "checking for CFLocaleCopyCurrent... $ECHO_C" >&6 +if test "${gt_cv_func_CFLocaleCopyCurrent+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + gt_save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$CPPFLAGS -I/System/Library/Frameworks/CoreFoundation.framework/Headers" + gt_save_LIBS="$LIBS" + LIBS="$LIBS -framework CoreFoundation" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +CFLocaleCopyCurrent(); + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_func_CFLocaleCopyCurrent=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_func_CFLocaleCopyCurrent=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + CPPFLAGS="$gt_save_CPPFLAGS" + LIBS="$gt_save_LIBS" +fi +echo "$as_me:$LINENO: result: $gt_cv_func_CFLocaleCopyCurrent" >&5 +echo "${ECHO_T}$gt_cv_func_CFLocaleCopyCurrent" >&6 + if test $gt_cv_func_CFLocaleCopyCurrent = yes; then + +cat >>confdefs.h <<\_ACEOF +#define HAVE_CFLOCALECOPYCURRENT 1 +_ACEOF + + fi + INTL_MACOSX_LIBS= + if test $gt_cv_func_CFPreferencesCopyAppValue = yes || test $gt_cv_func_CFLocaleCopyCurrent = yes; then + INTL_MACOSX_LIBS="-Wl,-framework -Wl,CoreFoundation" + fi + + + + + echo "$as_me:$LINENO: checking whether NLS is requested" >&5 +echo $ECHO_N "checking whether NLS is requested... $ECHO_C" >&6 + # Check whether --enable-nls or --disable-nls was given. +if test "${enable_nls+set}" = set; then + enableval="$enable_nls" + USE_NLS=$enableval +else + USE_NLS=yes +fi; + echo "$as_me:$LINENO: result: $USE_NLS" >&5 +echo "${ECHO_T}$USE_NLS" >&6 + + + + + BUILD_INCLUDED_LIBINTL=no + USE_INCLUDED_LIBINTL=no + + LIBINTL= + LTLIBINTL= + POSUB= + + if test "$USE_NLS" = "yes"; then + gt_use_preinstalled_gnugettext=no + + echo "$as_me:$LINENO: checking whether included gettext is requested" >&5 +echo $ECHO_N "checking whether included gettext is requested... $ECHO_C" >&6 + +# Check whether --with-included-gettext or --without-included-gettext was given. +if test "${with_included_gettext+set}" = set; then + withval="$with_included_gettext" + nls_cv_force_use_gnu_gettext=$withval +else + nls_cv_force_use_gnu_gettext=no +fi; + echo "$as_me:$LINENO: result: $nls_cv_force_use_gnu_gettext" >&5 +echo "${ECHO_T}$nls_cv_force_use_gnu_gettext" >&6 + + nls_cv_use_gnu_gettext="$nls_cv_force_use_gnu_gettext" + if test "$nls_cv_force_use_gnu_gettext" != "yes"; then + + + + + + + echo "$as_me:$LINENO: checking for GNU gettext in libc" >&5 +echo $ECHO_N "checking for GNU gettext in libc... $ECHO_C" >&6 +if test "${gt_cv_func_gnugettext1_libc+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +extern int _nl_msg_cat_cntr; +extern int *_nl_domain_bindings; +int +main () +{ +bindtextdomain ("", ""); +return * gettext ("") + _nl_msg_cat_cntr + *_nl_domain_bindings + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_func_gnugettext1_libc=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_func_gnugettext1_libc=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +echo "$as_me:$LINENO: result: $gt_cv_func_gnugettext1_libc" >&5 +echo "${ECHO_T}$gt_cv_func_gnugettext1_libc" >&6 + + if test "$gt_cv_func_gnugettext1_libc" != "yes"; then + + + + use_additional=yes + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + + eval additional_includedir=\"$includedir\" + eval additional_libdir=\"$libdir\" + + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + +# Check whether --with-libintl-prefix or --without-libintl-prefix was given. +if test "${with_libintl_prefix+set}" = set; then + withval="$with_libintl_prefix" + + if test "X$withval" = "Xno"; then + use_additional=no + else + if test "X$withval" = "X"; then + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + + eval additional_includedir=\"$includedir\" + eval additional_libdir=\"$libdir\" + + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + else + additional_includedir="$withval/include" + additional_libdir="$withval/lib" + fi + fi + +fi; + LIBINTL= + LTLIBINTL= + INCINTL= + rpathdirs= + ltrpathdirs= + names_already_handled= + names_next_round='intl ' + while test -n "$names_next_round"; do + names_this_round="$names_next_round" + names_next_round= + for name in $names_this_round; do + already_handled= + for n in $names_already_handled; do + if test "$n" = "$name"; then + already_handled=yes + break + fi + done + if test -z "$already_handled"; then + names_already_handled="$names_already_handled $name" + uppername=`echo "$name" | sed -e 'y|abcdefghijklmnopqrstuvwxyz./-|ABCDEFGHIJKLMNOPQRSTUVWXYZ___|'` + eval value=\"\$HAVE_LIB$uppername\" + if test -n "$value"; then + if test "$value" = yes; then + eval value=\"\$LIB$uppername\" + test -z "$value" || LIBINTL="${LIBINTL}${LIBINTL:+ }$value" + eval value=\"\$LTLIB$uppername\" + test -z "$value" || LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }$value" + else + : + fi + else + found_dir= + found_la= + found_so= + found_a= + if test $use_additional = yes; then + if test -n "$shlibext" && test -f "$additional_libdir/lib$name.$shlibext"; then + found_dir="$additional_libdir" + found_so="$additional_libdir/lib$name.$shlibext" + if test -f "$additional_libdir/lib$name.la"; then + found_la="$additional_libdir/lib$name.la" + fi + else + if test -f "$additional_libdir/lib$name.$libext"; then + found_dir="$additional_libdir" + found_a="$additional_libdir/lib$name.$libext" + if test -f "$additional_libdir/lib$name.la"; then + found_la="$additional_libdir/lib$name.la" + fi + fi + fi + fi + if test "X$found_dir" = "X"; then + for x in $LDFLAGS $LTLIBINTL; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + case "$x" in + -L*) + dir=`echo "X$x" | sed -e 's/^X-L//'` + if test -n "$shlibext" && test -f "$dir/lib$name.$shlibext"; then + found_dir="$dir" + found_so="$dir/lib$name.$shlibext" + if test -f "$dir/lib$name.la"; then + found_la="$dir/lib$name.la" + fi + else + if test -f "$dir/lib$name.$libext"; then + found_dir="$dir" + found_a="$dir/lib$name.$libext" + if test -f "$dir/lib$name.la"; then + found_la="$dir/lib$name.la" + fi + fi + fi + ;; + esac + if test "X$found_dir" != "X"; then + break + fi + done + fi + if test "X$found_dir" != "X"; then + LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }-L$found_dir -l$name" + if test "X$found_so" != "X"; then + if test "$enable_rpath" = no || test "X$found_dir" = "X/usr/lib"; then + LIBINTL="${LIBINTL}${LIBINTL:+ }$found_so" + else + haveit= + for x in $ltrpathdirs; do + if test "X$x" = "X$found_dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + ltrpathdirs="$ltrpathdirs $found_dir" + fi + if test "$hardcode_direct" = yes; then + LIBINTL="${LIBINTL}${LIBINTL:+ }$found_so" + else + if test -n "$hardcode_libdir_flag_spec" && test "$hardcode_minus_L" = no; then + LIBINTL="${LIBINTL}${LIBINTL:+ }$found_so" + haveit= + for x in $rpathdirs; do + if test "X$x" = "X$found_dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + rpathdirs="$rpathdirs $found_dir" + fi + else + haveit= + for x in $LDFLAGS $LIBINTL; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + if test "X$x" = "X-L$found_dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + LIBINTL="${LIBINTL}${LIBINTL:+ }-L$found_dir" + fi + if test "$hardcode_minus_L" != no; then + LIBINTL="${LIBINTL}${LIBINTL:+ }$found_so" + else + LIBINTL="${LIBINTL}${LIBINTL:+ }-l$name" + fi + fi + fi + fi + else + if test "X$found_a" != "X"; then + LIBINTL="${LIBINTL}${LIBINTL:+ }$found_a" + else + LIBINTL="${LIBINTL}${LIBINTL:+ }-L$found_dir -l$name" + fi + fi + additional_includedir= + case "$found_dir" in + */lib | */lib/) + basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e 's,/lib/*$,,'` + additional_includedir="$basedir/include" + ;; + esac + if test "X$additional_includedir" != "X"; then + if test "X$additional_includedir" != "X/usr/include"; then + haveit= + if test "X$additional_includedir" = "X/usr/local/include"; then + if test -n "$GCC"; then + case $host_os in + linux* | gnu* | k*bsd*-gnu) haveit=yes;; + esac + fi + fi + if test -z "$haveit"; then + for x in $CPPFLAGS $INCINTL; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + if test "X$x" = "X-I$additional_includedir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + if test -d "$additional_includedir"; then + INCINTL="${INCINTL}${INCINTL:+ }-I$additional_includedir" + fi + fi + fi + fi + fi + if test -n "$found_la"; then + save_libdir="$libdir" + case "$found_la" in + */* | *\\*) . "$found_la" ;; + *) . "./$found_la" ;; + esac + libdir="$save_libdir" + for dep in $dependency_libs; do + case "$dep" in + -L*) + additional_libdir=`echo "X$dep" | sed -e 's/^X-L//'` + if test "X$additional_libdir" != "X/usr/lib"; then + haveit= + if test "X$additional_libdir" = "X/usr/local/lib"; then + if test -n "$GCC"; then + case $host_os in + linux* | gnu* | k*bsd*-gnu) haveit=yes;; + esac + fi + fi + if test -z "$haveit"; then + haveit= + for x in $LDFLAGS $LIBINTL; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + if test "X$x" = "X-L$additional_libdir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + if test -d "$additional_libdir"; then + LIBINTL="${LIBINTL}${LIBINTL:+ }-L$additional_libdir" + fi + fi + haveit= + for x in $LDFLAGS $LTLIBINTL; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + if test "X$x" = "X-L$additional_libdir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + if test -d "$additional_libdir"; then + LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }-L$additional_libdir" + fi + fi + fi + fi + ;; + -R*) + dir=`echo "X$dep" | sed -e 's/^X-R//'` + if test "$enable_rpath" != no; then + haveit= + for x in $rpathdirs; do + if test "X$x" = "X$dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + rpathdirs="$rpathdirs $dir" + fi + haveit= + for x in $ltrpathdirs; do + if test "X$x" = "X$dir"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + ltrpathdirs="$ltrpathdirs $dir" + fi + fi + ;; + -l*) + names_next_round="$names_next_round "`echo "X$dep" | sed -e 's/^X-l//'` + ;; + *.la) + names_next_round="$names_next_round "`echo "X$dep" | sed -e 's,^X.*/,,' -e 's,^lib,,' -e 's,\.la$,,'` + ;; + *) + LIBINTL="${LIBINTL}${LIBINTL:+ }$dep" + LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }$dep" + ;; + esac + done + fi + else + LIBINTL="${LIBINTL}${LIBINTL:+ }-l$name" + LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }-l$name" + fi + fi + fi + done + done + if test "X$rpathdirs" != "X"; then + if test -n "$hardcode_libdir_separator"; then + alldirs= + for found_dir in $rpathdirs; do + alldirs="${alldirs}${alldirs:+$hardcode_libdir_separator}$found_dir" + done + acl_save_libdir="$libdir" + libdir="$alldirs" + eval flag=\"$hardcode_libdir_flag_spec\" + libdir="$acl_save_libdir" + LIBINTL="${LIBINTL}${LIBINTL:+ }$flag" + else + for found_dir in $rpathdirs; do + acl_save_libdir="$libdir" + libdir="$found_dir" + eval flag=\"$hardcode_libdir_flag_spec\" + libdir="$acl_save_libdir" + LIBINTL="${LIBINTL}${LIBINTL:+ }$flag" + done + fi + fi + if test "X$ltrpathdirs" != "X"; then + for found_dir in $ltrpathdirs; do + LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }-R$found_dir" + done + fi + + echo "$as_me:$LINENO: checking for GNU gettext in libintl" >&5 +echo $ECHO_N "checking for GNU gettext in libintl... $ECHO_C" >&6 +if test "${gt_cv_func_gnugettext1_libintl+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + gt_save_CPPFLAGS="$CPPFLAGS" + CPPFLAGS="$CPPFLAGS $INCINTL" + gt_save_LIBS="$LIBS" + LIBS="$LIBS $LIBINTL" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +extern int _nl_msg_cat_cntr; +extern +#ifdef __cplusplus +"C" +#endif +const char *_nl_expand_alias (const char *); +int +main () +{ +bindtextdomain ("", ""); +return * gettext ("") + _nl_msg_cat_cntr + *_nl_expand_alias ("") + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + gt_cv_func_gnugettext1_libintl=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +gt_cv_func_gnugettext1_libintl=no +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + if test "$gt_cv_func_gnugettext1_libintl" != yes && test -n "$LIBICONV"; then + LIBS="$LIBS $LIBICONV" + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +extern int _nl_msg_cat_cntr; +extern +#ifdef __cplusplus +"C" +#endif +const char *_nl_expand_alias (const char *); +int +main () +{ +bindtextdomain ("", ""); +return * gettext ("") + _nl_msg_cat_cntr + *_nl_expand_alias ("") + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext conftest$ac_exeext +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 + (eval $ac_link) 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; } && + { ac_try='test -s conftest$ac_exeext' + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 + (eval $ac_try) 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; }; then + LIBINTL="$LIBINTL $LIBICONV" + LTLIBINTL="$LTLIBINTL $LTLIBICONV" + gt_cv_func_gnugettext1_libintl=yes + +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +fi +rm -f conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + fi + CPPFLAGS="$gt_save_CPPFLAGS" + LIBS="$gt_save_LIBS" +fi +echo "$as_me:$LINENO: result: $gt_cv_func_gnugettext1_libintl" >&5 +echo "${ECHO_T}$gt_cv_func_gnugettext1_libintl" >&6 + fi + + if test "$gt_cv_func_gnugettext1_libc" = "yes" \ + || { test "$gt_cv_func_gnugettext1_libintl" = "yes" \ + && test "$PACKAGE" != gettext-runtime \ + && test "$PACKAGE" != gettext-tools; }; then + gt_use_preinstalled_gnugettext=yes + else + LIBINTL= + LTLIBINTL= + INCINTL= + fi + + + if test "$gt_use_preinstalled_gnugettext" != "yes"; then + nls_cv_use_gnu_gettext=yes + fi + fi + + if test "$nls_cv_use_gnu_gettext" = "yes"; then + BUILD_INCLUDED_LIBINTL=yes + USE_INCLUDED_LIBINTL=yes + LIBINTL="\${top_builddir}/intl/libintl.a $LIBICONV" + LTLIBINTL="\${top_builddir}/intl/libintl.a $LTLIBICONV" + LIBS=`echo " $LIBS " | sed -e 's/ -lintl / /' -e 's/^ //' -e 's/ $//'` + fi + + CATOBJEXT= + if test "$gt_use_preinstalled_gnugettext" = "yes" \ + || test "$nls_cv_use_gnu_gettext" = "yes"; then + CATOBJEXT=.gmo + fi + + + if test -n "$INTL_MACOSX_LIBS"; then + if test "$gt_use_preinstalled_gnugettext" = "yes" \ + || test "$nls_cv_use_gnu_gettext" = "yes"; then + LIBINTL="$LIBINTL $INTL_MACOSX_LIBS" + LTLIBINTL="$LTLIBINTL $INTL_MACOSX_LIBS" + fi + fi + + if test "$gt_use_preinstalled_gnugettext" = "yes" \ + || test "$nls_cv_use_gnu_gettext" = "yes"; then + +cat >>confdefs.h <<\_ACEOF +#define ENABLE_NLS 1 +_ACEOF + + else + USE_NLS=no + fi + fi + + echo "$as_me:$LINENO: checking whether to use NLS" >&5 +echo $ECHO_N "checking whether to use NLS... $ECHO_C" >&6 + echo "$as_me:$LINENO: result: $USE_NLS" >&5 +echo "${ECHO_T}$USE_NLS" >&6 + if test "$USE_NLS" = "yes"; then + echo "$as_me:$LINENO: checking where the gettext function comes from" >&5 +echo $ECHO_N "checking where the gettext function comes from... $ECHO_C" >&6 + if test "$gt_use_preinstalled_gnugettext" = "yes"; then + if test "$gt_cv_func_gnugettext1_libintl" = "yes"; then + gt_source="external libintl" + else + gt_source="libc" + fi + else + gt_source="included intl directory" + fi + echo "$as_me:$LINENO: result: $gt_source" >&5 +echo "${ECHO_T}$gt_source" >&6 + fi + + if test "$USE_NLS" = "yes"; then + + if test "$gt_use_preinstalled_gnugettext" = "yes"; then + if test "$gt_cv_func_gnugettext1_libintl" = "yes"; then + echo "$as_me:$LINENO: checking how to link with libintl" >&5 +echo $ECHO_N "checking how to link with libintl... $ECHO_C" >&6 + echo "$as_me:$LINENO: result: $LIBINTL" >&5 +echo "${ECHO_T}$LIBINTL" >&6 + + for element in $INCINTL; do + haveit= + for x in $CPPFLAGS; do + + acl_save_prefix="$prefix" + prefix="$acl_final_prefix" + acl_save_exec_prefix="$exec_prefix" + exec_prefix="$acl_final_exec_prefix" + eval x=\"$x\" + exec_prefix="$acl_save_exec_prefix" + prefix="$acl_save_prefix" + + if test "X$x" = "X$element"; then + haveit=yes + break + fi + done + if test -z "$haveit"; then + CPPFLAGS="${CPPFLAGS}${CPPFLAGS:+ }$element" + fi + done + + fi + + +cat >>confdefs.h <<\_ACEOF +#define HAVE_GETTEXT 1 +_ACEOF + + +cat >>confdefs.h <<\_ACEOF +#define HAVE_DCGETTEXT 1 +_ACEOF + + fi + + POSUB=po + fi + + + if test "$PACKAGE" = gettext-runtime || test "$PACKAGE" = gettext-tools; then + BUILD_INCLUDED_LIBINTL=yes + fi + + + + + + nls_cv_header_intl= + nls_cv_header_libgt= + + DATADIRNAME=share + + + INSTOBJEXT=.mo + + + GENCAT=gencat + + + INTLOBJS= + if test "$USE_INCLUDED_LIBINTL" = yes; then + INTLOBJS="\$(GETTOBJS)" + fi + + + INTL_LIBTOOL_SUFFIX_PREFIX= + + + + INTLLIBS="$LIBINTL" + + + + + + + +_localedir=`eval "echo $datadir/locale"` +if test "$_localedir" = "NONE/share/locale"; then + cat >>confdefs.h <<_ACEOF +#define LOCALEDIR "/usr/local/share/locale" +_ACEOF + +else + _localedir=`echo \"$_localedir\"` + cat >>confdefs.h <<_ACEOF +#define LOCALEDIR $_localedir +_ACEOF + +fi + + + +if test x$USE_INCLUDED_LIBINTL = xyes; then + COMPILE_INTL_TRUE= + COMPILE_INTL_FALSE='#' +else + COMPILE_INTL_TRUE='#' + COMPILE_INTL_FALSE= +fi + + + ac_config_files="$ac_config_files Makefile gsmlib/Makefile tests/Makefile apps/Makefile win32/Makefile doc/Makefile scripts/Makefile intl/Makefile po/Makefile.in ext/Makefile" + ac_config_commands="$ac_config_commands default" +cat >confcache <<\_ACEOF +# This file is a shell script that caches the results of configure +# tests run on this system so they can be shared between configure +# scripts and configure runs, see configure's option --config-cache. +# It is not useful on other systems. If it contains results you don't +# want to keep, you may remove or edit it. +# +# config.status only pays attention to the cache file if you give it +# the --recheck option to rerun configure. +# +# `ac_cv_env_foo' variables (set or unset) will be overridden when +# loading this file, other *unset* `ac_cv_foo' will be assigned the +# following values. + +_ACEOF + +# The following way of writing the cache mishandles newlines in values, +# but we know of no workaround that is simple, portable, and efficient. +# So, don't put newlines in cache variables' values. +# Ultrix sh set writes to stderr and can't be redirected directly, +# and sets the high bit in the cache file unless we assign to the vars. +{ + (set) 2>&1 | + case `(ac_space=' '; set | grep ac_space) 2>&1` in + *ac_space=\ *) + # `set' does not quote correctly, so add quotes (double-quote + # substitution turns \\\\ into \\, and sed turns \\ into \). + sed -n \ + "s/'/'\\\\''/g; + s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p" + ;; + *) + # `set' quotes correctly as required by POSIX, so do not add quotes. + sed -n \ + "s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1=\\2/p" + ;; + esac; +} | + sed ' + t clear + : clear + s/^\([^=]*\)=\(.*[{}].*\)$/test "${\1+set}" = set || &/ + t end + /^ac_cv_env/!s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/ + : end' >>confcache +if diff $cache_file confcache >/dev/null 2>&1; then :; else + if test -w $cache_file; then + test "x$cache_file" != "x/dev/null" && echo "updating cache $cache_file" + cat confcache >$cache_file + else + echo "not updating unwritable cache $cache_file" + fi +fi +rm -f confcache + +test "x$prefix" = xNONE && prefix=$ac_default_prefix +# Let make expand exec_prefix. +test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' + +# VPATH may cause trouble with some makes, so we remove $(srcdir), +# ${srcdir} and @srcdir@ from VPATH if srcdir is ".", strip leading and +# trailing colons and then remove the whole line if VPATH becomes empty +# (actually we leave an empty line to preserve line numbers). +if test "x$srcdir" = x.; then + ac_vpsub='/^[ ]*VPATH[ ]*=/{ +s/:*\$(srcdir):*/:/; +s/:*\${srcdir}:*/:/; +s/:*@srcdir@:*/:/; +s/^\([^=]*=[ ]*\):*/\1/; +s/:*$//; +s/^[^=]*=[ ]*$//; +}' +fi + +DEFS=-DHAVE_CONFIG_H + +ac_libobjs= +ac_ltlibobjs= +for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue + # 1. Remove the extension, and $U if already installed. + ac_i=`echo "$ac_i" | + sed 's/\$U\././;s/\.o$//;s/\.obj$//'` + # 2. Add them. + ac_libobjs="$ac_libobjs $ac_i\$U.$ac_objext" + ac_ltlibobjs="$ac_ltlibobjs $ac_i"'$U.lo' +done +LIBOBJS=$ac_libobjs + +LTLIBOBJS=$ac_ltlibobjs + + +if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"AMDEP\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"AMDEP\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"am__fastdepCC\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"am__fastdepCC\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${am__fastdepCXX_TRUE}" && test -z "${am__fastdepCXX_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"am__fastdepCXX\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"am__fastdepCXX\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${am__fastdepCXX_TRUE}" && test -z "${am__fastdepCXX_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"am__fastdepCXX\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"am__fastdepCXX\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${COMPILE_INTL_TRUE}" && test -z "${COMPILE_INTL_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"COMPILE_INTL\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"COMPILE_INTL\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi + +: ${CONFIG_STATUS=./config.status} +ac_clean_files_save=$ac_clean_files +ac_clean_files="$ac_clean_files $CONFIG_STATUS" +{ echo "$as_me:$LINENO: creating $CONFIG_STATUS" >&5 +echo "$as_me: creating $CONFIG_STATUS" >&6;} +cat >$CONFIG_STATUS <<_ACEOF +#! $SHELL +# Generated by $as_me. +# Run this file to recreate the current configuration. +# Compiler output produced by configure, useful for debugging +# configure, is in config.log if it exists. + +debug=false +ac_cs_recheck=false +ac_cs_silent=false +SHELL=\${CONFIG_SHELL-$SHELL} +_ACEOF + +cat >>$CONFIG_STATUS <<\_ACEOF +## --------------------- ## +## M4sh Initialization. ## +## --------------------- ## + +# Be Bourne compatible +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then + emulate sh + NULLCMD=: + # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which + # is contrary to our usage. Disable this feature. + alias -g '${1+"$@"}'='"$@"' +elif test -n "${BASH_VERSION+set}" && (set -o posix) >/dev/null 2>&1; then + set -o posix +fi +DUALCASE=1; export DUALCASE # for MKS sh + +# Support unset when possible. +if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then + as_unset=unset +else + as_unset=false +fi + + +# Work around bugs in pre-3.0 UWIN ksh. +$as_unset ENV MAIL MAILPATH +PS1='$ ' +PS2='> ' +PS4='+ ' + +# NLS nuisances. +for as_var in \ + LANG LANGUAGE LC_ADDRESS LC_ALL LC_COLLATE LC_CTYPE LC_IDENTIFICATION \ + LC_MEASUREMENT LC_MESSAGES LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER \ + LC_TELEPHONE LC_TIME +do + if (set +x; test -z "`(eval $as_var=C; export $as_var) 2>&1`"); then + eval $as_var=C; export $as_var + else + $as_unset $as_var + fi +done + +# Required to use basename. +if expr a : '\(a\)' >/dev/null 2>&1; then + as_expr=expr +else + as_expr=false +fi + +if (basename /) >/dev/null 2>&1 && test "X`basename / 2>&1`" = "X/"; then + as_basename=basename +else + as_basename=false +fi + + +# Name of the executable. +as_me=`$as_basename "$0" || +$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ + X"$0" : 'X\(//\)$' \| \ + X"$0" : 'X\(/\)$' \| \ + . : '\(.\)' 2>/dev/null || +echo X/"$0" | + sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/; q; } + /^X\/\(\/\/\)$/{ s//\1/; q; } + /^X\/\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + + +# PATH needs CR, and LINENO needs CR and PATH. +# Avoid depending upon Character Ranges. +as_cr_letters='abcdefghijklmnopqrstuvwxyz' +as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' +as_cr_Letters=$as_cr_letters$as_cr_LETTERS +as_cr_digits='0123456789' +as_cr_alnum=$as_cr_Letters$as_cr_digits + +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + echo "#! /bin/sh" >conf$$.sh + echo "exit 0" >>conf$$.sh + chmod +x conf$$.sh + if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then + PATH_SEPARATOR=';' + else + PATH_SEPARATOR=: + fi + rm -f conf$$.sh +fi + + + as_lineno_1=$LINENO + as_lineno_2=$LINENO + as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null` + test "x$as_lineno_1" != "x$as_lineno_2" && + test "x$as_lineno_3" = "x$as_lineno_2" || { + # Find who we are. Look in the path if we contain no path at all + # relative or not. + case $0 in + *[\\/]* ) as_myself=$0 ;; + *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break +done + + ;; + esac + # We did not find ourselves, most probably we were run as `sh COMMAND' + # in which case we are not to be found in the path. + if test "x$as_myself" = x; then + as_myself=$0 + fi + if test ! -f "$as_myself"; then + { { echo "$as_me:$LINENO: error: cannot find myself; rerun with an absolute path" >&5 +echo "$as_me: error: cannot find myself; rerun with an absolute path" >&2;} + { (exit 1); exit 1; }; } + fi + case $CONFIG_SHELL in + '') + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for as_base in sh bash ksh sh5; do + case $as_dir in + /*) + if ("$as_dir/$as_base" -c ' + as_lineno_1=$LINENO + as_lineno_2=$LINENO + as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null` + test "x$as_lineno_1" != "x$as_lineno_2" && + test "x$as_lineno_3" = "x$as_lineno_2" ') 2>/dev/null; then + $as_unset BASH_ENV || test "${BASH_ENV+set}" != set || { BASH_ENV=; export BASH_ENV; } + $as_unset ENV || test "${ENV+set}" != set || { ENV=; export ENV; } + CONFIG_SHELL=$as_dir/$as_base + export CONFIG_SHELL + exec "$CONFIG_SHELL" "$0" ${1+"$@"} + fi;; + esac + done +done +;; + esac + + # Create $as_me.lineno as a copy of $as_myself, but with $LINENO + # uniformly replaced by the line number. The first 'sed' inserts a + # line-number line before each line; the second 'sed' does the real + # work. The second script uses 'N' to pair each line-number line + # with the numbered line, and appends trailing '-' during + # substitution so that $LINENO is not a special case at line end. + # (Raja R Harinath suggested sed '=', and Paul Eggert wrote the + # second 'sed' script. Blame Lee E. McMahon for sed's syntax. :-) + sed '=' <$as_myself | + sed ' + N + s,$,-, + : loop + s,^\(['$as_cr_digits']*\)\(.*\)[$]LINENO\([^'$as_cr_alnum'_]\),\1\2\1\3, + t loop + s,-$,, + s,^['$as_cr_digits']*\n,, + ' >$as_me.lineno && + chmod +x $as_me.lineno || + { { echo "$as_me:$LINENO: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&5 +echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2;} + { (exit 1); exit 1; }; } + + # Don't try to exec as it changes $[0], causing all sort of problems + # (the dirname of $[0] is not the place where we might find the + # original and so on. Autoconf is especially sensible to this). + . ./$as_me.lineno + # Exit status is that of the last command. + exit +} + + +case `echo "testing\c"; echo 1,2,3`,`echo -n testing; echo 1,2,3` in + *c*,-n*) ECHO_N= ECHO_C=' +' ECHO_T=' ' ;; + *c*,* ) ECHO_N=-n ECHO_C= ECHO_T= ;; + *) ECHO_N= ECHO_C='\c' ECHO_T= ;; +esac + +if expr a : '\(a\)' >/dev/null 2>&1; then + as_expr=expr +else + as_expr=false +fi + +rm -f conf$$ conf$$.exe conf$$.file +echo >conf$$.file +if ln -s conf$$.file conf$$ 2>/dev/null; then + # We could just check for DJGPP; but this test a) works b) is more generic + # and c) will remain valid once DJGPP supports symlinks (DJGPP 2.04). + if test -f conf$$.exe; then + # Don't use ln at all; we don't have any links + as_ln_s='cp -p' + else + as_ln_s='ln -s' + fi +elif ln conf$$.file conf$$ 2>/dev/null; then + as_ln_s=ln +else + as_ln_s='cp -p' +fi +rm -f conf$$ conf$$.exe conf$$.file + +if mkdir -p . 2>/dev/null; then + as_mkdir_p=: +else + test -d ./-p && rmdir ./-p + as_mkdir_p=false +fi + +as_executable_p="test -f" + +# Sed expression to map a string onto a valid CPP name. +as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" + +# Sed expression to map a string onto a valid variable name. +as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" + + +# IFS +# We need space, tab and new line, in precisely that order. +as_nl=' +' +IFS=" $as_nl" + +# CDPATH. +$as_unset CDPATH + +exec 6>&1 + +# Open the log real soon, to keep \$[0] and so on meaningful, and to +# report actual input values of CONFIG_FILES etc. instead of their +# values after options handling. Logging --version etc. is OK. +exec 5>>config.log +{ + echo + sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX +## Running $as_me. ## +_ASBOX +} >&5 +cat >&5 <<_CSEOF + +This file was extended by $as_me, which was +generated by GNU Autoconf 2.59. Invocation command line was + + CONFIG_FILES = $CONFIG_FILES + CONFIG_HEADERS = $CONFIG_HEADERS + CONFIG_LINKS = $CONFIG_LINKS + CONFIG_COMMANDS = $CONFIG_COMMANDS + $ $0 $@ + +_CSEOF +echo "on `(hostname || uname -n) 2>/dev/null | sed 1q`" >&5 +echo >&5 +_ACEOF + +# Files that config.status was made for. +if test -n "$ac_config_files"; then + echo "config_files=\"$ac_config_files\"" >>$CONFIG_STATUS +fi + +if test -n "$ac_config_headers"; then + echo "config_headers=\"$ac_config_headers\"" >>$CONFIG_STATUS +fi + +if test -n "$ac_config_links"; then + echo "config_links=\"$ac_config_links\"" >>$CONFIG_STATUS +fi + +if test -n "$ac_config_commands"; then + echo "config_commands=\"$ac_config_commands\"" >>$CONFIG_STATUS +fi + +cat >>$CONFIG_STATUS <<\_ACEOF + +ac_cs_usage="\ +\`$as_me' instantiates files from templates according to the +current configuration. + +Usage: $0 [OPTIONS] [FILE]... + + -h, --help print this help, then exit + -V, --version print version number, then exit + -q, --quiet do not print progress messages + -d, --debug don't remove temporary files + --recheck update $as_me by reconfiguring in the same conditions + --file=FILE[:TEMPLATE] + instantiate the configuration file FILE + --header=FILE[:TEMPLATE] + instantiate the configuration header FILE + +Configuration files: +$config_files + +Configuration headers: +$config_headers + +Configuration commands: +$config_commands + +Report bugs to ." +_ACEOF + +cat >>$CONFIG_STATUS <<_ACEOF +ac_cs_version="\\ +config.status +configured by $0, generated by GNU Autoconf 2.59, + with options \\"`echo "$ac_configure_args" | sed 's/[\\""\`\$]/\\\\&/g'`\\" + +Copyright (C) 2003 Free Software Foundation, Inc. +This config.status script is free software; the Free Software Foundation +gives unlimited permission to copy, distribute and modify it." +srcdir=$srcdir +INSTALL="$INSTALL" +_ACEOF + +cat >>$CONFIG_STATUS <<\_ACEOF +# If no file are specified by the user, then we need to provide default +# value. By we need to know if files were specified by the user. +ac_need_defaults=: +while test $# != 0 +do + case $1 in + --*=*) + ac_option=`expr "x$1" : 'x\([^=]*\)='` + ac_optarg=`expr "x$1" : 'x[^=]*=\(.*\)'` + ac_shift=: + ;; + -*) + ac_option=$1 + ac_optarg=$2 + ac_shift=shift + ;; + *) # This is not an option, so the user has probably given explicit + # arguments. + ac_option=$1 + ac_need_defaults=false;; + esac + + case $ac_option in + # Handling of the options. +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF + -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) + ac_cs_recheck=: ;; + --version | --vers* | -V ) + echo "$ac_cs_version"; exit 0 ;; + --he | --h) + # Conflict between --help and --header + { { echo "$as_me:$LINENO: error: ambiguous option: $1 +Try \`$0 --help' for more information." >&5 +echo "$as_me: error: ambiguous option: $1 +Try \`$0 --help' for more information." >&2;} + { (exit 1); exit 1; }; };; + --help | --hel | -h ) + echo "$ac_cs_usage"; exit 0 ;; + --debug | --d* | -d ) + debug=: ;; + --file | --fil | --fi | --f ) + $ac_shift + CONFIG_FILES="$CONFIG_FILES $ac_optarg" + ac_need_defaults=false;; + --header | --heade | --head | --hea ) + $ac_shift + CONFIG_HEADERS="$CONFIG_HEADERS $ac_optarg" + ac_need_defaults=false;; + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil | --si | --s) + ac_cs_silent=: ;; + + # This is an error. + -*) { { echo "$as_me:$LINENO: error: unrecognized option: $1 +Try \`$0 --help' for more information." >&5 +echo "$as_me: error: unrecognized option: $1 +Try \`$0 --help' for more information." >&2;} + { (exit 1); exit 1; }; } ;; + + *) ac_config_targets="$ac_config_targets $1" ;; + + esac + shift +done + +ac_configure_extra_args= + +if $ac_cs_silent; then + exec 6>/dev/null + ac_configure_extra_args="$ac_configure_extra_args --silent" +fi + +_ACEOF +cat >>$CONFIG_STATUS <<_ACEOF +if \$ac_cs_recheck; then + echo "running $SHELL $0 " $ac_configure_args \$ac_configure_extra_args " --no-create --no-recursion" >&6 + exec $SHELL $0 $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion +fi + +_ACEOF + +cat >>$CONFIG_STATUS <<_ACEOF +# +# INIT-COMMANDS section. +# + +AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir" +# Capture the value of obsolete ALL_LINGUAS because we need it to compute + # POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES, CATALOGS. But hide it + # from automake. + eval 'OBSOLETE_ALL_LINGUAS''="$ALL_LINGUAS"' + # Capture the value of LINGUAS because we need it to compute CATALOGS. + LINGUAS="${LINGUAS-%UNSET%}" + + +_ACEOF + + + +cat >>$CONFIG_STATUS <<\_ACEOF +for ac_config_target in $ac_config_targets +do + case "$ac_config_target" in + # Handling of arguments. + "Makefile" ) CONFIG_FILES="$CONFIG_FILES Makefile" ;; + "gsmlib/Makefile" ) CONFIG_FILES="$CONFIG_FILES gsmlib/Makefile" ;; + "tests/Makefile" ) CONFIG_FILES="$CONFIG_FILES tests/Makefile" ;; + "apps/Makefile" ) CONFIG_FILES="$CONFIG_FILES apps/Makefile" ;; + "win32/Makefile" ) CONFIG_FILES="$CONFIG_FILES win32/Makefile" ;; + "doc/Makefile" ) CONFIG_FILES="$CONFIG_FILES doc/Makefile" ;; + "scripts/Makefile" ) CONFIG_FILES="$CONFIG_FILES scripts/Makefile" ;; + "intl/Makefile" ) CONFIG_FILES="$CONFIG_FILES intl/Makefile" ;; + "po/Makefile.in" ) CONFIG_FILES="$CONFIG_FILES po/Makefile.in" ;; + "ext/Makefile" ) CONFIG_FILES="$CONFIG_FILES ext/Makefile" ;; + "depfiles" ) CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; + "default-1" ) CONFIG_COMMANDS="$CONFIG_COMMANDS default-1" ;; + "default" ) CONFIG_COMMANDS="$CONFIG_COMMANDS default" ;; + "gsm_config.h" ) CONFIG_HEADERS="$CONFIG_HEADERS gsm_config.h" ;; + *) { { echo "$as_me:$LINENO: error: invalid argument: $ac_config_target" >&5 +echo "$as_me: error: invalid argument: $ac_config_target" >&2;} + { (exit 1); exit 1; }; };; + esac +done + +# If the user did not use the arguments to specify the items to instantiate, +# then the envvar interface is used. Set only those that are not. +# We use the long form for the default assignment because of an extremely +# bizarre bug on SunOS 4.1.3. +if $ac_need_defaults; then + test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files + test "${CONFIG_HEADERS+set}" = set || CONFIG_HEADERS=$config_headers + test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands +fi + +# Have a temporary directory for convenience. Make it in the build tree +# simply because there is no reason to put it here, and in addition, +# creating and moving files from /tmp can sometimes cause problems. +# Create a temporary directory, and hook for its removal unless debugging. +$debug || +{ + trap 'exit_status=$?; rm -rf $tmp && exit $exit_status' 0 + trap '{ (exit 1); exit 1; }' 1 2 13 15 +} + +# Create a (secure) tmp directory for tmp files. + +{ + tmp=`(umask 077 && mktemp -d -q "./confstatXXXXXX") 2>/dev/null` && + test -n "$tmp" && test -d "$tmp" +} || +{ + tmp=./confstat$$-$RANDOM + (umask 077 && mkdir $tmp) +} || +{ + echo "$me: cannot create a temporary directory in ." >&2 + { (exit 1); exit 1; } +} + +_ACEOF + +cat >>$CONFIG_STATUS <<_ACEOF + +# +# CONFIG_FILES section. +# + +# No need to generate the scripts if there are no CONFIG_FILES. +# This happens for instance when ./config.status config.h +if test -n "\$CONFIG_FILES"; then + # Protect against being on the right side of a sed subst in config.status. + sed 's/,@/@@/; s/@,/@@/; s/,;t t\$/@;t t/; /@;t t\$/s/[\\\\&,]/\\\\&/g; + s/@@/,@/; s/@@/@,/; s/@;t t\$/,;t t/' >\$tmp/subs.sed <<\\CEOF +s,@SHELL@,$SHELL,;t t +s,@PATH_SEPARATOR@,$PATH_SEPARATOR,;t t +s,@PACKAGE_NAME@,$PACKAGE_NAME,;t t +s,@PACKAGE_TARNAME@,$PACKAGE_TARNAME,;t t +s,@PACKAGE_VERSION@,$PACKAGE_VERSION,;t t +s,@PACKAGE_STRING@,$PACKAGE_STRING,;t t +s,@PACKAGE_BUGREPORT@,$PACKAGE_BUGREPORT,;t t +s,@exec_prefix@,$exec_prefix,;t t +s,@prefix@,$prefix,;t t +s,@program_transform_name@,$program_transform_name,;t t +s,@bindir@,$bindir,;t t +s,@sbindir@,$sbindir,;t t +s,@libexecdir@,$libexecdir,;t t +s,@datadir@,$datadir,;t t +s,@sysconfdir@,$sysconfdir,;t t +s,@sharedstatedir@,$sharedstatedir,;t t +s,@localstatedir@,$localstatedir,;t t +s,@libdir@,$libdir,;t t +s,@includedir@,$includedir,;t t +s,@oldincludedir@,$oldincludedir,;t t +s,@infodir@,$infodir,;t t +s,@mandir@,$mandir,;t t +s,@build_alias@,$build_alias,;t t +s,@host_alias@,$host_alias,;t t +s,@target_alias@,$target_alias,;t t +s,@DEFS@,$DEFS,;t t +s,@ECHO_C@,$ECHO_C,;t t +s,@ECHO_N@,$ECHO_N,;t t +s,@ECHO_T@,$ECHO_T,;t t +s,@LIBS@,$LIBS,;t t +s,@INSTALL_PROGRAM@,$INSTALL_PROGRAM,;t t +s,@INSTALL_SCRIPT@,$INSTALL_SCRIPT,;t t +s,@INSTALL_DATA@,$INSTALL_DATA,;t t +s,@CC@,$CC,;t t +s,@CFLAGS@,$CFLAGS,;t t +s,@LDFLAGS@,$LDFLAGS,;t t +s,@CPPFLAGS@,$CPPFLAGS,;t t +s,@ac_ct_CC@,$ac_ct_CC,;t t +s,@EXEEXT@,$EXEEXT,;t t +s,@OBJEXT@,$OBJEXT,;t t +s,@CYGPATH_W@,$CYGPATH_W,;t t +s,@PACKAGE@,$PACKAGE,;t t +s,@VERSION@,$VERSION,;t t +s,@ACLOCAL@,$ACLOCAL,;t t +s,@AUTOCONF@,$AUTOCONF,;t t +s,@AUTOMAKE@,$AUTOMAKE,;t t +s,@AUTOHEADER@,$AUTOHEADER,;t t +s,@MAKEINFO@,$MAKEINFO,;t t +s,@install_sh@,$install_sh,;t t +s,@STRIP@,$STRIP,;t t +s,@ac_ct_STRIP@,$ac_ct_STRIP,;t t +s,@INSTALL_STRIP_PROGRAM@,$INSTALL_STRIP_PROGRAM,;t t +s,@mkdir_p@,$mkdir_p,;t t +s,@AWK@,$AWK,;t t +s,@SET_MAKE@,$SET_MAKE,;t t +s,@am__leading_dot@,$am__leading_dot,;t t +s,@AMTAR@,$AMTAR,;t t +s,@am__tar@,$am__tar,;t t +s,@am__untar@,$am__untar,;t t +s,@DEPDIR@,$DEPDIR,;t t +s,@am__include@,$am__include,;t t +s,@am__quote@,$am__quote,;t t +s,@AMDEP_TRUE@,$AMDEP_TRUE,;t t +s,@AMDEP_FALSE@,$AMDEP_FALSE,;t t +s,@AMDEPBACKSLASH@,$AMDEPBACKSLASH,;t t +s,@CCDEPMODE@,$CCDEPMODE,;t t +s,@am__fastdepCC_TRUE@,$am__fastdepCC_TRUE,;t t +s,@am__fastdepCC_FALSE@,$am__fastdepCC_FALSE,;t t +s,@build@,$build,;t t +s,@build_cpu@,$build_cpu,;t t +s,@build_vendor@,$build_vendor,;t t +s,@build_os@,$build_os,;t t +s,@host@,$host,;t t +s,@host_cpu@,$host_cpu,;t t +s,@host_vendor@,$host_vendor,;t t +s,@host_os@,$host_os,;t t +s,@EGREP@,$EGREP,;t t +s,@LN_S@,$LN_S,;t t +s,@ECHO@,$ECHO,;t t +s,@AR@,$AR,;t t +s,@ac_ct_AR@,$ac_ct_AR,;t t +s,@RANLIB@,$RANLIB,;t t +s,@ac_ct_RANLIB@,$ac_ct_RANLIB,;t t +s,@CPP@,$CPP,;t t +s,@CXX@,$CXX,;t t +s,@CXXFLAGS@,$CXXFLAGS,;t t +s,@ac_ct_CXX@,$ac_ct_CXX,;t t +s,@CXXDEPMODE@,$CXXDEPMODE,;t t +s,@am__fastdepCXX_TRUE@,$am__fastdepCXX_TRUE,;t t +s,@am__fastdepCXX_FALSE@,$am__fastdepCXX_FALSE,;t t +s,@CXXCPP@,$CXXCPP,;t t +s,@F77@,$F77,;t t +s,@FFLAGS@,$FFLAGS,;t t +s,@ac_ct_F77@,$ac_ct_F77,;t t +s,@LIBTOOL@,$LIBTOOL,;t t +s,@ALLOCA@,$ALLOCA,;t t +s,@GSM_VERSION@,$GSM_VERSION,;t t +s,@MKINSTALLDIRS@,$MKINSTALLDIRS,;t t +s,@USE_NLS@,$USE_NLS,;t t +s,@MSGFMT@,$MSGFMT,;t t +s,@GMSGFMT@,$GMSGFMT,;t t +s,@XGETTEXT@,$XGETTEXT,;t t +s,@MSGMERGE@,$MSGMERGE,;t t +s,@GLIBC2@,$GLIBC2,;t t +s,@GLIBC21@,$GLIBC21,;t t +s,@INTL_MACOSX_LIBS@,$INTL_MACOSX_LIBS,;t t +s,@HAVE_POSIX_PRINTF@,$HAVE_POSIX_PRINTF,;t t +s,@HAVE_ASPRINTF@,$HAVE_ASPRINTF,;t t +s,@HAVE_SNPRINTF@,$HAVE_SNPRINTF,;t t +s,@HAVE_WPRINTF@,$HAVE_WPRINTF,;t t +s,@LIBICONV@,$LIBICONV,;t t +s,@LTLIBICONV@,$LTLIBICONV,;t t +s,@INTLBISON@,$INTLBISON,;t t +s,@BUILD_INCLUDED_LIBINTL@,$BUILD_INCLUDED_LIBINTL,;t t +s,@USE_INCLUDED_LIBINTL@,$USE_INCLUDED_LIBINTL,;t t +s,@CATOBJEXT@,$CATOBJEXT,;t t +s,@DATADIRNAME@,$DATADIRNAME,;t t +s,@INSTOBJEXT@,$INSTOBJEXT,;t t +s,@GENCAT@,$GENCAT,;t t +s,@INTLOBJS@,$INTLOBJS,;t t +s,@INTL_LIBTOOL_SUFFIX_PREFIX@,$INTL_LIBTOOL_SUFFIX_PREFIX,;t t +s,@INTLLIBS@,$INTLLIBS,;t t +s,@LIBINTL@,$LIBINTL,;t t +s,@LTLIBINTL@,$LTLIBINTL,;t t +s,@POSUB@,$POSUB,;t t +s,@COMPILE_INTL_TRUE@,$COMPILE_INTL_TRUE,;t t +s,@COMPILE_INTL_FALSE@,$COMPILE_INTL_FALSE,;t t +s,@LIBOBJS@,$LIBOBJS,;t t +s,@LTLIBOBJS@,$LTLIBOBJS,;t t +CEOF + +_ACEOF + + cat >>$CONFIG_STATUS <<\_ACEOF + # Split the substitutions into bite-sized pieces for seds with + # small command number limits, like on Digital OSF/1 and HP-UX. + ac_max_sed_lines=48 + ac_sed_frag=1 # Number of current file. + ac_beg=1 # First line for current file. + ac_end=$ac_max_sed_lines # Line after last line for current file. + ac_more_lines=: + ac_sed_cmds= + while $ac_more_lines; do + if test $ac_beg -gt 1; then + sed "1,${ac_beg}d; ${ac_end}q" $tmp/subs.sed >$tmp/subs.frag + else + sed "${ac_end}q" $tmp/subs.sed >$tmp/subs.frag + fi + if test ! -s $tmp/subs.frag; then + ac_more_lines=false + else + # The purpose of the label and of the branching condition is to + # speed up the sed processing (if there are no `@' at all, there + # is no need to browse any of the substitutions). + # These are the two extra sed commands mentioned above. + (echo ':t + /@[a-zA-Z_][a-zA-Z_0-9]*@/!b' && cat $tmp/subs.frag) >$tmp/subs-$ac_sed_frag.sed + if test -z "$ac_sed_cmds"; then + ac_sed_cmds="sed -f $tmp/subs-$ac_sed_frag.sed" + else + ac_sed_cmds="$ac_sed_cmds | sed -f $tmp/subs-$ac_sed_frag.sed" + fi + ac_sed_frag=`expr $ac_sed_frag + 1` + ac_beg=$ac_end + ac_end=`expr $ac_end + $ac_max_sed_lines` + fi + done + if test -z "$ac_sed_cmds"; then + ac_sed_cmds=cat + fi +fi # test -n "$CONFIG_FILES" + +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF +for ac_file in : $CONFIG_FILES; do test "x$ac_file" = x: && continue + # Support "outfile[:infile[:infile...]]", defaulting infile="outfile.in". + case $ac_file in + - | *:- | *:-:* ) # input from stdin + cat >$tmp/stdin + ac_file_in=`echo "$ac_file" | sed 's,[^:]*:,,'` + ac_file=`echo "$ac_file" | sed 's,:.*,,'` ;; + *:* ) ac_file_in=`echo "$ac_file" | sed 's,[^:]*:,,'` + ac_file=`echo "$ac_file" | sed 's,:.*,,'` ;; + * ) ac_file_in=$ac_file.in ;; + esac + + # Compute @srcdir@, @top_srcdir@, and @INSTALL@ for subdirectories. + ac_dir=`(dirname "$ac_file") 2>/dev/null || +$as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$ac_file" : 'X\(//\)[^/]' \| \ + X"$ac_file" : 'X\(//\)$' \| \ + X"$ac_file" : 'X\(/\)' \| \ + . : '\(.\)' 2>/dev/null || +echo X"$ac_file" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } + /^X\(\/\/\)[^/].*/{ s//\1/; q; } + /^X\(\/\/\)$/{ s//\1/; q; } + /^X\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + { if $as_mkdir_p; then + mkdir -p "$ac_dir" + else + as_dir="$ac_dir" + as_dirs= + while test ! -d "$as_dir"; do + as_dirs="$as_dir $as_dirs" + as_dir=`(dirname "$as_dir") 2>/dev/null || +$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$as_dir" : 'X\(//\)[^/]' \| \ + X"$as_dir" : 'X\(//\)$' \| \ + X"$as_dir" : 'X\(/\)' \| \ + . : '\(.\)' 2>/dev/null || +echo X"$as_dir" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } + /^X\(\/\/\)[^/].*/{ s//\1/; q; } + /^X\(\/\/\)$/{ s//\1/; q; } + /^X\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + done + test ! -n "$as_dirs" || mkdir $as_dirs + fi || { { echo "$as_me:$LINENO: error: cannot create directory \"$ac_dir\"" >&5 +echo "$as_me: error: cannot create directory \"$ac_dir\"" >&2;} + { (exit 1); exit 1; }; }; } + + ac_builddir=. + +if test "$ac_dir" != .; then + ac_dir_suffix=/`echo "$ac_dir" | sed 's,^\.[\\/],,'` + # A "../" for each directory in $ac_dir_suffix. + ac_top_builddir=`echo "$ac_dir_suffix" | sed 's,/[^\\/]*,../,g'` +else + ac_dir_suffix= ac_top_builddir= +fi + +case $srcdir in + .) # No --srcdir option. We are building in place. + ac_srcdir=. + if test -z "$ac_top_builddir"; then + ac_top_srcdir=. + else + ac_top_srcdir=`echo $ac_top_builddir | sed 's,/$,,'` + fi ;; + [\\/]* | ?:[\\/]* ) # Absolute path. + ac_srcdir=$srcdir$ac_dir_suffix; + ac_top_srcdir=$srcdir ;; + *) # Relative path. + ac_srcdir=$ac_top_builddir$srcdir$ac_dir_suffix + ac_top_srcdir=$ac_top_builddir$srcdir ;; +esac + +# Do not use `cd foo && pwd` to compute absolute paths, because +# the directories may not exist. +case `pwd` in +.) ac_abs_builddir="$ac_dir";; +*) + case "$ac_dir" in + .) ac_abs_builddir=`pwd`;; + [\\/]* | ?:[\\/]* ) ac_abs_builddir="$ac_dir";; + *) ac_abs_builddir=`pwd`/"$ac_dir";; + esac;; +esac +case $ac_abs_builddir in +.) ac_abs_top_builddir=${ac_top_builddir}.;; +*) + case ${ac_top_builddir}. in + .) ac_abs_top_builddir=$ac_abs_builddir;; + [\\/]* | ?:[\\/]* ) ac_abs_top_builddir=${ac_top_builddir}.;; + *) ac_abs_top_builddir=$ac_abs_builddir/${ac_top_builddir}.;; + esac;; +esac +case $ac_abs_builddir in +.) ac_abs_srcdir=$ac_srcdir;; +*) + case $ac_srcdir in + .) ac_abs_srcdir=$ac_abs_builddir;; + [\\/]* | ?:[\\/]* ) ac_abs_srcdir=$ac_srcdir;; + *) ac_abs_srcdir=$ac_abs_builddir/$ac_srcdir;; + esac;; +esac +case $ac_abs_builddir in +.) ac_abs_top_srcdir=$ac_top_srcdir;; +*) + case $ac_top_srcdir in + .) ac_abs_top_srcdir=$ac_abs_builddir;; + [\\/]* | ?:[\\/]* ) ac_abs_top_srcdir=$ac_top_srcdir;; + *) ac_abs_top_srcdir=$ac_abs_builddir/$ac_top_srcdir;; + esac;; +esac + + + case $INSTALL in + [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;; + *) ac_INSTALL=$ac_top_builddir$INSTALL ;; + esac + + # Let's still pretend it is `configure' which instantiates (i.e., don't + # use $as_me), people would be surprised to read: + # /* config.h. Generated by config.status. */ + if test x"$ac_file" = x-; then + configure_input= + else + configure_input="$ac_file. " + fi + configure_input=$configure_input"Generated from `echo $ac_file_in | + sed 's,.*/,,'` by configure." + + # First look for the input files in the build tree, otherwise in the + # src tree. + ac_file_inputs=`IFS=: + for f in $ac_file_in; do + case $f in + -) echo $tmp/stdin ;; + [\\/$]*) + # Absolute (can't be DOS-style, as IFS=:) + test -f "$f" || { { echo "$as_me:$LINENO: error: cannot find input file: $f" >&5 +echo "$as_me: error: cannot find input file: $f" >&2;} + { (exit 1); exit 1; }; } + echo "$f";; + *) # Relative + if test -f "$f"; then + # Build tree + echo "$f" + elif test -f "$srcdir/$f"; then + # Source tree + echo "$srcdir/$f" + else + # /dev/null tree + { { echo "$as_me:$LINENO: error: cannot find input file: $f" >&5 +echo "$as_me: error: cannot find input file: $f" >&2;} + { (exit 1); exit 1; }; } + fi;; + esac + done` || { (exit 1); exit 1; } + + if test x"$ac_file" != x-; then + { echo "$as_me:$LINENO: creating $ac_file" >&5 +echo "$as_me: creating $ac_file" >&6;} + rm -f "$ac_file" + fi +_ACEOF +cat >>$CONFIG_STATUS <<_ACEOF + sed "$ac_vpsub +$extrasub +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF +:t +/@[a-zA-Z_][a-zA-Z_0-9]*@/!b +s,@configure_input@,$configure_input,;t t +s,@srcdir@,$ac_srcdir,;t t +s,@abs_srcdir@,$ac_abs_srcdir,;t t +s,@top_srcdir@,$ac_top_srcdir,;t t +s,@abs_top_srcdir@,$ac_abs_top_srcdir,;t t +s,@builddir@,$ac_builddir,;t t +s,@abs_builddir@,$ac_abs_builddir,;t t +s,@top_builddir@,$ac_top_builddir,;t t +s,@abs_top_builddir@,$ac_abs_top_builddir,;t t +s,@INSTALL@,$ac_INSTALL,;t t +" $ac_file_inputs | (eval "$ac_sed_cmds") >$tmp/out + rm -f $tmp/stdin + if test x"$ac_file" != x-; then + mv $tmp/out $ac_file + else + cat $tmp/out + rm -f $tmp/out + fi + +done +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF + +# +# CONFIG_HEADER section. +# + +# These sed commands are passed to sed as "A NAME B NAME C VALUE D", where +# NAME is the cpp macro being defined and VALUE is the value it is being given. +# +# ac_d sets the value in "#define NAME VALUE" lines. +ac_dA='s,^\([ ]*\)#\([ ]*define[ ][ ]*\)' +ac_dB='[ ].*$,\1#\2' +ac_dC=' ' +ac_dD=',;t' +# ac_u turns "#undef NAME" without trailing blanks into "#define NAME VALUE". +ac_uA='s,^\([ ]*\)#\([ ]*\)undef\([ ][ ]*\)' +ac_uB='$,\1#\2define\3' +ac_uC=' ' +ac_uD=',;t' + +for ac_file in : $CONFIG_HEADERS; do test "x$ac_file" = x: && continue + # Support "outfile[:infile[:infile...]]", defaulting infile="outfile.in". + case $ac_file in + - | *:- | *:-:* ) # input from stdin + cat >$tmp/stdin + ac_file_in=`echo "$ac_file" | sed 's,[^:]*:,,'` + ac_file=`echo "$ac_file" | sed 's,:.*,,'` ;; + *:* ) ac_file_in=`echo "$ac_file" | sed 's,[^:]*:,,'` + ac_file=`echo "$ac_file" | sed 's,:.*,,'` ;; + * ) ac_file_in=$ac_file.in ;; + esac + + test x"$ac_file" != x- && { echo "$as_me:$LINENO: creating $ac_file" >&5 +echo "$as_me: creating $ac_file" >&6;} + + # First look for the input files in the build tree, otherwise in the + # src tree. + ac_file_inputs=`IFS=: + for f in $ac_file_in; do + case $f in + -) echo $tmp/stdin ;; + [\\/$]*) + # Absolute (can't be DOS-style, as IFS=:) + test -f "$f" || { { echo "$as_me:$LINENO: error: cannot find input file: $f" >&5 +echo "$as_me: error: cannot find input file: $f" >&2;} + { (exit 1); exit 1; }; } + # Do quote $f, to prevent DOS paths from being IFS'd. + echo "$f";; + *) # Relative + if test -f "$f"; then + # Build tree + echo "$f" + elif test -f "$srcdir/$f"; then + # Source tree + echo "$srcdir/$f" + else + # /dev/null tree + { { echo "$as_me:$LINENO: error: cannot find input file: $f" >&5 +echo "$as_me: error: cannot find input file: $f" >&2;} + { (exit 1); exit 1; }; } + fi;; + esac + done` || { (exit 1); exit 1; } + # Remove the trailing spaces. + sed 's/[ ]*$//' $ac_file_inputs >$tmp/in + +_ACEOF + +# Transform confdefs.h into two sed scripts, `conftest.defines' and +# `conftest.undefs', that substitutes the proper values into +# config.h.in to produce config.h. The first handles `#define' +# templates, and the second `#undef' templates. +# And first: Protect against being on the right side of a sed subst in +# config.status. Protect against being in an unquoted here document +# in config.status. +rm -f conftest.defines conftest.undefs +# Using a here document instead of a string reduces the quoting nightmare. +# Putting comments in sed scripts is not portable. +# +# `end' is used to avoid that the second main sed command (meant for +# 0-ary CPP macros) applies to n-ary macro definitions. +# See the Autoconf documentation for `clear'. +cat >confdef2sed.sed <<\_ACEOF +s/[\\&,]/\\&/g +s,[\\$`],\\&,g +t clear +: clear +s,^[ ]*#[ ]*define[ ][ ]*\([^ (][^ (]*\)\(([^)]*)\)[ ]*\(.*\)$,${ac_dA}\1${ac_dB}\1\2${ac_dC}\3${ac_dD},gp +t end +s,^[ ]*#[ ]*define[ ][ ]*\([^ ][^ ]*\)[ ]*\(.*\)$,${ac_dA}\1${ac_dB}\1${ac_dC}\2${ac_dD},gp +: end +_ACEOF +# If some macros were called several times there might be several times +# the same #defines, which is useless. Nevertheless, we may not want to +# sort them, since we want the *last* AC-DEFINE to be honored. +uniq confdefs.h | sed -n -f confdef2sed.sed >conftest.defines +sed 's/ac_d/ac_u/g' conftest.defines >conftest.undefs +rm -f confdef2sed.sed + +# This sed command replaces #undef with comments. This is necessary, for +# example, in the case of _POSIX_SOURCE, which is predefined and required +# on some systems where configure will not decide to define it. +cat >>conftest.undefs <<\_ACEOF +s,^[ ]*#[ ]*undef[ ][ ]*[a-zA-Z_][a-zA-Z_0-9]*,/* & */, +_ACEOF + +# Break up conftest.defines because some shells have a limit on the size +# of here documents, and old seds have small limits too (100 cmds). +echo ' # Handle all the #define templates only if necessary.' >>$CONFIG_STATUS +echo ' if grep "^[ ]*#[ ]*define" $tmp/in >/dev/null; then' >>$CONFIG_STATUS +echo ' # If there are no defines, we may have an empty if/fi' >>$CONFIG_STATUS +echo ' :' >>$CONFIG_STATUS +rm -f conftest.tail +while grep . conftest.defines >/dev/null +do + # Write a limited-size here document to $tmp/defines.sed. + echo ' cat >$tmp/defines.sed <>$CONFIG_STATUS + # Speed up: don't consider the non `#define' lines. + echo '/^[ ]*#[ ]*define/!b' >>$CONFIG_STATUS + # Work around the forget-to-reset-the-flag bug. + echo 't clr' >>$CONFIG_STATUS + echo ': clr' >>$CONFIG_STATUS + sed ${ac_max_here_lines}q conftest.defines >>$CONFIG_STATUS + echo 'CEOF + sed -f $tmp/defines.sed $tmp/in >$tmp/out + rm -f $tmp/in + mv $tmp/out $tmp/in +' >>$CONFIG_STATUS + sed 1,${ac_max_here_lines}d conftest.defines >conftest.tail + rm -f conftest.defines + mv conftest.tail conftest.defines +done +rm -f conftest.defines +echo ' fi # grep' >>$CONFIG_STATUS +echo >>$CONFIG_STATUS + +# Break up conftest.undefs because some shells have a limit on the size +# of here documents, and old seds have small limits too (100 cmds). +echo ' # Handle all the #undef templates' >>$CONFIG_STATUS +rm -f conftest.tail +while grep . conftest.undefs >/dev/null +do + # Write a limited-size here document to $tmp/undefs.sed. + echo ' cat >$tmp/undefs.sed <>$CONFIG_STATUS + # Speed up: don't consider the non `#undef' + echo '/^[ ]*#[ ]*undef/!b' >>$CONFIG_STATUS + # Work around the forget-to-reset-the-flag bug. + echo 't clr' >>$CONFIG_STATUS + echo ': clr' >>$CONFIG_STATUS + sed ${ac_max_here_lines}q conftest.undefs >>$CONFIG_STATUS + echo 'CEOF + sed -f $tmp/undefs.sed $tmp/in >$tmp/out + rm -f $tmp/in + mv $tmp/out $tmp/in +' >>$CONFIG_STATUS + sed 1,${ac_max_here_lines}d conftest.undefs >conftest.tail + rm -f conftest.undefs + mv conftest.tail conftest.undefs +done +rm -f conftest.undefs + +cat >>$CONFIG_STATUS <<\_ACEOF + # Let's still pretend it is `configure' which instantiates (i.e., don't + # use $as_me), people would be surprised to read: + # /* config.h. Generated by config.status. */ + if test x"$ac_file" = x-; then + echo "/* Generated by configure. */" >$tmp/config.h + else + echo "/* $ac_file. Generated by configure. */" >$tmp/config.h + fi + cat $tmp/in >>$tmp/config.h + rm -f $tmp/in + if test x"$ac_file" != x-; then + if diff $ac_file $tmp/config.h >/dev/null 2>&1; then + { echo "$as_me:$LINENO: $ac_file is unchanged" >&5 +echo "$as_me: $ac_file is unchanged" >&6;} + else + ac_dir=`(dirname "$ac_file") 2>/dev/null || +$as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$ac_file" : 'X\(//\)[^/]' \| \ + X"$ac_file" : 'X\(//\)$' \| \ + X"$ac_file" : 'X\(/\)' \| \ + . : '\(.\)' 2>/dev/null || +echo X"$ac_file" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } + /^X\(\/\/\)[^/].*/{ s//\1/; q; } + /^X\(\/\/\)$/{ s//\1/; q; } + /^X\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + { if $as_mkdir_p; then + mkdir -p "$ac_dir" + else + as_dir="$ac_dir" + as_dirs= + while test ! -d "$as_dir"; do + as_dirs="$as_dir $as_dirs" + as_dir=`(dirname "$as_dir") 2>/dev/null || +$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$as_dir" : 'X\(//\)[^/]' \| \ + X"$as_dir" : 'X\(//\)$' \| \ + X"$as_dir" : 'X\(/\)' \| \ + . : '\(.\)' 2>/dev/null || +echo X"$as_dir" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } + /^X\(\/\/\)[^/].*/{ s//\1/; q; } + /^X\(\/\/\)$/{ s//\1/; q; } + /^X\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + done + test ! -n "$as_dirs" || mkdir $as_dirs + fi || { { echo "$as_me:$LINENO: error: cannot create directory \"$ac_dir\"" >&5 +echo "$as_me: error: cannot create directory \"$ac_dir\"" >&2;} + { (exit 1); exit 1; }; }; } + + rm -f $ac_file + mv $tmp/config.h $ac_file + fi + else + cat $tmp/config.h + rm -f $tmp/config.h + fi +# Compute $ac_file's index in $config_headers. +_am_stamp_count=1 +for _am_header in $config_headers :; do + case $_am_header in + $ac_file | $ac_file:* ) + break ;; + * ) + _am_stamp_count=`expr $_am_stamp_count + 1` ;; + esac +done +echo "timestamp for $ac_file" >`(dirname $ac_file) 2>/dev/null || +$as_expr X$ac_file : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X$ac_file : 'X\(//\)[^/]' \| \ + X$ac_file : 'X\(//\)$' \| \ + X$ac_file : 'X\(/\)' \| \ + . : '\(.\)' 2>/dev/null || +echo X$ac_file | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } + /^X\(\/\/\)[^/].*/{ s//\1/; q; } + /^X\(\/\/\)$/{ s//\1/; q; } + /^X\(\/\).*/{ s//\1/; q; } + s/.*/./; q'`/stamp-h$_am_stamp_count +done +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF + +# +# CONFIG_COMMANDS section. +# +for ac_file in : $CONFIG_COMMANDS; do test "x$ac_file" = x: && continue + ac_dest=`echo "$ac_file" | sed 's,:.*,,'` + ac_source=`echo "$ac_file" | sed 's,[^:]*:,,'` + ac_dir=`(dirname "$ac_dest") 2>/dev/null || +$as_expr X"$ac_dest" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$ac_dest" : 'X\(//\)[^/]' \| \ + X"$ac_dest" : 'X\(//\)$' \| \ + X"$ac_dest" : 'X\(/\)' \| \ + . : '\(.\)' 2>/dev/null || +echo X"$ac_dest" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } + /^X\(\/\/\)[^/].*/{ s//\1/; q; } + /^X\(\/\/\)$/{ s//\1/; q; } + /^X\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + { if $as_mkdir_p; then + mkdir -p "$ac_dir" + else + as_dir="$ac_dir" + as_dirs= + while test ! -d "$as_dir"; do + as_dirs="$as_dir $as_dirs" + as_dir=`(dirname "$as_dir") 2>/dev/null || +$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$as_dir" : 'X\(//\)[^/]' \| \ + X"$as_dir" : 'X\(//\)$' \| \ + X"$as_dir" : 'X\(/\)' \| \ + . : '\(.\)' 2>/dev/null || +echo X"$as_dir" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } + /^X\(\/\/\)[^/].*/{ s//\1/; q; } + /^X\(\/\/\)$/{ s//\1/; q; } + /^X\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + done + test ! -n "$as_dirs" || mkdir $as_dirs + fi || { { echo "$as_me:$LINENO: error: cannot create directory \"$ac_dir\"" >&5 +echo "$as_me: error: cannot create directory \"$ac_dir\"" >&2;} + { (exit 1); exit 1; }; }; } + + ac_builddir=. + +if test "$ac_dir" != .; then + ac_dir_suffix=/`echo "$ac_dir" | sed 's,^\.[\\/],,'` + # A "../" for each directory in $ac_dir_suffix. + ac_top_builddir=`echo "$ac_dir_suffix" | sed 's,/[^\\/]*,../,g'` +else + ac_dir_suffix= ac_top_builddir= +fi + +case $srcdir in + .) # No --srcdir option. We are building in place. + ac_srcdir=. + if test -z "$ac_top_builddir"; then + ac_top_srcdir=. + else + ac_top_srcdir=`echo $ac_top_builddir | sed 's,/$,,'` + fi ;; + [\\/]* | ?:[\\/]* ) # Absolute path. + ac_srcdir=$srcdir$ac_dir_suffix; + ac_top_srcdir=$srcdir ;; + *) # Relative path. + ac_srcdir=$ac_top_builddir$srcdir$ac_dir_suffix + ac_top_srcdir=$ac_top_builddir$srcdir ;; +esac + +# Do not use `cd foo && pwd` to compute absolute paths, because +# the directories may not exist. +case `pwd` in +.) ac_abs_builddir="$ac_dir";; +*) + case "$ac_dir" in + .) ac_abs_builddir=`pwd`;; + [\\/]* | ?:[\\/]* ) ac_abs_builddir="$ac_dir";; + *) ac_abs_builddir=`pwd`/"$ac_dir";; + esac;; +esac +case $ac_abs_builddir in +.) ac_abs_top_builddir=${ac_top_builddir}.;; +*) + case ${ac_top_builddir}. in + .) ac_abs_top_builddir=$ac_abs_builddir;; + [\\/]* | ?:[\\/]* ) ac_abs_top_builddir=${ac_top_builddir}.;; + *) ac_abs_top_builddir=$ac_abs_builddir/${ac_top_builddir}.;; + esac;; +esac +case $ac_abs_builddir in +.) ac_abs_srcdir=$ac_srcdir;; +*) + case $ac_srcdir in + .) ac_abs_srcdir=$ac_abs_builddir;; + [\\/]* | ?:[\\/]* ) ac_abs_srcdir=$ac_srcdir;; + *) ac_abs_srcdir=$ac_abs_builddir/$ac_srcdir;; + esac;; +esac +case $ac_abs_builddir in +.) ac_abs_top_srcdir=$ac_top_srcdir;; +*) + case $ac_top_srcdir in + .) ac_abs_top_srcdir=$ac_abs_builddir;; + [\\/]* | ?:[\\/]* ) ac_abs_top_srcdir=$ac_top_srcdir;; + *) ac_abs_top_srcdir=$ac_abs_builddir/$ac_top_srcdir;; + esac;; +esac + + + { echo "$as_me:$LINENO: executing $ac_dest commands" >&5 +echo "$as_me: executing $ac_dest commands" >&6;} + case $ac_dest in + depfiles ) test x"$AMDEP_TRUE" != x"" || for mf in $CONFIG_FILES; do + # Strip MF so we end up with the name of the file. + mf=`echo "$mf" | sed -e 's/:.*$//'` + # Check whether this is an Automake generated Makefile or not. + # We used to match only the files named `Makefile.in', but + # some people rename them; so instead we look at the file content. + # Grep'ing the first line is not enough: some people post-process + # each Makefile.in and add a new line on top of each file to say so. + # So let's grep whole file. + if grep '^#.*generated by automake' $mf > /dev/null 2>&1; then + dirpart=`(dirname "$mf") 2>/dev/null || +$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$mf" : 'X\(//\)[^/]' \| \ + X"$mf" : 'X\(//\)$' \| \ + X"$mf" : 'X\(/\)' \| \ + . : '\(.\)' 2>/dev/null || +echo X"$mf" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } + /^X\(\/\/\)[^/].*/{ s//\1/; q; } + /^X\(\/\/\)$/{ s//\1/; q; } + /^X\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + else + continue + fi + # Extract the definition of DEPDIR, am__include, and am__quote + # from the Makefile without running `make'. + DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` + test -z "$DEPDIR" && continue + am__include=`sed -n 's/^am__include = //p' < "$mf"` + test -z "am__include" && continue + am__quote=`sed -n 's/^am__quote = //p' < "$mf"` + # When using ansi2knr, U may be empty or an underscore; expand it + U=`sed -n 's/^U = //p' < "$mf"` + # Find all dependency output files, they are included files with + # $(DEPDIR) in their names. We invoke sed twice because it is the + # simplest approach to changing $(DEPDIR) to its actual value in the + # expansion. + for file in `sed -n " + s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ + sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do + # Make sure the directory exists. + test -f "$dirpart/$file" && continue + fdir=`(dirname "$file") 2>/dev/null || +$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$file" : 'X\(//\)[^/]' \| \ + X"$file" : 'X\(//\)$' \| \ + X"$file" : 'X\(/\)' \| \ + . : '\(.\)' 2>/dev/null || +echo X"$file" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } + /^X\(\/\/\)[^/].*/{ s//\1/; q; } + /^X\(\/\/\)$/{ s//\1/; q; } + /^X\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + { if $as_mkdir_p; then + mkdir -p $dirpart/$fdir + else + as_dir=$dirpart/$fdir + as_dirs= + while test ! -d "$as_dir"; do + as_dirs="$as_dir $as_dirs" + as_dir=`(dirname "$as_dir") 2>/dev/null || +$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$as_dir" : 'X\(//\)[^/]' \| \ + X"$as_dir" : 'X\(//\)$' \| \ + X"$as_dir" : 'X\(/\)' \| \ + . : '\(.\)' 2>/dev/null || +echo X"$as_dir" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } + /^X\(\/\/\)[^/].*/{ s//\1/; q; } + /^X\(\/\/\)$/{ s//\1/; q; } + /^X\(\/\).*/{ s//\1/; q; } + s/.*/./; q'` + done + test ! -n "$as_dirs" || mkdir $as_dirs + fi || { { echo "$as_me:$LINENO: error: cannot create directory $dirpart/$fdir" >&5 +echo "$as_me: error: cannot create directory $dirpart/$fdir" >&2;} + { (exit 1); exit 1; }; }; } + + # echo "creating $dirpart/$file" + echo '# dummy' > "$dirpart/$file" + done +done + ;; + default-1 ) + for ac_file in $CONFIG_FILES; do + # Support "outfile[:infile[:infile...]]" + case "$ac_file" in + *:*) ac_file=`echo "$ac_file"|sed 's%:.*%%'` ;; + esac + # PO directories have a Makefile.in generated from Makefile.in.in. + case "$ac_file" in */Makefile.in) + # Adjust a relative srcdir. + ac_dir=`echo "$ac_file"|sed 's%/[^/][^/]*$%%'` + ac_dir_suffix="/`echo "$ac_dir"|sed 's%^\./%%'`" + ac_dots=`echo "$ac_dir_suffix"|sed 's%/[^/]*%../%g'` + # In autoconf-2.13 it is called $ac_given_srcdir. + # In autoconf-2.50 it is called $srcdir. + test -n "$ac_given_srcdir" || ac_given_srcdir="$srcdir" + case "$ac_given_srcdir" in + .) top_srcdir=`echo $ac_dots|sed 's%/$%%'` ;; + /*) top_srcdir="$ac_given_srcdir" ;; + *) top_srcdir="$ac_dots$ac_given_srcdir" ;; + esac + # Treat a directory as a PO directory if and only if it has a + # POTFILES.in file. This allows packages to have multiple PO + # directories under different names or in different locations. + if test -f "$ac_given_srcdir/$ac_dir/POTFILES.in"; then + rm -f "$ac_dir/POTFILES" + test -n "$as_me" && echo "$as_me: creating $ac_dir/POTFILES" || echo "creating $ac_dir/POTFILES" + cat "$ac_given_srcdir/$ac_dir/POTFILES.in" | sed -e "/^#/d" -e "/^[ ]*\$/d" -e "s,.*, $top_srcdir/& \\\\," | sed -e "\$s/\(.*\) \\\\/\1/" > "$ac_dir/POTFILES" + POMAKEFILEDEPS="POTFILES.in" + # ALL_LINGUAS, POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES depend + # on $ac_dir but don't depend on user-specified configuration + # parameters. + if test -f "$ac_given_srcdir/$ac_dir/LINGUAS"; then + # The LINGUAS file contains the set of available languages. + if test -n "$OBSOLETE_ALL_LINGUAS"; then + test -n "$as_me" && echo "$as_me: setting ALL_LINGUAS in configure.in is obsolete" || echo "setting ALL_LINGUAS in configure.in is obsolete" + fi + ALL_LINGUAS_=`sed -e "/^#/d" -e "s/#.*//" "$ac_given_srcdir/$ac_dir/LINGUAS"` + # Hide the ALL_LINGUAS assigment from automake. + eval 'ALL_LINGUAS''=$ALL_LINGUAS_' + POMAKEFILEDEPS="$POMAKEFILEDEPS LINGUAS" + else + # The set of available languages was given in configure.in. + eval 'ALL_LINGUAS''=$OBSOLETE_ALL_LINGUAS' + fi + # Compute POFILES + # as $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).po) + # Compute UPDATEPOFILES + # as $(foreach lang, $(ALL_LINGUAS), $(lang).po-update) + # Compute DUMMYPOFILES + # as $(foreach lang, $(ALL_LINGUAS), $(lang).nop) + # Compute GMOFILES + # as $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).gmo) + case "$ac_given_srcdir" in + .) srcdirpre= ;; + *) srcdirpre='$(srcdir)/' ;; + esac + POFILES= + UPDATEPOFILES= + DUMMYPOFILES= + GMOFILES= + for lang in $ALL_LINGUAS; do + POFILES="$POFILES $srcdirpre$lang.po" + UPDATEPOFILES="$UPDATEPOFILES $lang.po-update" + DUMMYPOFILES="$DUMMYPOFILES $lang.nop" + GMOFILES="$GMOFILES $srcdirpre$lang.gmo" + done + # CATALOGS depends on both $ac_dir and the user's LINGUAS + # environment variable. + INST_LINGUAS= + if test -n "$ALL_LINGUAS"; then + for presentlang in $ALL_LINGUAS; do + useit=no + if test "%UNSET%" != "$LINGUAS"; then + desiredlanguages="$LINGUAS" + else + desiredlanguages="$ALL_LINGUAS" + fi + for desiredlang in $desiredlanguages; do + # Use the presentlang catalog if desiredlang is + # a. equal to presentlang, or + # b. a variant of presentlang (because in this case, + # presentlang can be used as a fallback for messages + # which are not translated in the desiredlang catalog). + case "$desiredlang" in + "$presentlang"*) useit=yes;; + esac + done + if test $useit = yes; then + INST_LINGUAS="$INST_LINGUAS $presentlang" + fi + done + fi + CATALOGS= + if test -n "$INST_LINGUAS"; then + for lang in $INST_LINGUAS; do + CATALOGS="$CATALOGS $lang.gmo" + done + fi + test -n "$as_me" && echo "$as_me: creating $ac_dir/Makefile" || echo "creating $ac_dir/Makefile" + sed -e "/^POTFILES =/r $ac_dir/POTFILES" -e "/^# Makevars/r $ac_given_srcdir/$ac_dir/Makevars" -e "s|@POFILES@|$POFILES|g" -e "s|@UPDATEPOFILES@|$UPDATEPOFILES|g" -e "s|@DUMMYPOFILES@|$DUMMYPOFILES|g" -e "s|@GMOFILES@|$GMOFILES|g" -e "s|@CATALOGS@|$CATALOGS|g" -e "s|@POMAKEFILEDEPS@|$POMAKEFILEDEPS|g" "$ac_dir/Makefile.in" > "$ac_dir/Makefile" + for f in "$ac_given_srcdir/$ac_dir"/Rules-*; do + if test -f "$f"; then + case "$f" in + *.orig | *.bak | *~) ;; + *) cat "$f" >> "$ac_dir/Makefile" ;; + esac + fi + done + fi + ;; + esac + done ;; + default ) echo timestamp > stamp-h ;; + esac +done +_ACEOF + +cat >>$CONFIG_STATUS <<\_ACEOF + +{ (exit 0); exit 0; } +_ACEOF +chmod +x $CONFIG_STATUS +ac_clean_files=$ac_clean_files_save + + +# configure is writing to config.log, and then calls config.status. +# config.status does its own redirection, appending to config.log. +# Unfortunately, on DOS this fails, as config.log is still kept open +# by configure, so config.status won't be able to write to it; its +# output is simply discarded. So we exec the FD to /dev/null, +# effectively closing config.log, so it can be properly (re)opened and +# appended to by config.status. When coming back to configure, we +# need to make the FD available again. +if test "$no_create" != yes; then + ac_cs_success=: + ac_config_status_args= + test "$silent" = yes && + ac_config_status_args="$ac_config_status_args --quiet" + exec 5>/dev/null + $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false + exec 5>>config.log + # Use ||, not &&, to avoid exiting from the if with $? = 1, which + # would make configure fail if this is the last instruction. + $ac_cs_success || { (exit 1); exit 1; } +fi + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/configure.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/configure.in new file mode 100644 index 0000000000..d586c4e35d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/configure.in @@ -0,0 +1,131 @@ +dnl ************************************************************************* +dnl * GSM TA/ME library +dnl * +dnl * File: configure.in +dnl * +dnl * Purpose: autoconf configure script template +dnl * +dnl * Author: Peter Hofmann (software@pxh.de) +dnl * +dnl * Created: 11.11.1999 +dnl ************************************************************************* + +dnl Process this file with autoconf to produce a configure script. +AC_INIT(gsmlib/gsm_error.h) + +dnl Other +AC_CONFIG_AUX_DIR(scripts) +AC_PROG_INSTALL + +dnl check for libintl +AC_CHECK_LIB(intl, textdomain) + +dnl use config header +AM_CONFIG_HEADER(gsm_config.h) + +dnl use automake +AM_INIT_AUTOMAKE(gsmlib, 1.10) + +dnl change to no if you want no shared libraries for debugging purposes +AM_ENABLE_SHARED(yes) + +dnl use -O2 optimization by default +if test "$CXXFLAGS" = ""; then + CXXFLAGS="-O2" +fi + +dnl comment out this line to get extensive debugging output and asserts +dnl CXXFLAGS="-DNDEBUG $CXXFLAGS" + +dnl uncomment to get translations without installing gsmlib +dnl CXXFLAGS="-DLOCAL_TRANSLATIONS $CXXFLAGS" + +dnl check _REENTRANT in header files +if test x"`egrep _REENTRANT /usr/include/features.h`" != x; then + CXXFLAGS="-D_REENTRANT $CXXFLAGS" + CFLAGS="-D_REENTRANT $CFLAGS" +fi + +dnl output all warnings +CXXFLAGS="-Wall $CXXFLAGS" + +dnl use libtool +AM_PROG_LIBTOOL + +dnl Checks for programs. +AC_PROG_CPP +AC_PROG_CXX + +dnl check for gcc 2.95.x +AC_TRY_RUN([ +#include +main() +{ +#if defined(__GNUC__) && \ + ! (__GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 95)) + return 1; +#endif + return 0; +} +],, +[echo "need at least gcc 2.95 to compile correctly" +exit 1]) + +dnl check for alloca +AC_FUNC_ALLOCA + +dnl check for getopt_long in the C library +AC_CHECK_LIB(c, getopt_long, AC_DEFINE(HAVE_GETOPT_LONG)) + +dnl check for alarm in the C library +AC_CHECK_LIB(c, alarm, AC_DEFINE(HAVE_ALARM)) + +dnl check for netinet/in.h header +AC_CHECK_HEADERS(netinet/in.h) + +dnl check for string.h header +AC_CHECK_HEADERS(string.h) + +dnl check for libintl.h header +AC_CHECK_HEADERS(libintl.h) + +dnl Checks for typedefs, structures, and compiler characteristics. +AC_C_CONST + +dnl check for vsnprintf() +dnl AC_FUNC_VPRINTF +AC_EGREP_HEADER(vsnprintf, stdio.h, AC_DEFINE(HAVE_VSNPRINTF)) + +dnl checks for builtin data type sizes +AC_CHECK_SIZEOF(unsigned short int, 2) +AC_CHECK_SIZEOF(unsigned long int, 4) +AC_CHECK_SIZEOF(unsigned int, 4) + +dnl Project-specific settings +GSM_VERSION="1:4:0" +AC_SUBST(GSM_VERSION) + +dnl national language support (NLS) +LINGUAS="de" +ALL_LINGUAS=$LINGUAS +AM_GNU_GETTEXT + +dnl set locale dir (FIXME there must be a better way) +_localedir=`eval "echo $datadir/locale"` +if test "$_localedir" = "NONE/share/locale"; then + AC_DEFINE_UNQUOTED(LOCALEDIR, "/usr/local/share/locale") +else + _localedir=`echo \"$_localedir\"` + AC_DEFINE_UNQUOTED(LOCALEDIR, $_localedir) +fi + +dnl whether to compile the intl directory +AM_CONDITIONAL(COMPILE_INTL, test x$USE_INCLUDED_LIBINTL = xyes) + +AC_OUTPUT(Makefile gsmlib/Makefile tests/Makefile apps/Makefile win32/Makefile + doc/Makefile scripts/Makefile intl/Makefile po/Makefile.in + ext/Makefile, + echo timestamp > stamp-h) + +dnl repair Makefile in po subdir +dnl sed -e "/POTFILES =/r po/POTFILES" po/Makefile.in > po/Makefile diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.cron.d b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.cron.d new file mode 100644 index 0000000000..7974513ccc --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.cron.d @@ -0,0 +1,3 @@ +# /etc/cron.d/gsm-utils: crontab fragment for gsm-utils + +*/5 * * * * root if [ -x /usr/bin/gsmsmsrequeue ]; then /usr/bin/gsmsmsrequeue; fi diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.default b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.default new file mode 100644 index 0000000000..fa72d12e81 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.default @@ -0,0 +1,13 @@ +PHONEDEV=/dev/mobilephone # or /dev/ttyS0 or /dev/ircomm0 +BAUDRATE=9600 +PIN="" # or 1234 + +SPOOLDIR=/var/spool/sms +PRIORITIES=3 + +SMSADMIN=root +SUBJECT="SMS delivery report:" + +SMSPROCESSOR="" # or /usr/bin/gsmsmsprocessor + +function do_accounting { true; } # it's your turn diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.init b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.init new file mode 100644 index 0000000000..3a84240e09 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsm-utils.init @@ -0,0 +1,72 @@ +#! /bin/sh +# +# /etc/init.d/gsm-utils: Controls the GSM SMS send daemon +# +# written by Matthias Goebl + +PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin +DAEMON=/usr/bin/gsmsmsd +NAME=gsmsmsd +DESC="GSM SMS send daemon" + +test -x $DAEMON || exit 0 + +PHONEDEV=/dev/mobilephone # or /dev/ttyS0 or /dev/ircomm0 +BAUDRATE=9600 +PIN="" # or 1234 +SMSPROCESSOR="" # or /usr/bin/gsmsmsprocessor +SPOOLDIR=/var/spool/sms +PRIORITIES=3 +STARTOPTS="" +SMSUSER="gsmsms:gsmsms" +test -r /etc/default/gsm-utils && . /etc/default/gsm-utils # for overwriting some parameters + +OPTIONS="-d $PHONEDEV -b $BAUDRATE -L -P $PRIORITIES" +OPTIONS="$OPTIONS -s $SPOOLDIR/queue -S $SPOOLDIR/sent -F $SPOOLDIR/failed" +test -n "$SMSPROCESSOR" && OPTIONS="$OPTIONS -a $SMSPROCESSOR" +test -n "$SMSUSER" && STARTOPTS="$STARTOPTS --chuid $SMSUSER" +test -r /etc/default/gsm-utils && . /etc/default/gsm-utils # for overwriting OPTIONS + +case "$1" in + start) + echo -n "Starting $DESC: " + if [ -n "$PIN" ];then + echo -n "entering PIN.. " + ( + # This is ugly.. But if the PIN is already entered, the ME returns + # "ERROR" and makes gsmctl retrying.. + /usr/bin/gsmctl -d $PHONEDEV -b $BAUDRATE -I "+cpin=$PIN" & + PID=$! + sleep 3 + kill $PID 2>/dev/null + ) >/dev/null 2>&1 + fi + echo -n "$NAME" + start-stop-daemon --start --quiet --pidfile /var/run/gsm-utils/$NAME.pid \ + --make-pidfile --background $STARTOPTS --exec $DAEMON -- $OPTIONS + echo "." + ;; + stop) + echo -n "Stopping $DESC: $NAME " + start-stop-daemon --stop --quiet --pidfile /var/run/gsm-utils/$NAME.pid \ + --exec $DAEMON + sleep 5 + echo "." + ;; + restart|force-reload) + echo -n "Restarting $DESC: $NAME" + start-stop-daemon --start --quiet --pidfile /var/run/gsm-utils/$NAME.pid \ + --make-pidfile --background $STARTOPTS --exec $DAEMON -- $OPTIONS + sleep 5 + start-stop-daemon --start --quiet --pidfile /var/run/gsm-utils/$NAME.pid \ + --make-pidfile --background --exec $DAEMON -- $OPTIONS + echo "." + ;; + *) + N=/etc/init.d/gsm-utils + echo "Usage: $N {start|stop|restart|force-reload}" >&2 + exit 1 + ;; +esac + +exit 0 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsmsmsrequeue b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsmsmsrequeue new file mode 100644 index 0000000000..888c6a993f --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsmsmsrequeue @@ -0,0 +1,44 @@ +#! /bin/sh +# +# /usr/bin/gsmsmsrequeue: Re-queues failed SMS +# +# written by Matthias Goebl + +SPOOLDIR=/var/spool/sms +PRIORITIES=3 +SMSADMIN=root +SUBJECT="SMS delivery report:" + +function send_notify { + tmpfile="$SPOOLDIR/tmp/"`basename "$1"` + status="$2" + if mv "$1" "$tmpfile" 2>/dev/null; then + # extract the first tab-separated field after the phone number as + # email-address to send the notification to + mailto=` cat "$tmpfile" | sed -ne '1s/^[^ ]* \([^ ]*\).*/\1/p' ` + test -z "$mailto" && mailto="$SMSADMIN" + cat "$tmpfile" | mail -s "$SUBJECT $status" "$mailto" + rm "$tmpfile" + fi +} +function do_accounting { true; } + +test -r /etc/default/gsm-utils && . /etc/default/gsm-utils + +for p in `seq 1 $PRIORITIES`; do + ls "$SPOOLDIR/failed$p" | while read file; do + if expr "$file" : ".*rrrrrrrrrrrr" >/dev/null; then + send_notify "$SPOOLDIR/failed$p/$file" "failed" + else + # re-queue SMS + mv "$SPOOLDIR/failed$p/$file" "$SPOOLDIR/queue$p/${file}r" 2>/dev/null + fi + done +done + +for p in `seq 1 $PRIORITIES`; do + ls "$SPOOLDIR/sent$p" | while read file; do + do_accounting "$SPOOLDIR/sent$p/$file" "sent" + send_notify "$SPOOLDIR/sent$p/$file" "sent" + done +done diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsmsmsspool b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsmsmsspool new file mode 100644 index 0000000000..12ffb008e0 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/contrib/gsmsmsspool @@ -0,0 +1,34 @@ +#! /bin/sh +# +# /usr/bin/gsmsmsspool: Queues SMS for sending +# +# written by Matthias Goebl + +SPOOLDIR=/var/spool/sms +PRIORITIES=3 +test -r /etc/default/gsm-utils && . /etc/default/gsm-utils + +if [ -z "$1" ]; then + echo "Usage: gsmsmsspool NUMBER [MESSAGE]" + exit 1 +fi + +priority=$PRIORITIES # default priority +test -n "$GSMSMS_PRIORITY" && priority="$GSMSMS_PRIORITY" +mailto=`id -un` +test -n "$GSMSMS_NOTIFY" && mailto="$GSMSMS_NOTIFY" + +tmpfile="$SPOOLDIR/tmp/`date +%s`.$$" +umask 022 +echo "$1 $mailto" > "$tmpfile" +if [ -n "$2" ]; then + echo "$2" | head -c 160 >> "$tmpfile" +else + head -c 160 >> "$tmpfile" +fi + +if [ "`id -un`" = "root" ]; then + chown gsmsms:gsmsms "$tmpfile" +fi + +mv "$tmpfile" "$SPOOLDIR/queue$priority/" diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/changelog b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/changelog new file mode 100644 index 0000000000..a343c93fa5 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/changelog @@ -0,0 +1,244 @@ +gsmlib (1.10-12ubuntu1) hardy; urgency=low + + * Merge from Debian unstable. Remaining Ubuntu changes: + - [debian/gsm-utils.postinst, debian/gsm-utils.init] + Create /var/run/gsm-utils if it does not exist + - Actually fix the init script (debian #377448) + - Set Ubuntu maintainer adress. + + -- Albin Tonnerre Wed, 12 Dec 2007 00:45:00 +0100 + +gsmlib (1.10-12) unstable; urgency=low + + * addgroup --system gsmsms works better. Thanks Jon + * only delete gsmsms on purge + - gsm-utils: deletes and recreates the gsmsms user on each upgrade + (Closes: #346238) + - gsm-utils fails installation / addgroup: The user gsmsms; does + not exist (Closes: #445404) + * lintian cleanup: debian-rules-ignores-make-clean-error substvar- + source-version-is-deprecated + * Scripts are installed +x + - gsm-utils: uselessly installs non-executable scripts into /usr/bin + (Closes: #346230) + * Remove bogus symlink + - gsm-utils: wrong symlink for manpage gsmsiectl.1 (Closes: #322382) + - gsm-utils: gsmsiectl.1 dangling symlink (Closes: #399582) + * debian/gsm-utils.init reload/restart was not calling --stop. Thanks + Barry + - init script calls --start twice (Closes: #377448) + + -- Mark Purcell Mon, 08 Oct 2007 21:44:00 +0100 + +gsmlib (1.10-11) unstable; urgency=low + + * Create system group gsmsms - Thanks Emmanuel + - gsm-utils: creates group in non-system gid range (Closes: #353967) + - gsm-utils: postinst should create system grp gsmsms (Closes: + #390266) + * Upgrade to compat 4 + * Apply gcc-4.3 patch from Martin + - FTBFS with GCC 4.3: missing #includes (Closes: #417222) + + -- Mark Purcell Sat, 29 Sep 2007 18:22:56 +0100 + +gsmlib (1.10-10ubuntu3) feisty; urgency=low + + * Rebuild for ldbl128 change (powerpc, sparc). + * Set Ubuntu maintainer address. + + -- Matthias Klose Thu, 1 Mar 2007 22:37:57 +0000 + +gsmlib (1.10-10ubuntu2) edgy; urgency=low + + * [debian/gsm-utils.postinst, debian/gsm-utils.init] + Create /var/run/gsm-utils if it does not exist + + -- Matt Zimmerman Tue, 11 Jul 2006 13:59:12 -0700 + +gsmlib (1.10-10ubuntu1) edgy; urgency=low + + * Re-sync with Debian + * debian/gsm-utils.init reload/restart was not calling --stop + + -- Barry deFreese Sat, 8 Jul 2006 22:52:23 -0400 + +gsmlib (1.10-10) unstable; urgency=low + + * FTBFS with G++ 4.1: extra qualifications (Closes: #356109) + + -- Mark Purcell Sat, 20 May 2006 21:54:42 +0100 + +gsmlib (1.10-9) unstable; urgency=low + + * library package needs to be renamed (libstdc++ allocator change) + (Closes: #339179) + + -- Mark Purcell Mon, 21 Nov 2005 21:19:51 +0000 + +gsmlib (1.10-8) unstable; urgency=low + + * removal of automake1.6 (Closes: #335123) + * fails with dash [bashisms in scripts] (Closes: #309834) + * Update libtool Fixes: gsmlib(GNU/k*BSD): FTBFS: out of date libtool scripts (Closes: + #319688) + * [INTL:de] German PO file corrections (Closes: #314060) + * Fix: old-fsf-address-in-copyright-file + + -- Mark Purcell Thu, 3 Nov 2005 22:40:19 +0000 + +gsmlib (1.10-7) unstable; urgency=low + + * C++ 4.0 transition + * Closes: #315864: Missing manpages + * gsm-utils: maintainer-script-needs-depends-on-adduser postinst + + -- Mark Purcell Sat, 23 Jul 2005 00:46:31 +1000 + +gsmlib (1.10-6) unstable; urgency=low + + * Rebuild for invalid dependancies + * Closes: #258056: libgsmme 99% cpu usage + - Patch from Emard + * Closes: #274382: FTBFS with gcc-3.4: template-id `operator< + <>' for `bool gsmlib::operator<(const + gsmlib::MapKey<gsmlib::SortedPhonebookBase>&, const + gsmlib::MapKey<gsmlib::SortedPhonebookBase>&)' does not + match any template declaration + - Patch from Andreas Jochens + * Closes: #294251: FTBFS (amd64/gcc-4.0): explicit qualification in + declaration of `bool gsmlib::operator<(const + gsmlib::MapKey<SortedStore>&, const + gsmlib::MapKey<SortedStore>&)' + - Patch from Andreas Jochens + * Closes: #200189: Patch and contribution + + Added multi-queue-priority-system and syslog patch (Matthias Goebl) + + Included init, spool and requeue scripts for gsmsmsd (Matthias Goebl) + + gsmsmsd runs with own user and group (gsmsms:gsmsms) (Matthias Goebl) + + -- Mark Purcell Tue, 17 May 2005 11:34:45 +0100 + +gsmlib (1.10-5) unstable; urgency=low + + * Change Section: libdevel + * gsm_unix_serial.cc patch from Daniel Schepler to fix g++-3.3 + compliation. Thanks. (Closes: Bug#195151) + + -- Mark Purcell Sat, 19 Jul 2003 15:57:28 +1000 + +gsmlib (1.10-4) unstable; urgency=low + + * Include file descriptor leak patch from Edd Dumbill (Closes: + Bug#168475) + * lintian cleanup: description-synopsis-might-not-be-phrased-properly + * lintian cleanup: configure-generated-file-in-source + + -- Mark Purcell Sun, 9 Feb 2003 14:04:54 +1100 + +gsmlib (1.10-3) unstable; urgency=low + + * New Maintainer (Closes: Bug#180061). Thanks Mikael for your work. + + -- Mark Purcell Sat, 8 Feb 2003 16:55:26 +1100 + +gsmlib (1.10-2) unstable; urgency=low + + * Rebuild to use the new c++ ABI (GCC 3.2) + + -- Mikael Hedin Thu, 23 Jan 2003 20:57:50 +0100 + +gsmlib (1.10-1) unstable; urgency=low + + * New upstrem release. + + -- Mikael Hedin Wed, 6 Nov 2002 17:44:17 +0100 + +gsmlib (1.9-2) unstable; urgency=low + + * Made new rules for the config.guess/sub update thing (closes: #146865, + #146867). + + -- Mikael Hedin Tue, 14 May 2002 09:28:03 +0200 + +gsmlib (1.9-1) unstable; urgency=low + + * New upstream version. + * Use chrpath to get rid of rpaths. + * Add mini-manpage for gsmsiexfer. + * Remove b-d on auto-stuff, we don't use them. + + -- Mikael Hedin Mon, 13 May 2002 22:10:28 +0200 + +gsmlib (1.8-2) unstable; urgency=low + + * Removed b-d on gcc 3.0, as they are no longer nessecary. + + -- Mikael Hedin Thu, 24 Jan 2002 12:59:07 +0100 + +gsmlib (1.8-1) unstable; urgency=low + + * New upstream version. + * Revert the arch hack, now it should compile with either g++. + * Include the new lib in libgsmme1. Run dh_makeshlibs -V because of this. + * Added info for gsmsiectl in gsmctl(1). + + -- Mikael Hedin Wed, 9 Jan 2002 22:38:45 +0100 + +gsmlib (1.7-2) unstable; urgency=low + + * gsm-utils: Added shlibs:Depends (closes: #126127). + * Spelling correction (closes: #124705, #124972) + * Rm libgsmme1.postins, and let dh_makeshlibs take care of ldconfig. + * Made explicit arch list without sparc and arm, they cannot use g++-3.0 + right now. + + -- Mikael Hedin Sat, 22 Dec 2001 20:27:54 +0100 + +gsmlib (1.7-1) unstable; urgency=low + + * New upstream + * Use gcc-3.0 and g++-3.0, 2.95 doesn't compile. + + -- Mikael Hedin Thu, 1 Nov 2001 10:24:33 +0100 + +gsmlib (1.6-5) unstable; urgency=low + + * Updated manpage (closes: #110973) + * Corrected problem with OP status (closes: #110970) + + -- Mikael Hedin Sat, 8 Sep 2001 18:12:17 +0200 + +gsmlib (1.6-4) unstable; urgency=low + + * Support DEB_BUILD_OPTIONS + * Changed libgsmme-dev to section devel. + * Reran libtoolize. + * Lots of small patches to compile with g++-3.0. (Closes: #104411) + * Removed dh_testversion. + + -- Mikael Hedin Thu, 12 Jul 2001 16:06:23 +0200 + +gsmlib (1.6-3) unstable; urgency=low + + * Various minor corrections. + + -- Mikael Hedin Thu, 8 Mar 2001 16:24:07 +0100 + +gsmlib (1.6-2) unstable; urgency=low + + * Dont install INSTALL. Correct indentation for libgsmme1 description. + + -- Mikael Hedin Tue, 6 Mar 2001 14:55:05 +0100 + +gsmlib (1.6-1) unstable; urgency=low + + * New upstream version. + + -- Mikael Hedin Mon, 29 Jan 2001 17:57:21 +0100 + +gsmlib (1.5-1) unstable; urgency=low + + * Initial Release. + + -- Mikael Hedin Thu, 14 Dec 2000 01:06:40 +0100 + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/compat b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/compat new file mode 100644 index 0000000000..b8626c4cff --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/compat @@ -0,0 +1 @@ +4 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/control b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/control new file mode 100644 index 0000000000..8ae52158a3 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/control @@ -0,0 +1,52 @@ +Source: gsmlib +Section: comm +Priority: extra +Maintainer: Ubuntu MOTU Developers +XSBC-Original-Maintainer: Mark Purcell +Build-Depends: debhelper (>= 3.0.0), chrpath +Standards-Version: 3.2.1 + +Package: libgsmme-dev +Section: libdevel +Architecture: any +Depends: libgsmme1c2a (= ${binary:Version}), libc6-dev +Description: Header files and static libraries for gsmlib + Headers and static libraries for use when compiling programs with + gsmlib. + . + gsmlib is a library for access to a GSM mobile phone using the + standards ETSI GSM 07.07, ETSI GSM 07.05, and others. + . + Website: http://www.pxh.de/fs/gsmlib/ + +Package: libgsmme1c2a +Conflicts: libgsmme1, libgsmme1c102, libgsmme1c2 +Replaces: libgsmme1c102, libgsmme1c2 +Section: libs +Architecture: any +Depends: ${shlibs:Depends} +Description: GSM mobile phone access library + Library to access GSM mobile phones through GSM modems or IrDA devices. + Features include: + . + * modification of phone books stored in the mobile phone or on the + SIM card + * reading and writing of SMS messages stored in the mobile phone + * sending and reception of SMS messages + . + gsmlib uses standard ETSI GSM 07.07, ETSI GSM 07.05, and others. + . + Website: http://www.pxh.de/fs/gsmlib/ + +Package: gsm-utils +Section: comm +Architecture: any +Depends: ${shlibs:Depends}, adduser +Description: GSM mobile phone access applications + Some simple command line programs to access a GSM mobile phone via + GSM modem or IrDA. Functions include: modification of phone books and + reading, writing, sending and receiving SMS messages. Uses the GSM + standards ETSI GSM 07.07, ETSI GSM 07.05, and others. + . + Website: http://www.pxh.de/fs/gsmlib/ + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/copyright b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/copyright new file mode 100644 index 0000000000..b78ded23aa --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/copyright @@ -0,0 +1,26 @@ +This package was debianized by Mikael Hedin on +Thu, 14 Dec 2000 01:06:40 +0100. + +It was downloaded from http://www.pxh.de/fs/gsmlib/index.html + +Upstream Author: Peter Hofmann + +Copyright: + + This package 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; version 2 dated June, 1991. + + This package 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 package; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, + MA 02110-1301, USA. + +On Debian GNU/Linux systems, the complete text of the GNU General +Public License can be found in `/usr/share/common-licenses/GPL'. + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.cron.d b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.cron.d new file mode 100644 index 0000000000..7974513ccc --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.cron.d @@ -0,0 +1,3 @@ +# /etc/cron.d/gsm-utils: crontab fragment for gsm-utils + +*/5 * * * * root if [ -x /usr/bin/gsmsmsrequeue ]; then /usr/bin/gsmsmsrequeue; fi diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.default b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.default new file mode 100644 index 0000000000..fa72d12e81 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.default @@ -0,0 +1,13 @@ +PHONEDEV=/dev/mobilephone # or /dev/ttyS0 or /dev/ircomm0 +BAUDRATE=9600 +PIN="" # or 1234 + +SPOOLDIR=/var/spool/sms +PRIORITIES=3 + +SMSADMIN=root +SUBJECT="SMS delivery report:" + +SMSPROCESSOR="" # or /usr/bin/gsmsmsprocessor + +function do_accounting { true; } # it's your turn diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.dirs b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.dirs new file mode 100644 index 0000000000..7bc765edd6 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.dirs @@ -0,0 +1,11 @@ +var/spool/sms/queue1 +var/spool/sms/queue2 +var/spool/sms/queue3 +var/spool/sms/sent1 +var/spool/sms/sent2 +var/spool/sms/sent3 +var/spool/sms/failed1 +var/spool/sms/failed2 +var/spool/sms/failed3 +var/spool/sms/tmp +var/run/gsm-utils diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.docs b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.docs new file mode 100644 index 0000000000..d4f3801ab1 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.docs @@ -0,0 +1,4 @@ +NEWS +README +TODO +doc/FAQ diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.init b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.init new file mode 100644 index 0000000000..9a783b10ea --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.init @@ -0,0 +1,77 @@ +#! /bin/sh +# +# /etc/init.d/gsm-utils: Controls the GSM SMS send daemon +# +# written by Matthias Goebl + +PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin +DAEMON=/usr/bin/gsmsmsd +NAME=gsmsmsd +DESC="GSM SMS send daemon" + +test -x $DAEMON || exit 0 + +PHONEDEV=/dev/mobilephone # or /dev/ttyS0 or /dev/ircomm0 +BAUDRATE=9600 +PIN="" # or 1234 +SMSPROCESSOR="" # or /usr/bin/gsmsmsprocessor +SPOOLDIR=/var/spool/sms +PRIORITIES=3 +STARTOPTS="" +SMSUSER="gsmsms:gsmsms" +test -r /etc/default/gsm-utils && . /etc/default/gsm-utils # for overwriting some parameters + +OPTIONS="-d $PHONEDEV -b $BAUDRATE -L -P $PRIORITIES" +OPTIONS="$OPTIONS -s $SPOOLDIR/queue -S $SPOOLDIR/sent -F $SPOOLDIR/failed" +test -n "$SMSPROCESSOR" && OPTIONS="$OPTIONS -a $SMSPROCESSOR" +test -n "$SMSUSER" && STARTOPTS="$STARTOPTS --chuid $SMSUSER" +test -r /etc/default/gsm-utils && . /etc/default/gsm-utils # for overwriting OPTIONS + +if [ ! -d /var/run/gsm-utils ]; then + mkdir /var/run/gsm-utils + chown gsmsms:gsmsms /var/run/gsm-utils +fi + +case "$1" in + start) + echo -n "Starting $DESC: " + if [ -n "$PIN" ];then + echo -n "entering PIN.. " + ( + # This is ugly.. But if the PIN is already entered, the ME returns + # "ERROR" and makes gsmctl retrying.. + /usr/bin/gsmctl -d $PHONEDEV -b $BAUDRATE -I "+cpin=$PIN" & + PID=$! + sleep 3 + kill $PID 2>/dev/null + ) >/dev/null 2>&1 + fi + echo -n "$NAME" + start-stop-daemon --start --quiet --pidfile /var/run/gsm-utils/$NAME.pid \ + --make-pidfile --background $STARTOPTS --exec $DAEMON -- $OPTIONS + echo "." + ;; + stop) + echo -n "Stopping $DESC: $NAME " + start-stop-daemon --stop --quiet --pidfile /var/run/gsm-utils/$NAME.pid \ + --exec $DAEMON + sleep 5 + echo "." + ;; + restart|force-reload) + echo -n "Restarting $DESC: $NAME" + start-stop-daemon --stop --quiet --pidfile /var/run/gsm-utils/$NAME.pid \ + --make-pidfile --background --exec $DAEMON -- $OPTIONS + sleep 5 + start-stop-daemon --start --quiet --pidfile /var/run/gsm-utils/$NAME.pid \ + --make-pidfile --background $STARTOPTS --exec $DAEMON -- $OPTIONS + echo "." + ;; + *) + N=/etc/init.d/gsm-utils + echo "Usage: $N {start|stop|restart|force-reload}" >&2 + exit 1 + ;; +esac + +exit 0 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.postinst b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.postinst new file mode 100644 index 0000000000..7ad58b46f0 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.postinst @@ -0,0 +1,31 @@ +#!/bin/sh -e + +# create gsmsms group if necessary. +if ! grep -q ^gsmsms: /etc/group; then +# echo Adding system group: gsmsms. + addgroup --system gsmsms +fi + +# create gsmsms user if necessary. +if ! grep -q ^gsmsms: /etc/passwd; then +# echo Adding system user: gsmsms. + adduser --system --ingroup gsmsms \ + --no-create-home --home /var/spool/sms gsmsms +fi + +# allow gsmsms to use serial lines +if ! groups gsmsms | grep -q dialout ; then + adduser gsmsms dialout +fi + +# echo Updating spool directory structure: /var/spool/sms +if [ ! -d /var/run/gsm-utils ]; then + mkdir /var/run/gsm-utils +fi +chown -R gsmsms:gsmsms /var/spool/sms /var/run/gsm-utils +chmod 700 /var/spool/sms/* +chmod 750 /var/spool/sms +chmod 730 /var/spool/sms/queue* /var/spool/sms/tmp + +# Add the rest automatically.. +#DEBHELPER# diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.postrm b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.postrm new file mode 100644 index 0000000000..cba60a894c --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.postrm @@ -0,0 +1,43 @@ +#!/bin/sh +# postrm script for #PACKAGE# +# +# see: dh_installdeb(1) + +set -e + +# summary of how this script can be called: +# * `remove' +# * `purge' +# * `upgrade' +# * `failed-upgrade' +# * `abort-install' +# * `abort-install' +# * `abort-upgrade' +# * `disappear' +# +# for details, see http://www.debian.org/doc/debian-policy/ or +# the debian-policy package + + +case "$1" in + remove|upgrade|failed-upgrade|abort-install|abort-upgrade|disappear) + ;; + + purge) + deluser gsmsms + ;; + + *) + echo "postrm called with unknown argument \`$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.undocumented b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.undocumented new file mode 100644 index 0000000000..62d096021d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsm-utils.undocumented @@ -0,0 +1,2 @@ +gsmsmsspool.1 +gsmsmsrequeue.8 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsmsiexfer.1 b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsmsiexfer.1 new file mode 100644 index 0000000000..5f7d449649 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/gsmsiexfer.1 @@ -0,0 +1,29 @@ +.\" -*- eval: (nroff-mode) -*- +.de TQ +.br +.ns +.TP \\$1 +.. +.\" Like TP, but if specified indent is more than half +.\" the current line-length - indent, use the default indent. +.de Tp +.ie \\n(.$=0:((0\\$1)*2u>(\\n(.lu-\\n(.iu)) .TP +.el .TP "\\$1" +.. +.TH GSMSIEXFER 1 "" "gsmsiexfer" +.SH NAME +gsmsiexfer \- Siemens ME file transfer program for Siemens phones S25, S35, S45, ME45, SL45 +.SH SYNOPSIS +.B gsmsiexfer --help +.PP +.SH DESCRIPTION +\fIgsmsiexer\fP comes with no man page. Try gsmsiexfer --help, or +read the source. +.PP +.SH "SEE ALSO" +.BR gsminfo(7), +.BR gsmctl(1), +.BR gsmsendsms(1), +.BR gsmsmsd(8), +.BR gsmsmsstore(1). + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/libgsmme-dev.docs b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/libgsmme-dev.docs new file mode 100644 index 0000000000..8c378905c5 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/libgsmme-dev.docs @@ -0,0 +1,2 @@ +doc/README.developers +doc/README.NLS diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/rules b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/rules new file mode 100644 index 0000000000..11886b8d35 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/rules @@ -0,0 +1,137 @@ +#!/usr/bin/make -f +# Sample debian/rules that uses debhelper. +# GNU copyright 1997 to 1999 by Joey Hess. + +# Uncomment this to turn on verbose mode. +#export DH_VERBOSE=1 + +# shared library versions, option 1 +#version=2.0.5 +#major=2 +# option 2, assuming the library is created as src/.libs/libfoo.so.2.0.5 or so +me_version=`ls gsmlib/.libs/libgsmme*.so.* | \ + awk '{if (match($$0,/[0-9]+\.[0-9]+\.[0-9]+$$/)) print substr($$0,RSTART)}'` +me_major=`ls gsmlib/.libs/libgsmme*.so.* | \ + awk '{if (match($$0,/\.so\.[0-9]+$$/)) print substr($$0,RSTART+4)}'` +ex_version=`ls ext/.libs/libgsmext*.so.* | \ + awk '{if (match($$0,/[0-9]+\.[0-9]+\.[0-9]+$$/)) print substr($$0,RSTART)}'` +ex_major=`ls ext/.libs/libgsmext*.so.* | \ + awk '{if (match($$0,/\.so\.[0-9]+$$/)) print substr($$0,RSTART+4)}'` + + +export DEB_HOST_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_HOST_GNU_TYPE) +export DEB_BUILD_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_BUILD_GNU_TYPE) + + +# FOR AUTOCONF 2.13 ONLY +ifeq ($(DEB_BUILD_GNU_TYPE), $(DEB_HOST_GNU_TYPE)) + confflags += $(DEB_HOST_GNU_TYPE) +else + confflags += --host $(DEB_BUILD_GNU_TYPE) --build $(DEB_HOST_GNU_TYPE) +endif + +ifneq (,$(findstring debug,$(DEB_BUILD_OPTIONS))) +CFLAGS += -g +CXXFLAGS += -g +endif + +configure: configure-stamp +configure-stamp: + dh_testdir + # Add here commands to configure the package. + CFLAGS=$(CFLAGS) CXXFLAGS=$(CXXFLAGS) INSTALL_PROGRAM=$(INSTALL_PROGRAM) \ + ./configure $(confflags) --prefix=/usr --mandir=\$${prefix}/share/man \ + --infodir=\$${prefix}/share/info + + touch configure-stamp + +build: configure-stamp build-stamp +build-stamp: + dh_testdir + + # Add here commands to compile the package. + $(MAKE) + + touch build-stamp + +clean: + dh_testdir + dh_testroot + + # Add here commands to clean up after the build process. + [ ! -f Makefile ] || $(MAKE) distclean + rm -f build-stamp configure-stamp config.log config.status po/de.gmo + + -test -r /usr/share/misc/config.sub && \ + cp -f /usr/share/misc/config.sub scripts/config.sub + -test -r /usr/share/misc/config.guess && \ + cp -f /usr/share/misc/config.guess scripts/config.guess + + dh_clean + +install: build + dh_testdir + dh_testroot + dh_clean -k + dh_installdirs + dh_installdirs -pgsm-utils + + # Add here commands to install the package into debian/gsmlib. + $(MAKE) install DESTDIR=$(CURDIR)/debian/tmp + chrpath -d debian/tmp/usr/bin/* + cp contrib/gsmsmsspool contrib/gsmsmsrequeue debian/tmp/usr/bin + cp contrib/gsm-utils.init contrib/gsm-utils.default debian + cp contrib/gsm-utils.cron.d debian + + +# Build architecture-independent files here. +binary-indep: build install +# We have nothing to do by default. + +# Build architecture-dependent files here. +binary-arch: build install + dh_testdir + dh_testroot + # + # build libgsmlib${major} package by moving files from gsmlib-dev + # + dh_movefiles -plibgsmme$(me_major)c2a \ + usr/lib/libgsmme.so.$(me_major) \ + usr/lib/libgsmme.so.$(me_version) \ + usr/lib/libgsmext.so.$(ex_major) \ + usr/lib/libgsmext.so.$(ex_version) \ + usr/share/locale + + dh_movefiles -plibgsmme-dev \ + usr/include \ + usr/lib + + dh_movefiles -pgsm-utils \ + usr/bin + + +# dh_installdebconf + dh_installdocs + dh_installexamples + dh_installmenu +# dh_installemacsen +# dh_installpam + dh_installinit + dh_installcron + dh_installman -pgsm-utils debian/*.1 debian/tmp/usr/share/man/man*/* + dh_installinfo + dh_installchangelogs ChangeLog + dh_link + dh_strip + dh_compress + dh_fixperms + dh_makeshlibs -V + dh_installdeb +# dh_perl + dh_shlibdeps -ldebian/libgsmme1c2a/usr/lib + dh_gencontrol + dh_md5sums + dh_builddeb + +binary: binary-indep binary-arch +.PHONY: build clean binary-indep binary-arch binary install configure diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/watch b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/watch new file mode 100644 index 0000000000..530c7916ca --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/debian/watch @@ -0,0 +1,2 @@ +version=2 +http://www.pxh.de/fs/gsmlib/download/content.html gsmlib-(.*)\.tar\.gz diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/FAQ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/FAQ new file mode 100644 index 0000000000..303ab14555 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/FAQ @@ -0,0 +1,101 @@ +*** 1. I get the error + /usr/local/bin/gsmsmsd [ERROR]: cannot route status report message to TE + +Some phones/modems cannot route all kinds of SMS to the TE +(computer). Please try + + gsmsmsd no_stat + +This is documented in the gsmsmsd manual page. + + +*** 2. Siemens M20T expects an initial PIN. + +For the Siemens M20T an initial PIN must be send once (probably when +it is switched on or the computer is powered on). This PIN is used for +all subsequent invocations of gsmlib-based programs. The trick is to +issue the following program (eg. in the rc-scripts of the operating system): + + gsmctl -I "+cpin=" + + +*** 3. Sending SMS with or retrieving SMS from my Ericsson SH888 does +not work. + +Set the environment variable GSMLIB_SH888_FIX: + +export GSMLIB_SH888_FIX=1 (bash) +setenv GSMLIB_SH888_FIX 1 (tcsh) + +If it works now, I need your model number. You could just enter +"AT+CGMM" in a terminal program and send me the results. Alternatively +set the environment variable GSMLIB_DEBUG=2 and me the dump. + +*** 4. I get the error "ME/TA error 'Unidentified subscriber' (code +28)" when trying to send SMS using gsmsendsms or gsmsmsd. + +The SMS service centre address (SCA, the phone number of the centre that is +accepting SMS for delivery) is not set correctly in your phone. There +are three ways to correct this: + +1. set the default SCA (example is for Germany T-D1): + + gsmctl -o setsca "+491710760000" + +2. Use the menus of your phone to set the SMS SCA. + +3. Use the option "--sca 1234567" for the gsmsmsd, gsmsmsstore, and +gsmsendsms programs. This tries to set the SCA in the SMS itself (does +not change default SCA) and might not work with all phones. + +*** 5. gsmlib works unreliably with my phone. + +Try another baudrate, even higher baudrates sometimes work better then +lower ones. + +*** 6. On Win32 accessing the COM device fails. + +Use COMx: (x is the number of the COM device) instead of the UNIX +device name. If this doesn't work use "\\.\COMx:". + +*** 7. Windows 2000 Does Not Support Mapping Virtual COM Ports to + Infrared Ports. + +Windows 2000 users should follow the instructions in +support.microsoft.com article Q252795 in order to connect with their +mobile. + +*** 8. gcc-compiled shared C++ libraries do not work properly on some + commercial UNIX systems and with older version of gcc. + +The symptoms may be that the program dumps core on exceptions (AIX) or that +global constructors are not called (Solaris). + +Try to compile gsmlib with + + ./configure --disable-shared --enable-static + +if you encounter strange problems. + +*** 9. How to support unicode? + +You need 6 steps: + +1. set datacodingschema to DCS_SIXTEEN_BIT_ALPHABET + +2. set your locale correctly, for example, my locale, china. + setlocale(LC_ALL, "chs"); + +3. translate MBCS(multiple byte character set) string to unicode string. + wchar_t wstr[ 1000 ]; + memset(wstr, 0, 2000); + mbstowcs(wstr, data.c_str(), data.length()); + +4. get unicode string length. + int wcs_len = wcslen(wstr); + +5. change unicode string to net order. + for (int i = 0; i < wcs_len; i++) + wstr[ i ] = htons(wstr[ i ]); + +6. put unicode string into pdu. diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/Makefile.am b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/Makefile.am new file mode 100644 index 0000000000..f194f8d496 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/Makefile.am @@ -0,0 +1,33 @@ +## Process this file with automake to produce Makefile.in +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: doc Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 11.6.1999 +# ************************************************************************* + +man_MANS = gsmsmsd.8 gsmctl.1 gsmpb.1 gsmsendsms.1 gsmsmsstore.1 gsminfo.7 + +EXTRA_DIST = gsmsmsd.man gsmctl.man gsmpb.man gsmsendsms.man \ + gsmsmsstore.man gsmlib.lsm gsminfo.man \ + README.NLS README.developers FAQ + +%.1: %.man + sed -e "s/##VERSION##/$(VERSION)/g;s/##DATE##/`date`/g" \ + $< > $@ + +%.7: %.man + sed -e "s/##VERSION##/$(VERSION)/g;s/##DATE##/`date`/g" \ + $< > $@ + +%.8: %.man + sed -e "s/##VERSION##/$(VERSION)/g;s/##DATE##/`date`/g" \ + $< > $@ + +clean-local: + rm -f *.1 *.7 *.8 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/Makefile.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/Makefile.in new file mode 100644 index 0000000000..f0f33528e3 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/Makefile.in @@ -0,0 +1,412 @@ +# Makefile.in generated by automake 1.6.3 from Makefile.am. +# @configure_input@ + +# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002 +# Free Software Foundation, Inc. +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +@SET_MAKE@ + +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: doc Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 11.6.1999 +# ************************************************************************* +SHELL = @SHELL@ + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ + +bindir = @bindir@ +sbindir = @sbindir@ +libexecdir = @libexecdir@ +datadir = @datadir@ +sysconfdir = @sysconfdir@ +sharedstatedir = @sharedstatedir@ +localstatedir = @localstatedir@ +libdir = @libdir@ +infodir = @infodir@ +mandir = @mandir@ +includedir = @includedir@ +oldincludedir = /usr/include +pkgdatadir = $(datadir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ +top_builddir = .. + +ACLOCAL = @ACLOCAL@ +AUTOCONF = @AUTOCONF@ +AUTOMAKE = @AUTOMAKE@ +AUTOHEADER = @AUTOHEADER@ + +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd +INSTALL = @INSTALL@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_DATA = @INSTALL_DATA@ +install_sh_DATA = $(install_sh) -c -m 644 +install_sh_PROGRAM = $(install_sh) -c +install_sh_SCRIPT = $(install_sh) -c +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +INSTALL_HEADER = $(INSTALL_DATA) +transform = @program_transform_name@ +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +host_alias = @host_alias@ +host_triplet = @host@ + +EXEEXT = @EXEEXT@ +OBJEXT = @OBJEXT@ +PATH_SEPARATOR = @PATH_SEPARATOR@ +AMTAR = @AMTAR@ +AS = @AS@ +AWK = @AWK@ +BUILD_INCLUDED_LIBINTL = @BUILD_INCLUDED_LIBINTL@ +CATOBJEXT = @CATOBJEXT@ +CC = @CC@ +CPP = @CPP@ +CXX = @CXX@ +DATADIRNAME = @DATADIRNAME@ +DEPDIR = @DEPDIR@ +DLLTOOL = @DLLTOOL@ +ECHO = @ECHO@ +GENCAT = @GENCAT@ +GLIBC21 = @GLIBC21@ +GMSGFMT = @GMSGFMT@ +GSM_VERSION = @GSM_VERSION@ +HAVE_LIB = @HAVE_LIB@ +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ +INSTOBJEXT = @INSTOBJEXT@ +INTLBISON = @INTLBISON@ +INTLLIBS = @INTLLIBS@ +INTLOBJS = @INTLOBJS@ +INTL_LIBTOOL_SUFFIX_PREFIX = @INTL_LIBTOOL_SUFFIX_PREFIX@ +LIB = @LIB@ +LIBICONV = @LIBICONV@ +LIBINTL = @LIBINTL@ +LIBTOOL = @LIBTOOL@ +LN_S = @LN_S@ +LTLIB = @LTLIB@ +LTLIBICONV = @LTLIBICONV@ +LTLIBINTL = @LTLIBINTL@ +MKINSTALLDIRS = @MKINSTALLDIRS@ +OBJDUMP = @OBJDUMP@ +PACKAGE = @PACKAGE@ +POSUB = @POSUB@ +RANLIB = @RANLIB@ +STRIP = @STRIP@ +USE_INCLUDED_LIBINTL = @USE_INCLUDED_LIBINTL@ +USE_NLS = @USE_NLS@ +VERSION = @VERSION@ +am__include = @am__include@ +am__quote = @am__quote@ +install_sh = @install_sh@ + +man_MANS = gsmsmsd.8 gsmctl.1 gsmpb.1 gsmsendsms.1 gsmsmsstore.1 gsminfo.7 + +EXTRA_DIST = gsmsmsd.man gsmctl.man gsmpb.man gsmsendsms.man \ + gsmsmsstore.man gsmlib.lsm gsminfo.man \ + README.NLS README.developers FAQ + +subdir = doc +mkinstalldirs = $(SHELL) $(top_srcdir)/scripts/mkinstalldirs +CONFIG_HEADER = $(top_builddir)/gsm_config.h +CONFIG_CLEAN_FILES = +DIST_SOURCES = + +NROFF = nroff +MANS = $(man_MANS) +DIST_COMMON = Makefile.am Makefile.in +all: all-am + +.SUFFIXES: +$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4) + cd $(top_srcdir) && \ + $(AUTOMAKE) --gnu doc/Makefile +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe) + +mostlyclean-libtool: + -rm -f *.lo + +clean-libtool: + -rm -rf .libs _libs + +distclean-libtool: + -rm -f libtool +uninstall-info-am: + +man1dir = $(mandir)/man1 +install-man1: $(man1_MANS) $(man_MANS) + @$(NORMAL_INSTALL) + $(mkinstalldirs) $(DESTDIR)$(man1dir) + @list='$(man1_MANS) $(dist_man1_MANS) $(nodist_man1_MANS)'; \ + l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \ + for i in $$l2; do \ + case "$$i" in \ + *.1*) list="$$list $$i" ;; \ + esac; \ + done; \ + for i in $$list; do \ + if test -f $(srcdir)/$$i; then file=$(srcdir)/$$i; \ + else file=$$i; fi; \ + ext=`echo $$i | sed -e 's/^.*\\.//'`; \ + case "$$ext" in \ + 1*) ;; \ + *) ext='1' ;; \ + esac; \ + inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \ + inst=`echo $$inst | sed -e 's/^.*\///'`; \ + inst=`echo $$inst | sed '$(transform)'`.$$ext; \ + echo " $(INSTALL_DATA) $$file $(DESTDIR)$(man1dir)/$$inst"; \ + $(INSTALL_DATA) $$file $(DESTDIR)$(man1dir)/$$inst; \ + done +uninstall-man1: + @$(NORMAL_UNINSTALL) + @list='$(man1_MANS) $(dist_man1_MANS) $(nodist_man1_MANS)'; \ + l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \ + for i in $$l2; do \ + case "$$i" in \ + *.1*) list="$$list $$i" ;; \ + esac; \ + done; \ + for i in $$list; do \ + ext=`echo $$i | sed -e 's/^.*\\.//'`; \ + inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \ + inst=`echo $$inst | sed -e 's/^.*\///'`; \ + inst=`echo $$inst | sed '$(transform)'`.$$ext; \ + echo " rm -f $(DESTDIR)$(man1dir)/$$inst"; \ + rm -f $(DESTDIR)$(man1dir)/$$inst; \ + done + +man7dir = $(mandir)/man7 +install-man7: $(man7_MANS) $(man_MANS) + @$(NORMAL_INSTALL) + $(mkinstalldirs) $(DESTDIR)$(man7dir) + @list='$(man7_MANS) $(dist_man7_MANS) $(nodist_man7_MANS)'; \ + l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \ + for i in $$l2; do \ + case "$$i" in \ + *.7*) list="$$list $$i" ;; \ + esac; \ + done; \ + for i in $$list; do \ + if test -f $(srcdir)/$$i; then file=$(srcdir)/$$i; \ + else file=$$i; fi; \ + ext=`echo $$i | sed -e 's/^.*\\.//'`; \ + case "$$ext" in \ + 7*) ;; \ + *) ext='7' ;; \ + esac; \ + inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \ + inst=`echo $$inst | sed -e 's/^.*\///'`; \ + inst=`echo $$inst | sed '$(transform)'`.$$ext; \ + echo " $(INSTALL_DATA) $$file $(DESTDIR)$(man7dir)/$$inst"; \ + $(INSTALL_DATA) $$file $(DESTDIR)$(man7dir)/$$inst; \ + done +uninstall-man7: + @$(NORMAL_UNINSTALL) + @list='$(man7_MANS) $(dist_man7_MANS) $(nodist_man7_MANS)'; \ + l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \ + for i in $$l2; do \ + case "$$i" in \ + *.7*) list="$$list $$i" ;; \ + esac; \ + done; \ + for i in $$list; do \ + ext=`echo $$i | sed -e 's/^.*\\.//'`; \ + inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \ + inst=`echo $$inst | sed -e 's/^.*\///'`; \ + inst=`echo $$inst | sed '$(transform)'`.$$ext; \ + echo " rm -f $(DESTDIR)$(man7dir)/$$inst"; \ + rm -f $(DESTDIR)$(man7dir)/$$inst; \ + done + +man8dir = $(mandir)/man8 +install-man8: $(man8_MANS) $(man_MANS) + @$(NORMAL_INSTALL) + $(mkinstalldirs) $(DESTDIR)$(man8dir) + @list='$(man8_MANS) $(dist_man8_MANS) $(nodist_man8_MANS)'; \ + l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \ + for i in $$l2; do \ + case "$$i" in \ + *.8*) list="$$list $$i" ;; \ + esac; \ + done; \ + for i in $$list; do \ + if test -f $(srcdir)/$$i; then file=$(srcdir)/$$i; \ + else file=$$i; fi; \ + ext=`echo $$i | sed -e 's/^.*\\.//'`; \ + case "$$ext" in \ + 8*) ;; \ + *) ext='8' ;; \ + esac; \ + inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \ + inst=`echo $$inst | sed -e 's/^.*\///'`; \ + inst=`echo $$inst | sed '$(transform)'`.$$ext; \ + echo " $(INSTALL_DATA) $$file $(DESTDIR)$(man8dir)/$$inst"; \ + $(INSTALL_DATA) $$file $(DESTDIR)$(man8dir)/$$inst; \ + done +uninstall-man8: + @$(NORMAL_UNINSTALL) + @list='$(man8_MANS) $(dist_man8_MANS) $(nodist_man8_MANS)'; \ + l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \ + for i in $$l2; do \ + case "$$i" in \ + *.8*) list="$$list $$i" ;; \ + esac; \ + done; \ + for i in $$list; do \ + ext=`echo $$i | sed -e 's/^.*\\.//'`; \ + inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \ + inst=`echo $$inst | sed -e 's/^.*\///'`; \ + inst=`echo $$inst | sed '$(transform)'`.$$ext; \ + echo " rm -f $(DESTDIR)$(man8dir)/$$inst"; \ + rm -f $(DESTDIR)$(man8dir)/$$inst; \ + done +tags: TAGS +TAGS: + +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) + +top_distdir = .. +distdir = $(top_distdir)/$(PACKAGE)-$(VERSION) + +distdir: $(DISTFILES) + @list='$(DISTFILES)'; for file in $$list; do \ + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ + dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \ + if test "$$dir" != "$$file" && test "$$dir" != "."; then \ + dir="/$$dir"; \ + $(mkinstalldirs) "$(distdir)$$dir"; \ + else \ + dir=''; \ + fi; \ + if test -d $$d/$$file; then \ + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ + cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ + fi; \ + cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ + else \ + test -f $(distdir)/$$file \ + || cp -p $$d/$$file $(distdir)/$$file \ + || exit 1; \ + fi; \ + done +check-am: all-am +check: check-am +all-am: Makefile $(MANS) + +installdirs: + $(mkinstalldirs) $(DESTDIR)$(man1dir) $(DESTDIR)$(man7dir) $(DESTDIR)$(man8dir) + +install: install-am +install-exec: install-exec-am +install-data: install-data-am +uninstall: uninstall-am + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am + +installcheck: installcheck-am +install-strip: + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + INSTALL_STRIP_FLAG=-s \ + `test -z '$(STRIP)' || \ + echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -rm -f Makefile $(CONFIG_CLEAN_FILES) + +maintainer-clean-generic: + @echo "This command is intended for maintainers to use" + @echo "it deletes files that may require special tools to rebuild." +clean: clean-am + +clean-am: clean-generic clean-libtool clean-local mostlyclean-am + +distclean: distclean-am + +distclean-am: clean-am distclean-generic distclean-libtool + +dvi: dvi-am + +dvi-am: + +info: info-am + +info-am: + +install-data-am: install-man + +install-exec-am: + +install-info: install-info-am + +install-man: install-man1 install-man7 install-man8 + +installcheck-am: + +maintainer-clean: maintainer-clean-am + +maintainer-clean-am: distclean-am maintainer-clean-generic + +mostlyclean: mostlyclean-am + +mostlyclean-am: mostlyclean-generic mostlyclean-libtool + +uninstall-am: uninstall-info-am uninstall-man + +uninstall-man: uninstall-man1 uninstall-man7 uninstall-man8 + +.PHONY: all all-am check check-am clean clean-generic clean-libtool \ + clean-local distclean distclean-generic distclean-libtool \ + distdir dvi dvi-am info info-am install install-am install-data \ + install-data-am install-exec install-exec-am install-info \ + install-info-am install-man install-man1 install-man7 \ + install-man8 install-strip installcheck installcheck-am \ + installdirs maintainer-clean maintainer-clean-generic \ + mostlyclean mostlyclean-generic mostlyclean-libtool uninstall \ + uninstall-am uninstall-info-am uninstall-man uninstall-man1 \ + uninstall-man7 uninstall-man8 + + +%.1: %.man + sed -e "s/##VERSION##/$(VERSION)/g;s/##DATE##/`date`/g" \ + $< > $@ + +%.7: %.man + sed -e "s/##VERSION##/$(VERSION)/g;s/##DATE##/`date`/g" \ + $< > $@ + +%.8: %.man + sed -e "s/##VERSION##/$(VERSION)/g;s/##DATE##/`date`/g" \ + $< > $@ + +clean-local: + rm -f *.1 *.7 *.8 +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/README.NLS b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/README.NLS new file mode 100644 index 0000000000..a5381f6104 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/README.NLS @@ -0,0 +1,72 @@ +0 Introduction +-------------- + +This version of gsmlib contains national language support (NLS) using +the GNU (or OS-supplied) gettext library. gettext eases the handling +of translations of (usually english) output messages to other +languages by introducing the concept of message catalogs. + +Message catalogs can exist in various formats. The human-readable and +-editable format is the PO file format. I have written a PO-file for +the german language (de.po). These human-readable files are then +translated to MO files which can be used by the gettext library. + +Please refer to the GNU gettext documentation (at the time of this +writing gettext-0.10) for further details. + + +1 Compiling gsmlib with localized messages +------------------------------------------ + +Gsmlib is compiled by default with NLS enabled. If you don't want +NLS invoke configure with the option + +./configure --disable-nls + + +2 Adding new message dialogs +---------------------------- + +1. Edit the ALL_LINGUAS line in "source/configure.in" and add your + language, eg. French: + + ALL_LINGUAS="de fr" + +2. Execute "autoconf" to create a new "configure" script (possible + problem: incompatible "autoconf") + +3. Now issue "./configure" in the "sources" directory. + +4. go to the "po" subdirectory + +5. do a "touch fr.po" to create an initially empty PO-file. + +6. do a "make update-po". This extracts all the strings from the files + listed in "POTFILES" and puts them with empty translations into "fr.po" + (it also updates existing po-Files such as "de.po"). + +7. Now use the editor of your choice to provide translations in + "fr.po". There is an emacs major mode (po-mode) that eases this + process. + +8. now issue "make". This causes an "fr.mo" to be created. + + +3 Adding new strings to gsmlib source code +------------------------------------------ + +1. If you add new strings to the gsmlib source code that need + translation enclose them with "_(" and ")" (see gettext documentation + for special cases). + +2. go to the "po" directory. + +3. do a "make update-po". This updates all existing PO-files (removing + obsolete translations, providing new, emptry entries). + +4. Provide translations for the new, empty entries (ideally using + emacs po-mode) + +5. now issue "make". This causes up-to-date MO-files to be created. + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/README.developers b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/README.developers new file mode 100644 index 0000000000..7fdcc11940 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/README.developers @@ -0,0 +1,138 @@ +OVERVIEW + + The GSM library is written in C++ and uses the latest C++ + features: namespaces, exceptions, the standard template library. + + The actual library source code is in the gsmlib subdirectory of + this distribution. The following modules are available: + + gsm_alloca.h OS-specific alloca defines + gsm_at.h Utility classes for AT command sequence handling + gsm_error.h Error codes and error handling functions + gsm_event.h Event handler interface + gsm_me_ta.h Mobile Equipment/Terminal Adapter and SMS functions + (ETSI GSM 07.07 and 07.05) + gsm_parser.h Parser to parse MA/TA result strings + gsm_phonebook.h Phonebook management functions + gsm_port.h Abstract port definition + gsm_sms.h SMS functions (ETSI GSM 07.05) + gsm_sms_codec.h Coder and Encoder for SMS TPDUs + gsm_sms_store.h SMS functions, SMS store (ETSI GSM 07.05) + gsm_sorted_phonebook.h Alphabetically sorted phonebook + (residing in files or in the ME) + gsm_sorted_sms_store.h Sorted SMS store + (sorted by address, time or type) + (residing in files or in the ME) + gsm_unix_serial.h UNIX serial port implementation + gsm_util.h Various utilities + + +REQUIREMENTS + + I have used egcs-1.1.2 and libstdc++.so.2.8.0 for compiling the + library and all programs. Older probably don't work because of + missing features. + + +AVAILABLE DOCUMENTATION + + If you want to do your own programming using the GSM library please + refer to the extensively documented header files or to the example + programs in the test or apps subdirectory. + + I have used the following documentation to develop this software: + + gts_gsm_02.30_v5.2.0.pdf + gts_gsm_03.40_v5.3.0.pdf + gts_gsm_04.11_v5.1.0.pdf + gts_gsm_02.82_v5.0.0.pdf + gts_gsm_03.41_v5.2.0.pdf + gts_gsm_07.05_v5.3.0.pdf + gts_gsm_03.38_v5.3.0.pdf + gts_gsm_04.08_v5.1.0.pdf + gts_gsm_07.07_v5.0.0.pdf + + Due to copyright reasons I cannot include this documentation in + this distribution. You can download it from the ETSI website + (www.etsi.org) for free, though. + + +COMPILATION + + The code is automatically compiled without debugging code enabled + (mostly assert()'s). + + If there are any problems you can generate a debug version + by issuing + + CXXFLAGS="-g" ./configure --disable-shared + + To switch on asserts and additional debugging output change the line + + CXXFLAGS="-DNEBUG $CXXFLAGS" + + in configure.in do + + dnl CXXFLAGS="-DNEBUG $CXXFLAGS" + + Then regenerate configure by executing autoconf. + + You must use at least gcc-2.95.2 to compile gsmlib successfully. + + +TESTS + + The tests directory contains a number of software tests. Two kinds + of test programs are provided: Those, that run without a mobile + phone and those that require a mobile phone to be connected to a + serial port. + + No access to mobile phone needed: + runparser.sh Test the parser for AT responses + runsms.sh Test SMS message encoding and decoding routines + runspb.sh Test sorted phonebook module + runssms.sh Test sorted SMS store module + + Give mobile phone device as argument: + testsms2 Manipulate SMS store in the mobile phone (read/write) + testgsmlib Test the gsm_me_ta module (readonly) + testpb Dump all phonebooks in the mobile phone to the stdout + (readonly) + testpb2 Manipulate phonebook in the mobile phone (read/write) + + The tests that do not require a mobile phone can be executed by + issuing "make check" in the tests subdirectory. The others must be + invoked manually. WARNING: These tests alter the contents of the + mobile phone's phonebook or SMS message memory!!! Make sure, that + you understand what the test does and be prepared for loss of data in + the mobile phone. + +HINTS + + - By default gsmlib is compiled with NDEBUG set. There are lots + of assert()s all over the library that may help to find problems + in programs that use the library. Disable NDEBUG to get best + debugging support. + +CUSTOM BACKENDS + + gsmlib now allows custom backends to be defined for sorted phonebooks + and sorted SMS stores. This can be used to store phonebook entries in + relational databases or LDAP servers. The interfaces are defined in + gsm_sorted_phonebook_base.h and gsm_sorted_sms_store_base.h, + respectively. + + To register a custom backend (eg. for sorted phonebooks) follow + these steps: + + 1. Define a subclass of CustomPhonebookFactory. + + 2. Define a static initializer class in your module that uses the + interface CustomPhonebookRegistry::registerCustomPhonebookFactory() + to make your custom backend available. + + 3. Link your module to any application that should use your custom + backend. The gsmpb and gsmsmsstore programs are prepared to use the + CustomPhonebookRegistry class to obtain your custom backend + objects. + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmctl.man b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmctl.man new file mode 100644 index 0000000000..2a7a980b46 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmctl.man @@ -0,0 +1,683 @@ +.TH GSMCTL 8 "##DATE##" "gsmctl v##VERSION##" +.SH NAME +gsmctl, gsmsiectl \- GSM mobile phone control program +.SH SYNOPSIS +.B gsmctl +.RB [\| \-b +.IR baudrate \|] +.RB [\| \-\-baudrate +.IR baudrate\| ] +.RB [ \|\-d +.IR device\| ] +.RB [ \|\-\-device +.IR device\fP ] +.RB [ \|\-h\| ] +.RB [ \|\-\-help\| ] +.RB [ \|\-I +.IR "init string" \|] +.RB [ \|\-\-init +.IR "init string" \|] +.RB [ \|\-v\| ] +.RB [ \|\-\-version\| ] +.RB [ \|\-X\| ] +.RB [ \|\-\-xonxoff\| ] +.BI \-o \ operation +.RB | \ \-\-operation +.IR operation \ | +.I parameters +.PP +.B gsmsiectl +.RB [\| \-b +.IR baudrate \|] +.RB [\| \-\-baudrate +.IR baudrate\| ] +.RB [ \|\-d +.IR device\| ] +.RB [ \|\-\-device +.IR device\fP ] +.RB [ \|\-h\| ] +.RB [ \|\-\-help\| ] +.RB [ \|\-I +.IR "init string" \|] +.RB [ \|\-\-init +.IR "init string" \|] +.RB [ \|\-v\| ] +.RB [ \|\-\-version\| ] +.RB [ \|\-X\| ] +.RB [ \|\-\-xonxoff\| ] +.BI \-o \ operation +.RB | \ \-\-operation +.IR operation \ | +.I parameters +.SH DESCRIPTION +.B gsmctl +can request information from or perform operations on an GSM mobile +phone. +.PP +.B gsmctl +attaches itself to the +.I device +given on the command line (usually an GSM modem) using the specified +.IR baudrate . +If no +.I device +is given, the device +.I/dev/mobilephone +is used. If no +.I baudrate +is given, a default baud rate of 38400 is used. +.PP +.B gsmctl +can be used in to modes: If no +.B \-\-operation +option is given the +.I parameters +specify the status information to be retrieved from +the mobile phone. See the section +.B STATUS INFORMATION +for more details. If an +.B \-\-operation +option is given the requested +.I operation +is performed on the mobile using the +.IR parameters . +See the section +.B OPERATIONS +for more details. +.PP +.B gsmsiectl +is the same program with some extension for Siemens mobile phones. +Some extra +.B OPERATIONS +are available in this case. +.PP +Error messages are printed to the standard error output. If the +program terminates on error the error code 1 is returned. +.SH OPTIONS +.TP +.BI \-b\ baudrate ,\ \-\-baudrate\ baudrate +The baud rate to use. Defaults to 38400. +.TP +.BI \-d\ device ,\ \-\-device\ device +The device to which the GSM modem is connected. The default is +.IR /dev/mobilephone . +.TP +.B \-h,\ \-\-help +Prints an option summary. +.TP +.BI \-I\ "init string" ,\ \-\-init\ "init string" +Initialization string to send to the TA (default: "E0"). Note that the +sequence "ATZ" is sent first. +.TP +.BI \-o\ operation ,\ \-\-operation\ operation +This option is used to perform an operation on the mobile phone. Refer +to the section +.B OPERATIONS +for more information on the available +operations and the +.I parameters +required for each operation. +.TP +.B \-v,\ \-\-version +Prints the program version. +.TP +.B \-X,\ \-\-xonxoff +Uses software handshaking (XON/XOFF) for accessing the device. +.SH STATUS INFORMATION +If called without the +.B \-\-operation +option +.B gsmctl +prints out default mobile phone status information as specified by the +.I parameters +described below: +.TP 7 +.B ALL +Prints all available information. +.TP 7 +.B BATT +Prints out information about the current battery status. Two lines of +the form " text" and " charge" are printed. Text may be +of "0 ME is powered by the battery", "1 ME has a battery connected, +but is not powered by it", "2 ME does not have a battery connected", +or "3 Recognized power fault, calls inhibited". Charge is a number in +the range 0..100 where 0 means that the battery is empty or not +connected and 100 means full charge. +.TP 7 +.B BITERR +Prints information about the current bit error rate. The output is of +form " value" where value can be of 0..7, 99 (99 means not +available or not detectable). +.TP 7 +.B CLIP +This option prints a line of the form " on" if caller line +identification is turned on in the network, " off" otherwise. +.TP 7 +.B CSET +Display info about charsets. The output is in the form " +available" and " current", which describes the charsets +available and which is current. +.TP 7 +.B CURROP +Prints information about the current operator. The output line has the +form " Long name: \'xxxx\' Short name: \'yyyy\' Numeric Name: zzzz". +.TP 7 +.B FLCAP +Prints out the two-letter names of available facility locks. The +meaning of standardized facility lock names is as follows: +.RS +.TP 3 +.I CS +Lock control surface (eg. phone keyboard) +.TP 3 +.I PS +Lock phone to SIM card (mobile phone asks password when other than +current SIM card inserted) +.TP 3 +.I SC +Lock SIM card (SIM asks password in mobile phone power-up and when +this lock command issued) +.TP 3 +.I AO +Barr all outgoing calls +.TP 3 +.I OI +Barr outgoing international calls +.TP 3 +.I OX +Barr outgoing international calls except to home country +.TP 3 +.I AI +Barr all incoming calls +.TP 3 +.I IR +Barr incoming calls when roaming outside the home country +.TP 3 +.I NT +Barr incoming calls from numbers not stored to TA memory +.TP 3 +.I NM +Barr incoming calls from numbers not stored to mobile phone memory +.TP 3 +.I NS +Barr incoming calls from numbers not stored to SIM memory +.TP 3 +.I NA +Barr incoming calls from numbers not stored in Any memory +.TP 3 +.I AB +All Barring services (FIXME) +.TP 3 +.I AG +All outGoing barring services (FIXME) +.TP 3 +.I AC +All inComing barring services (FIXME) +.TP 3 +.I FD +SIM fixed dialling memory feature (if PIN2 authentication has not been +done during the current session, PIN2 is required as ) +.PP +Note that mobile phones may implement facility locks not documented +here. +.RE +.TP 7 +.B FLSTAT +Prints information about the status of facility locking in the mobile +phone. For each facility a line of the form " \'facilityname\' +classes" is printed. The classes may be "Voice", "Data", and/or "Fax" +depending on the class for which the facility is enabled. If "unknown" +is printed out this means that the TA is not able to report the +status. If the facility is not enabled for any class, no class +identifier is printed. See +.B FLCAP +for information about the available two-letter names of facility +locks. +.TP 7 +.B FORW +Prints information about call forwarding enabled in the mobile +phone. For each combination of reason (UnconditionalReason, +MobileBusyReason, NoReplyReason, and NotReachableReason) and class +(Voice, Data, and Fax) a line of the form " reason class +number: xxx subaddr: yyy time: zzz" is printed. The time is the number +of seconds to wait before forwarding in case of NoReplyReason. +.TP 7 +.B ME +Prints manufacturer, model, revision, and serial number of +the mobile phone (ME = mobile equipment). Output lines are numbered from +"" to "". +.TP 7 +.B OP +Prints information about the currently available mobile network +operators. For each operator an output line of the form " status +Long name: \'xxxx\' Short name: \'yyyy\' Numeric name: zzz" is returned +where status may be of: +.RS +.TP 10 +.I unknown +The status of the operator is unknown. +.TP +.I current +This is the currently selected operator. +.TP +.I available +This operator is available for selection. +.TP +.I forbidden +This operator is not available for selection, ie. not +accessible with this SIM card. +.RE +.TP 7 +.B PIN +Prints information about the current PIN status. The output is of +form " status". Where status can be one of the following lines: +.RS +.TP 10 +.I READY +ME is not pending for any password. +.TP +.I SIM PIN +ME is waiting SIM PIN to be given. +.TP +.I SIM PUK +ME is waiting SIM PUK to be given. +.TP +.I PH-SIM PIN +ME is waiting phone-to-SIM card password to be given. +.TP +.I PH-FSIM PIN +ME is waiting phone-to-very first SIM card password to be given. +.TP +.I PH-FSIM PUK +ME is waiting phone-to-very first SIM card unblocking password to be +given. +.TP +.I SIM PIN2 +ME is waiting SIM PIN2 to be given. +.TP +.I SIM PUK2 +ME is waiting SIM PUK2 to be given. +.TP +.I PH-NET PIN +ME is waiting network personalisation password to be given. +.TP +.I PH-NET PUK +ME is waiting network personalisation unblocking password to be given. +.TP +.I PH-NETSUB PIN +ME is waiting network subset personalisation password to be given. +.RE +.TP 7 +.B PW +Facilities in the mobile phone may be protected by passwords (ie. PINs +or PUKs). This option prints out lines of the form " +\'facilityname\' len" for each facility for which a facility lock +password exists. See +.B FLCAP +for information about the available two-letter names of facility +locks. +.TP 7 +.B SCA +Reports the default SMS service centre address currently set in the +mobile phone. +.TP 7 +.B SIG +Prints information about the current network signal +strength. The output is of the form " value". Following values +are possible: +.TP +.po +7 +.I 0 +-113 dBm or less +.TP +.I 1 +-111 dBm +.TP +.I 2...30 +-109... -53 dBm (in steps of 2 dBm) +.TP +.I 31 +-51 dBm or greater +.TP +.I 99 +not known or not detectable +.PP +.po +.SH OPERATIONS +.TP +.BI dial\ number +Dials +.IR number . +After dialling +.B gsmctl +waits for a keypress to terminate. +.PP +.B forw +.IR mode\ reason\ number\ [\| facilityclass\| ]\ [ forwardtime ] +.RS +Changes the call forwarding behaviour in the network. +.I mode +can be any of: +.RS 3 +.I disable +Call forwarding is disabled. +.PP +.I enable +Call forwarding is enabled. The call forwarding reason, number, and +(optionally) forwardtime must be registered beforehand. +.PP +.I register +This registers the call forwarding reason, number, and forwardtime in +the network. +.PP +.I erase +This is the counterpart to register. It erase the call forwarding info +in the network. +.RE +.PP +.I reason +can be any of: +.RS 3 +.I unconditional +This applies to every call. +.PP +.I mobilebusy +The mobile phone is busy. +.PP +.I noreply +The call is not answered in \fIforwardtime\fP seconds. +.PP +.I notreachable +Mobile phone cannot be reached (ie. switched off). +.PP +.I all +This refers to all forwarding reasons. +.PP +.I allconditional +This refers to all conditional forward reasons +.RI ( mobilebusy ,\ noreply ,\ notreachable ). +.RE +.PP +.I number +is the number the incoming call is forwarded to. See the explanation +for +.I lock +operation for the meaning of +.IR facilityclass . +The default for +.I forwardtime +is 20 seconds if omitted. +.I forwardtime +can be in the range 1..30. +.RE +.PP +.TP +.BI off +Sets functionality level of the phone to 0 (low functionality). The +effects of this command depend on the phone (eg. sets low power +consumption). +.PP +.TP +.BI on +Sets functionality level of the phone to 1 (high functionality). The +effects of this command depend on the phone. +.PP +.TP +.BI pin\ pin +Sets PIN code. Use +.BI gsmctl\ pin +to get the current pin status. +.PP +.B lock +.IR facility\ [\| facilityclass \|]\ [\| passwd \|] +.RS +Locks the named facility. Use +.BI gsmctl\ flcap +to get a list of supported facilities. The +.I facilityclass +can be any of: +.RS 3 +.I all +Voice, data, and fax. +.PP +.I v\ vf\ vd\ f\ fd\ d +Any combination of voice, data and fax. +.RE +.PP +The default is \fIall\fP if \fIfacilityclass\fP is omitted. The +\fIpasswd\fP is password for the facility. If no password is given +this parameter can be omitted. +.RE +.PP +.BI setop\ opmode\ numericname +.RS +Sets the current operator to +.IR numericname . +Use +.BI gsmctl\ op +to get a list of operators with their numeric codes. +.I opmode +can be any of: +.RS 3 +.I automatic +.PP +.I manual +.PP +.I deregister +Deregister from network. +.PP +.I manualautomatic +If manual selection fails, automatic mode is entered. +.RE +.RE +.PP +.B setpw +.IR facility\ [\| oldpasswd\| ]\ [\| newpasswd\| ] +.RS +Sets the password for the facility. If one of the passwords is omitted +this means that the facility has no password protection. Passwords are +PIN1, PIN2, PUK etc. +.RE +.TP +.BI setsca\ service\ centre\ address +Sets the default SMS service centre address. +.PP +.B unlock +.IR facility\ [\| facilityclass\| ]\ [ \|passwd\| ] +.RS +This is the reverse operation to \fBlock\fP. See above for a +description of the parameters. +.RE +.PP +.B Extra operators for gsmsiectl: +.PP +.B cset +.RS +Charset info. +.RE +.PP +.B pbook +.RS +Phone book info. +.RE +.PP +.B signal +.RS +Signal tone info. +.RE +.PP +.B ring +.RS +Ringing tone info. +.RE +.PP +.B binary +.RS +Binary info. +.RE +.SH EXAMPLES +The following invocation of +.I gsmctl +prints out all available status information for the mobile phone +connected to +.B /dev/mobilephone +.PP +.nf +.IP "" 3 +gsmctl all +.fi +.PP +The output could look like (lines edited to fit): +.RS 3 +.PP +.PD 0 + Manufacturer: SIEMENS +.HP + Model: S10 +.HP + Revision: 06 +.HP + Serial Number: 448058511817585 +.HP + Status: available Long name: 'D1-TELEKOM' Short name: '' Numeric name: 26201 +.HP + Status: forbidden Long name: 'D2 PRIVAT' Short name: '' Numeric name: 26202 +.HP + Long name: 'D1-TELEKOM' Short name: '' Numeric name: 26201 Mode: automatic +.HP + 'CS' +.HP + 'PS' +.HP + 'SC' Voice Data Fax +.HP + 'AO' +.HP + 'OI' +.HP + 'OX' +.HP + 'AI' +.HP + 'IR' +.HP + 'CS' 'PS' 'SC' 'AO' 'OI' 'OX' 'AI' 'IR' 'AB' 'AG' 'AC' +.HP + 'PS' 8 +.HP + 'SC' 8 +.HP + 'AO' 4 +.HP + 'OI' 4 +.HP + 'OX' 4 +.HP + 'AI' 4 +.HP + 'IR' 4 +.HP + 'AB' 4 +.HP + 'AG' 4 +.HP + 'AC' 4 +.HP + on +.HP + UnconditionalReason Voice inactive number: subaddr: time: -1 +.HP + UnconditionalReason Data inactive number: subaddr: time: -1 +.HP + UnconditionalReason Fax inactive number: subaddr: time: -1 +.HP + MobileBusyReason Voice active number: +494012345678 subaddr: time: -1 +.HP + MobileBusyReason Data inactive number: subaddr: time: -1 +.HP + MobileBusyReason Fax inactive number: subaddr: time: -1 +.HP + NoReplyReason Voice active number: +494012345678 subaddr: time: 20 +.HP + NoReplyReason Data inactive number: subaddr: time: -1 +.HP + NoReplyReason Fax inactive number: subaddr: time: -1 +.HP + NotReachableReason Voice active number: +494012345678 subaddr: time: -1 +.HP + NotReachableReason Data inactive number: subaddr: time: -1 +.HP + NotReachableReason Fax inactive number: subaddr: time: -1 +.HP + 0 ME is powered by the battery +.HP + 100 +.HP + 0 +.HP + 19 +.RE +.PD +.PP +The following locks the keys on the mobile phone: +.nf +.IP "" 3 +gsmctl -o lock cs +.fi +.PP +This changes the SIM card PIN from 1234 to 2345: +.nf +.IP "" 3 +gsmctl -o setpw sc 1234 2345 +.fi +.PP +Switch off all call forwarding (actually erase the numbers): +.nf +.IP "" 3 +gsmctl -o forw erase all +.fi +.PP +Switch on call forwarding to German D1 voice box: +.nf +.IP "" 3 +gsmctl -o forw register notreachable 3313 +gsmctl -o forw enable notreachable +.fi +.PP +.SH FILES +.TP +.B /dev/mobilephone +Default mobile phone device. +.SH AUTHOR +Peter Hofmann +.SH BUGS +Report bugs to software@pxh.de. Include a complete, self-ncontained +example that will allow the bug to be reproduced, and say which +version of \fIgsmctl\fP you are using. +.SH COPYRIGHT +Copyright \(co 1999 Peter Hofmann +.PP +.B gsmctl +is free software; you can redistribute it and/or modify it under the +terms of the GNU Library General Public License as published by the +Free Software Foundation; either version 2, or (at your option) any +later version. +.PP +.B gsmctl +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 Library General Public +License for more details. +.PP +You should have received a copy of the GNU Library General Public +License along with +.BR gsmctl ; +see the file COPYING. If not, write to the Free Software Foundation, +675 Mass Ave, Cambridge, MA 02139, USA. +.SH "SEE ALSO" +.BR gsminfo (7), +.BR gsmpb (1), +.BR gsmsendsms (1), +.BR gsmsmsd (8), +.BR gsmsmsstore (1). + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsminfo.man b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsminfo.man new file mode 100644 index 0000000000..7939502779 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsminfo.man @@ -0,0 +1,56 @@ +.\" -*- eval: (nroff-mode) -*- +.de TQ +.br +.ns +.TP \\$1 +.. +.\" Like TP, but if specified indent is more than half +.\" the current line-length - indent, use the default indent. +.de Tp +.ie \\n(.$=0:((0\\$1)*2u>(\\n(.lu-\\n(.iu)) .TP +.el .TP "\\$1" +.. +.TH GSMINFO 7 "##DATE##" "gsmctl v##VERSION##" +.PP +.SH NAME +gsminfo \- GSM general information +.PP +.SH DESCRIPTION +\fIgsmlib\fP is a library to access GSM mobile phones through GSM +modems or via IrDA devices. In the \fIgsmlib\fP documentation and error +messages the following abbreviations are used: +.TP .7i +\fBME\fP +Mobile Equipment. The mobile phone, usually. +.TP .7i +\fBSC\fP +Service Centre. In the context of this documentation, the center +responsible for sending and relaying SMs. +.TP .7i +\fBSM\fP +Short Message. +.TP .7i +\fBSME\fP +Short Message Equipment. Usually the mobile phone. +.TP .7i +\fBTA\fP +Terminal Adapter. This can be a GSM modem PC card or it can be +integrated into the ME. +.TP .7i +\fBTE\fP +Terminal Equipment. This is the device to which the TA is connected, +usually the computer. +.PP +.SH AUTHOR +Peter Hofmann +.PP +.SH COPYRIGHT +Copyright \(co 1999 Peter Hofmann +.PP +.SH "SEE ALSO" +.BR gsmctl(1), +.BR gsmpb(1), +.BR gsmsendsms(1), +.BR gsmsmsd(8), +.BR gsmsmsstore(1). + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmlib.lsm b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmlib.lsm new file mode 100644 index 0000000000..6056b88eed --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmlib.lsm @@ -0,0 +1,20 @@ +Begin3 +Title: gsmlib +Version: 1.0 +Entered-date: 29JUL99 +Description: This distribution contains a library to access + GSM mobile phones through GSM modems. Features include: + * modification of phonebooks stored in the + mobile phone or on the SIM card + * reading and writing of SMS messages stored in + the mobile phone + * sending and reception of SMS messages + Additionally, some simple command line programs are + provided to use these functionalities. +Keywords: gsm mobile phone modem sms +Author: Peter Hofmann +Maintained-by: Peter Hofmann +Primary-site: http://www.pxh.de/fs/gsmlib/ +Platforms: Linux +Copying-policy: LGPL +End diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmpb.man b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmpb.man new file mode 100644 index 0000000000..cfd09409a1 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmpb.man @@ -0,0 +1,245 @@ +.\" -*- eval: (nroff-mode) -*- +.de TQ +.br +.ns +.TP \\$1 +.. +.\" Like TP, but if specified indent is more than half +.\" the current line-length - indent, use the default indent. +.de Tp +.ie \\n(.$=0:((0\\$1)*2u>(\\n(.lu-\\n(.iu)) .TP +.el .TP "\\$1" +.. +.TH GSMPB 8 "##DATE##" "gsmpb v##VERSION##" +.SH NAME +gsmpb \- GSM mobile phone phonebook manipulation program +.SH SYNOPSIS +.B gsmpb +[ \fB-b\fP \fIbaudrate\fP ] +[ \fB--baudrate\fP \fIbaudrate\fP ] +[ \fB-c\fP ] +[ \fB--copy\fP ] +[ \fB-d\fP \fIdestination device or file\fP ] +[ \fB--destination\fP \fIdestination device or file\fP ] +[ \fB-h\fP ] +[ \fB--help\fP ] +[ \fB-i\fP ] +[ \fB--index\fP ] +[ \fB-I\fP \fIinit string\fP ] +[ \fB--init\fP \fIinit string\fP ] +[ \fB-p\fP \fIphonebook name\fP ] +[ \fB--phonebook\fP \fIphonebook name\fP ] +[ \fB-s\fP \fIsource device or file\fP ] +[ \fB--source\fP \fIsource device or file\fP ] +[ \fB-t\fP \fIcharacter set\fP ] +[ \fB--charset\fP \fIcharacter set\fP ] +[ \fB-v\fP ] +[ \fB--version\fP ] +[ \fB-V\fP ] +[ \fB--verbose\fP ] +[ \fB-X\fP ] +[ \fB--xonxoff\fP ] +[ \fB-y\fP ] +[ \fB--synchronize\fP ] +.PP +.SH DESCRIPTION +\fIgsmpb\fP can store or retrieve phonebook entries residing in a GSM +mobile phone's phonebook to or from a file. A synchronization mode is +also available. +.PP +\fIgsmpb\fP reads entries from the source which can be a mobile phone +(if a serial device file is given) or a file (if a file name is +given). The source is never modified. \fIgsmpb\fP writes phonebook +entries to a destination file or device. Depending on the mode the +source is copied to the destination file, thus overwriting the +destination, or the destination is synchronized with regard to the +source which is the default (details see below). +.PP +If "-" is given as the parameter for the \fB--source\fP or +\fB--destination\fP options, the phonebook is read from standard input +and/or written to standard output, respectively. +.PP +Phonebook entries names are encoded using the GSM default alphabet in +the mobile phone, whereas they are stored using the Latin-1 encoding +in phonebook files. When reading phonebook entries from a mobile phone +entry names are converted from the GSM default to Latin-1. Characters +that can not be converted to Latin-1 are encoded as character code +172 (Latin-1 boolean "not"). When writing file-based phonebook entries +to a mobile phone a conversion to the GSM default alphabet takes +place. Characters that can not be converted are encoded as GSM delta +(code 16). If the default character set has been changed using the +\fB--charset\fP option no conversion takes place. +.PP +Error messages are printed to the standard error output. If the program +terminates on error the error code 1 is returned. +.PP +.SH OPTIONS +.TP .7i +\fB-b\fP \fIbaudrate\fP, \fB--baudrate\fP \fIbaudrate\fP +The baud rate to use. The default baudrate is 38400. +.TP .7i +\fB-c\fP, \fB--copy\fP +This causes the contents of the source to be copied to the +destination. After this operation the destination has exactly the same +contents as the source. +.TP .7i +\fB-d\fP \fIdestination\fP, \fB--destination\fP \fIdestination\fP +The destination device or file. +.TP .7i +\fB-h\fP, \fB--help\fP +Prints an option summary. +.TP .7i +\fB-I\fP \fIinit string\fP, \fB--init\fP \fIinit string\fP +Initialization string to send to the TA (default: "E0"). Note that the +sequence "ATZ" is sent first. +.TP .7i +\fB-i\fP, \fB--index\fP +If the index position is given, \fIgsmpb\fP preserves the assignment +of entries to memory slots in the mobile phone's phonebook. This can +be used to backup phonebook entries with their position into a +phonebook file or to change the position of entries by editing a +phonebook file and writing them back to the mobile phone. +If this option is given the phonebook file used as the source +must contain indices for every entry. Additionally, these indices must +be unique, ie. it is not allowed to assign one entry twice to a +specific position in the mobile phone's phonebook. +.TP .7i +\fB-p\fP \fIphonebook\fP, \fB--phonebook\fP \fIphonebook\fP +The name of the phonebook to read from or write to. This is only used +for device sources and destinations. Commonly available phonebooks +are: +.TP .3i +.po +0.7i +.ll 5.8i +\fIFD\fP +SIM fixdialling-phonebook +.TP .3i +\fILD\fP +SIM last-dialling-phonebook +.TP .3i +\fIME\fP +ME phonebook +.TP .3i +\fIMT\fP +combined ME and SIM phonebook +.TP .3i +\fISM\fP +SIM phonebook +.TP .3i +\fITA\fP +TA phonebook +.TP .7i +.po -0.7i +.ll 6.5i +\fB-s\fP \fIsource\fP, \fB--source\fP \fIsource\fP +The source device or file. +.TP +\fB-t\fP \fIcharacter set\fP, \fB--charset\fP \fIcharacter set\fP +Set the character set to use for phonebook operations (default is the +GSM default alphabet). +.TP +\fB-v\fP, \fB--version\fP +Prints the program version. +.TP .7i +\fB-V\fP, \fB--verbose\fP +Prints out a detailed progress report. +.TP .7i +\fB-X\fP, \fB--xonxoff\fP +Uses software handshaking (XON/XOFF) for accessing the device. +.TP .7i +\fB-y\fP, \fB--synchronize\fP +This causes the contents of the source to be synchronized with the +destination (default). Synchronization in this context means: +.TP .2i +.po +0.7i +.ll 5.8i +\- +If the source contains an entry with a name that does not exist in the +destination this entry is added to the destination. +.TP .2i +\- +If the source contains an entry with a name that can also be found in +the destination, the entry in the destination is overwritten (ie. the +telephone number is updated). Exception: More then one entry with the +name exists in the destination. In this case the new entry ist just added. +.TP .2i +\- +Entries in the destination that do not exist in the source are +deleted. +.PP +Note that synchronization has the following properties that differ +from copying: This algorithm does not change the location of unchanged +entries in the destination phonebook. The synchronization function +is not case-sensitive when comparing names. +.PP +.po -0.7i +.ll 6.5i +.SH PHONEBOOK FILE FORMAT +Phonebook entries are stored in phonebook files that are meant to be +human-readable and -editable. There is one phonebook entry per line, +and each line has the format: +.PP +.nf +index|text|phone number +.fi +.PP +The fields have the following meanings: +.TP .7i +\fIindex\fP +The index of the entry which must be a positive number. The index may +also be empty. Indices can be used in conjunction with the +\fB--index\fP option to store the entry into a specific position in +the mobile phone. +.TP .7i +\fItext\fP +Descriptive text for the entry. The text may contain the special +characters '\\', '|', carriage return (ASCII code 13), or line feed +(ASCII code 10). These must be written "\\\\", "\\|", "\\r", "\\n", +respectively. The text should only contain characters that can be +encoded using the GSM default alphabet (see comments above). +.TP .7i +\fIphone number\fP +Phone numbers can only contains the digits 0-9 and the '+' sign. A '+' +sign denotes an international number. +.PP +.SH EXAMPLES +The following invocation of \fIgsmpb\fP synchronizes the mobile phone's +SIM phonebook with the file $HOME/.phonebook: +.PP +.nf +gsmpb --synchronize -b 19200 -d /dev/mobilephone \\ + -s $HOME/.phonebook -p "SM" +.fi +.PP +.SH AUTHOR +Peter Hofmann +.PP +.SH BUGS +Report bugs to software@pxh.de. Include a complete, self-contained +example that will allow the bug to be reproduced, and say which +version of \fIgsmpb\fP you are using. +.PP +.SH COPYRIGHT +Copyright \(co 1999 Peter Hofmann +.LP +\fIgsmpb\fP is free software; you can redistribute it and/or modify it under +the terms of the GNU Library General Public License as published by the Free +Software Foundation; either version 2, or (at your option) any later +version. +.LP +\fIgsmpb\fP 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 Library General Public License +for more details. +.LP +You should have received a copy of the GNU Library General Public License along +with \fIgsmpb\fP; see the file COPYING. If not, write to the Free Software +Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. +.PP +.SH "SEE ALSO" +.BR gsminfo(7), +.BR gsmctl(1), +.BR gsmsendsms(1), +.BR gsmsmsd(8), +.BR gsmsmsstore(1). + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsendsms.man b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsendsms.man new file mode 100644 index 0000000000..05aab7bdef --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsendsms.man @@ -0,0 +1,154 @@ +.\" -*- eval: (nroff-mode) -*- +.de TQ +.br +.ns +.TP \\$1 +.. +.\" Like TP, but if specified indent is more than half +.\" the current line-length - indent, use the default indent. +.de Tp +.ie \\n(.$=0:((0\\$1)*2u>(\\n(.lu-\\n(.iu)) .TP +.el .TP "\\$1" +.. +.TH GSMSENDSMS 8 "##DATE##" "gsmsendsms v##VERSION##" +.PP +.SH NAME +gsmsendsms \- SMS message sender utility +.PP +.SH SYNOPSIS +.B gsmsendsms +[ \fB-b\fP \fIbaudrate\fP ] +[ \fB--baudrate\fP \fIbaudrate\fP ] +[ \fB-c\fP \fIconcatenatedID\fP ] +[ \fB--concatenate\fP \fIconcatenatedID\fP ] +[ \fB-C\fP \fIservice centre address\fP ] +[ \fB--sca\fP \fIservice centre address\fP ] +[ \fB-d\fP \fIdevice\fP ] +[ \fB--device\fP \fIdevice\fP ] +[ \fB-h\fP ] +[ \fB--help\fP ] +[ \fB-I\fP \fIinit string\fP ] +[ \fB--init\fP \fIinit string\fP ] +[ \fB-r\fP ] +[ \fB--requeststat\fP ] +[ \fB-t\fP ] +[ \fB--test\fP ] +[ \fB-v\fP ] +[ \fB--version\fP ] +[ \fB-X\fP ] +[ \fB--xonxoff\fP ] +\fIphonenumber\fP +[ \fItext\fP ] +.PP +.SH DESCRIPTION +\fIgsmsendsms\fP sends SMS short messages using an GSM mobile phone. +.PP +\fIgsmsendsms\fP attaches itself to the \fIdevice\fP given on the command +line (usually an GSM modem) using the specified \fIbaudrate\fP. If no +\fIdevice\fP is given, the device \fI/dev/mobilephone\fP is used. If +no \fIbaudrate\fP is given, a default baud rate of 38400 is used. +.PP +\fIgsmsendsms\fP accepts a phone number (recipient address) and the +short message text as parameters. The text may have a maximum length +of 160 characters which is the maximum SMS message length. The GSM +default alphabet is used for encoding. ASCII and Latin-1 characters +that can not be encoded using the GSM default alphabet are converted +to the GSM delta character (GSM code 16). +.PP +Error messages are printed to the standard error output. If the program +terminates on error the error code 1 is returned. +.PP +.SH OPTIONS +.TP +\fB-b\fP \fIbaudrate\fP, \fB--baudrate\fP \fIbaudrate\fP +The baud rate to use. +.TP +\fB-c\fP \fIconcatenatedID\fP, \fB--concatenate\fP \fIconcatenatedID\fP +If an ID is given, large SMSs are split into several, concatenated +SMSs. All SMSs have the same ID and are numbered consecutively so that +the receiving phone can assemble them in the correct order. IDs must +be in the range 0..255. Not all receiving phones will support +concatenated SMSs (and display them as separate SMSs), +since all the numbering and ID information is +carried in the user data header element at the beginning of the SMS +user data. This information may show up as garbage in such phones. +.TP +\fB-C\fP \fIservice centre address\fP, \fB--sca\fP \fIservice centre address\fP +Sets the service centre address to use for all SUBMIT SMSs (may not +work with some phones). +.TP +\fB-d\fP \fIdevice\fP, \fB--device\fP \fIdevice\fP +The device to which the GSM modem is connected. The default is +\fI/dev/mobilephone\fP. +.TP +\fB-h\fP, \fB--help\fP +Prints an option summary. +.TP +\fB-I\fP \fIinit string\fP, \fB--init\fP \fIinit string\fP +Initialization string to send to the TA (default: "E0"). Note that the +sequence "ATZ" is sent first. +.TP +\fB-r\fP, \fB--requeststat\fP +Request status reports for sent SMS. +.TP +\fB-t\fP, \fB--test\fP +If this option is given the text is converted +to the GSM default alphabet and back to Latin-1. This option can be +used to find out how ASCII or Latin-1 texts are converted to the GSM +default alphabet. Characters that can not be converted to the GSM default +alphabet are reported as ASCII code 172 (Latin-1 boolean "not") +after this double conversion. No SMS messages are sent, a connection +to a mobile phone is not established. +.TP +\fB-v\fP, \fB--version\fP +Prints the program version. +.TP +\fB-X\fP, \fB--xonxoff\fP +Uses software handshaking (XON/XOFF) for accessing the device. +.PP +.SH EXAMPLES +The following two invocations of \fIgsmsendsms\fP each send the same +SMS message to the number "1234": +.PP +.nf +gsmsendsms -d /dev/ttyS2 -b 19200 1234 "This is a test." +echo "This is a test." | gsmsendsms -d /dev/ttyS2 -b 19200 1234 +.fi +.PP +.SH FILES +.TP 1.4i +.B /dev/mobilephone +Default mobile phone device. +.PP +.SH AUTHOR +Peter Hofmann +.PP +.SH BUGS +Report bugs to software@pxh.de. Include a complete, self-contained +example that will allow the bug to be reproduced, and say which +version of \fIgsmsendsms\fP you are using. +.PP +.SH COPYRIGHT +Copyright \(co 1999 Peter Hofmann +.LP +\fIgsmsendsms\fP is free software; you can redistribute it and/or modify it under +the terms of the GNU Library General Public License as published by the Free +Software Foundation; either version 2, or (at your option) any later +version. +.LP +\fIgsmsendsms\fP 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 +Library General Public License for more details. +.LP +You should have received a copy of the GNU Library General Public License along +with \fIgsmsendsms\fP; see the file COPYING. If not, write to the Free Software +Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. +.PP +.SH "SEE ALSO" +.BR gsminfo(7), +.BR gsmpb(1), +.BR gsmctl(1), +.BR gsmsmsd(8), +.BR gsmsmsstore(1). + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsmsd.man b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsmsd.man new file mode 100644 index 0000000000..033aa364f1 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsmsd.man @@ -0,0 +1,269 @@ +.\" -*- eval: (nroff-mode) -*- +.de TQ +.br +.ns +.TP \\$1 +.. +.\" Like TP, but if specified indent is more than half +.\" the current line-length - indent, use the default indent. +.de Tp +.ie \\n(.$=0:((0\\$1)*2u>(\\n(.lu-\\n(.iu)) .TP +.el .TP "\\$1" +.. +.TH GSMSMSD 8 "##DATE##" "gsmsmsd v##VERSION##" +.PP +.SH NAME +gsmsmsd \- SMS message reception daemon +.PP +.SH SYNOPSIS +.B gsmsmsd +[ \fB-a\fP \fIaction\fP ] +[ \fB--action\fP \fIaction\fP ] +[ \fB-b\fP \fIbaudrate\fP ] +[ \fB--baudrate\fP \fIbaudrate\fP ] +[ \fB-c\fP \fIconcatenatedID\fP ] +[ \fB--concatenate\fP \fIconcatenatedID\fP ] +[ \fB-C\fP \fIservice centre address\fP ] +[ \fB--sca\fP \fIservice centre address\fP ] +[ \fB-d\fP \fIdevice\fP ] +[ \fB--device\fP \fIdevice\fP ] +[ \fB-D\fP ] +[ \fB--direct\fP ] +[ \fB-f\fP ] +[ \fB--flush\fP ] +[ \fB-h\fP ] +[ \fB--help\fP ] +[ \fB-I\fP \fIinit string\fP ] +[ \fB--init\fP \fIinit string\fP ] +[ \fB-r\fP ] +[ \fB--requeststat\fP ] +[ \fB-s\fP \fIspool directory\fP ] +[ \fB--spool\fP \fIspool directory\fP ] +[ \fB-t\fP \fISMS store name\fP ] +[ \fB--store\fP \fISMS store name\fP ] +[ \fB-v\fP ] +[ \fB--version\fP ] +[ \fB-X\fP ] +[ \fB--xonxoff\fP ] +{ \fIsms_type\fP } +.PP +.SH DESCRIPTION +\fIgsmsmsd\fP reads new incoming SMS from the mobile phone and +dispatches them to a user-defined action. Additionally it can send SMS +message that it reads from a spooldir. +.PP +\fIgsmsmsd\fP attaches itself to the \fIdevice\fP given on the command +line (usually an GSM modem) using the specified \fIbaudrate\fP and +waits for incoming SMS messages. If no \fIdevice\fP is given, the +device \fI/dev/mobilephone\fP is used. If no \fIbaudrate\fP is given, a +default baud rate of 38400 is used. +.PP +If no action is given, the SMS message is printed to the standard +output. If an \fIaction\fP is specified the \fIaction\fP is excecuted using the +shell and the SMS message is written to the standard input of the action. +.PP +\fIgsmsmsd\fP needs one empty storage slot for SMS messages in the +mobile phone, otherwise SMS reception will not work. The SMS store to +use for temporary storage of incoming SMS can be selected using the +\fB--store\fP option, otherwise the ME default store is used. +.PP +To terminate \fIgsmsmsd\fP cleanly (without losing SMS messages) one +should send either SIGINT (CTRL-C on the command line) or SIGTERM to +the process. +.PP +Error messages are printed to the standard error output. If the program +terminates on error the error code 1 is returned. +.PP +\fIsms_type\fP may be any combination of: +.TP +\fIsms\fP, \fIno_sms\fP +Controls reception of normal SMS messages. +.TP +\fIcb\fP, \fIno_cb\fP +Controls reception of cell broadcast messages. +.TP +\fIstat\fP, \fIno_stat\fP +Controls reception of status reports. +.PP +The default is \fIsms\fP, \fIcb\fP, and \fIstat\fP. +.PP +.SH OPTIONS +.TP +\fB-a\fP \fIaction\fP, \fB--action\fP \fIaction\fP +The action to execute for each incoming SMS message. If no action +is given the SMS is written to the standard output. +.TP +\fB-b\fP \fIbaudrate\fP, \fB--baudrate\fP \fIbaudrate\fP +The baud rate to use. +.TP +\fB-c\fP \fIconcatenatedID\fP, \fB--concatenate\fP \fIconcatenatedID\fP +If an ID is given, large SMSs are split into several, concatenated +SMSs. All SMSs have the same ID and are numbered consecutively so that +the receiving phone can assemble them in the correct order. IDs must +be in the range 0..255. This number is increased by one for every +outgoing concatenated SMS and wraps around after 255. +Not all receiving phones will support +concatenated SMSs (and display them as separate SMSs), +since all the numbering and ID information is +carried in the user data header element at the beginning of the SMS +user data. This information may show up as garbage in such phones. +.TP +\fB-C\fP \fIservice centre address\fP, \fB--sca\fP \fIservice centre address\fP +Sets the service centre address to use for all SUBMIT SMSs (may not +work with some phones). +.TP +\fB-d\fP \fIdevice\fP, \fB--device\fP \fIdevice\fP +The device to which the GSM modem is connected. The default is +\fI/dev/mobilephone\fP. +.TP +\fB-D\fP, \fB--direct\fP +Enables direct routing of incoming SMS messages to the TE. This is not +supported by many mobile phone/GSM modem combinations. Therefore, the +default is to store incoming SMS temporarily before processing them in +the indicated store. +.TP +\fB-f\fP, \fB--flush\fP +This option causes \fIgsmsmsd\fP to flush (ie. read and erase) +existing SMS messages from +the SMS store selected by the \fB--store\fP option. The action given +by the \fB--action\fP option is executed on each of the flushed +SMS. This option should be used to ensure that enough space is +available in the SMS store for temporary storage of incoming SMS, +otherwise incoming SMS might be ignored silently by the ME. +.TP +\fB-h\fP, \fB--help\fP +Prints an option summary. +.TP +\fB-I\fP \fIinit string\fP, \fB--init\fP \fIinit string\fP +Initialization string to send to the TA (default: "E0"). Note that the +sequence "ATZ" is sent first. +.TP +\fB-r\fP, \fB--requeststat\fP +Request status reports for sent SMS. Note: This option only makes +sense if the phone supports routing of status reports to the +TE. Otherwise the status reports might show on the phone's display or +get lost. +.TP +\fB-s\fP \fIspool directory\fP, \fB--spool\fP \fIspool directory\fP +This option sets the spool directory where \fIgsmsmsd\fP expects SMS +messages to send. The format of SMS files is very simple: The first +line contains the phone number of the recipient. Everything else after +the first line is interpreted as the SMS text. Please refer to +.BR gsmsendsms(1) +for details on the SMS text character set and maximum length. +\fIgsmsmsd\fP polls the spool directory every 5 seconds. Sent +SMS message files are removed. +.TP +\fB-t\fP \fISMS store name\fP, \fB--store\fP \fISMS store name\fP +The name of the SMS store to read from (for the \fB--flush\fP option) +or write to (for temporary SMS storage). This option must +be must be used in conjunction with the \fB--flush\fP option. If this +option is omitted the ME uses it's default SMS store for temporary +storage of incoming SMS. A commonly available message +store is "SM" (SIM card). +.TP +\fB-v\fP, \fB--version\fP +Prints the program version. +.TP +\fB-X\fP, \fB--xonxoff\fP +Uses software handshaking (XON/XOFF) for accessing the device. +.PP +.SH EXAMPLES +The following invocation of \fIgsmsmsd\fP sends each incoming SMS message +as a mail to the user "smsadmin": +.PP +.nf +gsmsmsd -d /dev/ttyS2 -b 19200 -a "mail smsadmin" +.fi +.PP +This is the format of SMS deliver messages as output from \fIgsmsmsd\fP: +.PP +.nf +---------------------------------------------------------------- +Message type: SMS-DELIVER +SC address: '491710762100' +More messages to send: 1 +Reply path: 0 +User data header indicator: 0 +Status report indication: 0 +Originating address: '01805000102' +Protocol identifier: 0x39 +Data coding scheme: default alphabet +SC timestamp: 17.12.98 14:10:55(+0100) +User data length: 159 +User data header: 0x +User data: 'Nicht vergessen! Die XtraWeihnachtsverlosung lauft +noch bis zum 24.12. Nutzen Sie jetzt Ihre Gewinnchance und faxen +Sie Ihren Teiln.-Gutschein an 0180/5000 056' +---------------------------------------------------------------- +.fi +.PP +This is the format of SMS status report messages as output from \fIgsmsmsd\fP: +.PP +.nf +---------------------------------------------------------------- +Message type: SMS-STATUS-REPORT +SC address: '' +More messages to send: 0 +Status report qualifier: 0 +Message reference: 0 +Recipient address: '' +SC timestamp: 00.00.00 00:00:00(+0000) +Discharge time: 00.00.00 00:00:00(+0000) +Status: 0x0 'Short message received by the SME' +---------------------------------------------------------------- +.fi +.PP +The following invocation of \fIgsmsmsd\fP flushes all existing +messages from the "SM" SMS store and looks in the "/tmp/spooldir" +directory for SMS to send: +.PP +.nf +gsmsmsd -d /dev/ttyS2 --spool /tmp/spooldir -f --store sm \\ +--action 'mail smsadmin' +.fi +.PP +.SH FILES +.TP 1.4i +.B /dev/mobilephone +Default mobile phone device. +.PP +.SH AUTHOR +Peter Hofmann +.PP +.SH BUGS +Cell broadcast SMS message reception has not been tested, but it has +been enabled in the \fIgsmsmsd\fP daemon. +.PP +The mobile phone device is blocked when the \fIgsmsmsd\fP daemon is +running, ie. it cannot be used for data transfer or from the other +programs of this suite (\fIgsmpb\fP, \fIgsmsms\fP). +.PP +Report bugs to software@pxh.de. Include a complete, self-contained +example that will allow the bug to be reproduced, and say which +version of \fIgsmsmsd\fP you are using. +.PP +.SH COPYRIGHT +Copyright \(co 1999 Peter Hofmann +.LP +\fIgsmsmsd\fP is free software; you can redistribute it and/or modify it under +the terms of the GNU Library General Public License as published by the Free +Software Foundation; either version 2, or (at your option) any later +version. +.LP +\fIgsmsmsd\fP 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 +Library General Public License for more details. +.LP +You should have received a copy of the GNU Library General Public License along +with \fIgsmsmsd\fP; see the file COPYING. If not, write to the Free Software +Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. +.PP +.SH "SEE ALSO" +.BR gsminfo(7), +.BR gsmpb(1), +.BR gsmctl(1), +.BR gsmsendsms(1), +.BR gsmsmsstore(1). + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsmsstore.man b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsmsstore.man new file mode 100644 index 0000000000..af84535dd2 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/doc/gsmsmsstore.man @@ -0,0 +1,185 @@ +.\" -*- eval: (nroff-mode) -*- +.de TQ +.br +.ns +.TP \\$1 +.. +.\" Like TP, but if specified indent is more than half +.\" the current line-length - indent, use the default indent. +.de Tp +.ie \\n(.$=0:((0\\$1)*2u>(\\n(.lu-\\n(.iu)) .TP +.el .TP "\\$1" +.. +.TH GSMSMSSTORE 8 "##DATE##" "gsmsmsstore v##VERSION##" +.SH NAME +gsmsmsstore \- SMS store manipulation program +.SH SYNOPSIS +.B gsmsmsstore +[ \fB-a\fP ] +[ \fB--add\fP ] +[ \fB-b\fP \fIbaudrate\fP ] +[ \fB--baudrate\fP \fIbaudrate\fP ] +[ \fB-c\fP ] +[ \fB--copy\fP ] +[ \fB-C\fP \fIservice centre address\fP ] +[ \fB--sca\fP \fIservice centre address\fP ] +[ \fB-d\fP \fIdestination device or file\fP ] +[ \fB--destination\fP \fIdestination device or file\fP ] +[ \fB-h\fP ] +[ \fB--help\fP ] +[ \fB-I\fP \fIinit string\fP ] +[ \fB--init\fP \fIinit string\fP ] +[ \fB-k\fP ] +[ \fB--backup\fP ] +[ \fB-l\fP ] +[ \fB--list\fP ] +[ \fB-s\fP \fIsource device or file\fP ] +[ \fB--source\fP \fIsource device or file\fP ] +[ \fB-t\fP \fISMS store name\fP ] +[ \fB--store\fP \fISMS store name\fP ] +[ \fB-v\fP ] +[ \fB--version\fP ] +[ \fB-V\fP ] +[ \fB--verbose\fP ] +[ \fB-x\fP ] +[ \fB--delete\fP ] +[ \fB-X\fP ] +[ \fB--xonxoff\fP ] +{ \fIindices\fP } +[ \fIphonenumber\fP \fItext\fP ] +.PP +.SH DESCRIPTION +\fIgsmsmsstore\fP can store or retrieve SMS messages entries residing +in a GSM mobile phone's SMS store to or from a file, add SMS messages +to a store, or list the store's contents. Additionally, it is possible +to add SMS submit messages to a store. +.PP +\fIgsmsmsstore\fP reads entries from the source which can be a mobile +phone (if a serial device file is given) or a file (if a file name is +given). The source is never modified. \fIgsmsmsstore\fP writes SMS +messages to a destination file or device in the case of \fB--copy\fP, +\fB--backup\fP, and \fB--add\fP. +.PP +The \fB--list\fP option does not change any file but just lists the +contents to standard output. +.PP +The \fB--backup\fP and \fB--copy\fP options require both source and +destination files or devices. The \fB--list\fP option requires a +source. The \fB--add\fP and \fB--delete\fP options require a +destination file or device. +.PP +If "-" is given as the parameter for the \fB--source\fP or +\fB--destination\fP options, the SMS store is read from standard input +and/or written to standard output, respectively. +.PP +SMS message files are not human-readable. +.PP +Error messages are printed to the standard error output. If the program +terminates on error the error code 1 is returned. +.PP +.SH OPTIONS +.TP +\fB-a\fP, \fB--add\fP +Adds an SMS submit message with recipient address \fIphonenumber\fP and +text \fItext\fP to the destination. +.TP +\fB-b\fP \fIbaudrate\fP, \fB--baudrate\fP \fIbaudrate\fP +The baud rate to use. The default baudrate is 38400. +.TP +\fB-c\fP, \fB--copy\fP +This causes the contents of the source to be copied to the +destination. After this operation the destination has exactly the same +contents as the source. If \fIindices\fP are given on the command +line only those SMS messages denoted by the indices are copied to the +destination. +.TP +\fB-C\fP \fIservice centre address\fP, \fB--sca\fP \fIservice centre address\fP +Sets the service centre address to use for all SUBMIT SMSs (may not +work with some phones). +.TP +\fB-d\fP \fIdestination\fP, \fB--destination\fP \fIdestination\fP +The destination device or file. +.TP +\fB-h\fP, \fB--help\fP +Prints an option summary. +.TP +\fB-I\fP \fIinit string\fP, \fB--init\fP \fIinit string\fP +Initialization string to send to the TA (default: "E0"). Note that the +sequence "ATZ" is sent first. +.TP +\fB-k\fP, \fB--backup\fP +This causes those entries to be added from the source to the +destination that are not already present in the destination. If +\fIindices\fP are given on the command line only those SMS messages +denoted by the indices are backed up (ie. added) to the destination. +.TP +\fB-l\fP, \fB--list\fP +Prints out the entire contents of the source in human-readable form. +.TP +\fB-s\fP \fIsource\fP, \fB--source\fP \fIsource\fP +The source device or file. +.TP +\fB-t\fP \fISMS store name\fP, \fB--store\fP \fISMS store name\fP +The name of the SMS store to read from or write to. This information is +only used for device sources and destinations. A commonly available message +store is "SM" (SIM card). +.TP +\fB-v\fP, \fB--version\fP +Prints the program version. +.TP +\fB-V\fP, \fB--verbose\fP +Prints out a detailed progress report. +.TP +\fB-x\fP, \fB--delete\fP +Delete the SMS messages as denoted by the \fIindices\fP from the destination. +.TP +\fB-X\fP, \fB--xonxoff\fP +Uses software handshaking (XON/XOFF) for accessing the device. +.PP +.SH EXAMPLES +The following command lists all entries in the mobile phone connected +to \fI/dev/mobilephone\fP to the standard output: +.PP +.nf +gsmsmsstore -b 19200 -s /dev/mobilephone -t SM -l +.fi +.PP +The following adds entries 4, 7, and 10 from the device +\fI/dev/mobilephone\fP to the file \fIsmsstore\fP: +.PP +.nf +gsmsmsstore -s /dev/mobilephone -d /home/fred/smsstore + -t SM -b 4 7 10 +.fi +.PP +.SH AUTHOR +Peter Hofmann +.PP +.SH BUGS +Report bugs to software@pxh.de. Include a complete, self-contained +example that will allow the bug to be reproduced, and say which +version of \fIgsmsmsstore\fP you are using. +.PP +.SH COPYRIGHT +Copyright \(co 1999 Peter Hofmann +.LP +\fIgsmsmsstore\fP is free software; you can redistribute it and/or +modify it under the terms of the GNU Library General Public License as +published by the Free Software Foundation; either version 2, or (at +your option) any later version. +.LP +\fIgsmsmsstore\fP 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 +Library General Public License for more details. +.LP +You should have received a copy of the GNU Library General Public License +along with \fIgsmsmsstore\fP; see the file COPYING. If not, write to +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. +.PP +.SH "SEE ALSO" +.BR gsminfo(7), +.BR gsmctl(1), +.BR gsmpb(1), +.BR gsmsendsms(1), +.BR gsmsmsd(8). diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/Makefile.am b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/Makefile.am new file mode 100644 index 0000000000..1c1d2fc3ce --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/Makefile.am @@ -0,0 +1,40 @@ +## Process this file with automake to produce Makefile.in +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: Makefile for phone-specific extensions +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 16.12.2001 +# ************************************************************************* + +INCLUDES = -I.. + +EXTRA_DIST = README.sieme + +# build addon library +lib_LTLIBRARIES = libgsmext.la + +libgsmext_la_SOURCES = gsm_sie_me.cc + +libgsmext_la_LDFLAGS = -version-info $(GSM_VERSION) + +gsmincludedir = $(includedir)/gsmlib + +gsminclude_HEADERS = gsm_sie_me.h + +# build programs +bin_PROGRAMS = gsmsiectl gsmsiexfer + +# build gsmsiectl from gsmsiectl.cc and libgsmme.la +gsmsiectl_SOURCES = gsmsiectl.cc +gsmsiectl_LDADD = ../gsmlib/libgsmme.la libgsmext.la $(INTLLIBS) + +# build gsmsiexfer from gsmsiexfer.cc and libgsmme.la +gsmsiexfer_SOURCES = gsmsiexfer.cc +gsmsiexfer_LDADD = ../gsmlib/libgsmme.la libgsmext.la $(INTLLIBS) + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/Makefile.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/Makefile.in new file mode 100644 index 0000000000..42240fb530 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/Makefile.in @@ -0,0 +1,480 @@ +# Makefile.in generated by automake 1.6.3 from Makefile.am. +# @configure_input@ + +# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002 +# Free Software Foundation, Inc. +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +@SET_MAKE@ + +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: Makefile for phone-specific extensions +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 16.12.2001 +# ************************************************************************* +SHELL = @SHELL@ + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ + +bindir = @bindir@ +sbindir = @sbindir@ +libexecdir = @libexecdir@ +datadir = @datadir@ +sysconfdir = @sysconfdir@ +sharedstatedir = @sharedstatedir@ +localstatedir = @localstatedir@ +libdir = @libdir@ +infodir = @infodir@ +mandir = @mandir@ +includedir = @includedir@ +oldincludedir = /usr/include +pkgdatadir = $(datadir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ +top_builddir = .. + +ACLOCAL = @ACLOCAL@ +AUTOCONF = @AUTOCONF@ +AUTOMAKE = @AUTOMAKE@ +AUTOHEADER = @AUTOHEADER@ + +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd +INSTALL = @INSTALL@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_DATA = @INSTALL_DATA@ +install_sh_DATA = $(install_sh) -c -m 644 +install_sh_PROGRAM = $(install_sh) -c +install_sh_SCRIPT = $(install_sh) -c +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +INSTALL_HEADER = $(INSTALL_DATA) +transform = @program_transform_name@ +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +host_alias = @host_alias@ +host_triplet = @host@ + +EXEEXT = @EXEEXT@ +OBJEXT = @OBJEXT@ +PATH_SEPARATOR = @PATH_SEPARATOR@ +AMTAR = @AMTAR@ +AS = @AS@ +AWK = @AWK@ +BUILD_INCLUDED_LIBINTL = @BUILD_INCLUDED_LIBINTL@ +CATOBJEXT = @CATOBJEXT@ +CC = @CC@ +CPP = @CPP@ +CXX = @CXX@ +DATADIRNAME = @DATADIRNAME@ +DEPDIR = @DEPDIR@ +DLLTOOL = @DLLTOOL@ +ECHO = @ECHO@ +GENCAT = @GENCAT@ +GLIBC21 = @GLIBC21@ +GMSGFMT = @GMSGFMT@ +GSM_VERSION = @GSM_VERSION@ +HAVE_LIB = @HAVE_LIB@ +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ +INSTOBJEXT = @INSTOBJEXT@ +INTLBISON = @INTLBISON@ +INTLLIBS = @INTLLIBS@ +INTLOBJS = @INTLOBJS@ +INTL_LIBTOOL_SUFFIX_PREFIX = @INTL_LIBTOOL_SUFFIX_PREFIX@ +LIB = @LIB@ +LIBICONV = @LIBICONV@ +LIBINTL = @LIBINTL@ +LIBTOOL = @LIBTOOL@ +LN_S = @LN_S@ +LTLIB = @LTLIB@ +LTLIBICONV = @LTLIBICONV@ +LTLIBINTL = @LTLIBINTL@ +MKINSTALLDIRS = @MKINSTALLDIRS@ +OBJDUMP = @OBJDUMP@ +PACKAGE = @PACKAGE@ +POSUB = @POSUB@ +RANLIB = @RANLIB@ +STRIP = @STRIP@ +USE_INCLUDED_LIBINTL = @USE_INCLUDED_LIBINTL@ +USE_NLS = @USE_NLS@ +VERSION = @VERSION@ +am__include = @am__include@ +am__quote = @am__quote@ +install_sh = @install_sh@ + +INCLUDES = -I.. + +EXTRA_DIST = README.sieme + +# build addon library +lib_LTLIBRARIES = libgsmext.la + +libgsmext_la_SOURCES = gsm_sie_me.cc + +libgsmext_la_LDFLAGS = -version-info $(GSM_VERSION) + +gsmincludedir = $(includedir)/gsmlib + +gsminclude_HEADERS = gsm_sie_me.h + +# build programs +bin_PROGRAMS = gsmsiectl gsmsiexfer + +# build gsmsiectl from gsmsiectl.cc and libgsmme.la +gsmsiectl_SOURCES = gsmsiectl.cc +gsmsiectl_LDADD = ../gsmlib/libgsmme.la libgsmext.la $(INTLLIBS) + +# build gsmsiexfer from gsmsiexfer.cc and libgsmme.la +gsmsiexfer_SOURCES = gsmsiexfer.cc +gsmsiexfer_LDADD = ../gsmlib/libgsmme.la libgsmext.la $(INTLLIBS) +subdir = ext +mkinstalldirs = $(SHELL) $(top_srcdir)/scripts/mkinstalldirs +CONFIG_HEADER = $(top_builddir)/gsm_config.h +CONFIG_CLEAN_FILES = +LTLIBRARIES = $(lib_LTLIBRARIES) + +libgsmext_la_LIBADD = +am_libgsmext_la_OBJECTS = gsm_sie_me.lo +libgsmext_la_OBJECTS = $(am_libgsmext_la_OBJECTS) +bin_PROGRAMS = gsmsiectl$(EXEEXT) gsmsiexfer$(EXEEXT) +PROGRAMS = $(bin_PROGRAMS) + +am_gsmsiectl_OBJECTS = gsmsiectl.$(OBJEXT) +gsmsiectl_OBJECTS = $(am_gsmsiectl_OBJECTS) +gsmsiectl_DEPENDENCIES = ../gsmlib/libgsmme.la libgsmext.la +gsmsiectl_LDFLAGS = +am_gsmsiexfer_OBJECTS = gsmsiexfer.$(OBJEXT) +gsmsiexfer_OBJECTS = $(am_gsmsiexfer_OBJECTS) +gsmsiexfer_DEPENDENCIES = ../gsmlib/libgsmme.la libgsmext.la +gsmsiexfer_LDFLAGS = + +DEFS = @DEFS@ +DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) +CPPFLAGS = @CPPFLAGS@ +LDFLAGS = @LDFLAGS@ +LIBS = @LIBS@ +depcomp = $(SHELL) $(top_srcdir)/scripts/depcomp +am__depfiles_maybe = depfiles +@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/gsm_sie_me.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsmsiectl.Po ./$(DEPDIR)/gsmsiexfer.Po +CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ + $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) +LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ + $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ + $(AM_CXXFLAGS) $(CXXFLAGS) +CXXLD = $(CXX) +CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ + $(AM_LDFLAGS) $(LDFLAGS) -o $@ +CXXFLAGS = @CXXFLAGS@ +DIST_SOURCES = $(libgsmext_la_SOURCES) $(gsmsiectl_SOURCES) \ + $(gsmsiexfer_SOURCES) +HEADERS = $(gsminclude_HEADERS) + +DIST_COMMON = $(gsminclude_HEADERS) Makefile.am Makefile.in +SOURCES = $(libgsmext_la_SOURCES) $(gsmsiectl_SOURCES) $(gsmsiexfer_SOURCES) + +all: all-am + +.SUFFIXES: +.SUFFIXES: .cc .lo .o .obj +$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4) + cd $(top_srcdir) && \ + $(AUTOMAKE) --gnu ext/Makefile +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe) +libLTLIBRARIES_INSTALL = $(INSTALL) +install-libLTLIBRARIES: $(lib_LTLIBRARIES) + @$(NORMAL_INSTALL) + $(mkinstalldirs) $(DESTDIR)$(libdir) + @list='$(lib_LTLIBRARIES)'; for p in $$list; do \ + if test -f $$p; then \ + f="`echo $$p | sed -e 's|^.*/||'`"; \ + echo " $(LIBTOOL) --mode=install $(libLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) $$p $(DESTDIR)$(libdir)/$$f"; \ + $(LIBTOOL) --mode=install $(libLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) $$p $(DESTDIR)$(libdir)/$$f; \ + else :; fi; \ + done + +uninstall-libLTLIBRARIES: + @$(NORMAL_UNINSTALL) + @list='$(lib_LTLIBRARIES)'; for p in $$list; do \ + p="`echo $$p | sed -e 's|^.*/||'`"; \ + echo " $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(libdir)/$$p"; \ + $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(libdir)/$$p; \ + done + +clean-libLTLIBRARIES: + -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) + @list='$(lib_LTLIBRARIES)'; for p in $$list; do \ + dir="`echo $$p | sed -e 's|/[^/]*$$||'`"; \ + test -z "$dir" && dir=.; \ + echo "rm -f \"$${dir}/so_locations\""; \ + rm -f "$${dir}/so_locations"; \ + done +libgsmext.la: $(libgsmext_la_OBJECTS) $(libgsmext_la_DEPENDENCIES) + $(CXXLINK) -rpath $(libdir) $(libgsmext_la_LDFLAGS) $(libgsmext_la_OBJECTS) $(libgsmext_la_LIBADD) $(LIBS) +binPROGRAMS_INSTALL = $(INSTALL_PROGRAM) +install-binPROGRAMS: $(bin_PROGRAMS) + @$(NORMAL_INSTALL) + $(mkinstalldirs) $(DESTDIR)$(bindir) + @list='$(bin_PROGRAMS)'; for p in $$list; do \ + p1=`echo $$p|sed 's/$(EXEEXT)$$//'`; \ + if test -f $$p \ + || test -f $$p1 \ + ; then \ + f=`echo "$$p1" | sed 's,^.*/,,;$(transform);s/$$/$(EXEEXT)/'`; \ + echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) --mode=install $(binPROGRAMS_INSTALL) $$p $(DESTDIR)$(bindir)/$$f"; \ + $(INSTALL_PROGRAM_ENV) $(LIBTOOL) --mode=install $(binPROGRAMS_INSTALL) $$p $(DESTDIR)$(bindir)/$$f; \ + else :; fi; \ + done + +uninstall-binPROGRAMS: + @$(NORMAL_UNINSTALL) + @list='$(bin_PROGRAMS)'; for p in $$list; do \ + f=`echo "$$p" | sed 's,^.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/'`; \ + echo " rm -f $(DESTDIR)$(bindir)/$$f"; \ + rm -f $(DESTDIR)$(bindir)/$$f; \ + done + +clean-binPROGRAMS: + @list='$(bin_PROGRAMS)'; for p in $$list; do \ + f=`echo $$p|sed 's/$(EXEEXT)$$//'`; \ + echo " rm -f $$p $$f"; \ + rm -f $$p $$f ; \ + done +gsmsiectl$(EXEEXT): $(gsmsiectl_OBJECTS) $(gsmsiectl_DEPENDENCIES) + @rm -f gsmsiectl$(EXEEXT) + $(CXXLINK) $(gsmsiectl_LDFLAGS) $(gsmsiectl_OBJECTS) $(gsmsiectl_LDADD) $(LIBS) +gsmsiexfer$(EXEEXT): $(gsmsiexfer_OBJECTS) $(gsmsiexfer_DEPENDENCIES) + @rm -f gsmsiexfer$(EXEEXT) + $(CXXLINK) $(gsmsiexfer_LDFLAGS) $(gsmsiexfer_OBJECTS) $(gsmsiexfer_LDADD) $(LIBS) + +mostlyclean-compile: + -rm -f *.$(OBJEXT) core *.core + +distclean-compile: + -rm -f *.tab.c + +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_sie_me.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsmsiectl.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsmsiexfer.Po@am__quote@ + +distclean-depend: + -rm -rf ./$(DEPDIR) + +.cc.o: +@AMDEP_TRUE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(CXXCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$< + +.cc.obj: +@AMDEP_TRUE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(CXXCOMPILE) -c -o $@ `cygpath -w $<` + +.cc.lo: +@AMDEP_TRUE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(LTCXXCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$< +CXXDEPMODE = @CXXDEPMODE@ + +mostlyclean-libtool: + -rm -f *.lo + +clean-libtool: + -rm -rf .libs _libs + +distclean-libtool: + -rm -f libtool +uninstall-info-am: +gsmincludeHEADERS_INSTALL = $(INSTALL_HEADER) +install-gsmincludeHEADERS: $(gsminclude_HEADERS) + @$(NORMAL_INSTALL) + $(mkinstalldirs) $(DESTDIR)$(gsmincludedir) + @list='$(gsminclude_HEADERS)'; for p in $$list; do \ + if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ + f="`echo $$p | sed -e 's|^.*/||'`"; \ + echo " $(gsmincludeHEADERS_INSTALL) $$d$$p $(DESTDIR)$(gsmincludedir)/$$f"; \ + $(gsmincludeHEADERS_INSTALL) $$d$$p $(DESTDIR)$(gsmincludedir)/$$f; \ + done + +uninstall-gsmincludeHEADERS: + @$(NORMAL_UNINSTALL) + @list='$(gsminclude_HEADERS)'; for p in $$list; do \ + f="`echo $$p | sed -e 's|^.*/||'`"; \ + echo " rm -f $(DESTDIR)$(gsmincludedir)/$$f"; \ + rm -f $(DESTDIR)$(gsmincludedir)/$$f; \ + done + +ETAGS = etags +ETAGSFLAGS = + +tags: TAGS + +ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | \ + $(AWK) ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + mkid -fID $$unique + +TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ + $(TAGS_FILES) $(LISP) + tags=; \ + here=`pwd`; \ + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | \ + $(AWK) ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + test -z "$(ETAGS_ARGS)$$tags$$unique" \ + || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ + $$tags $$unique + +GTAGS: + here=`$(am__cd) $(top_builddir) && pwd` \ + && cd $(top_srcdir) \ + && gtags -i $(GTAGS_ARGS) $$here + +distclean-tags: + -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) + +top_distdir = .. +distdir = $(top_distdir)/$(PACKAGE)-$(VERSION) + +distdir: $(DISTFILES) + @list='$(DISTFILES)'; for file in $$list; do \ + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ + dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \ + if test "$$dir" != "$$file" && test "$$dir" != "."; then \ + dir="/$$dir"; \ + $(mkinstalldirs) "$(distdir)$$dir"; \ + else \ + dir=''; \ + fi; \ + if test -d $$d/$$file; then \ + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ + cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ + fi; \ + cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ + else \ + test -f $(distdir)/$$file \ + || cp -p $$d/$$file $(distdir)/$$file \ + || exit 1; \ + fi; \ + done +check-am: all-am +check: check-am +all-am: Makefile $(LTLIBRARIES) $(PROGRAMS) $(HEADERS) +install-binPROGRAMS: install-libLTLIBRARIES + + +installdirs: + $(mkinstalldirs) $(DESTDIR)$(libdir) $(DESTDIR)$(bindir) $(DESTDIR)$(gsmincludedir) + +install: install-am +install-exec: install-exec-am +install-data: install-data-am +uninstall: uninstall-am + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am + +installcheck: installcheck-am +install-strip: + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + INSTALL_STRIP_FLAG=-s \ + `test -z '$(STRIP)' || \ + echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -rm -f Makefile $(CONFIG_CLEAN_FILES) + +maintainer-clean-generic: + @echo "This command is intended for maintainers to use" + @echo "it deletes files that may require special tools to rebuild." +clean: clean-am + +clean-am: clean-binPROGRAMS clean-generic clean-libLTLIBRARIES \ + clean-libtool mostlyclean-am + +distclean: distclean-am + +distclean-am: clean-am distclean-compile distclean-depend \ + distclean-generic distclean-libtool distclean-tags + +dvi: dvi-am + +dvi-am: + +info: info-am + +info-am: + +install-data-am: install-gsmincludeHEADERS + +install-exec-am: install-binPROGRAMS install-libLTLIBRARIES + +install-info: install-info-am + +install-man: + +installcheck-am: + +maintainer-clean: maintainer-clean-am + +maintainer-clean-am: distclean-am maintainer-clean-generic + +mostlyclean: mostlyclean-am + +mostlyclean-am: mostlyclean-compile mostlyclean-generic \ + mostlyclean-libtool + +uninstall-am: uninstall-binPROGRAMS uninstall-gsmincludeHEADERS \ + uninstall-info-am uninstall-libLTLIBRARIES + +.PHONY: GTAGS all all-am check check-am clean clean-binPROGRAMS \ + clean-generic clean-libLTLIBRARIES clean-libtool distclean \ + distclean-compile distclean-depend distclean-generic \ + distclean-libtool distclean-tags distdir dvi dvi-am info \ + info-am install install-am install-binPROGRAMS install-data \ + install-data-am install-exec install-exec-am \ + install-gsmincludeHEADERS install-info install-info-am \ + install-libLTLIBRARIES install-man install-strip installcheck \ + installcheck-am installdirs maintainer-clean \ + maintainer-clean-generic mostlyclean mostlyclean-compile \ + mostlyclean-generic mostlyclean-libtool tags uninstall \ + uninstall-am uninstall-binPROGRAMS uninstall-gsmincludeHEADERS \ + uninstall-info-am uninstall-libLTLIBRARIES + +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/README.sieme b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/README.sieme new file mode 100644 index 0000000000..4305ae33a2 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/README.sieme @@ -0,0 +1,75 @@ +Extended support for Siemens mobile phones via gsmlib +----------------------------------------------------- + +* Hardware: + +Supported phones: S25, S35, S45, ME45, SL45 +Tested phones: S45, ME45 + +* Feature list: + + - ACM: Output ACM (accumulated call meter) and ACMmax => maybe not + + - BNR/BNW: Binary read and write => yes, xfer + + - CID: Output card ID => maybe + + - CKS: Output SIM card status => maybe + + - CNI: Output call number information => maybe + + - DBR: Database Read => yes, phonebook + + - DLD: Delete the "last number redial" memory => maybe dangerous? + + - GAUTH: Select Type of Authentication for PPP => no + + - ICO: Icon control => no + + - LCK: Switch locks on and off => yes, lock/unlock + + - LNG: Language settings => maybe + + - MGL: List SMS => no + + - MGO: SMS overflow indicator => no + + - MGR: Read SMS (same as AT+CMGR) => no + + - MSO: Switch device off => maybe not + + - NFS: Select NF hardware => maybe + + - NFV: Set the volume => maybe + + - PBC: Seek in telephone book => no + + - PBG: Sorted telephone book => yes + + - PBS: Select a telephone book => yes + + - PIC: Output PIN counter => maybe + + - PLM: Read the PLMN list => yes + + - PLR/PLW: read/write preferred-operator list => yes + + - PST: Play Signal Tone => yes + + - PWD: Change password to a lock => maybe + + - RTC: Set the ringing tone => yes + + - STK: SIM toolkit => no + + +* Additional References + +http://www.s45-world.net/vissie.htm + + +* Author and contact + +Christian W. Zuckschwerdt +http://triq.net/gsm.html + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsm_sie_me.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsm_sie_me.cc new file mode 100644 index 0000000000..fb22260836 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsm_sie_me.cc @@ -0,0 +1,258 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sie_me.cc +// * +// * Purpose: Mobile Equipment/Terminal Adapter and SMS functions +// * (According to "AT command set for S45 Siemens mobile phones" +// * v1.8, 26. July 2001 - Common AT prefix is "^S") +// * +// * Author: Christian W. Zuckschwerdt +// * +// * Created: 2001-12-15 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +// SieMe members + +void SieMe::init() throw(GsmException) +{ +} + +SieMe::SieMe(Ref port) throw(GsmException) : MeTa::MeTa(port) +{ + // initialize Siemens ME + + init(); +} + +vector SieMe::getSupportedPhonebooks() throw(GsmException) +{ + Parser p(_at->chat("^SPBS=?", "^SPBS:")); + return p.parseStringList(); +} + +string SieMe::getCurrentPhonebook() throw(GsmException) +{ + if (_lastPhonebookName == "") + { + Parser p(_at->chat("^SPBS?", "^SPBS:")); + // answer is e.g. ^SPBS: "SM",41,250 + _lastPhonebookName = p.parseString(); + p.parseComma(); + int _currentNumberOfEntries = p.parseInt(); + p.parseComma(); + int _maxNumberOfEntries = p.parseInt(); + } + return _lastPhonebookName; +} + +void SieMe::setPhonebook(string phonebookName) throw(GsmException) +{ + if (phonebookName != _lastPhonebookName) + { + _at->chat("^SPBS=\"" + phonebookName + "\""); + _lastPhonebookName = phonebookName; + } +} + + +IntRange SieMe:: getSupportedSignalTones() throw(GsmException) +{ + Parser p(_at->chat("^SPST=?", "^SPST:")); + // ^SPST: (0-4),(0,1) + IntRange typeRange = p.parseRange(); + p.parseComma(); + vector volumeList = p.parseIntList(); + return typeRange; +} + +void SieMe:: playSignalTone(int tone) throw(GsmException) +{ + _at->chat("^SPST=" + intToStr(tone) + ",1"); +} + +void SieMe:: stopSignalTone(int tone) throw(GsmException) +{ + _at->chat("^SPST=" + intToStr(tone) + ",0"); +} + + +IntRange SieMe::getSupportedRingingTones() throw(GsmException) // (AT^SRTC=?) +{ + Parser p(_at->chat("^SRTC=?", "^SRTC:")); + // ^SRTC: (0-42),(1-5) + IntRange typeRange = p.parseRange(); + p.parseComma(); + IntRange volumeRange = p.parseRange(); + return typeRange; +} + +int SieMe::getCurrentRingingTone() throw(GsmException) // (AT^SRTC?) +{ + Parser p(_at->chat("^SRTC?", "^SRTC:")); + // ^SRTC: 41,2,0 + int type = p.parseInt(); + p.parseComma(); + int volume = p.parseInt(); + p.parseComma(); + int ringing = p.parseInt(); + return type; +} + +void SieMe::setRingingTone(int tone, int volume) throw(GsmException) +{ + _at->chat("^SRTC=" + intToStr(tone) + "," + intToStr(volume)); +} + +void SieMe:: playRingingTone() throw(GsmException) +{ + // get ringing bool + Parser p(_at->chat("^SRTC?", "^SRTC:")); + // ^SRTC: 41,2,0 + int type = p.parseInt(); + p.parseComma(); + int volume = p.parseInt(); + p.parseComma(); + int ringing = p.parseInt(); + + if (ringing == 0) + toggleRingingTone(); +} + +void SieMe::stopRingingTone() throw(GsmException) +{ + // get ringing bool + Parser p(_at->chat("^SRTC?", "^SRTC:")); + // ^SRTC: 41,2,0 + int type = p.parseInt(); + p.parseComma(); + int volume = p.parseInt(); + p.parseComma(); + int ringing = p.parseInt(); + + if (ringing == 1) + toggleRingingTone(); +} + +void SieMe::toggleRingingTone() throw(GsmException) // (AT^SRTC) +{ + _at->chat("^SRTC"); +} + +// Siemens get supported binary read +vector SieMe::getSupportedBinaryReads() throw(GsmException) +{ + Parser p(_at->chat("^SBNR=?", "^SBNR:")); + // ^SBNR: ("bmp",(0-3)),("mid",(0-4)),("vcf",(0-500)),("vcs",(0-50)) + + return p.parseParameterRangeList(); +} + +// Siemens get supported binary write +vector SieMe::getSupportedBinaryWrites() throw(GsmException) +{ + Parser p(_at->chat("^SBNW=?", "^SBNW:")); + // ^SBNW: ("bmp",(0-3)),("mid",(0-4)),("vcf",(0-500)),("vcs",(0-50)),("t9d",(0)) + + return p.parseParameterRangeList(); +} + +// Siemens Binary Read +BinaryObject SieMe::getBinary(string type, int subtype) throw(GsmException) +{ + // expect several response lines + vector result; + result = _at->chatv("^SBNR=\"" + type + "\"," + intToStr(subtype), "^SBNR:"); + // "bmp",0,1,5 pdu "bmp",0,2,5 ... + // most likely to be PDUs of 382 chars (191 * 2) + string pdu; + int fragmentCount = 0; + for (vector::iterator i = result.begin(); i != result.end(); ++i) + { + ++fragmentCount; + // parse header + Parser p(*i); + string fragmentType = p.parseString(); + if (fragmentType != type) + throw GsmException(_("bad PDU type"), ChatError); + p.parseComma(); + int fragmentSubtype = p.parseInt(); + if (fragmentSubtype != subtype) + throw GsmException(_("bad PDU subtype"), ChatError); + p.parseComma(); + int fragmentNumber = p.parseInt(); + if (fragmentNumber != fragmentCount) + throw GsmException(_("bad PDU number"), ChatError); + p.parseComma(); + int numberOfFragments = p.parseInt(); + if (fragmentNumber > numberOfFragments) + throw GsmException(_("bad PDU number"), ChatError); + + // concat pdu fragment + ++i; + pdu += *i; + } + + BinaryObject bnr; + bnr._type = type; + bnr._subtype = subtype; + bnr._size = pdu.length() / 2; + bnr._data = new unsigned char[pdu.length() / 2]; + if (! hexToBuf(pdu, bnr._data)) + throw GsmException(_("bad hexadecimal PDU format"), ChatError); + + return bnr; +} + +// Siemens Binary Write +void SieMe::setBinary(string type, int subtype, BinaryObject obj) + throw(GsmException) +{ + if (obj._size <= 0) + throw GsmException(_("bad object"), ParameterError); + + // Limitation: The maximum pdu size is 176 bytes (or 352 characters) + // this should be a configurable field + int maxPDUsize = 176; + int numberOfPDUs = (obj._size + maxPDUsize - 1) / maxPDUsize; + unsigned char *p = obj._data; + + for (int i = 1; i <= numberOfPDUs; ++i) + { + // construct pdu + int size = maxPDUsize; + if (i == numberOfPDUs) + size = obj._size - (numberOfPDUs - 1) * maxPDUsize; + string pdu = bufToHex(p, size); + p += size; + + cout << "processing " << i << " of " << numberOfPDUs + << " of " << size << " bytes." << endl; + cout << "^SBNW=\"" + type + "\"," + intToStr(subtype) + "," + + intToStr(i) + "," + intToStr(numberOfPDUs) << endl; + cout << pdu << endl; + + _at->sendPdu("^SBNW=\"" + type + "\"," + intToStr(subtype) + "," + + intToStr(i) + "," + intToStr(numberOfPDUs), "", + pdu, true); + cout << "OK" << endl; + } +} + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsm_sie_me.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsm_sie_me.h new file mode 100644 index 0000000000..2c827a0379 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsm_sie_me.h @@ -0,0 +1,99 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sie_me.h +// * +// * Purpose: Mobile Equipment/Terminal Adapter and SMS functions +// * (According to "AT command set for S45 Siemens mobile phones" +// * v1.8, 26. July 2001 - Common AT prefix is "^S") +// * +// * Author: Christian W. Zuckschwerdt +// * +// * Created: 2001-12-15 +// ************************************************************************* + +#ifndef GSM_SIE_ME_H +#define GSM_SIE_ME_H + +#include +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + // *** Siemens mobile phone binary objects (bitmap, midi, vcal, vcard) + + struct BinaryObject + { + string _type; // Object type + int _subtype; // Object subtype (storage number) + unsigned char *_data; // Object binary data + int _size; // Object data size + }; + + // *** this class allows extended access to Siemens moblie phones + + class SieMe : public MeTa + { + private: + // init ME/TA to sensible defaults + void init() throw(GsmException); + + public: + // initialize a new MeTa object given the port + SieMe(Ref port) throw(GsmException); + + + // get the current phonebook in the Siemens ME + vector getSupportedPhonebooks() throw(GsmException);// (AT^SPBS=?) + + // get the current phonebook in the Siemens ME + string getCurrentPhonebook() throw(GsmException); // (AT^SPBS?) + + // set the current phonebook in the Siemens ME + // remember the last phonebook set for optimisation + void setPhonebook(string phonebookName) throw(GsmException); // (AT^SPBS=) + + + // Siemens get supported signal tones + IntRange getSupportedSignalTones() throw(GsmException); // (AT^SPST=?) + + // Siemens set ringing tone + void playSignalTone(int tone) throw(GsmException); // (AT^SRTC=x,1) + + // Siemens set ringing tone + void stopSignalTone(int tone) throw(GsmException); // (AT^SRTC=x,0) + + + // Siemens get ringing tone + IntRange getSupportedRingingTones() throw(GsmException); // (AT^SRTC=?) + // Siemens get ringing tone + int getCurrentRingingTone() throw(GsmException); // (AT^SRTC?) + // Siemens set ringing tone + void setRingingTone(int tone, int volume) throw(GsmException);// (AT^SRTC=) + // Siemens set ringing tone on + void playRingingTone() throw(GsmException); + // Siemens set ringing tone of + void stopRingingTone() throw(GsmException); + // Siemens toggle ringing tone + void toggleRingingTone() throw(GsmException); // (AT^SRTC) + + // Siemens get supported binary read + vector getSupportedBinaryReads() throw(GsmException); + + // Siemens get supported binary write + vector getSupportedBinaryWrites() throw(GsmException); + + // Siemens Binary Read + BinaryObject getBinary(string type, int subtype) throw(GsmException); + + // Siemens Binary Write + void setBinary(string type, int subtype, BinaryObject obj) + throw(GsmException); + }; +}; + +#endif // GSM_ME_TA_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsmsiectl.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsmsiectl.cc new file mode 100644 index 0000000000..4ea92edfea --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsmsiectl.cc @@ -0,0 +1,698 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsmsiectl.cc +// * +// * Purpose: GSM Siemens mobile phone control program +// * +// * Author: Christian W. Zuckschwerdt +// * +// * Created: 2001-12-15 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#if defined(HAVE_GETOPT_LONG) || defined(WIN32) +#include +#endif +#include +#include +#include +#include +#include +#include +#include +#include +#ifdef WIN32 +#include +#else +#include +#include +#endif +#include + +using namespace std; +using namespace gsmlib; + +// my ME + +static SieMe *m; + +// information parameters + +enum InfoParameter {AllInfo, // print all info + MeInfo, // MeInfo must be first! + OperatorInfo, + CurrentOperatorInfo, + FacilityLockStateInfo, + FacilityLockCapabilityInfo, + PasswordInfo, + CLIPInfo, + CallForwardingInfo, + BatteryInfo, + BitErrorInfo, + SCAInfo, + CharSetInfo, + PhonebookInfo, // extended Siemens info + SignalToneInfo, + RingingToneInfo, + BinaryInfo, + SignalInfo}; // SignalInfo must be last! + +// operation parameters + +// FIXME operations not implemented yet + +// options + +#ifdef HAVE_GETOPT_LONG +static struct option longOpts[] = +{ + {"xonxoff", no_argument, (int*)NULL, 'X'}, + {"operation", required_argument, (int*)NULL, 'o'}, + {"device", required_argument, (int*)NULL, 'd'}, + {"baudrate", required_argument, (int*)NULL, 'b'}, + {"init", required_argument, (int*)NULL, 'I'}, + {"help", no_argument, (int*)NULL, 'h'}, + {"version", no_argument, (int*)NULL, 'v'}, + {(char*)NULL, 0, (int*)NULL, 0} +}; +#else +#define getopt_long(argc, argv, options, longopts, indexptr) \ + getopt(argc, argv, options) +#endif + +// helper function, prints forwarding info + +void printForwardReason(string s, ForwardInfo &info) +{ + cout << s << " " + << (info._active ? _("active ") : _("inactive ")) + << _("number: ") << info._number + << _(" subaddr: ") << info._subAddr + << _(" time: ") << info._time << endl; +} + +// helper function, prints integer range + +void printIntRange(IntRange ir) +{ + cout << "(" << ir._low; + if (ir._high != NOT_SET) + cout << "-" << ir._high; + cout << ")"; +} + +// helper function, prints parameter range + +void printParameterRange(ParameterRange pr) +{ + cout << "(\"" << pr._parameter << "\","; + printIntRange(pr._range); + cout << ")"; +} + +// print information + +static void printInfo(InfoParameter ip) +{ + switch (ip) + { + case MeInfo: + { + MEInfo mei = m->getMEInfo(); + cout << _(" Manufacturer: ") << mei._manufacturer << endl + << _(" Model: ") << mei._model << endl + << _(" Revision: ") << mei._revision << endl + << _(" Serial Number: ") << mei._serialNumber << endl; + break; + } + case OperatorInfo: + { + int count = 0; + vector opis = m->getAvailableOPInfo(); + for (vector::iterator i = opis.begin(); i != opis.end(); ++i) + { + cout << " Status: "); + switch (i->_status) + { + case UnknownOPStatus: cout << _("unknown"); break; + case CurrentOPStatus: cout << _("current"); break; + case AvailableOPStatus: cout << _("available"); break; + case ForbiddenOPStatus: cout << _("forbidden"); break; + } + cout << _(" Long name: '") << i->_longName << "' " + << _(" Short name: '") << i->_shortName << "' " + << _(" Numeric name: ") << i->_numericName << endl; + ++count; + } + break; + } + case CurrentOperatorInfo: + { + OPInfo opi = m->getCurrentOPInfo(); + cout << "" + << _(" Long name: '") << opi._longName << "' " + << _(" Short name: '") << opi._shortName << "' " + << _(" Numeric name: ") << opi._numericName + << _(" Mode: "); + switch (opi._mode) + { + case AutomaticOPMode: cout << _("automatic"); break; + case ManualOPMode: cout << _("manual"); break; + case DeregisterOPMode: cout << _("deregister"); break; + case ManualAutomaticOPMode: cout << _("manual/automatic"); break; + } + cout << endl; + break; + } + case FacilityLockStateInfo: + { + int count = 0; + vector fclc = m->getFacilityLockCapabilities(); + for (vector::iterator i = fclc.begin(); i != fclc.end(); ++i) + if (*i != "AB" && *i != "AG" && *i != "AC") + { + cout << " '" << *i << "'"; + try + { + if (m->getFacilityLockStatus(*i, VoiceFacility)) + cout << _(" Voice"); + } + catch (GsmException &e) + { + cout << _(" unknown"); + } + try + { + if (m->getFacilityLockStatus(*i, DataFacility)) + cout << _(" Data"); + } + catch (GsmException &e) + { + cout << _(" unknown"); + } + try + { + if (m->getFacilityLockStatus(*i, FaxFacility)) + cout << _(" Fax"); + } + catch (GsmException &e) + { + cout << _(" unknown"); + } + cout << endl; + ++count; + } + break; + } + case FacilityLockCapabilityInfo: + { + cout << " "; + vector fclc = m->getFacilityLockCapabilities(); + for (vector::iterator i = fclc.begin(); i != fclc.end(); ++i) + cout << "'" << *i << "' "; + cout << endl; + break; + } + case PasswordInfo: + { + vector pwi = m->getPasswords(); + int count = 0; + for (vector::iterator i = pwi.begin(); i != pwi.end(); ++i) + { + cout << " '" + << i->_facility << "' " << i->_maxPasswdLen << endl; + ++count; + } + break; + } + case CLIPInfo: + { + cout << " " << (m->getNetworkCLIP() ? _("on") : _("off")) << endl; + break; + } + case CallForwardingInfo: + { + for (int r = 0; r < 4; ++r) + { + string text; + switch (r) + { + case 0: text = _("UnconditionalReason"); break; + case 1: text = _("MobileBusyReason"); break; + case 2: text = _("NoReplyReason"); break; + case 3: text = _("NotReachableReason"); break; + } + ForwardInfo voice, fax, data; + m->getCallForwardInfo((ForwardReason)r, voice, fax, data); + cout << " " + text + _(" Voice"), voice); + cout << " " + text + _(" Data"), data); + cout << " " + text + _(" Fax"), fax); + } + break; + } + case BatteryInfo: + { + cout << " "; + int bcs = m->getBatteryChargeStatus(); + switch (bcs) + { + case 0: cout << _("0 ME is powered by the battery") << endl; break; + case 1: cout << _("1 ME has a battery connected, but is not powered by it") + << endl; break; + case 2: cout << _("2 ME does not have a battery connected") << endl; break; + case 3: + cout << _("3 Recognized power fault, calls inhibited") << endl; + break; + } + cout << " " << m->getBatteryCharge() << endl; + break; + } + case BitErrorInfo: + { + cout << " " << m->getBitErrorRate() << endl; + break; + } + case SCAInfo: + { + cout << " " << m->getServiceCentreAddress() << endl; + break; + } + case CharSetInfo: + { + cout << " "; + vector cs = m->getSupportedCharSets(); + for (vector::iterator i = cs.begin(); i != cs.end(); ++i) + cout << "'" << *i << "' "; + cout << endl; + cout << " '" << m->getCurrentCharSet() << "'" << endl; + break; + } + case SignalInfo: + { + cout << " " << m->getSignalStrength() << endl; + break; + } + case PhonebookInfo: + { + cout << " "; + vector pb = m->getSupportedPhonebooks(); + for (vector::iterator i = pb.begin(); i != pb.end(); ++i) + cout << "'" << *i << "' "; + cout << endl; + cout << " '" << m->getCurrentPhonebook() << "'" << endl; + break; + } + case SignalToneInfo: + { + cout << " "; + IntRange st = m->getSupportedSignalTones(); + printIntRange(st); + cout << endl; +// cout << " '" << m->getCurrentSignalTone() << "'" << endl; + break; + } + case RingingToneInfo: + { + cout << " "; + IntRange rt = m->getSupportedRingingTones(); + printIntRange(rt); + cout << endl; + cout << " " << m->getCurrentRingingTone() << endl; + break; + } + case BinaryInfo: + { + cout << " "; + vector bnr = m->getSupportedBinaryReads(); + for (vector::iterator i = bnr.begin(); i != bnr.end(); ++i) + { + printParameterRange(*i); + cout << " "; + } + cout << endl; + cout << " "; + vector bnw = m->getSupportedBinaryWrites(); + for (vector::iterator i = bnw.begin(); i != bnw.end(); ++i) + { + printParameterRange(*i); + cout << " "; + } + cout << endl; + break; + } + default: + assert(0); + break; + } +} + +// convert facility class string of the form "", "all", or any combination +// of "v" (voice), "d" (data), or "f" (fax) to numeric form + +FacilityClass strToFacilityClass(string facilityClassS) +{ + facilityClassS = lowercase(facilityClassS); + FacilityClass facilityClass = (FacilityClass)0; + if (facilityClassS == "all" || facilityClassS == "") + return (FacilityClass)ALL_FACILITIES; + + // OR in facility class bits + for (unsigned int i = 0; i < facilityClassS.length(); ++i) + if (facilityClassS[i] == 'v') + facilityClass = (FacilityClass)(facilityClass | VoiceFacility); + else if (facilityClassS[i] == 'd') + facilityClass = (FacilityClass)(facilityClass | DataFacility); + else if (facilityClassS[i] == 'f') + facilityClass = (FacilityClass)(facilityClass | FaxFacility); + else + throw GsmException( + stringPrintf(_("unknown facility class parameter '%c'"), + facilityClassS[i]), ParameterError); + + return facilityClass; +} + +// check if argc - optind is in range min..max +// throw exception otherwise + +void checkParamCount(int optind, int argc, int min, int max) +{ + int paramCount = argc - optind; + if (paramCount < min) + throw GsmException(stringPrintf(_("not enough parameters, minimum number " + "of parameters is %d"), min), + ParameterError); + else if (paramCount > max) + throw GsmException(stringPrintf(_("too many parameters, maximum number " + "of parameters is %d"), max), + ParameterError); +} + +// *** main program + +int main(int argc, char *argv[]) +{ + try + { + // handle command line options + string device = "/dev/mobilephone"; + string operation; + string baudrate; + string initString = DEFAULT_INIT_STRING; + bool swHandshake = false; + + int opt; + int dummy; + while((opt = getopt_long(argc, argv, "I:o:d:b:hvX", longOpts, &dummy)) + != -1) + switch (opt) + { + case 'X': + swHandshake = true; + break; + case 'I': + initString = optarg; + break; + case 'd': + device = optarg; + break; + case 'o': + operation = optarg; + break; + case 'b': + baudrate = optarg; + break; + case 'v': + cerr << argv[0] << stringPrintf(_(": version %s [compiled %s]"), + VERSION, __DATE__) << endl; + exit(0); + break; + case 'h': + cerr << argv[0] << _(": [-b baudrate][-d device][-h]" + "[-I init string][-o operation]\n" + " [-v][-X]{parameters}") << endl + << endl + << _(" -b, --baudrate baudrate to use for device " + "(default: 38400)") + << endl + << _(" -d, --device sets the destination device to " + "connect to") << endl + << _(" -h, --help prints this message") << endl + << _(" -I, --init device AT init sequence") << endl + << _(" -o, --operation operation to perform on the mobile \n" + " phone with the specified parameters") + << endl + << _(" -v, --version prints version and exits") << endl + << _(" -X, --xonxoff switch on software handshake") << endl + << endl + << _(" parameters parameters to use for the operation\n" + " (if an operation is given) or\n" + " a specification which kind of\n" + " information to read from the mobile " + "phone") + << endl << endl + << _("Refer to gsmctl(1) for details on the available parameters" + " and operations.") + << endl << endl; + exit(0); + break; + case '?': + throw GsmException(_("unknown option"), ParameterError); + break; + } + + // open the port and ME/TA + m = new SieMe(new +#ifdef WIN32 + Win32SerialPort +#else + UnixSerialPort +#endif + (device, + baudrate == "" ? + DEFAULT_BAUD_RATE : + baudRateStrToSpeed(baudrate), + initString, swHandshake)); + + if (operation == "") + { // process info parameters + for (int i = optind; i < argc; ++i) + { + string param = lowercase(argv[i]); + if (param == "all") + for (int ip = MeInfo; ip <= SignalInfo; ++ip) + printInfo((InfoParameter)ip); + else if (param == "me") + printInfo(MeInfo); + else if (param == "op") + printInfo(OperatorInfo); + else if (param == "currop") + printInfo(CurrentOperatorInfo); + else if (param == "flstat") + printInfo(FacilityLockStateInfo); + else if (param == "flcap") + printInfo(FacilityLockCapabilityInfo); + else if (param == "pw") + printInfo(PasswordInfo); + else if (param == "clip") + printInfo(CLIPInfo); + else if (param == "forw") + printInfo(CallForwardingInfo); + else if (param == "batt") + printInfo(BatteryInfo); + else if (param == "biterr") + printInfo(BitErrorInfo); + else if (param == "sig") + printInfo(SignalInfo); + else if (param == "sca") + printInfo(SCAInfo); + else if (param == "cset") + printInfo(CharSetInfo); + else if (param == "pbook") + printInfo(PhonebookInfo); + else if (param == "signal") + printInfo(SignalToneInfo); + else if (param == "ring") + printInfo(RingingToneInfo); + else if (param == "binary") + printInfo(BinaryInfo); + else + throw GsmException( + stringPrintf(_("unknown information parameter '%s'"), + param.c_str()), + ParameterError); + } + } + else + { // process operation + operation = lowercase(operation); + if (operation == "dial") + { + // dial: number + checkParamCount(optind, argc, 1, 1); + + m->dial(argv[optind]); + + // wait for keypress from stdin + char c; + read(1, &c, 1); + } + else if (operation == "setop") + { + // setop: opmode numeric FIXME allow long and numeric too + checkParamCount(optind, argc, 2, 2); + string opmodeS = lowercase(argv[optind]); + OPModes opmode; + if (opmodeS == "automatic") + opmode = AutomaticOPMode; + else if (opmodeS == "manual") + opmode = ManualOPMode; + else if (opmodeS == "deregister") + opmode = DeregisterOPMode; + else if (opmodeS == "manualautomatic") + opmode = ManualAutomaticOPMode; + else + throw GsmException(stringPrintf(_("unknown opmode parameter '%s'"), + opmodeS.c_str()), ParameterError); + + m->setCurrentOPInfo(opmode, "" , "", checkNumber(argv[optind + 1])); + } + else if (operation == "lock") + { + // lock: facility [facilityclass] [passwd] + checkParamCount(optind, argc, 1, 3); + string passwd = (argc - optind == 3) ? + (string)argv[optind + 2] : (string)""; + + m->lockFacility(argv[optind], + (argc - optind >= 2) ? + strToFacilityClass(argv[optind + 1]) : + (FacilityClass)ALL_FACILITIES, + passwd); + } + else if (operation == "unlock") + { + // unlock: facility [facilityclass] [passwd] + checkParamCount(optind, argc, 1, 3); + string passwd = argc - optind == 3 ? argv[optind + 2] : ""; + + m->unlockFacility(argv[optind], + (argc - optind >= 2) ? + strToFacilityClass(argv[optind + 1]) : + (FacilityClass)ALL_FACILITIES, + passwd); + } + else if (operation == "setpw") + { + // set password: facility oldpasswd newpasswd + checkParamCount(optind, argc, 1, 3); + string oldPasswd = argc - optind >= 2 ? argv[optind + 1] : ""; + string newPasswd = argc - optind == 3 ? argv[optind + 2] : ""; + + m->setPassword(argv[optind], oldPasswd, newPasswd); + } + else if (operation == "forw") + { + // call forwarding: mode reason number [facilityclass] [forwardtime] + checkParamCount(optind, argc, 2, 5); + + // get optional parameters facility class and forwardtime + int forwardTime = argc - optind == 5 ? checkNumber(argv[optind + 4]) : + NOT_SET; + FacilityClass facilityClass = + argc - optind >= 4 ? strToFacilityClass(argv[optind + 3]) : + (FacilityClass)ALL_FACILITIES; + + // get forward reason + string reasonS = lowercase(argv[optind + 1]); + ForwardReason reason; + if (reasonS == "unconditional") + reason = UnconditionalReason; + else if (reasonS == "mobilebusy") + reason = MobileBusyReason; + else if (reasonS == "noreply") + reason = NoReplyReason; + else if (reasonS == "notreachable") + reason = NotReachableReason; + else if (reasonS == "all") + reason = AllReasons; + else if (reasonS == "allconditional") + reason = AllConditionalReasons; + else + throw GsmException( + stringPrintf(_("unknown forward reason parameter '%s'"), + reasonS.c_str()), ParameterError); + + // get mode + string modeS = lowercase(argv[optind]); + ForwardMode mode; + if (modeS == "disable") + mode = DisableMode; + else if (modeS == "enable") + mode = EnableMode; + else if (modeS == "register") + mode = RegistrationMode; + else if (modeS == "erase") + mode = ErasureMode; + else + throw GsmException( + stringPrintf(_("unknown forward mode parameter '%s'"), + modeS.c_str()), ParameterError); + + m->setCallForwarding(reason, mode, + (argc - optind >= 3) ? argv[optind + 2] : "", + "", // subaddr + facilityClass, forwardTime); + } + else if (operation == "setsca") + { + // set sca: number + checkParamCount(optind, argc, 1, 1); + m->setServiceCentreAddress(argv[optind]); + } + else if (operation == "cset") + { + // set charset: string + checkParamCount(optind, argc, 1, 1); + m->setCharSet(argv[optind]); + } + else if (operation == "signal") + { + // play signal tone: int + checkParamCount(optind, argc, 1, 1); + int tone = atoi(argv[optind]); + m->playSignalTone(tone); + } + else if (operation == "setrt") + { + // set ringing tone: int int + checkParamCount(optind, argc, 2, 2); + int tone = atoi(argv[optind]); + int volume = atoi(argv[optind + 1]); + m->setRingingTone(tone, volume); + } + else if (operation == "playrt") + { + // play/stop ringing tone + m->toggleRingingTone(); + } + else + throw GsmException(stringPrintf(_("unknown operation '%s'"), + operation.c_str()), ParameterError); + } + } + catch (GsmException &ge) + { + cerr << argv[0] << _("[ERROR]: ") << ge.what() << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsmsiexfer.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsmsiexfer.cc new file mode 100644 index 0000000000..90fce1f471 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/ext/gsmsiexfer.cc @@ -0,0 +1,292 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsmsiexfer.cc +// * +// * Purpose: Siemens ME file transfer program +// * +// * Author: Christian W. Zuckschwerdt +// * +// * Created: 2001-12-16 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#ifdef WIN32 +#include +#else +#include +#include +#endif +#if defined(HAVE_GETOPT_LONG) || defined(WIN32) +#include +#endif +#include +#include +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +#ifdef HAVE_GETOPT_LONG +static struct option longOpts[] = +{ + {"xonxoff", no_argument, (int*)NULL, 'X'}, + {"init", required_argument, (int*)NULL, 'I'}, + {"destination", required_argument, (int*)NULL, 'd'}, + {"source", required_argument, (int*)NULL, 's'}, + {"baudrate", required_argument, (int*)NULL, 'b'}, + {"type", required_argument, (int*)NULL, 't'}, + {"subtype", required_argument, (int*)NULL, 'i'}, + {"help", no_argument, (int*)NULL, 'h'}, + {"version", no_argument, (int*)NULL, 'v'}, + {"verbose", no_argument, (int*)NULL, 'V'}, + {(char*)NULL, 0, (int*)NULL, 0} +}; +#else +#define getopt_long(argc, argv, options, longopts, indexptr) \ + getopt(argc, argv, options) +#endif + +// I f*ck up this file IO thing. + +// read binary object from stdin +BinaryObject readBinaryFile(istream &ifs, string filename) +{ + size_t size = 10000; // Bad coder, no biscuits! + BinaryObject bnr; + bnr._data = new unsigned char[size]; + ifs.read((char*)bnr._data, size); + bnr._size = ifs.gcount(); + return bnr; +} + +// read binary object from file +BinaryObject readFile(string filename) +{ + // open the file + ifstream ifs(filename.c_str()); + if (ifs.bad()) + throw GsmException(stringPrintf(_("cannot open file '%s'"), + filename.c_str()), + OSError); + // and read the file + return readBinaryFile(ifs, filename); +} + +// read binary object from stdin +BinaryObject readFile(bool fromStdin) +{ + // read from stdin +// if (fromStdin) + return readBinaryFile(cin, (string)_("")); +} + +// write binary object to file +void writeBinaryFile(ostream &ofs, string filename, BinaryObject bnw) +{ + // well just dump the data + ofs.write((char*)bnw._data, bnw._size); +} + +// write binary object +void writeFile(string filename, BinaryObject obj) +{ + // open the file + ofstream ofs(filename.c_str()); + if (ofs.bad()) + throw GsmException(stringPrintf(_("cannot open file '%s'"), + filename.c_str()), + OSError); + // and read the file + writeBinaryFile(ofs, filename, obj); +} + +// write binary object to stdout +void writeFile(bool toStdout, BinaryObject obj) +{ +// if (toStdout) + writeBinaryFile(cout, (string)_(""), obj); +} + +// *** main program + +int main(int argc, char *argv[]) +{ + try + { + // handle command line options + string destination; + string source; + string baudrate; + string type; + string subtype; + int subtypeN; + bool verbose = false; + string initString = DEFAULT_INIT_STRING; + bool swHandshake = false; + Ref sourceMeTa, destMeTa; + BinaryObject sourceObject; + + int opt; + int dummy; + while((opt = getopt_long(argc, argv, "XI:s:d:b:hvVt:i:", longOpts, + &dummy)) + != -1) + switch (opt) + { + case 'X': + swHandshake = true; + break; + case 'I': + initString = optarg; + break; + case 'V': + verbose = true; + break; + case 't': + type = optarg; + break; + case 'i': + subtype = optarg; + subtypeN = atoi(optarg); + break; + case 'd': + destination = optarg; + break; + case 's': + source = optarg; + break; + case 'b': + baudrate = optarg; + break; + case 'v': + cerr << argv[0] << stringPrintf(_(": version %s [compiled %s]"), + VERSION, __DATE__) << endl; + exit(0); + break; + case 'h': + cerr << argv[0] << _(": [-b baudrate][-c][-d device or file][-h]" + "[-I init string]\n" + " [-p phonebook name][-s device or file]" + "[-t charset][-v]" + "[-V][-y][-X]") << endl + << endl + << _(" -b, --baudrate baudrate to use for device " + "(default: 38400)") + << endl + << _(" -c, --copy copy source entries to destination") + << endl + << _(" -d, --destination sets the destination device to " + "connect \n" + " to, or the file to write") << endl + << _(" -D, --destination-backend sets the destination backend") + << endl + << _(" -h, --help prints this message") << endl + << _(" -i, --index takes index positions into account") + << endl + << _(" -I, --init device AT init sequence") << endl + << _(" -p, --phonebook name of phonebook to use") << endl + << _(" -s, --source sets the source device to connect to,\n" + " or the file to read") << endl + << _(" -t, --charset sets the character set to use for\n" + " phonebook entries") << endl + << _(" -S, --source-backend sets the source backend") + << endl + << _(" -v, --version prints version and exits") << endl + << _(" -V, --verbose print detailed progress messages") + << endl + << _(" -X, --xonxoff switch on software handshake") << endl + << _(" -y, --synchronize synchronize destination with source\n" + " entries (destination is overwritten)\n" + " (see gsmpb(1) for details)") + << endl << endl; + exit(0); + break; + case '?': + throw GsmException(_("unknown option"), ParameterError); + break; + } + + // check if all parameters all present + if (destination == "" || source == "") + throw GsmException(_("both source and destination must be given"), + ParameterError); + + // start accessing source mobile phone or file + if (source == "-") + sourceObject = readFile(true); + else if (isFile(source)) + sourceObject = readFile(source); + else + { + if (type == "") + throw GsmException(_("type be given"), ParameterError); + if (subtype == "") + throw GsmException(_("subtype be given"), ParameterError); + + sourceMeTa = new SieMe(new +#ifdef WIN32 + Win32SerialPort +#else + UnixSerialPort +#endif + (source, + baudrate == "" ? DEFAULT_BAUD_RATE : + baudRateStrToSpeed(baudrate), initString, + swHandshake)); + sourceObject = sourceMeTa->getBinary(type, subtypeN); + } + + // make sure destination.c_str file exists + if (destination != "") + { + try + { + ofstream f(destination.c_str(), ios::out | ios::app); + } + catch (exception) + { + } + } + + // start accessing destination mobile phone or file + if (destination == "-") + writeFile(true, sourceObject); + else if (isFile(destination)) + writeFile(destination, sourceObject); + else + { + if (type == "") + throw GsmException(_("type must be given"), ParameterError); + if (subtype == "") + throw GsmException(_("subtype must be given"), ParameterError); + + destMeTa = new SieMe(new +#ifdef WIN32 + Win32SerialPort +#else + UnixSerialPort +#endif + (destination, + baudrate == "" ? DEFAULT_BAUD_RATE : + baudRateStrToSpeed(baudrate), initString, + swHandshake)); + destMeTa->setBinary(type, subtypeN, sourceObject); + } + } + catch (GsmException &ge) + { + cerr << argv[0] << _("[ERROR]: ") << ge.what() << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/g41.patch b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/g41.patch new file mode 100644 index 0000000000..4c33e6a7d2 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/g41.patch @@ -0,0 +1,29 @@ +--- ./gsmlib/gsm_me_ta.h~ 2006-03-09 19:15:59.000000000 +0000 ++++ ./gsmlib/gsm_me_ta.h 2006-03-09 19:16:31.000000000 +0000 +@@ -291,8 +291,8 @@ + // 3 disable phone receive RF circuits only + // 4 disable phone both transmit and receive RF circuits + // 5...127 implementation-defined +- int MeTa::getFunctionalityLevel() throw(GsmException); +- void MeTa::setFunctionalityLevel(int level) throw(GsmException); ++ int getFunctionalityLevel() throw(GsmException); ++ void setFunctionalityLevel(int level) throw(GsmException); + + // return battery charge status (+CBC): + // 0 ME is powered by the battery +@@ -386,13 +386,13 @@ + void setCallWaitingLockStatus(FacilityClass cl, + bool lock)throw(GsmException); + +- void MeTa::setCLIRPresentation(bool enable) throw(GsmException); ++ void setCLIRPresentation(bool enable) throw(GsmException); + //(+CLIR) + + // 0:according to the subscription of the CLIR service + // 1:CLIR invocation + // 2:CLIR suppression +- int MeTa::getCLIRPresentation() throw(GsmException); ++ int getCLIRPresentation() throw(GsmException); + + friend class Phonebook; + friend class SMSStore; diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsm_config.h.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsm_config.h.in new file mode 100644 index 0000000000..4ed31e1464 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsm_config.h.in @@ -0,0 +1,344 @@ +/* gsm_config.h.in. Generated from configure.in by autoheader. */ +/* used by libtool*/ +#define PACKAGE 0 + +/* used by libtool*/ +#define VERSION 0 + +/* Define if getopt_long() available */ +#undef HAVE_GETOPT_LONG + +/* Define if alarm() available */ +#undef HAVE_ALARM + +/* Define if netinet/in.h header available */ +#undef HAVE_NETINET_IN_H + +/* Define if string.h header available */ +#undef HAVE_STRING_H + +/* Define for NLS */ +#undef ENABLE_NLS +#undef HAVE_CATGETS +#undef HAVE_GETTEXT +#undef HAVE_LC_MESSAGES +#undef HAVE_STPCPY + +/* Define LOCALEDIR */ +#define LOCALEDIR "/usr/share/locale" + +/* Define if libintl.h header available */ +#undef HAVE_LIBINTL_H + +/* Define if vsnprintf() function available */ +#undef HAVE_VSNPRINTF + +/* Define to one of `_getb67', `GETB67', `getb67' for Cray-2 and Cray-YMP + systems. This function is required for `alloca.c' support on those systems. + */ +#undef CRAY_STACKSEG_END + +/* Define to 1 if using `alloca.c'. */ +#undef C_ALLOCA + +/* Define to 1 if translation of program messages to the user's native + language is requested. */ +#undef ENABLE_NLS + +/* Define to 1 if you have `alloca', as a function or macro. */ +#undef HAVE_ALLOCA + +/* Define to 1 if you have and it should be used (not on Ultrix). + */ +#undef HAVE_ALLOCA_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_ARGZ_H + +/* Define to 1 if you have the `asprintf' function. */ +#undef HAVE_ASPRINTF + +/* Define to 1 if you have the MacOS X function CFLocaleCopyCurrent in the + CoreFoundation framework. */ +#undef HAVE_CFLOCALECOPYCURRENT + +/* Define to 1 if you have the MacOS X function CFPreferencesCopyAppValue in + the CoreFoundation framework. */ +#undef HAVE_CFPREFERENCESCOPYAPPVALUE + +/* Define if the GNU dcgettext() function is already present or preinstalled. + */ +#undef HAVE_DCGETTEXT + +/* Define to 1 if you have the declaration of `feof_unlocked', and to 0 if you + don't. */ +#undef HAVE_DECL_FEOF_UNLOCKED + +/* Define to 1 if you have the declaration of `fgets_unlocked', and to 0 if + you don't. */ +#undef HAVE_DECL_FGETS_UNLOCKED + +/* Define to 1 if you have the declaration of `getc_unlocked', and to 0 if you + don't. */ +#undef HAVE_DECL_GETC_UNLOCKED + +/* Define to 1 if you have the declaration of `_snprintf', and to 0 if you + don't. */ +#undef HAVE_DECL__SNPRINTF + +/* Define to 1 if you have the declaration of `_snwprintf', and to 0 if you + don't. */ +#undef HAVE_DECL__SNWPRINTF + +/* Define to 1 if you have the header file. */ +#undef HAVE_DLFCN_H + +/* Define to 1 if you have the `fwprintf' function. */ +#undef HAVE_FWPRINTF + +/* Define to 1 if you have the `getcwd' function. */ +#undef HAVE_GETCWD + +/* Define to 1 if you have the `getegid' function. */ +#undef HAVE_GETEGID + +/* Define to 1 if you have the `geteuid' function. */ +#undef HAVE_GETEUID + +/* Define to 1 if you have the `getgid' function. */ +#undef HAVE_GETGID + +/* Define to 1 if you have the `getpagesize' function. */ +#undef HAVE_GETPAGESIZE + +/* Define if the GNU gettext() function is already present or preinstalled. */ +#undef HAVE_GETTEXT + +/* Define to 1 if you have the `getuid' function. */ +#undef HAVE_GETUID + +/* Define if you have the iconv() function. */ +#undef HAVE_ICONV + +/* Define if you have the 'intmax_t' type in or . */ +#undef HAVE_INTMAX_T + +/* Define if exists and doesn't clash with . */ +#undef HAVE_INTTYPES_H + +/* Define if exists, doesn't clash with , and + declares uintmax_t. */ +#undef HAVE_INTTYPES_H_WITH_UINTMAX + +/* Define if you have and nl_langinfo(CODESET). */ +#undef HAVE_LANGINFO_CODESET + +/* Define if your file defines LC_MESSAGES. */ +#undef HAVE_LC_MESSAGES + +/* Define to 1 if you have the `intl' library (-lintl). */ +#undef HAVE_LIBINTL + +/* Define to 1 if you have the header file. */ +#undef HAVE_LIBINTL_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_LIMITS_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_LOCALE_H + +/* Define if you have the 'long double' type. */ +#undef HAVE_LONG_DOUBLE + +/* Define if you have the 'long long' type. */ +#undef HAVE_LONG_LONG + +/* Define to 1 if you have the header file. */ +#undef HAVE_MALLOC_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_MEMORY_H + +/* Define to 1 if you have the `mempcpy' function. */ +#undef HAVE_MEMPCPY + +/* Define to 1 if you have a working `mmap' system call. */ +#undef HAVE_MMAP + +/* Define to 1 if you have the `munmap' function. */ +#undef HAVE_MUNMAP + +/* Define to 1 if you have the header file. */ +#undef HAVE_NETINET_IN_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_NL_TYPES_H + +/* Define if your printf() function supports format strings with positions. */ +#undef HAVE_POSIX_PRINTF + +/* Define to 1 if you have the `putenv' function. */ +#undef HAVE_PUTENV + +/* Define to 1 if you have the `setenv' function. */ +#undef HAVE_SETENV + +/* Define to 1 if you have the `setlocale' function. */ +#undef HAVE_SETLOCALE + +/* Define to 1 if you have the `snprintf' function. */ +#undef HAVE_SNPRINTF + +/* Define to 1 if you have the header file. */ +#undef HAVE_STDDEF_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_STDINT_H + +/* Define if exists, doesn't clash with , and declares + uintmax_t. */ +#undef HAVE_STDINT_H_WITH_UINTMAX + +/* Define to 1 if you have the header file. */ +#undef HAVE_STDLIB_H + +/* Define to 1 if you have the `stpcpy' function. */ +#undef HAVE_STPCPY + +/* Define to 1 if you have the `strcasecmp' function. */ +#undef HAVE_STRCASECMP + +/* Define to 1 if you have the `strdup' function. */ +#undef HAVE_STRDUP + +/* Define to 1 if you have the header file. */ +#undef HAVE_STRINGS_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_STRING_H + +/* Define to 1 if you have the `strtoul' function. */ +#undef HAVE_STRTOUL + +/* Define to 1 if you have the header file. */ +#undef HAVE_SYS_PARAM_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_SYS_STAT_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_SYS_TYPES_H + +/* Define to 1 if you have the `tsearch' function. */ +#undef HAVE_TSEARCH + +/* Define if you have the 'uintmax_t' type in or . */ +#undef HAVE_UINTMAX_T + +/* Define to 1 if you have the header file. */ +#undef HAVE_UNISTD_H + +/* Define if you have the 'unsigned long long' type. */ +#undef HAVE_UNSIGNED_LONG_LONG + +/* Define if you have the 'wchar_t' type. */ +#undef HAVE_WCHAR_T + +/* Define to 1 if you have the `wcslen' function. */ +#undef HAVE_WCSLEN + +/* Define if you have the 'wint_t' type. */ +#undef HAVE_WINT_T + +/* Define to 1 if you have the `__argz_count' function. */ +#undef HAVE___ARGZ_COUNT + +/* Define to 1 if you have the `__argz_next' function. */ +#undef HAVE___ARGZ_NEXT + +/* Define to 1 if you have the `__argz_stringify' function. */ +#undef HAVE___ARGZ_STRINGIFY + +/* Define to 1 if you have the `__fsetlocking' function. */ +#undef HAVE___FSETLOCKING + +/* Define as const if the declaration of iconv() needs const. */ +#undef ICONV_CONST + +/* Define if integer division by zero raises signal SIGFPE. */ +#undef INTDIV0_RAISES_SIGFPE + +/* Name of package */ +#undef PACKAGE + +/* Define to the address where bug reports for this package should be sent. */ +#undef PACKAGE_BUGREPORT + +/* Define to the full name of this package. */ +#undef PACKAGE_NAME + +/* Define to the full name and version of this package. */ +#undef PACKAGE_STRING + +/* Define to the one symbol short name of this package. */ +#undef PACKAGE_TARNAME + +/* Define to the version of this package. */ +#undef PACKAGE_VERSION + +/* Define if exists and defines unusable PRI* macros. */ +#undef PRI_MACROS_BROKEN + +/* The size of a `unsigned int', as computed by sizeof. */ +#undef SIZEOF_UNSIGNED_INT + +/* The size of a `unsigned long int', as computed by sizeof. */ +#undef SIZEOF_UNSIGNED_LONG_INT + +/* The size of a `unsigned short int', as computed by sizeof. */ +#undef SIZEOF_UNSIGNED_SHORT_INT + +/* Define as the maximum value of type 'size_t', if the system doesn't define + it. */ +#undef SIZE_MAX + +/* If using the C implementation of alloca, define if you know the + direction of stack growth for your system; otherwise it will be + automatically deduced at run-time. + STACK_DIRECTION > 0 => grows toward higher addresses + STACK_DIRECTION < 0 => grows toward lower addresses + STACK_DIRECTION = 0 => direction of growth unknown */ +#undef STACK_DIRECTION + +/* Define to 1 if you have the ANSI C header files. */ +#undef STDC_HEADERS + +/* Version number of package */ +#undef VERSION + +/* Define to empty if `const' does not conform to ANSI C. */ +#undef const + +/* Define to `__inline__' or `__inline' if that's what the C compiler + calls it, or to nothing if 'inline' is not supported under any name. */ +#ifndef __cplusplus +#undef inline +#endif + +/* Define to `long' if does not define. */ +#undef off_t + +/* Define as the type of the result of subtracting two pointers, if the system + doesn't define it. */ +#undef ptrdiff_t + +/* Define to empty if the C compiler doesn't support this keyword. */ +#undef signed + +/* Define to `unsigned' if does not define. */ +#undef size_t + +/* Define to unsigned long or unsigned long long if and + don't define. */ +#undef uintmax_t diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.dirs b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.dirs new file mode 100644 index 0000000000..7bc765edd6 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.dirs @@ -0,0 +1,11 @@ +var/spool/sms/queue1 +var/spool/sms/queue2 +var/spool/sms/queue3 +var/spool/sms/sent1 +var/spool/sms/sent2 +var/spool/sms/sent3 +var/spool/sms/failed1 +var/spool/sms/failed2 +var/spool/sms/failed3 +var/spool/sms/tmp +var/run/gsm-utils diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.postinst b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.postinst new file mode 100644 index 0000000000..cc623b611b --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.postinst @@ -0,0 +1,28 @@ +#!/bin/sh -e + +# create gsmsms group if necessary. +if ! grep -q ^gsmsms: /etc/group; then +# echo Adding system group: gsmsms. + addgroup gsmsms +fi + +# create gsmsms user if necessary. +if ! grep -q ^gsmsms: /etc/passwd; then +# echo Adding system user: gsmsms. + adduser --system --ingroup gsmsms \ + --no-create-home --home /var/spool/sms gsmsms +fi + +# allow gsmsms to use serial lines +if ! groups gsmsms | grep -q dialout ; then + adduser gsmsms dialout +fi + +# echo Updating spool directory structure: /var/spool/sms +chown -R gsmsms:gsmsms /var/spool/sms /var/run/gsm-utils +chmod 700 /var/spool/sms/* +chmod 750 /var/spool/sms +chmod 730 /var/spool/sms/queue* /var/spool/sms/tmp + +# Add the rest automatically.. +#DEBHELPER# diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.prerm b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.prerm new file mode 100644 index 0000000000..34c947e93e --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.prerm @@ -0,0 +1,7 @@ +#!/bin/sh -e + +deluser gsmsms || true +delgroup gsmsms || true + +# Add the rest automatically.. +#DEBHELPER# diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.undocumented b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.undocumented new file mode 100644 index 0000000000..62d096021d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib-1.10.debmg/debian/gsm-utils.undocumented @@ -0,0 +1,2 @@ +gsmsmsspool.1 +gsmsmsrequeue.8 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib.spec b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib.spec new file mode 100644 index 0000000000..c262954cc5 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib.spec @@ -0,0 +1,92 @@ +%define LIBVER 1.0.4 +Summary: Library to access GSM mobile phones through GSM modems +Name: gsmlib +Version: 1.10 +Release: 1 +Source: gsmlib-%{version}.tar.gz +Group: System Environment/Libraries +Copyright: GNU LIBRARY GENERAL PUBLIC LICENSE +URL: http://www.pxh.de/fs/gsmlib/ +Vendor: Peter Hofmann +Buildroot: /var/tmp/gsmlib-root + +%package devel +Summary: Development tools for programs which will use the gsmlib library. +Group: Development/Libraries +Requires: gsmlib + +%package ext +Summary: Extensions to gsmlib to support non-standard phone features. +Group: Development/Libraries +Requires: gsmlib + +%description +This distribution contains a library to access +GSM mobile phones through GSM modems. Features include: + * modification of phonebooks stored in the + mobile phone or on the SIM card + * reading and writing of SMS messages stored in + the mobile phone + * sending and reception of SMS messages +Additionally, some simple command line programs are +provided to use these functionalities. + +%description devel +The gsmlib-devel package includes the header files and static libraries +necessary for developing programs which use the gsmlib library. + +%description ext +The extension package of gsmlib contains programs, libraries, and +documentation to support non-standard features of GSM phones. The +following phones/phone types are currently supported: + * Siemens GSM phones + +%prep +%setup + +%build +CXXFLAGS="$RPM_OPT_FLAGS" ./configure --prefix=/usr +make + +%install +make DESTDIR="$RPM_BUILD_ROOT" install + +%post -p /sbin/ldconfig + +%postun -p /sbin/ldconfig + +%clean +rm -rf $RPM_BUILD_ROOT + +%files +%defattr(-,root,root) +/usr/lib/libgsmme.so +/usr/lib/libgsmme.so.%{LIBVER} +/usr/bin/gsmsmsstore +/usr/bin/gsmctl +/usr/bin/gsmsmsd +/usr/bin/gsmpb +/usr/bin/gsmsendsms +/usr/man/man1/gsmctl.1.gz +/usr/man/man7/gsminfo.7.gz +/usr/man/man1/gsmpb.1.gz +/usr/man/man1/gsmsendsms.1.gz +/usr/man/man8/gsmsmsd.8.gz +/usr/man/man1/gsmsmsstore.1.gz +/usr/share/locale/de/LC_MESSAGES/gsmlib.mo + +%doc README INSTALL ABOUT-NLS AUTHORS COPYING NEWS TODO +%doc doc/README.NLS doc/README.developers doc/FAQ ChangeLog + +%files devel +%defattr(-,root,root) +/usr/lib/libgsmme.a +/usr/include/gsmlib + +%files ext +/usr/bin/gsmsiectl +/usr/bin/gsmsiexfer +/usr/lib/libgsmext.so +/usr/lib/libgsmext.so.%{LIBVER} + +%doc ext/README.sieme diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/Makefile.am b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/Makefile.am new file mode 100644 index 0000000000..12d6948c52 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/Makefile.am @@ -0,0 +1,38 @@ +## Process this file with automake to produce Makefile.in +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: GSM library Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 5.5.1999 +# ************************************************************************* + +INCLUDES = -I.. + +lib_LTLIBRARIES = libgsmme.la + +libgsmme_la_SOURCES = gsm_phonebook.cc gsm_util.cc gsm_unix_serial.cc \ + gsm_me_ta.cc gsm_at.cc gsm_error.cc gsm_parser.cc \ + gsm_sms.cc gsm_sms_codec.cc gsm_sms_store.cc \ + gsm_event.cc gsm_sorted_phonebook.cc \ + gsm_sorted_sms_store.cc gsm_nls.cc \ + gsm_sorted_phonebook_base.cc gsm_cb.cc + +gsmincludedir = $(includedir)/gsmlib + +gsminclude_HEADERS = gsm_at.h gsm_parser.h gsm_sms.h gsm_unix_serial.h \ + gsm_error.h gsm_phonebook.h gsm_sms_codec.h \ + gsm_util.h gsm_me_ta.h gsm_port.h gsm_sms_store.h \ + gsm_event.h gsm_sorted_phonebook.h \ + gsm_sorted_sms_store.h gsm_map_key.h \ + gsm_sorted_phonebook_base.h gsm_cb.h + +noinst_HEADERS = gsm_nls.h gsm_sysdep.h + +libgsmme_la_LDFLAGS = -version-info $(GSM_VERSION) + +EXTRA_DIST = gsm_win32_serial.h gsm_win32_serial.cc diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/Makefile.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/Makefile.in new file mode 100644 index 0000000000..5e1f2477cb --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/Makefile.in @@ -0,0 +1,461 @@ +# Makefile.in generated by automake 1.6.3 from Makefile.am. +# @configure_input@ + +# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002 +# Free Software Foundation, Inc. +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +@SET_MAKE@ + +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: GSM library Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 5.5.1999 +# ************************************************************************* +SHELL = @SHELL@ + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ + +bindir = @bindir@ +sbindir = @sbindir@ +libexecdir = @libexecdir@ +datadir = @datadir@ +sysconfdir = @sysconfdir@ +sharedstatedir = @sharedstatedir@ +localstatedir = @localstatedir@ +libdir = @libdir@ +infodir = @infodir@ +mandir = @mandir@ +includedir = @includedir@ +oldincludedir = /usr/include +pkgdatadir = $(datadir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ +top_builddir = .. + +ACLOCAL = @ACLOCAL@ +AUTOCONF = @AUTOCONF@ +AUTOMAKE = @AUTOMAKE@ +AUTOHEADER = @AUTOHEADER@ + +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd +INSTALL = @INSTALL@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_DATA = @INSTALL_DATA@ +install_sh_DATA = $(install_sh) -c -m 644 +install_sh_PROGRAM = $(install_sh) -c +install_sh_SCRIPT = $(install_sh) -c +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +INSTALL_HEADER = $(INSTALL_DATA) +transform = @program_transform_name@ +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +host_alias = @host_alias@ +host_triplet = @host@ + +EXEEXT = @EXEEXT@ +OBJEXT = @OBJEXT@ +PATH_SEPARATOR = @PATH_SEPARATOR@ +AMTAR = @AMTAR@ +AS = @AS@ +AWK = @AWK@ +BUILD_INCLUDED_LIBINTL = @BUILD_INCLUDED_LIBINTL@ +CATOBJEXT = @CATOBJEXT@ +CC = @CC@ +CPP = @CPP@ +CXX = @CXX@ +DATADIRNAME = @DATADIRNAME@ +DEPDIR = @DEPDIR@ +DLLTOOL = @DLLTOOL@ +ECHO = @ECHO@ +GENCAT = @GENCAT@ +GLIBC21 = @GLIBC21@ +GMSGFMT = @GMSGFMT@ +GSM_VERSION = @GSM_VERSION@ +HAVE_LIB = @HAVE_LIB@ +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ +INSTOBJEXT = @INSTOBJEXT@ +INTLBISON = @INTLBISON@ +INTLLIBS = @INTLLIBS@ +INTLOBJS = @INTLOBJS@ +INTL_LIBTOOL_SUFFIX_PREFIX = @INTL_LIBTOOL_SUFFIX_PREFIX@ +LIB = @LIB@ +LIBICONV = @LIBICONV@ +LIBINTL = @LIBINTL@ +LIBTOOL = @LIBTOOL@ +LN_S = @LN_S@ +LTLIB = @LTLIB@ +LTLIBICONV = @LTLIBICONV@ +LTLIBINTL = @LTLIBINTL@ +MKINSTALLDIRS = @MKINSTALLDIRS@ +OBJDUMP = @OBJDUMP@ +PACKAGE = @PACKAGE@ +POSUB = @POSUB@ +RANLIB = @RANLIB@ +STRIP = @STRIP@ +USE_INCLUDED_LIBINTL = @USE_INCLUDED_LIBINTL@ +USE_NLS = @USE_NLS@ +VERSION = @VERSION@ +am__include = @am__include@ +am__quote = @am__quote@ +install_sh = @install_sh@ + +INCLUDES = -I.. + +lib_LTLIBRARIES = libgsmme.la + +libgsmme_la_SOURCES = gsm_phonebook.cc gsm_util.cc gsm_unix_serial.cc \ + gsm_me_ta.cc gsm_at.cc gsm_error.cc gsm_parser.cc \ + gsm_sms.cc gsm_sms_codec.cc gsm_sms_store.cc \ + gsm_event.cc gsm_sorted_phonebook.cc \ + gsm_sorted_sms_store.cc gsm_nls.cc \ + gsm_sorted_phonebook_base.cc gsm_cb.cc + + +gsmincludedir = $(includedir)/gsmlib + +gsminclude_HEADERS = gsm_at.h gsm_parser.h gsm_sms.h gsm_unix_serial.h \ + gsm_error.h gsm_phonebook.h gsm_sms_codec.h \ + gsm_util.h gsm_me_ta.h gsm_port.h gsm_sms_store.h \ + gsm_event.h gsm_sorted_phonebook.h \ + gsm_sorted_sms_store.h gsm_map_key.h \ + gsm_sorted_phonebook_base.h gsm_cb.h + + +noinst_HEADERS = gsm_nls.h gsm_sysdep.h + +libgsmme_la_LDFLAGS = -version-info $(GSM_VERSION) + +EXTRA_DIST = gsm_win32_serial.h gsm_win32_serial.cc +subdir = gsmlib +mkinstalldirs = $(SHELL) $(top_srcdir)/scripts/mkinstalldirs +CONFIG_HEADER = $(top_builddir)/gsm_config.h +CONFIG_CLEAN_FILES = +LTLIBRARIES = $(lib_LTLIBRARIES) + +libgsmme_la_LIBADD = +am_libgsmme_la_OBJECTS = gsm_phonebook.lo gsm_util.lo gsm_unix_serial.lo \ + gsm_me_ta.lo gsm_at.lo gsm_error.lo gsm_parser.lo gsm_sms.lo \ + gsm_sms_codec.lo gsm_sms_store.lo gsm_event.lo \ + gsm_sorted_phonebook.lo gsm_sorted_sms_store.lo gsm_nls.lo \ + gsm_sorted_phonebook_base.lo gsm_cb.lo +libgsmme_la_OBJECTS = $(am_libgsmme_la_OBJECTS) + +DEFS = @DEFS@ +DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) +CPPFLAGS = @CPPFLAGS@ +LDFLAGS = @LDFLAGS@ +LIBS = @LIBS@ +depcomp = $(SHELL) $(top_srcdir)/scripts/depcomp +am__depfiles_maybe = depfiles +@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/gsm_at.Plo ./$(DEPDIR)/gsm_cb.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_error.Plo ./$(DEPDIR)/gsm_event.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_me_ta.Plo ./$(DEPDIR)/gsm_nls.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_parser.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_phonebook.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_sms.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_sms_codec.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_sms_store.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_sorted_phonebook.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_sorted_phonebook_base.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_sorted_sms_store.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_unix_serial.Plo \ +@AMDEP_TRUE@ ./$(DEPDIR)/gsm_util.Plo +CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ + $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) +LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ + $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ + $(AM_CXXFLAGS) $(CXXFLAGS) +CXXLD = $(CXX) +CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ + $(AM_LDFLAGS) $(LDFLAGS) -o $@ +CXXFLAGS = @CXXFLAGS@ +DIST_SOURCES = $(libgsmme_la_SOURCES) +HEADERS = $(gsminclude_HEADERS) $(noinst_HEADERS) + +DIST_COMMON = $(gsminclude_HEADERS) $(noinst_HEADERS) Makefile.am \ + Makefile.in +SOURCES = $(libgsmme_la_SOURCES) + +all: all-am + +.SUFFIXES: +.SUFFIXES: .cc .lo .o .obj +$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4) + cd $(top_srcdir) && \ + $(AUTOMAKE) --gnu gsmlib/Makefile +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe) +libLTLIBRARIES_INSTALL = $(INSTALL) +install-libLTLIBRARIES: $(lib_LTLIBRARIES) + @$(NORMAL_INSTALL) + $(mkinstalldirs) $(DESTDIR)$(libdir) + @list='$(lib_LTLIBRARIES)'; for p in $$list; do \ + if test -f $$p; then \ + f="`echo $$p | sed -e 's|^.*/||'`"; \ + echo " $(LIBTOOL) --mode=install $(libLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) $$p $(DESTDIR)$(libdir)/$$f"; \ + $(LIBTOOL) --mode=install $(libLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) $$p $(DESTDIR)$(libdir)/$$f; \ + else :; fi; \ + done + +uninstall-libLTLIBRARIES: + @$(NORMAL_UNINSTALL) + @list='$(lib_LTLIBRARIES)'; for p in $$list; do \ + p="`echo $$p | sed -e 's|^.*/||'`"; \ + echo " $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(libdir)/$$p"; \ + $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(libdir)/$$p; \ + done + +clean-libLTLIBRARIES: + -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) + @list='$(lib_LTLIBRARIES)'; for p in $$list; do \ + dir="`echo $$p | sed -e 's|/[^/]*$$||'`"; \ + test -z "$dir" && dir=.; \ + echo "rm -f \"$${dir}/so_locations\""; \ + rm -f "$${dir}/so_locations"; \ + done +libgsmme.la: $(libgsmme_la_OBJECTS) $(libgsmme_la_DEPENDENCIES) + $(CXXLINK) -rpath $(libdir) $(libgsmme_la_LDFLAGS) $(libgsmme_la_OBJECTS) $(libgsmme_la_LIBADD) $(LIBS) + +mostlyclean-compile: + -rm -f *.$(OBJEXT) core *.core + +distclean-compile: + -rm -f *.tab.c + +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_at.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_cb.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_error.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_event.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_me_ta.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_nls.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_parser.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_phonebook.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_sms.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_sms_codec.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_sms_store.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_sorted_phonebook.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_sorted_phonebook_base.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_sorted_sms_store.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_unix_serial.Plo@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gsm_util.Plo@am__quote@ + +distclean-depend: + -rm -rf ./$(DEPDIR) + +.cc.o: +@AMDEP_TRUE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(CXXCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$< + +.cc.obj: +@AMDEP_TRUE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(CXXCOMPILE) -c -o $@ `cygpath -w $<` + +.cc.lo: +@AMDEP_TRUE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(LTCXXCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$< +CXXDEPMODE = @CXXDEPMODE@ + +mostlyclean-libtool: + -rm -f *.lo + +clean-libtool: + -rm -rf .libs _libs + +distclean-libtool: + -rm -f libtool +uninstall-info-am: +gsmincludeHEADERS_INSTALL = $(INSTALL_HEADER) +install-gsmincludeHEADERS: $(gsminclude_HEADERS) + @$(NORMAL_INSTALL) + $(mkinstalldirs) $(DESTDIR)$(gsmincludedir) + @list='$(gsminclude_HEADERS)'; for p in $$list; do \ + if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ + f="`echo $$p | sed -e 's|^.*/||'`"; \ + echo " $(gsmincludeHEADERS_INSTALL) $$d$$p $(DESTDIR)$(gsmincludedir)/$$f"; \ + $(gsmincludeHEADERS_INSTALL) $$d$$p $(DESTDIR)$(gsmincludedir)/$$f; \ + done + +uninstall-gsmincludeHEADERS: + @$(NORMAL_UNINSTALL) + @list='$(gsminclude_HEADERS)'; for p in $$list; do \ + f="`echo $$p | sed -e 's|^.*/||'`"; \ + echo " rm -f $(DESTDIR)$(gsmincludedir)/$$f"; \ + rm -f $(DESTDIR)$(gsmincludedir)/$$f; \ + done + +ETAGS = etags +ETAGSFLAGS = + +tags: TAGS + +ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | \ + $(AWK) ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + mkid -fID $$unique + +TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ + $(TAGS_FILES) $(LISP) + tags=; \ + here=`pwd`; \ + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | \ + $(AWK) ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + test -z "$(ETAGS_ARGS)$$tags$$unique" \ + || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ + $$tags $$unique + +GTAGS: + here=`$(am__cd) $(top_builddir) && pwd` \ + && cd $(top_srcdir) \ + && gtags -i $(GTAGS_ARGS) $$here + +distclean-tags: + -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) + +top_distdir = .. +distdir = $(top_distdir)/$(PACKAGE)-$(VERSION) + +distdir: $(DISTFILES) + @list='$(DISTFILES)'; for file in $$list; do \ + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ + dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \ + if test "$$dir" != "$$file" && test "$$dir" != "."; then \ + dir="/$$dir"; \ + $(mkinstalldirs) "$(distdir)$$dir"; \ + else \ + dir=''; \ + fi; \ + if test -d $$d/$$file; then \ + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ + cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ + fi; \ + cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ + else \ + test -f $(distdir)/$$file \ + || cp -p $$d/$$file $(distdir)/$$file \ + || exit 1; \ + fi; \ + done +check-am: all-am +check: check-am +all-am: Makefile $(LTLIBRARIES) $(HEADERS) + +installdirs: + $(mkinstalldirs) $(DESTDIR)$(libdir) $(DESTDIR)$(gsmincludedir) + +install: install-am +install-exec: install-exec-am +install-data: install-data-am +uninstall: uninstall-am + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am + +installcheck: installcheck-am +install-strip: + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + INSTALL_STRIP_FLAG=-s \ + `test -z '$(STRIP)' || \ + echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -rm -f Makefile $(CONFIG_CLEAN_FILES) + +maintainer-clean-generic: + @echo "This command is intended for maintainers to use" + @echo "it deletes files that may require special tools to rebuild." +clean: clean-am + +clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ + mostlyclean-am + +distclean: distclean-am + +distclean-am: clean-am distclean-compile distclean-depend \ + distclean-generic distclean-libtool distclean-tags + +dvi: dvi-am + +dvi-am: + +info: info-am + +info-am: + +install-data-am: install-gsmincludeHEADERS + +install-exec-am: install-libLTLIBRARIES + +install-info: install-info-am + +install-man: + +installcheck-am: + +maintainer-clean: maintainer-clean-am + +maintainer-clean-am: distclean-am maintainer-clean-generic + +mostlyclean: mostlyclean-am + +mostlyclean-am: mostlyclean-compile mostlyclean-generic \ + mostlyclean-libtool + +uninstall-am: uninstall-gsmincludeHEADERS uninstall-info-am \ + uninstall-libLTLIBRARIES + +.PHONY: GTAGS all all-am check check-am clean clean-generic \ + clean-libLTLIBRARIES clean-libtool distclean distclean-compile \ + distclean-depend distclean-generic distclean-libtool \ + distclean-tags distdir dvi dvi-am info info-am install \ + install-am install-data install-data-am install-exec \ + install-exec-am install-gsmincludeHEADERS install-info \ + install-info-am install-libLTLIBRARIES install-man \ + install-strip installcheck installcheck-am installdirs \ + maintainer-clean maintainer-clean-generic mostlyclean \ + mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ + tags uninstall uninstall-am uninstall-gsmincludeHEADERS \ + uninstall-info-am uninstall-libLTLIBRARIES + +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_at.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_at.cc new file mode 100644 index 0000000000..b571d5d93b --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_at.cc @@ -0,0 +1,428 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_at.cc +// * +// * Purpose: Utility classes for AT command sequence handling +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 3.5.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +// GsmAt members + +bool GsmAt::matchResponse(string answer, string responseToMatch) +{ + if (answer.substr(0, responseToMatch.length()) == responseToMatch) + return true; + else + // some TAs omit the ':' at the end of the response + if (_meTa.getCapabilities()._omitsColon && + responseToMatch[responseToMatch.length() - 1] == ':' && + answer.substr(0, responseToMatch.length() - 1) == + responseToMatch.substr(0, responseToMatch.length() - 1)) + return true; + return false; +} + +string GsmAt::cutResponse(string answer, string responseToMatch) +{ + if (answer.substr(0, responseToMatch.length()) == responseToMatch) + return normalize(answer.substr(responseToMatch.length(), + answer.length() - + responseToMatch.length())); + else + // some TAs omit the ':' at the end of the response + if (_meTa.getCapabilities()._omitsColon && + responseToMatch[responseToMatch.length() - 1] == ':' && + answer.substr(0, responseToMatch.length() - 1) == + responseToMatch.substr(0, responseToMatch.length() - 1)) + return normalize(answer.substr(responseToMatch.length() - 1, + answer.length() - + responseToMatch.length() + 1)); + assert(0); + return ""; +} + +void GsmAt::throwCmeException(string s) throw(GsmException) +{ + if (matchResponse(s, "ERROR")) + throw GsmException(_("unspecified ME/TA error"), ChatError); + + bool meError = matchResponse(s, "+CME ERROR:"); + if (meError) + s = cutResponse(s, "+CME ERROR:"); + else + s = cutResponse(s, "+CMS ERROR:"); + istrstream is(s.c_str()); + int error; + is >> error; + throw GsmException(_("ME/TA error '") + + (meError ? getMEErrorText(error) : + getSMSErrorText(error)) + + "' " + + stringPrintf(_("(code %s)"), s.c_str()), + ChatError, error); +} + +GsmAt::GsmAt(MeTa &meTa) : + _meTa(meTa), _port(meTa.getPort()), _eventHandler(NULL) +{ +} + +string GsmAt::chat(string atCommand, string response, + bool ignoreErrors, bool acceptEmptyResponse) + throw(GsmException) +{ + string dummy; + return chat(atCommand, response, dummy, ignoreErrors, false, + acceptEmptyResponse); +} + +string GsmAt::chat(string atCommand, string response, string &pdu, + bool ignoreErrors, bool expectPdu, + bool acceptEmptyResponse) throw(GsmException) +{ + string s; + bool gotOk = false; // special handling for empty SMS entries + + // send AT command + putLine("AT" + atCommand); + // and gobble up CR/LF (and possibly echoed characters if echo can't be + // switched off) + do + { + s = normalize(getLine()); + } + while (s.length() == 0 || s == "AT" + atCommand); + + // handle errors + if (matchResponse(s, "+CME ERROR:") || matchResponse(s, "+CMS ERROR:")) + if (ignoreErrors) + return ""; + else + throwCmeException(s); + if (matchResponse(s, "ERROR")) + if (ignoreErrors) + return ""; + else + throw GsmException(_("ME/TA error '' (code not known)"), + ChatError, -1); + + // return if response is "OK" and caller says this is OK + if (acceptEmptyResponse && s == "OK") + return ""; + + // handle PDU if one is expected + if (expectPdu) + { + string ps; + do + { + ps = normalize(getLine()); + } + while (ps.length() == 0 && ps != "OK"); + if (ps == "OK") + gotOk = true; + else + { + pdu = ps; + // remove trailing zero added by some devices (e.g. Falcom A2-1) + if (pdu.length() > 0 && pdu[pdu.length() - 1] == 0) + pdu.erase(pdu.length() - 1); + } + } + + // handle expected response + if (response.length() == 0) // no response expected + { + if (s == "OK") return ""; + // else fall through to error + } + else + { + string result; + // some TA/TEs don't prefix their response with the response string + // as proscribed by the standard: just handle either case + if (matchResponse(s, response)) + result = cutResponse(s, response); + else + result = s; + + if (gotOk) + return result; + else + { + // get the final "OK" + do + { + s = normalize(getLine()); + } + while (s.length() == 0); + + if (s == "OK") return result; + // else fall through to error + } + } + throw GsmException( + stringPrintf(_("unexpected response '%s' when sending 'AT%s'"), + s.c_str(), atCommand.c_str()), + ChatError); +} + +vector GsmAt::chatv(string atCommand, string response, + bool ignoreErrors) throw(GsmException) +{ + string s; + vector result; + + // send AT command + putLine("AT" + atCommand); + // and gobble up CR/LF (and possibly echoed characters if echo can't be + // switched off) + do + { + s = normalize(getLine()); + } + while (s.length() == 0 || s == "AT" + atCommand); + + // handle errors + if (matchResponse(s, "+CME ERROR:") || matchResponse(s, "+CMS ERROR:")) + if (ignoreErrors) + return result; + else + throwCmeException(s); + if (matchResponse(s, "ERROR")) + if (ignoreErrors) + return result; + else + throw GsmException(_("ME/TA error '' (code not known)"), + ChatError, -1); + + // push all lines that are not empty + // cut response prefix if it is there + // stop when an OK line is read + while (1) + { + if (s == "OK") + return result; + // some TA/TEs don't prefix their response with the response string + // as proscribed by the standard: just handle either case + if (response.length() != 0 && matchResponse(s, response)) + result.push_back(cutResponse(s, response)); + else + result.push_back(s); + // get next line + do + { + s = normalize(getLine()); + } + while (s.length() == 0); + reportProgress(); + } + + // never reached + assert(0); + return result; +} + +string GsmAt::normalize(string s) +{ + size_t start = 0, end = s.length(); + bool changed = true; + + while (start < end && changed) + { + changed = false; + if (isspace(s[start])) + { + ++start; + changed = true; + } + else + if (isspace(s[end - 1])) + { + --end; + changed = true; + } + } + return s.substr(start, end - start); +} + +string GsmAt::sendPdu(string atCommand, string response, string pdu, + bool acceptEmptyResponse) throw(GsmException) +{ + string s; + bool errorCondition; + bool retry = false; + int tries = 5; // How many error conditions do we accept + + int c; + do + { + errorCondition = false; + putLine("AT" + atCommand); + do + { + retry = false; + try + { + do + { + // read first of two bytes "> " + c = readByte(); + } + // there have been reports that some phones give spurious CRs + // LF separates CDSI messages if there are more than one + while (c == CR || c == LF); + } + catch (GsmException &e) + { + c = '-'; + errorCondition = true; // TA does not expect PDU anymore, retry + } + + if (c == '+' || c == 'E') // error or unsolicited result code + { + _port->putBack(c); + s = normalize(getLine()); + errorCondition = (s != ""); + + retry = ! errorCondition; + } + } + while (retry); + } + while (errorCondition && tries--); + + if (! errorCondition) + { + + if (c != '>' || readByte() != ' ') + throw GsmException(_("unexpected character in PDU handshake"), + ChatError); + + putLine(pdu + "\032", false); // write pdu followed by CTRL-Z + + // some phones (Ericcson T68, T39) send spurious zero characters after + // accepting the PDU + c = readByte(); + if (c != 0) + _port->putBack(c); + + // loop while empty lines (maybe with a zero, Ericsson T39m) + // or an echo of the pdu (with or without CTRL-Z) + // is read + do + { + s = normalize(getLine()); + } + while (s.length() == 0 || s == pdu || s == (pdu + "\032") || + (s.length() == 1 && s[0] == 0)); + } + + // handle errors + if (matchResponse(s, "+CME ERROR:") || matchResponse(s, "+CMS ERROR:")) + throwCmeException(s); + if (matchResponse(s, "ERROR")) + throw GsmException(_("ME/TA error '' (code not known)"), + ChatError, -1); + + // return if response is "OK" and caller says this is OK + if (acceptEmptyResponse && s == "OK") + return ""; + + if (matchResponse(s, response)) + { + string result = cutResponse(s, response); + // get the final "OK" + do + { + s = normalize(getLine()); + } + while (s.length() == 0); + + if (s == "OK") return result; + // else fall through to error + } + throw GsmException( + stringPrintf(_("unexpected response '%s' when sending 'AT%s'"), + s.c_str(), atCommand.c_str()), + ChatError); +} + +string GsmAt::getLine() throw(GsmException) +{ + if (_eventHandler == (GsmEvent*)NULL) + return _port->getLine(); + else + { + bool eventOccurred; + string result; + do + { + eventOccurred = false; + result = _port->getLine(); + string s = normalize(result); + if (matchResponse(s, "+CMT:") || + matchResponse(s, "+CBM:") || + matchResponse(s, "+CDS:") || + matchResponse(s, "+CMTI:") || + matchResponse(s, "+CBMI:") || + matchResponse(s, "+CDSI:") || + matchResponse(s, "RING") || + matchResponse(s, "NO CARRIER") || + // hack: the +CLIP? sequence returns +CLIP: n,m + // which is NOT an unsolicited result code + (matchResponse(s, "+CLIP:") && s.length() > 10)) + { + _eventHandler->dispatch(s, *this); + eventOccurred = true; + } + } + while (eventOccurred); + return result; + } +} + +void GsmAt::putLine(string line, + bool carriageReturn) throw(GsmException) +{ + _port->putLine(line, carriageReturn); + // remove empty echo line + if (carriageReturn) + getLine(); +} + +bool GsmAt::wait(GsmTime timeout) throw(GsmException) +{ + return _port->wait(timeout); +} + +int GsmAt::readByte() throw(GsmException) +{ + return _port->readByte(); +} + +GsmEvent *GsmAt::setEventHandler(GsmEvent *newHandler) +{ + GsmEvent *result = _eventHandler; + _eventHandler = newHandler; + return result; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_at.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_at.h new file mode 100644 index 0000000000..96c3359425 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_at.h @@ -0,0 +1,104 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_at.h +// * +// * Purpose: Utility classes for AT command sequence handling +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 3.5.1999 +// ************************************************************************* + +#ifndef GSM_AT_H +#define GSM_AT_H + +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + // forward declarations + + class GsmEvent; + class MeTa; + + // utiliy class to handle AT sequences + + class GsmAt : public RefBase + { + protected: + MeTa &_meTa; + Ref _port; + GsmEvent *_eventHandler; + + // return true if response matches + bool matchResponse(string answer, string responseToMatch); + + // cut response and normalize + string cutResponse(string answer, string responseToMatch); + + // parse CME error contained in string and throw MeTaException + void throwCmeException(string s) throw(GsmException); + + public: + GsmAt(MeTa &meTa); + + // return MeTa object for this AT object + MeTa &getMeTa() {return _meTa;} + + // the following sequence functions recognize asynchronous messages + // from the TA and return the appropriate event + + // send AT command, wait for response response, returns response line + // without response match + // if response == "" only an OK is expected + // white space at beginning or end are removed + // +CME ERROR or ERROR raises exception (if ignoreErrors == true) + // additionally, accept empty responses (just an OK) + // if acceptEmptyResponse == true + // in this case an empty string is returned + string chat(string atCommand = "", + string response = "", + bool ignoreErrors = false, + bool acceptEmptyResponse = false) throw(GsmException); + + // same as chat() above but also get pdu if expectPdu == true + string chat(string atCommand, + string response, + string &pdu, + bool ignoreErrors = false, + bool expectPdu = true, + bool acceptEmptyResponse = false) throw(GsmException); + + // same as above, but expect several response lines + vector chatv(string atCommand = "", + string response = "", + bool ignoreErrors = false) + throw(GsmException); + + // removes whitespace at beginning and end of string + string normalize(string s); + + // send pdu (wait for and send + // at the end + // return text after response + string sendPdu(string atCommand, string response, string pdu, + bool acceptEmptyResponse = false) throw(GsmException); + + // functions from class Port + string getLine() throw(GsmException); + void putLine(string line, + bool carriageReturn = true) throw(GsmException); + bool wait(GsmTime timeout) throw(GsmException); + int readByte() throw(GsmException); + + // set event handler class, return old one + GsmEvent *setEventHandler(GsmEvent *newHandler); + }; +}; + +#endif // GSM_AT_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_cb.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_cb.cc new file mode 100644 index 0000000000..37c0e4aae7 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_cb.cc @@ -0,0 +1,176 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_cb.cc +// * +// * Purpose: Cell Broadcast Message Implementation +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 4.8.2001 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +// local constants + +static const string dashes = +"---------------------------------------------------------------------------"; + +// CBDataCodingScheme members + +CBDataCodingScheme::CBDataCodingScheme(unsigned char dcs) : _dcs(dcs) +{ + if ((_dcs & 0xf0) <= 0x30) // bits 7..4 in the range 0000..0011 + if ((_dcs & 0x30) == 0) + _language = (Language)_dcs; + else + _language = Unknown; +} + +string CBDataCodingScheme::toString() const +{ + string result; + if (compressed()) result += _("compressed "); + switch (getLanguage()) + { + case German: + result += _("German"); + break; + case English: + result += _("English"); + break; + case Italian: + result += _("Italian"); + break; + case French: + result += _("French"); + break; + case Spanish: + result += _("Spanish"); + break; + case Dutch: + result += _("Dutch"); + break; + case Swedish: + result += _("Swedish"); + break; + case Danish: + result += _("Danish"); + break; + case Portuguese: + result += _("Portuguese"); + break; + case Finnish: + result += _("Finnish"); + break; + case Norwegian: + result += _("Norwegian"); + break; + case Greek: + result += _("Greek"); + break; + case Turkish: + result += _("Turkish"); + break; + } + result += " "; + switch (getAlphabet()) + { + case DCS_DEFAULT_ALPHABET: + result += _("default alphabet"); + break; + case DCS_EIGHT_BIT_ALPHABET: + result += _("8-bit alphabet"); + break; + case DCS_SIXTEEN_BIT_ALPHABET: + result += _("16-bit alphabet"); + break; + case DCS_RESERVED_ALPHABET: + result += _("reserved alphabet"); + break; + } + return result; +} + +// CBMessage members + +CBMessage::CBMessage(string pdu) throw(GsmException) +{ + SMSDecoder d(pdu); + _messageCode = d.getInteger(6) << 4; + _geographicalScope = (GeographicalScope)d.get2Bits(); + _updateNumber = d.getInteger(4); + _messageCode |= d.getInteger(4); + _messageIdentifier = d.getInteger(8) << 8; + _messageIdentifier |= d.getInteger(8); + _dataCodingScheme = CBDataCodingScheme(d.getOctet()); + _totalPageNumber = d.getInteger(4); + _currentPageNumber = d.getInteger(4); + + // the values 82 and 93 come from ETSI GSM 03.41, section 9.3 + d.markSeptet(); + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + { + _data = d.getString(93); + _data = gsmToLatin1(_data); + } + else + { + unsigned char *s = + (unsigned char*)alloca(sizeof(unsigned char) * 82); + d.getOctets(s, 82); + _data.assign((char*)s, (unsigned int)82); + } +} + +string CBMessage::toString() const +{ + ostrstream os; + os << dashes << endl + << _("Message type: CB") << endl + << _("Geographical scope: "); + switch (_geographicalScope) + { + case CellWide: + os << "Cell wide" << endl; + break; + case PLMNWide: + os << "PLMN wide" << endl; + break; + case LocationAreaWide: + os << "Location area wide" << endl; + break; + case CellWide2: + os << "Cell wide (2)" << endl; + break; + } + // remove trailing \r characters for output + string data = _data; + string::iterator i; + for (i = data.end(); i > data.begin() && *(i - 1) == '\r'; + --i); + data.erase(i, data.end()); + + os << _("Message Code: ") << _messageCode << endl + << _("Update Number: ") << _updateNumber << endl + << _("Message Identifer: ") << _messageIdentifier << endl + << _("Data coding scheme: ") << _dataCodingScheme.toString() << endl + << _("Total page number: ") << _totalPageNumber << endl + << _("Current page number: ") << _currentPageNumber << endl + << _("Data: '") << data << "'" << endl + << dashes << endl << endl << ends; + char *ss = os.str(); + string result(ss); + delete[] ss; + return result; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_cb.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_cb.h new file mode 100644 index 0000000000..3457c8105c --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_cb.h @@ -0,0 +1,106 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_cb.h +// * +// * Purpose: Cell Broadcast Message Implementation +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 4.8.2001 +// ************************************************************************* + +#ifndef GSM_CB_H +#define GSM_CB_H + +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + // representation of DataCodingScheme + // The data coding scheme is described in detail in ETSI GSM 03.38, section 5 + // This class reuses the DCS_* constants from DataCodingScheme in + // gsm_sms_codec + + class CBDataCodingScheme + { + public: + enum Language {German = 0, English = 1, Italian = 2, French = 3, + Spanish = 4, Dutch = 5, Swedish = 6, Danish = 7, + Portuguese = 8, Finnish = 9, Norwegian = 10, Greek = 11, + Turkish = 12, Unknown = 1000}; + + private: + unsigned char _dcs; + Language _language; + + public: + // initialize with data coding scheme octet + CBDataCodingScheme(unsigned char dcs); + + // default constructor + CBDataCodingScheme() : _dcs(DCS_DEFAULT_ALPHABET), _language(English) {} + + // return language of CBM + Language getLanguage() const {return _language;} + + // return compression level (if language == Unknown) + bool compressed() const {return (_dcs & DCS_COMPRESSED) == DCS_COMPRESSED;} + + // return type of alphabet used + // (DCS_DEFAULT_ALPHABET, DCS_EIGHT_BIT_ALPHABET, DCS_SIXTEEN_BIT_ALPHABET, + // DCS_RESERVED_ALPHABET) + unsigned char getAlphabet() const + {return _language == Unknown ? _dcs & (3 << 2) : DCS_DEFAULT_ALPHABET;} + + // create textual representation of CB data coding scheme + string toString() const; + }; + + // representation of Cell Broadcast message (CBM) + // The CBM format is described in detail in ETSI GSM 03.41, section 9.3 + + class CBMessage : public RefBase + { + public: + enum GeographicalScope {CellWide, PLMNWide, LocationAreaWide, + CellWide2}; + + private: + // fields parsed from the CB TPDU + GeographicalScope _geographicalScope; + int _messageCode; + int _updateNumber; + int _messageIdentifier; + CBDataCodingScheme _dataCodingScheme; + int _totalPageNumber; + int _currentPageNumber; + string _data; + + public: + // constructor with given pdu + CBMessage(string pdu) throw(GsmException); + + // accessor functions + GeographicalScope getGeographicalScope() const {return _geographicalScope;} + int getMessageCode() const {return _messageCode;} + int getUpdateNumber() const {return _updateNumber;} + int getMessageIdentifier() const {return _messageIdentifier;} + CBDataCodingScheme getDataCodingScheme() const {return _dataCodingScheme;} + int getTotalPageNumber() const {return _totalPageNumber;} + int getCurrentPageNumber() const {return _currentPageNumber;} + string getData() const {return _data;} + + // create textual representation of CBM + string toString() const; + }; + + // some useful typdefs + typedef Ref CBMessageRef; +}; + +#endif // GSM_CB_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_error.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_error.cc new file mode 100644 index 0000000000..2cf9179ede --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_error.cc @@ -0,0 +1,424 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_error.cc +// * +// * Purpose: Error codes and error handling functions +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 11.5.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +string gsmlib::getMEErrorText(const int errorCode) throw(GsmException) +{ + switch (errorCode) + { + case ME_PHONE_FAILURE: + return _("phone failure"); + break; + case ME_NO_CONNECTION_TO_PHONE: + return _("no connection to phone"); + break; + case ME_PHONE_ADAPTOR_LINK_RESERVED: + return _("phone adaptor link reserved"); + break; + case ME_OPERATION_NOT_ALLOWED: + return _("operation not allowed"); + break; + case ME_OPERATION_NOT_SUPPORTED: + return _("operation not supported"); + break; + case ME_PH_SIM_PIN_REQUIRED: + return _("ph SIM PIN required"); + break; + case ME_SIM_NOT_INSERTED: + return _("SIM not inserted"); + break; + case ME_SIM_PIN_REQUIRED: + return _("SIM PIN required"); + break; + case ME_SIM_PUK_REQUIRED: + return _("SIM PUK required"); + break; + case ME_SIM_FAILURE: + return _("SIM failure"); + break; + case ME_SIM_BUSY: + return _("SIM busy"); + break; + case ME_SIM_WRONG: + return _("SIM wrong"); + break; + case ME_INCORRECT_PASSWORD: + return _("incorrect password"); + break; + case ME_SIM_PIN2_REQUIRED: + return _("SIM PIN2 required"); + break; + case ME_SIM_PUK2_REQUIRED: + return _("SIM PUK2 required"); + break; + case ME_MEMORY_FULL: + return _("memory full"); + break; + case ME_INVALID_INDEX: + return _("invalid index"); + break; + case ME_NOT_FOUND: + return _("not found"); + break; + case ME_MEMORY_FAILURE: + return _("memory failure"); + break; + case ME_TEXT_STRING_TOO_LONG: + return _("text string too long"); + break; + case ME_INVALID_CHARACTERS_IN_TEXT_STRING: + return _("invalid characters in text string"); + break; + case ME_DIAL_STRING_TOO_LONG: + return _("dial string too long"); + break; + case ME_INVALID_CHARACTERS_IN_DIAL_STRING: + return _("invalid characters in dial string"); + break; + case ME_NO_NETWORK_SERVICE: + return _("no network service"); + break; + case ME_NETWORK_TIMEOUT: + return _("network timeout"); + break; + case ME_UNKNOWN: + return _("unknown"); + break; + default: + throw GsmException(stringPrintf(_("invalid ME error %d"), errorCode), + OtherError); + } +} + +string gsmlib::getSMSErrorText(const int errorCode) throw(GsmException) +{ + switch (errorCode) + { + case SMS_UNASSIGNED_OR_UNALLOCATED_NUMBER: + return _("Unassigned (unallocated) number"); + break; + case SMS_OPERATOR_DETERMINED_BARRING: + return _("Operator determined barring"); + break; + case SMS_CALL_BARRED: + return _("Call barred"); + break; + case SMS_NETWORK_FAILURE: + return _("Network failure"); + break; + case SMS_SHORT_MESSAGE_TRANSFER_REJECTED: + return _("Short message transfer rejected"); + break; + case SMS_CONGESTION: + case SMS_CONGESTION2: + return _("Congestion"); + break; + case SMS_DESTINATION_OUT_OF_SERVICE: + return _("Destination out of service"); + break; + case SMS_UNIDENTIFIED_SUBSCRIBER: + return _("Unidentified subscriber"); + break; + case SMS_FACILITY_REJECTED: + return _("Facility rejected"); + break; + case SMS_UNKNOWN_SUBSCRIBER: + return _("Unknown subscriber"); + break; + case SMS_NETWORK_OUT_OF_ORDER: + return _("Network out of order"); + break; + case SMS_TEMPORARY_FAILURE: + return _("Temporary failure"); + break; + case SMS_RESOURCES_UNAVAILABLE_UNSPECIFIED: + return _("Resources unavailable, unspecified"); + break; + case SMS_REQUESTED_FACILITY_NOT_SUBSCRIBED: + return _("Requested facility not subscribed"); + break; + case SMS_REQUESTED_FACILITY_NOT_IMPLEMENTED: + return _("Requested facility not implemented"); + break; + case SMS_INVALID_TRANSACTION_IDENTIFIER: + return _("Invalid Transaction Identifier"); + break; + case SMS_SEMANTICALLY_INCORRECT_MESSAGE: + return _("Semantically incorrect message"); + break; + case SMS_INVALID_MANDATORY_INFORMATION: + return _("Invalid mandatory information"); + break; + case SMS_MESSAGE_TYPE_NONEXISTENT_OR_NOT_IMPLEMENTED: + return _("Message type non-existent or not implemented"); + break; + case SMS_MESSAGE_NOT_COMPATIBLE_WITH_SHORT_MESSAGE_PROTOCOL_STATE: + return _("Message not compatible with short message protocol state"); + break; + case SMS_INFORMATION_ELEMENT_NONEXISTENT_OR_NOT_IMPLEMENTED: + return _("Information element non-existent or not implemented"); + break; + case SMS_UNSPECIFIED_PROTOCOL_ERROR: + return _("Protocol error, unspecified"); + break; + case SMS_UNSPECIFIED_INTERWORKING_ERROR: + return _("Interworking, unspecified"); + break; + case SMS_TELEMATIC_INTERWORKING_NOT_SUPPORTED: + return _("Telematic interworking not supported"); + break; + case SMS_SHORT_MESSAGE_TYPE_0_NOT_SUPPORTED: + return _("Short message Type 0 not supported"); + break; + case SMS_CANNOT_REPLACE_SHORT_MESSAGE: + return _("Cannot replace short message"); + break; + case SMS_UNSPECIFIED_TP_PID_ERROR: + return _("Unspecified TP-PID error"); + break; + case SMS_DATA_CODING_SCHEME_NOT_SUPPORTED: + return _("Data coding scheme (alphabet) not supported"); + break; + case SMS_MESSAGE_CLASS_NOT_SUPPORTED: + return _("Message class not supported"); + break; + case SMS_UNSPECIFIEC_TP_DCS_ERROR: + return _("Unspecifiec TP-DCS error"); + break; + case SMS_COMMAND_CANNOT_BE_ACTIONED: + return _("Command cannot be actioned"); + break; + case SMS_COMMAND_UNSUPPORTED: + return _("Command unsupported"); + break; + case SMS_UNSPECIFIED_TP_COMMAND_ERROR: + return _("Unspecified TP-Command error"); + break; + case SMS_TPDU_NOT_SUPPORTED: + return _("TPDU not supported"); + break; + case SMS_SC_BUSY: + return _("SC busy"); + break; + case SMS_NO_SC_SUBSCRIPTION: + return _("No SC subscription"); + break; + case SMS_SC_SYSTEM_FAILURE: + return _("SC system failure"); + break; + case SMS_INVALID_SME_ADDRESS: + return _("Invalid SME address"); + break; + case SMS_DESTINATION_SME_BARRED: + return _("Destination SME barred"); + break; + case SMS_SM_REJECTED_DUPLICATED_SM: + return _("SM Rejected-Duplicated SM"); + break; + case SMS_SIM_SMS_STORAGE_FULL: + return _("SIM SMS storage full"); + break; + case SMS_NO_SMS_STORAGE_CAPABILITY_IN_SIM: + return _("No SMS storage capability in SIM"); + break; + case SMS_ERROR_IN_MS: + return _("Error in MS"); + break; + case SMS_MEMORY_CAPACITY_EXCEED: + return _("Memory Capacity Exceed"); + break; + case SMS_UNSPECIFIED_ERROR_CAUSE: + return _("Unspecified error cause"); + break; + case SMS_ME_FAILURE: + return _("ME failure"); + break; + case SMS_SMS_SERVICE_OF_ME_RESERVED: + return _("SMS service of ME reserved"); + break; + case SMS_OPERATION_NOT_ALLOWED: + return _("operation not allowed"); + break; + case SMS_OPERATION_NOT_SUPPORTED: + return _("operation not supported"); + break; + case SMS_INVALID_PDU_MODE_PARAMETER: + return _("invalid PDU mode parameter"); + break; + case SMS_INVALID_TEXT_MODE_PARAMETER: + return _("invalid text mode parameter"); + break; + case SMS_SIM_NOT_INSERTED: + return _("SIM not inserted"); + break; + case SMS_SIM_PIN_REQUIRED: + return _("SIM PIN required"); + break; + case SMS_PH_SIM_PIN_REQUIRED: + return _("PH-SIM PIN required"); + break; + case SMS_SIM_FAILURE: + return _("SIM failure"); + break; + case SMS_SIM_BUSY: + return _("SIM busy"); + break; + case SMS_SIM_WRONG: + return _("SIM wrong"); + break; + case SMS_SIM_PUK_REQUIRED: + return _("SIM PUK required"); + break; + case SMS_SIM_PIN2_REQUIRED: + return _("SIM PIN2 required"); + break; + case SMS_SIM_PUK2_REQUIRED: + return _("SIM PUK2 required"); + break; + case SMS_MEMORY_FAILURE: + return _("memory failure"); + break; + case SMS_INVALID_MEMORY_INDEX: + return _("invalid memory index"); + break; + case SMS_MEMORY_FULL: + return _("memory full"); + break; + case SMS_SMSC_ADDRESS_UNKNOWN: + return _("SMSC address unknown"); + break; + case SMS_NO_NETWORK_SERVICE: + return _("no network service"); + break; + case SMS_NETWORK_TIMEOUT: + return _("network timeout"); + break; + case SMS_NO_CNMA_ACKNOWLEDGEMENT_EXPECTED: + return _("no +CNMA acknowledgement expected"); + break; + case SMS_UNKNOWN_ERROR: + return _("unknown error"); + break; + default: + throw GsmException(stringPrintf(_("invalid SMS error %d"), errorCode), + OtherError); + } +} + +string gsmlib::getSMSStatusString(unsigned char status) +{ + string result; + if (status < SMS_STATUS_TEMPORARY_BIT) + { + switch (status) + { + case SMS_STATUS_RECEIVED: + result = _("Short message received by the SME"); + break; + case SMS_STATUS_FORWARDED: + result = _("Short message forwarded by the SC to the SME but the SC " + "is unable to confirm delivery"); + break; + case SMS_STATUS_SM_REPLACES: + result = _("Short message replaced by the SC"); + break; + default: + result = _("reserved"); + break; + } + return result; + } + else if (status & SMS_STATUS_TEMPORARY_BIT) + { + switch (status & ~(SMS_STATUS_TEMPORARY_BIT | SMS_STATUS_PERMANENT_BIT)) + { + case SMS_STATUS_CONGESTION: + result = _("Congestion"); + break; + case SMS_STATUS_SME_BUSY: + result = _("SME busy"); + break; + case SMS_STATUS_NO_RESPONSE_FROM_SME: + result = _("No response from SME"); + break; + case SMS_STATUS_SERVICE_REJECTED: + result = _("Service rejected"); + break; + case SMS_STATUS_QUALITY_OF_SERVICE_UNAVAILABLE: + result = _("Quality of service not available"); + break; + case SMS_STATUS_ERROR_IN_SME: + result = _("Error in SME"); + break; + default: + result = _("reserved"); + break; + } + if (status & SMS_STATUS_PERMANENT_BIT) + return result + _(" (Temporary error, SC is not making any " + "more transfer attempts)"); + else + return result + _(" (Temporary error, SC still trying to " + "transfer SM)"); + } + else + { + switch (status & ~SMS_STATUS_PERMANENT_BIT) + { + case SMS_STATUS_REMOTE_PROCECURE_ERROR: + result = _("Remote Procedure Error"); + break; + case SMS_STATUS_INCOMPATIBLE_DESTINATION: + result = _("Incompatible destination"); + break; + case SMS_STATUS_CONNECTION_REJECTED_BY_SME: + result = _("Connection rejected by SME"); + break; + case SMS_STATUS_NOT_OBTAINABLE: + result = _("Not obtainable"); + break; + case SMS_STATUS_QUALITY_OF_SERVICE_UNAVAILABLE: + result = _("Quality of service not available"); + break; + case SMS_STATUS_NO_INTERWORKING_AVAILABLE: + result = _("No interworking available"); + break; + case SMS_STATUS_SM_VALIDITY_PERDIOD_EXPIRED: + result = _("SM validity period expired"); + break; + case SMS_STATUS_SM_DELETED_BY_ORIGINATING_SME: + result = _("SM deleted by originating SME"); + break; + case SMS_STATUS_SM_DELETED_BY_ADMINISTRATION: + result = _("SM deleted by SC administration"); + break; + case SMS_STATUS_SM_DOES_NOT_EXIST: + result = _("SM does not exit"); + break; + default: + result = _("reserved"); + break; + } + return result + _(" (Permanent Error, SC is not making any " + "more transfer attempts)"); + } +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_error.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_error.h new file mode 100644 index 0000000000..5dc96538e3 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_error.h @@ -0,0 +1,209 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_error.h +// * +// * Purpose: Error codes and error handling functions +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 4.5.1999 +// ************************************************************************* + +#ifndef GSM_ERROR_H +#define GSM_ERROR_H + +#include +#include + +using namespace std; + +namespace gsmlib +{ + // different classes of GSM errors + enum GsmErrorClass{OSError, // error caused by OS call (eg. file handling) + ParserError, // error when parsing AT response + ChatError, // error in chat sequence (ME/TA/SMS error) + ParameterError, // gsmlib function called with bad params + NotImplementedError, // feature not implemented + MeTaCapabilityError, // non-existent capability in ME + SMSFormatError, // SMS format error + InterruptException, // gsmlib was interrupted() + OtherError}; // all other errors + + // all gsmlib exceptions + + class GsmException : public runtime_error + { + private: + GsmErrorClass _errorClass; + int _errorCode; + + public: + GsmException(string errorText, GsmErrorClass errorClass) : + runtime_error(errorText), _errorClass(errorClass), _errorCode(-1) {} + + GsmException(string errorText, GsmErrorClass errorClass, int errorCode) : + runtime_error(errorText), _errorClass(errorClass), + _errorCode(errorCode) {} + + int getErrorCode() const {return _errorCode;} + + GsmErrorClass getErrorClass() const {return _errorClass;} + }; + + // error codes returned by TA/ME (+CMEE) + + const int ME_PHONE_FAILURE = 0; + const int ME_NO_CONNECTION_TO_PHONE = 1; + const int ME_PHONE_ADAPTOR_LINK_RESERVED = 2; + const int ME_OPERATION_NOT_ALLOWED = 3; + const int ME_OPERATION_NOT_SUPPORTED = 4; + const int ME_PH_SIM_PIN_REQUIRED = 5; + const int ME_SIM_NOT_INSERTED = 10; + const int ME_SIM_PIN_REQUIRED = 11; + const int ME_SIM_PUK_REQUIRED = 12; + const int ME_SIM_FAILURE = 13; + const int ME_SIM_BUSY = 14; + const int ME_SIM_WRONG = 15; + const int ME_INCORRECT_PASSWORD = 16; + const int ME_SIM_PIN2_REQUIRED = 17; + const int ME_SIM_PUK2_REQUIRED = 18; + const int ME_MEMORY_FULL = 20; + const int ME_INVALID_INDEX = 21; + const int ME_NOT_FOUND = 22; + const int ME_MEMORY_FAILURE = 23; + const int ME_TEXT_STRING_TOO_LONG = 24; + const int ME_INVALID_CHARACTERS_IN_TEXT_STRING = 25; + const int ME_DIAL_STRING_TOO_LONG = 26; + const int ME_INVALID_CHARACTERS_IN_DIAL_STRING = 27; + const int ME_NO_NETWORK_SERVICE = 30; + const int ME_NETWORK_TIMEOUT = 31; + const int ME_UNKNOWN = 100; + + // return descriptive text for the given error code + // the text is already translated + extern string getMEErrorText(const int errorCode) throw(GsmException); + + // SMS error codes + + // error codes from ETSI GSM 04.11, Annex E + const int SMS_UNASSIGNED_OR_UNALLOCATED_NUMBER = 1; + const int SMS_OPERATOR_DETERMINED_BARRING = 8; + const int SMS_CALL_BARRED = 10; + const int SMS_NETWORK_FAILURE = 17; + const int SMS_SHORT_MESSAGE_TRANSFER_REJECTED = 21; + const int SMS_CONGESTION = 22; + const int SMS_DESTINATION_OUT_OF_SERVICE = 27; + const int SMS_UNIDENTIFIED_SUBSCRIBER = 28; + const int SMS_FACILITY_REJECTED = 29; + const int SMS_UNKNOWN_SUBSCRIBER = 30; + const int SMS_NETWORK_OUT_OF_ORDER = 38; + const int SMS_TEMPORARY_FAILURE = 41; + const int SMS_CONGESTION2 = 42; + const int SMS_RESOURCES_UNAVAILABLE_UNSPECIFIED = 47; + const int SMS_REQUESTED_FACILITY_NOT_SUBSCRIBED = 50; + const int SMS_REQUESTED_FACILITY_NOT_IMPLEMENTED = 69; + const int SMS_INVALID_TRANSACTION_IDENTIFIER = 81; + const int SMS_SEMANTICALLY_INCORRECT_MESSAGE = 95; + const int SMS_INVALID_MANDATORY_INFORMATION = 96; + const int SMS_MESSAGE_TYPE_NONEXISTENT_OR_NOT_IMPLEMENTED = 97; + const int SMS_MESSAGE_NOT_COMPATIBLE_WITH_SHORT_MESSAGE_PROTOCOL_STATE = 98; + const int SMS_INFORMATION_ELEMENT_NONEXISTENT_OR_NOT_IMPLEMENTED = 99; + const int SMS_UNSPECIFIED_PROTOCOL_ERROR = 111; + const int SMS_UNSPECIFIED_INTERWORKING_ERROR = 127; + + // error codes from ETSI GSM 03.40, section 9.2.3.22 + const int SMS_TELEMATIC_INTERWORKING_NOT_SUPPORTED = 0x80; + const int SMS_SHORT_MESSAGE_TYPE_0_NOT_SUPPORTED = 0x81; + const int SMS_CANNOT_REPLACE_SHORT_MESSAGE = 0x82; + const int SMS_UNSPECIFIED_TP_PID_ERROR = 0x8f; + const int SMS_DATA_CODING_SCHEME_NOT_SUPPORTED = 0x90; + const int SMS_MESSAGE_CLASS_NOT_SUPPORTED = 0x91; + const int SMS_UNSPECIFIEC_TP_DCS_ERROR = 0x9f; + const int SMS_COMMAND_CANNOT_BE_ACTIONED = 0xa0; + const int SMS_COMMAND_UNSUPPORTED = 0xa1; + const int SMS_UNSPECIFIED_TP_COMMAND_ERROR = 0xaf; + const int SMS_TPDU_NOT_SUPPORTED = 0xb0; + const int SMS_SC_BUSY = 0xc0; + const int SMS_NO_SC_SUBSCRIPTION = 0xc1; + const int SMS_SC_SYSTEM_FAILURE = 0xc2; + const int SMS_INVALID_SME_ADDRESS = 0xc3; + const int SMS_DESTINATION_SME_BARRED = 0xc4; + const int SMS_SM_REJECTED_DUPLICATED_SM = 0xc5; + const int SMS_SIM_SMS_STORAGE_FULL = 0xd0; + const int SMS_NO_SMS_STORAGE_CAPABILITY_IN_SIM = 0xd1; + const int SMS_ERROR_IN_MS = 0xd2; + const int SMS_MEMORY_CAPACITY_EXCEED = 0xd3; + const int SMS_UNSPECIFIED_ERROR_CAUSE = 0xff; + + // error codes from ETSI GSM 07.05, section 3.2.5 + const int SMS_ME_FAILURE = 300; + const int SMS_SMS_SERVICE_OF_ME_RESERVED = 301; + const int SMS_OPERATION_NOT_ALLOWED = 302; + const int SMS_OPERATION_NOT_SUPPORTED = 303; + const int SMS_INVALID_PDU_MODE_PARAMETER = 304; + const int SMS_INVALID_TEXT_MODE_PARAMETER = 305; + const int SMS_SIM_NOT_INSERTED = 310; + const int SMS_SIM_PIN_REQUIRED = 311; + const int SMS_PH_SIM_PIN_REQUIRED = 312; + const int SMS_SIM_FAILURE = 313; + const int SMS_SIM_BUSY = 314; + const int SMS_SIM_WRONG = 315; + const int SMS_SIM_PUK_REQUIRED = 316; + const int SMS_SIM_PIN2_REQUIRED = 317; + const int SMS_SIM_PUK2_REQUIRED = 318; + const int SMS_MEMORY_FAILURE = 320; + const int SMS_INVALID_MEMORY_INDEX = 321; + const int SMS_MEMORY_FULL = 322; + const int SMS_SMSC_ADDRESS_UNKNOWN = 330; + const int SMS_NO_NETWORK_SERVICE = 331; + const int SMS_NETWORK_TIMEOUT = 332; + const int SMS_NO_CNMA_ACKNOWLEDGEMENT_EXPECTED = 340; + const int SMS_UNKNOWN_ERROR = 500; + + // return descriptive text for the given error code + // the text is already translated + extern string getSMSErrorText(const int errorCode) throw(GsmException); + + // SMS status handling + // success codes + const int SMS_STATUS_RECEIVED = 0; + const int SMS_STATUS_FORWARDED = 1; + const int SMS_STATUS_SM_REPLACES = 2; + + // if this bit is set, the error is only temporary and + // the SC is still trying to transfer the SM + const int SMS_STATUS_TEMPORARY_BIT = 32; + + // if this bit is set, the error is only temporary and + // the SC is still trying to transfer the SM + const int SMS_STATUS_PERMANENT_BIT = 64; + // both bits may be set at once + + // temporary errors (both bits may be set) + const int SMS_STATUS_CONGESTION = 0; + const int SMS_STATUS_SME_BUSY = 1; + const int SMS_STATUS_NO_RESPONSE_FROM_SME = 2; + const int SMS_STATUS_SERVICE_REJECTED = 3; + const int SMS_STATUS_QUALITY_OF_SERVICE_UNAVAILABLE = 4; + const int SMS_STATUS_ERROR_IN_SME = 5; + + // permanent errors (SMS_STATUS_PERMANENT_BIT is set) + const int SMS_STATUS_REMOTE_PROCECURE_ERROR = 0; + const int SMS_STATUS_INCOMPATIBLE_DESTINATION = 1; + const int SMS_STATUS_CONNECTION_REJECTED_BY_SME = 2; + const int SMS_STATUS_NOT_OBTAINABLE = 3; + // const int SMS_STATUS_QUALITY_OF_SERVICE_UNAVAILABLE = 4; + const int SMS_STATUS_NO_INTERWORKING_AVAILABLE = 5; + const int SMS_STATUS_SM_VALIDITY_PERDIOD_EXPIRED = 6; + const int SMS_STATUS_SM_DELETED_BY_ORIGINATING_SME = 7; + const int SMS_STATUS_SM_DELETED_BY_ADMINISTRATION = 8; + const int SMS_STATUS_SM_DOES_NOT_EXIST = 9; + + // return text for SMS status code + // the text is already translated + string getSMSStatusString(unsigned char status); +}; + +#endif // GSM_ERROR_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_event.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_event.cc new file mode 100644 index 0000000000..a608b04f62 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_event.cc @@ -0,0 +1,174 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_event.cc +// * +// * Purpose: Event handler interface +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 7.6.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +// GsmEvent members + +void GsmEvent::dispatch(string s, GsmAt &at) throw(GsmException) +{ + SMSMessageType messageType; + bool indication = false; + if (s.substr(0, 5) == "+CMT:") + messageType = NormalSMS; + else if (s.substr(0, 5) == "+CBM:") + messageType = CellBroadcastSMS; + else if (s.substr(0, 5) == "+CDS:") + { + // workaround for phones that report CDS when they actually mean CDSI + indication = at.getMeTa().getCapabilities()._CDSmeansCDSI; + messageType = StatusReportSMS; + } + else if (s.substr(0, 6) == "+CMTI:") + { + indication = true; + messageType = NormalSMS; + } + else if (s.substr(0, 6) == "+CBMI:") + { + indication = true; + messageType = CellBroadcastSMS; + } + else if (s.substr(0, 6) == "+CDSI:") + { + indication = true; + messageType = StatusReportSMS; + } + else if (s.substr(0, 4) == "RING") + { + ringIndication(); + return; + } + // handling NO CARRIER + else if (s.substr(0, 10) == "NO CARRIER") + { + noAnswer(); + return; + } + + else if (s.substr(0, 6) == "+CLIP:") + { + // ,[,,[,]] + s = s.substr(6); + Parser p(s); + string num = p.parseString(); + if (p.parseComma(true)) + { + unsigned int numberFormat; + if ((numberFormat = p.parseInt()) == InternationalNumberFormat) + num = "+" + num; + else if (numberFormat != UnknownNumberFormat) + throw GsmException(stringPrintf(_("unexpected number format %d"), + numberFormat), OtherError); + } + string subAddr; + string alpha; + if (p.parseComma(true)) + { + subAddr = p.parseString(true); + p.parseComma(); + p.parseInt(true); // FIXME subaddr type ignored + + if (p.parseComma(true)) + alpha = p.parseString(true); + } + + // call the event handler + callerLineID(num, subAddr, alpha); + return; + } + else + throw GsmException(stringPrintf(_("unexpected unsolicited event '%s'"), + s.c_str()), OtherError); + + if (indication) + { + // handle SMS storage indication + s = s.substr(6); + Parser p(s); + string storeName = p.parseString(); + p.parseComma(); + unsigned int index = p.parseInt(); + SMSReceptionIndication(storeName, index - 1, messageType); + } + else + if (messageType == CellBroadcastSMS) + { + // handle CB message + string pdu = at.getLine(); + + CBMessageRef cb = new CBMessage(pdu); + + // call the event handler + CBReception(cb); + } + else + { + // handle SMS + string pdu = at.getLine(); + + // add missing service centre address if required by ME + if (! at.getMeTa().getCapabilities()._hasSMSSCAprefix) + pdu = "00" + pdu; + + SMSMessageRef sms = SMSMessage::decode(pdu); + + // send acknowledgement if necessary + if (at.getMeTa().getCapabilities()._sendAck) + at.chat("+CNMA"); + + // call the event handler + SMSReception(sms, messageType); + } +} + +void GsmEvent::callerLineID(string number, string subAddr, string alpha) +{ + // ignore event +} + +void GsmEvent::SMSReception(SMSMessageRef newMessage, + SMSMessageType messageType) +{ + // ignore event +} + +void GsmEvent::CBReception(CBMessageRef newMessage) +{ + // ignore event +} + +void GsmEvent::SMSReceptionIndication(string storeName, unsigned int index, + SMSMessageType messageType) +{ + // ignore event +} + +void GsmEvent::ringIndication() +{ + // ignore event +} + +void GsmEvent::noAnswer() +{ + // ignore event +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_event.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_event.h new file mode 100644 index 0000000000..b2b986cd15 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_event.h @@ -0,0 +1,68 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_event.h +// * +// * Purpose: Event handler interface +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 7.6.1999 +// ************************************************************************* + +#ifndef GSM_EVENT_H +#define GSM_EVENT_H + +#include +#include + +using namespace std; + +namespace gsmlib +{ + // forward declarations + + class GsmAt; + + // event handler interface + + class GsmEvent + { + private: + // dispatch CMT/CBR/CDS/CLIP etc. + void dispatch(string s, GsmAt &at) throw(GsmException); + + public: + // for SMSReception, type of SMS + enum SMSMessageType {NormalSMS, CellBroadcastSMS, StatusReportSMS}; + + // caller line identification presentation + // only called if setCLIPEvent(true) is set + virtual void callerLineID(string number, string subAddr, string alpha); + + // called if the string NO CARRIER is read + virtual void noAnswer(); + + // SMS reception + // only called if setSMSReceptionEvent(...true...) is set + virtual void SMSReception(SMSMessageRef newMessage, + SMSMessageType messageType); + + // CB reception + // only called if setSMSReceptionEvent(...true...) is set + // storage of CBM in ME is not supported by the standard + virtual void CBReception(CBMessageRef newMessage); + + // SMS reception indication (called when SMS is not delivered to TE + // but stored in ME memory) + virtual void SMSReceptionIndication(string storeName, unsigned int index, + SMSMessageType messageType); + + // RING indication + virtual void ringIndication(); + + friend class gsmlib::GsmAt; + }; +}; + +#endif // GSM_EVENT_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_map_key.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_map_key.h new file mode 100644 index 0000000000..d47b7e0cd9 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_map_key.h @@ -0,0 +1,128 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_map_key.h +// * +// * Purpose: Common MapKey implementation for the multimaps in +// * gsm_sorted_sms_store and gsm_sorted_phonebook +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 5.11.1999 +// ************************************************************************* + +#ifndef GSM_MAP_KEY_H +#define GSM_MAP_KEY_H + +#include + +namespace gsmlib +{ + // sort order for MapKeys + + enum SortOrder {ByText = 0, ByTelephone = 1, ByIndex = 2, ByDate = 3, + ByType = 4, ByAddress = 5}; + + // wrapper for map key, can access Sortedtore to get sortOrder() + + template class MapKey + { + public: + SortedStore &_myStore; // my store + // different type keys + Address _addressKey; + Timestamp _timeKey; + int _intKey; + string _strKey; + + public: + // constructors for the different sort keys + MapKey(SortedStore &myStore, Address key) : + _myStore(myStore), _addressKey(key) {} + MapKey(SortedStore &myStore, Timestamp key) : + _myStore(myStore), _timeKey(key) {} + MapKey(SortedStore &myStore, int key) : + _myStore(myStore), _intKey(key) {} + MapKey(SortedStore &myStore, string key) : + _myStore(myStore), _strKey(key) {} + +/* + friend + bool operator< +#ifndef WIN32 + <> +#endif + (const MapKey &x, + const MapKey &y); + friend + bool operator== +#ifndef WIN32 + <> +#endif + (const MapKey &x, + const MapKey &y); +*/ + }; + + // compare two keys + template + extern bool operator<(const MapKey &x, + const MapKey &y); + template + extern bool operator==(const MapKey &x, + const MapKey &y); + + // MapKey members + + template + bool operator<(const MapKey &x, + const MapKey &y) + { + assert(&x._myStore == &y._myStore); + + switch (x._myStore.sortOrder()) + { + case ByDate: + return x._timeKey < y._timeKey; + case ByAddress: + return x._addressKey < y._addressKey; + case ByIndex: + case ByType: + return x._intKey < y._intKey; + case ByTelephone: + return Address(x._strKey) < Address(y._strKey); + case ByText: + return x._strKey < y._strKey; + default: + assert(0); + return true; + } + } + + template + bool operator==(const MapKey &x, + const MapKey &y) + { + assert(&x._myStore == &y._myStore); + + switch (x._myStore.sortOrder()) + { + case ByDate: + return x._timeKey == y._timeKey; + case ByAddress: + return x._addressKey == y._addressKey; + case ByIndex: + case ByType: + return x._intKey == y._intKey; + case ByTelephone: + return Address(x._strKey) == Address(y._strKey); + case ByText: + return x._strKey == y._strKey; + default: + assert(0); + return true; + } + } +}; + +#endif // GSM_MAP_KEY_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_me_ta.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_me_ta.cc new file mode 100644 index 0000000000..1f9e84581a --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_me_ta.cc @@ -0,0 +1,1254 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_me_ta.cc +// * +// * Purpose: Mobile Equipment/Terminal Adapter functions +// * (ETSI GSM 07.07) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 10.5.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include + +#include + +using namespace std; +using namespace gsmlib; + +// Capabilities members + +Capabilities::Capabilities() : + _hasSMSSCAprefix(true), + _cpmsParamCount(-1), // initialize to -1, must be set later by + // setSMSStore() function + _omitsColon(true), // FIXME + _veryShortCOPSanswer(false), // Falcom A2-1 + _wrongSMSStatusCode(false), // Motorola Timeport 260 + _CDSmeansCDSI(false), // Nokia Cellular Card Phone RPE-1 GSM900 and + // Nokia Card Phone RPM-1 GSM900/1800 + _sendAck(false) // send ack for directly routed SMS +{ +} + +// MeTa members + +void MeTa::init() throw(GsmException) +{ + // switch on extended error codes + // caution: may be ignored by some TAs, so allow it to fail + _at->chat("+CMEE=1", "", true, true); + + // select SMS pdu mode + _at->chat("+CMGF=0"); + + // now fill in capability object + MEInfo info = getMEInfo(); + + // Ericsson model 6050102 + if ((info._manufacturer == "ERICSSON" && + (info._model == "1100801" || + info._model == "1140801")) || + getenv("GSMLIB_SH888_FIX") != NULL) + { + // the Ericsson leaves out the service centre address + _capabilities._hasSMSSCAprefix = false; + } + + // handle Falcom strangeness + if ((info._manufacturer == "Funkanlagen Leipoldt OHG" && + info._revision == "01.95.F2") || + getenv("GSMLIB_FALCOM_A2_1_FIX") != NULL) + { + _capabilities._veryShortCOPSanswer = true; + } + + // handle Motorola SMS store bug - wrong status code + if ((info._manufacturer == "Motorola" && + info._model == "L Series")) + { + _capabilities._wrongSMSStatusCode = true; + } + + // handle Nokia Cellular Card Phone RPE-1 GSM900 and + // Nokia Card Phone RPM-1 GSM900/1800 bug - CDS means CDSI + if ((info._manufacturer == "Nokia Mobile Phones" && + (info._model == "Nokia Cellular Card Phone RPE-1 GSM900" || + info._model == "Nokia Card Phone RPM-1 GSM900/1800"))) + { + _capabilities._CDSmeansCDSI = true; + } + + // find out whether we are supposed to send an acknowledgment + Parser p(_at->chat("+CSMS?", "+CSMS:")); + _capabilities._sendAck = p.parseInt() >= 1; + + // set GSM default character set + try + { + setCharSet("GSM"); + } + catch (GsmException) + { + // ignore errors, some devices don't support this + } + + // set default event handler + // necessary to handle at least RING indications that might + // otherwise confuse gsmlib + _at->setEventHandler(&_defaultEventHandler); +} + +MeTa::MeTa(Ref port) throw(GsmException) : _port(port) +{ + // initialize AT handling + _at = new GsmAt(*this); + + init(); +} + +// MeTa::MeTa(Ref at) throw(GsmException) : +// _at(at) +// { +// init(); +// } + +void MeTa::setPIN(string pin) throw(GsmException) +{ + _at->chat("+CPIN=\"" + pin + "\""); +} + +string MeTa::getPINStatus() throw(GsmException) +{ + Parser p(_at->chat("+CPIN?", "+CPIN:")); + return p.parseString(); +} + +void MeTa::setPhonebook(string phonebookName) throw(GsmException) +{ + if (phonebookName != _lastPhonebookName) + { + _at->chat("+CPBS=\"" + phonebookName + "\""); + _lastPhonebookName = phonebookName; + } +} + +string MeTa::setSMSStore(string smsStore, int storeTypes, bool needResultCode) + throw(GsmException) +{ + if (_capabilities._cpmsParamCount == -1) + { + // count the number of parameters for the CPMS AT sequences + _capabilities._cpmsParamCount = 1; + Parser p(_at->chat("+CPMS=?", "+CPMS:")); + p.parseStringList(); + while (p.parseComma(true)) + { + ++_capabilities._cpmsParamCount; + p.parseStringList(); + } + } + + // optimatization: only set current SMS store if different from last call + // or the result code is needed + if (needResultCode || _lastSMSStoreName != smsStore) + { + _lastSMSStoreName = smsStore; + + // build chat string + string chatString = "+CPMS=\"" + smsStore + "\""; + for (int i = 1; i < min(_capabilities._cpmsParamCount, storeTypes); ++i) + chatString += ",\"" + smsStore + "\""; + + return _at->chat(chatString, "+CPMS:"); + } + return ""; +} + +void MeTa::getSMSStore(string &readDeleteStore, + string &writeSendStore, + string &receiveStore) throw(GsmException) +{ + Parser p(_at->chat("+CPMS?", "+CPMS:")); + writeSendStore = receiveStore = ""; + readDeleteStore = p.parseString(); + p.parseComma(); + p.parseInt(); + p.parseComma(); + p.parseInt(); + if (p.parseComma(true)) + { + writeSendStore = p.parseString(); + p.parseComma(); + p.parseInt(); + p.parseComma(); + p.parseInt(); + if (p.parseComma(true)) + { + receiveStore = p.parseString(); + } + } +} + +void MeTa::waitEvent(GsmTime timeout) throw(GsmException) +{ + if (_at->wait(timeout)) + _at->chat(); // send AT, wait for OK, handle events +} + +// aux function for MeTa::getMEInfo() + +static string stringVectorToString(const vector& v, + char separator = '\n') +{ + if (v.empty()) + return ""; + + // concatenate string in vector as rows + string result; + for (vector::const_iterator i = v.begin();;) + { + string s = *i; + // remove leading and trailing "s + if (s.length() > 0 && s[0] == '"') + s.erase(s.begin()); + if (s.length() > 0 && s[s.length() - 1] == '"') + s.erase(s.end() - 1); + + result += s; + // don't add end line to last + if ( ++i == v.end() || !separator) + break; + result += separator; + } + return result; +} + +MEInfo MeTa::getMEInfo() throw(GsmException) +{ + MEInfo result; + // some TAs just return OK and no info line + // leave the info empty in this case + // some TAs return multirows with info like address, firmware version + result._manufacturer = + stringVectorToString(_at->chatv("+CGMI", "+CGMI:", false)); + result._model = stringVectorToString(_at->chatv("+CGMM", "+CGMM:", false)); + result._revision = + stringVectorToString(_at->chatv("+CGMR", "+CGMR:", false)); + result._serialNumber = + stringVectorToString(_at->chatv("+CGSN", "+CGSN:", false),0); + return result; +} + +vector MeTa::getSupportedCharSets() throw(GsmException) +{ + Parser p(_at->chat("+CSCS=?", "+CSCS:")); + return p.parseStringList(); +} + +string MeTa::getCurrentCharSet() throw(GsmException) +{ + if (_lastCharSet == "") + { + Parser p(_at->chat("+CSCS?", "+CSCS:")); + _lastCharSet = p.parseString(); + } + return _lastCharSet; +} + +void MeTa::setCharSet(string charSetName) throw(GsmException) +{ + _at->chat("+CSCS=\"" + charSetName + "\""); + _lastCharSet = ""; +} + +string MeTa::getExtendedErrorReport() throw(GsmException) +{ + return _at->chat("+CEER", "+CEER:"); +} + +void MeTa::dial(string number) throw(GsmException) +{ + _at->chat("D" + number + ";"); +} + +void MeTa::answer() throw(GsmException) +{ + _at->chat("A"); +} + +void MeTa::hangup() throw(GsmException) +{ + _at->chat("H"); + +} + +vector MeTa::getAvailableOPInfo() throw(GsmException) +{ + vector result; + vector responses = _at->chatv("+COPS=?", "+COPS:"); + + // special treatment for Falcom A2-1, answer looks like + // responses.push_back("(1,29341),(3,29340)"); + if (_capabilities._veryShortCOPSanswer) + { + if (responses.size() == 1) + { + Parser p(responses[0]); + while (p.parseChar('(', true)) + { + OPInfo opi; + opi._status = (OPStatus)p.parseInt(); + p.parseComma(); + opi._numericName = p.parseInt(); + p.parseChar(')'); + p.parseComma(true); + result.push_back(opi); + } + } + } + else + // some formats I have encountered... + //responses.push_back("2,,,31017,,(0,1),(2)"); + //responses.push_back("(3,\"UK CELLNET\",\"CLNET\",\"23410\")," + // "(3,\"ONE2 ONE\",\"ONE2ONE\",\"23430\")," + // "(3,\"ORANGE\",\"ORANGE\",\"23433\")"); + //responses.push_back("(2,\"D1-TELEKOM\",,26201)," + // "(3,\"D2 PRIVAT\",,26202),,(0,1,3,4),(0,2)"); + // some phones arbitrarily split the response into several lines + //responses.push_back("(1,\"AMENA\",,\"21403\")," + // "(3,\"MOVISTAR\",,\"21407\"),"); + //responses.push_back("(3,\"E VODAFONE\",,\"21401\"),,(0,1),(2)"); + + // GSM modems might return + // 1. quadruplets of info enclosed in brackets separated by comma + // 2. several lines of quadruplets of info enclosed in brackets + // 3. several lines of quadruplets without brackets and additional + // info at EOL (e.g. Nokia 8290) + for (vector::iterator i = responses.begin(); + i != responses.end(); ++i) + { +// while (i->length() > 0 && ! isprint((*i)[i->length() - 1])) +// i->erase(i->length() - 1, 1); + + bool expectClosingBracket = false; + Parser p(*i); + while (1) + { + OPInfo opi; + expectClosingBracket = p.parseChar('(', true); + int status = p.parseInt(true); + opi._status = (status == NOT_SET ? UnknownOPStatus : (OPStatus)status); + p.parseComma(); + opi._longName = p.parseString(true); + p.parseComma(); + opi._shortName = p.parseString(true); + p.parseComma(); + try + { + opi._numericName = p.parseInt(true); + } + catch (GsmException &e) + { + if (e.getErrorClass() == ParserError) + { + // the Ericsson GM12 GSM modem returns the numeric ID as string + string s = p.parseString(); + opi._numericName = checkNumber(s); + } + else + throw e; + } + if (expectClosingBracket) p.parseChar(')'); + result.push_back(opi); + if (! p.parseComma(true)) break; + // two commas ",," mean the list is finished + if (p.getEol() == "" || p.parseComma(true)) break; + } + // without brackets, the ME/TA must use format 3. + if (! expectClosingBracket) break; + } + return result; +} + +OPInfo MeTa::getCurrentOPInfo() throw(GsmException) +{ + OPInfo result; + + // 1. This exception thing is necessary because not all ME/TA combinations + // might support all the formats and then return "ERROR". + // 2. Additionally some modems return "ERROR" for all "COPS=3,n" command + // and report only one format with the "COPS?" command (e.g. Nokia 8290). + + // get long format + try + { + try + { + _at->chat("+COPS=3,0"); + } + catch (GsmException &e) + { + if (e.getErrorClass() != ChatError) throw; + } + Parser p(_at->chat("+COPS?", "+COPS:")); + result._mode = (OPModes)p.parseInt(); + // some phones (e.g. Nokia Card Phone 2.0) just return "+COPS: 0" + // if no network connection + if (p.parseComma(true)) + { + if (p.parseInt() == 0) + { + p.parseComma(); + result._longName = p.parseString(); + } + } + } + catch (GsmException &e) + { + if (e.getErrorClass() != ChatError) throw; + } + + // get short format + try + { + try + { + _at->chat("+COPS=3,1"); + } + catch (GsmException &e) + { + if (e.getErrorClass() != ChatError) throw; + } + Parser p(_at->chat("+COPS?", "+COPS:")); + result._mode = (OPModes)p.parseInt(); + // some phones (e.g. Nokia Card Phone 2.0) just return "+COPS: 0" + // if no network connection + if (p.parseComma(true)) + { + if (p.parseInt() == 1) + { + p.parseComma(); + result._shortName = p.parseString(); + } + } + } + catch (GsmException &e) + { + if (e.getErrorClass() != ChatError) throw; + } + + // get numeric format + try + { + try + { + _at->chat("+COPS=3,2"); + } + catch (GsmException &e) + { + if (e.getErrorClass() != ChatError) throw; + } + Parser p(_at->chat("+COPS?", "+COPS:")); + result._mode = (OPModes)p.parseInt(); + // some phones (e.g. Nokia Card Phone 2.0) just return "+COPS: 0" + // if no network connection + if (p.parseComma(true)) + { + if (p.parseInt() == 2) + { + p.parseComma(); + try + { + result._numericName = p.parseInt(); + } + catch (GsmException &e) + { + if (e.getErrorClass() == ParserError) + { + // the Ericsson GM12 GSM modem returns the numeric ID as string + string s = p.parseString(); + result._numericName = checkNumber(s); + } + else + throw e; + } + } + } + } + catch (GsmException &e) + { + if (e.getErrorClass() != ChatError) throw; + } + return result; +} + +void MeTa::setCurrentOPInfo(OPModes mode, + string longName, + string shortName, + int numericName) throw(GsmException) +{ + bool done = false; + if (longName != "") + { + try + { + _at->chat("+COPS=" + intToStr((int)mode) + ",0,\"" + longName + "\""); + done = true; + } + catch (GsmException &e) + { + if (e.getErrorClass() != ChatError) throw; + } + } + if (shortName != "" && ! done) + { + try + { + _at->chat("+COPS=" + intToStr((int)mode) + ",1,\"" + shortName + "\""); + done = true; + } + catch (GsmException &e) + { + if (e.getErrorClass() != ChatError) throw; + } + } + if (numericName != NOT_SET && ! done) + { + try + { + _at->chat("+COPS=" + intToStr((int)mode) + ",2," + + intToStr(numericName)); + done = true; + } + catch (GsmException &e) + { + if (e.getErrorClass() != ChatError) throw; + } + } + if (! done) + throw GsmException(_("unable to set operator"), OtherError); +} + +vector MeTa::getFacilityLockCapabilities() throw(GsmException) +{ + string locks = _at->chat("+CLCK=?", "+CLCK:"); + // some TA don't add '(' and ')' (Option FirstFone) + if (locks.length() && locks[0] != '(') + { + locks.insert(locks.begin(),'('); + locks += ')'; + } + Parser p(locks); + return p.parseStringList(); +} + +bool MeTa::getFacilityLockStatus(string facility, FacilityClass cl) + throw(GsmException) +{ + // some TA return always multiline response with all classes + // (Option FirstFone) + // !!! errors handling is correct (responses.empty() true) ? + vector responses = + _at->chatv("+CLCK=\"" + facility + "\",2,," + intToStr((int)cl),"+CLCK:",true); + for (vector::iterator i = responses.begin(); + i != responses.end(); ++i) + { + Parser p(*i); + int enabled = p.parseInt(); + + // if the first time and there is no comma this + // return direct state of classes + // else return all classes + if (i == responses.begin()) + { + if (!p.parseComma(true)) + return enabled == 1; + } + else + p.parseComma(); + + if ( p.parseInt() == (int)cl ) + return enabled == 1; + } + return false; + +// Parser p(_at->chat("+CLCK=\"" + facility + "\",2,," + intToStr((int)cl), +// "+CLCK:")); +// return p.parseInt() == 1; +} + +void MeTa::lockFacility(string facility, FacilityClass cl, string passwd) + throw(GsmException) +{ + if (passwd == "") + _at->chat("+CLCK=\"" + facility + "\",1,," + intToStr((int)cl)); + else + _at->chat("+CLCK=\"" + facility + "\",1,\"" + passwd + "\"," + + intToStr((int)cl)); +} + +void MeTa::unlockFacility(string facility, FacilityClass cl, string passwd) + throw(GsmException) +{ + if (passwd == "") + _at->chat("+CLCK=\"" + facility + "\",0,," + intToStr((int)cl)); + else + _at->chat("+CLCK=\"" + facility + "\",0,\"" + passwd + "\"," + + intToStr((int)cl)); +} + +vector MeTa::getPasswords() throw(GsmException) +{ + vector result; + Parser p(_at->chat("+CPWD=?", "+CPWD:")); + while (1) + { + PWInfo pwi; + if (!p.parseChar('(', true)) break; // exit if no new tuple + pwi._facility = p.parseString(); + p.parseComma(); + pwi._maxPasswdLen = p.parseInt(); + p.parseChar(')'); + p.parseComma(true); + result.push_back(pwi); + } + return result; +} + +void MeTa::setPassword(string facility, string oldPasswd, string newPasswd) + throw(GsmException) +{ + _at->chat("+CPWD=\"" + facility + "\",\"" + oldPasswd + "\",\"" + + newPasswd + "\""); +} + +bool MeTa::getNetworkCLIP() throw(GsmException) +{ + Parser p(_at->chat("+CLIP?", "+CLIP:")); + p.parseInt(); // ignore result code presentation + p.parseComma(); + return p.parseInt() == 1; +} + +void MeTa::setCLIPPresentation(bool enable) throw(GsmException) +{ + if (enable) + _at->chat("+CLIP=1"); + else + _at->chat("+CLIP=0"); +} + +bool MeTa::getCLIPPresentation() throw(GsmException) +{ + Parser p(_at->chat("+CLIP?", "+CLIP:")); + return p.parseInt() == 1; // ignore rest of line +} + +void MeTa::setCallForwarding(ForwardReason reason, + ForwardMode mode, + string number, + string subaddr, + FacilityClass cl, + int forwardTime) throw(GsmException) +{ + // FIXME subaddr is currently ignored + if (forwardTime != NOT_SET && (forwardTime < 0 || forwardTime > 30)) + throw GsmException(_("call forward time must be in the range 0..30"), + ParameterError); + + int numberType; + number = removeWhiteSpace(number); + if (number.length() > 0 && number[0] == '+') + { + numberType = InternationalNumberFormat; + number = number.substr(1); // skip the '+' at the beginning + } + else + numberType = UnknownNumberFormat; + _at->chat("+CCFC=" + intToStr(reason) + "," + intToStr(mode) + "," + "\"" + number + "\"," + + (number.length() > 0 ? intToStr(numberType) : "") + + "," + intToStr(cl) + + // FIXME subaddr and type + (forwardTime == NOT_SET ? "" : + (",,," + intToStr(forwardTime)))); +} + +void MeTa::getCallForwardInfo(ForwardReason reason, + ForwardInfo &voice, + ForwardInfo &fax, + ForwardInfo &data) throw(GsmException) +{ + // Initialize to some sensible values: + voice._active = false; + voice._cl = VoiceFacility; + voice._time = -1; + voice._reason = NoReason; + data._active = false; + data._cl = DataFacility; + data._time = -1; + data._reason = NoReason; + fax._active = false; + fax._cl = FaxFacility; + fax._time = -1; + fax._reason = NoReason; + + vector responses = + _at->chatv("+CCFC=" + intToStr(reason) + ",2", "+CCFC:"); + if (responses.size() == 1) + { + // only one line was returned. We have to ask for all three classes + // (voice, data, fax) separately + responses.clear(); + responses.push_back(_at->chat("+CCFC=" + intToStr(reason) + + ",2,,,1", "+CCFC:")); + responses.push_back(_at->chat("+CCFC=" + intToStr(reason) + + ",2,,,2", "+CCFC:")); + responses.push_back(_at->chat("+CCFC=" + intToStr(reason) + + ",2,,,4", "+CCFC:")); + } + + for (vector::iterator i = responses.begin(); + i != responses.end(); ++i) + { + Parser p(*i); + int status = p.parseInt(); + p.parseComma(); + FacilityClass cl = (FacilityClass)p.parseInt(); + string number; + string subAddr; + int forwardTime = NOT_SET; + + // parse number + if (p.parseComma(true)) + { + number = p.parseString(); + p.parseComma(); + unsigned int numberType = p.parseInt(); + if (numberType == InternationalNumberFormat) number = "+" + number; + + // parse subaddr + if (p.parseComma(true)) + { + // FIXME subaddr type not handled + subAddr = p.parseString(true); + p.parseComma(); + p.parseInt(true); + + // parse forwardTime + if (p.parseComma(true)) + { + forwardTime = p.parseInt(); + } + } + } + switch (cl) + { + case VoiceFacility: + voice._active = (status == 1); + voice._cl = VoiceFacility; + voice._number = number; + voice._subAddr = subAddr; + voice._time = forwardTime; + voice._reason = reason; + break; + case DataFacility: + data._active = (status == 1); + data._cl = DataFacility; + data._number = number; + data._subAddr = subAddr; + data._time = forwardTime; + data._reason = reason; + break; + case FaxFacility: + fax._active = (status == 1); + fax._cl = FaxFacility; + fax._number = number; + fax._subAddr = subAddr; + fax._time = forwardTime; + fax._reason = reason; + break; + } + } +} + +int MeTa::getBatteryChargeStatus() throw(GsmException) +{ + Parser p(_at->chat("+CBC", "+CBC:")); + return p.parseInt(); +} + +int MeTa::getBatteryCharge() throw(GsmException) +{ + Parser p(_at->chat("+CBC", "+CBC:")); + p.parseInt(); + p.parseComma(); + return p.parseInt(); +} + +int MeTa::getFunctionalityLevel() throw(GsmException) +{ + try { + Parser p(_at->chat("+CFUN?", "+CFUN:")); + // some phones return functionality level like "(2)" + bool expectClosingParen = p.parseChar('(', true); + int result = p.parseInt(); + if (expectClosingParen) + p.parseChar(')'); + return result; + } + catch (GsmException &x) + { + if (x.getErrorClass() == ChatError) + { + throw GsmException(_("Functionality Level commands not supported by ME"), + MeTaCapabilityError); + } else { + throw; + } + } +} + +void MeTa::setFunctionalityLevel(int level) throw(GsmException) +{ + try { + Parser p(_at->chat("+CFUN=" + intToStr(level))); + } catch (GsmException &x) { + if (x.getErrorClass() == ChatError) + { + // If the command AT+CFUN commands really aren't supported by the ME, + // then this will throw an appropriate exception for us. + getFunctionalityLevel(); + // If the number was just out of range, we get here. + throw GsmException(_("Requested Functionality Level out of range"), + ParameterError); + } + throw; + } +} + +int MeTa::getSignalStrength() throw(GsmException) +{ + Parser p(_at->chat("+CSQ", "+CSQ:")); + return p.parseInt(); +} + +int MeTa::getBitErrorRate() throw(GsmException) +{ + Parser p(_at->chat("+CSQ", "+CSQ:")); + p.parseInt(); + p.parseComma(); + return p.parseInt(); +} + +vector MeTa::getPhoneBookStrings() throw(GsmException) +{ + Parser p(_at->chat("+CPBS=?", "+CPBS:")); + return p.parseStringList(); +} + +PhonebookRef MeTa::getPhonebook(string phonebookString, + bool preload) throw(GsmException) +{ + for (PhonebookVector::iterator i = _phonebookCache.begin(); + i != _phonebookCache.end(); ++i) + { + if ((*i)->name() == phonebookString) + return *i; + } + PhonebookRef newPb(new Phonebook(phonebookString, _at, *this, preload)); + _phonebookCache.push_back(newPb); + return newPb; +} + +string MeTa::getServiceCentreAddress() throw(GsmException) +{ + Parser p(_at->chat("+CSCA?", "+CSCA:")); + return p.parseString(); +} + +void MeTa::setServiceCentreAddress(string sca) throw(GsmException) +{ + int type; + sca = removeWhiteSpace(sca); + if (sca.length() > 0 && sca[0] == '+') + { + type = InternationalNumberFormat; + sca = sca.substr(1, sca.length() - 1); + } + else + type = UnknownNumberFormat; + Parser p(_at->chat("+CSCA=\"" + sca + "\"," + intToStr(type))); +} + +vector MeTa::getSMSStoreNames() throw(GsmException) +{ + Parser p(_at->chat("+CPMS=?", "+CPMS:")); + // only return values + return p.parseStringList(); +} + +SMSStoreRef MeTa::getSMSStore(string storeName) throw(GsmException) +{ + for (SMSStoreVector::iterator i = _smsStoreCache.begin(); + i != _smsStoreCache.end(); ++i) + { + if ((*i)->name() == storeName) + return *i; + } + SMSStoreRef newSs(new SMSStore(storeName, _at, *this)); + _smsStoreCache.push_back(newSs); + return newSs; +} + +void MeTa::sendSMS(Ref smsMessage) throw(GsmException) +{ + smsMessage->setAt(_at); + smsMessage->send(); +} + +void MeTa::sendSMSs(Ref smsTemplate, string text, + bool oneSMS, + int concatenatedMessageId) + throw(GsmException) +{ + assert(! smsTemplate.isnull()); + + // compute maximum text length for normal SMSs and concatenated SMSs + unsigned int maxTextLength, concMaxTextLength; + switch (smsTemplate->dataCodingScheme().getAlphabet()) + { + case DCS_DEFAULT_ALPHABET: + maxTextLength = 160; + concMaxTextLength = 152; + break; + case DCS_EIGHT_BIT_ALPHABET: + maxTextLength = 140; + concMaxTextLength = 134; + break; + case DCS_SIXTEEN_BIT_ALPHABET: + maxTextLength = 70; + concMaxTextLength = 67; + break; + default: + throw GsmException(_("unsupported alphabet for SMS"), + ParameterError); + break; + } + + // simple case, only send one SMS + if (oneSMS || text.length() <= maxTextLength) + { + if (text.length() > maxTextLength) + throw GsmException(_("SMS text is larger than allowed"), + ParameterError); + smsTemplate->setUserData(text); + sendSMS(smsTemplate); + } + else // send multiple SMSs + { + if (concatenatedMessageId != -1) + maxTextLength = concMaxTextLength; + + int numMessages = (text.length() + maxTextLength - 1) / maxTextLength; + if (numMessages > 255) + throw GsmException(_("not more than 255 concatenated SMSs allowed"), + ParameterError); + unsigned char numMessage = 0; + while (true) + { + if (concatenatedMessageId != -1) + { + unsigned char udhs[] = {0x00, 0x03, concatenatedMessageId, + numMessages, ++numMessage}; + UserDataHeader udh(string((char*)udhs, 5)); + smsTemplate->setUserDataHeader(udh); + } + smsTemplate->setUserData(text.substr(0, maxTextLength)); + sendSMS(smsTemplate); + if (text.length() < maxTextLength) + break; + text.erase(0, maxTextLength); + } + } +} + +void MeTa::setMessageService(int serviceLevel) throw(GsmException) +{ + string s; + switch (serviceLevel) + { + case 0: + s = "0"; + break; + case 1: + s = "1"; + break; + default: + throw GsmException(_("only serviceLevel 0 or 1 supported"), + ParameterError); + } + // some devices (eg. Origo 900) don't support service level setting + _at->chat("+CSMS=" + s, "+CSMS:", true); +} + +unsigned int MeTa::getMessageService() throw(GsmException) +{ + Parser p(_at->chat("+CSMS?", "+CSMS:")); + return p.parseInt(); +} + +void MeTa::getSMSRoutingToTA(bool &smsRouted, + bool &cbsRouted, + bool &statusReportsRouted) throw(GsmException) +{ + Parser p(_at->chat("+CNMI?", "+CNMI:")); + p.parseInt(); + int smsMode = 0; + int cbsMode = 0; + int statMode = 0; + int bufferMode = 0; + + if (p.parseComma(true)) + { + smsMode = p.parseInt(); + if (p.parseComma(true)) + { + cbsMode = p.parseInt(); + if (p.parseComma(true)) + { + statMode = p.parseInt(); + if (p.parseComma(true)) + { + bufferMode = p.parseInt(); + } + } + } + } + + smsRouted = (smsMode == 2) || (smsMode == 3); + cbsRouted = (cbsMode == 2) || (cbsMode == 3); + statusReportsRouted = (statMode == 1); +} + +void MeTa::setSMSRoutingToTA(bool enableSMS, bool enableCBS, + bool enableStatReport, + bool onlyReceptionIndication) + throw(GsmException) +{ + bool smsModesSet = false; + bool cbsModesSet = false; + bool statModesSet = false; + bool bufferModesSet = false; + + // find out capabilities + Parser p(_at->chat("+CNMI=?", "+CNMI:")); + vector modes = p.parseIntList(); + vector smsModes(1); + vector cbsModes(1); + vector statModes(1); + vector bufferModes(1); + if (p.parseComma(true)) + { + smsModes = p.parseIntList(); + smsModesSet = true; + if (p.parseComma(true)) + { + cbsModes = p.parseIntList(); + cbsModesSet = true; + if (p.parseComma(true)) + { + statModes = p.parseIntList(); + statModesSet = true; + if (p.parseComma(true)) + { + bufferModes = p.parseIntList(); + bufferModesSet = true; + } + } + } + } + + // now set the mode vectors to the default if not set + if (! smsModesSet) smsModes[0] = true; + if (! cbsModesSet) cbsModes[0] = true; + if (! statModesSet) statModes[0] = true; + if (! bufferModesSet) bufferModes[0] = true; + + string chatString; + + // now try to set some optimal combination depending on + // ME/TA's capabilities + + // handle modes + if (isSet(modes, 2)) + chatString = "2"; + else if (isSet(modes, 1)) + chatString = "1"; + else if (isSet(modes, 0)) + chatString = "0"; + else if (isSet(modes, 3)) + chatString = "3"; + + if (onlyReceptionIndication) + { + // handle sms mode + if (enableSMS) + { + if (isSet(smsModes, 1)) + chatString += ",1"; + else + throw GsmException(_("cannot route SMS messages to TE"), + MeTaCapabilityError); + } + else + chatString += ",0"; + + // handle cbs mode + if (enableCBS) + { + if (isSet(cbsModes, 1)) + chatString += ",1"; + else if (isSet(cbsModes, 2)) + chatString += ",2"; + else + throw GsmException(_("cannot route cell broadcast messages to TE"), + MeTaCapabilityError); + } + else + chatString += ",0"; + + // handle stat mode + if (enableStatReport) + { + if (isSet(statModes, 2)) + chatString += ",2"; + else + throw GsmException(_("cannot route status reports messages to TE"), + MeTaCapabilityError); + } + else + chatString += ",0"; + } + else + { + // handle sms mode + if (enableSMS) + { + if (isSet(smsModes, 2)) + chatString += ",2"; + else if (isSet(smsModes, 3)) + chatString += ",3"; + else + throw GsmException(_("cannot route SMS messages to TE"), + MeTaCapabilityError); + } + else + chatString += ",0"; + + // handle cbs mode + if (enableCBS) + { + if (isSet(cbsModes, 2)) + chatString += ",2"; + else if (isSet(cbsModes, 3)) + chatString += ",3"; + else + throw GsmException(_("cannot route cell broadcast messages to TE"), + MeTaCapabilityError); + } + else + chatString += ",0"; + + // handle stat mode + if (enableStatReport) + { + if (isSet(statModes, 1)) + chatString += ",1"; + else if (isSet(statModes, 2)) + chatString += ",2"; + else + throw GsmException(_("cannot route status report messages to TE"), + MeTaCapabilityError); + } + else + chatString += ",0"; + } + + // handle buffer mode but only if it was reported by the +CNMI=? command + // the Ericsson GM12 GSM modem does not like it otherwise + if (bufferModesSet) + if (isSet(bufferModes, 1)) + chatString += ",1"; + else + chatString += ",0"; + + _at->chat("+CNMI=" + chatString); +} + +bool MeTa::getCallWaitingLockStatus(FacilityClass cl) + throw(GsmException) +{ + // some TA return always multiline response with all classes + // (Option FirstFone) + // !!! errors handling is correct (responses.empty() true) ? + vector responses = + _at->chatv("+CCWA=0,2," + intToStr((int)cl),"+CCWA:",true); + for (vector::iterator i = responses.begin(); + i != responses.end(); ++i) + { + Parser p(*i); + int enabled = p.parseInt(); + + // if the first time and there is no comma this + // return direct state of classes + // else return all classes + if (i == responses.begin()) + { + if (! p.parseComma(true)) + return enabled == 1; + } + else + p.parseComma(); + + if (p.parseInt() == (int)cl) + return enabled == 1; + } + return false; + +} +void MeTa::setCallWaitingLockStatus(FacilityClass cl, bool lock) + throw(GsmException) +{ + if(lock) + _at->chat("+CCWA=0,1," + intToStr((int)cl)); + else + _at->chat("+CCWA=0,0," + intToStr((int)cl)); +} + +void MeTa::setCLIRPresentation(bool enable) throw(GsmException) +{ + if (enable) + _at->chat("+CLIR=1"); + else + _at->chat("+CLIR=0"); +} + +int MeTa::getCLIRPresentation() throw(GsmException) +{ + // 0:according to the subscription of the CLIR service + // 1:CLIR invocation + // 2:CLIR suppression + Parser p(_at->chat("+CLIR?", "+CLIR:")); + return p.parseInt(); +} + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_me_ta.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_me_ta.h new file mode 100644 index 0000000000..f397e84695 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_me_ta.h @@ -0,0 +1,402 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_me_ta.h +// * +// * Purpose: Mobile Equipment/Terminal Adapter and SMS functions +// * (ETSI GSM 07.07 and 07.05) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 3.5.1999 +// ************************************************************************* + +#ifndef GSM_ME_TA_H +#define GSM_ME_TA_H + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + // *** phone capability description (you could also call it phone quirks) + + struct Capabilities + { + bool _hasSMSSCAprefix; // SMS have service centre address prefix + int _cpmsParamCount; // number of SMS store parameters to + // CPMS command + bool _omitsColon; // omits trailing ':' in AT responses + bool _veryShortCOPSanswer; // Falcom A2-1 + bool _wrongSMSStatusCode; // Motorola Timeport 260 + bool _CDSmeansCDSI; // Nokia Cellular Card Phone RPE-1 GSM900 + bool _sendAck; // send ack for directly routed SMS + Capabilities(); // constructor, set default behaviours + }; + + // *** auxiliary structs + + // Static ME information (AT command sequences given in brackets) + struct MEInfo + { + string _manufacturer; // (+CGMI) + string _model; // (+CGMM) + string _revision; // (+CGMR) + string _serialNumber; // (+CGSN), IMEI + }; + + // modes for network operation selection + enum OPModes {AutomaticOPMode = 0, ManualOPMode = 1, + DeregisterOPMode = 2, ManualAutomaticOPMode = 4}; + + // status codes or network operaton selection + enum OPStatus {UnknownOPStatus = 0, AvailableOPStatus = 1, + CurrentOPStatus = 2, ForbiddenOPStatus = 3}; + + // network operator info + struct OPInfo + { + OPModes _mode; + OPStatus _status; + string _longName; + string _shortName; + int _numericName; // may be NOT_SET + + OPInfo() : _status(UnknownOPStatus), _numericName(NOT_SET) {} + }; + + // facility classes + enum FacilityClass {VoiceFacility = 1, DataFacility = 2, FaxFacility = 4}; + const int ALL_FACILITIES = VoiceFacility | DataFacility | FaxFacility; + + // struct to hold password info + struct PWInfo + { + string _facility; + int _maxPasswdLen; + }; + + // call forward reasons + // AllReasons encompasses 0..3 + // AllConditionalReasons encompasses 1..3 + enum ForwardReason {UnconditionalReason = 0, MobileBusyReason = 1, + NoReplyReason = 2, NotReachableReason = 3, + AllReasons = 4, AllConditionalReasons = 5, NoReason = 6}; + + // call forward modes + enum ForwardMode {DisableMode = 0, EnableMode = 1, + RegistrationMode = 3, ErasureMode = 4}; + + // call forward info + struct ForwardInfo + { + bool _active; // status in the network + FacilityClass _cl; // voice, fax, or data + string _number; // telephone number + string _subAddr; // subaddress + int _time; // time in the range 1..30 (for NoReplyReason) + ForwardReason _reason; // reason for the forwarding + }; + + // SMS types + typedef Ref SMSStoreRef; + typedef vector SMSStoreVector; + + // this class allows access to all functions of a ME/TA as described + // in sections 5-8 of ETSI GSM 07.07 + // Note: If the ME is changed (ie. disconnected an another one connected + // to the TA), a new ME object must be created + // (Mobile equipment = ME, terminal adapter = TA) + class MeTa : public RefBase + { + protected: + Ref _port; // port the ME/TA is connected to + Ref _at; // chat object for the port + PhonebookVector _phonebookCache; // cache of all used phonebooks + SMSStoreVector _smsStoreCache; // cache of all used phonebooks + string _lastPhonebookName; // remember last phonebook set on ME/TA + string _lastSMSStoreName; // remember last SMS store set on ME/TA + Capabilities _capabilities; // ME/TA quirks + GsmEvent _defaultEventHandler; // default event handler + // see comments in MeTa::init() + string _lastCharSet; // remember last character set + + // init ME/TA to sensible defaults + void init() throw(GsmException); + + public: + // initialize a new MeTa object given the port + MeTa(Ref port) throw(GsmException); + + // initialize a new MeTa object given the AT handler + //MeTa(Ref at) throw(GsmException); + + // set the current phonebook in the ME + // remember the last phonebook set for optimisation + void setPhonebook(string phonebookName) throw(GsmException); + + // set the current SMS store in the ME + // set storeTypes to + // 1 to set store for reading and deleting + // 2 to set store for writing and sending (includes type 1) + // 3 to preferred store for receiving SMS (includes types 1 and 2) + // remember the last SMS store set for optimisation + // if needResultCode is set this optimisation is not done + string setSMSStore(string smsStore, int storeTypes, + bool needResultCode = false) + throw(GsmException); + + // get current SMS store settings + void getSMSStore(string &readDeleteStore, + string &writeSendStore, + string &receiveStore) throw(GsmException); + + // get capabilities of this ME/TA + Capabilities getCapabilities() const {return _capabilities;} + + // return my port + Ref getPort() {return _port;} + + // return my at handler + Ref getAt() {return _at;} + + // set event handler for unsolicited result codes + GsmEvent *setEventHandler(GsmEvent *newHandler) + {return _at->setEventHandler(newHandler);} + + // wait for an event + void waitEvent(GsmTime timeout) throw(GsmException); + + // *** ETSI GSM 07.07 Section 5: "General Commands" + + // return ME information + MEInfo getMEInfo() throw(GsmException); + + // return available character sets + vector getSupportedCharSets() throw(GsmException);// (+CSCS=?) + + // return current character set (default: GSM) + string getCurrentCharSet() throw(GsmException);// (+CSCS?) + + // set character set to use + void setCharSet(string charSetName) throw(GsmException);// (+CSCS=) + + // *** ETSI GSM 07.07 Section 6: "Call control commands and methods" + + // get extended error report + string getExtendedErrorReport() throw(GsmException);// (+CEER) + + // dial a number, CLI presentation as defined in network + void dial(string number) throw(GsmException);// (ATD) + + // answer + void answer() throw(GsmException); // (ATA) + + // hangup + void hangup() throw(GsmException); // (ATH) + + // set Personal Identification Number + void setPIN(string number) throw(GsmException);// (+CPIN) + + // get PIN Status + string getPINStatus() throw(GsmException);// (+CPIN?) + + // *** ETSI GSM 07.07 Section 7: "Network service related commands" + + // return available network operators + // this fills in all fields of OPInfo with the exception of _mode + vector getAvailableOPInfo() throw(GsmException); // (+COPS=?) + + // return current network operators + // this fills in all the fields of OPInfo with the exception of _status + OPInfo getCurrentOPInfo() throw(GsmException); + + // set network operator + // caller must fill in ALL names it has read from previous calls + // of getCurrentOPInfo() or getAvailableOPInfo() + // (because ME/TA might not implement all names) + void setCurrentOPInfo(OPModes mode, + string longName = "", + string shortName = "", + int numericName = NOT_SET) throw(GsmException); + + // get facility lock capabilities (+CLCK) + vector getFacilityLockCapabilities() throw(GsmException); + + // query facility lock status for named facility + bool getFacilityLockStatus(string facility, FacilityClass cl) + throw(GsmException); + + // lock facility + void lockFacility(string facility, FacilityClass cl, string passwd = "") + throw(GsmException); + + // unlock facility + void unlockFacility(string facility, FacilityClass cl, string passwd = "") + throw(GsmException); + + // return names of facility for which a password can be set + // and the maximum length of the respective password + vector getPasswords() throw(GsmException);// (+CPWD=?) + + // set password for the given facility + void setPassword(string facility, string oldPasswd, string newPasswd) + throw(GsmException); + // (+CPWD=) + + // get CLIP (caller line identification presentation) in the network + bool getNetworkCLIP() throw(GsmException);// (+CLIP?) + + // set CLIP presentation on or off + // enables GsmEvent::callerLineID + void setCLIPPresentation(bool enable) throw(GsmException);// (+CLIP=) + + // returns if the above is enable + bool getCLIPPresentation() throw(GsmException);// (+CLIP?) + + // set call forwarding + void setCallForwarding(ForwardReason reason, + ForwardMode mode, + string number, + string subaddr, + FacilityClass cl = (FacilityClass)ALL_FACILITIES, + int forwardTime = NOT_SET) + throw(GsmException); // (+CCFC=) + + // get Information of currently set CF in the network + // the caller must give the reason to query + void getCallForwardInfo(ForwardReason reason, + ForwardInfo &voice, + ForwardInfo &fax, + ForwardInfo &data) + throw(GsmException); // (+CCFC=) + + + // *** ETSI GSM 07.07 Section 8: "Mobile Equipment control + // and status commands" + + // return/set ME functionality level (+CFUN): + // 0 Minimum functionality + // 1 full functionality + // 2 disable phone transmit RF circuits only + // 3 disable phone receive RF circuits only + // 4 disable phone both transmit and receive RF circuits + // 5...127 implementation-defined + int getFunctionalityLevel() throw(GsmException); + void setFunctionalityLevel(int level) throw(GsmException); + + // return battery charge status (+CBC): + // 0 ME is powered by the battery + // 1 ME has a battery connected, but is not powered by it + // 2 ME does not have a battery connected + // 3 Recognized power fault, calls inhibited + int getBatteryChargeStatus() throw(GsmException); + + // return battery charge (range 0..100) (+CBC) + int getBatteryCharge() throw(GsmException); + + // get signal strength indication (+CSQ): + // 0 -113 dBm or less + // 1 -111 dBm + // 2...30 -109... -53 dBm + // 31 -51 dBm or greater + // 99 not known or not detectable + int getSignalStrength() throw(GsmException); + + // get channel bit error rate (+CSQ): + // 0...7 as RXQUAL values in the table in GSM 05.08 [20] subclause 8.2.4 + // 99 not known or not detectable + int getBitErrorRate() throw(GsmException); + + // get available phone book memory storage strings (+CPBS=?) + vector getPhoneBookStrings() throw(GsmException); + + // get phone book given the phone book memory storage string + PhonebookRef getPhonebook(string phonebookString, + bool preload = false) throw(GsmException); + + + // *** ETSI GSM 07.05 SMS functions + + // return service centre address (+CSCA?) + string getServiceCentreAddress() throw(GsmException); + + // set service centre address (+CSCA=) + void setServiceCentreAddress(string sca) throw(GsmException); + + // return names of available message stores (, +CPMS=?) + vector getSMSStoreNames() throw(GsmException); + + // return SMS store given the name + SMSStoreRef getSMSStore(string storeName) throw(GsmException); + + // send a single SMS message + void sendSMS(Ref smsMessage) throw(GsmException); + + // send one or several (concatenated) SMS messages + // The SUBMIT message template must have all options set, only + // the userData and the userDataHeader are changed. + // If oneSMS is true, only one SMS is sent. Otherwise several SMSs + // are sent. If concatenatedMessageId is != -1 this is used as the message + // ID for concatenated SMS (for this a user data header as defined in + // GSM GTS 3.40 is used, the old UDH in the template is overwritten). + void sendSMSs(Ref smsTemplate, string text, + bool oneSMS = false, + int concatenatedMessageId = -1) + throw(GsmException); + + // set SMS service level + // if set to 1 send commands return ACK PDU, 0 is the default + void setMessageService(int serviceLevel) throw(GsmException); + + // return SMS service level + unsigned int getMessageService() throw(GsmException); + + // return true if any of the thre message types GsmEvent::SMSMessageType + // is routed directly to the TA and not stored in the ME + void getSMSRoutingToTA(bool &smsRouted, // (+CNMI?) + bool &cbsRouted, + bool &statusReportsRouted) throw(GsmException); + + // sets routing of SMS to TA to true for all supported SMSMessageTypes + // if onlyReceptionIndication is set to true + // only GsmEvent::SMSReceptionIndication is called + // this has two reasons: GSM 07.05 section 3.4.1 does not recommend + // direct routing of new SMS to the TA + // I cannot test direct routing of SMS because it does not work with + // my hardware + void setSMSRoutingToTA(bool enableSMS, bool enableCBS, + bool enableStatReport, + bool onlyReceptionIndication = true) + throw(GsmException); + // (+CNMI=) + + bool getCallWaitingLockStatus(FacilityClass cl) + throw(GsmException); + + void setCallWaitingLockStatus(FacilityClass cl, + bool lock)throw(GsmException); + + void setCLIRPresentation(bool enable) throw(GsmException); + //(+CLIR) + + // 0:according to the subscription of the CLIR service + // 1:CLIR invocation + // 2:CLIR suppression + int getCLIRPresentation() throw(GsmException); + + friend class Phonebook; + friend class SMSStore; + }; +}; + +#endif // GSM_ME_TA_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_nls.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_nls.cc new file mode 100644 index 0000000000..5eb205bf81 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_nls.cc @@ -0,0 +1,32 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_nls.cc +// * +// * Purpose: Groups macros, initialization and includes +// * for National Language Support (NLS) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 3.11.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include + +using namespace std; + +#ifdef ENABLE_NLS + +using namespace gsmlib; + +#ifdef HAVE_LOCALE_H +#include +#endif + +bool InitNLS::initialized = false; + +#endif // ENABLE_NLS diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_nls.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_nls.h new file mode 100644 index 0000000000..6bfa6eb2f7 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_nls.h @@ -0,0 +1,71 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_nls.h +// * +// * Purpose: Groups macros, initialization and includes +// * for National Language Support (NLS) +// * +// * Warning: Only include this header from gsmlib .cc-files +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 3.11.1999 +// ************************************************************************* + +#ifndef GSM_NLS_H +#define GSM_NLS_H + +#ifdef HAVE_CONFIG_H +#include +#endif + +#ifdef ENABLE_NLS + +#ifdef HAVE_LIBINTL_H +#include +#else +#include "../intl/libintl.h" +#endif +#ifdef HAVE_LOCALE_H +#include +#endif + +#define _(String) dgettext(PACKAGE, String) + +// this causes automatic NLS initialization if one file of the library +// includes gsm_nls.h + +namespace gsmlib +{ + const class InitNLS + { + static bool initialized; + + public: + InitNLS() + { + if (! initialized) // do only once + { + setlocale(LC_ALL, ""); +#ifdef LOCAL_TRANSLATIONS + bindtextdomain(PACKAGE, "../po"); +#else + bindtextdomain(PACKAGE, LOCALEDIR); +#endif + textdomain(PACKAGE); + initialized = true; + } + } + } initNLS; +}; + +#else + +#define _(String) (String) + +#endif // ENABLE_NLS + +#define N_(String) (String) + +#endif // GSM_NLS_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_parser.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_parser.cc new file mode 100644 index 0000000000..38a21cd515 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_parser.cc @@ -0,0 +1,381 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_parser.cc +// * +// * Purpose: Parser to parse MA/TA result strings +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 13.5.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +// Parser members + +int Parser::nextChar(bool skipWhiteSpace) +{ + if (skipWhiteSpace) + while (_i < _s.length() && isspace(_s[_i])) ++_i; + + if (_i == _s.length()) + { + _eos = true; + return -1; + } + + return _s[_i++]; +} + +bool Parser::checkEmptyParameter(bool allowNoParameter) throw(GsmException) +{ + int c = nextChar(); + if (c == ',' || c == -1) + if (allowNoParameter) + { + putBackChar(); + return true; + } + else + throwParseException(_("expected parameter")); + + putBackChar(); + return false; +} + +string Parser::parseString2(bool stringWithQuotationMarks) + throw(GsmException) +{ + int c; + string result; + if (parseChar('"', true)) // OK, string starts and ends with quotation mark + if (stringWithQuotationMarks) + { + // read till end of line + while ((c = nextChar(false)) != -1) + result += c; + + // check for """ at end of line + if (result.length() == 0 || result[result.length() - 1] != '"') + throwParseException(_("expected '\"'")); + + // remove """ at the end + result.resize(result.length() - 1); + } + else + { + // read till next """ + while ((c = nextChar(false)) != '"') + if (c == -1) + throwParseException(); + else + result += c; + } + else // string ends with "," or EOL + { + c = nextChar(false); + while (c != ',' && c != -1) + { + result += c; + c = nextChar(false); + } + if (c == ',') putBackChar(); + } + + return result; +} + +int Parser::parseInt2() throw(GsmException) +{ + string s; + int c; + int result; + + while (isdigit(c = nextChar())) s += c; + + putBackChar(); + if (s.length() == 0) + throwParseException(_("expected number")); + + istrstream is(s.c_str()); + is >> result; + return result; +} + +void Parser::throwParseException(string message) throw(GsmException) +{ + ostrstream os; + if (message.length() == 0) + throw GsmException(stringPrintf(_("unexpected end of string '%s'"), + _s.c_str()), ParserError); + else + throw GsmException(message + + stringPrintf(_(" (at position %d of string '%s')"), _i, + _s.c_str()), ParserError); +} + +Parser::Parser(string s) : _i(0), _s(s), _eos(false) +{ +} + +bool Parser::parseChar(char c, bool allowNoChar) throw(GsmException) +{ + if (nextChar() != c) + if (allowNoChar) + { + putBackChar(); + return false; + } + else + throwParseException(stringPrintf(_("expected '%c'"), c)); + return true; +} + +vector Parser::parseStringList(bool allowNoList) + throw(GsmException) +{ + // handle case of empty parameter + vector result; + if (checkEmptyParameter(allowNoList)) return result; + + parseChar('('); + if (nextChar() != ')') + { + putBackChar(); + while (1) + { + result.push_back(parseString()); + int c = nextChar(); + if (c == ')') + break; + if (c == -1) + throwParseException(); + if (c != ',') + throwParseException(_("expected ')' or ','")); + } + } + + return result; +} + +vector Parser::parseIntList(bool allowNoList) + throw(GsmException) +{ + // handle case of empty parameter + bool isRange = false; + vector result; + int resultCapacity = 0; + unsigned int saveI = _i; + + if (checkEmptyParameter(allowNoList)) return result; + + // check for the case of a integer list consisting of only one parameter + // some TAs omit the parentheses in this case + if (isdigit(nextChar())) + { + putBackChar(); + int num = parseInt(); + result.resize(num + 1, false); + result[num] = true; + return result; + } + putBackChar(); + + // run in two passes + // pass 0: find capacity needed for result + // pass 1: resize result and fill it in + for (int pass = 0; pass < 2; ++pass) + { + if (pass == 1) + { + _i = saveI; + result.resize(resultCapacity + 1, false); + } + + parseChar('('); + if (nextChar() != ')') + { + putBackChar(); + int lastInt = -1; + while (1) + { + int thisInt = parseInt(); + + if (isRange) + { + assert(lastInt != -1); + if (lastInt <= thisInt) + for (int i = lastInt; i < thisInt; ++i) + { + if (i > resultCapacity) + resultCapacity = i; + if (pass == 1) + result[i] = true; + } + else + for (int i = thisInt; i < lastInt; ++i) + { + if (i > resultCapacity) + resultCapacity = i; + if (pass == 1) + result[i] = true; + } + isRange = false; + } + + if (thisInt > resultCapacity) + resultCapacity = thisInt; + if (pass == 1) + result[thisInt] = true; + lastInt = thisInt; + + int c = nextChar(); + if (c == ')') + break; + + if (c == -1) + throwParseException(); + + if (c != ',' && c != '-') + throwParseException(_("expected ')', ',' or '-'")); + + if (c == ',') + isRange = false; + else // is '-' + if (isRange) + throwParseException(_("range of the form a-b-c not allowed")); + else + isRange = true; + } + } + } + if (isRange) + throwParseException(_("range of the form a- no allowed")); + return result; +} + +vector Parser::parseParameterRangeList(bool allowNoList) + throw(GsmException) +{ + // handle case of empty parameter + vector result; + if (checkEmptyParameter(allowNoList)) return result; + + result.push_back(parseParameterRange()); + while (parseComma(true)) + { + result.push_back(parseParameterRange()); + } + + return result; +} + +ParameterRange Parser::parseParameterRange(bool allowNoParameterRange) + throw(GsmException) +{ + // handle case of empty parameter + ParameterRange result; + if (checkEmptyParameter(allowNoParameterRange)) return result; + + parseChar('('); + result._parameter = parseString(); + parseComma(); + result._range = parseRange(false, true); + parseChar(')'); + + return result; +} + +IntRange Parser::parseRange(bool allowNoRange, bool allowNonRange) + throw(GsmException) +{ + // handle case of empty parameter + IntRange result; + if (checkEmptyParameter(allowNoRange)) return result; + + parseChar('('); + result._low = parseInt(); + // allow non-ranges is allowNonRange == true + if (parseChar('-', allowNonRange)) + result._high = parseInt(); + parseChar(')'); + + return result; +} + +int Parser::parseInt(bool allowNoInt) throw(GsmException) +{ + // handle case of empty parameter + int result = NOT_SET; + if (checkEmptyParameter(allowNoInt)) return result; + + result = parseInt2(); + + return result; +} + +string Parser::parseString(bool allowNoString, + bool stringWithQuotationMarks) + throw(GsmException) +{ + // handle case of empty parameter + string result; + if (checkEmptyParameter(allowNoString)) return result; + + result = parseString2(stringWithQuotationMarks); + + return result; +} + +bool Parser::parseComma(bool allowNoComma) throw(GsmException) +{ + if (nextChar() != ',') + if(allowNoComma) + { + putBackChar(); + return false; + } + else + throwParseException(_("expected comma")); + return true; +} + +string Parser::parseEol() throw(GsmException) +{ + string result; + int c; + while ((c = nextChar()) != -1) result += c; + return result; +} + +void Parser::checkEol() throw(GsmException) +{ + if (nextChar() != -1) + { + putBackChar(); + throwParseException(_("expected end of line")); + } +} + +string Parser::getEol() +{ + string result; + int c; + unsigned int saveI = _i; + bool saveEos = _eos; + while ((c = nextChar()) != -1) result += c; + _i = saveI; + _eos = saveEos; + return result; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_parser.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_parser.h new file mode 100644 index 0000000000..8404f9f1cb --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_parser.h @@ -0,0 +1,125 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_parser.h +// * +// * Purpose: Parser to parse MA/TA result strings +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 13.5.1999 +// ************************************************************************* + +#ifndef GSM_PARSER_H +#define GSM_PARSER_H + +#include +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + class Parser : public RefBase + { + private: + unsigned int _i; // index into _s, next character + string _s; // string to parse + bool _eos; // true if end-of-string reached in nextChar() + + // return next character or -1 if end of string + int nextChar(bool skipWhiteSpace = true); + + // "puts back" a character + void putBackChar() {if (! _eos) --_i;} + + // check for empty parameter (ie. "," or end of string) + // skips white space + // returns true if no parameter + // or throw an GsmException if allowNoParameter == false + bool checkEmptyParameter(bool allowNoParameter) throw(GsmException); + + // parse a string (like "string") + // throw an exception if not well-formed + string parseString2(bool stringWithQuotationMarks) throw(GsmException); + + // parse a int (like 1234) + // throw an exception if not well-formed + int parseInt2() throw(GsmException); + + // throw a parser exception + void throwParseException(string message = "") throw(GsmException); + + public: + Parser(string s); + + // the following functions skip white space + // parse a character, if absent throw a GsmException + // return false if allowNoChar == true and character not encountered + bool parseChar(char c, bool allowNoChar = false) throw(GsmException); + + // parse a list of the form "("ABC", DEF")" + // the list can be empty (ie. == "" ) if allowNoList == true + vector parseStringList(bool allowNoList = false) + throw(GsmException); + + // parse a list of the form "(12, 14)" or "(1-4, 10)" + // the result is returned as a bit vector where for each integer + // in the list and/or range(s) a bit is set + // the list can be empty (ie. == "") if allowNoList == true + vector parseIntList(bool allowNoList = false) + throw(GsmException); + + // parse a list of parameter ranges (see below) + // the list can be empty (ie. == "" ) if allowNoList == true + vector parseParameterRangeList(bool allowNoList = false) + throw(GsmException); + + // parse a string plus its valid integer range of the + // form "("string",(1-125))" + // the parameter range may be absent if allowNoParameterRange == true + ParameterRange parseParameterRange(bool allowNoParameterRange = false) + throw(GsmException); + + // parse an integer range of the form "(1-125)" + // the range may be absent if allowNoRange == true + // then IntRange::_high and _low are set to NOT_SET + // the range may be short if allowNonRange == true + // then IntRange::_high is set to NOT_SET + IntRange parseRange(bool allowNoRange = false, bool allowNonRange = false) + throw(GsmException); + + // parse an integer of the form "1234" + // allow absent int if allowNoInt == true + // then it returns NOT_SET + int parseInt(bool allowNoInt = false) throw(GsmException); + + // parse a string of the form ""string"" + // allow absent string if allowNoString == true + // then it returns "" + // if stringWithQuotationMarks == true the string may contain """ + // the string is then parsed till the end of the line + string parseString(bool allowNoString = false, + bool stringWithQuotationMarks = false) + throw(GsmException); + + // parse a single "," + // the comma may be absent if allowNoComma == true + // returns true if there was a comma + bool parseComma(bool allowNoComma = false) throw(GsmException); + + // parse till end of line, return result without whitespace + string parseEol() throw(GsmException); + + // check that end of line is reached + void checkEol() throw(GsmException); + + // return string till end of line without whitespace + // (does not change internal state) + string getEol(); + }; +}; + +#endif // GSM_PARSER_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_phonebook.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_phonebook.cc new file mode 100644 index 0000000000..24d89e805d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_phonebook.cc @@ -0,0 +1,585 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_phonebook.cc +// * +// * Purpose: Phonebook management functions +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 6.5.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +// PhonebookEntry members + +PhonebookEntry::PhonebookEntry(const PhonebookEntryBase &e) + throw(GsmException) : _cached(true), _myPhonebook(NULL) +{ + set(e.telephone(), e.text(), e.index(), e.useIndex()); +} + +void PhonebookEntry::set(string telephone, string text, int index, + bool useIndex) + throw(GsmException) +{ + checkTextAndTelephone(text, telephone); + + if (_myPhonebook != NULL) + { + if (text.length() > _myPhonebook->getMaxTextLen()) + throw GsmException( + stringPrintf(_("length of text '%s' exceeds maximum text " + "length (%d characters) of phonebook '%s'"), + text.c_str(), _myPhonebook->getMaxTextLen(), + _myPhonebook->name().c_str()), + ParameterError); + + if (telephone.length() > _myPhonebook->getMaxTelephoneLen()) + throw GsmException( + stringPrintf(_("length of telephone number '%s' " + "exceeds maximum telephone number " + "length (%d characters) of phonebook '%s'"), + telephone.c_str(), _myPhonebook->getMaxTelephoneLen(), + _myPhonebook->name().c_str()), + ParameterError); + + _myPhonebook->writeEntry(_index, telephone, text); + } + else + _index = index; + + _useIndex = useIndex; + _cached = true; + _telephone = telephone; + _text = text; + _changed = true; +} + +string PhonebookEntry::text() const throw(GsmException) +{ + if (! cached()) + { + assert(_myPhonebook != NULL); + // these operations are at least "logically const" + PhonebookEntry *thisEntry = const_cast(this); + _myPhonebook->readEntry(_index, thisEntry->_telephone, thisEntry->_text); + thisEntry->_cached = true; + } + return _text; +} + +string PhonebookEntry::telephone() const throw(GsmException) +{ + if (! cached()) + { + assert(_myPhonebook != NULL); + // these operations are at least "logically const" + PhonebookEntry *thisEntry = const_cast(this); + _myPhonebook->readEntry(_index, thisEntry->_telephone, thisEntry->_text); + thisEntry->_cached = true; + } + return _telephone; +} + +bool PhonebookEntry::cached() const +{ + if (_myPhonebook == NULL) + return _cached; + else + return _cached && _myPhonebook->_useCache; +} + +PhonebookEntry::PhonebookEntry(const PhonebookEntry &e) throw(GsmException) +{ + set(e._telephone, e._text, e._index, e._useIndex); +} + +PhonebookEntry &PhonebookEntry::operator=(const PhonebookEntry &e) + throw(GsmException) +{ + set(e._telephone, e._text, e._index, e._useIndex); + return *this; +} + +// Phonebook members + +int Phonebook::parsePhonebookEntry(string response, + string &telephone, string &text) +{ + // this is a workaround for a bug that occurs with my ME/TA combination + // some texts are truncated and don't have a trailing " + if (response.length() > 0 && response[response.length() - 1] != '"') + response += '"'; + Parser p(response); + + int index = p.parseInt(); + p.parseComma(); + + // handle case of empty entry + if (p.getEol().substr(0, 5) == "EMPTY") + { + telephone = ""; + text = ""; + return index; + } + + telephone = p.parseString(); + p.parseComma(); + unsigned int numberFormat = p.parseInt(); + if (numberFormat != UnknownNumberFormat && + numberFormat != InternationalNumberFormat) + cerr << "*** GSMLIB WARNING: Unexpected number format when reading from " + << "phonebook: " << numberFormat << " ***" << endl; + p.parseComma(); + text = p.parseString(false, true); + if (lowercase(_myMeTa.getCurrentCharSet()) == "gsm") + text = gsmToLatin1(text); + if (numberFormat == InternationalNumberFormat) + { + // skip leading "+" signs that may already exist + while (telephone.length() > 0 && telephone[0] == '+') + telephone = telephone.substr(1); + telephone = "+" + telephone; + } + + return index; +} + +void Phonebook::readEntry(int index, string &telephone, string &text) + throw(GsmException) +{ + // select phonebook + _myMeTa.setPhonebook(_phonebookName); + + // read entry + string response = _at->chat("+CPBR=" + intToStr(index), "+CPBR:", + false, // dont't ignore errors + true); // but accept empty responses + // (the latter is necessary for some mobile phones that return nothing + // if the entry is empty) + + if (response.length() == 0) // OK phone returned empty response + { + telephone = text = ""; // then the entry is empty as well + } + else + parsePhonebookEntry(response, telephone, text); + +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "*** Reading PB entry " << index << " number " << telephone + << " text " << text << endl; +#endif +} + +void Phonebook::findEntry(string text, int &index, string &telephone) + throw(GsmException) +{ + // select phonebook + _myMeTa.setPhonebook(_phonebookName); + + // read entry + string response = _at->chat("+CPBF=\"" + text + "\"", "+CPBF:", + false, // dont't ignore errors + true); // but accept empty responses + // (the latter is necessary for some mobile phones that return nothing + // if the entry is empty) + + if (response.length() == 0) // OK phone returned empty response + { + telephone = ""; // then the entry is empty as well + index = 0; + } + else + index=parsePhonebookEntry(response, telephone, text); + +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "*** Finding PB entry " << text << " number " << telephone + << " index " << index << endl; +#endif +} + +void Phonebook::writeEntry(int index, string telephone, string text) + throw(GsmException) +{ +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "*** Writing PB entry #" << index << " number '" << telephone + << "' text '" << text << "'" << endl; +#endif + // select phonebook + _myMeTa.setPhonebook(_phonebookName); + + // write entry + string s; + if (telephone == "" && text == "") + { + ostrstream os; + os << "+CPBW=" << index; + os << ends; + char *ss = os.str(); + s = string(ss); + delete[] ss; + } + else + { + int type; + if (telephone.find('+') == string::npos) + type = UnknownNumberFormat; + else + type = InternationalNumberFormat; + string gsmText = text; + if (lowercase(_myMeTa.getCurrentCharSet()) == "gsm") + gsmText = latin1ToGsm(gsmText); + ostrstream os; + os << "+CPBW=" << index << ",\"" << telephone << "\"," << type + << ",\""; + os << ends; + char *ss = os.str(); + s = string(ss); + delete[] ss; + // this cannot be added with ostrstream because the gsmText can + // contain a zero (GSM default alphabet for '@') + s += gsmText + "\""; + } + _at->chat(s); +} + +Phonebook::iterator Phonebook::insertFirstEmpty(string telephone, string text) + throw(GsmException) +{ + for (int i = 0; i < _maxSize; i++) + if (_phonebook[i].empty()) + { + _phonebook[i].set(telephone, text); + adjustSize(1); + return begin() + i; + } + throw GsmException(_("phonebook full"), OtherError); +} + +Phonebook::iterator Phonebook::insert(const string telephone, + const string text, + const int index) +{ + for (int i = 0; i < _maxSize; i++) + if (_phonebook[i].index() == index) + if (_phonebook[i].empty()) + { + _phonebook[i].set(telephone, text); + adjustSize(1); + return begin() + i; + } + else + throw GsmException(_("attempt to overwrite phonebook entry"), + OtherError); + return end(); +} + +Phonebook::Phonebook(string phonebookName, Ref at, MeTa &myMeTa, + bool preload) throw(GsmException) : + _phonebookName(phonebookName), _at(at), _myMeTa(myMeTa), _useCache(true) +{ + // select phonebook + _myMeTa.setPhonebook(_phonebookName); + + // query size and maximum capacity of phonebook + _size = -1; // -1 means not known yet + _maxSize = -1; + Parser q(_at->chat("+CPBS?", "+CPBS:")); + string dummy = q.parseString(); + if (q.parseComma(true)) // this means that + { // used and total result is supported by ME + _size = q.parseInt(); + q.parseComma(); + _maxSize = q.parseInt(); + } + + // get basic phonebook info from ME + Parser p(_at->chat("+CPBR=?", "+CPBR:")); + + // get index of actually available entries in the phonebook + vector availablePositions = p.parseIntList(); + p.parseComma(); + _maxNumberLength = p.parseInt(); + p.parseComma(); + _maxTextLength = p.parseInt(); + + // find out capacity of phonebook in ME + // Note: The phonebook in the ME may be sparse, eg. the range of + // allowed index numbers may be something like (3-4, 20-100, 120). + // The standard allows this, even though it is unlikely to be + // implemented like that by anyone. + // In memory we store only phonebook entries that may actually be + // used, ie. the phonebook in memory is not sparse. + // Each entry has a member _index that corresponds to the index in the ME. + if (_maxSize == -1) + { + _maxSize = 0; + for (vector::iterator i = availablePositions.begin(); + i != availablePositions.end(); ++i) + if (*i) ++_maxSize; + } + + // for use with preload below + int *meToPhonebookIndexMap = + (int*)alloca(sizeof(int) * (availablePositions.size() + 1)); + + // initialize phone book entries + if (_maxSize == 0) + _phonebook = NULL; + else + _phonebook = new PhonebookEntry[_maxSize]; + int nextAvailableIndex = 0; + int i; + for (i = 0; i < _maxSize; i++) + { + while (! availablePositions[nextAvailableIndex]) + nextAvailableIndex++; + _phonebook[i]._index = nextAvailableIndex; + _phonebook[i]._cached = false; + _phonebook[i]._myPhonebook = this; + meToPhonebookIndexMap[nextAvailableIndex++] = i; + } + + // find out first index number of phonebook + int firstIndex = -1; + for (i = 0; i < _maxSize; i++) + if (availablePositions[i]) + { + firstIndex = i; + break; + } + + // preload phonebook + // Note: this contains a workaround for the bug that + // some MEs can not return the entire phonebook with one AT command + // To detect this condition, _size must be known + // also, this code only handles non-sparse phonebooks + if (preload && _size != -1 && + (int)availablePositions.size() == _maxSize + firstIndex) + { + int entriesRead = 0; + int startIndex = firstIndex; + + while (entriesRead < _size) + { + reportProgress(0, _maxSize); // chatv also calls reportProgress() + vector responses = + _at->chatv("+CPBR=" + intToStr(startIndex) + + "," + intToStr(_maxSize + firstIndex - 1), + "+CPBR:", true); + + // this means that we have read nothing even though not all + // entries have been retrieved (entriesRead < _size) + // this could be due to a malfunction of the ME... + // anyway, missing entries can be read later by readEntry() + if (responses.size() == 0) + { +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "*** error when preloading phonebook: " + "not all entries returned" << endl; +#endif + break; + } + + for (vector::iterator i = responses.begin(); + i != responses.end(); ++i) + { + string telephone, text; + int meIndex = parsePhonebookEntry(*i, telephone, text); + _phonebook[meToPhonebookIndexMap[meIndex]]._cached = true; + _phonebook[meToPhonebookIndexMap[meIndex]]._telephone = telephone; + _phonebook[meToPhonebookIndexMap[meIndex]]._text = text; + assert(_phonebook[meToPhonebookIndexMap[meIndex]]._index == meIndex); + + ++entriesRead; + startIndex = meIndex + 1; +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "*** Preloading PB entry " << meIndex + << " number " << telephone + << " text " << text << endl; +#endif + } + } + } +} + +Phonebook::iterator Phonebook::begin() +{ + return &_phonebook[0]; +} + +Phonebook::const_iterator Phonebook::begin() const +{ + return &_phonebook[0]; +} + +Phonebook::iterator Phonebook::end() +{ + return &_phonebook[_maxSize]; +} + +Phonebook::const_iterator Phonebook::end() const +{ + return &_phonebook[_maxSize]; +} + +Phonebook::reference Phonebook::operator[](int n) +{ + return _phonebook[n]; +} + +Phonebook::const_reference Phonebook::operator[](int n) const +{ + return _phonebook[n]; +} + +Phonebook::reference Phonebook::front() +{ + return _phonebook[0]; +} + +Phonebook::const_reference Phonebook::front() const +{ + return _phonebook[0]; +} + +Phonebook::reference Phonebook::back() +{ + return _phonebook[_maxSize - 1]; +} + +Phonebook::const_reference Phonebook::back() const +{ + return _phonebook[_maxSize - 1]; +} + +int Phonebook::size() const throw(GsmException) +{ + if (_size != -1) + return _size; + else + { + int result = 0; + for (int i = 0; i < _maxSize; i++) + if (! _phonebook[i].empty()) + result++; + Phonebook *thisPhonebook = const_cast(this); + thisPhonebook->_size = result; + return result; + } +} + +Phonebook::iterator Phonebook::insert(iterator position, + const PhonebookEntry& x) + throw(GsmException) +{ + if (x.useIndex() && x.index() != -1) + return insert(x.telephone(), x.text(), x.index()); + else + return insertFirstEmpty(x.telephone(), x.text()); +} + +void Phonebook::insert (iterator pos, int n, const PhonebookEntry& x) + throw(GsmException) +{ + for (int i = 0; i < n; i++) + if (x.useIndex() && x.index() != -1) + insert(x.telephone(), x.text(), x.index()); + else + insertFirstEmpty(x.telephone(), x.text()); +} + +void Phonebook::insert (iterator pos, long n, const PhonebookEntry& x) + throw(GsmException) +{ + for (long i = 0; i < n; i++) + if (x.useIndex() && x.index() != -1) + insert(x.telephone(), x.text(), x.index()); + else + insertFirstEmpty(x.telephone(), x.text()); +} + +Phonebook::iterator Phonebook::erase(iterator position) + throw(GsmException) +{ + if (! position->empty()) + { + position->set("", ""); + adjustSize(-1); + } + return position + 1; +} + +Phonebook::iterator Phonebook::erase(iterator first, iterator last) + throw(GsmException) +{ + iterator i; + for (i = first; i != last; ++i) + erase(i); + return i; +} + +void Phonebook::clear() throw(GsmException) +{ + for (iterator i = begin(); i != end(); ++i) + erase(i); +} + +Phonebook::iterator Phonebook::find(string text) throw(GsmException) +{ + int index; + string telephone; + + int i; + for (i = 0; i < _maxSize; i++) + if (_phonebook[i].text() == text) + return begin() + i; + + findEntry(text, index, telephone); + + for (i = 0; i < _maxSize; i++) + if (_phonebook[i].index() == index) + if (_phonebook[i].cached()) + { + // if entry was already (= cached) and is now different + // the SIM card or it's contents were changed + if (_phonebook[i]._telephone != telephone || + _phonebook[i]._text != text) + throw GsmException(_("SIM card changed while accessing phonebook"), + OtherError); + } + else + { + _phonebook[i]._cached = true; + _phonebook[i]._telephone = telephone; + _phonebook[i]._text = text; + return begin() + i; + } + return end(); +} + +Phonebook::~Phonebook() +{ + delete []_phonebook; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_phonebook.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_phonebook.h new file mode 100644 index 0000000000..4999da532e --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_phonebook.h @@ -0,0 +1,195 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_phonebook.h +// * +// * Purpose: Phonebook management functions +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 4.5.1999 +// ************************************************************************* + +#ifndef GSM_PHONEBOOK_H +#define GSM_PHONEBOOK_H + +#include +#include +#include +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + // forward declarations + class Phonebook; + + // a single entry in the phonebook that corresponds to an ME entry + + class PhonebookEntry : public PhonebookEntryBase + { + private: + // this constructor is only used by Phonebook + PhonebookEntry() {} + bool _cached; // true, if this entry corresponds to info + // in the ME + Phonebook *_myPhonebook; + + public: + PhonebookEntry(string telephone, string text) : + PhonebookEntryBase(telephone, text), + _cached(true), _myPhonebook(NULL) {} + PhonebookEntry(const PhonebookEntryBase &e) throw(GsmException); + + // accessor functions, inherited from PhonebookEntryBase + // set() does not use the index argument + void set(string telephone, string text, int index = -1, + bool useIndex = false) + throw(GsmException); + string text() const throw(GsmException); + string telephone() const throw(GsmException); + + // return true if entry is cached (and caching is enabled) + bool cached() const; + + PhonebookEntry(const PhonebookEntry &e) throw(GsmException); + PhonebookEntry &operator=(const PhonebookEntry &e) throw(GsmException); + + virtual ~PhonebookEntry() {} + + friend class Phonebook; + }; + + // this class corresponds to a phonebook in the ME + // all functions directly update storage in the ME + // if the ME is exchanged, the storage may become corrupted because + // of internal buffering in the Phonebook class + + class Phonebook : public RefBase, public NoCopy + { + public: + // iterator defs + typedef PhonebookEntry *iterator; + typedef const PhonebookEntry *const_iterator; + typedef PhonebookEntry &reference; + typedef const PhonebookEntry &const_reference; + + private: + PhonebookEntry *_phonebook; // array of size _maxSize of entries + int _maxSize; // maximum size of pb (-1 == not known yet) + int _size; // current size of pb (-1 == not known yet) + string _phonebookName; // name of the phonebook, 2-byte like "ME" + unsigned int _maxNumberLength; // maximum length of telephone number + unsigned int _maxTextLength; // maximum length of descriptive text + Ref _at; // my GsmAt class + vector _positionMap; // maps in-memory index to ME index + MeTa &_myMeTa; // the MeTa object that created this Phonebook + bool _useCache; // true if entries should be cached + + // helper function, parse phonebook response returned by ME/TA + // returns index of entry + int parsePhonebookEntry(string response, string &telephone, string &text); + + // internal access functions + // read/write/find entry from/to ME + void readEntry(int index, string &telephone, string &text) + throw(GsmException); + void writeEntry(int index, string telephone, string text) + throw(GsmException); + void findEntry(string text, int &index, string &telephone) + throw(GsmException); + + // adjust size only if it was set once + void adjustSize(int sizeAdjust) + { + if (_size != -1) _size += sizeAdjust; + } + + // insert into first empty position and return position where inserted + iterator insertFirstEmpty(const string telephone, const string text) + throw(GsmException); + + // insert into specified index position + iterator insert(const string telephone, const string text, + const int index); + + // used my class MeTa + // load phonebook name phonebookName, use AT handler at + // preload entire phonebook if preload == true + Phonebook(string phonebookName, Ref at, + MeTa &myMeTa, bool preload = false) throw(GsmException); + + public: + // set cache mode on or off + void setCaching(bool useCache) {_useCache = useCache;} + + // return name of this phonebook (2-character string) + string name() const {return _phonebookName;} + + // return maximum telephone number length + unsigned int getMaxTelephoneLen() const {return _maxNumberLength;} + + // return maximum entry description length + unsigned int getMaxTextLen() const { return _maxTextLength;} + + // phonebook traversal commands + // these are suitable to use stdc++ lib algorithms and iterators + // ME have fixed storage space implemented as memory slots + // that may either be empty or used + + // traversal commands + iterator begin(); + const_iterator begin() const; + iterator end(); + const_iterator end() const; + reference front(); + const_reference front() const; + reference back(); + const_reference back() const; + reference operator[](int n); + const_reference operator[](int n) const; + + // the size macros return the number of used entries + int size() const throw(GsmException); + int max_size() const {return _maxSize;} + int capacity() const {return _maxSize;} + bool empty() const throw(GsmException) {return size() == 0;} + + // insert iterators insert into the first empty cell regardless of position + // - existing iterators are not invalidated after an insert operation + // - return position where it was actually inserted (may be != position) + // - insert only writes to available positions + // - throw an exception if size() == max_size() (ie. not empty slots) + iterator insert(iterator position, const PhonebookEntry& x) + throw(GsmException); + + // insert n times, same procedure as above + void insert(iterator pos, int n, const PhonebookEntry& x) + throw(GsmException); + void insert(iterator pos, long n, const PhonebookEntry& x) + throw(GsmException); + + // erase operators set used slots to "empty" + iterator erase(iterator position) throw(GsmException); + iterator erase(iterator first, iterator last) throw(GsmException); + void clear() throw(GsmException); + + // finds an entry given the text + iterator find(string text) throw(GsmException); + + // destructor + virtual ~Phonebook(); + + friend class PhonebookEntry; + friend class MeTa; + }; + + // useful phonebook types + typedef Ref PhonebookRef; + typedef vector PhonebookVector; +}; + +#endif // GSM_PHONEBOOK_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_port.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_port.h new file mode 100644 index 0000000000..83c4edf60e --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_port.h @@ -0,0 +1,58 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_port.h +// * +// * Purpose: Abstract port definition +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 3.5.1999 +// ************************************************************************* + +#ifndef GSM_PORT_H +#define GSM_PORT_H + +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + // TA defaults + const int TIMEOUT_SECS = 60; + const char DEFAULT_INIT_STRING[] = "E0"; + const int DEFAULT_BAUD_RATE = 38400; + + class Port : public RefBase + { + public: + // read line from port(including eol characters) + virtual string getLine() throw(GsmException) =0; + + // write line to port + virtual void putLine(string line, + bool carriageReturn = true) throw(GsmException) =0; + + // wait for new data to become available, return after timeout + // if timeout == 0, wait forever + // return true if data available + virtual bool wait(GsmTime timeout) throw(GsmException) =0; + + // put back one byte that can be read by a subsequent call to readByte() + virtual void putBack(unsigned char c) =0; + + // read a single byte, return -1 if error or file closed + virtual int readByte() throw(GsmException) =0; + + // set timeout for the readByte(), getLine(), and putLine() functions + // (globally for ALL ports) + virtual void setTimeOut(unsigned int timeout) =0; + + virtual ~Port() {} + }; +}; + +#endif // GSM_PORT_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms.cc new file mode 100644 index 0000000000..e150423add --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms.cc @@ -0,0 +1,863 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sms.cc +// * +// * Purpose: SMS functions +// * (ETSI GSM 07.05) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 16.5.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +// local constants + +static const string dashes = +"---------------------------------------------------------------------------"; + +// SMSMessage members + +Ref SMSMessage::decode(string pdu, + bool SCtoMEdirection, + GsmAt *at) throw(GsmException) +{ + Ref result; + SMSDecoder d(pdu); + d.getAddress(true); + MessageType messageTypeIndicator = (MessageType)d.get2Bits(); // bits 0..1 + if (SCtoMEdirection) + // TPDUs from SC to ME + switch (messageTypeIndicator) + { + case SMS_DELIVER: + result = new SMSDeliverMessage(pdu); + break; + + case SMS_STATUS_REPORT: + result = new SMSStatusReportMessage(pdu); + break; + + case SMS_SUBMIT_REPORT: + // observed with Motorola Timeport 260, the SCtoMEdirection can + // be wrong in this case + if (at != NULL && at->getMeTa().getCapabilities()._wrongSMSStatusCode) + result = new SMSSubmitMessage(pdu); + else + result = new SMSSubmitReportMessage(pdu); + break; + + default: + throw GsmException(_("unhandled SMS TPDU type"), OtherError); + } + else + // TPDUs from ME to SC + switch (messageTypeIndicator) + { + case SMS_SUBMIT: + result = new SMSSubmitMessage(pdu); + break; + + case SMS_DELIVER_REPORT: + result = new SMSDeliverReportMessage(pdu); + break; + + case SMS_COMMAND: + result = new SMSCommandMessage(pdu); + break; + + default: + throw GsmException(_("unhandled SMS TPDU type"), OtherError); + } + result->_at = at; + return result; +} + +Ref SMSMessage::decode(istream& s) throw(gsmlib::GsmException) +{ + string pdu; + unsigned char ScToMe; + + s >> ScToMe; + s >> pdu; + + return decode(pdu,ScToMe=='S'); +} + +unsigned char SMSMessage::send(Ref &ackPdu) + throw(GsmException) +{ + if (_messageTypeIndicator != SMS_SUBMIT && + _messageTypeIndicator != SMS_COMMAND) + throw GsmException(_("can only send SMS-SUBMIT and SMS-COMMAND TPDUs"), + ParameterError); + + if (_at.isnull()) + throw GsmException(_("no device given for sending SMS"), ParameterError); + + string pdu = encode(); + Parser p(_at->sendPdu("+CMGS=" + + intToStr(pdu.length() / 2 - getSCAddressLen()), + "+CMGS:", pdu)); + unsigned char messageReference = p.parseInt(); + + if (p.parseComma(true)) + { + string pdu = p.parseEol(); + + // add missing service centre address if required by ME + if (! _at->getMeTa().getCapabilities()._hasSMSSCAprefix) + pdu = "00" + pdu; + + ackPdu = SMSMessage::decode(pdu); + } + else + ackPdu = SMSMessageRef(); + + return messageReference; +} + +unsigned char SMSMessage::send() throw(GsmException) +{ + SMSMessageRef mref; + return send(mref); +} + +unsigned int SMSMessage::getSCAddressLen() +{ + SMSEncoder e; + e.setAddress(_serviceCentreAddress, true); + return e.getLength(); +} + +unsigned char SMSMessage::userDataLength() const +{ + unsigned int udhl = _userDataHeader.length(); + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + return _userData.length() + (udhl ? ((1 + udhl) * 8 + 6) / 7 : 0); + else + return _userData.length() + (udhl ? (1 + udhl) : 0); +} + +ostream& SMSMessage::operator<<(ostream& s) +{ + unsigned char ScToMe; + + if (dynamic_cast(this) || + dynamic_cast(this) || + dynamic_cast(this)) + { + ScToMe = 'S'; + } + else if (dynamic_cast(this) || + dynamic_cast(this) || + dynamic_cast(this)) + { + ScToMe = 'M'; + } + else + { + throw GsmException(_("unhandled SMS TPDU type"), OtherError); + } + + s << ScToMe; + return s << encode(); +} + +// SMSMessage::SMSMessage(SMSMessage &m) +// { +// _at = m._at; + +// } + +// SMSMessage &SMSMessage::operator=(SMSMessage &m) +// { +// } + +SMSMessage::~SMSMessage() {} + +// SMSDeliverMessage members + +void SMSDeliverMessage::init() +{ + _messageTypeIndicator = SMS_DELIVER; + _moreMessagesToSend = false; + _replyPath = false; + _statusReportIndication = false; + _protocolIdentifier = 0; +} + +SMSDeliverMessage::SMSDeliverMessage() +{ + init(); +} + +SMSDeliverMessage::SMSDeliverMessage(string pdu) throw(GsmException) +{ + SMSDecoder d(pdu); + _serviceCentreAddress = d.getAddress(true); + _messageTypeIndicator = (MessageType)d.get2Bits(); // bits 0..1 + assert(_messageTypeIndicator == SMS_DELIVER); + _moreMessagesToSend = d.getBit(); // bit 2 + d.getBit(); // bit 3 + d.getBit(); // bit 4 + _statusReportIndication = d.getBit(); // bit 5 + bool userDataHeaderIndicator = d.getBit(); // bit 6 + _replyPath = d.getBit(); // bit 7 + _originatingAddress = d.getAddress(); + _protocolIdentifier = d.getOctet(); + _dataCodingScheme = d.getOctet(); + _serviceCentreTimestamp = d.getTimestamp(); + unsigned char userDataLength = d.getOctet(); + d.markSeptet(); + + if (userDataHeaderIndicator) + { + _userDataHeader.decode(d); + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + userDataLength -= ((_userDataHeader.length() + 1) * 8 + 6) / 7; + else + userDataLength -= ((string)_userDataHeader).length() + 1; + } + else + _userDataHeader = UserDataHeader(); + + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + { // userDataLength is length in septets + _userData = d.getString(userDataLength); + _userData = gsmToLatin1(_userData); + } + else + { // userDataLength is length in octets + unsigned char *s = + (unsigned char*)alloca(sizeof(unsigned char) * userDataLength); + d.getOctets(s, userDataLength); + _userData.assign((char*)s, (unsigned int)userDataLength); + } +} + +string SMSDeliverMessage::encode() +{ + SMSEncoder e; + e.setAddress(_serviceCentreAddress, true); + e.set2Bits(_messageTypeIndicator); // bits 0..1 + e.setBit(_moreMessagesToSend); // bit 2 + e.setBit(); // bit 3 + e.setBit(); // bit 4 + e.setBit(_statusReportIndication); // bit 5 + e.setBit(_userDataHeader.length() != 0); // bit 6 + e.setBit(_replyPath); // bit 7 + e.setAddress(_originatingAddress); + e.setOctet(_protocolIdentifier); + e.setOctet(_dataCodingScheme); + e.setTimestamp(_serviceCentreTimestamp); + e.setOctet(userDataLength()); + e.markSeptet(); + if (_userDataHeader.length()) _userDataHeader.encode(e); + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + e.setString(latin1ToGsm(_userData)); + else + e.setOctets((unsigned char*)_userData.data(), _userData.length()); + return e.getHexString(); +} + +string SMSDeliverMessage::toString() const +{ + ostrstream os; + os << dashes << endl + << _("Message type: SMS-DELIVER") << endl + << _("SC address: '") << _serviceCentreAddress._number << "'" << endl + << _("More messages to send: ") << _moreMessagesToSend << endl + << _("Reply path: ") << _replyPath << endl + << _("User data header indicator: ") + << (_userDataHeader.length()!=0) << endl + << _("Status report indication: ") << _statusReportIndication << endl + << _("Originating address: '") << _originatingAddress._number + << "'" << endl + << _("Protocol identifier: 0x") << hex + << (unsigned int)_protocolIdentifier << dec << endl + << _("Data coding scheme: ") << _dataCodingScheme.toString() << endl + << _("SC timestamp: ") << _serviceCentreTimestamp.toString() << endl + << _("User data length: ") << (int)userDataLength() << endl + << _("User data header: 0x") + << bufToHex((unsigned char*) + ((string)_userDataHeader).data(), + ((string)_userDataHeader).length()) + << endl + << _("User data: '") << _userData << "'" << endl + << dashes << endl << endl + << ends; + char *ss = os.str(); + string result(ss); + delete[] ss; + return result; +} + +Address SMSDeliverMessage::address() const +{ + return _originatingAddress; +} + +Ref SMSDeliverMessage::clone() +{ + Ref result = new SMSDeliverMessage(*this); + return result; +} + +// SMSSubmitMessage members + +void SMSSubmitMessage::init() +{ + // set everything to sensible default values + _messageTypeIndicator = SMS_SUBMIT; + _validityPeriodFormat = TimePeriod::Relative; + _validityPeriod._format = TimePeriod::Relative; + _validityPeriod._relativeTime = 168; // 2 days + _statusReportRequest = false; + _replyPath = false; + _rejectDuplicates = true; + _messageReference = 0; + _protocolIdentifier = 0; +} + +SMSSubmitMessage::SMSSubmitMessage() +{ + init(); +} + +SMSSubmitMessage::SMSSubmitMessage(string pdu) throw(GsmException) +{ + SMSDecoder d(pdu); + _serviceCentreAddress = d.getAddress(true); + _messageTypeIndicator = (MessageType)d.get2Bits(); // bits 0..1 + assert(_messageTypeIndicator == SMS_SUBMIT); + _rejectDuplicates = d.getBit(); // bit 2 + _validityPeriodFormat = (TimePeriod::Format)d.get2Bits(); // bits 3..4 + _statusReportRequest = d.getBit(); // bit 5 + bool userDataHeaderIndicator = d.getBit(); // bit 6 + _replyPath = d.getBit(); // bit 7 + _messageReference = d.getOctet(); + _destinationAddress = d.getAddress(); + _protocolIdentifier = d.getOctet(); + _dataCodingScheme = d.getOctet(); + if (_validityPeriodFormat != TimePeriod::NotPresent) + _validityPeriod = d.getTimePeriod(_validityPeriodFormat); + unsigned char userDataLength = d.getOctet(); + d.markSeptet(); + + if (userDataHeaderIndicator) + { + _userDataHeader.decode(d); + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + userDataLength -= ((_userDataHeader.length() + 1) * 8 + 6) / 7; + else + userDataLength -= ((string)_userDataHeader).length() + 1; + } + else + _userDataHeader = UserDataHeader(); + + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + { // userDataLength is length in septets + _userData = d.getString(userDataLength); + _userData = gsmToLatin1(_userData); + } + else + { // _userDataLength is length in octets + unsigned char *s = + (unsigned char*)alloca(sizeof(unsigned char) * userDataLength); + d.getOctets(s, userDataLength); + _userData.assign((char*)s, userDataLength); + } +} + +SMSSubmitMessage::SMSSubmitMessage(string text, string number) +{ + init(); + _destinationAddress = Address(number); + _userData = text; +} + +string SMSSubmitMessage::encode() +{ + SMSEncoder e; + e.setAddress(_serviceCentreAddress, true); + e.set2Bits(_messageTypeIndicator); // bits 0..1 + e.setBit(_rejectDuplicates); // bit 2 + e.set2Bits(_validityPeriodFormat); // bits 3..4 + e.setBit(_statusReportRequest); // bit 5 + bool userDataHeaderIndicator = _userDataHeader.length() != 0; + e.setBit(userDataHeaderIndicator); // bit 6 + e.setBit(_replyPath); // bit 7 + e.setOctet(_messageReference); + e.setAddress(_destinationAddress); + e.setOctet(_protocolIdentifier); + e.setOctet(_dataCodingScheme); + e.setTimePeriod(_validityPeriod); + e.setOctet(userDataLength()); + e.markSeptet(); + if (userDataHeaderIndicator) _userDataHeader.encode(e); + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + e.setString(latin1ToGsm(_userData)); + else + e.setOctets((unsigned char*)_userData.data(), _userData.length()); + return e.getHexString(); +} + +string SMSSubmitMessage::toString() const +{ + ostrstream os; + os << dashes << endl + << _("Message type: SMS-SUBMIT") << endl + << _("SC address: '") << _serviceCentreAddress._number << "'" << endl + << _("Reject duplicates: ") << _rejectDuplicates << endl + << _("Validity period format: "); + switch (_validityPeriodFormat) + { + case TimePeriod::NotPresent: + os << _("not present"); + break; + case TimePeriod::Relative: + os << _("relative"); + break; + case TimePeriod::Absolute: + os << _("absolute"); + break; + default: + os << _("unknown"); + break; + } + os << endl + << _("Reply path: ") << _replyPath << endl + << _("User data header indicator: ") + << (_userDataHeader.length()!=0) << endl + << _("Status report request: ") << _statusReportRequest << endl + << _("Message reference: ") << (unsigned int)_messageReference << endl + << _("Destination address: '") << _destinationAddress._number + << "'" << endl + << _("Protocol identifier: 0x") << hex + << (unsigned int)_protocolIdentifier << dec << endl + << _("Data coding scheme: ") << _dataCodingScheme.toString() << endl + << _("Validity period: ") << _validityPeriod.toString() << endl + << _("User data length: ") << (int)userDataLength() << endl + << _("User data header: 0x") << bufToHex((unsigned char*) + ((string)_userDataHeader).data(), + _userDataHeader.length()) + << endl + << _("User data: '") << _userData << "'" << endl + << dashes << endl << endl + << ends; + char *ss = os.str(); + string result(ss); + delete[] ss; + return result; +} + +Address SMSSubmitMessage::address() const +{ + return _destinationAddress; +} + +Ref SMSSubmitMessage::clone() +{ + Ref result = new SMSSubmitMessage(*this); + return result; +} + +// SMSStatusReportMessage members + +void SMSStatusReportMessage::init() +{ + _messageTypeIndicator = SMS_STATUS_REPORT; + _moreMessagesToSend = false; + _statusReportQualifier = false; + _messageReference = 0; + _status = SMS_STATUS_RECEIVED; +} + +SMSStatusReportMessage::SMSStatusReportMessage(string pdu) throw(GsmException) +{ + SMSDecoder d(pdu); + _serviceCentreAddress = d.getAddress(true); + _messageTypeIndicator = (MessageType)d.get2Bits(); // bits 0..1 + assert(_messageTypeIndicator == SMS_STATUS_REPORT); + _moreMessagesToSend = d.getBit(); // bit 2 + d.getBit(); // bit 3 + d.getBit(); // bit 4 + _statusReportQualifier = d.getBit(); // bit 5 + _messageReference = d.getOctet(); + _recipientAddress = d.getAddress(); + _serviceCentreTimestamp = d.getTimestamp(); + _dischargeTime = d.getTimestamp(); + _status = d.getOctet(); +} + +string SMSStatusReportMessage::encode() +{ + SMSEncoder e; + e.setAddress(_serviceCentreAddress, true); + e.set2Bits(_messageTypeIndicator); // bits 0..1 + e.setBit(_moreMessagesToSend); // bit 2 + e.setBit(); // bit 3 + e.setBit(); // bit 4 + e.setBit(_statusReportQualifier); // bit 5 + e.setOctet(_messageReference); + e.setAddress(_recipientAddress); + e.setTimestamp(_serviceCentreTimestamp); + e.setTimestamp(_dischargeTime); + e.setOctet(_status); + return e.getHexString(); +} + +string SMSStatusReportMessage::toString() const +{ + ostrstream os; + os << dashes << endl + << _("Message type: SMS-STATUS-REPORT") << endl + << _("SC address: '") << _serviceCentreAddress._number << "'" << endl + << _("More messages to send: ") << _moreMessagesToSend << endl + << _("Status report qualifier: ") << _statusReportQualifier << endl + << _("Message reference: ") << (unsigned int)_messageReference << endl + << _("Recipient address: '") << _recipientAddress._number << "'" << endl + << _("SC timestamp: ") << _serviceCentreTimestamp.toString() << endl + << _("Discharge time: ") << _dischargeTime.toString() << endl + << _("Status: 0x") << hex << (unsigned int)_status << dec + << " '" << getSMSStatusString(_status) << "'" << endl + << dashes << endl << endl + << ends; + char *ss = os.str(); + string result(ss); + delete[] ss; + return result; +} + +Address SMSStatusReportMessage::address() const +{ + return _recipientAddress; +} + +Ref SMSStatusReportMessage::clone() +{ + Ref result = new SMSStatusReportMessage(*this); + return result; +} + +// SMSCommandMessage members + +void SMSCommandMessage::init() +{ + _messageTypeIndicator = SMS_COMMAND; + _messageReference = 0; + _statusReportRequest = true; + _protocolIdentifier = 0; + _commandType = EnquireSM; + _messageNumber = 0; + _commandDataLength = 0; +} + +SMSCommandMessage::SMSCommandMessage(string pdu) throw(GsmException) +{ + SMSDecoder d(pdu); + _serviceCentreAddress = d.getAddress(true); + _messageTypeIndicator = (MessageType)d.get2Bits(); // bits 0..1 + assert(_messageTypeIndicator == SMS_COMMAND); + d.getBit(); // bit 2 + d.getBit(); // bit 3 + d.getBit(); // bit 4 + _statusReportRequest = d.getBit(); // bit 5 + _messageReference = d.getOctet(); + _protocolIdentifier = d.getOctet(); + _commandType = d.getOctet(); + _messageNumber = d.getOctet(); + _destinationAddress = d.getAddress(); + _commandDataLength = d.getOctet(); + unsigned char *s = + (unsigned char*)alloca(sizeof(unsigned char) * _commandDataLength); + d.getOctets(s, _commandDataLength); +} + +string SMSCommandMessage::encode() +{ + SMSEncoder e; + e.setAddress(_serviceCentreAddress, true); + e.set2Bits(_messageTypeIndicator); // bits 0..1 + e.setBit(); // bit 2 + e.setBit(); // bit 3 + e.setBit(); // bit 4 + e.setBit(_statusReportRequest); // bit 5 + e.setOctet(_messageReference); + e.setOctet(_protocolIdentifier); + e.setOctet(_commandType); + e.setOctet(_messageNumber); + e.setAddress(_destinationAddress); + e.setOctet(_commandData.length()); + e.setOctets((const unsigned char*)_commandData.data(), + (short unsigned int)_commandData.length()); + return e.getHexString(); +} + +string SMSCommandMessage::toString() const +{ + ostrstream os; + os << dashes << endl + << _("Message type: SMS-COMMAND") << endl + << _("SC address: '") << _serviceCentreAddress._number << "'" << endl + << _("Message reference: ") << (unsigned int)_messageReference << endl + << _("Status report request: ") << _statusReportRequest << endl + << _("Protocol identifier: 0x") << hex + << (unsigned int)_protocolIdentifier << dec << endl + << _("Command type: 0x") << hex << (unsigned int)_commandType + << dec << endl + << _("Message number: ") << (unsigned int)_messageNumber << endl + << _("Destination address: '") << _destinationAddress._number + << "'" << endl + << _("Command data length: ") << (unsigned int)_commandDataLength << endl + << _("Command data: '") << _commandData << "'" << endl + << dashes << endl << endl + << ends; + char *ss = os.str(); + string result(ss); + delete[] ss; + return result; +} + +Address SMSCommandMessage::address() const +{ + return _destinationAddress; +} + +Ref SMSCommandMessage::clone() +{ + Ref result = new SMSCommandMessage(*this); + return result; +} + +// SMSDeliverReportMessage members + +void SMSDeliverReportMessage::init() +{ + _messageTypeIndicator = SMS_DELIVER_REPORT; + _protocolIdentifierPresent = false; + _dataCodingSchemePresent = false; + _userDataLengthPresent = false; +} + +SMSDeliverReportMessage::SMSDeliverReportMessage(string pdu) + throw(GsmException) +{ + SMSDecoder d(pdu); + _serviceCentreAddress = d.getAddress(true); + _messageTypeIndicator = (MessageType)d.get2Bits(); // bits 0..1 + assert(_messageTypeIndicator == SMS_DELIVER_REPORT); + d.alignOctet(); // skip to parameter indicator + _protocolIdentifierPresent = d.getBit(); // bit 0 + _dataCodingSchemePresent = d.getBit(); // bit 1 + _userDataLengthPresent = d.getBit(); // bit 2 + if (_protocolIdentifierPresent) + _protocolIdentifier = d.getOctet(); + if (_dataCodingSchemePresent) + _dataCodingScheme = d.getOctet(); + if (_userDataLengthPresent) + { + unsigned char userDataLength = d.getOctet(); + d.markSeptet(); + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + { + _userData = d.getString(userDataLength); + _userData = gsmToLatin1(_userData); + } + else + { // userDataLength is length in octets + unsigned char *s = + (unsigned char*)alloca(sizeof(unsigned char) * userDataLength); + d.getOctets(s, userDataLength); + _userData.assign((char*)s, userDataLength); + } + } +} + +string SMSDeliverReportMessage::encode() +{ + SMSEncoder e; + e.setAddress(_serviceCentreAddress, true); + e.set2Bits(_messageTypeIndicator); // bits 0..1 + e.alignOctet(); // skip to parameter indicator + e.setBit(_protocolIdentifierPresent); // bit 0 + e.setBit(_dataCodingSchemePresent); // bit 1 + e.setBit(_userDataLengthPresent); // bit 2 + if (_protocolIdentifierPresent) + e.setOctet(_protocolIdentifier); + if (_dataCodingSchemePresent) + e.setOctet(_dataCodingScheme); + if (_userDataLengthPresent) + { + unsigned char userDataLength = _userData.length(); + e.setOctet(userDataLength); + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + e.setString(latin1ToGsm(_userData)); + else + e.setOctets((unsigned char*)_userData.data(), userDataLength); + } + return e.getHexString(); +} + +string SMSDeliverReportMessage::toString() const +{ + ostrstream os; + os << dashes << endl + << _("Message type: SMS-DELIVER-REPORT") << endl + << _("SC address: '") << _serviceCentreAddress._number << "'" << endl + << _("Protocol identifier present: ") << _protocolIdentifierPresent + << endl + << _("Data coding scheme present: ") << _dataCodingSchemePresent << endl + << _("User data length present: ") << _userDataLengthPresent << endl; + if (_protocolIdentifierPresent) + os << _("Protocol identifier: 0x") << hex + << (unsigned int)_protocolIdentifier + << dec << endl; + if (_dataCodingSchemePresent) + os << _("Data coding scheme: ") << _dataCodingScheme.toString() << endl; + if (_userDataLengthPresent) + os << _("User data length: ") << (int)userDataLength() << endl + << _("User data: '") << _userData << "'" << endl; + os << dashes << endl << endl + << ends; + char *ss = os.str(); + string result(ss); + delete[] ss; + return result; +} + +Address SMSDeliverReportMessage::address() const +{ + assert(0); // not address, should not be in SMS store + return Address(); +} + +Ref SMSDeliverReportMessage::clone() +{ + Ref result = new SMSDeliverReportMessage(*this); + return result; +} + +// SMSSubmitReportMessage members + +void SMSSubmitReportMessage::init() +{ + _messageTypeIndicator = SMS_SUBMIT_REPORT; + _protocolIdentifierPresent = false; + _dataCodingSchemePresent = false; + _userDataLengthPresent = false; +} + +SMSSubmitReportMessage::SMSSubmitReportMessage(string pdu) throw(GsmException) +{ + SMSDecoder d(pdu); + _serviceCentreAddress = d.getAddress(true); + _messageTypeIndicator = (MessageType)d.get2Bits(); // bits 0..1 + assert(_messageTypeIndicator == SMS_SUBMIT_REPORT); + _serviceCentreTimestamp = d.getTimestamp(); + _protocolIdentifierPresent = d.getBit(); // bit 0 + _dataCodingSchemePresent = d.getBit(); // bit 1 + _userDataLengthPresent = d.getBit(); // bit 2 + if (_protocolIdentifierPresent) + _protocolIdentifier = d.getOctet(); + if (_dataCodingSchemePresent) + _dataCodingScheme = d.getOctet(); + if (_userDataLengthPresent) + { + unsigned char userDataLength = d.getOctet(); + d.markSeptet(); + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + { + _userData = d.getString(userDataLength); + _userData = gsmToLatin1(_userData); + } + else + { // _userDataLength is length in octets + unsigned char *s = + (unsigned char*)alloca(sizeof(unsigned char) * userDataLength); + d.getOctets(s, userDataLength); + _userData.assign((char*)s, userDataLength); + } + } +} + +string SMSSubmitReportMessage::encode() +{ + SMSEncoder e; + e.setAddress(_serviceCentreAddress, true); + e.set2Bits(_messageTypeIndicator); // bits 0..1 + e.setTimestamp(_serviceCentreTimestamp); + e.setBit(_protocolIdentifierPresent); // bit 0 + e.setBit(_dataCodingSchemePresent); // bit 1 + e.setBit(_userDataLengthPresent); // bit 2 + if (_protocolIdentifierPresent) + e.setOctet(_protocolIdentifier); + if (_dataCodingSchemePresent) + e.setOctet(_dataCodingScheme); + if (_userDataLengthPresent) + { + e.setOctet(userDataLength()); + if (_dataCodingScheme.getAlphabet() == DCS_DEFAULT_ALPHABET) + e.setString(latin1ToGsm(_userData)); + else + e.setOctets((unsigned char*)_userData.data(), _userData.length()); + } + return e.getHexString(); +} + +string SMSSubmitReportMessage::toString() const +{ + ostrstream os; + os << dashes << endl + << _("Message type: SMS-SUBMIT-REPORT") << endl + << _("SC address: '") << _serviceCentreAddress._number << "'" << endl + << _("SC timestamp: ") << _serviceCentreTimestamp.toString() << endl + << _("Protocol identifier present: ") << _protocolIdentifierPresent + << endl + << _("Data coding scheme present: ") << _dataCodingSchemePresent << endl + << _("User data length present: ") << _userDataLengthPresent << endl; + if (_protocolIdentifierPresent) + os << _("Protocol identifier: 0x") << hex + << (unsigned int)_protocolIdentifier + << dec << endl; + if (_dataCodingSchemePresent) + os << _("Data coding scheme: ") << _dataCodingScheme.toString() << endl; + if (_userDataLengthPresent) + os << _("User data length: ") << (int)userDataLength() << endl + << _("User data: '") << _userData << "'" << endl; + os << dashes << endl << endl + << ends; + char *ss = os.str(); + string result(ss); + delete[] ss; + return result; +} + +Address SMSSubmitReportMessage::address() const +{ + assert(0); // not address, should not be in SMS store + return Address(); +} + +Ref SMSSubmitReportMessage::clone() +{ + Ref result = new SMSSubmitReportMessage(*this); + return result; +} + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms.h new file mode 100644 index 0000000000..bd871391bb --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms.h @@ -0,0 +1,480 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sms.h +// * +// * Purpose: SMS functions +// * (ETSI GSM 07.05) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 16.5.1999 +// ************************************************************************* + +#ifndef GSM_SMS_H +#define GSM_SMS_H + +#include +#include +#include +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + // forward declarations + class SMSStore; + class SMSMessage; + + // this class represents a single SMS message + class SMSMessage : public RefBase + { + private: + Ref _at; // connection to the device + + public: + // possible values for message type indicator + enum MessageType {SMS_DELIVER = 0, SMS_DELIVER_REPORT = 0, + SMS_STATUS_REPORT = 2, SMS_COMMAND = 2, + SMS_SUBMIT = 1, SMS_SUBMIT_REPORT = 1}; + + protected: + // fields of the different TPDUs + // all PDUs + string _userData; + UserDataHeader _userDataHeader; + Address _serviceCentreAddress; + MessageType _messageTypeIndicator;// 2 bits + DataCodingScheme _dataCodingScheme; + + public: + // decode hexadecimal pdu string + // return SMSMessage of the appropriate type + // differentiate between SMS transfer directions SC to ME, ME to SC + // also give GsmAt object for send() + static Ref decode(string pdu, + bool SCtoMEdirection = true, + GsmAt *at = NULL) + throw(GsmException); + + static Ref decode(istream& s) throw(GsmException); + + // encode pdu, return hexadecimal pdu string + virtual string encode() = 0; + + // send this PDU + // returns message reference and ACK-PDU (if requested) + // only applicate to SMS-SUBMIT and SMS-COMMAND + unsigned char send(Ref &ackPdu) throw(GsmException); + + // same as above, but ACK-PDU is discarded + unsigned char send() throw(GsmException); + + // create textual representation of SMS + virtual string toString() const = 0; + + // return deep copy of this message + virtual Ref clone() = 0; + + // return length of SC address when encoded + unsigned int getSCAddressLen(); + + // accessor functions + MessageType messageType() const {return _messageTypeIndicator;} + Address serviceCentreAddress() const {return _serviceCentreAddress;} + + // provided for sorting messages by timestamp + virtual Timestamp serviceCentreTimestamp() const {return Timestamp();} + + // return recipient, destination etc. address (for sorting by address) + virtual Address address() const = 0; + + virtual void setUserData(string x) {_userData = x;} + virtual string userData() const {return _userData;} + + // return the size of user data (including user data header) + unsigned char userDataLength() const; + + // accessor functions + virtual void setUserDataHeader(UserDataHeader x) {_userDataHeader = x;} + virtual UserDataHeader userDataHeader() const {return _userDataHeader;} + + virtual DataCodingScheme dataCodingScheme() const + {return _dataCodingScheme;} + virtual void setDataCodingScheme(DataCodingScheme x) + {_dataCodingScheme = x;} + + void setServiceCentreAddress(Address &x) {_serviceCentreAddress = x;} + void setAt(Ref at) {_at = at;} + + virtual ~SMSMessage(); + + // print ASCII hex representation of message + ostream& operator<<(ostream& s); + + // copy constructor and assignment +// SMSMessage(SMSMessage &m); +// SMSMessage &operator=(SMSMessage &m); + + friend class SMSStore; + }; + + // SMS-DELIVER TPDU + class SMSDeliverMessage : public SMSMessage + { + private: + // SMS-DELIVER PDU members (see GSM 03.40 section 9.2.2.1) + bool _moreMessagesToSend; + bool _replyPath; + bool _statusReportIndication; + Address _originatingAddress; + unsigned char _protocolIdentifier; // octet + Timestamp _serviceCentreTimestamp; + + // initialize members to sensible values + void init(); + + public: + // constructor, sets sensible default values + SMSDeliverMessage(); + + // constructor with given pdu + SMSDeliverMessage(string pdu) throw(GsmException); + + // encode pdu, return hexadecimal pdu string + virtual string encode(); + + // create textual representation of SMS + virtual string toString() const; + + // inherited from SMSMessage + Address address() const; + Ref clone(); + + // accessor functions + bool moreMessagesToSend() const {return _moreMessagesToSend;} + bool replyPath() const {return _replyPath;} + bool statusReportIndication() const {return _statusReportIndication;} + Address originatingAddress() const {return _originatingAddress;} + unsigned char protocolIdentifier() const {return _protocolIdentifier;} + Timestamp serviceCentreTimestamp() const {return _serviceCentreTimestamp;} + + void setMoreMessagesToSend(bool x) {_moreMessagesToSend = x;} + void setReplyPath(bool x) {_replyPath = x;} + void setStatusReportIndication(bool x) {_statusReportIndication = x;} + void setOriginatingAddress(Address &x) {_originatingAddress = x;} + void setProtocolIdentifier(unsigned char x) {_protocolIdentifier = x;} + void setServiceCentreTimestamp(Timestamp &x) {_serviceCentreTimestamp = x;} + + virtual ~SMSDeliverMessage() {} + }; + + // SMS-SUBMIT TPDU + class SMSSubmitMessage : public SMSMessage + { + private: + // SMS-SUBMIT PDU (see GSM 03.40 section 9.2.2.2) + bool _rejectDuplicates; + TimePeriod::Format _validityPeriodFormat; // 2 bits + bool _replyPath; + bool _statusReportRequest; + unsigned char _messageReference; // integer + Address _destinationAddress; + unsigned char _protocolIdentifier; + TimePeriod _validityPeriod; + + // initialize members to sensible values + void init(); + + public: + // constructor, sets sensible default values + SMSSubmitMessage(); + + // constructor with given pdu + SMSSubmitMessage(string pdu) throw(GsmException); + + // convenience constructor + // given the text and recipient telephone number + SMSSubmitMessage(string text, string number); + + // encode pdu, return hexadecimal pdu string + virtual string encode(); + + // create textual representation of SMS + virtual string toString() const; + + // inherited from SMSMessage + Address address() const; + Ref clone(); + + // accessor functions + bool rejectDuplicates() const {return _rejectDuplicates;} + TimePeriod::Format validityPeriodFormat() const + {return _validityPeriodFormat;} + bool replyPath() const {return _replyPath;} + bool statusReportRequest() const {return _statusReportRequest;} + unsigned char messageReference() const {return _messageReference;} + Address destinationAddress() const {return _destinationAddress;} + unsigned char protocolIdentifier() const {return _protocolIdentifier;} + TimePeriod validityPeriod() const {return _validityPeriod;} + + void setRejectDuplicates(bool x) {_rejectDuplicates = x;} + void setValidityPeriodFormat(TimePeriod::Format &x) + {_validityPeriodFormat = x;} + void setReplyPath(bool x) {_replyPath = x;} + void setStatusReportRequest(bool x) {_statusReportRequest = x;} + void setMessageReference(unsigned char x) {_messageReference = x;} + void setDestinationAddress(Address &x) {_destinationAddress = x;} + void setProtocolIdentifier(unsigned char x) {_protocolIdentifier = x;} + void setValidityPeriod(TimePeriod &x) {_validityPeriod = x;} + + virtual ~SMSSubmitMessage() {} + }; + + // SMS-STATUS-REPORT TPDU + class SMSStatusReportMessage : public SMSMessage + { + private: + // SMS-STATUS-REPORT PDU (see GSM 03.40 section 9.2.2.3) + bool _moreMessagesToSend; + bool _statusReportQualifier; + unsigned char _messageReference; + Address _recipientAddress; + Timestamp _serviceCentreTimestamp; + Timestamp _dischargeTime; + unsigned char _status; // octet + + // initialize members to sensible values + void init(); + + public: + // constructor, sets sensible default values + SMSStatusReportMessage() {init();} + + // constructor with given pdu + SMSStatusReportMessage(string pdu) throw(GsmException); + + // encode pdu, return hexadecimal pdu string + virtual string encode(); + + // create textual representation of SMS + virtual string toString() const; + + // inherited from SMSMessage + Address address() const; + Ref clone(); + + // accessor functions + bool moreMessagesToSend() const {return _moreMessagesToSend;} + bool statusReportQualifier() const {return _statusReportQualifier;} + unsigned char messageReference() const {return _messageReference;} + Address recipientAddress() const {return _recipientAddress;} + Timestamp serviceCentreTimestamp() const {return _serviceCentreTimestamp;} + Timestamp dischargeTime() const {return _dischargeTime;} + unsigned char status() const {return _status;} + + void setMoreMessagesToSend(bool x) {_moreMessagesToSend = x;} + void setStatusReportQualifier(bool x) {_statusReportQualifier = x;} + void setMessageReference(unsigned char x) {_messageReference = x;} + void setRecipientAddress(Address x) {_recipientAddress = x;} + void setServiceCentreTimestamp(Timestamp x) {_serviceCentreTimestamp = x;} + void setDischargeTime(Timestamp x) {_serviceCentreTimestamp = x;} + void setStatus(unsigned char x) {_status = x;} + + virtual ~SMSStatusReportMessage() {} + }; + + // SMS-COMMAND TPDU + class SMSCommandMessage : public SMSMessage + { + public: + // command types, other values are reserved or SC-specific + enum CommandType {EnquireSM = 0, CancelStatusReportRequest = 1, + DeleteSubmittedSM = 2, EnalbeStatusReportRequest = 3}; + + private: + // SMS-COMMAND PDU (see GSM 03.40 section 9.2.2.4) + unsigned char _messageReference; + bool _statusReportRequest; + unsigned char _protocolIdentifier; + unsigned char _commandType; + unsigned char _messageNumber; + Address _destinationAddress; + unsigned char _commandDataLength; + string _commandData; + + // initialize members to sensible values + void init(); + + public: + // constructor, sets sensible default values + SMSCommandMessage() {init();} + + // constructor with given pdu + SMSCommandMessage(string pdu) throw(GsmException); + + // encode pdu, return hexadecimal pdu string + virtual string encode(); + + // create textual representation of SMS + virtual string toString() const; + + // inherited from SMSMessage + Address address() const; + Ref clone(); + + // accessor functions + unsigned char messageReference() const {return _messageReference;} + bool statusReportRequest() const {return _statusReportRequest;} + unsigned char protocolIdentifier() const {return _protocolIdentifier;} + unsigned char commandType() const {return _commandType;} + unsigned char messageNumber() const {return _messageNumber;} + Address destinationAddress() const {return _destinationAddress;} + unsigned char commandDataLength() const {return _commandDataLength;} + string commandData() const {return _commandData;} + + void setMessageReference(unsigned char x) {_messageReference = x;} + void setStatusReportRequest(bool x) {_statusReportRequest = x;} + void setProtocolIdentifier(unsigned char x) {_protocolIdentifier = x;} + void setCommandType(unsigned char x) {_commandType = x;} + void setMessageNumber(unsigned char x) {_messageNumber = x;} + void setDestinationAddress(Address &x) {_destinationAddress = x;} + void setCommandDataLength(unsigned char x) {_commandDataLength = x;} + void setCommandData(string x) {_commandData = x;} + + virtual ~SMSCommandMessage() {} + }; + + // SMS-DELIVER-REPORT TPDU for RP-ACK + class SMSDeliverReportMessage : public SMSMessage + { + private: + // SMS-DELIVER-REPORT PDU (see GSM 03.40 section 9.2.2.1a (II)) + bool _protocolIdentifierPresent; // parameter indicator + bool _dataCodingSchemePresent; + bool _userDataLengthPresent; + unsigned char _protocolIdentifier; + + // initialize members to sensible values + void init(); + + public: + // constructor, sets sensible default values + SMSDeliverReportMessage() {init();} + + // constructor with given pdu + SMSDeliverReportMessage(string pdu) throw(GsmException); + + // encode pdu, return hexadecimal pdu string + virtual string encode(); + + // create textual representation of SMS + virtual string toString() const; + + // inherited from SMSMessage + Address address() const; + Ref clone(); + + // accessor functions + bool protocolIdentifierPresent() const {return _protocolIdentifierPresent;} + bool dataCodingSchemePresent() const {return _dataCodingSchemePresent;} + bool userDataLengthPresent() const {return _userDataLengthPresent;} + unsigned char protocolIdentifier() const + {assert(_protocolIdentifierPresent); return _protocolIdentifier;} + DataCodingScheme dataCodingScheme() const + {assert(_dataCodingSchemePresent); return _dataCodingScheme;} + UserDataHeader userDataHeader() const + {assert(_userDataLengthPresent); return _userDataHeader;} + string userData() const + {assert(_userDataLengthPresent); return _userData;} + + void setProtocolIdentifier(unsigned char x) + {_protocolIdentifierPresent = true; _protocolIdentifier = x;} + void setDataCodingScheme(DataCodingScheme x) + {_dataCodingSchemePresent = true; _dataCodingScheme = x;} + void setUserDataHeader(UserDataHeader x) + { + _userDataLengthPresent = true; + _userDataHeader = x; + } + void setUserData(string x) + { + _userDataLengthPresent = true; + _userData = x; + } + + virtual ~SMSDeliverReportMessage() {} + }; + + // SMS-SUBMIT-REPORT TPDU for RP-ACK + class SMSSubmitReportMessage : public SMSMessage + { + private: + // SMS-SUBMIT-REPORT PDU (see GSM 03.40 section 9.2.2.2a (II)) + Timestamp _serviceCentreTimestamp; + bool _protocolIdentifierPresent; // parameter indicator + bool _dataCodingSchemePresent; + bool _userDataLengthPresent; + unsigned char _protocolIdentifier; + DataCodingScheme _dataCodingScheme; + + // initialize members to sensible values + void init(); + + public: + // constructor, sets sensible default values + SMSSubmitReportMessage() {init();} + + // constructor with given pdu + SMSSubmitReportMessage(string pdu) throw(GsmException); + + // encode pdu, return hexadecimal pdu string + virtual string encode(); + + // create textual representation of SMS + virtual string toString() const; + + // inherited from SMSMessage + Address address() const; + Ref clone(); + + // accessor functions + Timestamp serviceCentreTimestamp() const {return _serviceCentreTimestamp;} + bool protocolIdentifierPresent() const {return _protocolIdentifierPresent;} + bool dataCodingSchemePresent() const {return _dataCodingSchemePresent;} + bool userDataLengthPresent() const {return _userDataLengthPresent;} + unsigned char protocolIdentifier() const + {assert(_protocolIdentifierPresent); return _protocolIdentifier;} + DataCodingScheme dataCodingScheme() const + {assert(_dataCodingSchemePresent); return _dataCodingScheme;} + UserDataHeader userDataHeader() const + {assert(_userDataLengthPresent); return _userDataHeader;} + string userData() const + {assert(_userDataLengthPresent); return _userData;} + + void setServiceCentreTimestamp(Timestamp &x) {_serviceCentreTimestamp = x;} + void setProtocolIdentifier(unsigned char x) + {_protocolIdentifierPresent = true; _protocolIdentifier = x;} + void setDataCodingScheme(DataCodingScheme x) + {_dataCodingSchemePresent = true; _dataCodingScheme = x;} + void setUserDataHeader(UserDataHeader x) + { + _userDataLengthPresent = true; + _userDataHeader = x; + } + void setUserData(string x) + { + _userDataLengthPresent = true; + _userData = x; + } + virtual ~SMSSubmitReportMessage() {} + }; + + // some useful typdefs + typedef Ref SMSMessageRef; +}; + +#endif // GSM_SMS_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_codec.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_codec.cc new file mode 100644 index 0000000000..cdcb0032bc --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_codec.cc @@ -0,0 +1,702 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sms_codec.cc +// * +// * Purpose: Coder and Encoder for SMS TPDUs +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 17.5.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include +#include +#include +#ifdef HAVE_STRING_H +#include +#endif +#include +#include +using namespace std; +using namespace gsmlib; + +// Address members + +Address::Address(string number) : _plan(ISDN_Telephone) +{ + number = removeWhiteSpace(number); + if (number.length() > 0 && number[0] == '+') + { + _type = International; + _number = number.substr(1, number.length() - 1); + } + else + { + _type = Unknown; + _number = number; + } +} + +string Address::toString() const +{ + if (_type == International) + return "+" + _number; + else + return _number; +} + +bool gsmlib::operator<(const Address &x, const Address &y) +{ + // normalize numbers according to the following two rules: + // - prepend "+" if international number + // - append 0s to the shorter number so that both numbers have equal length + string xnumber = x._number; + string ynumber = y._number; + static string twenty0s = "00000000000000000000"; + + if (x._type == Address::International) xnumber = "+" + xnumber; + if (y._type == Address::International) ynumber = "+" + ynumber; + + while (xnumber.length() != ynumber.length()) + if (xnumber.length() < ynumber.length()) + { + int diff = ynumber.length() - xnumber.length(); + xnumber += twenty0s.substr(0, (diff > 20 ? 20 : diff)); + } + else + { + int diff = xnumber.length() - ynumber.length(); + ynumber += twenty0s.substr(0, (diff > 20 ? 20 : diff)); + } + + return xnumber < ynumber; +} + +bool gsmlib::operator==(const Address &x, const Address &y) +{ + return x._number == y._number && x._plan == y._plan; +} + +// Timestamp members + +bool Timestamp::empty() const +{ + return _year == 0 && _month == 0 && _day == 0 && _hour == 0 && + _minute == 0 && _seconds == 0 && _timeZoneMinutes == 0; +} + +string Timestamp::toString(bool appendTimeZone) const +{ + short timeZoneMinutes = _timeZoneMinutes; + short timeZoneHours = timeZoneMinutes / 60; + timeZoneMinutes %= 60; + + // format date and time in a locale-specific way + struct tm t; + t.tm_sec = _seconds; + t.tm_min = _minute; + t.tm_hour = _hour; + t.tm_mon = _month - 1; + // year 2000 heuristics, SMSs cannot be older than start of GSM network + t.tm_year = _year < 80 ? _year + 100 : _year; + t.tm_mday = _day; + t.tm_isdst = -1; + t.tm_yday = 0; + t.tm_wday = 0; + +#ifdef BROKEN_STRFTIME + char formattedTime[1024]; + strftime(formattedTime, 1024, "%x %X", &t); +#else + int formattedTimeSize = strftime(NULL, INT_MAX, "%x %X", &t) + 1; + char *formattedTime = (char*)alloca(sizeof(char) * formattedTimeSize); + strftime(formattedTime, formattedTimeSize, "%x %X", &t); +#endif + + if (! appendTimeZone) + return formattedTime; + + ostrstream os; + os << formattedTime << " (" << (_negativeTimeZone ? '-' : '+') + << setfill('0') << setw(2) << timeZoneHours + << setw(2) << timeZoneMinutes << ')' << ends; + char *ss = os.str(); + string result(ss); + delete[] ss; + return result; +} + +bool gsmlib::operator<(const Timestamp &x, const Timestamp &y) +{ + // we don't take time zone info into account because + // - it's more complicated to compute + // - it might confuse the user for whom it's also too complicated + if (x._year < y._year) + return true; + else if (x._year > y._year) + return false; + + if (x._month < y._month) + return true; + else if (x._month > y._month) + return false; + + if (x._day < y._day) + return true; + else if (x._day > y._day) + return false; + + if (x._hour < y._hour) + return true; + else if (x._hour > y._hour) + return false; + + if (x._minute < y._minute) + return true; + else if (x._minute > y._minute) + return false; + + return x._seconds < y._seconds; +} + +bool gsmlib::operator==(const Timestamp &x, const Timestamp &y) +{ + // we don't take time zone info in order to be consistent with operator< + return x._year == y._year && x._month == y._month && x._day == y._day && + x._hour == y._hour && x._minute == y._minute && x._seconds == y._seconds; +} + +// TimePeriod members + +string TimePeriod::toString() const +{ + switch (_format) + { + case NotPresent: + return _("not present"); + case Relative: + { + ostrstream os; + if (_relativeTime <= 143) + os << ((int)_relativeTime + 1) * 5 << _(" minutes"); + else if (_relativeTime <= 167) + os << 12 * 60 + ((int)_relativeTime - 143) * 30 << _(" minutes"); + else if (_relativeTime <= 196) + os << (int)_relativeTime - 166 << _(" days"); + else if (_relativeTime <= 143) + os << (int)_relativeTime - 192 << _(" weeks"); + os << ends; + char *ss = os.str(); + string result(ss); + delete[] ss; + return result; + } + case Absolute: + return _absoluteTime.toString(); + default: + return _("unknown"); + } +} + +// DataCodingScheme members + +string DataCodingScheme::toString() const +{ + string result; + if (compressed()) result += _("compressed "); + if (messageWaitingIndication()) + switch (getMessageWaitingType()) + { + case DCS_VOICEMAIL_MESSAGE_WAITING: + result += _("voicemail message waiting"); + break; + case DCS_FAX_MESSAGE_WAITING: + result += _("fax message waiting"); + break; + case DCS_ELECTRONIC_MAIL_MESSAGE_WAITING: + result += _("electronic mail message waiting"); + break; + case DCS_OTHER_MESSAGE_WAITING: + result += _("other message waiting"); + break; + } + else + switch (getAlphabet()) + { + case DCS_DEFAULT_ALPHABET: + result += _("default alphabet"); + break; + case DCS_EIGHT_BIT_ALPHABET: + result += _("8-bit alphabet"); + break; + case DCS_SIXTEEN_BIT_ALPHABET: + result += _("16-bit alphabet"); + break; + case DCS_RESERVED_ALPHABET: + result += _("reserved alphabet"); + break; + } + return result; +} + +// SMSDecoder members + +SMSDecoder::SMSDecoder(string pdu) : _bi(0), _septetStart(NULL) +{ + _p = new unsigned char[pdu.length() / 2]; + _op = _p; + if (! hexToBuf(pdu, _p)) + throw GsmException(_("bad hexadecimal PDU format"), SMSFormatError); + _maxop = _op + pdu.length() / 2; +} + +void SMSDecoder::alignOctet() +{ + if (_bi != 0) + { + _bi = 0; + ++_op; + } +} + +void SMSDecoder::alignSeptet() +{ + assert(_septetStart != NULL); + while (((_op - _septetStart) * 8 + _bi) % 7 != 0) getBit(); +} + +unsigned char SMSDecoder::get2Bits() +{ + unsigned char result = getBit(); + return result | (getBit() << 1); +} + +unsigned char SMSDecoder::getOctet() +{ + alignOctet(); + if (_op >= _maxop) + throw GsmException(_("premature end of PDU"), SMSFormatError); + return *_op++; +} + +void SMSDecoder::getOctets(unsigned char* octets, unsigned short length) +{ + alignOctet(); + for (unsigned short i = 0; i < length; ++i) + { + if (_op >= _maxop) + throw GsmException(_("premature end of PDU"), SMSFormatError); + *octets++ = *_op++; + } +} + +string SMSDecoder::getSemiOctets(unsigned short length) +{ + string result; + result.reserve(length); + alignOctet(); + for (unsigned short i = 0; i < length; ++i) + { + if (_bi == 0) + { + if (_op >= _maxop) + throw GsmException(_("premature end of PDU"), SMSFormatError); + // bits 0..3 are most significant + result += '0' + (*_op & 0xf); + _bi = 4; + } + else + { + if (_op >= _maxop) + throw GsmException(_("premature end of PDU"), SMSFormatError); + // bits 4..7 are least significant, skip 0xf digit + if ((*_op & 0xf0) != 0xf0) + result += '0' + (*_op >> 4); + _bi = 0; + ++_op; + } + } + alignOctet(); + return result; +} + +unsigned long SMSDecoder::getSemiOctetsInteger(unsigned short length) +{ + unsigned long result = 0; + alignOctet(); + for (unsigned short i = 0; i < length; ++i) + { + if (_bi == 0) + { + if (_op >= _maxop) + throw GsmException(_("premature end of PDU"), SMSFormatError); + // bits 0..3 are most significant + result = result * 10 + (*_op & 0xf); + _bi = 4; + } + else + { + if (_op >= _maxop) + throw GsmException(_("premature end of PDU"), SMSFormatError); + // bits 4..7 are least significant, skip 0xf digit + if ((*_op & 0xf0) != 0xf0) + result = result * 10 + (*_op >> 4); + _bi = 0; + ++_op; + } + } + alignOctet(); + return result; +} + +unsigned long SMSDecoder::getTimeZone(bool &negativeTimeZone) +{ + unsigned long result = 0; + alignOctet(); + for (unsigned short i = 0; i < 2; ++i) + { + if (_bi == 0) + { + if (_op >= _maxop) + throw GsmException(_("premature end of PDU"), SMSFormatError); + // bits 0..3 are most significant + if (i == 0) + { // get sign + result = result * 10 + (*_op & 0x7); + negativeTimeZone = (*_op & 0x8 == 0); + } + else + result = result * 10 + (*_op & 0xf); + _bi = 4; + } + else + { + if (_op >= _maxop) + throw GsmException(_("premature end of PDU"), SMSFormatError); + // bits 4..7 are least significant + result = result * 10 + (*_op >> 4); + _bi = 0; + ++_op; + } + } + alignOctet(); + return result * 15; // compute minutes +} + +unsigned long SMSDecoder::getInteger(unsigned short length) +{ + unsigned long result = 0; + for (unsigned short i = 0; i < length; ++i) + result |= (getBit() << i); + return result; +} + +string SMSDecoder::getString(unsigned short length) +{ + string result; + alignSeptet(); + for (unsigned short i = 0; i < length; ++i) + { + unsigned char c = 0; + for (unsigned short j = 0; j < 7; ++j) + c |= getBit() << j; + result += c; + } + return result; +} + +Address SMSDecoder::getAddress(bool scAddressFormat) +{ + Address result; + alignOctet(); + + unsigned char addressLength = getOctet(); + if (addressLength == 0 && scAddressFormat) + return result; // special case for SUBMIT-PDUs + + // parse Type-of-Address + result._plan = (Address::NumberingPlan)getInteger(4); + result._type = (Address::Type)getInteger(3); + + // get address + if (result._type == Address::Alphanumeric) + { + markSeptet(); + // addressLength is number of semi-octets + // (addressLength / 2) * 8 is number of available bits + // divided by 7 is number of 7-bit characters + result._number = gsmToLatin1(getString(addressLength * 4 / 7)); + alignOctet(); + } + else + result._number = getSemiOctets(scAddressFormat ? + (addressLength - 1) * 2 : addressLength); + return result; +} + +Timestamp SMSDecoder::getTimestamp() +{ + Timestamp result; + + result._year = getSemiOctetsInteger(2); + result._month = getSemiOctetsInteger(2); + result._day = getSemiOctetsInteger(2); + result._hour = getSemiOctetsInteger(2); + result._minute = getSemiOctetsInteger(2); + result._seconds = getSemiOctetsInteger(2); + result._timeZoneMinutes = getTimeZone(result._negativeTimeZone); + return result; +} + +TimePeriod SMSDecoder::getTimePeriod(TimePeriod::Format format) +{ + TimePeriod result; + result._format = format; + switch (format) + { + case TimePeriod::NotPresent: + break; + case TimePeriod::Relative: + result._relativeTime = getOctet(); + break; + case TimePeriod::Absolute: + result._absoluteTime = getTimestamp(); + break; + default: + throw GsmException(_("unknown time period format"), SMSFormatError); + break; + } + return result; +} + +SMSDecoder::~SMSDecoder() +{ + delete _p; +} + +// SMSEncoder members + +SMSEncoder::SMSEncoder() : _bi(0), _op(_p) +{ + memset((void*)_p, 0, sizeof(_p)); +} + +void SMSEncoder::alignOctet() +{ + if (_bi != 0) + { + _bi = 0; + ++_op; + } +} + +void SMSEncoder::alignSeptet() +{ + while (((_op - _septetStart) * 8 + _bi) % 7 != 0) setBit(); +} + +void SMSEncoder::set2Bits(unsigned char twoBits) +{ + setBit(twoBits & 1); + setBit((twoBits & 2) == 2); +} + +void SMSEncoder::setOctet(unsigned char octet) +{ + alignOctet(); + *_op++ = octet; +} + +void SMSEncoder::setOctets(const unsigned char* octets, unsigned short length) +{ + alignOctet(); + for (unsigned short i = 0; i < length; ++i) + *_op++ = octets[i]; +} + +void SMSEncoder::setSemiOctets(string semiOctets) +{ + alignOctet(); + for (unsigned int i = 0; i < semiOctets.length(); ++i) + { + if (_bi == 0) + { + *_op = semiOctets[i] - '0'; + _bi = 4; + } + else + { + *_op++ |= (semiOctets[i] - '0') << 4; + _bi = 0; + } + } + if (_bi == 4) + *_op++ |= 0xf0; + _bi = 0; +} + +void SMSEncoder::setSemiOctetsInteger(unsigned long intValue, + unsigned short length) +{ + ostrstream os; + os << intValue << ends; + char *ss = os.str(); + string s(ss); + delete[] ss; + assert(s.length() <= length); + while (s.length() < length) s = '0' + s; + setSemiOctets(s); +} + +void SMSEncoder::setTimeZone(bool negativeTimeZone, unsigned long timeZone) +{ + setSemiOctetsInteger(timeZone / 15, 2); + if (!negativeTimeZone) + *(_op - 1) |= 8; +} + +void SMSEncoder::setInteger(unsigned long intvalue, unsigned short length) +{ + for (unsigned short i = 0; i < length; ++i) + setBit((intvalue & (1 << i)) != 0); +} + +void SMSEncoder::setString(string stringValue) +{ + alignSeptet(); + for (unsigned int i = 0; i < stringValue.length(); ++i) + { + unsigned char c = stringValue[i]; + for (unsigned short j = 0; j < 7; ++j) + setBit(((1 << j) & c) != 0); + } +} + +void SMSEncoder::setAddress(Address &address, bool scAddressFormat) +{ + alignOctet(); + if (scAddressFormat) + { + unsigned int numberLen = address._number.length(); + if (numberLen == 0) + { + setOctet(0); // special case: use default SC address + return; // (set by +CSCA=) + } + setOctet(numberLen / 2 + numberLen % 2 + 1); + // not supported for SCA format + assert(address._type != Address::Alphanumeric); + } + else + if (address._type == Address::Alphanumeric) + // address in GSM default encoding, see also comment in getAddress() + setOctet((address._number.length() * 7 + 6) / 8 * 2); + else + setOctet(address._number.length()); + + setInteger(address._plan, 4); + setInteger(address._type, 3); + setBit(1); + + if (address._number.length() > 0) + if (address._type == Address::Alphanumeric) + { + markSeptet(); + setString(latin1ToGsm(address._number)); + } + else + setSemiOctets(address._number); + alignOctet(); +} + +void SMSEncoder::setTimestamp(Timestamp timestamp) +{ + setSemiOctetsInteger(timestamp._year, 2); + setSemiOctetsInteger(timestamp._month, 2); + setSemiOctetsInteger(timestamp._day, 2); + setSemiOctetsInteger(timestamp._hour, 2); + setSemiOctetsInteger(timestamp._minute, 2); + setSemiOctetsInteger(timestamp._seconds, 2); + setTimeZone(timestamp._negativeTimeZone, timestamp._timeZoneMinutes); +} + +void SMSEncoder::setTimePeriod(TimePeriod period) +{ + switch (period._format) + { + case TimePeriod::NotPresent: + break; + case TimePeriod::Relative: + setOctet(period._relativeTime); + break; + case TimePeriod::Absolute: + setTimestamp(period._absoluteTime); + break; + default: + assert(0); + break; + } +} + +string SMSEncoder::getHexString() +{ + short bi = _bi; + unsigned char *op = _op; + alignOctet(); + string result = bufToHex(_p, _op - _p); + _bi = bi; + _op = op; + return result; +} + +unsigned int SMSEncoder::getLength() +{ + short bi = _bi; + unsigned char *op = _op; + alignOctet(); + unsigned int result = _op - _p; + _bi = bi; + _op = op; + return result; +} + +// UserDataHeader members + +void UserDataHeader::encode(SMSEncoder &e) +{ + e.setOctet(_udh.length()); + e.setOctets((unsigned char*)_udh.data(), _udh.length()); +} + +void UserDataHeader::decode(SMSDecoder &d) +{ + unsigned char udhLen = d.getOctet(); + unsigned char *s = + (unsigned char*)alloca(sizeof(unsigned char) * udhLen); + d.getOctets(s, udhLen); + string ss((char*)s, (unsigned int)udhLen); + _udh = ss; +} + +string UserDataHeader::getIE(unsigned char id) +{ + int udhl, pos = 0; + + udhl = _udh.length(); + while (pos < udhl) + { + unsigned char iei = _udh[pos++]; + unsigned char ieidl = _udh[pos++]; + if (iei == id) return _udh.substr(pos, ieidl); + pos += ieidl; + } + return ""; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_codec.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_codec.h new file mode 100644 index 0000000000..692b424561 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_codec.h @@ -0,0 +1,329 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sms_codec.h +// * +// * Purpose: Coder and Encoder for SMS TPDUs +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 16.5.1999 +// ************************************************************************* + +#ifndef GSM_SMS_CODEC_H +#define GSM_SMS_CODEC_H + +#include +#include + +using namespace std; + +namespace gsmlib +{ + // this struct represents a telephone number + // usually _type == Unknown or International + // and _number == ISDN_Telephone + struct Address + { + enum Type {Unknown = 0, International = 1, National = 2, + NetworkSpecific = 3, Subscriber = 4, + Alphanumeric = 5, Abbreviated = 6, Reserved = 7}; + enum NumberingPlan {UnknownPlan = 0, ISDN_Telephone = 1, + Data = 3, Telex = 4, NationalPlan = 8, + PrivatePlan = 9, Ermes = 10, ReservedPlan = 15}; + Type _type; + NumberingPlan _plan; + string _number; + + Address() : _type(Unknown), _plan(UnknownPlan) {} + // the constructor sets _type and _plan to defaults + // _plan == ISDN_Telephone + // _type == International if number starts with "+" + // _type == unknown otherwise + // number must be of the form "+123456" or "123456" + Address(string number); + + // return string representation + string toString() const; + + friend bool operator<(const Address &x, const Address &y); + friend bool operator==(const Address &x, const Address &y); + }; + + // compare two addresses + extern bool operator<(const Address &x, const Address &y); + extern bool operator==(const Address &x, const Address &y); + + // representation of a SMS timestamp + struct Timestamp + { + short _year, _month, _day, _hour, _minute, _seconds, _timeZoneMinutes; + bool _negativeTimeZone; + + Timestamp() : _year(0), _month(0), _day(0), _hour(0), + _minute(0), _seconds(0), _timeZoneMinutes(0), _negativeTimeZone(false) {} + + // return true if the time stamp is empty (ie. contains only zeroes) + bool empty() const; + + // return string representation + string toString(bool appendTimeZone = true) const; + + friend bool operator<(const Timestamp &x, const Timestamp &y); + friend bool operator==(const Timestamp &x, const Timestamp &y); + }; + + // compare two timestamps + extern bool operator<(const Timestamp &x, const Timestamp &y); + extern bool operator==(const Timestamp &x, const Timestamp &y); + + // representation of time period + struct TimePeriod + { + // possible values for validity period format + enum Format {NotPresent = 0, Relative = 2, Absolute = 3}; + Format _format; + Timestamp _absoluteTime; + unsigned char _relativeTime; + + TimePeriod() : _format(NotPresent), _relativeTime(0) {} + + // return string representation (already translated) + string toString() const; + }; + + // representation of DataCodingScheme + // the data coding scheme is described in detail in ETSI GSM 03.38, section 4 + const unsigned char DCS_COMPRESSED = 0x20; // bit 5 + + const unsigned char DCS_DEFAULT_ALPHABET = 0 << 2; // bit 2..3 == 0 + const unsigned char DCS_EIGHT_BIT_ALPHABET = 1 << 2; // bit 2..3 == 01 + const unsigned char DCS_SIXTEEN_BIT_ALPHABET = 2 << 2; // bit 2..3 == 10 + const unsigned char DCS_RESERVED_ALPHABET = 3 << 2; // bit 2..3 == 11 + + const unsigned char DCS_MESSAGE_WAITING_INDICATION = 0xc0; // bit 7..6 == 11 + const unsigned char DCS_VOICEMAIL_MESSAGE_WAITING = 0; + const unsigned char DCS_FAX_MESSAGE_WAITING = 1; + const unsigned char DCS_ELECTRONIC_MAIL_MESSAGE_WAITING = 2; + const unsigned char DCS_OTHER_MESSAGE_WAITING = 3; + + class DataCodingScheme + { + private: + unsigned char _dcs; + + public: + // initialize with data coding scheme octet + DataCodingScheme(unsigned char dcs) : _dcs(dcs) {} + + // set to default values (no message waiting, no message class indication, + // default 7-bit alphabet) + DataCodingScheme() : _dcs(DCS_DEFAULT_ALPHABET) {} + + // return type of alphabet used (if messageWaitingIndication == false) + unsigned char getAlphabet() const {return _dcs & (3 << 2);} + + // return true if message compressed + // (if messageWaitingIndication == false) + bool compressed() const {return _dcs & DCS_COMPRESSED == DCS_COMPRESSED;} + + // return true if message waiting indication + bool messageWaitingIndication() const + {return _dcs & DCS_MESSAGE_WAITING_INDICATION == + DCS_MESSAGE_WAITING_INDICATION;} + + // return type of waiting message (if messageWaitingIndication == true) + unsigned char getMessageWaitingType() const {return _dcs & 3;} + + // return string representation (already translated) + string toString() const; + + operator unsigned char() const {return _dcs;} + }; + + // utility class facilitate SMS TPDU decoding + class SMSDecoder + { + private: + unsigned char *_p; // buffer to hold pdu + short _bi; // bit index (0..7) + unsigned char *_op; // current octet pointer + unsigned char *_septetStart; // start of septet string + + unsigned char *_maxop; // pointer to last byte after _p + + public: + // initialize with a hexadecimal octet string containing SMS TPDU + SMSDecoder(string pdu); + + // align to octet border + void alignOctet(); + + // remember starting point of septets (important for alignSeptet()) + void markSeptet() {alignOctet(); _septetStart = _op;} + + // align to septet border + void alignSeptet(); + + // get single bit + bool getBit() + { + assert(_op < _maxop); + bool result = ((*_op >> _bi) & 1); + if (_bi == 7) + { + _bi = 0; + ++_op; + } + else + ++_bi; + return result; + } + + // get two bits + unsigned char get2Bits(); + + // get one octet + unsigned char getOctet(); + + // get string of octets of specified length + void getOctets(unsigned char* octets, unsigned short length); + + // get length semi-octets (bcd-coded number) as ASCII string of numbers + string getSemiOctets(unsigned short length); + + // get length semi-octets (bcd-coded number) as integer + unsigned long getSemiOctetsInteger(unsigned short length); + + // get time zone (in minutes) and time zone sign + unsigned long getTimeZone(bool &negativeTimeZone); + + // get integer with length number of bits + unsigned long getInteger(unsigned short length); + + // get length number of alphanumeric 7-bit characters + // markSeptet() must be called before this function + string getString(unsigned short length); + + // get address/telephone number + // service centre address has special format + Address getAddress(bool scAddressFormat = false); + + // get Timestamp + Timestamp getTimestamp(); + + // get TimePeriod of given format + TimePeriod getTimePeriod(TimePeriod::Format format); + + // destructor + ~SMSDecoder(); + }; + + // utility class for SMS TPDU encoding + class SMSEncoder + { + private: + unsigned char _p[2000]; // buffer to hold pdu (2000 should be enough) + short _bi; // bit index (0..7) + unsigned char *_op; // current octet pointer + unsigned char *_septetStart; // start of septet string + + public: + // constructor + SMSEncoder(); + + // align to octet border + void alignOctet(); + + // remember starting point of septets (important for alignSeptet()) + void markSeptet() {alignOctet(); _septetStart = _op;} + + // align to septet border + void alignSeptet(); + + // set single bit + void setBit(bool bit = false) + { + if (bit) + *_op |= (1 << _bi); + if (_bi == 7) + { + _bi = 0; + ++_op; + } + else + ++_bi; + } + + // set two bits + void set2Bits(unsigned char twoBits); + + // set one octet + void setOctet(unsigned char octet); + + // set string of octets of specified length + void setOctets(const unsigned char* octets, unsigned short length); + + // set semi-octets semiOctets (given as ASCII string of numbers) + void setSemiOctets(string semiOctets); + + // set semi-octets (given as integer) + void setSemiOctetsInteger(unsigned long intValue, unsigned short length); + + // set time zone (in minutes) and time zone sign + void setTimeZone(bool negativeTimeZone, unsigned long timeZone); + + // set integer with length number of bits + void setInteger(unsigned long intvalue, unsigned short length); + + // set alphanumeric 7-bit characters + void setString(string stringValue); + + // set address/telephone number + // service centre address has special format + void setAddress(Address &address, bool scAddressFormat = false); + + // set Timestamp + void setTimestamp(Timestamp timestamp); + + // set TimePeriod + void setTimePeriod(TimePeriod period); + + // return constructed TPDU as hex-encoded string + string getHexString(); + + // return current length of TPDU + unsigned int getLength(); + }; + + // class to handle user data header + class UserDataHeader + { + private: + string _udh; + + public: + // empty user data header + UserDataHeader() {} + + // initialize with user data header + UserDataHeader (string udh) : _udh(udh) {} + + // encode header + void encode(SMSEncoder &e); + + // decode header + void decode(SMSDecoder &d); + + // return a given information element, if present, or an empty string + string getIE(unsigned char id); + + // return the size of the header + unsigned int length() const {return _udh.length();} + + // return user data header as octet string + operator string() const {return _udh;} + }; +}; + +#endif // GSM_SMS_CODEC_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_store.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_store.cc new file mode 100644 index 0000000000..91e15ce3a8 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_store.cc @@ -0,0 +1,489 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sms_store.cc +// * +// * Purpose: SMS functions, SMS store +// * (ETSI GSM 07.05) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 20.5.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +// SMSStoreEntry members + +SMSStoreEntry::SMSStoreEntry() : + _status(Unknown), _cached(false), _mySMSStore(NULL), _index(0) +{ +} + + +SMSMessageRef SMSStoreEntry::message() const throw(GsmException) +{ + if (! cached()) + { + assert(_mySMSStore != NULL); + // these operations are at least "logically const" + SMSStoreEntry *thisEntry = const_cast(this); + _mySMSStore->readEntry(_index, thisEntry->_message, thisEntry->_status); + thisEntry->_cached = true; + } + return _message; +} + +CBMessageRef SMSStoreEntry::cbMessage() const throw(GsmException) +{ + assert(_mySMSStore != NULL); + + // these operations are at least "logically const" + SMSStoreEntry *thisEntry = const_cast(this); + // don't cache CB message for now + thisEntry->_cached = false; + + CBMessageRef result; + _mySMSStore->readEntry(_index, result); + return result; +} + +SMSStoreEntry::SMSMemoryStatus SMSStoreEntry::status() const + throw(GsmException) +{ + if (! cached()) + { + assert(_mySMSStore != NULL); + // these operations are at least "logically const" + SMSStoreEntry *thisEntry = const_cast(this); + _mySMSStore->readEntry(_index, thisEntry->_message, thisEntry->_status); + thisEntry->_cached = true; + } + return _status; +} + +bool SMSStoreEntry::empty() const throw(GsmException) +{ + return message().isnull(); +} + +unsigned char SMSStoreEntry::send(Ref &ackPdu) + throw(GsmException) +{ + return _mySMSStore->send(_index, ackPdu); +} + +unsigned char SMSStoreEntry::send() throw(GsmException) +{ + SMSMessageRef mref; + return send(mref); +} + +bool SMSStoreEntry::cached() const +{ + if (_mySMSStore == NULL) + return _cached; + else + return _cached && _mySMSStore->_useCache; +} + +Ref SMSStoreEntry::clone() +{ + Ref result = new SMSStoreEntry(_message->clone()); + result->_status = _status; + result->_index = _index; + return result; +} + +bool SMSStoreEntry::operator==(const SMSStoreEntry &e) const +{ + if (_message.isnull() || e._message.isnull()) + return _message.isnull() && e._message.isnull(); + else + return _message->encode() == e._message->encode(); +} + +SMSStoreEntry::SMSStoreEntry(const SMSStoreEntry &e) +{ + _message = e._message; + _status = e._status; + _cached = e._cached; + _mySMSStore = e._mySMSStore; + _index = e._index; +} + +SMSStoreEntry &SMSStoreEntry::operator=(const SMSStoreEntry &e) +{ + _message = e._message; + _status = e._status; + _cached = e._cached; + _mySMSStore = e._mySMSStore; + _index = e._index; + return *this; +} + +// iterator members + +SMSStoreEntry &SMSStoreIterator::operator*() +{ + return (*_store)[_index]; +} + +SMSStoreEntry *SMSStoreIterator::operator->() +{ + return &(*_store)[_index]; +} + +SMSStoreIterator::operator SMSStoreEntry*() +{ + return &(*_store)[_index]; +} + +SMSStoreIterator &SMSStoreIterator::operator=(const SMSStoreIterator &i) +{ + _index = i._index; + _store = i._store; + return *this; +} + +const SMSStoreEntry &SMSStoreConstIterator::operator*() +{ + return (*_store)[_index]; +} + +const SMSStoreEntry *SMSStoreConstIterator::operator->() +{ + return &(*_store)[_index]; +} + +// SMSStore members + +void SMSStore::readEntry(int index, SMSMessageRef &message, + SMSStoreEntry::SMSMemoryStatus &status) + throw(GsmException) +{ + // select SMS store + _meTa.setSMSStore(_storeName, 1); + +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "*** Reading SMS entry " << index << endl; +#endif // NDEBUG + + string pdu; + Ref p; + try + { + p = new Parser(_at->chat("+CMGR=" + intToStr(index + 1), "+CMGR:", + pdu, false, true, true)); + } + catch (GsmException &ge) + { + if (ge.getErrorCode() != SMS_INVALID_MEMORY_INDEX) + throw ge; + else + { + message = SMSMessageRef(); + status = SMSStoreEntry::Unknown; + return; + } + } + + if (pdu.length() == 0) + { + message = SMSMessageRef(); + status = SMSStoreEntry::Unknown; + } + else + { + // add missing service centre address if required by ME + if (! _at->getMeTa().getCapabilities()._hasSMSSCAprefix) + pdu = "00" + pdu; + + status = (SMSStoreEntry::SMSMemoryStatus)p->parseInt(); + + // ignore the rest of the line + message = SMSMessageRef( + SMSMessage::decode(pdu, + !(status == SMSStoreEntry::StoredUnsent || + status == SMSStoreEntry::StoredSent), + _at.getptr())); + } +} + +void SMSStore::readEntry(int index, CBMessageRef &message) + throw(GsmException) +{ + // select SMS store + _meTa.setSMSStore(_storeName, 1); + +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "*** Reading CB entry " << index << endl; +#endif // NDEBUG + + string pdu; + Ref p; + try + { + // this is just one row splitted in two part + // (msvc6 fail with internal compiler error) + string s = _at->chat("+CMGR=" + intToStr(index + 1), "+CMGR:", + pdu, false, true, true); + p = new Parser(s); + } + catch (GsmException &ge) + { + if (ge.getErrorCode() != SMS_INVALID_MEMORY_INDEX) + throw ge; + else + { + message = CBMessageRef(); + return; + } + } + + if (pdu.length() == 0) + message = CBMessageRef(); + else + message = CBMessageRef(new CBMessage(pdu)); +} + +void SMSStore::writeEntry(int &index, SMSMessageRef message) + throw(GsmException) +{ + // select SMS store + _meTa.setSMSStore(_storeName, 2); + +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "*** Writing SMS entry " << index << endl; +#endif + + // compute length of pdu + string pdu = message->encode(); + + // set message status to "RECEIVED READ" for SMS_DELIVER, SMS_STATUS_REPORT + string statusString; + + // Normally the ",1" sets the message status to "REC READ" (received read) + // which is appropriate for all non-submit messages + // Motorola Timeport 260 does not like this code, though + // DELIVER messages are magically recognized anyway + if (message->messageType() != SMSMessage::SMS_SUBMIT && + ! _at->getMeTa().getCapabilities()._wrongSMSStatusCode) + statusString = ",1"; + + Parser p(_at->sendPdu("+CMGW=" + + intToStr(pdu.length() / 2 - + message->getSCAddressLen()) + statusString, + "+CMGW:", pdu)); + index = p.parseInt() - 1; +} + +void SMSStore::eraseEntry(int index) throw(GsmException) +{ + // Select SMS store + _meTa.setSMSStore(_storeName, 1); + +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "*** Erasing SMS entry " << index << endl; +#endif + + _at->chat("+CMGD=" + intToStr(index + 1)); +} + +unsigned char SMSStore::send(int index, Ref &ackPdu) + throw(GsmException) +{ + Parser p(_at->chat("+CMSS=" + intToStr(index + 1), "+CMSS:")); + unsigned char messageReference = p.parseInt(); + + if (p.parseComma(true)) + { + string pdu = p.parseEol(); + + // add missing service centre address if required by ME + if (! _at->getMeTa().getCapabilities()._hasSMSSCAprefix) + pdu = "00" + pdu; + + ackPdu = SMSMessage::decode(pdu); + } + else + ackPdu = SMSMessageRef(); + + return messageReference; +} + +int SMSStore::doInsert(SMSMessageRef message) + throw(GsmException) +{ + int index; + writeEntry(index, message); + // it is safer to force reading back the SMS from the ME + resizeStore(index + 1); + _store[index]->_cached = false; + return index; +} + +SMSStore::SMSStore(string storeName, Ref at, MeTa &meTa) + throw(GsmException) : + _storeName(storeName), _at(at), _meTa(meTa), _useCache(true) +{ + // select SMS store + Parser p(_meTa.setSMSStore(_storeName, true, true)); + + p.parseInt(); // skip number of used mems + p.parseComma(); + + resizeStore(p.parseInt()); // ignore rest of line +} + +void SMSStore::resizeStore(int newSize) +{ + int oldSize = _store.size(); + if (newSize > oldSize) + { + // cout << "*** Resizing from " << oldSize << " to " << newSize << endl; + _store.resize(newSize); + + // initialize store entries + for (int i = oldSize; i < newSize; i++) + { + _store[i] = new SMSStoreEntry(); + _store[i]->_index = i; + _store[i]->_cached = false; + _store[i]->_mySMSStore = this; + } + } +} + +SMSStore::iterator SMSStore::begin() +{ + return SMSStoreIterator(0, this); +} + +SMSStore::const_iterator SMSStore::begin() const +{ + return SMSStoreConstIterator(0, this); +} + +SMSStore::iterator SMSStore::end() +{ + return SMSStoreIterator(_store.size(), this); +} + +SMSStore::const_iterator SMSStore::end() const +{ + return SMSStoreConstIterator(_store.size(), this); +} + +SMSStore::reference SMSStore::operator[](int n) +{ + resizeStore(n + 1); + return *_store[n]; +} + +SMSStore::const_reference SMSStore::operator[](int n) const +{ + const_cast(this)->resizeStore(n + 1); + return *_store[n]; +} + +SMSStore::reference SMSStore::front() +{ + return *_store[0]; +} + +SMSStore::const_reference SMSStore::front() const +{ + return *_store[0]; +} + +SMSStore::reference SMSStore::back() +{ + return *_store.back(); +} + +SMSStore::const_reference SMSStore::back() const +{ + return *_store.back(); +} + +int SMSStore::size() const throw(GsmException) +{ + // select SMS store + Parser p(_meTa.setSMSStore(_storeName, 1, true)); + + return p.parseInt(); +} + +SMSStore::iterator SMSStore::insert(iterator position, + const SMSStoreEntry& x) + throw(GsmException) +{ + int index = doInsert(x.message()); + return SMSStoreIterator(index, this); +} + +SMSStore::iterator SMSStore::insert(const SMSStoreEntry& x) + throw(GsmException) +{ + int index = doInsert(x.message()); + return SMSStoreIterator(index, this); +} + +void SMSStore::insert (iterator pos, int n, const SMSStoreEntry& x) + throw(GsmException) +{ + for (int i = 0; i < n; i++) + doInsert(x.message()); +} + +void SMSStore::insert (iterator pos, long n, const SMSStoreEntry& x) + throw(GsmException) +{ + for (long i = 0; i < n; i++) + doInsert(x.message()); +} + +SMSStore::iterator SMSStore::erase(iterator position) + throw(GsmException) +{ + eraseEntry(position->_index); + position->_cached = false; + return position + 1; +} + +SMSStore::iterator SMSStore::erase(iterator first, iterator last) + throw(GsmException) +{ + iterator i(0, this); + for (i = first; i != last; ++i) + erase(i); + return i; +} + +void SMSStore::clear() throw(GsmException) +{ + for (iterator i = begin(); i != end(); ++i) + erase(i); +} + +SMSStore::~SMSStore() +{ + for (vector::iterator i = _store.begin(); + i != _store.end(); ++i) + delete *i; +} + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_store.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_store.h new file mode 100644 index 0000000000..59d0ec8eac --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sms_store.h @@ -0,0 +1,295 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sms_store.h +// * +// * Purpose: SMS functions, SMS store +// * (ETSI GSM 07.05) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 20.5.1999 +// ************************************************************************* + +#ifndef GSM_SMS_STORE_H +#define GSM_SMS_STORE_H + +#include +#include +#include +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + // forward declarations + class SMSStore; + class MeTa; + + // a single entry in the SMS store + + class SMSStoreEntry : public RefBase + { + public: + // status in ME memory + enum SMSMemoryStatus {ReceivedUnread = 0, ReceivedRead = 1, + StoredUnsent = 2, StoredSent = 3, + All = 4, Unknown = 5}; + + private: + SMSMessageRef _message; + SMSMemoryStatus _status; + bool _cached; + SMSStore *_mySMSStore; + int _index; + + public: + // this constructor is only used by SMSStore + SMSStoreEntry(); + + // create new entry given a SMS message + SMSStoreEntry(SMSMessageRef message) : + _message(message), _status(Unknown), _cached(true), _mySMSStore(NULL), + _index(0) {} + + // create new entry given a SMS message and an index + // only to be used for file-based stores (see gsm_sorted_sms_store) + SMSStoreEntry(SMSMessageRef message, int index) : + _message(message), _status(Unknown), _cached(true), _mySMSStore(NULL), + _index(index) {} + + // clear cached flag + void clearCached() { _cached = false; } + + // return SMS message stored in the entry + SMSMessageRef message() const throw(GsmException); + + // return CB message stored in the entry + CBMessageRef cbMessage() const throw(GsmException); + + // return message status in store + SMSMemoryStatus status() const throw(GsmException); + + // return true if empty, ie. no SMS in this entry + bool empty() const throw(GsmException); + + // send this PDU from store + // returns message reference and ACK-PDU (if requested) + // only applicate to SMS-SUBMIT and SMS-COMMAND + unsigned char send(Ref &ackPdu) throw(GsmException); + + // same as above, but ACK-PDU is discarded + unsigned char send() throw(GsmException); + + // return index (guaranteed to be unique, + // can be used for identification in store) + int index() const {return _index;} + + // return true if entry is cached (and caching is enabled) + bool cached() const; + + // return deep copy of this entry + Ref clone(); + + // equality operator + bool operator==(const SMSStoreEntry &e) const; + + // return store reference + SMSStore *getStore() {return _mySMSStore;} + + // copy constructor and assignment + SMSStoreEntry(const SMSStoreEntry &e); + SMSStoreEntry &operator=(const SMSStoreEntry &e); + + friend class SMSStore; + }; + + // iterator for the SMSStore class + +#if __GNUC__ == 2 && __GNUC_MINOR__ == 95 + class SMSStoreIterator : public random_access_iterator +#else + class SMSStoreIterator : public iterator +#endif + { + int _index; + SMSStore *_store; + + SMSStoreIterator(int index, SMSStore *store) : + _index(index), _store(store) {} + + public: + SMSStoreIterator(SMSStoreEntry *entry) : + _index(entry->index()), _store(entry->getStore()) {} + + SMSStoreEntry &operator*(); + SMSStoreEntry *operator->(); + SMSStoreIterator &operator+(int i) + {_index += i; return *this;} + operator SMSStoreEntry*(); + SMSStoreIterator &operator=(const SMSStoreIterator &i); + SMSStoreIterator &operator++() + {++_index; return *this;} + SMSStoreIterator &operator--() + {--_index; return *this;} + SMSStoreIterator &operator++(int i) + {_index += i; return *this;} + SMSStoreIterator &operator--(int i) + {_index -= i; return *this;} + bool operator<(SMSStoreIterator &i) + {return _index < i._index;} + bool operator==(const SMSStoreIterator &i) const + {return _index == i._index;} + bool operator!=(const SMSStoreIterator &i) const + {return _index != i._index;} + + friend class SMSStore; + }; + +#if __GNUC__ == 2 && __GNUC_MINOR__ == 95 + class SMSStoreConstIterator : public random_access_iterator +#else + class SMSStoreConstIterator : public iterator +#endif + { + int _index; + const SMSStore *_store; + + SMSStoreConstIterator(int index, const SMSStore *store) : + _index(index), _store(store) {} + + public: + const SMSStoreEntry &operator*(); + const SMSStoreEntry *operator->(); + SMSStoreConstIterator &operator++() + {++_index; return *this;} + SMSStoreConstIterator &operator--() + {--_index; return *this;} + SMSStoreConstIterator &operator++(int i) + {_index += i; return *this;} + SMSStoreConstIterator &operator--(int i) + {_index -= i; return *this;} + bool operator<(SMSStoreConstIterator &i) + {return _index < i._index;} + bool operator==(const SMSStoreConstIterator &i) const + {return _index == i._index;} + + friend class SMSStore; + }; + + // this class corresponds to a SMS store in the ME + // all functions directly update storage in the ME + // if the ME is exchanged, the storage may become corrupted because + // of internal buffering in the SMSStore class + + class SMSStore : public RefBase, public NoCopy + { + private: + vector _store; // vector of store entries + string _storeName; // name of the store, 2-byte like "SM" + Ref _at; // my GsmAt class + MeTa &_meTa; // my MeTa class + bool _useCache; // true if entries should be cached + + // internal access functions + // read/write entry from/to ME + void readEntry(int index, SMSMessageRef &message, + SMSStoreEntry::SMSMemoryStatus &status) throw(GsmException); + void readEntry(int index, CBMessageRef &message) throw(GsmException); + void writeEntry(int &index, SMSMessageRef message) + throw(GsmException); + // erase entry + void eraseEntry(int index) throw(GsmException); + // send PDU index from store + // returns message reference and ACK-PDU (if requested) + // only applicate to SMS-SUBMIT and SMS-COMMAND + unsigned char send(int index, Ref &ackPdu) throw(GsmException); + + + // do the actual insertion, return index of new element + int doInsert(SMSMessageRef message) throw(GsmException); + + // used by class MeTa + SMSStore(string storeName, Ref at, MeTa &meTa) throw(GsmException); + + // resize store entry vector if necessary + void resizeStore(int newSize); + + public: + // iterator defs + typedef SMSStoreIterator iterator; + typedef SMSStoreConstIterator const_iterator; + typedef SMSStoreEntry &reference; + typedef const SMSStoreEntry &const_reference; + + // set cache mode on or off + void setCaching(bool useCache) {_useCache = useCache;} + + // return name of this store (2-character string) + string name() const {return _storeName;} + + // SMS store traversal commands + // these are suitable to use stdc++ lib algorithms and iterators + // ME have fixed storage space implemented as memory slots + // that may either be empty or used + + // traversal commands + iterator begin(); + const_iterator begin() const; + iterator end(); + const_iterator end() const; + reference front(); + const_reference front() const; + reference back(); + const_reference back() const; + reference operator[](int n); + const_reference operator[](int n) const; + + // The size macros return the number of used entries + // Warning: indices may be _larger_ than size() because of this + // (perhaps this should be changed, because it is unexpected behavior) + + int size() const throw(GsmException); + int max_size() const {return _store.size();} + int capacity() const {return _store.size();} + bool empty() const throw(GsmException) {return size() == 0;} + + // insert iterators insert into the first empty cell regardless of position + // existing iterators may be invalidated after an insert operation + // return position + // insert only writes to available positions + // warning: insert fails silently if size() == max_size() + iterator insert(iterator position, const SMSStoreEntry& x) + throw(GsmException); + iterator insert(const SMSStoreEntry& x) throw(GsmException); + + // insert n times, same procedure as above + void insert (iterator pos, int n, const SMSStoreEntry& x) + throw(GsmException); + void insert (iterator pos, long n, const SMSStoreEntry& x) + throw(GsmException); + + // erase operators set used slots to "empty" + iterator erase(iterator position) throw(GsmException); + iterator erase(iterator first, iterator last) throw(GsmException); + void clear() throw(GsmException); + + // destructor + ~SMSStore(); + + friend class SMSStoreEntry; + friend class MeTa; + }; + + typedef Ref SMSStoreRef; + +}; + +#endif // GSM_SMS_STORE_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook.cc new file mode 100644 index 0000000000..b569ea6c67 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook.cc @@ -0,0 +1,502 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sorted_phonebook.cc +// * +// * Purpose: Alphabetically sorted phonebook +// * (residing in files or in the ME) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 25.6.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include +#include + +const int MAX_LINE_SIZE = 1000; + +using namespace std; +using namespace gsmlib; + +string SortedPhonebook::escapeString(string s) +{ + string result; + + for (const char *pp = s.c_str(); *pp != 0; ++pp) + { + if (*pp == CR) + result += "\\r"; + else if (*pp == LF) + result += "\\n"; + else if (*pp == '\\') + result += "\\\\"; + else if (*pp == '|') + result += "\\|"; + else + result += *pp; + } + return result; +} + +string SortedPhonebook::unescapeString(char *line, unsigned int &pos) +{ + string result; + bool escaped = false; + + while (! (line[pos] == '|' && ! escaped) && line[pos] != 0 && + line[pos] != CR && line[pos] != LF) + { + if (escaped) + { + escaped = false; + if (line[pos] == 'r') + result += CR; + else if (line[pos] == 'n') + result += LF; + else if (line[pos] == '\\') + result += '\\'; + else if (line[pos] == '|') + result += '|'; + else + result += line[pos]; + } + else + if (line[pos] == '\\') + escaped = true; + else + result += line[pos]; + + ++pos; + } + return result; +} + +void SortedPhonebook::readPhonebookFile(istream &pbs, string filename) + throw(GsmException) +{ + // read entries + while (! pbs.eof()) + { + char line[MAX_LINE_SIZE]; + pbs.getline(line, MAX_LINE_SIZE); + + if (strlen(line) == 0) + continue; // skip empty lines + + if (pbs.bad()) + throw GsmException(stringPrintf(_("error reading from file '%s"), + filename.c_str()), + OSError); + + // convert line to newEntry (line format : [index] '|' text '|' number + string text, telephone; + unsigned int pos = 0; + + // parse index + string indexS = unescapeString(line, pos); + int index = -1; + if (indexS.length() == 0) + { + if (_useIndices) + throw GsmException(stringPrintf(_("entry '%s' lacks index"), line), + ParserError); + } + else + { + index = checkNumber(indexS); + _useIndices = true; + } + if (line[pos++] != '|') + throw GsmException(stringPrintf(_("line '%s' has invalid format"), line), + ParserError); + + // parse text + text = unescapeString(line, pos); + if (line[pos++] != '|') + throw GsmException(stringPrintf(_("line '%s' has invalid format"), line), + ParserError); + + // parse telephone number + telephone = unescapeString(line, pos); + + insert(PhonebookEntryBase(telephone, text, index)); + } +} + +void SortedPhonebook::sync(bool fromDestructor) throw(GsmException) +{ + // if not in file it already is stored in ME/TA + if (! _fromFile) return; + + // if writing to stdout and not called from destructor ignore + // (avoids writing to stdout multiple times) + if (_filename == "" && ! fromDestructor) return; + + // find out if any of the entries have been updated + if (! _changed) // only look if we're not writing the file anyway + for (iterator i = begin(); i != end(); i++) + if (i->changed()) + { + _changed = true; + break; + } + + if (_changed) + { + checkReadonly(); + // create backup file - but only once + if (! _madeBackupFile && _filename != "") // don't make backup of stdout + { + renameToBackupFile(_filename); + _madeBackupFile = true; + } + + // open stream + ostream *pbs = NULL; + try + { + if (_filename == "") + pbs = &cout; + else + pbs = new ofstream(_filename.c_str()); + + if (pbs->bad()) + throw GsmException( + stringPrintf(_("error opening file '%s' for writing"), + (_filename == "" ? _("") : + _filename.c_str())), + OSError); + + // and write the entries + for (PhonebookMap::iterator i = _sortedPhonebook.begin(); + i != _sortedPhonebook.end(); ++i) + { + // convert entry to output line + string line = + (_useIndices ? intToStr(i->second->index()) : "") + "|" + + escapeString(i->second->text()) + "|" + + escapeString(i->second->telephone()); + + // write out the line + *pbs << line << endl; + if (pbs->bad()) + throw GsmException( + stringPrintf(_("error writing to file '%s'"), + (_filename == "" ? _("") : + _filename.c_str())), + OSError); + } + } + catch(GsmException &e) + { + if (pbs != &cout) delete pbs; + throw; + } + // close file + if (pbs != &cout) delete pbs; + + // reset all changed states + _changed = false; + for (iterator j = begin(); j != end(); j++) + j->resetChanged(); + } +} + +void SortedPhonebook::checkReadonly() throw(GsmException) +{ + if (_readonly) throw GsmException( + _("attempt to change phonebook read from "), + ParameterError); +} + +SortedPhonebook::SortedPhonebook(string filename, bool useIndices) + throw(GsmException) : + _changed(false), _fromFile(true), _madeBackupFile(false), + _sortOrder(ByIndex), _useIndices(useIndices), _readonly(false), + _filename(filename) +{ + // open the file + ifstream pbs(filename.c_str()); + if (pbs.bad()) + throw GsmException(stringPrintf(_("cannot open file '%s'"), + filename.c_str()), + OSError); + // and read the file + readPhonebookFile(pbs, filename); +} + +SortedPhonebook::SortedPhonebook(bool fromStdin, bool useIndices) + throw(GsmException) : + _changed(false), _fromFile(true), _madeBackupFile(false), + _sortOrder(ByIndex), _useIndices(useIndices), _readonly(fromStdin) + // _filename is "" - this means stdout +{ + // read from stdin + if (fromStdin) + readPhonebookFile(cin, (string)_("")); +} + +SortedPhonebook::SortedPhonebook(PhonebookRef mePhonebook) + throw(GsmException) : + _changed(false), _fromFile(false), _madeBackupFile(false), + _sortOrder(ByIndex), _readonly(false), _mePhonebook(mePhonebook) +{ + int entriesRead = 0; + reportProgress(0, _mePhonebook->end() - _mePhonebook->begin()); + + for (Phonebook::iterator i = _mePhonebook->begin(); + i != _mePhonebook->end(); ++i) + { + if (! i->empty()) + { + _sortedPhonebook.insert( + PhonebookMap::value_type(PhoneMapKey(*this, lowercase(i->text())), i)); + ++entriesRead; + if (entriesRead == _mePhonebook->size()) + return; // ready + } + reportProgress(i - _mePhonebook->begin()); + } +} + +void SortedPhonebook::setSortOrder(SortOrder newOrder) +{ + if (newOrder == _sortOrder) return; // nothing to do + + PhonebookMap savedPhonebook = _sortedPhonebook; // save phonebook + _sortedPhonebook = PhonebookMap(); // empty old phonebook + _sortOrder = newOrder; + + // re-insert entries + switch (newOrder) + { + case ByTelephone: + { + for (PhonebookMap::iterator i = savedPhonebook.begin(); + i != savedPhonebook.end(); ++i) + _sortedPhonebook. + insert(PhonebookMap::value_type( + PhoneMapKey(*this, lowercase(i->second->telephone())), i->second)); + break; + } + case ByText: + { + for (PhonebookMap::iterator i = savedPhonebook.begin(); + i != savedPhonebook.end(); ++i) + _sortedPhonebook. + insert(PhonebookMap::value_type( + PhoneMapKey(*this, lowercase(i->second->text())), i->second)); + break; + } + case ByIndex: + { + for (PhonebookMap::iterator i = savedPhonebook.begin(); + i != savedPhonebook.end(); ++i) + _sortedPhonebook. + insert(PhonebookMap::value_type( + PhoneMapKey(*this, i->second->index()), i->second)); + break; + } + default: + assert(0); + break; + } +} + +unsigned int SortedPhonebook::getMaxTelephoneLen() const +{ + if (_fromFile) + return UINT_MAX; + else + return _mePhonebook->getMaxTelephoneLen(); +} + +unsigned int SortedPhonebook::getMaxTextLen() const +{ + if (_fromFile) + return UINT_MAX; + else + return _mePhonebook->getMaxTextLen(); +} + +int SortedPhonebook::max_size() const +{ + if (_fromFile) + return _sortedPhonebook.max_size(); + else + return _mePhonebook->max_size(); +} + +int SortedPhonebook::capacity() const +{ + if (_fromFile) + return _sortedPhonebook.max_size(); + else + return _mePhonebook->capacity(); +} + +SortedPhonebook::iterator +SortedPhonebook::insert(const PhonebookEntryBase& x) throw(GsmException) +{ + checkReadonly(); + _changed = true; + PhonebookEntryBase *newEntry; + + if (_fromFile) + if (_useIndices) + { + if (x.index() != -1) // check that index is unique + { + for (PhonebookMap::iterator i = _sortedPhonebook.begin(); + i != _sortedPhonebook.end(); ++i) + if (i->second->index() == x.index()) + throw GsmException(_("indices must be unique in phonebook"), + ParameterError); + newEntry = new PhonebookEntryBase(x); + } + else // set index + { + SortOrder saveSortOrder = _sortOrder; + setSortOrder(ByIndex); + int index = 0; + for (PhonebookMap::iterator i = _sortedPhonebook.begin(); + i != _sortedPhonebook.end(); ++i, ++index) + if (i->second->index() != index) + break; + setSortOrder(saveSortOrder); + newEntry = new PhonebookEntryBase(); + newEntry->set(x.telephone(), x.text(), index, true); + } + } + else // index info in x is ignored + newEntry = new PhonebookEntryBase(x); + else + { + PhonebookEntry newMEEntry(x); + newEntry = _mePhonebook->insert((PhonebookEntry*)NULL, newMEEntry); + } + switch (_sortOrder) + { + case ByTelephone: + return + _sortedPhonebook. + insert(PhonebookMap::value_type( + PhoneMapKey(*this, lowercase(newEntry->telephone())), newEntry)); + case ByText: + return + _sortedPhonebook. + insert(PhonebookMap::value_type( + PhoneMapKey(*this, lowercase(newEntry->text())), newEntry)); + case ByIndex: + return + _sortedPhonebook. + insert(PhonebookMap::value_type( + PhoneMapKey(*this, newEntry->index()), newEntry)); + default: + assert(0); + break; + } + return SortedPhonebook::iterator(); +} + +SortedPhonebook::iterator +SortedPhonebook::insert(iterator position, const PhonebookEntryBase& x) + throw(GsmException) +{ + return insert(x); +} + +SortedPhonebook::size_type SortedPhonebook::erase(string &key) + throw(GsmException) +{ + // deallocate memory or remove from underlying ME phonebook + for (PhonebookMap::iterator i = + _sortedPhonebook.find(PhoneMapKey(*this, lowercase(key))); + i != _sortedPhonebook.end() && + i->first == PhoneMapKey(*this, lowercase(key)); + ++i) + { + checkReadonly(); + _changed = true; + if (_fromFile) + delete i->second; + else + _mePhonebook->erase((Phonebook::iterator)i->second); + } + + return _sortedPhonebook.erase(PhoneMapKey(*this, lowercase(key))); +} + +SortedPhonebook::size_type SortedPhonebook::erase(int key) + throw(GsmException) +{ + // deallocate memory or remove from underlying ME phonebook + for (PhonebookMap::iterator i = + _sortedPhonebook.find(PhoneMapKey(*this, key)); + i != _sortedPhonebook.end() && i->first == PhoneMapKey(*this, key); + ++i) + { + checkReadonly(); + _changed = true; + if (_fromFile) + delete i->second; + else + _mePhonebook->erase((Phonebook::iterator)i->second); + } + + return _sortedPhonebook.erase(PhoneMapKey(*this, key)); +} + +void SortedPhonebook::erase(iterator position) + throw(GsmException) +{ + checkReadonly(); + _changed = true; + // deallocate memory or remove from underlying ME phonebook + if (_fromFile) + delete ((PhonebookMap::iterator)position)->second; + else + _mePhonebook->erase((Phonebook::iterator) + ((PhonebookMap::iterator)position)->second); + _sortedPhonebook.erase(position); +} + +void SortedPhonebook::erase(iterator first, iterator last) + throw(GsmException) +{ + checkReadonly(); + _changed = true; + for (PhonebookMap::iterator i = first; i != last; ++i) + if (_fromFile) + delete i->second; + else + _mePhonebook->erase((Phonebook::iterator)i->second); + _sortedPhonebook.erase(first, last); +} + +void SortedPhonebook::clear() throw(GsmException) +{ + checkReadonly(); + _changed = true; + for (iterator i = begin(); i != end(); i++) + erase(i); +} + +SortedPhonebook::~SortedPhonebook() +{ + if (_fromFile) + { + sync(true); + for (PhonebookMap::iterator i = _sortedPhonebook.begin(); + i != _sortedPhonebook.end(); ++i) + delete i->second; + } +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook.h new file mode 100644 index 0000000000..c0d3b787fe --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook.h @@ -0,0 +1,159 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sorted_phonebook.h +// * +// * Purpose: Alphabetically sorted phonebook +// * (residing in files or in the ME) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 25.6.1999 +// ************************************************************************* + +#ifndef GSM_SORTED_PHONEBOOK_H +#define GSM_SORTED_PHONEBOOK_H + +#include +#include +#include +#include +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + + // The class SortedPhonebook makes the phonebook more manageable: + // - empty slots in the ME phonebook are hidden by the API + // - the class transparently handles phonebooks that reside in files + + class SortedPhonebook : public SortedPhonebookBase + { + private: + bool _changed; // true if file has changed after last save + bool _fromFile; // true if phonebook read from file + bool _madeBackupFile; // true if backup file was created + SortOrder _sortOrder; // sort order for the phonebook + bool _useIndices; // if phonebook from file: input file had + // indices; will write indices, too + bool _readonly; // =true if read from stdin + string _filename; // name of the file if phonebook from file + PhonebookMap _sortedPhonebook; // phonebook from file + PhonebookRef _mePhonebook; // phonebook if from ME + + // convert CR and LF in string to "\r" and "\n" respectively + string escapeString(string s); + + // convert "\r" and "\n" to CR and LF respectively + // start parsing with pos, stop when CR, LF, 0, or '|' is encountered + string unescapeString(char *line, unsigned int &pos); + + // initial read of phonebook file + void readPhonebookFile(istream &pbs, string filename) throw(GsmException); + + // synchronize SortedPhonebook with file (no action if in ME) + void sync(bool fromDestructor) throw(GsmException); + + // throw an exception if _readonly is set + void checkReadonly() throw(GsmException); + + public: + // iterator defs + typedef SortedPhonebookIterator iterator; + typedef PhonebookMap::size_type size_type; + + // constructor for file-based phonebook + // expect indices in file if useIndices == true + // read from file + SortedPhonebook(string filename, bool useIndices) + throw(GsmException); + // read from stdin or start empty and write to stdout + SortedPhonebook(bool fromStdin, bool useIndices) + throw(GsmException); + + // constructor for ME-based phonebook + SortedPhonebook(PhonebookRef mePhonebook) throw(GsmException); + + // return maximum telephone number length + unsigned int getMaxTelephoneLen() const; + + // return maximum entry description length + unsigned int getMaxTextLen() const; + + // handle sorting + void setSortOrder(SortOrder newOrder); + SortOrder sortOrder() const {return _sortOrder;} + + // phonebook traversal commands + // these are suitable to use stdc++ lib algorithms and iterators + // ME have fixed storage space implemented as memory slots + // that may either be empty or used + + // traversal commands + iterator begin() {return _sortedPhonebook.begin();} + iterator end() {return _sortedPhonebook.end();} + + // the size macros return the number of used entries + int size() const {return _sortedPhonebook.size();} + int max_size() const; + int capacity() const; + bool empty() const throw(GsmException) {return size() == 0;} + + // existing iterators remain valid after an insert or erase operation + // note: inserting many entries in indexed mode is inefficient + // if the sort order is not set to indexed before + + // return position + // insert only writes to available positions + // warning: insert fails silently if size() == max_size() + iterator insert(const PhonebookEntryBase& x) throw(GsmException); + iterator insert(iterator position, const PhonebookEntryBase& x) + throw(GsmException); + + PhonebookMap::size_type count(string &key) + {return _sortedPhonebook.count(PhoneMapKey(*this, lowercase(key)));} + iterator find(string &key) + {return _sortedPhonebook.find(PhoneMapKey(*this, lowercase(key)));} + iterator lower_bound(string &key) + {return _sortedPhonebook.lower_bound(PhoneMapKey(*this, + lowercase(key)));} + iterator upper_bound(string &key) + {return _sortedPhonebook.upper_bound(PhoneMapKey(*this, + lowercase(key)));} + pair equal_range(string &key) + {return _sortedPhonebook.equal_range(PhoneMapKey(*this, + lowercase(key)));} + + PhonebookMap::size_type count(int key) + {return _sortedPhonebook.count(PhoneMapKey(*this, key));} + iterator find(int key) + {return _sortedPhonebook.find(PhoneMapKey(*this, key));} + iterator lower_bound(int key) + {return _sortedPhonebook.lower_bound(PhoneMapKey(*this, key));} + iterator upper_bound(int key) + {return _sortedPhonebook.upper_bound(PhoneMapKey(*this, key));} + pair equal_range(int key) + {return _sortedPhonebook.equal_range(PhoneMapKey(*this, key));} + + size_type erase(string &key) throw(GsmException); + size_type erase(int key) throw(GsmException); + void erase(iterator position) throw(GsmException); + void erase(iterator first, iterator last) throw(GsmException); + void clear() throw(GsmException); + + // synchronize SortedPhonebook with file (no action if in ME) + void sync() throw(GsmException) {sync(false);} + + // destructor + // writes back change to file if phonebook is in file + virtual ~SortedPhonebook(); + }; + + // typedef Ref SortedPhonebookRef; +}; + +#endif // GSM_SORTED_PHONEBOOK_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook_base.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook_base.cc new file mode 100644 index 0000000000..1061dc60b9 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook_base.cc @@ -0,0 +1,115 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sorted_phonebook_base.cc +// * +// * Purpose: Virtual base class for alphabetically sorted phonebook +// * The infrastructure in this module allows custom backends for +// * storing phonebook entries to be integrated into gsmlib +// * (eg. LDAP- or RDBMS-based phonebook stores). +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 5.6.2000 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include + +#include + +using namespace std; +using namespace gsmlib; + +// PhonebookEntryBase members + +void PhonebookEntryBase::set(string telephone, string text, int index, + bool useIndex) + throw(GsmException) +{ + checkTextAndTelephone(text, telephone); + + _changed = true; + _telephone = telephone; + _text = text; + _useIndex = useIndex; + if (index != -1) + _index = index; +} + +bool PhonebookEntryBase::operator==(const PhonebookEntryBase &e) const +{ + assert(! ((_useIndex || e._useIndex) && + (_index == -1 || e._index == -1))); + return _telephone == e._telephone && _text == e._text && + (! (_useIndex || e._useIndex) || _index == e._index); +} + +string PhonebookEntryBase::text() const throw(GsmException) +{ + return _text; +} + +string PhonebookEntryBase::telephone() const throw(GsmException) +{ + return _telephone; +} + +bool PhonebookEntryBase::empty() const throw(GsmException) +{ + return (text() == "") && (telephone() == ""); +} + +Ref PhonebookEntryBase::clone() +{ + Ref result = new PhonebookEntryBase(*this); + return result; +} + +PhonebookEntryBase::PhonebookEntryBase(const PhonebookEntryBase &e) + throw(GsmException) +{ + set(e._telephone, e._text, e._index, e._useIndex); +} + +PhonebookEntryBase &PhonebookEntryBase::operator=(const PhonebookEntryBase &e) + throw(GsmException) +{ + set(e._telephone, e._text, e._index, e._useIndex); + return *this; +} + +// CustomPhonebookRegistry members + +map +*CustomPhonebookRegistry::_factoryList = NULL; + +void CustomPhonebookRegistry:: +registerCustomPhonebookFactory(string backendName, + CustomPhonebookFactory *factory) + throw(GsmException) +{ + if (_factoryList == NULL) + _factoryList = new map; + backendName = lowercase(backendName); + if (_factoryList->find(backendName) != _factoryList->end()) + throw GsmException(stringPrintf(_("backend '%s' already registered"), + backendName.c_str()), ParameterError); +} + +SortedPhonebookRef CustomPhonebookRegistry:: +createPhonebook(string backendName, string source) throw(GsmException) +{ + if (_factoryList == NULL) + _factoryList = new map; + backendName = lowercase(backendName); + if (_factoryList->find(backendName) == _factoryList->end()) + throw GsmException(stringPrintf(_("backend '%s' not registered"), + backendName.c_str()), ParameterError); + return (*_factoryList)[backendName]->createPhonebook(source); +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook_base.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook_base.h new file mode 100644 index 0000000000..166f81f45a --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_phonebook_base.h @@ -0,0 +1,220 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sorted_phonebook_base.h +// * +// * Purpose: Virtual base class for alphabetically sorted phonebook +// * The infrastructure in this module allows custom backends for +// * storing phonebook entries to be integrated into gsmlib +// * (eg. LDAP- or RDBMS-based phonebook stores). +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 5.6.2000 +// ************************************************************************* + +#ifndef GSM_SORTED_PHONEBOOK_BASE_H +#define GSM_SORTED_PHONEBOOK_BASE_H + +#include +#include +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + // a single entry in a phonebook + + class PhonebookEntryBase : public RefBase + { + protected: + bool _changed; // set to true if _telephone or _text changed + string _telephone; + string _text; + int _index; // my position in the phonebook + // == -1 if not used (can only happen if + // phonebook is read from file) + bool _useIndex; // compare indices in operator==, + // use _index for inserting into + // Phonebook + + public: + PhonebookEntryBase() : + _changed(false), _index(-1), _useIndex(false) {} + + // convenience constructor + PhonebookEntryBase(string telephone, string text, int index = -1) : + _changed(false), _telephone(telephone), _text(text), + _index(index), _useIndex(false) {} + + // accessor functions + virtual void set(string telephone, string text, int index = -1, + bool useIndex = false) + throw(GsmException); + virtual string text() const throw(GsmException); + virtual string telephone() const throw(GsmException); + + // return true if both telephone and text are empty + bool empty() const throw(GsmException); + + // set to true if operator== should compare the _index as well + void setUseIndex(bool useIndex) + {_useIndex = useIndex;} + bool useIndex() const {return _useIndex;} + + // equality operator + // if one of the operands has _useIndex == true + // takes _index and e._index into account + bool operator==(const PhonebookEntryBase &e) const; + + // return index + int index() const {return _index;} + + // return true if entry changed + bool changed() const {return _changed;} + + // reset the changed status (ie. if synced to file) + void resetChanged() {_changed = false;} + + // return deep copy of this entry + virtual Ref clone(); + + PhonebookEntryBase(const PhonebookEntryBase &e) throw(GsmException); + PhonebookEntryBase &operator=(const PhonebookEntryBase &e) + throw(GsmException); + + virtual ~PhonebookEntryBase() {} + }; + + // MapKey for sortedPhonebook + + class SortedPhonebookBase; + typedef MapKey PhoneMapKey; + + // maps text or telephone to entry + + typedef multimap PhonebookMap; + + // iterator for SortedPhonebook that hides the "second" member of the map + + typedef PhonebookMap::iterator PhonebookMapIterator; + class SortedPhonebookIterator : public PhonebookMapIterator + { + public: + SortedPhonebookIterator() {} + SortedPhonebookIterator(PhonebookMap::iterator i) : + PhonebookMapIterator(i) {} + + PhonebookEntryBase &operator*() + {return *((PhonebookMap::iterator)*this)->second;} + + PhonebookEntryBase *operator->() + {return ((PhonebookMap::iterator)*this)->second;} + }; + + // virtual base class for sorted phonebooks + + class SortedPhonebookBase : public RefBase, public NoCopy + { + public: + // iterator defs + typedef SortedPhonebookIterator iterator; + typedef PhonebookMap::size_type size_type; + + // return maximum telephone number length + virtual unsigned int getMaxTelephoneLen() const = 0; + + // return maximum entry description length + virtual unsigned int getMaxTextLen() const = 0; + + // handle sorting + virtual void setSortOrder(SortOrder newOrder) = 0; + virtual SortOrder sortOrder() const = 0; + + // phonebook traversal commands + // these are suitable to use stdc++ lib algorithms and iterators + + // traversal commands + virtual iterator begin() = 0; + virtual iterator end() = 0; + + // the size macros return the number of used entries + virtual int size() const = 0; + virtual int max_size() const = 0; + virtual int capacity() const = 0; + virtual bool empty() const throw(GsmException) = 0; + + // existing iterators remain valid after an insert or erase operation + + // return position + // insert only writes to available positions + // warning: insert fails silently if size() == max_size() + virtual iterator insert(const PhonebookEntryBase& x) throw(GsmException) + = 0; + virtual iterator insert(iterator position, const PhonebookEntryBase& x) + throw(GsmException) = 0; + + virtual PhonebookMap::size_type count(string &key) = 0; + virtual iterator find(string &key) = 0; + virtual iterator lower_bound(string &key) = 0; + virtual iterator upper_bound(string &key) = 0; + virtual pair equal_range(string &key) = 0; + + virtual PhonebookMap::size_type count(int key) = 0; + virtual iterator find(int key) = 0; + virtual iterator lower_bound(int key) = 0; + virtual iterator upper_bound(int key) = 0; + virtual pair equal_range(int key) = 0; + + virtual size_type erase(string &key) throw(GsmException) = 0; + virtual size_type erase(int key) throw(GsmException) = 0; + virtual void erase(iterator position) throw(GsmException) = 0; + virtual void erase(iterator first, iterator last) throw(GsmException) = 0; + virtual void clear() throw(GsmException) = 0; + + // synchronize SortedPhonebookBase with storage + virtual void sync() throw(GsmException) = 0; + + virtual ~SortedPhonebookBase() {} + }; + + typedef Ref SortedPhonebookRef; + + + // base factory class for custom backends + class CustomPhonebookFactory + { + public: + // return sorted phonebook object given the source specification + // (eg. database name, URL, etc.) + virtual SortedPhonebookRef createPhonebook(string source) + throw(GsmException) = 0; + }; + + // registry for custom backends + + class CustomPhonebookRegistry + { + // registered factories + static map *_factoryList; + + public: + // register a factory class for a specific backend + // (case does not matter for backend name) + static void registerCustomPhonebookFactory(string backendName, + CustomPhonebookFactory *factory) + throw(GsmException); + + + // return a phonebook object given the backend name and the source + // specification + static SortedPhonebookRef + createPhonebook(string backendName, string source) throw(GsmException); + }; + +}; + +#endif // GSM_SORTED_PHONEBOOK_BASE_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_sms_store.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_sms_store.cc new file mode 100644 index 0000000000..7ca9f9f160 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_sms_store.cc @@ -0,0 +1,499 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sorted_sms_store.cc +// * +// * Purpose: Sorted SMS store (residing in files or in the ME) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 14.8.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include +#ifdef HAVE_NETINET_IN_H +#include +#endif + +using namespace std; +using namespace gsmlib; + +// SMS message file format: +// version number of file format, unsigned short int, 2 bytes in network byte +// order +// then comes the message: +// 1. length of PDU (see 4. below): unsigned short int, +// 2 bytes in network byte order +// 2. index of message, unique for this file: unsigned long, +// 4 bytes in network byte order +// 3. MessageType (1 byte), any of: +// 0 SMS_DELIVER +// 1 SMS_SUBMIT +// 2 SMS_STATUS_REPORT +// 4. PDU in hexadecimal format + +static const unsigned short int SMS_STORE_FILE_FORMAT_VERSION = 1; + +// SortedSMSStore members + +// aux function read bytes with error handling +// return false if EOF +static bool readnbytes(string &filename, + istream &is, int len, char *buf, + bool eofIsError = true) throw(GsmException) +{ + is.read(buf, len); + if (is.bad() || (is.eof() && eofIsError)) + throw GsmException(stringPrintf(_("error reading from file '%s'"), + (filename == "" ? _("") : + filename.c_str())), OSError); + return ! is.eof(); +} + +// aux function write bytes with error handling +static void writenbytes(string &filename, ostream &os, + int len, const char *buf) throw(GsmException) +{ + os.write(buf, len); + if (os.bad()) + throw GsmException(stringPrintf(_("error writing to file '%s'"), + (filename == "" ? _("") : + filename.c_str())), OSError); +} + +void SortedSMSStore::readSMSFile(istream &pbs, string filename) + throw(GsmException) +{ + char numberBuf[4]; + + // check the version + try + { + readnbytes(filename, pbs, 2, numberBuf); + } + catch (GsmException &ge) + { + // ignore error, file might be empty initially + } + unsigned_int_2 version = ntohs(*((unsigned_int_2*)numberBuf)); + if (! pbs.eof() && version != SMS_STORE_FILE_FORMAT_VERSION) + throw GsmException(stringPrintf(_("file '%s' has wrong version"), + filename.c_str()), ParameterError); + + // read entries + while (1) + { + // read PDU length and exit loop if EOF + if (! readnbytes(filename, pbs, 2, numberBuf, false)) + break; + + unsigned_int_2 pduLen = ntohs(*((unsigned_int_2*)numberBuf)); + if (pduLen > 500) + throw GsmException(stringPrintf(_("corrupt SMS store file '%s'"), + filename.c_str()), ParameterError); + + // read reserved integer field of message (was formerly index) + readnbytes(filename, pbs, 4, numberBuf); + //unsigned_int_4 reserved = ntohl(*((unsigned_int_4*)numberBuf)); + + // read message type + readnbytes(filename, pbs, 1, numberBuf); + SMSMessage::MessageType messageType = + (SMSMessage::MessageType)numberBuf[0]; + if (messageType > 2) + throw GsmException(stringPrintf(_("corrupt SMS store file '%s'"), + filename.c_str()), ParameterError); + + char *pduBuf = (char*)alloca(sizeof(char) * pduLen); + + // read pdu + readnbytes(filename, pbs, pduLen, pduBuf); + SMSMessageRef message = + SMSMessage::decode(string(pduBuf, pduLen), + (messageType != SMSMessage::SMS_SUBMIT)); + + SMSStoreEntry *newEntry = new SMSStoreEntry(message, _nextIndex++); + _sortedSMSStore.insert( + SMSStoreMap::value_type( + SMSMapKey(*this, message->serviceCentreTimestamp()), + newEntry) + ); + } +} + +void SortedSMSStore::sync(bool fromDestructor) throw(GsmException) +{ + if (_fromFile && _changed) + { + checkReadonly(); + + // if writing to stdout and not called from destructor ignore + // (avoids writing to stdout multiple times) + if (_filename == "" && ! fromDestructor) return; + + // create backup file - but only once + if (! _madeBackupFile && _filename != "") // don't make backup of stdout + { + renameToBackupFile(_filename); + _madeBackupFile = true; + } + + // open stream + ostream *pbs = NULL; + try + { + if (_filename == "") + pbs = &cout; + else + pbs = new ofstream(_filename.c_str(), ios::out | ios::binary); + + if (pbs->bad()) + throw GsmException( + stringPrintf(_("error opening file '%s' for writing"), + (_filename == "" ? _("") : + _filename.c_str())), + OSError); + + // write version number + unsigned_int_2 version = htons(SMS_STORE_FILE_FORMAT_VERSION); + writenbytes(_filename, *pbs, 2, (char*)&version); + + // and write the entries + for (SMSStoreMap::iterator i = _sortedSMSStore.begin(); + i != _sortedSMSStore.end(); ++i) + { + // create PDU and write length + string pdu = i->second->message()->encode(); + unsigned_int_2 pduLen = htons(pdu.length()); + writenbytes(_filename, *pbs, 2, (char*)&pduLen); + + // write reserved field (was formerly index) + unsigned_int_4 reserved = htonl(0); + writenbytes(_filename, *pbs, 4, (char*)&reserved); + + // write message type + char messageType = i->second->message()->messageType(); + writenbytes(_filename, *pbs, 1, (char*)&messageType); + + // write PDU + writenbytes(_filename, *pbs, pdu.length(), pdu.data()); + } + } + catch(GsmException &e) + { + if (pbs != &cout) delete pbs; + throw; + } + // close file + if (pbs != &cout) delete pbs; + + _changed = false; + } +} + +void SortedSMSStore::checkReadonly() throw(GsmException) +{ + if (_readonly) throw GsmException( + _("attempt to change SMS store read from "), + ParameterError); +} + +SortedSMSStore::SortedSMSStore(string filename) throw(GsmException) : + _changed(false), _fromFile(true), _madeBackupFile(false), + _sortOrder(ByDate), _readonly(false), _filename(filename), _nextIndex(0) +{ + // open the file + ifstream pbs(filename.c_str(), ios::in | ios::binary); + if (pbs.bad()) + throw GsmException(stringPrintf(_("cannot open file '%s'"), + filename.c_str()), OSError); + // and read the file + readSMSFile(pbs, filename); +} + +SortedSMSStore::SortedSMSStore(bool fromStdin) throw(GsmException) : + _changed(false), _fromFile(true), _madeBackupFile(false), + _sortOrder(ByDate), _readonly(fromStdin), _nextIndex(0) + // _filename is "" - this means stdout +{ + // read from stdin + if (fromStdin) + readSMSFile(cin, (string)_("")); +} + +SortedSMSStore::SortedSMSStore(SMSStoreRef meSMSStore) + throw(GsmException) : + _changed(false), _fromFile(false), _madeBackupFile(false), + _sortOrder(ByDate), _readonly(false), _meSMSStore(meSMSStore) +{ + // It is necessary to count the entries read because + // the maximum index into the SMS store may be larger than smsStore.size() + int entriesRead = 0; + reportProgress(0, _meSMSStore->size()); + + for (int i = 0;; ++i) + { + if (entriesRead == _meSMSStore->size()) + break; // ready + if (! _meSMSStore()[i].empty()) + { + _sortedSMSStore.insert( + SMSStoreMap::value_type( + SMSMapKey(*this, + _meSMSStore()[i].message()->serviceCentreTimestamp()), + &_meSMSStore()[i]) + ); + ++entriesRead; + reportProgress(entriesRead); + } + } +} + +void SortedSMSStore::setSortOrder(SortOrder newOrder) +{ + if (_sortOrder == newOrder) return; // nothing to be done + + SMSStoreMap savedSMSStore = _sortedSMSStore; + _sortedSMSStore = SMSStoreMap(); + _sortOrder = newOrder; + + switch (newOrder) + { + case ByIndex: + { + for (SMSStoreMap::iterator i = savedSMSStore.begin(); + i != savedSMSStore.end(); ++i) + _sortedSMSStore.insert( + SMSStoreMap::value_type(SMSMapKey(*this, (i->second->index())), + i->second)); + break; + } + case ByDate: + { + for (SMSStoreMap::iterator i = savedSMSStore.begin(); + i != savedSMSStore.end(); ++i) + _sortedSMSStore.insert( + SMSStoreMap::value_type( + SMSMapKey(*this, (i->second->message()->serviceCentreTimestamp())), + i->second)); + break; + } + case ByAddress: + { + for (SMSStoreMap::iterator i = savedSMSStore.begin(); + i != savedSMSStore.end(); ++i) + _sortedSMSStore.insert( + SMSStoreMap::value_type( + SMSMapKey(*this, (i->second->message()->address())), + i->second)); + break; + } + case ByType: + { + for (SMSStoreMap::iterator i = savedSMSStore.begin(); + i != savedSMSStore.end(); ++i) + _sortedSMSStore.insert( + SMSStoreMap::value_type( + SMSMapKey(*this, (i->second->message()->messageType())), + i->second)); + break; + } + default: + assert(0); + break; + } +} + +int SortedSMSStore::max_size() const +{ + if (_fromFile) + return _sortedSMSStore.max_size(); + else + return _meSMSStore->max_size(); +} + +int SortedSMSStore::capacity() const +{ + if (_fromFile) + return _sortedSMSStore.max_size(); + else + return _meSMSStore->capacity(); +} + +SortedSMSStore::iterator +SortedSMSStore::insert(const SMSStoreEntry& x) throw(GsmException) +{ + checkReadonly(); + _changed = true; + SMSStoreEntry *newEntry; + + if (_fromFile) + newEntry = new SMSStoreEntry(x.message(), _nextIndex++); + else + { + SMSStoreEntry newMEEntry(x.message()); + newEntry = _meSMSStore->insert(newMEEntry); + } + + switch (_sortOrder) + { + case ByIndex: + return + _sortedSMSStore. + insert(SMSStoreMap::value_type(SMSMapKey(*this, newEntry->index()), + newEntry)); + break; + case ByDate: + return + _sortedSMSStore. + insert(SMSStoreMap::value_type( + SMSMapKey(*this, newEntry->message()->serviceCentreTimestamp()), + newEntry)); + break; + case ByAddress: + return + _sortedSMSStore. + insert(SMSStoreMap::value_type( + SMSMapKey(*this, newEntry->message()->address()), + newEntry)); + break; + case ByType: + return + _sortedSMSStore. + insert(SMSStoreMap::value_type( + SMSMapKey(*this, newEntry->message()->messageType()), + newEntry)); + break; + default: + assert(0); + break; + } + return SortedSMSStore::iterator(); +} + +SortedSMSStore::iterator +SortedSMSStore::insert(iterator position, const SMSStoreEntry& x) + throw(GsmException) +{ + return insert(x); +} + +SortedSMSStore::size_type SortedSMSStore::erase(Address &key) + throw(GsmException) +{ + assert(_sortOrder == ByAddress); + + SMSMapKey mapKey(*this, key); + + // deallocate memory or remove from underlying ME SMS store + for (SMSStoreMap::iterator i = _sortedSMSStore.find(mapKey); + i != _sortedSMSStore.end() && i->first == mapKey; ++i) + { + checkReadonly(); + _changed = true; + if (_fromFile) + delete i->second; + else + _meSMSStore->erase((SMSStore::iterator)i->second); + } + + return _sortedSMSStore.erase(mapKey); +} + +SortedSMSStore::size_type SortedSMSStore::erase(int key) + throw(GsmException) +{ + assert(_sortOrder == ByIndex || _sortOrder == ByType); + + SMSMapKey mapKey(*this, key); + + // deallocate memory or remove from underlying ME SMS store + for (SMSStoreMap::iterator i = _sortedSMSStore.find(mapKey); + i != _sortedSMSStore.end() && i->first == mapKey; ++i) + { + checkReadonly(); + _changed = true; + if (_fromFile) + delete i->second; + else + _meSMSStore->erase((SMSStore::iterator)i->second); + } + + return _sortedSMSStore.erase(mapKey); +} + +SortedSMSStore::size_type SortedSMSStore::erase(Timestamp &key) + throw(GsmException) +{ + assert(_sortOrder == ByDate); + + SMSMapKey mapKey(*this, key); + + // deallocate memory or remove from underlying ME SMS store + for (SMSStoreMap::iterator i = _sortedSMSStore.find(mapKey); + i != _sortedSMSStore.end() && i->first == mapKey; ++i) + { + checkReadonly(); + _changed = true; + if (_fromFile) + delete i->second; + else + _meSMSStore->erase((SMSStore::iterator)i->second); + } + + return _sortedSMSStore.erase(mapKey); +} + +void SortedSMSStore::erase(iterator position) + throw(GsmException) +{ + checkReadonly(); + _changed = true; + // deallocate memory or remove from underlying ME SMS store + if (_fromFile) + delete ((SMSStoreMap::iterator)position)->second; + else + _meSMSStore->erase((SMSStore::iterator) + ((SMSStoreMap::iterator)position)->second); + _sortedSMSStore.erase(position); +} + +void SortedSMSStore::erase(iterator first, iterator last) + throw(GsmException) +{ + checkReadonly(); + _changed = true; + for (SMSStoreMap::iterator i = first; i != last; ++i) + if (_fromFile) + delete i->second; + else + _meSMSStore->erase((SMSStore::iterator)i->second); + _sortedSMSStore.erase(first, last); +} + +void SortedSMSStore::clear() throw(GsmException) +{ + checkReadonly(); + _changed = true; + for (iterator i = begin(); i != end(); i++) + erase(i); +} + +SortedSMSStore::~SortedSMSStore() +{ + if (_fromFile) + { + sync(true); + for (SMSStoreMap::iterator i = _sortedSMSStore.begin(); + i != _sortedSMSStore.end(); ++i) + delete i->second; + } +} + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_sms_store.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_sms_store.h new file mode 100644 index 0000000000..126c5856bd --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sorted_sms_store.h @@ -0,0 +1,217 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sorted_sms_store.h +// * +// * Purpose: Sorted SMS store (residing in files or in the ME) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 14.8.1999 +// ************************************************************************* + +#ifndef GSM_SORTED_SMS_STORE_H +#define GSM_SORTED_SMS_STORE_H + +#include +#include +#include +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + // MapKey for SortedSMSStore + + class SortedSMSStore; + typedef MapKey SMSMapKey; + + // maps key (see SortedSMSStore::SortOrder) to entry + + typedef multimap SMSStoreMap; + + // iterator for SortedSMSStore that hides the "second" member of the map + + typedef SMSStoreMap::iterator SMSStoreMapIterator; + class SortedSMSStoreIterator : public SMSStoreMapIterator + { + public: + SortedSMSStoreIterator() {} + SortedSMSStoreIterator(SMSStoreMap::iterator i) : + SMSStoreMapIterator(i) {} + + SMSStoreEntry &operator*() + {return *((SMSStoreMap::iterator)*this)->second;} + + SMSStoreEntry *operator->() + {return ((SMSStoreMap::iterator)*this)->second;} + }; + + // The class SortedSMSStore makes the SMS store more manageable: + // - empty slots in the ME phonebook are hidden by the API + // - the class transparently handles stores that reside in files + + class SortedSMSStore : public RefBase, public NoCopy + { + private: + + bool _changed; // true if file has changed after last save + bool _fromFile; // true if store read from file + bool _madeBackupFile; // true if backup file was created + SortOrder _sortOrder; // sort order of the _sortedSMSStore + // (default is ByDate) + bool _readonly; // =true if read from stdin + string _filename; // name of the file if store from file + SMSStoreMap _sortedSMSStore; // store from file + SMSStoreRef _meSMSStore; // store if from ME + + unsigned int _nextIndex; // next index to use for file-based store + + // initial read of SMS file + void readSMSFile(istream &pbs, string filename) throw(GsmException); + + // synchronize SortedSMSStore with file (no action if in ME) + void sync(bool fromDestructor) throw(GsmException); + + // throw an exception if _readonly is set + void checkReadonly() throw(GsmException); + + public: + // iterator defs + typedef SortedSMSStoreIterator iterator; + typedef SMSStoreMap::size_type size_type; + + // constructor for file-based store + // read from file + SortedSMSStore(string filename) throw(GsmException); + // read from stdin or start empty and write to stdout + SortedSMSStore(bool fromStdin) throw(GsmException); + + // constructor for ME-based store + SortedSMSStore(SMSStoreRef meSMSStore) throw(GsmException); + + // handle sorting + void setSortOrder(SortOrder newOrder); + SortOrder sortOrder() const {return _sortOrder;} + + // store traversal commands + // these are suitable to use stdc++ lib algorithms and iterators + + // traversal commands + iterator begin() {return _sortedSMSStore.begin();} + iterator end() {return _sortedSMSStore.end();} + + // the size macros return the number of used entries + int size() const {return _sortedSMSStore.size();} + int max_size() const; + int capacity() const; + bool empty() const throw(GsmException) {return size() == 0;} + + // existing iterators may be invalidated after an insert operation + // return position + // insert only writes to available positions + // warning: insert fails silently if size() == max_size() + iterator insert(const SMSStoreEntry& x) throw(GsmException); + iterator insert(iterator position, const SMSStoreEntry& x) + throw(GsmException); + + SMSStoreMap::size_type count(Address &key) + { + assert(_sortOrder == ByAddress); + return _sortedSMSStore.count(SMSMapKey(*this, key)); + } + iterator find(Address &key) + { + assert(_sortOrder == ByAddress); + return _sortedSMSStore.find(SMSMapKey(*this, key)); + } + iterator lower_bound(Address &key) + { + assert(_sortOrder == ByAddress); + return _sortedSMSStore.lower_bound(SMSMapKey(*this, key)); + } + iterator upper_bound(Address &key) + { + assert(_sortOrder == ByAddress); + return _sortedSMSStore.upper_bound(SMSMapKey(*this, key)); + } + pair equal_range(Address &key) + { + assert(_sortOrder == ByAddress); + return _sortedSMSStore.equal_range(SMSMapKey(*this, key)); + } + + SMSStoreMap::size_type count(Timestamp &key) + { + assert(_sortOrder == ByDate); + return _sortedSMSStore.count(SMSMapKey(*this, key)); + } + iterator find(Timestamp &key) + { + assert(_sortOrder == ByDate); + return _sortedSMSStore.find(SMSMapKey(*this, key)); + } + iterator lower_bound(Timestamp &key) + { + assert(_sortOrder == ByDate); + return _sortedSMSStore.lower_bound(SMSMapKey(*this, key)); + } + iterator upper_bound(Timestamp &key) + { + assert(_sortOrder == ByDate); + return _sortedSMSStore.upper_bound(SMSMapKey(*this, key)); + } + pair equal_range(Timestamp &key) + { + assert(_sortOrder == ByDate); + return _sortedSMSStore.equal_range(SMSMapKey(*this, key)); + } + + SMSStoreMap::size_type count(int key) + { + assert(_sortOrder == ByIndex || _sortOrder == ByType); + return _sortedSMSStore.count(SMSMapKey(*this, key)); + } + iterator find(int key) + { + assert(_sortOrder == ByIndex || _sortOrder == ByType); + return _sortedSMSStore.find(SMSMapKey(*this, key)); + } + iterator lower_bound(int key) + { + assert(_sortOrder == ByIndex || _sortOrder == ByType); + return _sortedSMSStore.lower_bound(SMSMapKey(*this, key)); + } + iterator upper_bound(int key) + { + assert(_sortOrder == ByIndex || _sortOrder == ByType); + return _sortedSMSStore.upper_bound(SMSMapKey(*this, key)); + } + pair equal_range(int key) + { + assert(_sortOrder == ByIndex || _sortOrder == ByType); + return _sortedSMSStore.equal_range(SMSMapKey(*this, key)); + } + + size_type erase(Address &key) throw(GsmException); + size_type erase(int key) throw(GsmException); + size_type erase(Timestamp &key) throw(GsmException); + void erase(iterator position) throw(GsmException); + void erase(iterator first, iterator last) throw(GsmException); + void clear() throw(GsmException); + + // synchronize SortedPhonebook with file (no action if in ME) + void sync() throw(GsmException) {sync(false);} + + // destructor + // writes back change to file if store is in file + ~SortedSMSStore(); + }; + + typedef Ref SortedSMSStoreRef; +}; + +#endif // GSM_SORTED_SMS_STORE_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sysdep.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sysdep.h new file mode 100644 index 0000000000..864fcf99ff --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_sysdep.h @@ -0,0 +1,83 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_sysdep.h +// * +// * Purpose: Some magic to make alloca work on different platforms plus +// * other system-dependent stuff +// * +// * Warning: Only include this header from gsmlib .cc-files +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 28.10.1999 +// ************************************************************************* + +#ifndef GSM_SYSDEP_H +#define GSM_SYSDEP_H + +#ifdef HAVE_CONFIG_H +#include +#endif + +extern "C" { + + // this is mostly taken from the autoconf documentation (WIN32 added) + +#ifdef __GNUC__ +# define alloca __builtin_alloca +#else +# if HAVE_ALLOCA_H +# include +# else +# ifdef _AIX + #pragma alloca +# else +# ifdef WIN32 +# include +# define alloca _alloca +# else +# ifndef alloca /* predefined by HP cc +Olibcalls */ +char *alloca (); +# endif +# endif +# endif +# endif +#endif + +} + +// Windows-specific stuff +#if defined(WIN32) && ! defined(__GNUC__) +#define NOMINMAX +#include +#include + +#ifdef _MSC_VER +#define min __min +#endif + +#define S_ISREG(mode) (((mode) & _S_IFREG) == _S_IFREG) +#define S_ISCHR(mode) (((mode) & _S_IFCHR) == _S_IFCHR) + +#define read _read +#endif + +// define common data types with fixed sizes + +#if SIZEOF_UNSIGNED_SHORT_INT == 2 + typedef unsigned short int unsigned_int_2; +#else +#error "no suitable 2 byte unsigned int available" +#endif +#if SIZEOF_UNSIGNED_LONG_INT == 4 + typedef unsigned long int unsigned_int_4; +#else +#if SIZEOF_UNSIGNED_INT == 4 + typedef unsigned int unsigned_int_4; +#else +#error "no suitable 4 byte unsigned int available" +#endif +#endif + +#endif // GSM_SYSDEP_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_unix_serial.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_unix_serial.cc new file mode 100644 index 0000000000..d62d379239 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_unix_serial.cc @@ -0,0 +1,455 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_unix_port.cc +// * +// * Purpose: UNIX serial port implementation +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 10.5.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +static const int holdoff[] = {2000000, 1000000, 400000}; +static const int holdoffArraySize = sizeof(holdoff)/sizeof(int); + +// alarm handling for socket read/write +// the timerMtx is necessary since several threads cannot use the +// timer indepently of each other + +static pthread_mutex_t timerMtx = PTHREAD_MUTEX_INITIALIZER; + +// for non-GNU systems, define alarm() +#ifndef HAVE_ALARM +unsigned int alarm(unsigned int seconds) +{ + struct itimerval old, newt; + newt.it_interval.tv_usec = 0; + newt.it_interval.tv_sec = 0; + newt.it_value.tv_usec = 0; + newt.it_value.tv_sec = (long int)seconds; + if (setitimer(ITIMER_REAL, &newt, &old) < 0) + return 0; + else + return old.it_value.tv_sec; +} +#endif + +// this routine is called in case of a timeout +static void catchAlarm(int) +{ + // do nothing +} + +// start timer +static void startTimer() +{ + pthread_mutex_lock(&timerMtx); + struct sigaction newAction; + newAction.sa_handler = catchAlarm; + newAction.sa_flags = 0; + sigaction(SIGALRM, &newAction, NULL); + alarm(1); +} + +// reset timer +static void stopTimer() +{ + alarm(0); + sigaction(SIGALRM, NULL, NULL); + pthread_mutex_unlock(&timerMtx); +} + +// UnixSerialPort members + +void UnixSerialPort::throwModemException(string message) throw(GsmException) +{ + ostrstream os; + os << message << " (errno: " << errno << "/" << strerror(errno) << ")" + << ends; + char *ss = os.str(); + string s(ss); + delete[] ss; + throw GsmException(s, OSError, errno); +} + +void UnixSerialPort::putBack(unsigned char c) +{ + assert(_oldChar == -1); + _oldChar = c; +} + +int UnixSerialPort::readByte() throw(GsmException) +{ + if (_oldChar != -1) + { + int result = _oldChar; + _oldChar = -1; + return result; + } + + unsigned char c; + int timeElapsed = 0; + struct timeval oneSecond; + bool readDone = false; + + while (! readDone && timeElapsed < _timeoutVal) + { + if (interrupted()) + throwModemException(_("interrupted when reading from TA")); + + // setup fd_set data structure for select() + fd_set fdSet; + oneSecond.tv_sec = 1; + oneSecond.tv_usec = 0; + FD_ZERO(&fdSet); + FD_SET(_fd, &fdSet); + + switch (select(FD_SETSIZE, &fdSet, NULL, NULL, &oneSecond)) + { + case 1: + { + int res = read(_fd, &c, 1); + if (res != 1) + throwModemException(_("end of file when reading from TA")); + else + readDone = true; + break; + } + case 0: + ++timeElapsed; + break; + default: + if (errno != EINTR) + throwModemException(_("reading from TA")); + break; + } + } + if (! readDone) + throwModemException(_("timeout when reading from TA")); + +#ifndef NDEBUG + if (debugLevel() >= 2) + { + // some useful debugging code + if (c == LF) + cerr << ""; + else if (c == CR) + cerr << ""; + else cerr << "<'" << (char) c << "'>"; + cerr.flush(); + } +#endif + return c; +} + +UnixSerialPort::UnixSerialPort(string device, speed_t lineSpeed, + string initString, bool swHandshake) + throw(GsmException) : + _oldChar(-1), _timeoutVal(TIMEOUT_SECS) +{ + struct termios t; + + // open device + _fd = open(device.c_str(), O_RDWR | O_NOCTTY | O_NONBLOCK); + if (_fd == -1) + throwModemException(stringPrintf(_("opening device '%s'"), + device.c_str())); + + // switch off non-blocking mode + int fdFlags; + if ((fdFlags = fcntl(_fd, F_GETFL)) == -1) { + close(_fd); + throwModemException(_("getting file status flags failed")); + } + fdFlags &= ~O_NONBLOCK; + if (fcntl(_fd, F_SETFL, fdFlags) == -1) { + close(_fd); + throwModemException(_("switching of non-blocking mode failed")); + } + + long int saveTimeoutVal = _timeoutVal; + _timeoutVal = 3; + int initTries = holdoffArraySize; + while (initTries-- > 0) + { + // flush all pending output + tcflush(_fd, TCOFLUSH); + + // toggle DTR to reset modem + int mctl = TIOCM_DTR; + if (ioctl(_fd, TIOCMBIC, &mctl) < 0) { + close(_fd); + throwModemException(_("clearing DTR failed")); + } + // the waiting time for DTR toggling is increased with each loop + usleep(holdoff[initTries]); + if (ioctl(_fd, TIOCMBIS, &mctl) < 0) { + close(_fd); + throwModemException(_("setting DTR failed")); + } + // get line modes + if (tcgetattr(_fd, &t) < 0) { + close(_fd); + throwModemException(stringPrintf(_("tcgetattr device '%s'"), + device.c_str())); + } + + // set line speed + cfsetispeed(&t, lineSpeed); + cfsetospeed(&t, lineSpeed); + + // set the device to a sane state + t.c_iflag |= IGNPAR | (swHandshake ? IXON | IXOFF : 0); + t.c_iflag &= ~(INPCK | ISTRIP | IMAXBEL | + (swHandshake ? 0 : IXON | IXOFF) + | IXANY | IGNCR | ICRNL | IMAXBEL | INLCR | IGNBRK); + t.c_oflag &= ~(OPOST); + // be careful, only touch "known" flags + t.c_cflag &= ~(CSIZE | CSTOPB | PARENB | PARODD | + (swHandshake ? CRTSCTS : 0 )); + t.c_cflag |= CS8 | CREAD | HUPCL | (swHandshake ? 0 : CRTSCTS) | CLOCAL; + t.c_lflag &= ~(ECHO | ECHOE | ECHOPRT | ECHOK | ECHOKE | ECHONL | + ECHOCTL | ISIG | IEXTEN | TOSTOP | FLUSHO | ICANON); + t.c_lflag |= NOFLSH; + t.c_cc[VMIN] = 1; + t.c_cc[VTIME] = 0; + + t.c_cc[VSUSP] = 0; + + // write back + if(tcsetattr (_fd, TCSANOW, &t) < 0) { + close(_fd); + throwModemException(stringPrintf(_("tcsetattr device '%s'"), + device.c_str())); + } + // the waiting time for writing to the ME/TA is increased with each loop + usleep(holdoff[initTries]); + + // flush all pending input + tcflush(_fd, TCIFLUSH); + + try + { + // reset modem + putLine("ATZ"); + bool foundOK = false; + int readTries = 5; + while (readTries-- > 0) + { + // for the first call getLine() waits only 3 seconds + // because of _timeoutVal = 3 + string s = getLine(); + if (s.find("OK") != string::npos || + s.find("CABLE: GSM") != string::npos) + { + foundOK = true; + readTries = 0; // found OK, exit loop + } + else if (s.find("ERROR") != string::npos) + readTries = 0; // error, exit loop + } + + // set getLine/putLine timeout back to old value + _timeoutVal = saveTimeoutVal; + + if (foundOK) + { + // init modem + readTries = 5; + putLine("AT" + initString); + while (readTries-- > 0) + { + string s = getLine(); + if (s.find("OK") != string::npos || + s.find("CABLE: GSM") != string::npos) + return; // found OK, return + } + } + } + catch (GsmException &e) + { + _timeoutVal = saveTimeoutVal; + if (initTries == 0) { + close(_fd); + throw e; + } + } + } + // no response after 3 tries + close(_fd); + throw GsmException(stringPrintf(_("reset modem failed '%s'"), + device.c_str()), OtherError); +} + +string UnixSerialPort::getLine() throw(GsmException) +{ + string result; + int c; + while ((c = readByte()) >= 0) + { + while (c == CR) + { + c = readByte(); + } + if (c == LF) + break; + result += c; + } + +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "<-- " << result << endl; +#endif + + return result; +} + +void UnixSerialPort::putLine(string line, + bool carriageReturn) throw(GsmException) +{ +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "--> " << line << endl; +#endif + + if (carriageReturn) line += CR; + const char *l = line.c_str(); + + int timeElapsed = 0; + struct timeval oneSecond; + + ssize_t bytesWritten = 0; + while (bytesWritten < (ssize_t)line.length() && timeElapsed < _timeoutVal) + { + if (interrupted()) + throwModemException(_("interrupted when writing to TA")); + + // setup fd_set data structure for select() + fd_set fdSet; + oneSecond.tv_sec = 1; + oneSecond.tv_usec = 0; + FD_ZERO(&fdSet); + FD_SET(_fd, &fdSet); + + switch (select(FD_SETSIZE, NULL, &fdSet, NULL, &oneSecond)) + { + case 1: + { + ssize_t bw = write(_fd, l + bytesWritten, line.length() - bytesWritten); + if (bw < 0) + throwModemException(_("writing to TA")); + bytesWritten += bw; + break; + } + case 0: + ++timeElapsed; + break; + default: + if (errno != EINTR) + throwModemException(_("writing to TA")); + break; + } + } + + while (timeElapsed < _timeoutVal) + { + if (interrupted()) + throwModemException(_("interrupted when writing to TA")); + startTimer(); + int res = tcdrain(_fd); // wait for output to be read by TA + stopTimer(); + if (res == 0) + break; + else + { + assert(errno == EINTR); + ++timeElapsed; + } + } + if (timeElapsed >= _timeoutVal) + throwModemException(_("timeout when writing to TA")); + + // echo CR LF must be removed by higher layer functions in gsm_at because + // in order to properly handle unsolicited result codes from the ME/TA +} + +bool UnixSerialPort::wait(GsmTime timeout) throw(GsmException) +{ + fd_set fds; + FD_ZERO(&fds); + FD_SET(_fd, &fds); + return select(FD_SETSIZE, &fds, NULL, NULL, timeout) != 0; +} + +// set timeout for read or write in seconds. +void UnixSerialPort::setTimeOut(unsigned int timeout) +{ + _timeoutVal = timeout; +} + +UnixSerialPort::~UnixSerialPort() +{ + if (_fd != -1) + close(_fd); +} + +speed_t gsmlib::baudRateStrToSpeed(string baudrate) throw(GsmException) +{ + if (baudrate == "300") + return B300; + else if (baudrate == "600") + return B600; + else if (baudrate == "1200") + return B1200; + else if (baudrate == "2400") + return B2400; + else if (baudrate == "4800") + return B4800; + else if (baudrate == "9600") + return B9600; + else if (baudrate == "19200") + return B19200; + else if (baudrate == "38400") + return B38400; +#ifdef B57600 + else if (baudrate == "57600") + return B57600; +#endif +#ifdef B115200 + else if (baudrate == "115200") + return B115200; +#endif +#ifdef B230400 + else if (baudrate == "230400") + return B230400; +#endif +#ifdef B460800 + else if (baudrate == "460800") + return B460800; +#endif + else + throw GsmException(stringPrintf(_("unknown baudrate '%s'"), + baudrate.c_str()), ParameterError); +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_unix_serial.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_unix_serial.h new file mode 100644 index 0000000000..29b1800b6c --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_unix_serial.h @@ -0,0 +1,62 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_unix_port.h +// * +// * Purpose: UNIX serial port implementation +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 4.5.1999 +// ************************************************************************* + +#ifndef GSM_UNIX_SERIAL_H +#define GSM_UNIX_SERIAL_H + +#include +#include +#include +#include +#include +#include + +using namespace std; + +namespace gsmlib +{ + class UnixSerialPort : public Port + { + private: + int _fd; // file descriptor for device + int _debug; // debug level (set by environment variable + // GSM_DEBUG + int _oldChar; // character set by putBack() (-1 == none) + long int _timeoutVal; // timeout for getLine/readByte + + // throw GsmException include UNIX errno + void throwModemException(string message) throw(GsmException); + + public: + // create Port given the UNIX device name + UnixSerialPort(string device, speed_t lineSpeed = DEFAULT_BAUD_RATE, + string initString = DEFAULT_INIT_STRING, + bool swHandshake = false) + throw(GsmException); + + // inherited from Port + void putBack(unsigned char c); + int readByte() throw(GsmException); + string getLine() throw(GsmException); + void putLine(string line, + bool carriageReturn = true) throw(GsmException); + bool wait(GsmTime timeout) throw(GsmException); + void setTimeOut(unsigned int timeout); + + virtual ~UnixSerialPort(); + }; + + // convert baudrate string ("300" .. "460800") to speed_t + extern speed_t baudRateStrToSpeed(string baudrate) throw(GsmException); +}; + +#endif // GSM_UNIX_SERIAL_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_util.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_util.cc new file mode 100644 index 0000000000..a6e342d765 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_util.cc @@ -0,0 +1,380 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_util.h +// * +// * Purpose: Various utilities +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 4.5.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#if !defined(HAVE_CONFIG_H) || defined(HAVE_UNISTD_H) +#include +#endif +#if !defined(HAVE_CONFIG_H) || defined(HAVE_MALLOC_H) +#include +#endif +#include +#ifdef HAVE_VSNPRINTF +// switch on vsnprintf() prototype in stdio.h +#define __USE_GNU +#define _GNU_SOURCE +#endif +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +// Latin-1 undefined character (code 172 (Latin-1 boolean not, "¬")) +const int NOP = 172; + +// GSM undefined character (code 16 (GSM Delta)) +const int GSM_NOP = 16; + +// conversion tables, Latin1 to GSM and GSM to Latin1 + +static unsigned char gsmToLatin1Table[] = +{ + // 0 '@', '£', '$', '¥', 'è', 'é', 'ù', 'ì', + '@', 163, '$', 165, 232, 233, 249, 236, + // 8 'ò', 'Ç', LF, 'Ø', 'ø', CR, 'Å', 'å', + 242, 199, 10, 216, 248, 13, 197, 229, + // 16 '¬', '_', '¬', '¬', '¬', '¬', '¬', '¬', + NOP, '_', NOP, NOP, NOP, NOP, NOP, NOP, + // 24 '¬', '¬', '¬', '¬', 'Æ', 'æ', 'ß', 'É', + NOP, NOP, NOP, NOP, 198, 230, 223, 201, + // 32 ' ', '!', '"', '#', '¤', '%', '&', ''', + ' ', '!', '"', '#', 164, '%', '&', '\'', + // 40 '(', ')', '*', '+', ',', '-', '.', '/', + '(', ')', '*', '+', ',', '-', '.', '/', + // 48 '0', '1', '2', '3', '4', '5', '6', '7', + '0', '1', '2', '3', '4', '5', '6', '7', + // 56 '8', '9', ':', ';', '<', '=', '>', '?', + '8', '9', ':', ';', '<', '=', '>', '?', + // 64 '¡', 'A', 'B', 'C', 'D', 'E', 'F', 'G', + 161, 'A', 'B', 'C', 'D', 'E', 'F', 'G', + // 72 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', + 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', + // 80 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', + 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', + // 88 'X', 'Y', 'Z', 'Ä', 'Ö', 'Ñ', 'Ü', '§', + 'X', 'Y', 'Z', 196, 214, 209, 220, 167, + // 96 '¿', 'a', 'b', 'c', 'd', 'e', 'f', 'g', + 191, 'a', 'b', 'c', 'd', 'e', 'f', 'g', + // 104 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', + 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', + // 112 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', + 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', + // 120 'x', 'y', 'z', 'ä', 'ö', 'ñ', 'ü', 'à', + 'x', 'y', 'z', 228, 246, 241, 252, 224 +}; + +static unsigned char latin1ToGsmTable[256]; + +static class Latin1ToGsmTableInit +{ +public: + Latin1ToGsmTableInit() + { + memset((void*)latin1ToGsmTable, GSM_NOP, 256); + for (int i = 0; i < 128; i++) + if (gsmToLatin1Table[i] != NOP) + latin1ToGsmTable[gsmToLatin1Table[i]] = i; + } +} latin1ToGsmTableInit; + +string gsmlib::gsmToLatin1(string s) +{ + string result(s.length(), 0); + for (string::size_type i = 0; i < s.length(); i++) + result[i] = (unsigned char)s[i] > 127 ? NOP : gsmToLatin1Table[s[i]]; + return result; +} + +string gsmlib::latin1ToGsm(string s) +{ + string result(s.length(), 0); + for (string::size_type i = 0; i < s.length(); i++) + result[i] = latin1ToGsmTable[(unsigned char)s[i]]; + return result; +} + +static unsigned char byteToHex[] = +{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', + 'A', 'B', 'C', 'D', 'E', 'F'}; + +string gsmlib::bufToHex(const unsigned char *buf, unsigned long length) +{ + const unsigned char *bb = buf; + string result; + result.reserve(length * 2); + + for (unsigned long i = 0; i < length; ++i) + { + result += byteToHex[*bb >> 4]; + result += byteToHex[*bb++ & 0xf]; + } + return result; +} + +bool gsmlib::hexToBuf(const string &hexString, unsigned char *buf) +{ + if (hexString.length() % 2 != 0) + return false; + + unsigned char *bb = buf; + for (unsigned int i = 0; i < hexString.length(); i += 2) + { + unsigned char c = hexString[i]; + if (! isdigit(c) && ! ('a' <= c && c <= 'f') && ! ('A' <= c && c <= 'F')) + return false; + *bb = (isdigit(c) ? c - '0' : + ((('a' <= c && c <= 'f') ? c - 'a' : c - 'A')) + 10) << 4; + c = hexString[i + 1]; + if (! isdigit(c) && ! ('a' <= c && c <= 'f') && ! ('A' <= c && c <= 'F')) + return false; + *bb++ |= isdigit(c) ? c - '0' : + ((('a' <= c && c <= 'f') ? c - 'a' : c - 'A') + 10); + } + return true; +} + +string gsmlib::intToStr(int i) +{ + ostrstream os; + os << i << ends; + char *ss = os.str(); + string s(ss); + delete[] ss; + return s; +} + +string gsmlib::removeWhiteSpace(string s) +{ + string result; + for (unsigned int i = 0; i < s.length(); ++i) + if (! isspace(s[i])) + result += s[i]; + return result; +} + +#ifdef WIN32 + +// helper routine, find out whether filename starts with "COM" +static bool isCom(string filename) +{ + filename = removeWhiteSpace(lowercase(filename)); + // remove UNC begin + if ( filename.compare(0, 4, "\\\\.\\") == 0 ) + filename.erase(0, 4); + return filename.length() < 3 || filename.substr(0, 3) == "com"; +} +#endif + +bool gsmlib::isFile(string filename) +{ +#ifdef WIN32 + // stat does not work reliably under Win32 to indicate devices + if (isCom(filename)) + return false; +#endif + + struct stat statBuf; + int retries = 0; + + while (retries < 10) + { + if (stat(filename.c_str(), &statBuf) != 0) + throw GsmException( + stringPrintf(_("error when calling stat('%s') (errno: %d/%s)"), + filename.c_str(), errno, strerror(errno)), + OSError); + +#ifndef WIN32 + if (S_ISLNK(statBuf.st_mode)) + { + int size = 100; + while (1) + { + char *buffer = (char*)malloc(size); + int nchars = readlink(filename.c_str(), buffer, size); + if (nchars < size) + { + filename.assign(buffer, nchars); + free(buffer); + break; + } + free(buffer); + size *= 2; + } + ++retries; + } + else if (S_ISCHR(statBuf.st_mode)) + return false; + else +#endif + if (S_ISREG(statBuf.st_mode)) + return true; + else + throw GsmException( + stringPrintf(_("file '%s' is neither file nor character device"), + filename.c_str()), + ParameterError); + } + throw GsmException(_("maxmimum number of symbolic links exceeded"), + ParameterError); +} + +void gsmlib::renameToBackupFile(string filename) throw(GsmException) +{ + string backupFilename = filename + "~"; + unlink(backupFilename.c_str()); + if (rename(filename.c_str(), backupFilename.c_str()) < 0) + throw GsmException( + stringPrintf(_("error renaming '%s' to '%s'"), + filename.c_str(), backupFilename.c_str()), + OSError, errno); +} + +// NoCopy members + +#ifndef NDEBUG + +NoCopy::NoCopy(NoCopy &n) +{ + cerr << "ABORT: NoCopy copy constructor used" << endl; + abort(); +} + +NoCopy &NoCopy::operator=(NoCopy &n) +{ + cerr << "ABORT: NoCopy::operator= used" << endl; + abort(); + return n; +} + +#endif // NDEBUG + +string gsmlib::lowercase(string s) +{ + string result; + for (unsigned int i = 0; i < s.length(); ++i) + result += tolower(s[i]); + return result; +} + +int gsmlib::checkNumber(string s) throw(GsmException) +{ + for (unsigned int i = 0; i < s.length(); ++i) + if (! isdigit(s[i])) + throw GsmException(stringPrintf(_("expected number, got '%s'"), + s.c_str()), ParameterError); + int result; + istrstream is(s.c_str()); + is >> result; + return result; +} + +#ifdef HAVE_VSNPRINTF +string gsmlib::stringPrintf(const char *format, ...) +{ + va_list args; + va_start(args, format); + int size = 1024; + while (1) + { + char *buf = (char*)alloca(sizeof(char) * size); + int nchars = vsnprintf(buf, size, format, args); + if (nchars < size) + { + va_end(args); + return string(buf, nchars); + } + size *= 2; + } + return ""; +} + +#else +char gsmlib::__s[20000]; // buffer for the replacement macro +#endif // HAVE_VSNPRINTF + +#ifndef NDEBUG +int gsmlib::debugLevel() +{ + char *s = getenv("GSMLIB_DEBUG"); + if (s == NULL) return 0; + return checkNumber(s); +} +#endif + +// interrupt interface + +namespace gsmlib +{ + static InterruptBase *interruptObject = NULL; +} + +void gsmlib::setInterruptObject(InterruptBase *intObject) +{ + interruptObject = intObject; +} + +bool gsmlib::interrupted() +{ + return interruptObject != NULL && interruptObject->interrupted(); +} + +void gsmlib::checkTextAndTelephone(string text, string telephone) + throw(GsmException) +{ + if (text.find('"') != string::npos) + throw GsmException( + stringPrintf(_("text '%s' contains illegal character '\"'"), + text.c_str()), + ParameterError); + + for (unsigned int i = 0; i < telephone.length(); ++i) + if (! isdigit(telephone[i]) && ! (telephone[i] == '+') && + ! (telephone[i] == '*') && ! (telephone[i] == '#') && + ! (telephone[i] == 'p') && ! (telephone[i] == 'w') && + ! (telephone[i] == 'P') && ! (telephone[i] == 'W')) + throw GsmException( + stringPrintf(_("illegal character in telephone number '%s'"), + telephone.c_str()), ParameterError); +} + +// progress interface + +namespace gsmlib +{ + static ProgressBase *progressObject = NULL; +} + +void gsmlib::setProgressObject(ProgressBase *progObject) +{ + progressObject = progObject; +} + +void gsmlib::reportProgress(int part, int total) +{ + if (progressObject != NULL) + progressObject->reportProgress(part, total); +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_util.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_util.h new file mode 100644 index 0000000000..127ef05ce6 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_util.h @@ -0,0 +1,232 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_util.h +// * +// * Purpose: Various utilities +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 4.5.1999 +// ************************************************************************* + +#ifndef GSM_UTIL_H +#define GSM_UTIL_H + +#include +#include +#include +#ifndef WIN32 +#include +#endif +#include + +using namespace std; + +namespace gsmlib +{ + // time type + typedef struct timeval *GsmTime; + + // some constants + const char CR = 13; // ASCII carriage return + const char LF = 10; // ASCII line feed + + // common number formats + const unsigned int UnknownNumberFormat = 129; + const unsigned int InternationalNumberFormat = 145; + + // convert gsm to Latin-1 + // characters that have no counterpart in Latin-1 are converted to + // code 172 (Latin-1 boolean not, "¬") + string gsmToLatin1(string s); + + // convert Latin-1 to gsm + // characters that have no counterpart in GSM are converted to + // code 16 (GSM Delta) + string latin1ToGsm(string s); + + // convert byte buffer of length to hexadecimal string + string bufToHex(const unsigned char *buf, unsigned long length); + + // convert hexString to byte buffer, return false if no hexString + bool hexToBuf(const string &hexString, unsigned char *buf); + + // indicate that a value is not set + const int NOT_SET = -1; + + // An integer range + struct IntRange + { + int _high, _low; + + IntRange() : _high(NOT_SET), _low(NOT_SET) {} + }; + + // A valid integer range for a given parameter + struct ParameterRange + { + string _parameter; + IntRange _range; + }; + + // *** general-purpose pointer wrapper with reference counting + + class RefBase + { + private: + int _refCount; + + public: + RefBase() : _refCount(0) {} + int ref() {return _refCount++;} + int unref() {return --_refCount;} + int refCount() const {return _refCount;} + }; + + template + class Ref + { + private: + T *_rep; + public: + T *operator->() const {return _rep;} + T &operator()() {return *_rep;} + T *getptr() {return _rep;} + bool isnull() const {return _rep == (T*)NULL;} + Ref() : _rep((T*)NULL) {} + Ref(T *pp) : _rep(pp) {if (pp != (T*)NULL) pp->ref();} + Ref(const Ref &r); + Ref &operator=(const Ref &r); + ~Ref(); + bool operator==(const Ref &r) const + { + return _rep == r._rep; + } + }; + + template + Ref::Ref(const Ref &r) : _rep(r._rep) + { + if (_rep != (T*)NULL) _rep->ref(); + } + + template + Ref &Ref::operator=(const Ref &r) + { + if (r._rep != (T*)NULL) r._rep->ref(); + if (_rep != (T*)NULL && _rep->unref() == 0) delete _rep; + _rep = r._rep; + return *this; + } + + template + Ref::~Ref() + { + if (_rep != (T*)NULL && _rep->unref() == 0) delete _rep; + } + + // utility function return string given an int + string intToStr(int i); + + // remove white space from the string + string removeWhiteSpace(string s); + + // return true if bit is set in vector + inline bool isSet(vector &b, unsigned int bit) + { + return b.size() > bit && b[bit]; + } + + // return true if filename refers to a file + // throws exception if filename is neither file nor device + bool isFile(string filename); + + // make backup file adequate for this operating system + void renameToBackupFile(string filename) throw(GsmException); + + // Base class for class for which copying is not allow + // only used for debugging + + class NoCopy + { + public: + NoCopy() {} + +#ifndef NDEBUG + NoCopy(NoCopy &n); + + NoCopy &operator=(NoCopy &n); +#endif + }; + + // convert string to lower case + string lowercase(string s); + + // convert string to number and check for all digits + int checkNumber(string s) throw(GsmException); + + // like printf, but return C++ string +#ifdef HAVE_VSNPRINTF + string stringPrintf(const char *format, ...) +#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ > 4) + __attribute__((format (printf, 1, 2))) +#endif + ; +#else + // WARNING: This replacement code is + // - not threadsafe + // - subject to buffer overruns +#define stringPrintf(format, args...) \ + (sprintf(__s, format, ## args), string(__s)) + + extern char __s[]; +#endif // HAVE_VSNPRINTF + + // return debug level +#ifndef NDEBUG + extern int debugLevel(); +#endif + + // interface for interrupting gsmlib activity + + class InterruptBase + { + public: + // this member should return true if gsmlib is to be interrupted + virtual bool interrupted() = 0; + }; + + // set global interrupt object + extern void setInterruptObject(InterruptBase *intObject); + + // return true if interrupted + extern bool interrupted(); + + // interface for reporting progress + + class ProgressBase + { + public: + // override this to receive progress reports + virtual void reportProgress(int part, int total) = 0; + }; + + // set global progress object + extern void setProgressObject(ProgressBase *progObject); + + // report progress (part/total * 100 is meant to be the percentage) + // this function is called by + // - GsmAt::chatv() without arguments, used by Phonebook::Phonebook() + // - Phonebook::Phonebook() + // - SortedPhonebook::SortedPhonebook() + // - SortedSMSStore::SortedSMSStore() + extern void reportProgress(int part = -1, int total = -1); + + // check for valid text and telephone number + // throw exception if error + extern void checkTextAndTelephone(string text, string telephone) + throw(GsmException); +}; + +#endif // GSM_UTIL_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_win32_serial.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_win32_serial.cc new file mode 100644 index 0000000000..dda1d74587 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_win32_serial.cc @@ -0,0 +1,507 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_win32_port.cc +// * +// * Purpose: WIN32 serial port implementation +// * +// * Author: Frediano Ziglio (freddy77@angelfire.com) +// * +// * Created: 25.10.2000 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +static long int timeoutVal = TIMEOUT_SECS; + +struct ExceptionSafeOverlapped: public OVERLAPPED +{ + ExceptionSafeOverlapped() + { + memset((OVERLAPPED*)this,0,sizeof(OVERLAPPED)); + hEvent = CreateEvent( NULL, TRUE, FALSE, NULL ); + if (hEvent == INVALID_HANDLE_VALUE) + throw GsmException(_("error creating event"),OSError,GetLastError()); + } + ~ExceptionSafeOverlapped() + { CloseHandle(hEvent); } +}; + +typedef BOOL (WINAPI *TCancelIoProc)(HANDLE file); +TCancelIoProc CancelIoProc = NULL; +BOOL CancelIoHook(HANDLE file) +{ + if (CancelIoProc) + return CancelIoProc(file); + + HMODULE hmodule = GetModuleHandle("KERNEL32"); + if (hmodule) + { + CancelIoProc = (TCancelIoProc)GetProcAddress(hmodule,"CancelIo"); + if (CancelIoProc) + return CancelIoProc(file); + } + + return TRUE; +} +#define CancelIo CancelIoHook + +// Win32SerialPort members + +void Win32SerialPort::throwModemException(string message) throw(GsmException) +{ + ostrstream os; + os << message << " (errno: " << errno << "/" << strerror(errno) << ")" + << ends; + char *ss = os.str(); + string s(ss); + delete[] ss; + throw GsmException(s, OSError, errno); +} + +void Win32SerialPort::putBack(unsigned char c) +{ + assert(_oldChar == -1); + _oldChar = c; +} + +int Win32SerialPort::readByte() throw(GsmException) +{ + if (_oldChar != -1) + { + int result = _oldChar; + _oldChar = -1; + return result; + } + + unsigned char c; + int timeElapsed = 0; + bool readDone = true; + ExceptionSafeOverlapped over; + + DWORD initTime = GetTickCount(); + DWORD dwReaded; + if (!ReadFile(_file,&c,1,&dwReaded,&over)) + { + readDone = false; + if (GetLastError() != ERROR_IO_PENDING) + { + throwModemException(_("reading from TA")); + } + + while(!readDone) + { + if (interrupted()) + throwModemException(_("interrupted when reading from TA")); + + // wait another second + switch(WaitForSingleObject(over.hEvent,1000)) + { + case WAIT_TIMEOUT: + break; + case WAIT_OBJECT_0: + case WAIT_ABANDONED: + // !!! do a infinite loop if (bytesWritten < lenght) ? + GetOverlappedResult(_file,&over,&dwReaded,TRUE); + readDone = true; + break; + case WAIT_FAILED: + throwModemException(_("reading from TA")); + } + + timeElapsed = (GetTickCount() - initTime)/1000U; + + // timeout elapsed ? + if (timeElapsed >= timeoutVal) + { + CancelIo(_file); + break; + } + + } + } + + if (! readDone) + throwModemException(_("timeout when reading from TA")); + +#ifndef NDEBUG + if (debugLevel() >= 2) + { + // some useful debugging code + if (c == LF) + cerr << ""; + else if (c == CR) + cerr << ""; + else cerr << "<'" << (char) c << "'>"; + cerr.flush(); + } +#endif + return c; +} + +Win32SerialPort::Win32SerialPort(string device, int lineSpeed, + string initString, bool swHandshake) + throw(GsmException) : + _oldChar(-1) +{ + try + { + int holdoff[] = {2000, 1000, 400}; + + // open device + _file = CreateFile(device.c_str(),GENERIC_READ | GENERIC_WRITE, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL | FILE_FLAG_OVERLAPPED, NULL ); + if (_file == INVALID_HANDLE_VALUE) + throwModemException(stringPrintf(_("opening device '%s'"), + device.c_str())); + + int initTries = 3; + while (initTries-- > 0) + { + // flush all pending output + FlushFileBuffers(_file); + + // toggle DTR to reset modem + if (!EscapeCommFunction(_file,CLRDTR)) + throwModemException(_("clearing DTR failed")); + Sleep(holdoff[initTries]); + if (!EscapeCommFunction(_file,SETDTR)) + throwModemException(_("setting DTR failed")); + + DCB dcb; + // get line modes + if (!GetCommState(_file,&dcb)) + throwModemException(stringPrintf(_("GetCommState device '%s'"), + device.c_str())); + +// if (tcgetattr(_fd, &t) < 0) +// throwModemException(stringPrintf(_("tcgetattr device '%s'"), +// device.c_str())); + + // set the device to a sane state + dcb.fBinary = TRUE; + dcb.BaudRate = lineSpeed; + + // n,8,1 + dcb.fParity = FALSE; + dcb.Parity = 0; + dcb.ByteSize = 8; + dcb.StopBits = 0; + + if (!swHandshake) + { + dcb.fInX = FALSE; + dcb.fOutX = FALSE; + dcb.fOutxDsrFlow = FALSE; + dcb.fOutxCtsFlow = FALSE; + } + else + { + dcb.fInX = TRUE; + dcb.fOutX = TRUE; + dcb.fOutxDsrFlow = FALSE; + dcb.fOutxCtsFlow = FALSE; + } + dcb.fDtrControl = DTR_CONTROL_ENABLE; + dcb.fRtsControl = RTS_CONTROL_ENABLE; + +// t.c_iflag |= IGNPAR; +// t.c_iflag &= ~(INPCK | ISTRIP | IMAXBEL | +// (swHandshake ? CRTSCTS : IXON | IXOFF) +// | IXANY | IGNCR | ICRNL | IMAXBEL | INLCR | IGNBRK); +// t.c_oflag &= ~(OPOST); +// // be careful, only touch "known" flags +// t.c_cflag&= ~(CSIZE | CSTOPB | PARENB | PARODD); +// t.c_cflag|= CS8 | CREAD | HUPCL | +// (swHandshake ? IXON | IXOFF : CRTSCTS) | +// CLOCAL; +// t.c_lflag &= ~(ECHO | ECHOE | ECHOPRT | ECHOK | ECHOKE | ECHONL | +// ECHOCTL | ISIG | IEXTEN | TOSTOP | FLUSHO | ICANON); +// t.c_lflag |= NOFLSH; +// +// t.c_cc[VMIN] = 1; +// t.c_cc[VTIME] = 0; +// +// t.c_cc[VSUSP] = 0; + + // write back + if (!SetCommState(_file,&dcb)) + throwModemException(stringPrintf(_("SetCommState device '%s'"), + device.c_str())); + + Sleep(holdoff[initTries]); + + if (!SetupComm(_file,1024,1024)) + throwModemException(stringPrintf(_("SetupComm device '%s'"), + device.c_str())); + + + // flush all pending input + PurgeComm(_file,PURGE_RXABORT|PURGE_RXCLEAR); + + try + { + // reset modem + putLine("ATZ"); + bool foundOK = false; + int readTries = 5; + while (readTries-- > 0) + { + string s = getLine(); + if (s.find("OK") != string::npos || + s.find("CABLE: GSM") != string::npos) + { + foundOK = true; + readTries = 0; // found OK, exit loop + } + } + + if (foundOK) + { + // init modem + readTries = 5; + // !!! no not declare this in loop, compiler error on Visual C++ + // (without SP and with SP4) + string s; + putLine("AT" + initString); + do + { + s = getLine(); + if (s.find("OK") != string::npos || + s.find("CABLE: GSM") != string::npos) + return; // found OK, return + } while(--readTries); + } + } + catch (GsmException &e) + { + if (initTries == 0) + throw e; + } + } + // no response after 3 tries + throw GsmException(stringPrintf(_("reset modem failed '%s'"), + device.c_str()), OtherError); + } + catch (GsmException &e) + { + if ( _file != INVALID_HANDLE_VALUE) + CloseHandle(_file); + throw e; + } +} + +string Win32SerialPort::getLine() throw(GsmException) +{ + string result; + int c; + while ((c = readByte()) > 0) + { + while (c == CR) + { + c = readByte(); + } + if (c == LF) + break; + result += c; + } + +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "<-- " << result << endl; +#endif + + return result; +} + +void Win32SerialPort::putLine(string line, + bool carriageReturn) throw(GsmException) +{ +#ifndef NDEBUG + if (debugLevel() >= 1) + cerr << "--> " << line << endl; +#endif + + if (carriageReturn) line += CR; + // !!! BUG, mantain this pointer isn't corrent, use iterator !!! + const char *l = line.c_str(); + + FlushFileBuffers(_file); // flush all pending input and output + + int timeElapsed = 0; + + DWORD bytesWritten = 0; + + ExceptionSafeOverlapped over; + + DWORD initTime = GetTickCount(); + if (!WriteFile(_file,l,line.length(),&bytesWritten,&over)) + { + if (GetLastError() != ERROR_IO_PENDING) + { + throwModemException(_("writing to TA")); + } + + while(bytesWritten < (DWORD)line.length()) + { + if (interrupted()) + throwModemException(_("interrupted when writing to TA")); + + // wait another second + switch(WaitForSingleObject(over.hEvent,1000)) + { + case WAIT_TIMEOUT: + break; + case WAIT_OBJECT_0: + case WAIT_ABANDONED: + // !!! do a infinite loop if (bytesWritten < lenght) ? + GetOverlappedResult(_file,&over,&bytesWritten,TRUE); + break; + case WAIT_FAILED: + throwModemException(_("writing to TA")); + } + + timeElapsed = (GetTickCount() - initTime)/1000U; + + // timeout elapsed ? + if (timeElapsed >= timeoutVal) + { + CancelIo(_file); + throwModemException(_("timeout when writing to TA")); + } + + } + } + + return; +/* + // empty buffer + SetCommMask(_file,EV_TXEMPTY); + DWORD dwEvent; + ResetEvent(over.hEvent); + if( WaitCommEvent(_file,&dwEvent,&over) ) + return; // already empty + + // check true errors + if (GetLastError() != ERROR_IO_PENDING) + throwModemException(_("error comm waiting")); + + while(timeElapsed < timeoutVal) + { + if (interrupted()) + throwModemException(_("interrupted when flushing to TA")); + + switch( WaitForSingleObject( over.hEvent, 1000 ) ) + { + case WAIT_TIMEOUT: + break; + + // successfully flushed + case WAIT_ABANDONED: + case WAIT_OBJECT_0: + return; + + default: + throwModemException(_("error waiting")); + } + timeElapsed = (GetTickCount() - initTime)/1000U; + } + + CancelIo(_file); + throwModemException(_("timeout when writing to TA")); +*/ + + // echo CR LF must be removed by higher layer functions in gsm_at because + // in order to properly handle unsolicited result codes from the ME/TA +} + +bool Win32SerialPort::wait(GsmTime timeout) throw(GsmException) +{ + // See differences from UNIX + // Why do I use Windows ? + DWORD dwEvent; + SetCommMask(_file,EV_RXCHAR); + if (!timeout) + { + if( !WaitCommEvent(_file,&dwEvent,NULL) ) + throwModemException(_("error comm waiting")); + return true; + } + + ExceptionSafeOverlapped over; + if( !WaitCommEvent(_file,&dwEvent,&over) ) + { + // check true errors + if (GetLastError() != ERROR_IO_PENDING) + throwModemException(_("error comm waiting")); + + switch( WaitForSingleObject( over.hEvent, timeout->tv_sec*1000U+(timeout->tv_usec/1000U) ) ) + { + case WAIT_TIMEOUT: + CancelIo(_file); + return false; + + case WAIT_ABANDONED: + case WAIT_OBJECT_0: + return true; + + default: + throwModemException(_("error waiting")); + } + } + + return true; +} + +void Win32SerialPort::setTimeOut(unsigned int timeout) +{ + timeoutVal = timeout; +} + +Win32SerialPort::~Win32SerialPort() +{ + if ( _file != INVALID_HANDLE_VALUE) + CloseHandle(_file); +} + +int gsmlib::baudRateStrToSpeed(string baudrate) throw(GsmException) +{ + if (baudrate == "300") + return 300; + else if (baudrate == "600") + return 600; + else if (baudrate == "1200") + return 1200; + else if (baudrate == "2400") + return 2400; + else if (baudrate == "4800") + return 4800; + else if (baudrate == "9600") + return 9600; + else if (baudrate == "19200") + return 19200; + else if (baudrate == "38400") + return 38400; + else if (baudrate == "57600") + return 57600; + else if (baudrate == "115200") + return 115200; + else + throw GsmException(stringPrintf(_("unknown baudrate '%s'"), + baudrate.c_str()), ParameterError); +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_win32_serial.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_win32_serial.h new file mode 100644 index 0000000000..627bd09354 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/gsmlib/gsm_win32_serial.h @@ -0,0 +1,60 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: gsm_win32_port.h +// * +// * Purpose: WIN32 serial port implementation +// * +// * Author: Frediano Ziglio (freddy77@angelfire.com) +// * +// * Created: 25.10.2000 +// ************************************************************************* + +#ifndef GSM_WIN32_SERIAL_H +#define GSM_WIN32_SERIAL_H + +#include +#include +#include +#include +#define WIN32_MEAN_AND_LEAN +#include + +using namespace std; + +namespace gsmlib +{ + class Win32SerialPort : public Port + { + private: + HANDLE _file; // file handle for device + int _oldChar; // character set by putBack() (-1 == none) +// OVERLAPPED _overIn; // overlapped structure for wait + + // throw GsmException include UNIX errno + void throwModemException(string message) throw(GsmException); + + public: + // create Port given the UNIX device name + Win32SerialPort(string device, int lineSpeed = DEFAULT_BAUD_RATE, + string initString = DEFAULT_INIT_STRING, + bool swHandshake = false) + throw(GsmException); + + // inherited from Port + void putBack(unsigned char c); + int readByte() throw(GsmException); + string getLine() throw(GsmException); + void putLine(string line, + bool carriageReturn = true) throw(GsmException); + bool wait(GsmTime timeout) throw(GsmException); + void setTimeOut(unsigned int timeout); + + virtual ~Win32SerialPort(); + }; + + // convert baudrate string ("300" .. "460800") to speed_t + extern int baudRateStrToSpeed(string baudrate) throw(GsmException); +}; + +#endif // GSM_UNIX_SERIAL_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/ChangeLog b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/ChangeLog new file mode 100644 index 0000000000..198950159d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/ChangeLog @@ -0,0 +1,1086 @@ +1998-04-29 Ulrich Drepper + + * intl/localealias.c (read_alias_file): Use unsigned char for + local variables. Remove unused variable tp. + * intl/l10nflist.c (_nl_normalize_codeset): Use unsigned char * + for type of codeset. For loosing Solaris systems. + * intl/loadinfo.h: Adapt prototype of _nl_normalize_codeset. + * intl/bindtextdom.c (BINDTEXTDOMAIN): Don't define local variable + len if not needed. + Patches by Jim Meyering. + +1998-04-28 Ulrich Drepper + + * loadmsgcat.c (_nl_load_domain): Don't assign the element use_mmap if + mmap is not supported. + + * hash-string.h: Don't include . + +1998-04-27 Ulrich Drepper + + * textdomain.c: Use strdup is available. + + * localealias.c: Define HAVE_MEMPCPY so that we can use this + function. Define and use semapahores to protect modfication of + global objects when compiling for glibc. Add code to allow + freeing alias table. + + * l10nflist.c: Don't assume stpcpy not being a macro. + + * gettextP.h: Define internal_function macri if not already done. + Use glibc byte-swap macros instead of defining SWAP when compiled + for glibc. + (struct loaded_domain): Add elements to allow unloading. + + * Makefile.in (distclean): Don't remove libintl.h here. + + * bindtextdomain.c: Carry over changes from glibc. Use strdup if + available. + + * dcgettext.c: Don't assume stpcpy not being a macro. Mark internal + functions. Add memory freeing code for glibc. + + * dgettext.c: Update copyright. + + * explodename.c: Include stdlib.h and string.h only if they exist. + Use strings.h eventually. + + * finddomain.c: Mark internal functions. Use strdup if available. + Add memory freeing code for glibc. + +1997-10-10 20:00 Ulrich Drepper + + * libgettext.h: Fix dummy textdomain and bindtextdomain macros. + They should return reasonable values. + Reported by Tom Tromey . + +1997-09-16 03:33 Ulrich Drepper + + * libgettext.h: Define PARAMS also to `args' if __cplusplus is defined. + * intlh.inst.in: Likewise. + Reported by Jean-Marc Lasgouttes . + + * libintl.glibc: Update from current glibc version. + +1997-09-06 02:10 Ulrich Drepper + + * intlh.inst.in: Reformat copyright. + +1997-08-19 15:22 Ulrich Drepper + + * dcgettext.c (DCGETTEXT): Remove wrong comment. + +1997-08-16 00:13 Ulrich Drepper + + * Makefile.in (install-data): Don't change directory to install. + +1997-08-01 14:30 Ulrich Drepper + + * cat-compat.c: Fix copyright. + + * localealias.c: Don't define strchr unless !HAVE_STRCHR. + + * loadmsgcat.c: Update copyright. Fix typos. + + * l10nflist.c: Don't define strchr unless !HAVE_STRCHR. + (_nl_make_l10nflist): Handle sponsor and revision correctly. + + * gettext.c: Update copyright. + * gettext.h: Likewise. + * hash-string.h: Likewise. + + * finddomain.c: Remoave dead code. Define strchr only if + !HAVE_STRCHR. + + * explodename.c: Include . + + * explodename.c: Reformat copyright text. + (_nl_explode_name): Fix typo. + + * dcgettext.c: Define and use __set_errno. + (guess_category_value): Don't use setlocale if HAVE_LC_MESSAGES is + not defined. + + * bindtextdom.c: Pretty printing. + +1997-05-01 02:25 Ulrich Drepper + + * dcgettext.c (guess_category_value): Don't depend on + HAVE_LC_MESSAGES. We don't need the macro here. + Patch by Bruno Haible . + + * cat-compat.c (textdomain): DoN't refer to HAVE_SETLOCALE_NULL + macro. Instead use HAVE_LOCALE_NULL and define it when using + glibc, as in dcgettext.c. + Patch by Bruno Haible . + + * Makefile.in (CPPFLAGS): New variable. Reported by Franc,ois + Pinard. + +Mon Mar 10 06:51:17 1997 Ulrich Drepper + + * Makefile.in: Implement handling of libtool. + + * gettextP.h: Change data structures for use of generic lowlevel + i18n file handling. + +Wed Dec 4 20:21:18 1996 Ulrich Drepper + + * textdomain.c: Put parentheses around arguments of memcpy macro + definition. + * localealias.c: Likewise. + * l10nflist.c: Likewise. + * finddomain.c: Likewise. + * bindtextdom.c: Likewise. + Reported by Thomas Esken. + +Mon Nov 25 22:57:51 1996 Ulrich Drepper + + * textdomain.c: Move definition of `memcpy` macro to right + position. + +Fri Nov 22 04:01:58 1996 Ulrich Drepper + + * finddomain.c [!HAVE_STRING_H && !_LIBC]: Define memcpy using + bcopy if not already defined. Reported by Thomas Esken. + * bindtextdom.c: Likewise. + * l10nflist.c: Likewise. + * localealias.c: Likewise. + * textdomain.c: Likewise. + +Tue Oct 29 11:10:27 1996 Ulrich Drepper + + * Makefile.in (libdir): Change to use exec_prefix instead of + prefix. Reported by Knut-HåvardAksnes . + +Sat Aug 31 03:07:09 1996 Ulrich Drepper + + * l10nflist.c (_nl_normalize_codeset): We convert to lower case, + so don't prepend uppercase `ISO' for only numeric arg. + +Fri Jul 19 00:15:46 1996 Ulrich Drepper + + * l10nflist.c: Move inclusion of argz.h, ctype.h, stdlib.h after + definition of _GNU_SOURCE. Patch by Roland McGrath. + + * Makefile.in (uninstall): Fix another bug with `for' loop and + empty arguments. Patch by Jim Meyering. Correct name os + uninstalled files: no intl- prefix anymore. + + * Makefile.in (install-data): Again work around shells which + cannot handle mpty for list. Reported by Jim Meyering. + +Sat Jul 13 18:11:35 1996 Ulrich Drepper + + * Makefile.in (install): Split goal. Now depend on install-exec + and install-data. + (install-exec, install-data): New goals. Created from former + install goal. + Reported by Karl Berry. + +Sat Jun 22 04:58:14 1996 Ulrich Drepper + + * Makefile.in (MKINSTALLDIRS): New variable. Path to + mkinstalldirs script. + (install): use MKINSTALLDIRS variable or if the script is not present + try to find it in the $top_scrdir). + +Wed Jun 19 02:56:56 1996 Ulrich Drepper + + * l10nflist.c: Linux libc *partly* includes the argz_* functions. + Grr. Work around by renaming the static version and use macros + for renaming. + +Tue Jun 18 20:11:17 1996 Ulrich Drepper + + * l10nflist.c: Correct presence test macros of __argz_* functions. + + * l10nflist.c: Include based on test of it instead when + __argz_* functions are available. + Reported by Andreas Schwab. + +Thu Jun 13 15:17:44 1996 Ulrich Drepper + + * explodename.c, l10nflist.c: Define NULL for dumb systems. + +Tue Jun 11 17:05:13 1996 Ulrich Drepper + + * intlh.inst.in, libgettext.h (dcgettext): Rename local variable + result to __result to prevent name clash. + + * l10nflist.c, localealias.c, dcgettext.c: Define _GNU_SOURCE to + get prototype for stpcpy and strcasecmp. + + * intlh.inst.in, libgettext.h: Move declaration of + `_nl_msg_cat_cntr' outside __extension__ block to prevent warning + from gcc's -Wnested-extern option. + +Fri Jun 7 01:58:00 1996 Ulrich Drepper + + * Makefile.in (install): Remove comment. + +Thu Jun 6 17:28:17 1996 Ulrich Drepper + + * Makefile.in (install): Work around for another Buglix stupidity. + Always use an `else' close for `if's. Reported by Nelson Beebe. + + * Makefile.in (intlh.inst): Correct typo in phony rule. + Reported by Nelson Beebe. + +Thu Jun 6 01:49:52 1996 Ulrich Drepper + + * dcgettext.c (read_alias_file): Rename variable alloca_list to + block_list as the macro calls assume. + Patch by Eric Backus. + + * localealias.c [!HAVE_ALLOCA]: Define alloca as macro using + malloc. + (read_alias_file): Rename varriabe alloca_list to block_list as the + macro calls assume. + Patch by Eric Backus. + + * l10nflist.c: Correct conditional for inclusion. + Reported by Roland McGrath. + + * Makefile.in (all): Depend on all-@USE_INCLUDED_LIBINTL@, not + all-@USE_NLS@. + + * Makefile.in (install): intlh.inst comes from local dir, not + $(srcdir). + + * Makefile.in (intlh.inst): Special handling of this goal. If + used in gettext, this is really a rul to construct this file. If + used in any other package it is defined as a .PHONY rule with + empty body. + + * finddomain.c: Extract locale file information handling into + l10nfile.c. Rename local stpcpy__ function to stpcpy. + + * dcgettext.c (stpcpy): Add local definition. + + * l10nflist.c: Solve some portability problems. Patches partly by + Thomas Esken. Add local definition of stpcpy. + +Tue Jun 4 02:47:49 1996 Ulrich Drepper + + * intlh.inst.in: Don't depend including on + HAVE_LOCALE_H. Instead configure must rewrite this fiile + depending on the result of the configure run. + + * Makefile.in (install): libintl.inst is now called intlh.inst. + Add rules for updating intlh.inst from intlh.inst.in. + + * libintl.inst: Renamed to intlh.inst.in. + + * localealias.c, dcgettext.c [__GNUC__]: Define HAVE_ALLOCA to 1 + because gcc has __buitlin_alloca. + Reported by Roland McGrath. + +Mon Jun 3 00:32:16 1996 Ulrich Drepper + + * Makefile.in (installcheck): New goal to fulfill needs of + automake's distcheck. + + * Makefile.in (install): Reorder commands so that VERSION is + found. + + * Makefile.in (gettextsrcdir): Now use subdirectory intl/ in + @datadir@/gettext. + (COMSRCS): Add l10nfile.c. + (OBJECTS): Add l10nfile.o. + (DISTFILES): Rename to DISTFILE.normal. Remove $(DISTFILES.common). + (DISTFILE.gettext): Remove $(DISTFILES.common). + (all-gettext): Remove goal. + (install): If $(PACKAGE) = gettext install, otherwose do nothing. No + package but gettext itself should install libintl.h + headers. + (dist): Extend goal to work for gettext, too. + (dist-gettext): Remove goal. + + * dcgettext.c [!HAVE_ALLOCA]: Define macro alloca by using malloc. + +Sun Jun 2 17:33:06 1996 Ulrich Drepper + + * loadmsgcat.c (_nl_load_domain): Parameter is now comes from + find_l10nfile. + +Sat Jun 1 02:23:03 1996 Ulrich Drepper + + * l10nflist.c (__argz_next): Add definition. + + * dcgettext.c [!HAVE_ALLOCA]: Add code for handling missing alloca + code. Use new l10nfile handling. + + * localealias.c [!HAVE_ALLOCA]: Add code for handling missing + alloca code. + + * l10nflist.c: Initial revision. + +Tue Apr 2 18:51:18 1996 Ulrich Drepper + + * Makefile.in (all-gettext): New goal. Same as all-yes. + +Thu Mar 28 23:01:22 1996 Karl Eichwalder + + * Makefile.in (gettextsrcdir): Define using @datadir@. + +Tue Mar 26 12:39:14 1996 Ulrich Drepper + + * finddomain.c: Include . Reported by Roland McGrath. + +Sat Mar 23 02:00:35 1996 Ulrich Drepper + + * finddomain.c (stpcpy): Rename to stpcpy__ to prevent clashing + with external declaration. + +Sat Mar 2 00:47:09 1996 Ulrich Drepper + + * Makefile.in (all-no): Rename from all_no. + +Sat Feb 17 00:25:59 1996 Ulrich Drepper + + * gettextP.h [loaded_domain]: Array `successor' must now contain up + to 63 elements (because of codeset name normalization). + + * finddomain.c: Implement codeset name normalization. + +Thu Feb 15 04:39:09 1996 Ulrich Drepper + + * Makefile.in (all): Define to `all-@USE_NLS@'. + (all-yes, all_no): New goals. `all-no' is noop, `all-yes' + is former all. + +Mon Jan 15 21:46:01 1996 Howard Gayle + + * localealias.c (alias_compare): Increment string pointers in loop + of strcasecmp replacement. + +Fri Dec 29 21:16:34 1995 Ulrich Drepper + + * Makefile.in (install-src): Who commented this goal out ? :-) + +Fri Dec 29 15:08:16 1995 Ulrich Drepper + + * dcgettext.c (DCGETTEXT): Save `errno'. Failing system calls + should not effect it because a missing catalog is no error. + Reported by Harald Knig . + +Tue Dec 19 22:09:13 1995 Ulrich Drepper + + * Makefile.in (Makefile): Explicitly use $(SHELL) for running + shell scripts. + +Fri Dec 15 17:34:59 1995 Andreas Schwab + + * Makefile.in (install-src): Only install library and header when + we use the own implementation. Don't do it when using the + system's gettext or catgets functions. + + * dcgettext.c (find_msg): Must not swap domain->hash_size here. + +Sat Dec 9 16:24:37 1995 Ulrich Drepper + + * localealias.c, libintl.inst, libgettext.h, hash-string.h, + gettextP.h, finddomain.c, dcgettext.c, cat-compat.c: + Use PARAMS instead of __P. Suggested by Roland McGrath. + +Tue Dec 5 11:39:14 1995 Larry Schwimmer + + * libgettext.h: Use `#if !defined (_LIBINTL_H)' instead of `#if + !_LIBINTL_H' because Solaris defines _LIBINTL_H as empty. + +Mon Dec 4 15:42:07 1995 Ulrich Drepper + + * Makefile.in (install-src): + Install libintl.inst instead of libintl.h.install. + +Sat Dec 2 22:51:38 1995 Marcus Daniels + + * cat-compat.c (textdomain): + Reverse order in which files are tried you load. First + try local file, when this failed absolute path. + +Wed Nov 29 02:03:53 1995 Nelson H. F. Beebe + + * cat-compat.c (bindtextdomain): Add missing { }. + +Sun Nov 26 18:21:41 1995 Ulrich Drepper + + * libintl.inst: Add missing __P definition. Reported by Nelson Beebe. + + * Makefile.in: + Add dummy `all' and `dvi' goals. Reported by Tom Tromey. + +Sat Nov 25 16:12:01 1995 Franc,ois Pinard + + * hash-string.h: Capitalize arguments of macros. + +Sat Nov 25 12:01:36 1995 Ulrich Drepper + + * Makefile.in (DISTFILES): Prevent files names longer than 13 + characters. libintl.h.glibc->libintl.glibc, + libintl.h.install->libintl.inst. Reported by Joshua R. Poulson. + +Sat Nov 25 11:31:12 1995 Eric Backus + + * dcgettext.c: Fix bug in preprocessor conditionals. + +Sat Nov 25 02:35:27 1995 Nelson H. F. Beebe + + * libgettext.h: Solaris cc does not understand + #if !SYMBOL1 && !SYMBOL2. Sad but true. + +Thu Nov 23 16:22:14 1995 Ulrich Drepper + + * hash-string.h (hash_string): + Fix for machine with >32 bit `unsigned long's. + + * dcgettext.c (DCGETTEXT): + Fix horrible bug in loop for alternative translation. + +Thu Nov 23 01:45:29 1995 Ulrich Drepper + + * po2tbl.sed.in, linux-msg.sed, xopen-msg.sed: + Some further simplifications in message number generation. + +Mon Nov 20 21:08:43 1995 Ulrich Drepper + + * libintl.h.glibc: Use __const instead of const in prototypes. + + * Makefile.in (install-src): + Install libintl.h.install instead of libintl.h. This + is a stripped-down version. Suggested by Peter Miller. + + * libintl.h.install, libintl.h.glibc: Initial revision. + + * localealias.c (_nl_expand_alias, read_alias_file): + Protect prototypes in type casts by __P. + +Tue Nov 14 16:43:58 1995 Ulrich Drepper + + * hash-string.h: Correct prototype for hash_string. + +Sun Nov 12 12:42:30 1995 Ulrich Drepper + + * hash-string.h (hash_string): Add prototype. + + * gettextP.h: Fix copyright. + (SWAP): Add prototype. + +Wed Nov 8 22:56:33 1995 Ulrich Drepper + + * localealias.c (read_alias_file): Forgot sizeof. + Avoid calling *printf function. This introduces a big overhead. + Patch by Roland McGrath. + +Tue Nov 7 14:21:08 1995 Ulrich Drepper + + * finddomain.c, cat-compat.c: Wrong indentation in #if for stpcpy. + + * finddomain.c (stpcpy): + Define substitution function local. The macro was to flaky. + + * cat-compat.c: Fix typo. + + * xopen-msg.sed, linux-msg.sed: + While bringing message number to right place only accept digits. + + * linux-msg.sed, xopen-msg.sed: Now that the counter does not have + leading 0s we don't need to remove them. Reported by Marcus + Daniels. + + * Makefile.in (../po/cat-id-tbl.o): Use $(top_srdir) in + dependency. Reported by Marcus Daniels. + + * cat-compat.c: (stpcpy) [!_LIBC && !HAVE_STPCPY]: Define replacement. + Generally cleanup using #if instead of #ifndef. + + * Makefile.in: Correct typos in comment. By Franc,ois Pinard. + +Mon Nov 6 00:27:02 1995 Ulrich Drepper + + * Makefile.in (install-src): Don't install libintl.h and libintl.a + if we use an available gettext implementation. + +Sun Nov 5 22:02:08 1995 Ulrich Drepper + + * libgettext.h: Fix typo: HAVE_CATGETTS -> HAVE_CATGETS. Reported + by Franc,ois Pinard. + + * libgettext.h: Use #if instead of #ifdef/#ifndef. + + * finddomain.c: + Comments describing what has to be done should start with FIXME. + +Sun Nov 5 19:38:01 1995 Ulrich Drepper + + * Makefile.in (DISTFILES): Split. Use DISTFILES with normal meaning. + DISTFILES.common names the files common to both dist goals. + DISTFILES.gettext are the files only distributed in GNU gettext. + +Sun Nov 5 17:32:54 1995 Ulrich Drepper + + * dcgettext.c (DCGETTEXT): Correct searching in derived locales. + This was necessary since a change in _nl_find_msg several weeks + ago. I really don't know this is still not fixed. + +Sun Nov 5 12:43:12 1995 Ulrich Drepper + + * loadmsgcat.c (_nl_load_domain): Test for FILENAME == NULL. This + might mark a special condition. + + * finddomain.c (make_entry_rec): Don't make illegal entry as decided. + + * Makefile.in (dist): Suppress error message when ln failed. + Get files from $(srcdir) explicitly. + + * libgettext.h (gettext_const): Rename to gettext_noop. + +Fri Nov 3 07:36:50 1995 Ulrich Drepper + + * finddomain.c (make_entry_rec): + Protect against wrong locale names by testing mask. + + * libgettext.h (gettext_const): Add macro definition. + Capitalize macro arguments. + +Thu Nov 2 23:15:51 1995 Ulrich Drepper + + * finddomain.c (_nl_find_domain): + Test for pointer != NULL before accessing value. + Reported by Tom Tromey. + + * gettext.c (NULL): + Define as (void*)0 instad of 0. Reported by Franc,ois Pinard. + +Mon Oct 30 21:28:52 1995 Ulrich Drepper + + * po2tbl.sed.in: Serious typo bug fixed by Jim Meyering. + +Sat Oct 28 23:20:47 1995 Ulrich Drepper + + * libgettext.h: Disable dcgettext optimization for Solaris 2.3. + + * localealias.c (alias_compare): + Peter Miller reported that tolower in some systems is + even dumber than I thought. Protect call by `isupper'. + +Fri Oct 27 22:22:51 1995 Ulrich Drepper + + * Makefile.in (libdir, includedir): New variables. + (install-src): Install libintl.a and libintl.h in correct dirs. + +Fri Oct 27 22:07:29 1995 Ulrich Drepper + + * Makefile.in (SOURCES): Fix typo: intrl.compat.c -> intl-compat.c. + + * po2tbl.sed.in: Patch for buggy SEDs by Christian von Roques. + + * localealias.c: + Fix typo and superflous test. Reported by Christian von Roques. + +Fri Oct 6 11:52:05 1995 Ulrich Drepper + + * finddomain.c (_nl_find_domain): + Correct some remainder from the pre-CEN syntax. Now + we don't have a constant number of successors anymore. + +Wed Sep 27 21:41:13 1995 Ulrich Drepper + + * Makefile.in (DISTFILES): Add libintl.h.glibc. + + * Makefile.in (dist-libc): Add goal for packing sources for glibc. + (COMSRCS, COMHDRS): Splitted to separate sources shared with glibc. + + * loadmsgcat.c: Forget to continue #if line. + + * localealias.c: + [_LIBC]: Rename strcasecmp to __strcasecmp to keep ANSI C name + space clean. + + * dcgettext.c, finddomain.c: Better comment to last change. + + * loadmsgcat.c: + [_LIBC]: Rename fstat, open, close, read, mmap, and munmap to + __fstat, __open, __close, __read, __mmap, and __munmap resp + to keep ANSI C name space clean. + + * finddomain.c: + [_LIBC]: Rename stpcpy to __stpcpy to keep ANSI C name space clean. + + * dcgettext.c: + [_LIBC]: Rename getced and stpcpy to __getcwd and __stpcpy resp to + keep ANSI C name space clean. + + * libgettext.h: + Include sys/types.h for those old SysV systems out there. + Reported by Francesco Potorti`. + + * loadmsgcat.c (use_mmap): Define if compiled for glibc. + + * bindtextdom.c: Include all those standard headers + unconditionally if _LIBC is defined. + + * finddomain.c: Fix 2 times defiend -> defined. + + * textdomain.c: Include libintl.h instead of libgettext.h when + compiling for glibc. Include all those standard headers + unconditionally if _LIBC is defined. + + * localealias.c, loadmsgcat.c: Prepare to be compiled in glibc. + + * gettext.c: + Include libintl.h instead of libgettext.h when compiling for glibc. + Get NULL from stddef.h if we compile for glibc. + + * finddomain.c: Include libintl.h instead of libgettext.h when + compiling for glibc. Include all those standard headers + unconditionally if _LIBC is defined. + + * dcgettext.c: Include all those standard headers unconditionally + if _LIBC is defined. + + * dgettext.c: If compiled in glibc include libintl.h instead of + libgettext.h. + (locale.h): Don't rely on HAVE_LOCALE_H when compiling for glibc. + + * dcgettext.c: If compiled in glibc include libintl.h instead of + libgettext.h. + (getcwd): Don't rely on HAVE_GETCWD when compiling for glibc. + + * bindtextdom.c: + If compiled in glibc include libintl.h instead of libgettext.h. + +Mon Sep 25 22:23:06 1995 Ulrich Drepper + + * localealias.c (_nl_expand_alias): Don't call bsearch if NMAP <= 0. + Reported by Marcus Daniels. + + * cat-compat.c (bindtextdomain): + String used in putenv must not be recycled. + Reported by Marcus Daniels. + + * libgettext.h (__USE_GNU_GETTEXT): + Additional symbol to signal that we use GNU gettext + library. + + * cat-compat.c (bindtextdomain): + Fix bug with the strange stpcpy replacement. + Reported by Nelson Beebe. + +Sat Sep 23 08:23:51 1995 Ulrich Drepper + + * cat-compat.c: Include for stpcpy prototype. + + * localealias.c (read_alias_file): + While expand strdup code temporary variable `cp' hided + higher level variable with same name. Rename to `tp'. + + * textdomain.c (textdomain): + Avoid warning by using temporary variable in strdup code. + + * finddomain.c (_nl_find_domain): Remove unused variable `application'. + +Thu Sep 21 15:51:44 1995 Ulrich Drepper + + * localealias.c (alias_compare): + Use strcasecmp() only if available. Else use + implementation in place. + + * intl-compat.c: + Wrapper functions now call *__ functions instead of __*. + + * libgettext.h: Declare prototypes for *__ functions instead for __*. + + * cat-compat.c, loadmsgcat.c: + Don't use xmalloc, xstrdup, and stpcpy. These functions are not part + of the standard libc and so prevent libintl.a from being used + standalone. + + * bindtextdom.c: + Don't use xmalloc, xstrdup, and stpcpy. These functions are not part + of the standard libc and so prevent libintl.a from being used + standalone. + Rename to bindtextdomain__ if not used in GNU C Library. + + * dgettext.c: + Rename function to dgettext__ if not used in GNU C Library. + + * gettext.c: + Don't use xmalloc, xstrdup, and stpcpy. These functions are not part + of the standard libc and so prevent libintl.a from being used + standalone. + Functions now called gettext__ if not used in GNU C Library. + + * dcgettext.c, localealias.c, textdomain.c, finddomain.c: + Don't use xmalloc, xstrdup, and stpcpy. These functions are not part + of the standard libc and so prevent libintl.a from being used + standalone. + +Sun Sep 17 23:14:49 1995 Ulrich Drepper + + * finddomain.c: Correct some bugs in handling of CEN standard + locale definitions. + +Thu Sep 7 01:49:28 1995 Ulrich Drepper + + * finddomain.c: Implement CEN syntax. + + * gettextP.h (loaded_domain): Extend number of successors to 31. + +Sat Aug 19 19:25:29 1995 Ulrich Drepper + + * Makefile.in (aliaspath): Remove path to X11 locale dir. + + * Makefile.in: Make install-src depend on install. This helps + gettext to install the sources and other packages can use the + install goal. + +Sat Aug 19 15:19:33 1995 Ulrich Drepper + + * Makefile.in (uninstall): Remove stuff installed by install-src. + +Tue Aug 15 13:13:53 1995 Ulrich Drepper + + * VERSION.in: Initial revision. + + * Makefile.in (DISTFILES): + Add VERSION file. This is not necessary for gettext, but + for other packages using this library. + +Tue Aug 15 06:16:44 1995 Ulrich Drepper + + * gettextP.h (_nl_find_domain): + New prototype after changing search strategy. + + * finddomain.c (_nl_find_domain): + We now try only to find a specified catalog. Fall back to other + catalogs listed in the locale list is now done in __dcgettext. + + * dcgettext.c (__dcgettext): + Now we provide message fall back even to different languages. + I.e. if a message is not available in one language all the other + in the locale list a tried. Formerly fall back was only possible + within one language. Implemented by moving one loop from + _nl_find_domain to here. + +Mon Aug 14 23:45:50 1995 Ulrich Drepper + + * Makefile.in (gettextsrcdir): + Directory where source of GNU gettext library are made + available. + (INSTALL, INSTALL_DATA): Programs used for installing sources. + (gettext-src): New. Rule to install GNU gettext sources for use in + gettextize shell script. + +Sun Aug 13 14:40:48 1995 Ulrich Drepper + + * loadmsgcat.c (_nl_load_domain): + Use mmap for loading only when munmap function is + also available. + + * Makefile.in (install): Depend on `all' goal. + +Wed Aug 9 11:04:33 1995 Ulrich Drepper + + * localealias.c (read_alias_file): + Do not overwrite '\n' when terminating alias value string. + + * localealias.c (read_alias_file): + Handle long lines. Ignore the rest not fitting in + the buffer after the initial `fgets' call. + +Wed Aug 9 00:54:29 1995 Ulrich Drepper + + * gettextP.h (_nl_load_domain): + Add prototype, replacing prototype for _nl_load_msg_cat. + + * finddomain.c (_nl_find_domain): + Remove unneeded variable filename and filename_len. + (expand_alias): Remove prototype because functions does not + exist anymore. + + * localealias.c (read_alias_file): + Change type of fname_len parameter to int. + (xmalloc): Add prototype. + + * loadmsgcat.c: Better prototypes for xmalloc. + +Tue Aug 8 22:30:39 1995 Ulrich Drepper + + * finddomain.c (_nl_find_domain): + Allow alias name to be constructed from the four components. + + * Makefile.in (aliaspath): New variable. Set to preliminary value. + (SOURCES): Add localealias.c. + (OBJECTS): Add localealias.o. + + * gettextP.h: Add prototype for _nl_expand_alias. + + * finddomain.c: Aliasing handled in intl/localealias.c. + + * localealias.c: Aliasing for locale names. + + * bindtextdom.c: Better prototypes for xmalloc and xstrdup. + +Mon Aug 7 23:47:42 1995 Ulrich Drepper + + * Makefile.in (DISTFILES): gettext.perl is now found in misc/. + + * cat-compat.c (bindtextdomain): + Correct implementation. dirname parameter was not used. + Reported by Marcus Daniels. + + * gettextP.h (loaded_domain): + New fields `successor' and `decided' for oo, lazy + message handling implementation. + + * dcgettext.c: + Adopt for oo, lazy message handliing. + Now we can inherit translations from less specific locales. + (find_msg): New function. + + * loadmsgcat.c, finddomain.c: + Complete rewrite. Implement oo, lazy message handling :-). + We now have an additional environment variable `LANGUAGE' with + a higher priority than LC_ALL for the LC_MESSAGE locale. + Here we can set a colon separated list of specifications each + of the form `language[_territory[.codeset]][@modifier]'. + +Sat Aug 5 09:55:42 1995 Ulrich Drepper + + * finddomain.c (unistd.h): + Include to get _PC_PATH_MAX defined on system having it. + +Fri Aug 4 22:42:00 1995 Ulrich Drepper + + * finddomain.c (stpcpy): Include prototype. + + * Makefile.in (dist): Remove `copying instead' message. + +Wed Aug 2 18:52:03 1995 Ulrich Drepper + + * Makefile.in (ID, TAGS): Do not use $^. + +Tue Aug 1 20:07:11 1995 Ulrich Drepper + + * Makefile.in (TAGS, ID): Use $^ as command argument. + (TAGS): Give etags -o option t write to current directory, + not $(srcdir). + (ID): Use $(srcdir) instead os $(top_srcdir)/src. + (distclean): Remove ID. + +Sun Jul 30 11:51:46 1995 Ulrich Drepper + + * Makefile.in (gnulocaledir): + New variable, always using share/ for data directory. + (DEFS): Add GNULOCALEDIR, used in finddomain.c. + + * finddomain.c (_nl_default_dirname): + Set to GNULOCALEDIR, because it always has to point + to the directory where GNU gettext Library writes it to. + + * intl-compat.c (textdomain, bindtextdomain): + Undefine macros before function definition. + +Sat Jul 22 01:10:02 1995 Ulrich Drepper + + * libgettext.h (_LIBINTL_H): + Protect definition in case where this file is included as + libgettext.h on Solaris machines. Add comment about this. + +Wed Jul 19 02:36:42 1995 Ulrich Drepper + + * intl-compat.c (textdomain): Correct typo. + +Wed Jul 19 01:51:35 1995 Ulrich Drepper + + * dcgettext.c (dcgettext): Function now called __dcgettext. + + * dgettext.c (dgettext): Now called __dgettext and calls + __dcgettext. + + * gettext.c (gettext): + Function now called __gettext and calls __dgettext. + + * textdomain.c (textdomain): Function now called __textdomain. + + * bindtextdom.c (bindtextdomain): Function now called + __bindtextdomain. + + * intl-compat.c: Initial revision. + + * Makefile.in (SOURCES): Add intl-compat.c. + (OBJECTS): We always compile the GNU gettext library functions. + OBJECTS contains all objects but cat-compat.o, ../po/cat-if-tbl.o, + and intl-compat.o. + (GETTOBJS): Contains now only intl-compat.o. + + * libgettext.h: + Re-include protection matches dualistic character of libgettext.h. + For all functions in GNU gettext library define __ counter part. + + * finddomain.c (strchr): Define as index if not found in C library. + (_nl_find_domain): For relative paths paste / in between. + +Tue Jul 18 16:37:45 1995 Ulrich Drepper + + * loadmsgcat.c, finddomain.c: Add inclusion of sys/types.h. + + * xopen-msg.sed: Fix bug with `msgstr ""' lines. + A little bit better comments. + +Tue Jul 18 01:18:27 1995 Ulrich Drepper + + * Makefile.in: + po-mode.el, makelinks, combine-sh are now found in ../misc. + + * po-mode.el, makelinks, combine-sh, elisp-comp: + Moved to ../misc/. + + * libgettext.h, gettextP.h, gettext.h: Uniform test for __STDC__. + +Sun Jul 16 22:33:02 1995 Ulrich Drepper + + * Makefile.in (INSTALL, INSTALL_DATA): New variables. + (install-data, uninstall): Install/uninstall .elc file. + + * po-mode.el (Installation comment): + Add .pox as possible extension of .po files. + +Sun Jul 16 13:23:27 1995 Ulrich Drepper + + * elisp-comp: Complete new version by Franc,ois: This does not + fail when not compiling in the source directory. + +Sun Jul 16 00:12:17 1995 Ulrich Drepper + + * Makefile.in (../po/cat-id-tbl.o): + Use $(MAKE) instead of make for recursive make. + + * Makefile.in (.el.elc): Use $(SHELL) instead of /bin/sh. + (install-exec): Add missing dummy goal. + (install-data, uninstall): @ in multi-line shell command at + beginning, not in front of echo. Reported by Eric Backus. + +Sat Jul 15 00:21:28 1995 Ulrich Drepper + + * Makefile.in (DISTFILES): + Rename libgettext.perl to gettext.perl to fit in 14 chars + file systems. + + * gettext.perl: + Rename to gettext.perl to fit in 14 chars file systems. + +Thu Jul 13 23:17:20 1995 Ulrich Drepper + + * cat-compat.c: If !STDC_HEADERS try to include malloc.h. + +Thu Jul 13 20:55:02 1995 Ulrich Drepper + + * po2tbl.sed.in: Pretty printing. + + * linux-msg.sed, xopen-msg.sed: + Correct bugs with handling substitute flags in branches. + + * hash-string.h (hash_string): + Old K&R compilers don't under stand `unsigned char'. + + * gettext.h (nls_uint32): + Some old K&R compilers (eg HP) don't understand `unsigned int'. + + * cat-compat.c (msg_to_cat_id): De-ANSI-fy prototypes. + +Thu Jul 13 01:34:33 1995 Ulrich Drepper + + * Makefile.in (ELCFILES): New variable. + (DISTFILES): Add elisp-comp. + Add implicit rule for .el -> .elc compilation. + (install-data): install $ELCFILES + (clean): renamed po-to-tbl and po-to-msg to po2tbl and po2msg resp. + + * elisp-comp: Initial revision + +Wed Jul 12 16:14:52 1995 Ulrich Drepper + + * Makefile.in: + cat-id-tbl.c is now found in po/. This enables us to use an identical + intl/ directory in all packages. + + * dcgettext.c (dcgettext): hashing does not work for table size <= 2. + + * textdomain.c: fix typo (#if def -> #if defined) + +Tue Jul 11 18:44:43 1995 Ulrich Drepper + + * Makefile.in (stamp-cat-id): use top_srcdir to address source files + (DISTFILES,distclean): move tupdate.perl to src/ + + * po-to-tbl.sed.in: + add additional jump to clear change flag to recognize multiline strings + +Tue Jul 11 01:32:50 1995 Ulrich Drepper + + * textdomain.c: Protect inclusion of stdlib.h and string.h. + + * loadmsgcat.c: Protect inclusion of stdlib.h. + + * libgettext.h: Protect inclusion of locale.h. + Allow use in C++ programs. + Define NULL is not happened already. + + * Makefile.in (DISTFILES): ship po-to-tbl.sed.in instead of + po-to-tbl.sed. + (distclean): remove po-to-tbl.sed and tupdate.perl. + + * tupdate.perl.in: Substitute Perl path even in exec line. + Don't include entries without translation from old .po file. + +Tue Jul 4 00:41:51 1995 Ulrich Drepper + + * tupdate.perl.in: use "Updated: " in msgid "". + + * cat-compat.c: Fix typo (LOCALDIR -> LOCALEDIR). + Define getenv if !__STDC__. + + * bindtextdom.c: Protect stdlib.h and string.h inclusion. + Define free if !__STDC__. + + * finddomain.c: Change DEF_MSG_DOM_DIR to LOCALEDIR. + Define free if !__STDC__. + + * cat-compat.c: Change DEF_MSG_DOM_DIR to LOCALEDIR. + +Mon Jul 3 23:56:30 1995 Ulrich Drepper + + * Makefile.in: Use LOCALEDIR instead of DEF_MSG_DOM_DIR. + Remove unneeded $(srcdir) from Makefile.in dependency. + + * makelinks: Add copyright and short description. + + * po-mode.el: Last version for 0.7. + + * tupdate.perl.in: Fix die message. + + * dcgettext.c: Protect include of string.h. + + * gettext.c: Protect include of stdlib.h and further tries to get NULL. + + * finddomain.c: Some corrections in includes. + + * Makefile.in (INCLUDES): Prune list correct path to Makefile.in. + + * po-to-tbl.sed: Adopt for new .po file format. + + * linux-msg.sed, xopen-msg.sed: Adopt for new .po file format. + +Sun Jul 2 23:55:03 1995 Ulrich Drepper + + * tupdate.perl.in: Complete rewrite for new .po file format. + +Sun Jul 2 02:06:50 1995 Ulrich Drepper + + * First official release. This directory contains all the code + needed to internationalize own packages. It provides functions + which allow to use the X/Open catgets function with an interface + like the Uniforum gettext function. For system which does not + have neither of those a complete implementation is provided. diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/Makefile b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/Makefile new file mode 100644 index 0000000000..ecaf364def --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/Makefile @@ -0,0 +1,214 @@ +# Makefile for directory with message catalog handling in GNU NLS Utilities. +# Copyright (C) 1995, 1996, 1997 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +PACKAGE = gsmlib +VERSION = 1.10 + +SHELL = /bin/sh + +srcdir = . +top_srcdir = .. +top_builddir = .. + + +prefix = /usr +exec_prefix = ${prefix} +transform = s,x,x, +libdir = $(exec_prefix)/lib +includedir = $(prefix)/include +datadir = $(prefix)/share +localedir = $(datadir)/locale +gnulocaledir = $(prefix)/share/locale +gettextsrcdir = ${prefix}/share/gettext/intl +aliaspath = $(localedir):. +subdir = intl + +INSTALL = /usr/bin/install -c +INSTALL_DATA = ${INSTALL} -m 644 +MKINSTALLDIRS = $(top_builddir)/scripts/mkinstalldirs + +l = @l@ + +AR = ar +CC = i486-linux-gnu-gcc +LIBTOOL = $(SHELL) $(top_builddir)/libtool +RANLIB = ranlib + +DEFS = -DGNULOCALEDIR=\"$(gnulocaledir)\" \ +-DLOCALE_ALIAS_PATH=\"$(aliaspath)\" -DHAVE_CONFIG_H +CPPFLAGS = +CFLAGS = -D_REENTRANT +LDFLAGS = + +COMPILE = $(CC) -c $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS) + +HEADERS = $(COMHDRS) libgettext.h loadinfo.h +COMHDRS = gettext.h gettextP.h hash-string.h +SOURCES = $(COMSRCS) intl-compat.c cat-compat.c +COMSRCS = bindtextdom.c dcgettext.c dgettext.c gettext.c \ +finddomain.c loadmsgcat.c localealias.c textdomain.c l10nflist.c \ +explodename.c +OBJECTS = bindtextdom.$lo dcgettext.$lo dgettext.$lo gettext.$lo \ +finddomain.$lo loadmsgcat.$lo localealias.$lo textdomain.$lo l10nflist.$lo \ +explodename.$lo +CATOBJS = cat-compat.$lo ../po/cat-id-tbl.$lo +GETTOBJS = intl-compat.$lo +DISTFILES.common = ChangeLog Makefile.in linux-msg.sed po2tbl.sed.in \ +xopen-msg.sed $(HEADERS) $(SOURCES) +DISTFILES.normal = VERSION +DISTFILES.gettext = libintl.glibc intlh.inst.in + +.SUFFIXES: +.SUFFIXES: .c .o .lo +.c.o: + $(COMPILE) $< +.c.lo: + $(LIBTOOL) --mode=compile $(COMPILE) $< + +INCLUDES = -I.. -I. -I$(top_srcdir)/intl -I$(top_srcdir)/lib + +all: all-no + +all-yes: libintl.$la intlh.inst +all-no: + +libintl.a: $(OBJECTS) + rm -f $@ + $(AR) cru $@ $(OBJECTS) + $(RANLIB) $@ + +libintl.la: $(OBJECTS) + $(LIBTOOL) --mode=link $(CC) $(LDFLAGS) -o $@ $(OBJECTS) \ + -version-info 1:0 -rpath $(libdir) + +../po/cat-id-tbl.$lo: ../po/cat-id-tbl.c $(top_srcdir)/po/$(PACKAGE).pot + cd ../po && $(MAKE) cat-id-tbl.$lo + +check: all + +# This installation goal is only used in GNU gettext. Packages which +# only use the library should use install instead. + +# We must not install the libintl.h/libintl.a files if we are on a +# system which has the gettext() function in its C library or in a +# separate library or use the catgets interface. A special case is +# where configure found a previously installed GNU gettext library. +# If you want to use the one which comes with this version of the +# package, you have to use `configure --with-included-gettext'. +install: install-exec install-data +install-exec: all + if test "$(PACKAGE)" = "gettext" \ + && test '' = '$(GETTOBJS)'; then \ + if test -r $(MKINSTALLDIRS); then \ + $(MKINSTALLDIRS) $(libdir) $(includedir); \ + else \ + $(top_srcdir)/mkinstalldirs $(libdir) $(includedir); \ + fi; \ + $(INSTALL_DATA) intlh.inst $(includedir)/libintl.h; \ + $(INSTALL_DATA) libintl.a $(libdir)/libintl.a; \ + else \ + : ; \ + fi +install-data: all + if test "$(PACKAGE)" = "gettext"; then \ + if test -r $(MKINSTALLDIRS); then \ + $(MKINSTALLDIRS) $(gettextsrcdir); \ + else \ + $(top_srcdir)/mkinstalldirs $(gettextsrcdir); \ + fi; \ + $(INSTALL_DATA) VERSION $(gettextsrcdir)/VERSION; \ + dists="$(DISTFILES.common)"; \ + for file in $$dists; do \ + $(INSTALL_DATA) $(srcdir)/$$file $(gettextsrcdir)/$$file; \ + done; \ + else \ + : ; \ + fi + +# Define this as empty until I found a useful application. +installcheck: + +uninstall: + dists="$(DISTFILES.common)"; \ + for file in $$dists; do \ + rm -f $(gettextsrcdir)/$$file; \ + done + +info dvi: + +$(OBJECTS): ../gsm_config.h libgettext.h +bindtextdom.$lo finddomain.$lo loadmsgcat.$lo: gettextP.h gettext.h loadinfo.h +dcgettext.$lo: gettextP.h gettext.h hash-string.h loadinfo.h + +tags: TAGS + +TAGS: $(HEADERS) $(SOURCES) + here=`pwd`; cd $(srcdir) && etags -o $$here/TAGS $(HEADERS) $(SOURCES) + +id: ID + +ID: $(HEADERS) $(SOURCES) + here=`pwd`; cd $(srcdir) && mkid -f$$here/ID $(HEADERS) $(SOURCES) + + +mostlyclean: + rm -f *.a *.o *.lo core core.* + +clean: mostlyclean + +distclean: clean + rm -f Makefile ID TAGS po2msg.sed po2tbl.sed + +maintainer-clean: distclean + @echo "This command is intended for maintainers to use;" + @echo "it deletes files that may require special tools to rebuild." + + +# GNU gettext needs not contain the file `VERSION' but contains some +# other files which should not be distributed in other packages. +distdir = ../$(PACKAGE)-$(VERSION)/$(subdir) +dist distdir: Makefile $(DISTFILES) + if test "$(PACKAGE)" = gettext; then \ + additional="$(DISTFILES.gettext)"; \ + else \ + additional="$(DISTFILES.normal)"; \ + fi; \ + for file in $(DISTFILES.common) $$additional; do \ + ln $(srcdir)/$$file $(distdir) 2> /dev/null \ + || cp -p $(srcdir)/$$file $(distdir); \ + done + +dist-libc: + tar zcvf intl-glibc.tar.gz $(COMSRCS) $(COMHDRS) libintl.h.glibc + +Makefile: Makefile.in ../config.status + cd .. \ + && CONFIG_FILES=$(subdir)/$@ CONFIG_HEADERS= $(SHELL) ./config.status + +# The dependency for intlh.inst is different in gettext and all other +# packages. Because we cannot you GNU make features we have to solve +# the problem while rewriting Makefile.in. +@GT_YES@intlh.inst: intlh.inst.in ../config.status +@GT_YES@ cd .. \ +@GT_YES@ && CONFIG_FILES=$(subdir)/$@ CONFIG_HEADERS= \ +@GT_YES@ $(SHELL) ./config.status +@GT_NO@.PHONY: intlh.inst +@GT_NO@intlh.inst: + +# Tell versions [3.59,3.63) of GNU make not to export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/Makefile.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/Makefile.in new file mode 100644 index 0000000000..fc1e9e3ff1 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/Makefile.in @@ -0,0 +1,214 @@ +# Makefile for directory with message catalog handling in GNU NLS Utilities. +# Copyright (C) 1995, 1996, 1997 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +PACKAGE = @PACKAGE@ +VERSION = @VERSION@ + +SHELL = /bin/sh + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +top_builddir = .. +VPATH = @srcdir@ + +prefix = @prefix@ +exec_prefix = @exec_prefix@ +transform = @program_transform_name@ +libdir = $(exec_prefix)/lib +includedir = $(prefix)/include +datadir = $(prefix)/@DATADIRNAME@ +localedir = $(datadir)/locale +gnulocaledir = $(prefix)/share/locale +gettextsrcdir = @datadir@/gettext/intl +aliaspath = $(localedir):. +subdir = intl + +INSTALL = @INSTALL@ +INSTALL_DATA = @INSTALL_DATA@ +MKINSTALLDIRS = @MKINSTALLDIRS@ + +l = @l@ + +AR = ar +CC = @CC@ +LIBTOOL = @LIBTOOL@ +RANLIB = @RANLIB@ + +DEFS = -DGNULOCALEDIR=\"$(gnulocaledir)\" \ +-DLOCALE_ALIAS_PATH=\"$(aliaspath)\" @DEFS@ +CPPFLAGS = @CPPFLAGS@ +CFLAGS = @CFLAGS@ +LDFLAGS = @LDFLAGS@ + +COMPILE = $(CC) -c $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS) + +HEADERS = $(COMHDRS) libgettext.h loadinfo.h +COMHDRS = gettext.h gettextP.h hash-string.h +SOURCES = $(COMSRCS) intl-compat.c cat-compat.c +COMSRCS = bindtextdom.c dcgettext.c dgettext.c gettext.c \ +finddomain.c loadmsgcat.c localealias.c textdomain.c l10nflist.c \ +explodename.c +OBJECTS = @INTLOBJS@ bindtextdom.$lo dcgettext.$lo dgettext.$lo gettext.$lo \ +finddomain.$lo loadmsgcat.$lo localealias.$lo textdomain.$lo l10nflist.$lo \ +explodename.$lo +CATOBJS = cat-compat.$lo ../po/cat-id-tbl.$lo +GETTOBJS = intl-compat.$lo +DISTFILES.common = ChangeLog Makefile.in linux-msg.sed po2tbl.sed.in \ +xopen-msg.sed $(HEADERS) $(SOURCES) +DISTFILES.normal = VERSION +DISTFILES.gettext = libintl.glibc intlh.inst.in + +.SUFFIXES: +.SUFFIXES: .c .o .lo +.c.o: + $(COMPILE) $< +.c.lo: + $(LIBTOOL) --mode=compile $(COMPILE) $< + +INCLUDES = -I.. -I. -I$(top_srcdir)/intl -I$(top_srcdir)/lib + +all: all-@USE_INCLUDED_LIBINTL@ + +all-yes: libintl.$la intlh.inst +all-no: + +libintl.a: $(OBJECTS) + rm -f $@ + $(AR) cru $@ $(OBJECTS) + $(RANLIB) $@ + +libintl.la: $(OBJECTS) + $(LIBTOOL) --mode=link $(CC) $(LDFLAGS) -o $@ $(OBJECTS) \ + -version-info 1:0 -rpath $(libdir) + +../po/cat-id-tbl.$lo: ../po/cat-id-tbl.c $(top_srcdir)/po/$(PACKAGE).pot + cd ../po && $(MAKE) cat-id-tbl.$lo + +check: all + +# This installation goal is only used in GNU gettext. Packages which +# only use the library should use install instead. + +# We must not install the libintl.h/libintl.a files if we are on a +# system which has the gettext() function in its C library or in a +# separate library or use the catgets interface. A special case is +# where configure found a previously installed GNU gettext library. +# If you want to use the one which comes with this version of the +# package, you have to use `configure --with-included-gettext'. +install: install-exec install-data +install-exec: all + if test "$(PACKAGE)" = "gettext" \ + && test '@INTLOBJS@' = '$(GETTOBJS)'; then \ + if test -r $(MKINSTALLDIRS); then \ + $(MKINSTALLDIRS) $(libdir) $(includedir); \ + else \ + $(top_srcdir)/mkinstalldirs $(libdir) $(includedir); \ + fi; \ + $(INSTALL_DATA) intlh.inst $(includedir)/libintl.h; \ + $(INSTALL_DATA) libintl.a $(libdir)/libintl.a; \ + else \ + : ; \ + fi +install-data: all + if test "$(PACKAGE)" = "gettext"; then \ + if test -r $(MKINSTALLDIRS); then \ + $(MKINSTALLDIRS) $(gettextsrcdir); \ + else \ + $(top_srcdir)/mkinstalldirs $(gettextsrcdir); \ + fi; \ + $(INSTALL_DATA) VERSION $(gettextsrcdir)/VERSION; \ + dists="$(DISTFILES.common)"; \ + for file in $$dists; do \ + $(INSTALL_DATA) $(srcdir)/$$file $(gettextsrcdir)/$$file; \ + done; \ + else \ + : ; \ + fi + +# Define this as empty until I found a useful application. +installcheck: + +uninstall: + dists="$(DISTFILES.common)"; \ + for file in $$dists; do \ + rm -f $(gettextsrcdir)/$$file; \ + done + +info dvi: + +$(OBJECTS): ../gsm_config.h libgettext.h +bindtextdom.$lo finddomain.$lo loadmsgcat.$lo: gettextP.h gettext.h loadinfo.h +dcgettext.$lo: gettextP.h gettext.h hash-string.h loadinfo.h + +tags: TAGS + +TAGS: $(HEADERS) $(SOURCES) + here=`pwd`; cd $(srcdir) && etags -o $$here/TAGS $(HEADERS) $(SOURCES) + +id: ID + +ID: $(HEADERS) $(SOURCES) + here=`pwd`; cd $(srcdir) && mkid -f$$here/ID $(HEADERS) $(SOURCES) + + +mostlyclean: + rm -f *.a *.o *.lo core core.* + +clean: mostlyclean + +distclean: clean + rm -f Makefile ID TAGS po2msg.sed po2tbl.sed + +maintainer-clean: distclean + @echo "This command is intended for maintainers to use;" + @echo "it deletes files that may require special tools to rebuild." + + +# GNU gettext needs not contain the file `VERSION' but contains some +# other files which should not be distributed in other packages. +distdir = ../$(PACKAGE)-$(VERSION)/$(subdir) +dist distdir: Makefile $(DISTFILES) + if test "$(PACKAGE)" = gettext; then \ + additional="$(DISTFILES.gettext)"; \ + else \ + additional="$(DISTFILES.normal)"; \ + fi; \ + for file in $(DISTFILES.common) $$additional; do \ + ln $(srcdir)/$$file $(distdir) 2> /dev/null \ + || cp -p $(srcdir)/$$file $(distdir); \ + done + +dist-libc: + tar zcvf intl-glibc.tar.gz $(COMSRCS) $(COMHDRS) libintl.h.glibc + +Makefile: Makefile.in ../config.status + cd .. \ + && CONFIG_FILES=$(subdir)/$@ CONFIG_HEADERS= $(SHELL) ./config.status + +# The dependency for intlh.inst is different in gettext and all other +# packages. Because we cannot you GNU make features we have to solve +# the problem while rewriting Makefile.in. +@GT_YES@intlh.inst: intlh.inst.in ../config.status +@GT_YES@ cd .. \ +@GT_YES@ && CONFIG_FILES=$(subdir)/$@ CONFIG_HEADERS= \ +@GT_YES@ $(SHELL) ./config.status +@GT_NO@.PHONY: intlh.inst +@GT_NO@intlh.inst: + +# Tell versions [3.59,3.63) of GNU make not to export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/VERSION b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/VERSION new file mode 100644 index 0000000000..ee66b0612b --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/VERSION @@ -0,0 +1 @@ +GNU gettext library from gettext-0.10.35 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/bindtextdom.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/bindtextdom.c new file mode 100644 index 0000000000..42b11aaddb --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/bindtextdom.c @@ -0,0 +1,203 @@ +/* Implementation of the bindtextdomain(3) function + Copyright (C) 1995, 1996, 1997, 1998 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + +#if defined STDC_HEADERS || defined _LIBC +# include +#else +# ifdef HAVE_MALLOC_H +# include +# else +void free (); +# endif +#endif + +#if defined HAVE_STRING_H || defined _LIBC +# include +#else +# include +# ifndef memcpy +# define memcpy(Dst, Src, Num) bcopy (Src, Dst, Num) +# endif +#endif + +#ifdef _LIBC +# include +#else +# include "libgettext.h" +#endif +#include "gettext.h" +#include "gettextP.h" + +/* @@ end of prolog @@ */ + +/* Contains the default location of the message catalogs. */ +extern const char _nl_default_dirname[]; + +/* List with bindings of specific domains. */ +extern struct binding *_nl_domain_bindings; + + +/* Names for the libintl functions are a problem. They must not clash + with existing names and they should follow ANSI C. But this source + code is also used in GNU C Library where the names have a __ + prefix. So we have to make a difference here. */ +#ifdef _LIBC +# define BINDTEXTDOMAIN __bindtextdomain +# ifndef strdup +# define strdup(str) __strdup (str) +# endif +#else +# define BINDTEXTDOMAIN bindtextdomain__ +#endif + +/* Specify that the DOMAINNAME message catalog will be found + in DIRNAME rather than in the system locale data base. */ +char * +BINDTEXTDOMAIN (domainname, dirname) + const char *domainname; + const char *dirname; +{ + struct binding *binding; + + /* Some sanity checks. */ + if (domainname == NULL || domainname[0] == '\0') + return NULL; + + for (binding = _nl_domain_bindings; binding != NULL; binding = binding->next) + { + int compare = strcmp (domainname, binding->domainname); + if (compare == 0) + /* We found it! */ + break; + if (compare < 0) + { + /* It is not in the list. */ + binding = NULL; + break; + } + } + + if (dirname == NULL) + /* The current binding has be to returned. */ + return binding == NULL ? (char *) _nl_default_dirname : binding->dirname; + + if (binding != NULL) + { + /* The domain is already bound. If the new value and the old + one are equal we simply do nothing. Otherwise replace the + old binding. */ + if (strcmp (dirname, binding->dirname) != 0) + { + char *new_dirname; + + if (strcmp (dirname, _nl_default_dirname) == 0) + new_dirname = (char *) _nl_default_dirname; + else + { +#if defined _LIBC || defined HAVE_STRDUP + new_dirname = strdup (dirname); + if (new_dirname == NULL) + return NULL; +#else + size_t len = strlen (dirname) + 1; + new_dirname = (char *) malloc (len); + if (new_dirname == NULL) + return NULL; + + memcpy (new_dirname, dirname, len); +#endif + } + + if (binding->dirname != _nl_default_dirname) + free (binding->dirname); + + binding->dirname = new_dirname; + } + } + else + { + /* We have to create a new binding. */ +#if !defined _LIBC && !defined HAVE_STRDUP + size_t len; +#endif + struct binding *new_binding = + (struct binding *) malloc (sizeof (*new_binding)); + + if (new_binding == NULL) + return NULL; + +#if defined _LIBC || defined HAVE_STRDUP + new_binding->domainname = strdup (domainname); + if (new_binding->domainname == NULL) + return NULL; +#else + len = strlen (domainname) + 1; + new_binding->domainname = (char *) malloc (len); + if (new_binding->domainname == NULL) + return NULL; + memcpy (new_binding->domainname, domainname, len); +#endif + + if (strcmp (dirname, _nl_default_dirname) == 0) + new_binding->dirname = (char *) _nl_default_dirname; + else + { +#if defined _LIBC || defined HAVE_STRDUP + new_binding->dirname = strdup (dirname); + if (new_binding->dirname == NULL) + return NULL; +#else + len = strlen (dirname) + 1; + new_binding->dirname = (char *) malloc (len); + if (new_binding->dirname == NULL) + return NULL; + memcpy (new_binding->dirname, dirname, len); +#endif + } + + /* Now enqueue it. */ + if (_nl_domain_bindings == NULL + || strcmp (domainname, _nl_domain_bindings->domainname) < 0) + { + new_binding->next = _nl_domain_bindings; + _nl_domain_bindings = new_binding; + } + else + { + binding = _nl_domain_bindings; + while (binding->next != NULL + && strcmp (domainname, binding->next->domainname) > 0) + binding = binding->next; + + new_binding->next = binding->next; + binding->next = new_binding; + } + + binding = new_binding; + } + + return binding->dirname; +} + +#ifdef _LIBC +/* Alias for function name in GNU C Library. */ +weak_alias (__bindtextdomain, bindtextdomain); +#endif diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/cat-compat.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/cat-compat.c new file mode 100644 index 0000000000..4eb0e068f1 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/cat-compat.c @@ -0,0 +1,262 @@ +/* Compatibility code for gettext-using-catgets interface. + Copyright (C) 1995, 1997 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + +#include + +#ifdef STDC_HEADERS +# include +# include +#else +char *getenv (); +# ifdef HAVE_MALLOC_H +# include +# endif +#endif + +#ifdef HAVE_NL_TYPES_H +# include +#endif + +#include "libgettext.h" + +/* @@ end of prolog @@ */ + +/* XPG3 defines the result of `setlocale (category, NULL)' as: + ``Directs `setlocale()' to query `category' and return the current + setting of `local'.'' + However it does not specify the exact format. And even worse: POSIX + defines this not at all. So we can use this feature only on selected + system (e.g. those using GNU C Library). */ +#ifdef _LIBC +# define HAVE_LOCALE_NULL +#endif + +/* The catalog descriptor. */ +static nl_catd catalog = (nl_catd) -1; + +/* Name of the default catalog. */ +static const char default_catalog_name[] = "messages"; + +/* Name of currently used catalog. */ +static const char *catalog_name = default_catalog_name; + +/* Get ID for given string. If not found return -1. */ +static int msg_to_cat_id PARAMS ((const char *msg)); + +/* Substitution for systems lacking this function in their C library. */ +#if !_LIBC && !HAVE_STPCPY +static char *stpcpy PARAMS ((char *dest, const char *src)); +#endif + + +/* Set currently used domain/catalog. */ +char * +textdomain (domainname) + const char *domainname; +{ + nl_catd new_catalog; + char *new_name; + size_t new_name_len; + char *lang; + +#if defined HAVE_SETLOCALE && defined HAVE_LC_MESSAGES \ + && defined HAVE_LOCALE_NULL + lang = setlocale (LC_MESSAGES, NULL); +#else + lang = getenv ("LC_ALL"); + if (lang == NULL || lang[0] == '\0') + { + lang = getenv ("LC_MESSAGES"); + if (lang == NULL || lang[0] == '\0') + lang = getenv ("LANG"); + } +#endif + if (lang == NULL || lang[0] == '\0') + lang = "C"; + + /* See whether name of currently used domain is asked. */ + if (domainname == NULL) + return (char *) catalog_name; + + if (domainname[0] == '\0') + domainname = default_catalog_name; + + /* Compute length of added path element. */ + new_name_len = sizeof (LOCALEDIR) - 1 + 1 + strlen (lang) + + sizeof ("/LC_MESSAGES/") - 1 + sizeof (PACKAGE) - 1 + + sizeof (".cat"); + + new_name = (char *) malloc (new_name_len); + if (new_name == NULL) + return NULL; + + strcpy (new_name, PACKAGE); + new_catalog = catopen (new_name, 0); + + if (new_catalog == (nl_catd) -1) + { + /* NLSPATH search didn't work, try absolute path */ + sprintf (new_name, "%s/%s/LC_MESSAGES/%s.cat", LOCALEDIR, lang, + PACKAGE); + new_catalog = catopen (new_name, 0); + + if (new_catalog == (nl_catd) -1) + { + free (new_name); + return (char *) catalog_name; + } + } + + /* Close old catalog. */ + if (catalog != (nl_catd) -1) + catclose (catalog); + if (catalog_name != default_catalog_name) + free ((char *) catalog_name); + + catalog = new_catalog; + catalog_name = new_name; + + return (char *) catalog_name; +} + +char * +bindtextdomain (domainname, dirname) + const char *domainname; + const char *dirname; +{ +#if HAVE_SETENV || HAVE_PUTENV + char *old_val, *new_val, *cp; + size_t new_val_len; + + /* This does not make much sense here but to be compatible do it. */ + if (domainname == NULL) + return NULL; + + /* Compute length of added path element. If we use setenv we don't need + the first byts for NLSPATH=, but why complicate the code for this + peanuts. */ + new_val_len = sizeof ("NLSPATH=") - 1 + strlen (dirname) + + sizeof ("/%L/LC_MESSAGES/%N.cat"); + + old_val = getenv ("NLSPATH"); + if (old_val == NULL || old_val[0] == '\0') + { + old_val = NULL; + new_val_len += 1 + sizeof (LOCALEDIR) - 1 + + sizeof ("/%L/LC_MESSAGES/%N.cat"); + } + else + new_val_len += strlen (old_val); + + new_val = (char *) malloc (new_val_len); + if (new_val == NULL) + return NULL; + +# if HAVE_SETENV + cp = new_val; +# else + cp = stpcpy (new_val, "NLSPATH="); +# endif + + cp = stpcpy (cp, dirname); + cp = stpcpy (cp, "/%L/LC_MESSAGES/%N.cat:"); + + if (old_val == NULL) + { +# if __STDC__ + stpcpy (cp, LOCALEDIR "/%L/LC_MESSAGES/%N.cat"); +# else + + cp = stpcpy (cp, LOCALEDIR); + stpcpy (cp, "/%L/LC_MESSAGES/%N.cat"); +# endif + } + else + stpcpy (cp, old_val); + +# if HAVE_SETENV + setenv ("NLSPATH", new_val, 1); + free (new_val); +# else + putenv (new_val); + /* Do *not* free the environment entry we just entered. It is used + from now on. */ +# endif + +#endif + + return (char *) domainname; +} + +#undef gettext +char * +gettext (msg) + const char *msg; +{ + int msgid; + + if (msg == NULL || catalog == (nl_catd) -1) + return (char *) msg; + + /* Get the message from the catalog. We always use set number 1. + The message ID is computed by the function `msg_to_cat_id' + which works on the table generated by `po-to-tbl'. */ + msgid = msg_to_cat_id (msg); + if (msgid == -1) + return (char *) msg; + + return catgets (catalog, 1, msgid, (char *) msg); +} + +/* Look through the table `_msg_tbl' which has `_msg_tbl_length' entries + for the one equal to msg. If it is found return the ID. In case when + the string is not found return -1. */ +static int +msg_to_cat_id (msg) + const char *msg; +{ + int cnt; + + for (cnt = 0; cnt < _msg_tbl_length; ++cnt) + if (strcmp (msg, _msg_tbl[cnt]._msg) == 0) + return _msg_tbl[cnt]._msg_number; + + return -1; +} + + +/* @@ begin of epilog @@ */ + +/* We don't want libintl.a to depend on any other library. So we + avoid the non-standard function stpcpy. In GNU C Library this + function is available, though. Also allow the symbol HAVE_STPCPY + to be defined. */ +#if !_LIBC && !HAVE_STPCPY +static char * +stpcpy (dest, src) + char *dest; + const char *src; +{ + while ((*dest++ = *src++) != '\0') + /* Do nothing. */ ; + return dest - 1; +} +#endif diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/dcgettext.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/dcgettext.c new file mode 100644 index 0000000000..ed697f371b --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/dcgettext.c @@ -0,0 +1,624 @@ +/* Implementation of the dcgettext(3) function. + Copyright (C) 1995, 1996, 1997, 1998 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + +#include + +#ifdef __GNUC__ +# define alloca __builtin_alloca +# define HAVE_ALLOCA 1 +#else +# if defined HAVE_ALLOCA_H || defined _LIBC +# include +# else +# ifdef _AIX + #pragma alloca +# else +# ifndef alloca +char *alloca (); +# endif +# endif +# endif +#endif + +#include +#ifndef errno +extern int errno; +#endif +#ifndef __set_errno +# define __set_errno(val) errno = (val) +#endif + +#if defined STDC_HEADERS || defined _LIBC +# include +#else +char *getenv (); +# ifdef HAVE_MALLOC_H +# include +# else +void free (); +# endif +#endif + +#if defined HAVE_STRING_H || defined _LIBC +# ifndef _GNU_SOURCE +# define _GNU_SOURCE 1 +# endif +# include +#else +# include +#endif +#if !HAVE_STRCHR && !defined _LIBC +# ifndef strchr +# define strchr index +# endif +#endif + +#if defined HAVE_UNISTD_H || defined _LIBC +# include +#endif + +#include "gettext.h" +#include "gettextP.h" +#ifdef _LIBC +# include +#else +# include "libgettext.h" +#endif +#include "hash-string.h" + +/* @@ end of prolog @@ */ + +#ifdef _LIBC +/* Rename the non ANSI C functions. This is required by the standard + because some ANSI C functions will require linking with this object + file and the name space must not be polluted. */ +# define getcwd __getcwd +# ifndef stpcpy +# define stpcpy __stpcpy +# endif +#else +# if !defined HAVE_GETCWD +char *getwd (); +# define getcwd(buf, max) getwd (buf) +# else +char *getcwd (); +# endif +# ifndef HAVE_STPCPY +static char *stpcpy PARAMS ((char *dest, const char *src)); +# endif +#endif + +/* Amount to increase buffer size by in each try. */ +#define PATH_INCR 32 + +/* The following is from pathmax.h. */ +/* Non-POSIX BSD systems might have gcc's limits.h, which doesn't define + PATH_MAX but might cause redefinition warnings when sys/param.h is + later included (as on MORE/BSD 4.3). */ +#if defined(_POSIX_VERSION) || (defined(HAVE_LIMITS_H) && !defined(__GNUC__)) +# include +#endif + +#ifndef _POSIX_PATH_MAX +# define _POSIX_PATH_MAX 255 +#endif + +#if !defined(PATH_MAX) && defined(_PC_PATH_MAX) +# define PATH_MAX (pathconf ("/", _PC_PATH_MAX) < 1 ? 1024 : pathconf ("/", _PC_PATH_MAX)) +#endif + +/* Don't include sys/param.h if it already has been. */ +#if defined(HAVE_SYS_PARAM_H) && !defined(PATH_MAX) && !defined(MAXPATHLEN) +# include +#endif + +#if !defined(PATH_MAX) && defined(MAXPATHLEN) +# define PATH_MAX MAXPATHLEN +#endif + +#ifndef PATH_MAX +# define PATH_MAX _POSIX_PATH_MAX +#endif + +/* XPG3 defines the result of `setlocale (category, NULL)' as: + ``Directs `setlocale()' to query `category' and return the current + setting of `local'.'' + However it does not specify the exact format. And even worse: POSIX + defines this not at all. So we can use this feature only on selected + system (e.g. those using GNU C Library). */ +#ifdef _LIBC +# define HAVE_LOCALE_NULL +#endif + +/* Name of the default domain used for gettext(3) prior any call to + textdomain(3). The default value for this is "messages". */ +const char _nl_default_default_domain[] = "messages"; + +/* Value used as the default domain for gettext(3). */ +const char *_nl_current_default_domain = _nl_default_default_domain; + +/* Contains the default location of the message catalogs. */ +const char _nl_default_dirname[] = GNULOCALEDIR; + +/* List with bindings of specific domains created by bindtextdomain() + calls. */ +struct binding *_nl_domain_bindings; + +/* Prototypes for local functions. */ +static char *find_msg PARAMS ((struct loaded_l10nfile *domain_file, + const char *msgid)) internal_function; +static const char *category_to_name PARAMS ((int category)) internal_function; +static const char *guess_category_value PARAMS ((int category, + const char *categoryname)) + internal_function; + + +/* For those loosing systems which don't have `alloca' we have to add + some additional code emulating it. */ +#ifdef HAVE_ALLOCA +/* Nothing has to be done. */ +# define ADD_BLOCK(list, address) /* nothing */ +# define FREE_BLOCKS(list) /* nothing */ +#else +struct block_list +{ + void *address; + struct block_list *next; +}; +# define ADD_BLOCK(list, addr) \ + do { \ + struct block_list *newp = (struct block_list *) malloc (sizeof (*newp)); \ + /* If we cannot get a free block we cannot add the new element to \ + the list. */ \ + if (newp != NULL) { \ + newp->address = (addr); \ + newp->next = (list); \ + (list) = newp; \ + } \ + } while (0) +# define FREE_BLOCKS(list) \ + do { \ + while (list != NULL) { \ + struct block_list *old = list; \ + list = list->next; \ + free (old); \ + } \ + } while (0) +# undef alloca +# define alloca(size) (malloc (size)) +#endif /* have alloca */ + + +/* Names for the libintl functions are a problem. They must not clash + with existing names and they should follow ANSI C. But this source + code is also used in GNU C Library where the names have a __ + prefix. So we have to make a difference here. */ +#ifdef _LIBC +# define DCGETTEXT __dcgettext +#else +# define DCGETTEXT dcgettext__ +#endif + +/* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY + locale. */ +char * +DCGETTEXT (domainname, msgid, category) + const char *domainname; + const char *msgid; + int category; +{ +#ifndef HAVE_ALLOCA + struct block_list *block_list = NULL; +#endif + struct loaded_l10nfile *domain; + struct binding *binding; + const char *categoryname; + const char *categoryvalue; + char *dirname, *xdomainname; + char *single_locale; + char *retval; + int saved_errno = errno; + + /* If no real MSGID is given return NULL. */ + if (msgid == NULL) + return NULL; + + /* If DOMAINNAME is NULL, we are interested in the default domain. If + CATEGORY is not LC_MESSAGES this might not make much sense but the + defintion left this undefined. */ + if (domainname == NULL) + domainname = _nl_current_default_domain; + + /* First find matching binding. */ + for (binding = _nl_domain_bindings; binding != NULL; binding = binding->next) + { + int compare = strcmp (domainname, binding->domainname); + if (compare == 0) + /* We found it! */ + break; + if (compare < 0) + { + /* It is not in the list. */ + binding = NULL; + break; + } + } + + if (binding == NULL) + dirname = (char *) _nl_default_dirname; + else if (binding->dirname[0] == '/') + dirname = binding->dirname; + else + { + /* We have a relative path. Make it absolute now. */ + size_t dirname_len = strlen (binding->dirname) + 1; + size_t path_max; + char *ret; + + path_max = (unsigned) PATH_MAX; + path_max += 2; /* The getcwd docs say to do this. */ + + dirname = (char *) alloca (path_max + dirname_len); + ADD_BLOCK (block_list, dirname); + + __set_errno (0); + while ((ret = getcwd (dirname, path_max)) == NULL && errno == ERANGE) + { + path_max += PATH_INCR; + dirname = (char *) alloca (path_max + dirname_len); + ADD_BLOCK (block_list, dirname); + __set_errno (0); + } + + if (ret == NULL) + { + /* We cannot get the current working directory. Don't signal an + error but simply return the default string. */ + FREE_BLOCKS (block_list); + __set_errno (saved_errno); + return (char *) msgid; + } + + stpcpy (stpcpy (strchr (dirname, '\0'), "/"), binding->dirname); + } + + /* Now determine the symbolic name of CATEGORY and its value. */ + categoryname = category_to_name (category); + categoryvalue = guess_category_value (category, categoryname); + + xdomainname = (char *) alloca (strlen (categoryname) + + strlen (domainname) + 5); + ADD_BLOCK (block_list, xdomainname); + + stpcpy (stpcpy (stpcpy (stpcpy (xdomainname, categoryname), "/"), + domainname), + ".mo"); + + /* Creating working area. */ + single_locale = (char *) alloca (strlen (categoryvalue) + 1); + ADD_BLOCK (block_list, single_locale); + + + /* Search for the given string. This is a loop because we perhaps + got an ordered list of languages to consider for th translation. */ + while (1) + { + /* Make CATEGORYVALUE point to the next element of the list. */ + while (categoryvalue[0] != '\0' && categoryvalue[0] == ':') + ++categoryvalue; + if (categoryvalue[0] == '\0') + { + /* The whole contents of CATEGORYVALUE has been searched but + no valid entry has been found. We solve this situation + by implicitly appending a "C" entry, i.e. no translation + will take place. */ + single_locale[0] = 'C'; + single_locale[1] = '\0'; + } + else + { + char *cp = single_locale; + while (categoryvalue[0] != '\0' && categoryvalue[0] != ':') + *cp++ = *categoryvalue++; + *cp = '\0'; + } + + /* If the current locale value is C (or POSIX) we don't load a + domain. Return the MSGID. */ + if (strcmp (single_locale, "C") == 0 + || strcmp (single_locale, "POSIX") == 0) + { + FREE_BLOCKS (block_list); + __set_errno (saved_errno); + return (char *) msgid; + } + + + /* Find structure describing the message catalog matching the + DOMAINNAME and CATEGORY. */ + domain = _nl_find_domain (dirname, single_locale, xdomainname); + + if (domain != NULL) + { + retval = find_msg (domain, msgid); + + if (retval == NULL) + { + int cnt; + + for (cnt = 0; domain->successor[cnt] != NULL; ++cnt) + { + retval = find_msg (domain->successor[cnt], msgid); + + if (retval != NULL) + break; + } + } + + if (retval != NULL) + { + FREE_BLOCKS (block_list); + __set_errno (saved_errno); + return retval; + } + } + } + /* NOTREACHED */ +} + +#ifdef _LIBC +/* Alias for function name in GNU C Library. */ +weak_alias (__dcgettext, dcgettext); +#endif + + +static char * +internal_function +find_msg (domain_file, msgid) + struct loaded_l10nfile *domain_file; + const char *msgid; +{ + size_t top, act, bottom; + struct loaded_domain *domain; + + if (domain_file->decided == 0) + _nl_load_domain (domain_file); + + if (domain_file->data == NULL) + return NULL; + + domain = (struct loaded_domain *) domain_file->data; + + /* Locate the MSGID and its translation. */ + if (domain->hash_size > 2 && domain->hash_tab != NULL) + { + /* Use the hashing table. */ + nls_uint32 len = strlen (msgid); + nls_uint32 hash_val = hash_string (msgid); + nls_uint32 idx = hash_val % domain->hash_size; + nls_uint32 incr = 1 + (hash_val % (domain->hash_size - 2)); + nls_uint32 nstr = W (domain->must_swap, domain->hash_tab[idx]); + + if (nstr == 0) + /* Hash table entry is empty. */ + return NULL; + + if (W (domain->must_swap, domain->orig_tab[nstr - 1].length) == len + && strcmp (msgid, + domain->data + W (domain->must_swap, + domain->orig_tab[nstr - 1].offset)) == 0) + return (char *) domain->data + W (domain->must_swap, + domain->trans_tab[nstr - 1].offset); + + while (1) + { + if (idx >= domain->hash_size - incr) + idx -= domain->hash_size - incr; + else + idx += incr; + + nstr = W (domain->must_swap, domain->hash_tab[idx]); + if (nstr == 0) + /* Hash table entry is empty. */ + return NULL; + + if (W (domain->must_swap, domain->orig_tab[nstr - 1].length) == len + && strcmp (msgid, + domain->data + W (domain->must_swap, + domain->orig_tab[nstr - 1].offset)) + == 0) + return (char *) domain->data + + W (domain->must_swap, domain->trans_tab[nstr - 1].offset); + } + /* NOTREACHED */ + } + + /* Now we try the default method: binary search in the sorted + array of messages. */ + bottom = 0; + top = domain->nstrings; + while (bottom < top) + { + int cmp_val; + + act = (bottom + top) / 2; + cmp_val = strcmp (msgid, domain->data + + W (domain->must_swap, + domain->orig_tab[act].offset)); + if (cmp_val < 0) + top = act; + else if (cmp_val > 0) + bottom = act + 1; + else + break; + } + + /* If an translation is found return this. */ + return bottom >= top ? NULL : (char *) domain->data + + W (domain->must_swap, + domain->trans_tab[act].offset); +} + + +/* Return string representation of locale CATEGORY. */ +static const char * +internal_function +category_to_name (category) + int category; +{ + const char *retval; + + switch (category) + { +#ifdef LC_COLLATE + case LC_COLLATE: + retval = "LC_COLLATE"; + break; +#endif +#ifdef LC_CTYPE + case LC_CTYPE: + retval = "LC_CTYPE"; + break; +#endif +#ifdef LC_MONETARY + case LC_MONETARY: + retval = "LC_MONETARY"; + break; +#endif +#ifdef LC_NUMERIC + case LC_NUMERIC: + retval = "LC_NUMERIC"; + break; +#endif +#ifdef LC_TIME + case LC_TIME: + retval = "LC_TIME"; + break; +#endif +#ifdef LC_MESSAGES + case LC_MESSAGES: + retval = "LC_MESSAGES"; + break; +#endif +#ifdef LC_RESPONSE + case LC_RESPONSE: + retval = "LC_RESPONSE"; + break; +#endif +#ifdef LC_ALL + case LC_ALL: + /* This might not make sense but is perhaps better than any other + value. */ + retval = "LC_ALL"; + break; +#endif + default: + /* If you have a better idea for a default value let me know. */ + retval = "LC_XXX"; + } + + return retval; +} + +/* Guess value of current locale from value of the environment variables. */ +static const char * +internal_function +guess_category_value (category, categoryname) + int category; + const char *categoryname; +{ + const char *retval; + + /* The highest priority value is the `LANGUAGE' environment + variable. This is a GNU extension. */ + retval = getenv ("LANGUAGE"); + if (retval != NULL && retval[0] != '\0') + return retval; + + /* `LANGUAGE' is not set. So we have to proceed with the POSIX + methods of looking to `LC_ALL', `LC_xxx', and `LANG'. On some + systems this can be done by the `setlocale' function itself. */ +#if defined HAVE_SETLOCALE && defined HAVE_LC_MESSAGES && defined HAVE_LOCALE_NULL + return setlocale (category, NULL); +#else + /* Setting of LC_ALL overwrites all other. */ + retval = getenv ("LC_ALL"); + if (retval != NULL && retval[0] != '\0') + return retval; + + /* Next comes the name of the desired category. */ + retval = getenv (categoryname); + if (retval != NULL && retval[0] != '\0') + return retval; + + /* Last possibility is the LANG environment variable. */ + retval = getenv ("LANG"); + if (retval != NULL && retval[0] != '\0') + return retval; + + /* We use C as the default domain. POSIX says this is implementation + defined. */ + return "C"; +#endif +} + +/* @@ begin of epilog @@ */ + +/* We don't want libintl.a to depend on any other library. So we + avoid the non-standard function stpcpy. In GNU C Library this + function is available, though. Also allow the symbol HAVE_STPCPY + to be defined. */ +#if !_LIBC && !HAVE_STPCPY +static char * +stpcpy (dest, src) + char *dest; + const char *src; +{ + while ((*dest++ = *src++) != '\0') + /* Do nothing. */ ; + return dest - 1; +} +#endif + + +#ifdef _LIBC +/* If we want to free all resources we have to do some work at + program's end. */ +static void __attribute__ ((unused)) +free_mem (void) +{ + struct binding *runp; + + for (runp = _nl_domain_bindings; runp != NULL; runp = runp->next) + { + free (runp->domainname); + if (runp->dirname != _nl_default_dirname) + /* Yes, this is a pointer comparison. */ + free (runp->dirname); + } + + if (_nl_current_default_domain != _nl_default_default_domain) + /* Yes, again a pointer comparison. */ + free ((char *) _nl_current_default_domain); +} + +text_set_element (__libc_subfreeres, free_mem); +#endif diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/dgettext.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/dgettext.c new file mode 100644 index 0000000000..6525d83293 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/dgettext.c @@ -0,0 +1,59 @@ +/* Implementation of the dgettext(3) function + Copyright (C) 1995, 1996, 1997 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + +#if defined HAVE_LOCALE_H || defined _LIBC +# include +#endif + +#ifdef _LIBC +# include +#else +# include "libgettext.h" +#endif + +/* @@ end of prolog @@ */ + +/* Names for the libintl functions are a problem. They must not clash + with existing names and they should follow ANSI C. But this source + code is also used in GNU C Library where the names have a __ + prefix. So we have to make a difference here. */ +#ifdef _LIBC +# define DGETTEXT __dgettext +# define DCGETTEXT __dcgettext +#else +# define DGETTEXT dgettext__ +# define DCGETTEXT dcgettext__ +#endif + +/* Look up MSGID in the DOMAINNAME message catalog of the current + LC_MESSAGES locale. */ +char * +DGETTEXT (domainname, msgid) + const char *domainname; + const char *msgid; +{ + return DCGETTEXT (domainname, msgid, LC_MESSAGES); +} + +#ifdef _LIBC +/* Alias for function name in GNU C Library. */ +weak_alias (__dgettext, dgettext); +#endif diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/explodename.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/explodename.c new file mode 100644 index 0000000000..b80aa79ae2 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/explodename.c @@ -0,0 +1,188 @@ +/* Copyright (C) 1995, 1996, 1997, 1998 Free Software Foundation, Inc. + Contributed by Ulrich Drepper , 1995. + + 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + +#if defined STDC_HEADERS || defined _LIBC +# include +#endif + +#if defined HAVE_STRING_H || defined _LIBC +# include +#else +# include +#endif +#include + +#include "loadinfo.h" + +/* On some strange systems still no definition of NULL is found. Sigh! */ +#ifndef NULL +# if defined __STDC__ && __STDC__ +# define NULL ((void *) 0) +# else +# define NULL 0 +# endif +#endif + +/* @@ end of prolog @@ */ + +int +_nl_explode_name (name, language, modifier, territory, codeset, + normalized_codeset, special, sponsor, revision) + char *name; + const char **language; + const char **modifier; + const char **territory; + const char **codeset; + const char **normalized_codeset; + const char **special; + const char **sponsor; + const char **revision; +{ + enum { undecided, xpg, cen } syntax; + char *cp; + int mask; + + *modifier = NULL; + *territory = NULL; + *codeset = NULL; + *normalized_codeset = NULL; + *special = NULL; + *sponsor = NULL; + *revision = NULL; + + /* Now we determine the single parts of the locale name. First + look for the language. Termination symbols are `_' and `@' if + we use XPG4 style, and `_', `+', and `,' if we use CEN syntax. */ + mask = 0; + syntax = undecided; + *language = cp = name; + while (cp[0] != '\0' && cp[0] != '_' && cp[0] != '@' + && cp[0] != '+' && cp[0] != ',') + ++cp; + + if (*language == cp) + /* This does not make sense: language has to be specified. Use + this entry as it is without exploding. Perhaps it is an alias. */ + cp = strchr (*language, '\0'); + else if (cp[0] == '_') + { + /* Next is the territory. */ + cp[0] = '\0'; + *territory = ++cp; + + while (cp[0] != '\0' && cp[0] != '.' && cp[0] != '@' + && cp[0] != '+' && cp[0] != ',' && cp[0] != '_') + ++cp; + + mask |= TERRITORY; + + if (cp[0] == '.') + { + /* Next is the codeset. */ + syntax = xpg; + cp[0] = '\0'; + *codeset = ++cp; + + while (cp[0] != '\0' && cp[0] != '@') + ++cp; + + mask |= XPG_CODESET; + + if (*codeset != cp && (*codeset)[0] != '\0') + { + *normalized_codeset = _nl_normalize_codeset (*codeset, + cp - *codeset); + if (strcmp (*codeset, *normalized_codeset) == 0) + free ((char *) *normalized_codeset); + else + mask |= XPG_NORM_CODESET; + } + } + } + + if (cp[0] == '@' || (syntax != xpg && cp[0] == '+')) + { + /* Next is the modifier. */ + syntax = cp[0] == '@' ? xpg : cen; + cp[0] = '\0'; + *modifier = ++cp; + + while (syntax == cen && cp[0] != '\0' && cp[0] != '+' + && cp[0] != ',' && cp[0] != '_') + ++cp; + + mask |= XPG_MODIFIER | CEN_AUDIENCE; + } + + if (syntax != xpg && (cp[0] == '+' || cp[0] == ',' || cp[0] == '_')) + { + syntax = cen; + + if (cp[0] == '+') + { + /* Next is special application (CEN syntax). */ + cp[0] = '\0'; + *special = ++cp; + + while (cp[0] != '\0' && cp[0] != ',' && cp[0] != '_') + ++cp; + + mask |= CEN_SPECIAL; + } + + if (cp[0] == ',') + { + /* Next is sponsor (CEN syntax). */ + cp[0] = '\0'; + *sponsor = ++cp; + + while (cp[0] != '\0' && cp[0] != '_') + ++cp; + + mask |= CEN_SPONSOR; + } + + if (cp[0] == '_') + { + /* Next is revision (CEN syntax). */ + cp[0] = '\0'; + *revision = ++cp; + + mask |= CEN_REVISION; + } + } + + /* For CEN syntax values it might be important to have the + separator character in the file name, not for XPG syntax. */ + if (syntax == xpg) + { + if (*territory != NULL && (*territory)[0] == '\0') + mask &= ~TERRITORY; + + if (*codeset != NULL && (*codeset)[0] == '\0') + mask &= ~XPG_CODESET; + + if (*modifier != NULL && (*modifier)[0] == '\0') + mask &= ~XPG_MODIFIER; + } + + return mask; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/finddomain.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/finddomain.c new file mode 100644 index 0000000000..9588532f3d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/finddomain.c @@ -0,0 +1,216 @@ +/* Handle list of needed message catalogs + Copyright (C) 1995, 1996, 1997, 1998 Free Software Foundation, Inc. + Written by Ulrich Drepper , 1995. + + 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + +#include +#include +#include +#include + +#if defined STDC_HEADERS || defined _LIBC +# include +#else +# ifdef HAVE_MALLOC_H +# include +# else +void free (); +# endif +#endif + +#if defined HAVE_STRING_H || defined _LIBC +# include +#else +# include +# ifndef memcpy +# define memcpy(Dst, Src, Num) bcopy (Src, Dst, Num) +# endif +#endif +#if !HAVE_STRCHR && !defined _LIBC +# ifndef strchr +# define strchr index +# endif +#endif + +#if defined HAVE_UNISTD_H || defined _LIBC +# include +#endif + +#include "gettext.h" +#include "gettextP.h" +#ifdef _LIBC +# include +#else +# include "libgettext.h" +#endif + +/* @@ end of prolog @@ */ +/* List of already loaded domains. */ +static struct loaded_l10nfile *_nl_loaded_domains; + + +/* Return a data structure describing the message catalog described by + the DOMAINNAME and CATEGORY parameters with respect to the currently + established bindings. */ +struct loaded_l10nfile * +internal_function +_nl_find_domain (dirname, locale, domainname) + const char *dirname; + char *locale; + const char *domainname; +{ + struct loaded_l10nfile *retval; + const char *language; + const char *modifier; + const char *territory; + const char *codeset; + const char *normalized_codeset; + const char *special; + const char *sponsor; + const char *revision; + const char *alias_value; + int mask; + + /* LOCALE can consist of up to four recognized parts for the XPG syntax: + + language[_territory[.codeset]][@modifier] + + and six parts for the CEN syntax: + + language[_territory][+audience][+special][,[sponsor][_revision]] + + Beside the first part all of them are allowed to be missing. If + the full specified locale is not found, the less specific one are + looked for. The various parts will be stripped off according to + the following order: + (1) revision + (2) sponsor + (3) special + (4) codeset + (5) normalized codeset + (6) territory + (7) audience/modifier + */ + + /* If we have already tested for this locale entry there has to + be one data set in the list of loaded domains. */ + retval = _nl_make_l10nflist (&_nl_loaded_domains, dirname, + strlen (dirname) + 1, 0, locale, NULL, NULL, + NULL, NULL, NULL, NULL, NULL, domainname, 0); + if (retval != NULL) + { + /* We know something about this locale. */ + int cnt; + + if (retval->decided == 0) + _nl_load_domain (retval); + + if (retval->data != NULL) + return retval; + + for (cnt = 0; retval->successor[cnt] != NULL; ++cnt) + { + if (retval->successor[cnt]->decided == 0) + _nl_load_domain (retval->successor[cnt]); + + if (retval->successor[cnt]->data != NULL) + break; + } + return cnt >= 0 ? retval : NULL; + /* NOTREACHED */ + } + + /* See whether the locale value is an alias. If yes its value + *overwrites* the alias name. No test for the original value is + done. */ + alias_value = _nl_expand_alias (locale); + if (alias_value != NULL) + { +#if defined _LIBC || defined HAVE_STRDUP + locale = strdup (alias_value); + if (locale == NULL) + return NULL; +#else + size_t len = strlen (alias_value) + 1; + locale = (char *) malloc (len); + if (locale == NULL) + return NULL; + + memcpy (locale, alias_value, len); +#endif + } + + /* Now we determine the single parts of the locale name. First + look for the language. Termination symbols are `_' and `@' if + we use XPG4 style, and `_', `+', and `,' if we use CEN syntax. */ + mask = _nl_explode_name (locale, &language, &modifier, &territory, + &codeset, &normalized_codeset, &special, + &sponsor, &revision); + + /* Create all possible locale entries which might be interested in + generalization. */ + retval = _nl_make_l10nflist (&_nl_loaded_domains, dirname, + strlen (dirname) + 1, mask, language, territory, + codeset, normalized_codeset, modifier, special, + sponsor, revision, domainname, 1); + if (retval == NULL) + /* This means we are out of core. */ + return NULL; + + if (retval->decided == 0) + _nl_load_domain (retval); + if (retval->data == NULL) + { + int cnt; + for (cnt = 0; retval->successor[cnt] != NULL; ++cnt) + { + if (retval->successor[cnt]->decided == 0) + _nl_load_domain (retval->successor[cnt]); + if (retval->successor[cnt]->data != NULL) + break; + } + } + + /* The room for an alias was dynamically allocated. Free it now. */ + if (alias_value != NULL) + free (locale); + + return retval; +} + + +#ifdef _LIBC +static void __attribute__ ((unused)) +free_mem (void) +{ + struct loaded_l10nfile *runp = _nl_loaded_domains; + + while (runp != NULL) + { + struct loaded_l10nfile *here = runp; + if (runp->data != NULL) + _nl_unload_domain ((struct loaded_domain *) runp->data); + runp = runp->next; + free (here); + } +} + +text_set_element (__libc_subfreeres, free_mem); +#endif diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettext.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettext.c new file mode 100644 index 0000000000..c3c64bf8c5 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettext.c @@ -0,0 +1,70 @@ +/* Implementation of gettext(3) function. + Copyright (C) 1995, 1997 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + +#ifdef _LIBC +# define __need_NULL +# include +#else +# ifdef STDC_HEADERS +# include /* Just for NULL. */ +# else +# ifdef HAVE_STRING_H +# include +# else +# define NULL ((void *) 0) +# endif +# endif +#endif + +#ifdef _LIBC +# include +#else +# include "libgettext.h" +#endif + +/* @@ end of prolog @@ */ + +/* Names for the libintl functions are a problem. They must not clash + with existing names and they should follow ANSI C. But this source + code is also used in GNU C Library where the names have a __ + prefix. So we have to make a difference here. */ +#ifdef _LIBC +# define GETTEXT __gettext +# define DGETTEXT __dgettext +#else +# define GETTEXT gettext__ +# define DGETTEXT dgettext__ +#endif + +/* Look up MSGID in the current default message catalog for the current + LC_MESSAGES locale. If not found, returns MSGID itself (the default + text). */ +char * +GETTEXT (msgid) + const char *msgid; +{ + return DGETTEXT (NULL, msgid); +} + +#ifdef _LIBC +/* Alias for function name in GNU C Library. */ +weak_alias (__gettext, gettext); +#endif diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettext.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettext.h new file mode 100644 index 0000000000..3cd23d7d6a --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettext.h @@ -0,0 +1,105 @@ +/* Internal header for GNU gettext internationalization functions. + Copyright (C) 1995, 1997 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 Library General Public + License along with the GNU C Library; see the file COPYING.LIB. If not, + write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. */ + +#ifndef _GETTEXT_H +#define _GETTEXT_H 1 + +#include + +#if HAVE_LIMITS_H || _LIBC +# include +#endif + +/* @@ end of prolog @@ */ + +/* The magic number of the GNU message catalog format. */ +#define _MAGIC 0x950412de +#define _MAGIC_SWAPPED 0xde120495 + +/* Revision number of the currently used .mo (binary) file format. */ +#define MO_REVISION_NUMBER 0 + +/* The following contortions are an attempt to use the C preprocessor + to determine an unsigned integral type that is 32 bits wide. An + alternative approach is to use autoconf's AC_CHECK_SIZEOF macro, but + doing that would require that the configure script compile and *run* + the resulting executable. Locally running cross-compiled executables + is usually not possible. */ + +#if __STDC__ +# define UINT_MAX_32_BITS 4294967295U +#else +# define UINT_MAX_32_BITS 0xFFFFFFFF +#endif + +/* If UINT_MAX isn't defined, assume it's a 32-bit type. + This should be valid for all systems GNU cares about because + that doesn't include 16-bit systems, and only modern systems + (that certainly have ) have 64+-bit integral types. */ + +#ifndef UINT_MAX +# define UINT_MAX UINT_MAX_32_BITS +#endif + +#if UINT_MAX == UINT_MAX_32_BITS +typedef unsigned nls_uint32; +#else +# if USHRT_MAX == UINT_MAX_32_BITS +typedef unsigned short nls_uint32; +# else +# if ULONG_MAX == UINT_MAX_32_BITS +typedef unsigned long nls_uint32; +# else + /* The following line is intended to throw an error. Using #error is + not portable enough. */ + "Cannot determine unsigned 32-bit data type." +# endif +# endif +#endif + + +/* Header for binary .mo file format. */ +struct mo_file_header +{ + /* The magic number. */ + nls_uint32 magic; + /* The revision number of the file format. */ + nls_uint32 revision; + /* The number of strings pairs. */ + nls_uint32 nstrings; + /* Offset of table with start offsets of original strings. */ + nls_uint32 orig_tab_offset; + /* Offset of table with start offsets of translation strings. */ + nls_uint32 trans_tab_offset; + /* Size of hashing table. */ + nls_uint32 hash_tab_size; + /* Offset of first hashing entry. */ + nls_uint32 hash_tab_offset; +}; + +struct string_desc +{ + /* Length of addressed string. */ + nls_uint32 length; + /* Offset of string in file. */ + nls_uint32 offset; +}; + +/* @@ begin of epilog @@ */ + +#endif /* gettext.h */ diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettextP.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettextP.h new file mode 100644 index 0000000000..00c5203197 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/gettextP.h @@ -0,0 +1,89 @@ +/* Header describing internals of gettext library + Copyright (C) 1995, 1996, 1997, 1998 Free Software Foundation, Inc. + Written by Ulrich Drepper , 1995. + + 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifndef _GETTEXTP_H +#define _GETTEXTP_H + +#include "loadinfo.h" + +/* @@ end of prolog @@ */ + +#ifndef PARAMS +# if __STDC__ +# define PARAMS(args) args +# else +# define PARAMS(args) () +# endif +#endif + +#ifndef internal_function +# define internal_function +#endif + +#ifndef W +# define W(flag, data) ((flag) ? SWAP (data) : (data)) +#endif + + +#ifdef _LIBC +# include +# define SWAP(i) bswap_32 (i) +#else +static nls_uint32 SWAP PARAMS ((nls_uint32 i)); + +static inline nls_uint32 +SWAP (i) + nls_uint32 i; +{ + return (i << 24) | ((i & 0xff00) << 8) | ((i >> 8) & 0xff00) | (i >> 24); +} +#endif + + +struct loaded_domain +{ + const char *data; + int use_mmap; + size_t mmap_size; + int must_swap; + nls_uint32 nstrings; + struct string_desc *orig_tab; + struct string_desc *trans_tab; + nls_uint32 hash_size; + nls_uint32 *hash_tab; +}; + +struct binding +{ + struct binding *next; + char *domainname; + char *dirname; +}; + +struct loaded_l10nfile *_nl_find_domain PARAMS ((const char *__dirname, + char *__locale, + const char *__domainname)) + internal_function; +void _nl_load_domain PARAMS ((struct loaded_l10nfile *__domain)) + internal_function; +void _nl_unload_domain PARAMS ((struct loaded_domain *__domain)) + internal_function; + +/* @@ begin of epilog @@ */ + +#endif /* gettextP.h */ diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/hash-string.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/hash-string.h new file mode 100644 index 0000000000..cacb38e479 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/hash-string.h @@ -0,0 +1,59 @@ +/* Implements a string hashing function. + Copyright (C) 1995, 1997 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 Library General Public + License along with the GNU C Library; see the file COPYING.LIB. If not, + write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. */ + +/* @@ end of prolog @@ */ + +#ifndef PARAMS +# if __STDC__ +# define PARAMS(Args) Args +# else +# define PARAMS(Args) () +# endif +#endif + +/* We assume to have `unsigned long int' value with at least 32 bits. */ +#define HASHWORDBITS 32 + + +/* Defines the so called `hashpjw' function by P.J. Weinberger + [see Aho/Sethi/Ullman, COMPILERS: Principles, Techniques and Tools, + 1986, 1987 Bell Telephone Laboratories, Inc.] */ +static unsigned long hash_string PARAMS ((const char *__str_param)); + +static inline unsigned long +hash_string (str_param) + const char *str_param; +{ + unsigned long int hval, g; + const char *str = str_param; + + /* Compute the hash value for the given string. */ + hval = 0; + while (*str != '\0') + { + hval <<= 4; + hval += (unsigned long) *str++; + g = hval & ((unsigned long) 0xf << (HASHWORDBITS - 4)); + if (g != 0) + { + hval ^= g >> (HASHWORDBITS - 8); + hval ^= g; + } + } + return hval; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/intl-compat.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/intl-compat.c new file mode 100644 index 0000000000..21ffc60c19 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/intl-compat.c @@ -0,0 +1,76 @@ +/* intl-compat.c - Stub functions to call gettext functions from GNU gettext + Library. + Copyright (C) 1995 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + +#include "libgettext.h" + +/* @@ end of prolog @@ */ + + +#undef gettext +#undef dgettext +#undef dcgettext +#undef textdomain +#undef bindtextdomain + + +char * +bindtextdomain (domainname, dirname) + const char *domainname; + const char *dirname; +{ + return bindtextdomain__ (domainname, dirname); +} + + +char * +dcgettext (domainname, msgid, category) + const char *domainname; + const char *msgid; + int category; +{ + return dcgettext__ (domainname, msgid, category); +} + + +char * +dgettext (domainname, msgid) + const char *domainname; + const char *msgid; +{ + return dgettext__ (domainname, msgid); +} + + +char * +gettext (msgid) + const char *msgid; +{ + return gettext__ (msgid); +} + + +char * +textdomain (domainname) + const char *domainname; +{ + return textdomain__ (domainname); +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/l10nflist.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/l10nflist.c new file mode 100644 index 0000000000..174794201c --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/l10nflist.c @@ -0,0 +1,411 @@ +/* Handle list of needed message catalogs + Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc. + Contributed by Ulrich Drepper , 1995. + + 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + + +#if defined HAVE_STRING_H || defined _LIBC +# ifndef _GNU_SOURCE +# define _GNU_SOURCE 1 +# endif +# include +#else +# include +# ifndef memcpy +# define memcpy(Dst, Src, Num) bcopy (Src, Dst, Num) +# endif +#endif +#if !HAVE_STRCHR && !defined _LIBC +# ifndef strchr +# define strchr index +# endif +#endif + +#if defined _LIBC || defined HAVE_ARGZ_H +# include +#endif +#include +#include + +#if defined STDC_HEADERS || defined _LIBC +# include +#endif + +#include "loadinfo.h" + +/* On some strange systems still no definition of NULL is found. Sigh! */ +#ifndef NULL +# if defined __STDC__ && __STDC__ +# define NULL ((void *) 0) +# else +# define NULL 0 +# endif +#endif + +/* @@ end of prolog @@ */ + +#ifdef _LIBC +/* Rename the non ANSI C functions. This is required by the standard + because some ANSI C functions will require linking with this object + file and the name space must not be polluted. */ +# ifndef stpcpy +# define stpcpy(dest, src) __stpcpy(dest, src) +# endif +#else +# ifndef HAVE_STPCPY +static char *stpcpy PARAMS ((char *dest, const char *src)); +# endif +#endif + +/* Define function which are usually not available. */ + +#if !defined _LIBC && !defined HAVE___ARGZ_COUNT +/* Returns the number of strings in ARGZ. */ +static size_t argz_count__ PARAMS ((const char *argz, size_t len)); + +static size_t +argz_count__ (argz, len) + const char *argz; + size_t len; +{ + size_t count = 0; + while (len > 0) + { + size_t part_len = strlen (argz); + argz += part_len + 1; + len -= part_len + 1; + count++; + } + return count; +} +# undef __argz_count +# define __argz_count(argz, len) argz_count__ (argz, len) +#endif /* !_LIBC && !HAVE___ARGZ_COUNT */ + +#if !defined _LIBC && !defined HAVE___ARGZ_STRINGIFY +/* Make '\0' separated arg vector ARGZ printable by converting all the '\0's + except the last into the character SEP. */ +static void argz_stringify__ PARAMS ((char *argz, size_t len, int sep)); + +static void +argz_stringify__ (argz, len, sep) + char *argz; + size_t len; + int sep; +{ + while (len > 0) + { + size_t part_len = strlen (argz); + argz += part_len; + len -= part_len + 1; + if (len > 0) + *argz++ = sep; + } +} +# undef __argz_stringify +# define __argz_stringify(argz, len, sep) argz_stringify__ (argz, len, sep) +#endif /* !_LIBC && !HAVE___ARGZ_STRINGIFY */ + +#if !defined _LIBC && !defined HAVE___ARGZ_NEXT +static char *argz_next__ PARAMS ((char *argz, size_t argz_len, + const char *entry)); + +static char * +argz_next__ (argz, argz_len, entry) + char *argz; + size_t argz_len; + const char *entry; +{ + if (entry) + { + if (entry < argz + argz_len) + entry = strchr (entry, '\0') + 1; + + return entry >= argz + argz_len ? NULL : (char *) entry; + } + else + if (argz_len > 0) + return argz; + else + return 0; +} +# undef __argz_next +# define __argz_next(argz, len, entry) argz_next__ (argz, len, entry) +#endif /* !_LIBC && !HAVE___ARGZ_NEXT */ + + +/* Return number of bits set in X. */ +static int pop PARAMS ((int x)); + +static inline int +pop (x) + int x; +{ + /* We assume that no more than 16 bits are used. */ + x = ((x & ~0x5555) >> 1) + (x & 0x5555); + x = ((x & ~0x3333) >> 2) + (x & 0x3333); + x = ((x >> 4) + x) & 0x0f0f; + x = ((x >> 8) + x) & 0xff; + + return x; +} + + +struct loaded_l10nfile * +_nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len, mask, language, + territory, codeset, normalized_codeset, modifier, special, + sponsor, revision, filename, do_allocate) + struct loaded_l10nfile **l10nfile_list; + const char *dirlist; + size_t dirlist_len; + int mask; + const char *language; + const char *territory; + const char *codeset; + const char *normalized_codeset; + const char *modifier; + const char *special; + const char *sponsor; + const char *revision; + const char *filename; + int do_allocate; +{ + char *abs_filename; + struct loaded_l10nfile *last = NULL; + struct loaded_l10nfile *retval; + char *cp; + size_t entries; + int cnt; + + /* Allocate room for the full file name. */ + abs_filename = (char *) malloc (dirlist_len + + strlen (language) + + ((mask & TERRITORY) != 0 + ? strlen (territory) + 1 : 0) + + ((mask & XPG_CODESET) != 0 + ? strlen (codeset) + 1 : 0) + + ((mask & XPG_NORM_CODESET) != 0 + ? strlen (normalized_codeset) + 1 : 0) + + (((mask & XPG_MODIFIER) != 0 + || (mask & CEN_AUDIENCE) != 0) + ? strlen (modifier) + 1 : 0) + + ((mask & CEN_SPECIAL) != 0 + ? strlen (special) + 1 : 0) + + (((mask & CEN_SPONSOR) != 0 + || (mask & CEN_REVISION) != 0) + ? (1 + ((mask & CEN_SPONSOR) != 0 + ? strlen (sponsor) + 1 : 0) + + ((mask & CEN_REVISION) != 0 + ? strlen (revision) + 1 : 0)) : 0) + + 1 + strlen (filename) + 1); + + if (abs_filename == NULL) + return NULL; + + retval = NULL; + last = NULL; + + /* Construct file name. */ + memcpy (abs_filename, dirlist, dirlist_len); + __argz_stringify (abs_filename, dirlist_len, ':'); + cp = abs_filename + (dirlist_len - 1); + *cp++ = '/'; + cp = stpcpy (cp, language); + + if ((mask & TERRITORY) != 0) + { + *cp++ = '_'; + cp = stpcpy (cp, territory); + } + if ((mask & XPG_CODESET) != 0) + { + *cp++ = '.'; + cp = stpcpy (cp, codeset); + } + if ((mask & XPG_NORM_CODESET) != 0) + { + *cp++ = '.'; + cp = stpcpy (cp, normalized_codeset); + } + if ((mask & (XPG_MODIFIER | CEN_AUDIENCE)) != 0) + { + /* This component can be part of both syntaces but has different + leading characters. For CEN we use `+', else `@'. */ + *cp++ = (mask & CEN_AUDIENCE) != 0 ? '+' : '@'; + cp = stpcpy (cp, modifier); + } + if ((mask & CEN_SPECIAL) != 0) + { + *cp++ = '+'; + cp = stpcpy (cp, special); + } + if ((mask & (CEN_SPONSOR | CEN_REVISION)) != 0) + { + *cp++ = ','; + if ((mask & CEN_SPONSOR) != 0) + cp = stpcpy (cp, sponsor); + if ((mask & CEN_REVISION) != 0) + { + *cp++ = '_'; + cp = stpcpy (cp, revision); + } + } + + *cp++ = '/'; + stpcpy (cp, filename); + + /* Look in list of already loaded domains whether it is already + available. */ + last = NULL; + for (retval = *l10nfile_list; retval != NULL; retval = retval->next) + if (retval->filename != NULL) + { + int compare = strcmp (retval->filename, abs_filename); + if (compare == 0) + /* We found it! */ + break; + if (compare < 0) + { + /* It's not in the list. */ + retval = NULL; + break; + } + + last = retval; + } + + if (retval != NULL || do_allocate == 0) + { + free (abs_filename); + return retval; + } + + retval = (struct loaded_l10nfile *) + malloc (sizeof (*retval) + (__argz_count (dirlist, dirlist_len) + * (1 << pop (mask)) + * sizeof (struct loaded_l10nfile *))); + if (retval == NULL) + return NULL; + + retval->filename = abs_filename; + retval->decided = (__argz_count (dirlist, dirlist_len) != 1 + || ((mask & XPG_CODESET) != 0 + && (mask & XPG_NORM_CODESET) != 0)); + retval->data = NULL; + + if (last == NULL) + { + retval->next = *l10nfile_list; + *l10nfile_list = retval; + } + else + { + retval->next = last->next; + last->next = retval; + } + + entries = 0; + /* If the DIRLIST is a real list the RETVAL entry corresponds not to + a real file. So we have to use the DIRLIST separation mechanism + of the inner loop. */ + cnt = __argz_count (dirlist, dirlist_len) == 1 ? mask - 1 : mask; + for (; cnt >= 0; --cnt) + if ((cnt & ~mask) == 0 + && ((cnt & CEN_SPECIFIC) == 0 || (cnt & XPG_SPECIFIC) == 0) + && ((cnt & XPG_CODESET) == 0 || (cnt & XPG_NORM_CODESET) == 0)) + { + /* Iterate over all elements of the DIRLIST. */ + char *dir = NULL; + + while ((dir = __argz_next ((char *) dirlist, dirlist_len, dir)) + != NULL) + retval->successor[entries++] + = _nl_make_l10nflist (l10nfile_list, dir, strlen (dir) + 1, cnt, + language, territory, codeset, + normalized_codeset, modifier, special, + sponsor, revision, filename, 1); + } + retval->successor[entries] = NULL; + + return retval; +} + +/* Normalize codeset name. There is no standard for the codeset + names. Normalization allows the user to use any of the common + names. */ +const char * +_nl_normalize_codeset (codeset, name_len) + const unsigned char *codeset; + size_t name_len; +{ + int len = 0; + int only_digit = 1; + char *retval; + char *wp; + size_t cnt; + + for (cnt = 0; cnt < name_len; ++cnt) + if (isalnum (codeset[cnt])) + { + ++len; + + if (isalpha (codeset[cnt])) + only_digit = 0; + } + + retval = (char *) malloc ((only_digit ? 3 : 0) + len + 1); + + if (retval != NULL) + { + if (only_digit) + wp = stpcpy (retval, "iso"); + else + wp = retval; + + for (cnt = 0; cnt < name_len; ++cnt) + if (isalpha (codeset[cnt])) + *wp++ = tolower (codeset[cnt]); + else if (isdigit (codeset[cnt])) + *wp++ = codeset[cnt]; + + *wp = '\0'; + } + + return (const char *) retval; +} + + +/* @@ begin of epilog @@ */ + +/* We don't want libintl.a to depend on any other library. So we + avoid the non-standard function stpcpy. In GNU C Library this + function is available, though. Also allow the symbol HAVE_STPCPY + to be defined. */ +#if !_LIBC && !HAVE_STPCPY +static char * +stpcpy (dest, src) + char *dest; + const char *src; +{ + while ((*dest++ = *src++) != '\0') + /* Do nothing. */ ; + return dest - 1; +} +#endif diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/libgettext.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/libgettext.h new file mode 100644 index 0000000000..3a92960ae3 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/libgettext.h @@ -0,0 +1,182 @@ +/* Message catalogs for internationalization. + Copyright (C) 1995, 1996, 1997, 1998 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +/* Because on some systems (e.g. Solaris) we sometimes have to include + the systems libintl.h as well as this file we have more complex + include protection above. But the systems header might perhaps also + define _LIBINTL_H and therefore we have to protect the definition here. */ + +#if !defined _LIBINTL_H || !defined _LIBGETTEXT_H +#ifndef _LIBINTL_H +# define _LIBINTL_H 1 +#endif +#define _LIBGETTEXT_H 1 + +/* We define an additional symbol to signal that we use the GNU + implementation of gettext. */ +#define __USE_GNU_GETTEXT 1 + +#include + +#if HAVE_LOCALE_H +# include +#endif + + +#ifdef __cplusplus +extern "C" { +#endif + +/* @@ end of prolog @@ */ + +#ifndef PARAMS +# if __STDC__ || defined __cplusplus +# define PARAMS(args) args +# else +# define PARAMS(args) () +# endif +#endif + +#ifndef NULL +# if !defined __cplusplus || defined __GNUC__ +# define NULL ((void *) 0) +# else +# define NULL (0) +# endif +#endif + +#if !HAVE_LC_MESSAGES +/* This value determines the behaviour of the gettext() and dgettext() + function. But some system does not have this defined. Define it + to a default value. */ +# define LC_MESSAGES (-1) +#endif + + +/* Declarations for gettext-using-catgets interface. Derived from + Jim Meyering's libintl.h. */ +struct _msg_ent +{ + const char *_msg; + int _msg_number; +}; + + +#if HAVE_CATGETS +/* These two variables are defined in the automatically by po-to-tbl.sed + generated file `cat-id-tbl.c'. */ +extern const struct _msg_ent _msg_tbl[]; +extern int _msg_tbl_length; +#endif + + +/* For automatical extraction of messages sometimes no real + translation is needed. Instead the string itself is the result. */ +#define gettext_noop(Str) (Str) + +/* Look up MSGID in the current default message catalog for the current + LC_MESSAGES locale. If not found, returns MSGID itself (the default + text). */ +extern char *gettext PARAMS ((const char *__msgid)); +extern char *gettext__ PARAMS ((const char *__msgid)); + +/* Look up MSGID in the DOMAINNAME message catalog for the current + LC_MESSAGES locale. */ +extern char *dgettext PARAMS ((const char *__domainname, const char *__msgid)); +extern char *dgettext__ PARAMS ((const char *__domainname, + const char *__msgid)); + +/* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY + locale. */ +extern char *dcgettext PARAMS ((const char *__domainname, const char *__msgid, + int __category)); +extern char *dcgettext__ PARAMS ((const char *__domainname, + const char *__msgid, int __category)); + + +/* Set the current default message catalog to DOMAINNAME. + If DOMAINNAME is null, return the current default. + If DOMAINNAME is "", reset to the default of "messages". */ +extern char *textdomain PARAMS ((const char *__domainname)); +extern char *textdomain__ PARAMS ((const char *__domainname)); + +/* Specify that the DOMAINNAME message catalog will be found + in DIRNAME rather than in the system locale data base. */ +extern char *bindtextdomain PARAMS ((const char *__domainname, + const char *__dirname)); +extern char *bindtextdomain__ PARAMS ((const char *__domainname, + const char *__dirname)); + +#if ENABLE_NLS + +/* Solaris 2.3 has the gettext function but dcgettext is missing. + So we omit this optimization for Solaris 2.3. BTW, Solaris 2.4 + has dcgettext. */ +# if !HAVE_CATGETS && (!HAVE_GETTEXT || HAVE_DCGETTEXT) + +# define gettext(Msgid) \ + dgettext (NULL, Msgid) + +# define dgettext(Domainname, Msgid) \ + dcgettext (Domainname, Msgid, LC_MESSAGES) + +# if defined __GNUC__ && __GNUC__ == 2 && __GNUC_MINOR__ >= 7 +/* This global variable is defined in loadmsgcat.c. We need a sign, + whether a new catalog was loaded, which can be associated with all + translations. */ +extern int _nl_msg_cat_cntr; + +# define dcgettext(Domainname, Msgid, Category) \ + (__extension__ \ + ({ \ + char *__result; \ + if (__builtin_constant_p (Msgid)) \ + { \ + static char *__translation__; \ + static int __catalog_counter__; \ + if (! __translation__ || __catalog_counter__ != _nl_msg_cat_cntr) \ + { \ + __translation__ = \ + dcgettext__ (Domainname, Msgid, Category); \ + __catalog_counter__ = _nl_msg_cat_cntr; \ + } \ + __result = __translation__; \ + } \ + else \ + __result = dcgettext__ (Domainname, Msgid, Category); \ + __result; \ + })) +# endif +# endif + +#else + +# define gettext(Msgid) (Msgid) +# define dgettext(Domainname, Msgid) (Msgid) +# define dcgettext(Domainname, Msgid, Category) (Msgid) +# define textdomain(Domainname) ((char *) Domainname) +# define bindtextdomain(Domainname, Dirname) ((char *) Dirname) + +#endif + +/* @@ begin of epilog @@ */ + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/linux-msg.sed b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/linux-msg.sed new file mode 100644 index 0000000000..5918e720a9 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/linux-msg.sed @@ -0,0 +1,100 @@ +# po2msg.sed - Convert Uniforum style .po file to Linux style .msg file +# Copyright (C) 1995 Free Software Foundation, Inc. +# Ulrich Drepper , 1995. +# +# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +# +# +# The first directive in the .msg should be the definition of the +# message set number. We use always set number 1. +# +1 { + i\ +$set 1 # Automatically created by po2msg.sed + h + s/.*/0/ + x +} +# +# Mitch's old catalog format does not allow comments. +# +# We copy the original message as a comment into the .msg file. +# +/^msgid/ { + s/msgid[ ]*"// +# +# This does not work now with the new format. +# /"$/! { +# s/\\$// +# s/$/ ... (more lines following)"/ +# } + x +# The following nice solution is by +# Bruno + td +# Increment a decimal number in pattern space. +# First hide trailing `9' digits. + :d + s/9\(_*\)$/_\1/ + td +# Assure at least one digit is available. + s/^\(_*\)$/0\1/ +# Increment the last digit. + s/8\(_*\)$/9\1/ + s/7\(_*\)$/8\1/ + s/6\(_*\)$/7\1/ + s/5\(_*\)$/6\1/ + s/4\(_*\)$/5\1/ + s/3\(_*\)$/4\1/ + s/2\(_*\)$/3\1/ + s/1\(_*\)$/2\1/ + s/0\(_*\)$/1\1/ +# Convert the hidden `9' digits to `0's. + s/_/0/g + x + G + s/\(.*\)"\n\([0-9]*\)/$ #\2 Original Message:(\1)/p +} +# +# The .msg file contains, other then the .po file, only the translations +# but each given a unique ID. Starting from 1 and incrementing by 1 for +# each message we assign them to the messages. +# It is important that the .po file used to generate the cat-id-tbl.c file +# (with po-to-tbl) is the same as the one used here. (At least the order +# of declarations must not be changed.) +# +/^msgstr/ { + s/msgstr[ ]*"\(.*\)"/# \1/ +# Clear substitution flag. + tb +# Append the next line. + :b + N +# Look whether second part is continuation line. + s/\(.*\n\)"\(.*\)"/\1\2/ +# Yes, then branch. + ta + P + D +# Note that D includes a jump to the start!! +# We found a continuation line. But before printing insert '\'. + :a + s/\(.*\)\(\n.*\)/\1\\\2/ + P +# We cannot use D here. + s/.*\n\(.*\)/\1/ + tb +} +d diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/loadinfo.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/loadinfo.h new file mode 100644 index 0000000000..f4ebf6d811 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/loadinfo.h @@ -0,0 +1,76 @@ +/* Copyright (C) 1996, 1997 Free Software Foundation, Inc. + This file is part of the GNU C Library. + Contributed by Ulrich Drepper , 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifndef PARAMS +# if __STDC__ +# define PARAMS(args) args +# else +# define PARAMS(args) () +# endif +#endif + +/* Encoding of locale name parts. */ +#define CEN_REVISION 1 +#define CEN_SPONSOR 2 +#define CEN_SPECIAL 4 +#define XPG_NORM_CODESET 8 +#define XPG_CODESET 16 +#define TERRITORY 32 +#define CEN_AUDIENCE 64 +#define XPG_MODIFIER 128 + +#define CEN_SPECIFIC (CEN_REVISION|CEN_SPONSOR|CEN_SPECIAL|CEN_AUDIENCE) +#define XPG_SPECIFIC (XPG_CODESET|XPG_NORM_CODESET|XPG_MODIFIER) + + +struct loaded_l10nfile +{ + const char *filename; + int decided; + + const void *data; + + struct loaded_l10nfile *next; + struct loaded_l10nfile *successor[1]; +}; + + +extern const char *_nl_normalize_codeset PARAMS ((const unsigned char *codeset, + size_t name_len)); + +extern struct loaded_l10nfile * +_nl_make_l10nflist PARAMS ((struct loaded_l10nfile **l10nfile_list, + const char *dirlist, size_t dirlist_len, int mask, + const char *language, const char *territory, + const char *codeset, + const char *normalized_codeset, + const char *modifier, const char *special, + const char *sponsor, const char *revision, + const char *filename, int do_allocate)); + + +extern const char *_nl_expand_alias PARAMS ((const char *name)); + +extern int _nl_explode_name PARAMS ((char *name, const char **language, + const char **modifier, + const char **territory, + const char **codeset, + const char **normalized_codeset, + const char **special, + const char **sponsor, + const char **revision)); diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/loadmsgcat.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/loadmsgcat.c new file mode 100644 index 0000000000..e74a2f77f5 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/loadmsgcat.c @@ -0,0 +1,222 @@ +/* Load needed message catalogs. + Copyright (C) 1995, 1996, 1997, 1998 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + +#include +#include +#include + +#if defined STDC_HEADERS || defined _LIBC +# include +#endif + +#if defined HAVE_UNISTD_H || defined _LIBC +# include +#endif + +#if (defined HAVE_MMAP && defined HAVE_MUNMAP) || defined _LIBC +# include +#endif + +#include "gettext.h" +#include "gettextP.h" + +/* @@ end of prolog @@ */ + +#ifdef _LIBC +/* Rename the non ISO C functions. This is required by the standard + because some ISO C functions will require linking with this object + file and the name space must not be polluted. */ +# define open __open +# define close __close +# define read __read +# define mmap __mmap +# define munmap __munmap +#endif + +/* We need a sign, whether a new catalog was loaded, which can be associated + with all translations. This is important if the translations are + cached by one of GCC's features. */ +int _nl_msg_cat_cntr = 0; + + +/* Load the message catalogs specified by FILENAME. If it is no valid + message catalog do nothing. */ +void +internal_function +_nl_load_domain (domain_file) + struct loaded_l10nfile *domain_file; +{ + int fd; + size_t size; + struct stat st; + struct mo_file_header *data = (struct mo_file_header *) -1; +#if (defined HAVE_MMAP && defined HAVE_MUNMAP && !defined DISALLOW_MMAP) \ + || defined _LIBC + int use_mmap = 0; +#endif + struct loaded_domain *domain; + + domain_file->decided = 1; + domain_file->data = NULL; + + /* If the record does not represent a valid locale the FILENAME + might be NULL. This can happen when according to the given + specification the locale file name is different for XPG and CEN + syntax. */ + if (domain_file->filename == NULL) + return; + + /* Try to open the addressed file. */ + fd = open (domain_file->filename, O_RDONLY); + if (fd == -1) + return; + + /* We must know about the size of the file. */ + if (fstat (fd, &st) != 0 + || (size = (size_t) st.st_size) != st.st_size + || size < sizeof (struct mo_file_header)) + { + /* Something went wrong. */ + close (fd); + return; + } + +#if (defined HAVE_MMAP && defined HAVE_MUNMAP && !defined DISALLOW_MMAP) \ + || defined _LIBC + /* Now we are ready to load the file. If mmap() is available we try + this first. If not available or it failed we try to load it. */ + data = (struct mo_file_header *) mmap (NULL, size, PROT_READ, + MAP_PRIVATE, fd, 0); + + if (data != (struct mo_file_header *) -1) + { + /* mmap() call was successful. */ + close (fd); + use_mmap = 1; + } +#endif + + /* If the data is not yet available (i.e. mmap'ed) we try to load + it manually. */ + if (data == (struct mo_file_header *) -1) + { + size_t to_read; + char *read_ptr; + + data = (struct mo_file_header *) malloc (size); + if (data == NULL) + return; + + to_read = size; + read_ptr = (char *) data; + do + { + long int nb = (long int) read (fd, read_ptr, to_read); + if (nb == -1) + { + close (fd); + return; + } + + read_ptr += nb; + to_read -= nb; + } + while (to_read > 0); + + close (fd); + } + + /* Using the magic number we can test whether it really is a message + catalog file. */ + if (data->magic != _MAGIC && data->magic != _MAGIC_SWAPPED) + { + /* The magic number is wrong: not a message catalog file. */ +#if (defined HAVE_MMAP && defined HAVE_MUNMAP && !defined DISALLOW_MMAP) \ + || defined _LIBC + if (use_mmap) + munmap ((caddr_t) data, size); + else +#endif + free (data); + return; + } + + domain_file->data + = (struct loaded_domain *) malloc (sizeof (struct loaded_domain)); + if (domain_file->data == NULL) + return; + + domain = (struct loaded_domain *) domain_file->data; + domain->data = (char *) data; +#if (defined HAVE_MMAP && defined HAVE_MUNMAP && !defined DISALLOW_MMAP) \ + || defined _LIBC + domain->use_mmap = use_mmap; +#endif + domain->mmap_size = size; + domain->must_swap = data->magic != _MAGIC; + + /* Fill in the information about the available tables. */ + switch (W (domain->must_swap, data->revision)) + { + case 0: + domain->nstrings = W (domain->must_swap, data->nstrings); + domain->orig_tab = (struct string_desc *) + ((char *) data + W (domain->must_swap, data->orig_tab_offset)); + domain->trans_tab = (struct string_desc *) + ((char *) data + W (domain->must_swap, data->trans_tab_offset)); + domain->hash_size = W (domain->must_swap, data->hash_tab_size); + domain->hash_tab = (nls_uint32 *) + ((char *) data + W (domain->must_swap, data->hash_tab_offset)); + break; + default: + /* This is an illegal revision. */ +#if (defined HAVE_MMAP && defined HAVE_MUNMAP && !defined DISALLOW_MMAP) \ + || defined _LIBC + if (use_mmap) + munmap ((caddr_t) data, size); + else +#endif + free (data); + free (domain); + domain_file->data = NULL; + return; + } + + /* Show that one domain is changed. This might make some cached + translations invalid. */ + ++_nl_msg_cat_cntr; +} + + +#ifdef _LIBC +void +internal_function +_nl_unload_domain (domain) + struct loaded_domain *domain; +{ + if (domain->use_mmap) + munmap ((caddr_t) domain->data, domain->mmap_size); + else + free ((void *) domain->data); + + free (domain); +} +#endif diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/localealias.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/localealias.c new file mode 100644 index 0000000000..18cc68886b --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/localealias.c @@ -0,0 +1,424 @@ +/* Handle aliases for locale names. + Copyright (C) 1995, 1996, 1997, 1998 Free Software Foundation, Inc. + Written by Ulrich Drepper , 1995. + + 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + +#include +#include +#include + +#ifdef __GNUC__ +# define alloca __builtin_alloca +# define HAVE_ALLOCA 1 +#else +# if defined HAVE_ALLOCA_H || defined _LIBC +# include +# else +# ifdef _AIX + #pragma alloca +# else +# ifndef alloca +char *alloca (); +# endif +# endif +# endif +#endif + +#if defined STDC_HEADERS || defined _LIBC +# include +#else +char *getenv (); +# ifdef HAVE_MALLOC_H +# include +# else +void free (); +# endif +#endif + +#if defined HAVE_STRING_H || defined _LIBC +# ifndef _GNU_SOURCE +# define _GNU_SOURCE 1 +# endif +# include +#else +# include +# ifndef memcpy +# define memcpy(Dst, Src, Num) bcopy (Src, Dst, Num) +# endif +#endif +#if !HAVE_STRCHR && !defined _LIBC +# ifndef strchr +# define strchr index +# endif +#endif + +#include "gettext.h" +#include "gettextP.h" + +/* @@ end of prolog @@ */ + +#ifdef _LIBC +/* Rename the non ANSI C functions. This is required by the standard + because some ANSI C functions will require linking with this object + file and the name space must not be polluted. */ +# define strcasecmp __strcasecmp + +# define mempcpy __mempcpy +# define HAVE_MEMPCPY 1 + +/* We need locking here since we can be called from different places. */ +# include + +__libc_lock_define_initialized (static, lock); +#endif + + +/* For those loosing systems which don't have `alloca' we have to add + some additional code emulating it. */ +#ifdef HAVE_ALLOCA +/* Nothing has to be done. */ +# define ADD_BLOCK(list, address) /* nothing */ +# define FREE_BLOCKS(list) /* nothing */ +#else +struct block_list +{ + void *address; + struct block_list *next; +}; +# define ADD_BLOCK(list, addr) \ + do { \ + struct block_list *newp = (struct block_list *) malloc (sizeof (*newp)); \ + /* If we cannot get a free block we cannot add the new element to \ + the list. */ \ + if (newp != NULL) { \ + newp->address = (addr); \ + newp->next = (list); \ + (list) = newp; \ + } \ + } while (0) +# define FREE_BLOCKS(list) \ + do { \ + while (list != NULL) { \ + struct block_list *old = list; \ + list = list->next; \ + free (old); \ + } \ + } while (0) +# undef alloca +# define alloca(size) (malloc (size)) +#endif /* have alloca */ + + +struct alias_map +{ + const char *alias; + const char *value; +}; + + +static char *string_space = NULL; +static size_t string_space_act = 0; +static size_t string_space_max = 0; +static struct alias_map *map; +static size_t nmap = 0; +static size_t maxmap = 0; + + +/* Prototypes for local functions. */ +static size_t read_alias_file PARAMS ((const char *fname, int fname_len)) + internal_function; +static void extend_alias_table PARAMS ((void)); +static int alias_compare PARAMS ((const struct alias_map *map1, + const struct alias_map *map2)); + + +const char * +_nl_expand_alias (name) + const char *name; +{ + static const char *locale_alias_path = LOCALE_ALIAS_PATH; + struct alias_map *retval; + const char *result = NULL; + size_t added; + +#ifdef _LIBC + __libc_lock_lock (lock); +#endif + + do + { + struct alias_map item; + + item.alias = name; + + if (nmap > 0) + retval = (struct alias_map *) bsearch (&item, map, nmap, + sizeof (struct alias_map), + (int (*) PARAMS ((const void *, + const void *)) + ) alias_compare); + else + retval = NULL; + + /* We really found an alias. Return the value. */ + if (retval != NULL) + { + result = retval->value; + break; + } + + /* Perhaps we can find another alias file. */ + added = 0; + while (added == 0 && locale_alias_path[0] != '\0') + { + const char *start; + + while (locale_alias_path[0] == ':') + ++locale_alias_path; + start = locale_alias_path; + + while (locale_alias_path[0] != '\0' && locale_alias_path[0] != ':') + ++locale_alias_path; + + if (start < locale_alias_path) + added = read_alias_file (start, locale_alias_path - start); + } + } + while (added != 0); + +#ifdef _LIBC + __libc_lock_unlock (lock); +#endif + + return result; +} + + +static size_t +internal_function +read_alias_file (fname, fname_len) + const char *fname; + int fname_len; +{ +#ifndef HAVE_ALLOCA + struct block_list *block_list = NULL; +#endif + FILE *fp; + char *full_fname; + size_t added; + static const char aliasfile[] = "/locale.alias"; + + full_fname = (char *) alloca (fname_len + sizeof aliasfile); + ADD_BLOCK (block_list, full_fname); +#ifdef HAVE_MEMPCPY + mempcpy (mempcpy (full_fname, fname, fname_len), + aliasfile, sizeof aliasfile); +#else + memcpy (full_fname, fname, fname_len); + memcpy (&full_fname[fname_len], aliasfile, sizeof aliasfile); +#endif + + fp = fopen (full_fname, "r"); + if (fp == NULL) + { + FREE_BLOCKS (block_list); + return 0; + } + + added = 0; + while (!feof (fp)) + { + /* It is a reasonable approach to use a fix buffer here because + a) we are only interested in the first two fields + b) these fields must be usable as file names and so must not + be that long + */ + unsigned char buf[BUFSIZ]; + unsigned char *alias; + unsigned char *value; + unsigned char *cp; + + if (fgets (buf, sizeof buf, fp) == NULL) + /* EOF reached. */ + break; + + /* Possibly not the whole line fits into the buffer. Ignore + the rest of the line. */ + if (strchr (buf, '\n') == NULL) + { + char altbuf[BUFSIZ]; + do + if (fgets (altbuf, sizeof altbuf, fp) == NULL) + /* Make sure the inner loop will be left. The outer loop + will exit at the `feof' test. */ + break; + while (strchr (altbuf, '\n') == NULL); + } + + cp = buf; + /* Ignore leading white space. */ + while (isspace (cp[0])) + ++cp; + + /* A leading '#' signals a comment line. */ + if (cp[0] != '\0' && cp[0] != '#') + { + alias = cp++; + while (cp[0] != '\0' && !isspace (cp[0])) + ++cp; + /* Terminate alias name. */ + if (cp[0] != '\0') + *cp++ = '\0'; + + /* Now look for the beginning of the value. */ + while (isspace (cp[0])) + ++cp; + + if (cp[0] != '\0') + { + size_t alias_len; + size_t value_len; + + value = cp++; + while (cp[0] != '\0' && !isspace (cp[0])) + ++cp; + /* Terminate value. */ + if (cp[0] == '\n') + { + /* This has to be done to make the following test + for the end of line possible. We are looking for + the terminating '\n' which do not overwrite here. */ + *cp++ = '\0'; + *cp = '\n'; + } + else if (cp[0] != '\0') + *cp++ = '\0'; + + if (nmap >= maxmap) + extend_alias_table (); + + alias_len = strlen (alias) + 1; + value_len = strlen (value) + 1; + + if (string_space_act + alias_len + value_len > string_space_max) + { + /* Increase size of memory pool. */ + size_t new_size = (string_space_max + + (alias_len + value_len > 1024 + ? alias_len + value_len : 1024)); + char *new_pool = (char *) realloc (string_space, new_size); + if (new_pool == NULL) + { + FREE_BLOCKS (block_list); + return added; + } + string_space = new_pool; + string_space_max = new_size; + } + + map[nmap].alias = memcpy (&string_space[string_space_act], + alias, alias_len); + string_space_act += alias_len; + + map[nmap].value = memcpy (&string_space[string_space_act], + value, value_len); + string_space_act += value_len; + + ++nmap; + ++added; + } + } + } + + /* Should we test for ferror()? I think we have to silently ignore + errors. --drepper */ + fclose (fp); + + if (added > 0) + qsort (map, nmap, sizeof (struct alias_map), + (int (*) PARAMS ((const void *, const void *))) alias_compare); + + FREE_BLOCKS (block_list); + return added; +} + + +static void +extend_alias_table () +{ + size_t new_size; + struct alias_map *new_map; + + new_size = maxmap == 0 ? 100 : 2 * maxmap; + new_map = (struct alias_map *) realloc (map, (new_size + * sizeof (struct alias_map))); + if (new_map == NULL) + /* Simply don't extend: we don't have any more core. */ + return; + + map = new_map; + maxmap = new_size; +} + + +#ifdef _LIBC +static void __attribute__ ((unused)) +free_mem (void) +{ + if (string_space != NULL) + free (string_space); + if (map != NULL) + free (map); +} +text_set_element (__libc_subfreeres, free_mem); +#endif + + +static int +alias_compare (map1, map2) + const struct alias_map *map1; + const struct alias_map *map2; +{ +#if defined _LIBC || defined HAVE_STRCASECMP + return strcasecmp (map1->alias, map2->alias); +#else + const unsigned char *p1 = (const unsigned char *) map1->alias; + const unsigned char *p2 = (const unsigned char *) map2->alias; + unsigned char c1, c2; + + if (p1 == p2) + return 0; + + do + { + /* I know this seems to be odd but the tolower() function in + some systems libc cannot handle nonalpha characters. */ + c1 = isupper (*p1) ? tolower (*p1) : *p1; + c2 = isupper (*p2) ? tolower (*p2) : *p2; + if (c1 == '\0') + break; + ++p1; + ++p2; + } + while (c1 == c2); + + return c1 - c2; +#endif +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/po2tbl.sed.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/po2tbl.sed.in new file mode 100644 index 0000000000..b3bcca4d73 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/po2tbl.sed.in @@ -0,0 +1,102 @@ +# po2tbl.sed - Convert Uniforum style .po file to lookup table for catgets +# Copyright (C) 1995 Free Software Foundation, Inc. +# Ulrich Drepper , 1995. +# +# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +# +1 { + i\ +/* Automatically generated by po2tbl.sed from @PACKAGE NAME@.pot. */\ +\ +#if HAVE_CONFIG_H\ +# include \ +#endif\ +\ +#include "libgettext.h"\ +\ +const struct _msg_ent _msg_tbl[] = { + h + s/.*/0/ + x +} +# +# Write msgid entries in C array form. +# +/^msgid/ { + s/msgid[ ]*\(".*"\)/ {\1/ + tb +# Append the next line + :b + N +# Look whether second part is continuation line. + s/\(.*\)"\(\n\)"\(.*"\)/\1\2\3/ +# Yes, then branch. + ta +# Because we assume that the input file correctly formed the line +# just read cannot be again be a msgid line. So it's safe to ignore +# it. + s/\(.*\)\n.*/\1/ + bc +# We found a continuation line. But before printing insert '\'. + :a + s/\(.*\)\(\n.*\)/\1\\\2/ + P +# We cannot use D here. + s/.*\n\(.*\)/\1/ +# Some buggy seds do not clear the `successful substitution since last ``t''' +# flag on `N', so we do a `t' here to clear it. + tb +# Not reached + :c + x +# The following nice solution is by +# Bruno + td +# Increment a decimal number in pattern space. +# First hide trailing `9' digits. + :d + s/9\(_*\)$/_\1/ + td +# Assure at least one digit is available. + s/^\(_*\)$/0\1/ +# Increment the last digit. + s/8\(_*\)$/9\1/ + s/7\(_*\)$/8\1/ + s/6\(_*\)$/7\1/ + s/5\(_*\)$/6\1/ + s/4\(_*\)$/5\1/ + s/3\(_*\)$/4\1/ + s/2\(_*\)$/3\1/ + s/1\(_*\)$/2\1/ + s/0\(_*\)$/1\1/ +# Convert the hidden `9' digits to `0's. + s/_/0/g + x + G + s/\(.*\)\n\([0-9]*\)/\1, \2},/ + s/\(.*\)"$/\1/ + p +} +# +# Last line. +# +$ { + i\ +};\ + + g + s/0*\(.*\)/int _msg_tbl_length = \1;/p +} +d diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/textdomain.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/textdomain.c new file mode 100644 index 0000000000..2e8facb1f8 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/textdomain.c @@ -0,0 +1,108 @@ +/* Implementation of the textdomain(3) function. + Copyright (C) 1995, 1996, 1997, 1998 Free Software Foundation, Inc. + Written by Ulrich Drepper , 1995. + + 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +#ifdef HAVE_CONFIG_H +# include +#endif + +#if defined STDC_HEADERS || defined _LIBC +# include +#endif + +#if defined STDC_HEADERS || defined HAVE_STRING_H || defined _LIBC +# include +#else +# include +# ifndef memcpy +# define memcpy(Dst, Src, Num) bcopy (Src, Dst, Num) +# endif +#endif + +#ifdef _LIBC +# include +#else +# include "libgettext.h" +#endif + +/* @@ end of prolog @@ */ + +/* Name of the default text domain. */ +extern const char _nl_default_default_domain[]; + +/* Default text domain in which entries for gettext(3) are to be found. */ +extern const char *_nl_current_default_domain; + + +/* Names for the libintl functions are a problem. They must not clash + with existing names and they should follow ANSI C. But this source + code is also used in GNU C Library where the names have a __ + prefix. So we have to make a difference here. */ +#ifdef _LIBC +# define TEXTDOMAIN __textdomain +# ifndef strdup +# define strdup(str) __strdup (str) +# endif +#else +# define TEXTDOMAIN textdomain__ +#endif + +/* Set the current default message catalog to DOMAINNAME. + If DOMAINNAME is null, return the current default. + If DOMAINNAME is "", reset to the default of "messages". */ +char * +TEXTDOMAIN (domainname) + const char *domainname; +{ + char *old; + + /* A NULL pointer requests the current setting. */ + if (domainname == NULL) + return (char *) _nl_current_default_domain; + + old = (char *) _nl_current_default_domain; + + /* If domain name is the null string set to default domain "messages". */ + if (domainname[0] == '\0' + || strcmp (domainname, _nl_default_default_domain) == 0) + _nl_current_default_domain = _nl_default_default_domain; + else + { + /* If the following malloc fails `_nl_current_default_domain' + will be NULL. This value will be returned and so signals we + are out of core. */ +#if defined _LIBC || defined HAVE_STRDUP + _nl_current_default_domain = strdup (domainname); +#else + size_t len = strlen (domainname) + 1; + char *cp = (char *) malloc (len); + if (cp != NULL) + memcpy (cp, domainname, len); + _nl_current_default_domain = cp; +#endif + } + + if (old != _nl_default_default_domain) + free (old); + + return (char *) _nl_current_default_domain; +} + +#ifdef _LIBC +/* Alias for function name in GNU C Library. */ +weak_alias (__textdomain, textdomain); +#endif diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/xopen-msg.sed b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/xopen-msg.sed new file mode 100644 index 0000000000..b19c0bbd0e --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/intl/xopen-msg.sed @@ -0,0 +1,104 @@ +# po2msg.sed - Convert Uniforum style .po file to X/Open style .msg file +# Copyright (C) 1995 Free Software Foundation, Inc. +# Ulrich Drepper , 1995. +# +# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +# +# +# The first directive in the .msg should be the definition of the +# message set number. We use always set number 1. +# +1 { + i\ +$set 1 # Automatically created by po2msg.sed + h + s/.*/0/ + x +} +# +# We copy all comments into the .msg file. Perhaps they can help. +# +/^#/ s/^#[ ]*/$ /p +# +# We copy the original message as a comment into the .msg file. +# +/^msgid/ { +# Does not work now +# /"$/! { +# s/\\$// +# s/$/ ... (more lines following)"/ +# } + s/^msgid[ ]*"\(.*\)"$/$ Original Message: \1/ + p +} +# +# The .msg file contains, other then the .po file, only the translations +# but each given a unique ID. Starting from 1 and incrementing by 1 for +# each message we assign them to the messages. +# It is important that the .po file used to generate the cat-id-tbl.c file +# (with po-to-tbl) is the same as the one used here. (At least the order +# of declarations must not be changed.) +# +/^msgstr/ { + s/msgstr[ ]*"\(.*\)"/\1/ + x +# The following nice solution is by +# Bruno + td +# Increment a decimal number in pattern space. +# First hide trailing `9' digits. + :d + s/9\(_*\)$/_\1/ + td +# Assure at least one digit is available. + s/^\(_*\)$/0\1/ +# Increment the last digit. + s/8\(_*\)$/9\1/ + s/7\(_*\)$/8\1/ + s/6\(_*\)$/7\1/ + s/5\(_*\)$/6\1/ + s/4\(_*\)$/5\1/ + s/3\(_*\)$/4\1/ + s/2\(_*\)$/3\1/ + s/1\(_*\)$/2\1/ + s/0\(_*\)$/1\1/ +# Convert the hidden `9' digits to `0's. + s/_/0/g + x +# Bring the line in the format ` ' + G + s/^[^\n]*$/& / + s/\(.*\)\n\([0-9]*\)/\2 \1/ +# Clear flag from last substitution. + tb +# Append the next line. + :b + N +# Look whether second part is a continuation line. + s/\(.*\n\)"\(.*\)"/\1\2/ +# Yes, then branch. + ta + P + D +# Note that `D' includes a jump to the start!! +# We found a continuation line. But before printing insert '\'. + :a + s/\(.*\)\(\n.*\)/\1\\\2/ + P +# We cannot use the sed command `D' here + s/.*\n\(.*\)/\1/ + tb +} +d diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/Makefile.in.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/Makefile.in.in new file mode 100644 index 0000000000..629f3d4b46 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/Makefile.in.in @@ -0,0 +1,250 @@ +# Makefile for program source directory in GNU NLS utilities package. +# Copyright (C) 1995, 1996, 1997 by Ulrich Drepper +# +# This file file be copied and used freely without restrictions. It can +# be used in projects which are not available under the GNU Public License +# but which still want to provide support for the GNU gettext functionality. +# Please note that the actual code is *not* freely available. + +PACKAGE = @PACKAGE@ +VERSION = @VERSION@ + +DESTDIR = + +SHELL = /bin/sh +@SET_MAKE@ + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ + +prefix = $(DESTDIR)@prefix@ +exec_prefix = @exec_prefix@ +datadir = $(prefix)/@DATADIRNAME@ +localedir = $(datadir)/locale +gnulocaledir = $(prefix)/share/locale +gettextsrcdir = $(prefix)/share/gettext/po +subdir = po + +INSTALL = @INSTALL@ +INSTALL_DATA = @INSTALL_DATA@ +MKINSTALLDIRS = ../scripts/mkinstalldirs + +CC = @CC@ +GENCAT = @GENCAT@ +GMSGFMT = PATH=../src:$$PATH @GMSGFMT@ +MSGFMT = @MSGFMT@ +XGETTEXT = PATH=../src:$$PATH @XGETTEXT@ +MSGMERGE = PATH=../src:$$PATH msgmerge + +DEFS = @DEFS@ +CFLAGS = @CFLAGS@ +CPPFLAGS = @CPPFLAGS@ + +INCLUDES = -I.. -I$(top_srcdir)/intl + +COMPILE = $(CC) -c $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS) + +SOURCES = cat-id-tbl.c +POFILES = @POFILES@ +GMOFILES = @GMOFILES@ +DISTFILES = Makefile.in.in POTFILES.in $(PACKAGE).pot \ +stamp-cat-id $(POFILES) $(GMOFILES) $(SOURCES) + +POTFILES = \ + +CATALOGS = @CATALOGS@ +CATOBJEXT = @CATOBJEXT@ +INSTOBJEXT = @INSTOBJEXT@ + +.SUFFIXES: +.SUFFIXES: .c .o .po .pox .gmo .mo .msg .cat + +.c.o: + $(COMPILE) $< + +.po.pox: + $(MAKE) $(PACKAGE).pot + $(MSGMERGE) $< $(srcdir)/$(PACKAGE).pot -o $*.pox + +.po.mo: + $(MSGFMT) -o $@ $< + +.po.gmo: + file=$(srcdir)/`echo $* | sed 's,.*/,,'`.gmo \ + && rm -f $$file && $(GMSGFMT) -o $$file $< + +.po.cat: + sed -f ../intl/po2msg.sed < $< > $*.msg \ + && rm -f $@ && $(GENCAT) $@ $*.msg + + +all: all-@USE_NLS@ + +all-yes: cat-id-tbl.c $(CATALOGS) +all-no: + +$(srcdir)/$(PACKAGE).pot: $(POTFILES) + $(XGETTEXT) --default-domain=$(PACKAGE) --directory=$(top_srcdir) \ + --add-comments --keyword=_ --keyword=N_ \ + --files-from=$(srcdir)/POTFILES.in \ + && test ! -f $(PACKAGE).po \ + || ( rm -f $(srcdir)/$(PACKAGE).pot \ + && mv $(PACKAGE).po $(srcdir)/$(PACKAGE).pot ) + +$(srcdir)/cat-id-tbl.c: stamp-cat-id; @: +$(srcdir)/stamp-cat-id: $(PACKAGE).pot + rm -f cat-id-tbl.tmp + sed -f ../intl/po2tbl.sed $(srcdir)/$(PACKAGE).pot \ + | sed -e "s/@PACKAGE NAME@/$(PACKAGE)/" > cat-id-tbl.tmp + if cmp -s cat-id-tbl.tmp $(srcdir)/cat-id-tbl.c; then \ + rm cat-id-tbl.tmp; \ + else \ + echo cat-id-tbl.c changed; \ + rm -f $(srcdir)/cat-id-tbl.c; \ + mv cat-id-tbl.tmp $(srcdir)/cat-id-tbl.c; \ + fi + cd $(srcdir) && rm -f stamp-cat-id && echo timestamp > stamp-cat-id + + +install: install-exec install-data +install-exec: +install-data: install-data-@USE_NLS@ +install-data-no: all +install-data-yes: all + if test -r "$(MKINSTALLDIRS)"; then \ + $(MKINSTALLDIRS) $(datadir); \ + else \ + $(SHELL) ../scripts/mkinstalldirs $(datadir); \ + fi + @catalogs='$(CATALOGS)'; \ + for cat in $$catalogs; do \ + cat=`basename $$cat`; \ + case "$$cat" in \ + *.gmo) destdir=$(gnulocaledir);; \ + *) destdir=$(localedir);; \ + esac; \ + lang=`echo $$cat | sed 's/\$(CATOBJEXT)$$//'`; \ + dir=$$destdir/$$lang/LC_MESSAGES; \ + if test -r "$(MKINSTALLDIRS)"; then \ + $(MKINSTALLDIRS) $$dir; \ + else \ + $(SHELL) ../scripts/mkinstalldirs $$dir; \ + fi; \ + if test -r $$cat; then \ + $(INSTALL_DATA) $$cat $$dir/$(PACKAGE)$(INSTOBJEXT); \ + echo "installing $$cat as $$dir/$(PACKAGE)$(INSTOBJEXT)"; \ + else \ + $(INSTALL_DATA) $(srcdir)/$$cat $$dir/$(PACKAGE)$(INSTOBJEXT); \ + echo "installing $(srcdir)/$$cat as" \ + "$$dir/$(PACKAGE)$(INSTOBJEXT)"; \ + fi; \ + if test -r $$cat.m; then \ + $(INSTALL_DATA) $$cat.m $$dir/$(PACKAGE)$(INSTOBJEXT).m; \ + echo "installing $$cat.m as $$dir/$(PACKAGE)$(INSTOBJEXT).m"; \ + else \ + if test -r $(srcdir)/$$cat.m ; then \ + $(INSTALL_DATA) $(srcdir)/$$cat.m \ + $$dir/$(PACKAGE)$(INSTOBJEXT).m; \ + echo "installing $(srcdir)/$$cat as" \ + "$$dir/$(PACKAGE)$(INSTOBJEXT).m"; \ + else \ + true; \ + fi; \ + fi; \ + done + if test "$(PACKAGE)" = "gettext"; then \ + if test -r "$(MKINSTALLDIRS)"; then \ + $(MKINSTALLDIRS) $(gettextsrcdir); \ + else \ + $(SHELL) ../scripts/mkinstalldirs $(gettextsrcdir); \ + fi; \ + $(INSTALL_DATA) $(srcdir)/Makefile.in.in \ + $(gettextsrcdir)/Makefile.in.in; \ + else \ + : ; \ + fi + +# Define this as empty until I found a useful application. +installcheck: + +uninstall: + catalogs='$(CATALOGS)'; \ + for cat in $$catalogs; do \ + cat=`basename $$cat`; \ + lang=`echo $$cat | sed 's/\$(CATOBJEXT)$$//'`; \ + rm -f $(localedir)/$$lang/LC_MESSAGES/$(PACKAGE)$(INSTOBJEXT); \ + rm -f $(localedir)/$$lang/LC_MESSAGES/$(PACKAGE)$(INSTOBJEXT).m; \ + rm -f $(gnulocaledir)/$$lang/LC_MESSAGES/$(PACKAGE)$(INSTOBJEXT); \ + rm -f $(gnulocaledir)/$$lang/LC_MESSAGES/$(PACKAGE)$(INSTOBJEXT).m; \ + done + rm -f $(gettextsrcdir)/po-Makefile.in.in + +check: all + +cat-id-tbl.o: ../intl/libgettext.h + +dvi info tags TAGS ID: + +mostlyclean: + rm -f core core.* *.pox $(PACKAGE).po *.old.po cat-id-tbl.tmp + rm -fr *.o + +clean: mostlyclean + +distclean: clean + rm -f Makefile Makefile.in POTFILES *.mo *.msg *.cat *.cat.m + +maintainer-clean: distclean + @echo "This command is intended for maintainers to use;" + @echo "it deletes files that may require special tools to rebuild." + rm -f $(GMOFILES) + +distdir = ../$(PACKAGE)-$(VERSION)/$(subdir) +dist distdir: update-po $(DISTFILES) + dists="$(DISTFILES)"; \ + for file in $$dists; do \ + ln $(srcdir)/$$file $(distdir) 2> /dev/null \ + || cp -p $(srcdir)/$$file $(distdir) || echo ignore; \ + done + +update-po: Makefile + $(MAKE) $(PACKAGE).pot + PATH=`pwd`/../src:$$PATH; \ + cd $(srcdir); \ + catalogs='$(CATALOGS)'; \ + for cat in $$catalogs; do \ + cat=`basename $$cat`; \ + lang=`echo $$cat | sed 's/\$(CATOBJEXT)$$//'`; \ + mv $$lang.po $$lang.old.po; \ + echo "$$lang:"; \ + if $(MSGMERGE) $$lang.old.po $(PACKAGE).pot -o $$lang.po; then \ + rm -f $$lang.old.po; \ + else \ + echo "msgmerge for $$cat failed!"; \ + rm -f $$lang.po; \ + mv $$lang.old.po $$lang.po; \ + fi; \ + done + +POTFILES: POTFILES.in + ( if test 'x$(srcdir)' != 'x.'; then \ + posrcprefix='$(top_srcdir)/'; \ + else \ + posrcprefix="../"; \ + fi; \ + rm -f $@-t $@ \ + && (sed -e '/^#/d' -e '/^[ ]*$$/d' \ + -e "s@.*@ $$posrcprefix& \\\\@" < $(srcdir)/$@.in \ + | sed -e '$$s/\\$$//') > $@-t \ + && chmod a-w $@-t \ + && mv $@-t $@ ) + +Makefile: Makefile.in.in ../config.status POTFILES + cd .. \ + && CONFIG_FILES=$(subdir)/$@.in CONFIG_HEADERS= \ + $(SHELL) ./config.status + +# Tell versions [3.59,3.63) of GNU make not to export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/POTFILES.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/POTFILES.in new file mode 100644 index 0000000000..8b9106da56 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/POTFILES.in @@ -0,0 +1,19 @@ +apps/gsmsmsd.cc +apps/gsmsendsms.cc +apps/gsmpb.cc +apps/gsmctl.cc +apps/gsmsmsstore.cc +gsmlib/gsm_at.cc +gsmlib/gsm_error.cc +gsmlib/gsm_event.cc +gsmlib/gsm_me_ta.cc +gsmlib/gsm_nls.cc +gsmlib/gsm_parser.cc +gsmlib/gsm_phonebook.cc +gsmlib/gsm_sms.cc +gsmlib/gsm_sms_codec.cc +gsmlib/gsm_sms_store.cc +gsmlib/gsm_unix_serial.cc +gsmlib/gsm_util.cc +gsmlib/gsm_sorted_phonebook.cc +gsmlib/gsm_sorted_sms_store.cc diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/cat-id-tbl.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/cat-id-tbl.c new file mode 100644 index 0000000000..e69de29bb2 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/de.gmo b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/de.gmo new file mode 100644 index 0000000000000000000000000000000000000000..7ac755ac73d7810320dafa6fbb64875a20636f6e GIT binary patch literal 34591 zcmb`P34moqb@wkI0t3n>t0I?yVR~fVY`_4++B4Gw4bwBjbPpoqC~vvl@6oT{Yu++T zi*bvID;kx!izdXl;gUp+iTh_34M+?oYBbRg=hMWvB+-aOO!E7ms=D{Sr2#+lpyq#X z-C9qbI_K1>s{Y3l9(PB?uYE`qJq7%uqoe4@Ja0Wku~BsDnNc(fo(5h3?glRgUk$DT zKkwgv2Cn6OZ5&1Cfn`wNUj-`PC&4w~kHHpr&RJ1Z1z!(d2}Vm@x~sqqymrC$;0M74 z@VnqGVCig^?_Th7-q)Yw>g|9dyuTA%4&DbU|AXKGaMiLXS^>TbY=VCSt^_xp8$|`M z2^PV(f@<%7gS){CC`{>I4bFg{0B6BvRHpdf0xtwV3Em0*1bjUBIx0IHd^7k&@Ezch z;0M9uz>k5)f?oiS0RJ959ee=%8u$xP<$vXA&Ro=Hjwf7ejZf%Z-FZB=b+kg3`9N#JQX}1Tn18QbP;$ySOrf7-{Rjt44%gO zKZ9z|VI&frPXW&W*Mn-`6!--2*&ss@&4Fsqo4_Z79|AQG?*-MK$HTNIf~SB=e;%lM zZuHm!W8Pl@o(bL!s$KW`_wRsK4$Q2ne+nr2tp=Y2UJ0H6PJuBv1FHO&`0u|1s=Xft zHI9D*)f-(4fQ1!k8ycYZjsQw)SbDj*I1d8q} zL8eG_35bY@D&Se*Z~FIlgKF13pv^N-fet+r91u-$45&+m3KL)er)malc4f7K-GIY zDE|0eQ29R#s-O3RyTG4<>hIPKj&2Q5`CkQ!Uq1kz27UoN1w06fza9oPK1W>Yp_)M21WN5fy)1SQ29Opo(g^z)V%q+fBzY%bjM%j;#Yv`#}@E(a5t#@dqMU4 zrJ&0BZBX@p02CcR1ByO>1!~;B3?f>hZ+KjS@RwY?7*zT_9%n$+b1NwM^a@bvJ_2f9 zd>uq2MMqxYbnhm3it;9{$Wu4 z`4TAlNLj0&t3cJe8#H==qW3F6&4)LF>d)_kqW_(^A$}jRC_-N*1&tf>%sM7j-D?8r3Zfx z)VRG5RQo>xiZ1^IYQ8@RsvU=Iar9XVs@`>=+CK%J3C@BVrcK}(|h2C@x>T;B)H4tvp~(?8Bp~f z0M*~$0>xiQBYv0yx6^tHJBQkAdp{;k>Aw zBcR%SIVgU=3A_mGf~xOsQ00CORDZt*ivCA#b@iMBYTj%BHJ&q|`tefm2=E=C+VgHu z^!pU3^6mxC27m0|PnmG-x*Sx!H-oBgA1M0X0jhm>fhzw~;L+e$K(+td;5lHl&CRQ2 zp!j79d;-`2pLz�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\n" +"Language-Team: Peter Hofmann\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=ISO-8859-15\n" +"Content-Transfer-Encoding: 8bit\n" + +# , c-format +#: apps/gsmsmsd.cc:164 +#, c-format +msgid "could not execute '%s'" +msgstr "konnte '%s' nicht ausführen" + +# , c-format +#: apps/gsmsmsd.cc:168 +#, c-format +msgid "error writing to '%s'" +msgstr "Fehler beim Schreiben zu '%s'" + +# , c-format +#: apps/gsmsmsd.cc:196 +#, c-format +msgid "error when calling opendir('%s')(errno: %d/%s)" +msgstr "Fehler beim Aufruf von opendir('%s') (errno: %d/%s)" + +# , c-format +#: apps/gsmsmsd.cc:225 +#, c-format +msgid "count not open SMS spool file %s" +msgstr "kann SMS Spool-Datei '%s' nicht öffnen" + +# , c-format +#: apps/gsmsmsd.cc:341 apps/gsmsendsms.cc:144 apps/gsmpb.cc:311 +#: apps/gsmctl.cc:380 apps/gsmsmsstore.cc:179 +#, c-format +msgid ": version %s [compiled %s]" +msgstr ": Version %s [kompiliert am %s]" + +#: apps/gsmsmsd.cc:346 +msgid "" +": [-a action][-b baudrate][-C sca][-d device][-f][-h][-I init string]\n" +" [-s spool dir][-t][-v]{sms_type}" +msgstr "" +": [-a Aktion][-b Baud-Rate][-C sca][-d Gerät][-f][-h][-I Init String]\n" +" [-s Spoolverzeichnis][-t][-v]{SMS-Typ}" + +#: apps/gsmsmsd.cc:350 +msgid "" +" -a, --action the action to execute when an SMS arrives\n" +" (SMS is send to stdin of action)" +msgstr "" +" -a, --action die auszuführende Aktion, wenn eine SMS eintrifft\n" +" (Kurznachricht wird zur Standardeingabe der Aktion\n" +" geschrieben)" + +#: apps/gsmsmsd.cc:354 apps/gsmsendsms.cc:153 apps/gsmpb.cc:322 +#: apps/gsmctl.cc:389 apps/gsmsmsstore.cc:194 +msgid " -b, --baudrate baudrate to use for device (default: 38400)" +msgstr "" +" -b, --baudrate für das Gerät zu verwendende Baud-Rate\n" +" (Voreinstellung: 38400)" + +#: apps/gsmsmsd.cc:357 +msgid " -c, --concatenate start ID for concatenated SMS messages" +msgstr " -c, --concatenate Start-ID für verbundene SMS-Nachrichten" + +#: apps/gsmsmsd.cc:359 apps/gsmsendsms.cc:158 apps/gsmsmsstore.cc:200 +msgid " -C, --sca SMS service centre address" +msgstr " -C, --sca SMS service centre address" + +#: apps/gsmsmsd.cc:360 +msgid " -d, --device sets the device to connect to" +msgstr " -d, --device stellt das Ziel-Gerät ein" + +#: apps/gsmsmsd.cc:361 +msgid " -D, --direct enable direct routing of SMSs" +msgstr "" +" -D, --direct direkte Weiterleitung von SMSs ohne Zwischenspeicherung" + +#: apps/gsmsmsd.cc:362 +msgid " -f, --flush flush SMS from store" +msgstr " -f, --flush lösche und bearbeite SMS im Speicher" + +#: apps/gsmsmsd.cc:363 apps/gsmsendsms.cc:161 apps/gsmpb.cc:332 +#: apps/gsmctl.cc:394 apps/gsmsmsstore.cc:204 +msgid " -h, --help prints this message" +msgstr " -h, --help gibt diesen Hilfetext aus" + +#: apps/gsmsmsd.cc:364 apps/gsmsendsms.cc:162 apps/gsmpb.cc:335 +#: apps/gsmctl.cc:395 apps/gsmsmsstore.cc:205 +msgid " -I, --init device AT init sequence" +msgstr " -I, --init AT-Initialisierungssequenz" + +#: apps/gsmsmsd.cc:365 apps/gsmsendsms.cc:163 +msgid " -r, --requeststat request SMS status report" +msgstr " -r, --requeststat fordert SMS-Statusreport an" + +#: apps/gsmsmsd.cc:366 +msgid " -s, --spool spool directory for outgoing SMS" +msgstr " -s, --spool Spool-Verzeichnis für zu sendende SMS" + +#: apps/gsmsmsd.cc:368 +msgid "" +" -t, --store name of SMS store to use for flush\n" +" and/or temporary SMS storage" +msgstr "" +" -t, --store gibt den zu verwendenden SMS-Speicher an (für flush-\n" +" Option und/oder temporären SMS-Speicher)" + +#: apps/gsmsmsd.cc:371 apps/gsmsendsms.cc:167 apps/gsmpb.cc:343 +#: apps/gsmctl.cc:399 apps/gsmsmsstore.cc:213 +msgid " -v, --version prints version and exits" +msgstr " -v, --version gibt Versionsnummer aus und terminiert" + +#: apps/gsmsmsd.cc:372 apps/gsmsendsms.cc:169 apps/gsmpb.cc:346 +#: apps/gsmctl.cc:400 apps/gsmsmsstore.cc:218 +msgid " -X, --xonxoff switch on software handshake" +msgstr " -X, --xonxoff Software Handshake anschalten" + +#: apps/gsmsmsd.cc:374 +msgid " sms_type may be any combination of" +msgstr " SMS-Typ kann aus den folgenden Parametern kombiniert werden:" + +#: apps/gsmsmsd.cc:375 +msgid " sms, no_sms controls reception of normal SMS" +msgstr " sms, no_sms schaltet Empfang von normalen SMS an bzw. aus" + +#: apps/gsmsmsd.cc:377 +msgid " cb, no_cb controls reception of cell broadcast messages" +msgstr "" +" cb, no_cb schaltet Empfang von Zellen-weiten Nachrichten an bzw. " +"aus" + +#: apps/gsmsmsd.cc:379 +msgid " stat, no_stat controls reception of status reports" +msgstr " stat, no_stat schaltet Empfang von Status-Reports an bzw. aus" + +#: apps/gsmsmsd.cc:381 +msgid " default is \"sms cb stat\"" +msgstr " Die Voreinstellung ist \"sms cb stat\"." + +#: apps/gsmsmsd.cc:382 +msgid "If no action is given, the SMS is printed to stdout" +msgstr "" +"Wenn keine Aktion angegeben ist, wird die SMS auf der Standardausgabe\n" +"angezeigt." + +#: apps/gsmsmsd.cc:387 apps/gsmsendsms.cc:178 apps/gsmpb.cc:354 +#: apps/gsmctl.cc:414 apps/gsmsmsstore.cc:223 +msgid "unknown option" +msgstr "unbekannte Option" + +# , c-format +#: apps/gsmsmsd.cc:426 +#, c-format +msgid "error when calling sigaction() (errno: %d/%s)" +msgstr "Fehler beim Aufruf von sigaction() (errno: %d/%s)" + +#: apps/gsmsmsd.cc:446 +msgid "store name must be given for flush option" +msgstr "Speichername muß angegeben werden für flush-Option" + +#. process the new message +#: apps/gsmsmsd.cc:454 apps/gsmsmsd.cc:522 +msgid "Type of message: " +msgstr "Typ der Nachricht: " + +#: apps/gsmsmsd.cc:458 apps/gsmsmsd.cc:526 +msgid "SMS message\n" +msgstr "SMS Nachricht\n" + +#: apps/gsmsmsd.cc:461 +msgid "submit report message\n" +msgstr "Submit-Report-Nachricht\n" + +#: apps/gsmsmsd.cc:464 apps/gsmsmsd.cc:532 +msgid "status report message\n" +msgstr "Status-Report-Nachricht\n" + +#: apps/gsmsmsd.cc:529 +msgid "cell broadcast message\n" +msgstr "Zellen-weite Nachricht\n" + +#: apps/gsmsmsd.cc:585 apps/gsmsmsd.cc:587 apps/gsmsendsms.cc:253 +#: apps/gsmpb.cc:503 apps/gsmctl.cc:631 apps/gsmsmsstore.cc:435 +msgid "[ERROR]: " +msgstr "[FEHLER]: " + +#: apps/gsmsmsd.cc:588 +msgid "(try setting sms_type, please refer to gsmsmsd manpage)" +msgstr "" +"(versuchen Sie, den sms_type zu setzen; siehe auch gsmsmsd Manual-Seite)" + +#: apps/gsmsendsms.cc:149 +msgid "" +": [-b baudrate][-c concatenatedID][-C sca][-d device][-h][-I init string]\n" +" [-t][-v][-X] phonenumber [text]" +msgstr "" +": [-b Baud-Rate][-c concatenatedID][-C sca][-d Gerät][-h][-I Init String]\n" +" [-t][-v][-X] Telefonnummer [Text]" + +#: apps/gsmsendsms.cc:156 +msgid " -c, --concatenate ID for concatenated SMS messages" +msgstr " -c, --concatenate ID für verbundene SMS-Nachrichten" + +#: apps/gsmsendsms.cc:159 apps/gsmctl.cc:392 +msgid " -d, --device sets the destination device to connect to" +msgstr " -d, --device stellt das Ziel-Gerät ein" + +#: apps/gsmsendsms.cc:164 +msgid "" +" -t, --test convert text to GSM alphabet and vice\n" +" versa, no SMS message is sent" +msgstr "" +" -t, --test konvertiert den Text in das GSM-Alphabet und\n" +" wieder zurück. Es wird keine SMS-Nachricht versendet." + +#: apps/gsmsendsms.cc:171 +msgid " phonenumber recipient's phone number" +msgstr " Telefonummer die Telefonnummer des Empfängers" + +#: apps/gsmsendsms.cc:172 +msgid "" +" text optional text of the SMS message\n" +" if omitted: read from stdin" +msgstr "" +" text Text der SMS-Nachricht (optional),\n" +" wenn nicht angegeben: lese von der Standardeingabe" + +#: apps/gsmsendsms.cc:205 +msgid "phone number and text missing" +msgstr "weder Telefonnummer noch Text angegeben" + +#: apps/gsmsendsms.cc:208 apps/gsmsmsstore.cc:261 +msgid "more than two parameters given" +msgstr "mehr als zwei Parameter angegeben" + +#: apps/gsmsendsms.cc:224 +msgid "text is larger than 160 characters" +msgstr "der Text ist länger als 160 Zeichen" + +# , c-format +#: apps/gsmpb.cc:102 apps/gsmpb.cc:491 +#, c-format +msgid "inserting '%s' tel# %s" +msgstr "füge ein '%s' Tel# %s" + +# , c-format +#: apps/gsmpb.cc:105 apps/gsmpb.cc:230 apps/gsmpb.cc:494 +#, c-format +msgid " (index #%d)" +msgstr " (Index #%d)" + +# , c-format +#: apps/gsmpb.cc:144 +#, c-format +msgid "updating '%s' tel# %s to new tel# %s" +msgstr "überschreibe '%s' Tel# %s mit neuer Tel# %s" + +# , c-format +#: apps/gsmpb.cc:177 +#, c-format +msgid "updating '%s' tel# %s to new tel# %s(index %d)" +msgstr "überschreibe '%s' Tel# %s mit neuer Tel# %s (Index %d)" + +# , c-format +#: apps/gsmpb.cc:227 +#, c-format +msgid "deleting '%s' tel# %s" +msgstr "lösche '%s' Tel# %s" + +#: apps/gsmpb.cc:316 +msgid "" +": [-b baudrate][-c][-d device or file][-h][-I init string]\n" +" [-p phonebook name][-s device or file][-t charset][-v][-V][-y][-X]" +msgstr "" +": [-b Baud-Rate][-c][-d Gerät oder Datei][-h][-I Init String]\n" +" [-p Telefonbuchname][-s Gerät oder Datei][-t Zeichensatz][-v][-V][-y][-X]" + +#: apps/gsmpb.cc:325 +msgid " -c, --copy copy source entries to destination" +msgstr " -c, --copy kopiere Quell-Einträge zum Zielgerät/-datei" + +#: apps/gsmpb.cc:327 +msgid "" +" -d, --destination sets the destination device to connect \n" +" to, or the file to write" +msgstr " -d, --destination setzt das Zielgerät bzw. die Zieldatei" + +#: apps/gsmpb.cc:330 +msgid " -D, --destination-backend sets the destination backend" +msgstr " -D, --destination-backend stellt den Typ des Ziel-Backends ein" + +#: apps/gsmpb.cc:333 +msgid " -i, --index takes index positions into account" +msgstr " -i, --index berücksichtige die Indexpositionen der Einträge" + +#: apps/gsmpb.cc:336 +msgid " -p, --phonebook name of phonebook to use" +msgstr " -p, --phonebook Name des zu verwendenden Telefonbuchs" + +#: apps/gsmpb.cc:337 apps/gsmsmsstore.cc:210 +msgid "" +" -s, --source sets the source device to connect to,\n" +" or the file to read" +msgstr " -s, --source setzt das Quellgerät bzw. die Quelldatei" + +#: apps/gsmpb.cc:339 +msgid "" +" -t, --charset sets the character set to use for\n" +" phonebook entries" +msgstr " -t, --charset setzt den Zeichensatz für Telefonbucheinträge" + +#: apps/gsmpb.cc:341 +msgid " -S, --source-backend sets the source backend" +msgstr " -S, --source-backend stellt den Typ des Ziel-Backends ein" + +#: apps/gsmpb.cc:344 apps/gsmsmsstore.cc:214 +msgid " -V, --verbose print detailed progress messages" +msgstr " -V, --verbose gibt detaillierte Fortschrittsmeldungen aus" + +#: apps/gsmpb.cc:347 +msgid "" +" -y, --synchronize synchronize destination with source\n" +" entries (destination is overwritten)\n" +" (see gsmpb(1) for details)" +msgstr "" +" -y, --synchronize synchronisiere das Zielgerät/-datei mit der Quelle\n" +" (Zieleinträge werden eventuell überschrieben)\n" +" (siehe gsmpb(1) für weitere Details)" + +#: apps/gsmpb.cc:360 +msgid "both source and destination must be given" +msgstr "sowohl Quellgerät/-datei als auch Zielgerät/-datei erforderlich" + +#: apps/gsmpb.cc:374 apps/gsmpb.cc:416 +msgid "phonebook name must be given" +msgstr "ein Telefonbuchname muß angegeben werden" + +# , c-format +#: apps/gsmpb.cc:441 +#, c-format +msgid "" +"text '%s' is too large to fit into destination (maximum size %d characters)" +msgstr "" +"Text '%s' ist zu groß für das Zielgerät (maximale Textlänge %d Zeichen)" + +# , c-format +#: apps/gsmpb.cc:447 +#, c-format +msgid "" +"phone number '%s' is too large to fit into destination (maximum size %d " +"characters)" +msgstr "" +"Telefonnummer '%s' ist zu groß für das Zielgerät (maximale Länge %d Zeichen)" + +#: apps/gsmctl.cc:90 +msgid "active " +msgstr "aktiv" + +#: apps/gsmctl.cc:90 +msgid "inactive " +msgstr "inaktiv" + +#: apps/gsmctl.cc:91 +msgid "number: " +msgstr "Telefonnummer: " + +#: apps/gsmctl.cc:92 +msgid " subaddr: " +msgstr " Unteradresse: " + +#: apps/gsmctl.cc:93 +msgid " time: " +msgstr " Zeit: " + +#: apps/gsmctl.cc:105 +msgid " Manufacturer: " +msgstr " Hersteller: " + +#: apps/gsmctl.cc:106 +msgid " Model: " +msgstr " Modell: " + +#: apps/gsmctl.cc:107 +msgid " Revision: " +msgstr " Revision: " + +#: apps/gsmctl.cc:108 +msgid " Serial Number: " +msgstr " Seriennummer: " + +#: apps/gsmctl.cc:116 apps/gsmctl.cc:118 +msgid " Functionality Level: " +msgstr " Funktionalitäts-Level: " + +#: apps/gsmctl.cc:118 +msgid "unsupported" +msgstr "Kommando nicht unterstützt" + +#: apps/gsmctl.cc:128 +msgid "> Status: " +msgstr "> Status: " + +#: apps/gsmctl.cc:131 gsmlib/gsm_error.cc:104 gsmlib/gsm_sms.cc:441 +#: gsmlib/gsm_sms_codec.cc:204 +msgid "unknown" +msgstr "unbekannt" + +#: apps/gsmctl.cc:132 +msgid "current" +msgstr "aktuell" + +#: apps/gsmctl.cc:133 +msgid "available" +msgstr "verfügbar" + +#: apps/gsmctl.cc:134 +msgid "forbidden" +msgstr "nicht wählbar" + +#: apps/gsmctl.cc:136 apps/gsmctl.cc:147 +msgid " Long name: '" +msgstr " Langname: '" + +#: apps/gsmctl.cc:137 apps/gsmctl.cc:148 +msgid " Short name: '" +msgstr " Kurzname: '" + +#: apps/gsmctl.cc:138 apps/gsmctl.cc:149 +msgid " Numeric name: " +msgstr " Numerischer Name: " + +#: apps/gsmctl.cc:150 +msgid " Mode: " +msgstr " Modus: " + +#: apps/gsmctl.cc:153 +msgid "automatic" +msgstr "automatisch" + +#: apps/gsmctl.cc:154 +msgid "manual" +msgstr "manuell" + +#: apps/gsmctl.cc:155 +msgid "deregister" +msgstr "abmelden" + +#: apps/gsmctl.cc:156 +msgid "manual/automatic" +msgstr "manuell/automatisch" + +#: apps/gsmctl.cc:172 apps/gsmctl.cc:247 +msgid " Voice" +msgstr " Sprache" + +#: apps/gsmctl.cc:176 apps/gsmctl.cc:185 apps/gsmctl.cc:194 +msgid " unknown" +msgstr " unbekannt" + +#: apps/gsmctl.cc:181 apps/gsmctl.cc:249 +msgid " Data" +msgstr " Daten" + +#: apps/gsmctl.cc:190 apps/gsmctl.cc:251 +msgid " Fax" +msgstr " Fax" + +#: apps/gsmctl.cc:229 +msgid "on" +msgstr "an" + +#: apps/gsmctl.cc:229 +msgid "off" +msgstr "aus" + +#: apps/gsmctl.cc:239 +msgid "UnconditionalReason" +msgstr "\"Alle Anrufe\"" + +#: apps/gsmctl.cc:240 +msgid "MobileBusyReason" +msgstr "\"Mobiltelefon besetzt\"" + +#: apps/gsmctl.cc:241 +msgid "NoReplyReason" +msgstr "\"Keine Antwort\"" + +#: apps/gsmctl.cc:242 +msgid "NotReachableReason" +msgstr "\"Nicht erreichbar\"" + +#: apps/gsmctl.cc:261 +msgid "0 ME is powered by the battery" +msgstr "0 ME wird von der Batterie gespeist" + +#: apps/gsmctl.cc:262 +msgid "1 ME has a battery connected, but is not powered by it" +msgstr "1 ME-Batterie ist vorhanden, liefert aber keinen Strom" + +#: apps/gsmctl.cc:264 +msgid "2 ME does not have a battery connected" +msgstr "2 ME-Batterie nicht angeschlossen" + +#: apps/gsmctl.cc:266 +msgid "3 Recognized power fault, calls inhibited" +msgstr "3 Problem mit der Energieversorgung, keine Anrufe möglich" + +# , c-format +#: apps/gsmctl.cc:323 +#, c-format +msgid "unknown facility class parameter '%c'" +msgstr "unbekannter Dienstmerkmal-Parameter '%c'" + +# , c-format +#: apps/gsmctl.cc:336 +#, c-format +msgid "not enough parameters, minimum number of parameters is %d" +msgstr "nicht genügend Parameter, die Mindestanzahl der Parameter ist %d" + +# , c-format +#: apps/gsmctl.cc:340 +#, c-format +msgid "too many parameters, maximum number of parameters is %d" +msgstr "zu viele Parameter, die Maximalanzahl der Parameter ist %d" + +#: apps/gsmctl.cc:385 +msgid "" +": [-b baudrate][-d device][-h][-I init string][-o operation]\n" +" [-v][-X]{parameters}" +msgstr "" +": [-b Baud-Rate][-d Gerät][-h][-I Init String][-o Operation]\n" +" [-v][-X]{Parameter}" + +#: apps/gsmctl.cc:396 +msgid "" +" -o, --operation operation to perform on the mobile \n" +" phone with the specified parameters" +msgstr "" +" -o, --operation gibt die Operation an, die auf dem Mobiltelefon\n" +" mit den angegebenen Parametern ausgeführt werden soll" + +#: apps/gsmctl.cc:402 +msgid "" +" parameters parameters to use for the operation\n" +" (if an operation is given) or\n" +" a specification which kind of\n" +" information to read from the mobile phone" +msgstr "" +" Parameter die für die Operation zu verwendenden Parameter\n" +" (wenn eine Operation ausgeführt werden soll) oder\n" +" die Spezifikation der vom Mobiltelefon zu lesenden\n" +" Informationen" + +#: apps/gsmctl.cc:408 +msgid "" +"Refer to gsmctl(1) for details on the available parameters and operations." +msgstr "" +"Bitte beziehen Sie sich auf die Manual-Seite gsmctl(1) für weitere Details\n" +"über die unterstützten Parameter und Operationen." + +# , c-format +#: apps/gsmctl.cc:471 +#, c-format +msgid "unknown information parameter '%s'" +msgstr "unbekannter Informations-Parameter '%s'" + +# , c-format +#: apps/gsmctl.cc:520 +#, c-format +msgid "unknown opmode parameter '%s'" +msgstr "Unbekannter (Operations-)Modus-Parameter '%s'" + +# , c-format +#: apps/gsmctl.cc:588 +#, c-format +msgid "unknown forward reason parameter '%s'" +msgstr "unbekannter Weiterleitungsgrund-Parameter '%s'" + +# , c-format +#: apps/gsmctl.cc:604 +#, c-format +msgid "unknown forward mode parameter '%s'" +msgstr "unbekannter Weiterleitungs-Modus-Parameter '%s'" + +# , c-format +#: apps/gsmctl.cc:625 +#, c-format +msgid "unknown operation '%s'" +msgstr "unbekannte Operation '%s'" + +# , c-format +#: apps/gsmsmsstore.cc:91 apps/gsmsmsstore.cc:363 apps/gsmsmsstore.cc:380 +#, c-format +msgid "inserting entry #%d from source into destination" +msgstr "füge Eintrag #%d von Quellgerät/-datei in Zielgerät/-datei ein" + +# , c-format +#: apps/gsmsmsstore.cc:102 +#, c-format +msgid "incompatible options '%c' and '%c'" +msgstr "inkompatible Optionen '%c' und '%c'" + +#: apps/gsmsmsstore.cc:184 +msgid "" +": [-a][-b baudrate][-c][-C sca][-d device or file]\n" +" [-h][-I init string][-k][-l][-s device or file][-t SMS store name]\n" +" [-v][-V][-x][-X]{indices}|[phonenumber text]" +msgstr "" +": [-a][-b Baud-Rate][-c][-C sca][-d Gerät oder Datei]\n" +" [-h][-I Init String][-k][-l][-s Gerät oder Datei][-t SMS Speichername]\n" +" [-v][-V][-x][-X]{Indices}|[Telefonnummer Text]" + +#: apps/gsmsmsstore.cc:191 +msgid "" +" -a, --add add new SMS submit message\n" +" (phonenumber and text) to destination" +msgstr "" +" -a, --add füge neue SMS-Submit-Nachricht (Telefonnummer und\n" +" Text) in das Zielgerät/-datei ein" + +#: apps/gsmsmsstore.cc:197 +msgid "" +" -c, --copy copy source entries to destination\n" +" (if indices are given, copy only these entries)" +msgstr "" +" -c, --copy kopiere Quell-Einträge in das Zielgerät/-datei\n" +" (wenn Indices angegeben sind, kopiere nur diese Einträge)" + +#: apps/gsmsmsstore.cc:201 +msgid "" +" -d, --destination sets the destination device to\n" +" connect to, or the file to write to" +msgstr " -d, --destination setzt das Zielgerät bzw. die Zieldatei" + +#: apps/gsmsmsstore.cc:206 +msgid "" +" -k, --backup backup new entries to destination\n" +" (if indices are given, copy only these entries)" +msgstr "" +" -k, --backup sichert alle neuen Einträge in die Zieldatei/-gerät\n" +" (wenn Indices angegeben sind, sichere nur diese Einträge)" + +#: apps/gsmsmsstore.cc:209 +msgid " -l, --list list source to stdout" +msgstr "" +" -l, --list schreibe Liste der Quelleinträge auf die Standardausgabe" + +#: apps/gsmsmsstore.cc:212 +msgid " -t, --store name of SMS store to use" +msgstr " -t, --store gibt den zu verwendenden SMS-Speicher an" + +#: apps/gsmsmsstore.cc:216 +msgid " -x, --delete delete entries denoted by indices" +msgstr "" +" -x, --delete lösche die durch die Indices spezifizierten Einträge" + +#: apps/gsmsmsstore.cc:229 +msgid "no operation option given" +msgstr "keine Operations-Option angegeben" + +#: apps/gsmsmsstore.cc:232 +msgid "both source and destination required" +msgstr "sowohl Quellgerät/-datei als auch Zielgerät/-datei erforderlich" + +#: apps/gsmsmsstore.cc:237 +msgid "destination must not be given" +msgstr "Zielgerät/-datei darf nicht angegeben werden" + +#: apps/gsmsmsstore.cc:239 +msgid "source required" +msgstr "Quellgerät/-datei erforderlich" + +#: apps/gsmsmsstore.cc:244 +msgid "source must not be given" +msgstr "Quellgerät/-datei darf nicht angegeben werden" + +#: apps/gsmsmsstore.cc:246 +msgid "destination required" +msgstr "Zielgerät/-datei erforderlich" + +# , c-format +#: apps/gsmsmsstore.cc:254 gsmlib/gsm_util.cc:285 +#, c-format +msgid "expected number, got '%s'" +msgstr "Zahl erwartet, nicht '%s'" + +#: apps/gsmsmsstore.cc:264 +msgid "not enough parameters given" +msgstr "nicht genügend Parameter angegeben" + +#: apps/gsmsmsstore.cc:269 +msgid "unexpected parameters" +msgstr "unerwartete Parameter" + +#: apps/gsmsmsstore.cc:280 apps/gsmsmsstore.cc:317 +msgid "store name must be given" +msgstr "Speichername muß angegeben werden" + +# , c-format +#: apps/gsmsmsstore.cc:344 apps/gsmsmsstore.cc:377 +#, c-format +msgid "no index '%s' in source" +msgstr "kein Index '%s' in der Quelldatei/-gerät" + +# , c-format +#: apps/gsmsmsstore.cc:392 +#, c-format +msgid "index #%d" +msgstr "Index #%d" + +#: apps/gsmsmsstore.cc:406 +msgid "inserting new entry into destination" +msgstr "füge neuen Eintrag in das Zielgerät/-datei ein" + +# , c-format +#: apps/gsmsmsstore.cc:421 +#, c-format +msgid "deleting entry #%d from destination" +msgstr "lösche Eintrag #%d von Zielgerät/-datei" + +# , c-format +#: apps/gsmsmsstore.cc:426 +#, c-format +msgid "no index '%s' in destination" +msgstr "kein Index '%s' in Zielgerät/-datei" + +#: gsmlib/gsm_at.cc:66 +msgid "unspecified ME/TA error" +msgstr "unspezifizierter ME/TA-Fehler" + +#: gsmlib/gsm_at.cc:76 +msgid "ME/TA error '" +msgstr "ME/TA-Fehler '" + +# , c-format +#: gsmlib/gsm_at.cc:80 +#, c-format +msgid "(code %s)" +msgstr "(Code %s)" + +#: gsmlib/gsm_at.cc:125 gsmlib/gsm_at.cc:215 gsmlib/gsm_at.cc:344 +msgid "ME/TA error '' (code not known)" +msgstr "ME/TA-Fehler '' (Code nicht bekannt)" + +# , c-format +#: gsmlib/gsm_at.cc:184 gsmlib/gsm_at.cc:365 +#, c-format +msgid "unexpected response '%s' when sending 'AT%s'" +msgstr "unerwartete Antwort '%s' beim Senden von 'AT%s'" + +#: gsmlib/gsm_at.cc:318 +msgid "unexpected character in PDU handshake" +msgstr "unerwartetes Zeichen im PDU-Handshake" + +#: gsmlib/gsm_error.cc:29 +msgid "phone failure" +msgstr "Telefon-Fehler" + +#: gsmlib/gsm_error.cc:32 +msgid "no connection to phone" +msgstr "keine Verbindung zum Telefon" + +#: gsmlib/gsm_error.cc:35 +msgid "phone adaptor link reserved" +msgstr "Telefonadapter-Verbindung reserviert" + +#: gsmlib/gsm_error.cc:38 gsmlib/gsm_error.cc:259 +msgid "operation not allowed" +msgstr "Operation nicht erlaubt" + +#: gsmlib/gsm_error.cc:41 gsmlib/gsm_error.cc:262 +msgid "operation not supported" +msgstr "Operation nicht unterstützt" + +#: gsmlib/gsm_error.cc:44 +msgid "ph SIM PIN required" +msgstr "ph SIM PIN erforderlich" + +#: gsmlib/gsm_error.cc:47 gsmlib/gsm_error.cc:271 +msgid "SIM not inserted" +msgstr "SIM nicht eingesteckt" + +#: gsmlib/gsm_error.cc:50 gsmlib/gsm_error.cc:274 +msgid "SIM PIN required" +msgstr "SIM PIN erforderlich" + +#: gsmlib/gsm_error.cc:53 gsmlib/gsm_error.cc:289 +msgid "SIM PUK required" +msgstr "SIM PUK erforderlich" + +#: gsmlib/gsm_error.cc:56 gsmlib/gsm_error.cc:280 +msgid "SIM failure" +msgstr "SIM-Fehler" + +#: gsmlib/gsm_error.cc:59 gsmlib/gsm_error.cc:283 +msgid "SIM busy" +msgstr "SIM beschäftigt" + +#: gsmlib/gsm_error.cc:62 gsmlib/gsm_error.cc:286 +msgid "SIM wrong" +msgstr "falsche SIM" + +#: gsmlib/gsm_error.cc:65 +msgid "incorrect password" +msgstr "falsches Paßwort" + +#: gsmlib/gsm_error.cc:68 gsmlib/gsm_error.cc:292 +msgid "SIM PIN2 required" +msgstr "SIM PIN2 erforderlich" + +#: gsmlib/gsm_error.cc:71 gsmlib/gsm_error.cc:295 +msgid "SIM PUK2 required" +msgstr "SIM PUK2 erforderlich" + +#: gsmlib/gsm_error.cc:74 gsmlib/gsm_error.cc:304 +msgid "memory full" +msgstr "Speicher voll" + +#: gsmlib/gsm_error.cc:77 +msgid "invalid index" +msgstr "ungültiger Index" + +#: gsmlib/gsm_error.cc:80 +msgid "not found" +msgstr "nicht gefunden" + +#: gsmlib/gsm_error.cc:83 gsmlib/gsm_error.cc:298 +msgid "memory failure" +msgstr "Speicher-Fehler" + +#: gsmlib/gsm_error.cc:86 +msgid "text string too long" +msgstr "Zeichenkette zu lang" + +#: gsmlib/gsm_error.cc:89 +msgid "invalid characters in text string" +msgstr "ungültige Zeichen in der Zeichenkette" + +#: gsmlib/gsm_error.cc:92 +msgid "dial string too long" +msgstr "zu wählende Telefonnummer zu lang" + +#: gsmlib/gsm_error.cc:95 +msgid "invalid characters in dial string" +msgstr "ungültige Zeichen in zu wählender Telefonnummer" + +#: gsmlib/gsm_error.cc:98 gsmlib/gsm_error.cc:310 +msgid "no network service" +msgstr "kein Netz" + +#: gsmlib/gsm_error.cc:101 gsmlib/gsm_error.cc:313 +msgid "network timeout" +msgstr "Netz-Zeitüberschreitung" + +# , c-format +#: gsmlib/gsm_error.cc:107 +#, c-format +msgid "invalid ME error %d" +msgstr "ungültiger ME-Fehler %d" + +#: gsmlib/gsm_error.cc:117 +msgid "Unassigned (unallocated) number" +msgstr "nicht zugewiesene Nummer" + +#: gsmlib/gsm_error.cc:120 +msgid "Operator determined barring" +msgstr "vom Operator geschaltete Sperre" + +#: gsmlib/gsm_error.cc:123 +msgid "Call barred" +msgstr "Rufsperre" + +#: gsmlib/gsm_error.cc:126 +msgid "Network failure" +msgstr "Netz-Fehler" + +#: gsmlib/gsm_error.cc:129 +msgid "Short message transfer rejected" +msgstr "Kurznachrichten-Übertragung zurückgewiesen" + +#: gsmlib/gsm_error.cc:133 gsmlib/gsm_error.cc:355 +msgid "Congestion" +msgstr "Netzüberlastung" + +#: gsmlib/gsm_error.cc:136 +msgid "Destination out of service" +msgstr "Ziel außer Betrieb" + +#: gsmlib/gsm_error.cc:139 +msgid "Unidentified subscriber" +msgstr "unidentifizierter Teilnehmer" + +#: gsmlib/gsm_error.cc:142 +msgid "Facility rejected" +msgstr "Dienstmerkmal zurückgewiesen" + +#: gsmlib/gsm_error.cc:145 +msgid "Unknown subscriber" +msgstr "unbekannter Teilnehmer" + +#: gsmlib/gsm_error.cc:148 +msgid "Network out of order" +msgstr "Netz außer Betrieb" + +#: gsmlib/gsm_error.cc:151 +msgid "Temporary failure" +msgstr "temporärer Fehler" + +#: gsmlib/gsm_error.cc:154 +msgid "Resources unavailable, unspecified" +msgstr "Ressourcen nicht verfügbar, nicht spezifiziert" + +#: gsmlib/gsm_error.cc:157 +msgid "Requested facility not subscribed" +msgstr "angefordertes Dienstmerkmal nicht freigeschaltet" + +#: gsmlib/gsm_error.cc:160 +msgid "Requested facility not implemented" +msgstr "angefordertes Dienstmerkmal nicht implementiert" + +#: gsmlib/gsm_error.cc:163 +msgid "Invalid Transaction Identifier" +msgstr "ungültiger Transaktionsbezeichner" + +#: gsmlib/gsm_error.cc:166 +msgid "Semantically incorrect message" +msgstr "semantisch fehlerhafte Nachricht" + +#: gsmlib/gsm_error.cc:169 +msgid "Invalid mandatory information" +msgstr "ungültige, obligatorische Information" + +#: gsmlib/gsm_error.cc:172 +msgid "Message type non-existent or not implemented" +msgstr "Nachrichtentyp nicht existent bzw. nicht implementiert" + +#: gsmlib/gsm_error.cc:175 +msgid "Message not compatible with short message protocol state" +msgstr "Nachricht nicht vereinbar mit Kurznachrichten-Protokollstatus" + +#: gsmlib/gsm_error.cc:178 +msgid "Information element non-existent or not implemented" +msgstr "Informationselement nicht existent oder nicht implementiert" + +#: gsmlib/gsm_error.cc:181 +msgid "Protocol error, unspecified" +msgstr "Protokollfehler, nicht spezifiziert" + +#: gsmlib/gsm_error.cc:184 +msgid "Interworking, unspecified" +msgstr "Interworking, nicht spezifiziert" + +#: gsmlib/gsm_error.cc:187 +msgid "Telematic interworking not supported" +msgstr "Telematisches Interworking nicht unterstützt" + +#: gsmlib/gsm_error.cc:190 +msgid "Short message Type 0 not supported" +msgstr "Kurznachrichtentyp 0 nicht unterstützt" + +#: gsmlib/gsm_error.cc:193 +msgid "Cannot replace short message" +msgstr "kann Kurznachricht nicht ersetzen" + +#: gsmlib/gsm_error.cc:196 +msgid "Unspecified TP-PID error" +msgstr "unspezifizierter TP-PID-Fehler" + +#: gsmlib/gsm_error.cc:199 +msgid "Data coding scheme (alphabet) not supported" +msgstr "Datenkodierungsschema (Alphabet) nicht unterstützt" + +#: gsmlib/gsm_error.cc:202 +msgid "Message class not supported" +msgstr "Nachrichtenklasse nicht unterstützt" + +#: gsmlib/gsm_error.cc:205 +msgid "Unspecifiec TP-DCS error" +msgstr "unspezifizierter TP-DCS-Fehler" + +#: gsmlib/gsm_error.cc:208 +msgid "Command cannot be actioned" +msgstr "Kommando kann nicht ausgeführt werden" + +#: gsmlib/gsm_error.cc:211 +msgid "Command unsupported" +msgstr "Kommando nicht unterstützt" + +#: gsmlib/gsm_error.cc:214 +msgid "Unspecified TP-Command error" +msgstr "unspezifizierter TP-Kommando-Fehler" + +#: gsmlib/gsm_error.cc:217 +msgid "TPDU not supported" +msgstr "TPDU nicht unterstützt" + +#: gsmlib/gsm_error.cc:220 +msgid "SC busy" +msgstr "SC besetzt" + +#: gsmlib/gsm_error.cc:223 +msgid "No SC subscription" +msgstr "SC nicht freigeschaltet" + +#: gsmlib/gsm_error.cc:226 +msgid "SC system failure" +msgstr "SC-Systemfehler" + +#: gsmlib/gsm_error.cc:229 +msgid "Invalid SME address" +msgstr "ungültige SME-Adresse" + +#: gsmlib/gsm_error.cc:232 +msgid "Destination SME barred" +msgstr "Ziel-SME gesperrt" + +#: gsmlib/gsm_error.cc:235 +msgid "SM Rejected-Duplicated SM" +msgstr "Kurznachricht zurückgewiesen - doppelte Kurznachricht" + +#: gsmlib/gsm_error.cc:238 +msgid "SIM SMS storage full" +msgstr "SIM-SMS-Speicher voll" + +#: gsmlib/gsm_error.cc:241 +msgid "No SMS storage capability in SIM" +msgstr "Keine SMS-Speicherfähigkeit in SIM" + +#: gsmlib/gsm_error.cc:244 +msgid "Error in MS" +msgstr "Fehler im MS" + +#: gsmlib/gsm_error.cc:247 +msgid "Memory Capacity Exceed" +msgstr "Speicherkapazität überschritten" + +#: gsmlib/gsm_error.cc:250 +msgid "Unspecified error cause" +msgstr "unspezifizierter Fehlergrund" + +#: gsmlib/gsm_error.cc:253 +msgid "ME failure" +msgstr "ME-Fehler" + +#: gsmlib/gsm_error.cc:256 +msgid "SMS service of ME reserved" +msgstr "SMS-Dienst im ME reserviert" + +#: gsmlib/gsm_error.cc:265 +msgid "invalid PDU mode parameter" +msgstr "ungültiger PDU-Modus-Parameter" + +#: gsmlib/gsm_error.cc:268 +msgid "invalid text mode parameter" +msgstr "ungültiger Text-Modus-Parameter" + +#: gsmlib/gsm_error.cc:277 +msgid "PH-SIM PIN required" +msgstr "PH-SIM PIN erforderlich" + +#: gsmlib/gsm_error.cc:301 +msgid "invalid memory index" +msgstr "ungültiger Speicherindex" + +#: gsmlib/gsm_error.cc:307 +msgid "SMSC address unknown" +msgstr "SMSC-Adresse nicht bekannt" + +#: gsmlib/gsm_error.cc:316 +msgid "no +CNMA acknowledgement expected" +msgstr "keine +CNMA-Bestätigung erwartet" + +#: gsmlib/gsm_error.cc:319 +msgid "unknown error" +msgstr "unbekannter Fehler" + +# , c-format +#: gsmlib/gsm_error.cc:322 +#, c-format +msgid "invalid SMS error %d" +msgstr "ungültiger SMS-Fehler %d" + +#: gsmlib/gsm_error.cc:335 +msgid "Short message received by the SME" +msgstr "Kurznachricht von der SME empfangen" + +#: gsmlib/gsm_error.cc:338 +msgid "" +"Short message forwarded by the SC to the SME but the SC is unable to confirm " +"delivery" +msgstr "" +"die Kurznachricht wurde vom SC zur SME weitergeleitet, aber das SC ist nicht " +"in der Lage, den Empfang zu bestätigen" + +#: gsmlib/gsm_error.cc:342 +msgid "Short message replaced by the SC" +msgstr "Kurznachricht wurde vom SC ersetzt" + +#: gsmlib/gsm_error.cc:345 gsmlib/gsm_error.cc:373 gsmlib/gsm_error.cc:418 +msgid "reserved" +msgstr "reserviert" + +#: gsmlib/gsm_error.cc:358 +msgid "SME busy" +msgstr "SME besetzt" + +#: gsmlib/gsm_error.cc:361 +msgid "No response from SME" +msgstr "keine Antwort vom SME" + +#: gsmlib/gsm_error.cc:364 +msgid "Service rejected" +msgstr "Dienst zurückgewiesen" + +#: gsmlib/gsm_error.cc:367 gsmlib/gsm_error.cc:400 +msgid "Quality of service not available" +msgstr "Dienstqualität nicht verfügbar" + +#: gsmlib/gsm_error.cc:370 +msgid "Error in SME" +msgstr "Fehler im SME" + +#: gsmlib/gsm_error.cc:377 +msgid " (Temporary error, SC is not making any more transfer attempts)" +msgstr " (temporärer Fehler, SC macht keine weiteren Übertragungsversuche)" + +#: gsmlib/gsm_error.cc:380 +msgid " (Temporary error, SC still trying to transfer SM)" +msgstr " (temporärer Fehler, SC versucht weiterhin die SM zu übertragen)" + +#: gsmlib/gsm_error.cc:388 +msgid "Remote Procedure Error" +msgstr "Fern-Prozedur-Aufrufs-Fehler" + +#: gsmlib/gsm_error.cc:391 +msgid "Incompatible destination" +msgstr "inkompatibles Ziel" + +#: gsmlib/gsm_error.cc:394 +msgid "Connection rejected by SME" +msgstr "Verbindung vom SME zurückgewiesen" + +#: gsmlib/gsm_error.cc:397 +msgid "Not obtainable" +msgstr "nicht verfügbar" + +#: gsmlib/gsm_error.cc:403 +msgid "No interworking available" +msgstr "kein Interworking verfügbar" + +#: gsmlib/gsm_error.cc:406 +msgid "SM validity period expired" +msgstr "SM-Gültigkeitszeitraum überschritten" + +#: gsmlib/gsm_error.cc:409 +msgid "SM deleted by originating SME" +msgstr "SM von der sendenden SME gelöscht" + +#: gsmlib/gsm_error.cc:412 +msgid "SM deleted by SC administration" +msgstr "SM von der SC-Administration gelöscht" + +#: gsmlib/gsm_error.cc:415 +msgid "SM does not exit" +msgstr "SM macht keinen Exit" + +#: gsmlib/gsm_error.cc:421 +msgid " (Permanent Error, SC is not making any more transfer attempts)" +msgstr " (permanenter Fehler, SC macht keine weiteren Übertragungsversuche)" + +# , c-format +#: gsmlib/gsm_event.cc:80 +#, c-format +msgid "unexpected number format %d" +msgstr "unerwartetes Telefonnummernformat %d" + +# , c-format +#: gsmlib/gsm_event.cc:100 +#, c-format +msgid "unexpected unsolicited event '%s'" +msgstr "unerwartetes asynchrones Ereignis '%s'" + +#: gsmlib/gsm_me_ta.cc:536 +msgid "unable to set operator" +msgstr "kann den Netzbetreiber nicht setzen" + +#: gsmlib/gsm_me_ta.cc:663 +msgid "call forward time must be in the range 0..30" +msgstr "Rufumleitungszeit muss im Bereich 0..30 sein" + +#: gsmlib/gsm_me_ta.cc:811 +msgid "Functionality Level commands not supported by ME" +msgstr "" +"Funktionalitäts-Level-Kommandos werden vom Gerät (ME) nicht unterstützt" + +#. If the number was just out of range, we get here. +#: gsmlib/gsm_me_ta.cc:830 +msgid "Requested Functionality Level out of range" +msgstr "Angeforderter Funktionalitäts-Level außerhalb des erlaubten Bereichs" + +#: gsmlib/gsm_me_ta.cc:941 +msgid "unsupported alphabet for SMS" +msgstr "nicht unterstütztes Alphabet für SMS" + +#: gsmlib/gsm_me_ta.cc:950 +msgid "SMS text is larger than allowed" +msgstr "SMS-Text ist länger als erlaubt" + +#: gsmlib/gsm_me_ta.cc:962 +msgid "not more than 255 concatenated SMSs allowed" +msgstr "nicht mehr als 255 verbundene SMSs erlaubt" + +#: gsmlib/gsm_me_ta.cc:995 +msgid "only serviceLevel 0 or 1 supported" +msgstr "nur Dienst-Level 0 oder 1 unterstützt" + +#: gsmlib/gsm_me_ta.cc:1108 gsmlib/gsm_me_ta.cc:1150 +msgid "cannot route SMS messages to TE" +msgstr "kann keine Kurznachrichten zum TE weiterleiten" + +#: gsmlib/gsm_me_ta.cc:1122 gsmlib/gsm_me_ta.cc:1164 +msgid "cannot route cell broadcast messages to TE" +msgstr "kann keine Zellen-weiten Nachrichten zum TE weiterleiten" + +#: gsmlib/gsm_me_ta.cc:1134 +msgid "cannot route status reports messages to TE" +msgstr "kann keine Status-Report-Nachrichten zum TE weiterleiten" + +#: gsmlib/gsm_me_ta.cc:1178 +msgid "cannot route status report messages to TE" +msgstr "kann keine Status-Report-Nachrichten zum TE weiterleiten" + +#: gsmlib/gsm_parser.cc:51 +msgid "expected parameter" +msgstr "Parameter erwartet" + +#: gsmlib/gsm_parser.cc:71 +msgid "expected '\"'" +msgstr "'\"' erwartet" + +#: gsmlib/gsm_parser.cc:109 +msgid "expected number" +msgstr "Zahl erwartet" + +# , c-format +#: gsmlib/gsm_parser.cc:120 +#, c-format +msgid "unexpected end of string '%s'" +msgstr "unerwartetes Ende der Zeichenkette '%s'" + +# , c-format +#: gsmlib/gsm_parser.cc:124 +#, c-format +msgid " (at position %d of string '%s')" +msgstr " (an Position %d der Zeichenkette '%s')" + +# , c-format +#: gsmlib/gsm_parser.cc:141 +#, c-format +msgid "expected '%c'" +msgstr "'%c' erwartet" + +#: gsmlib/gsm_parser.cc:165 +msgid "expected ')' or ','" +msgstr "')' oder ',' erwartet" + +#: gsmlib/gsm_parser.cc:251 +msgid "expected ')', ',' or '-'" +msgstr "')', ',' oder '-' erwartet" + +#: gsmlib/gsm_parser.cc:257 +msgid "range of the form a-b-c not allowed" +msgstr "Bereich der Form a-b-c nicht erlaubt" + +#: gsmlib/gsm_parser.cc:264 +msgid "range of the form a- no allowed" +msgstr "Bereich der Form a- nicht erlaubt" + +#: gsmlib/gsm_parser.cc:350 +msgid "expected comma" +msgstr "Komma erwartet" + +#: gsmlib/gsm_parser.cc:367 +msgid "expected end of line" +msgstr "Zeilenende erwartet" + +# , c-format +#: gsmlib/gsm_phonebook.cc:47 +#, c-format +msgid "" +"length of text '%s' exceeds maximum text length (%d characters) of phonebook " +"'%s'" +msgstr "" +"die Länge des Texts '%s' überschreitet die maximale Textlänge (%d Zeichen) " +"des Telefonbuchs '%s'" + +# , c-format +#: gsmlib/gsm_phonebook.cc:55 +#, c-format +msgid "" +"length of telephone number '%s' exceeds maximum telephone number length (%d " +"characters) of phonebook '%s'" +msgstr "" +"die Länge der Telefonnummer '%s' überschreitet die maximale " +"Telefonnummernlänge (%d Zeichen) des Telefonbuchs '%s'" + +#: gsmlib/gsm_phonebook.cc:275 +msgid "phonebook full" +msgstr "Telefonbuch voll" + +#: gsmlib/gsm_phonebook.cc:291 +msgid "attempt to overwrite phonebook entry" +msgstr "Versuch, einen Telefonbucheintrag zu überschreiben" + +#: gsmlib/gsm_phonebook.cc:569 +msgid "SIM card changed while accessing phonebook" +msgstr "SIM-Karte wurde gewechselt beim Zugriff auf Telefonbuch" + +#: gsmlib/gsm_sms.cc:66 gsmlib/gsm_sms.cc:85 gsmlib/gsm_sms.cc:175 +msgid "unhandled SMS TPDU type" +msgstr "unerwarteter SMS TPDU-Typ" + +#: gsmlib/gsm_sms.cc:107 +msgid "can only send SMS-SUBMIT and SMS-COMMAND TPDUs" +msgstr "kann nur SMS-SUBMIT und SMS-COMMAND TPDUs senden" + +#: gsmlib/gsm_sms.cc:111 +msgid "no device given for sending SMS" +msgstr "kein Gerät zum Versenden von SMS angegeben" + +#: gsmlib/gsm_sms.cc:283 +msgid "Message type: SMS-DELIVER" +msgstr "Nachrichtentyp: SMS-DELIVER" + +#: gsmlib/gsm_sms.cc:284 gsmlib/gsm_sms.cc:426 gsmlib/gsm_sms.cc:531 +#: gsmlib/gsm_sms.cc:618 gsmlib/gsm_sms.cc:723 gsmlib/gsm_sms.cc:829 +msgid "SC address: '" +msgstr "SC-Adresse: '" + +#: gsmlib/gsm_sms.cc:285 gsmlib/gsm_sms.cc:532 +msgid "More messages to send: " +msgstr "Mehr Nachrichten zu versenden: " + +#: gsmlib/gsm_sms.cc:286 gsmlib/gsm_sms.cc:445 +msgid "Reply path: " +msgstr "Antwortpfad: " + +#: gsmlib/gsm_sms.cc:287 gsmlib/gsm_sms.cc:446 +msgid "User data header indicator: " +msgstr "Benutzerdatenvorspann (Indikation): " + +#: gsmlib/gsm_sms.cc:289 +msgid "Status report indication: " +msgstr "Status-Report-Indikation: " + +#: gsmlib/gsm_sms.cc:290 +msgid "Originating address: '" +msgstr "Senderadresse: '" + +#: gsmlib/gsm_sms.cc:292 gsmlib/gsm_sms.cc:452 gsmlib/gsm_sms.cc:621 +#: gsmlib/gsm_sms.cc:729 gsmlib/gsm_sms.cc:836 +msgid "Protocol identifier: 0x" +msgstr "Protokollbezeichner: 0x" + +#: gsmlib/gsm_sms.cc:294 gsmlib/gsm_sms.cc:454 gsmlib/gsm_sms.cc:733 +#: gsmlib/gsm_sms.cc:840 +msgid "Data coding scheme: " +msgstr "Datenkodierungsschema: " + +#: gsmlib/gsm_sms.cc:295 gsmlib/gsm_sms.cc:536 gsmlib/gsm_sms.cc:830 +msgid "SC timestamp: " +msgstr "SC-Zeitstempel: " + +#: gsmlib/gsm_sms.cc:296 gsmlib/gsm_sms.cc:456 gsmlib/gsm_sms.cc:735 +#: gsmlib/gsm_sms.cc:842 +msgid "User data length: " +msgstr "Benutzerdatenlänge: " + +#: gsmlib/gsm_sms.cc:297 gsmlib/gsm_sms.cc:457 +msgid "User data header: 0x" +msgstr "Benutzerdatenvorspann: 0x" + +#: gsmlib/gsm_sms.cc:302 gsmlib/gsm_sms.cc:461 gsmlib/gsm_sms.cc:736 +#: gsmlib/gsm_sms.cc:843 +msgid "User data: '" +msgstr "Benutzerdaten: '" + +#: gsmlib/gsm_sms.cc:425 +msgid "Message type: SMS-SUBMIT" +msgstr "Nachrichtentyp: SMS-SUBMIT" + +#: gsmlib/gsm_sms.cc:427 +msgid "Reject duplicates: " +msgstr "Duplikate zurückweisen: " + +#: gsmlib/gsm_sms.cc:428 +msgid "Validity period format: " +msgstr "Gültigkeitszeitraum-Format: " + +#: gsmlib/gsm_sms.cc:432 gsmlib/gsm_sms_codec.cc:183 +msgid "not present" +msgstr "nicht vorhanden" + +#: gsmlib/gsm_sms.cc:435 +msgid "relative" +msgstr "relativ" + +#: gsmlib/gsm_sms.cc:438 +msgid "absolute" +msgstr "absolut" + +#: gsmlib/gsm_sms.cc:448 gsmlib/gsm_sms.cc:620 +msgid "Status report request: " +msgstr "Status-Report-Anforderung: " + +#: gsmlib/gsm_sms.cc:449 gsmlib/gsm_sms.cc:534 gsmlib/gsm_sms.cc:619 +msgid "Message reference: " +msgstr "Nachrichtenreferenz: " + +#: gsmlib/gsm_sms.cc:450 gsmlib/gsm_sms.cc:626 +msgid "Destination address: '" +msgstr "Zieladresse: '" + +#: gsmlib/gsm_sms.cc:455 +msgid "Validity period: " +msgstr "Gültigkeitszeitraum: " + +#: gsmlib/gsm_sms.cc:530 +msgid "Message type: SMS-STATUS-REPORT" +msgstr "Nachrichtentyp: SMS-STATUS-REPORT" + +#: gsmlib/gsm_sms.cc:533 +msgid "Status report qualifier: " +msgstr "Status-Report-Attribut: " + +#: gsmlib/gsm_sms.cc:535 +msgid "Recipient address: '" +msgstr "Empfängeradresse: '" + +#: gsmlib/gsm_sms.cc:537 +msgid "Discharge time: " +msgstr "Aussendezeit: " + +#: gsmlib/gsm_sms.cc:538 +msgid "Status: 0x" +msgstr "Status: 0x" + +#: gsmlib/gsm_sms.cc:617 +msgid "Message type: SMS-COMMAND" +msgstr "Nachrichtentyp: SMS-COMMAND" + +#: gsmlib/gsm_sms.cc:623 +msgid "Command type: 0x" +msgstr "Kommandotyp: 0x" + +#: gsmlib/gsm_sms.cc:625 +msgid "Message number: " +msgstr "Nachrichtennummer: " + +#: gsmlib/gsm_sms.cc:628 +msgid "Command data length: " +msgstr "Kommandodatenlänge: " + +#: gsmlib/gsm_sms.cc:629 +msgid "Command data: '" +msgstr "Kommandodaten: '" + +#: gsmlib/gsm_sms.cc:722 +msgid "Message type: SMS-DELIVER-REPORT" +msgstr "Nachrichtentyp: SMS-DELIVER-REPORT" + +#: gsmlib/gsm_sms.cc:724 gsmlib/gsm_sms.cc:831 +msgid "Protocol identifier present: " +msgstr "Protokollbezeichner präsent: " + +#: gsmlib/gsm_sms.cc:726 gsmlib/gsm_sms.cc:833 +msgid "Data coding scheme present: " +msgstr "Datenkodierungsschema präsent: " + +#: gsmlib/gsm_sms.cc:727 gsmlib/gsm_sms.cc:834 +msgid "User data length present: " +msgstr "Benutzerdatenlänge präsent: " + +#: gsmlib/gsm_sms.cc:828 +msgid "Message type: SMS-SUBMIT-REPORT" +msgstr "Nachrichtentyp: SMS-SUBMIT-REPORT" + +#: gsmlib/gsm_sms_codec.cc:188 gsmlib/gsm_sms_codec.cc:190 +msgid " minutes" +msgstr " Minuten" + +#: gsmlib/gsm_sms_codec.cc:192 +msgid " days" +msgstr " Tage" + +#: gsmlib/gsm_sms_codec.cc:194 +msgid " weeks" +msgstr " Wochen" + +#: gsmlib/gsm_sms_codec.cc:213 +msgid "compressed " +msgstr "komprimiert " + +#: gsmlib/gsm_sms_codec.cc:218 +msgid "voicemail message waiting" +msgstr "Sprachnachricht abrufbar" + +#: gsmlib/gsm_sms_codec.cc:221 +msgid "fax message waiting" +msgstr "Faxnachricht abrufbar" + +#: gsmlib/gsm_sms_codec.cc:224 +msgid "electronic mail message waiting" +msgstr "E-Mail-Nachricht abrufbar" + +#: gsmlib/gsm_sms_codec.cc:227 +msgid "other message waiting" +msgstr "andere Nachricht abrufbar" + +#: gsmlib/gsm_sms_codec.cc:234 +msgid "default alphabet" +msgstr "Standardalphabet" + +#: gsmlib/gsm_sms_codec.cc:237 +msgid "8-bit alphabet" +msgstr "8-Bit Alphabet" + +#: gsmlib/gsm_sms_codec.cc:240 +msgid "16-bit alphabet" +msgstr "16-bit Alphabet" + +#: gsmlib/gsm_sms_codec.cc:243 +msgid "reserved alphabet" +msgstr "reserviertes Alphabet" + +#: gsmlib/gsm_sms_codec.cc:256 +msgid "bad hexadecimal PDU format" +msgstr "fehlerhaftes hexadezimales PDU-Format" + +#: gsmlib/gsm_sms_codec.cc:285 gsmlib/gsm_sms_codec.cc:295 +#: gsmlib/gsm_sms_codec.cc:310 gsmlib/gsm_sms_codec.cc:318 +#: gsmlib/gsm_sms_codec.cc:339 gsmlib/gsm_sms_codec.cc:347 +#: gsmlib/gsm_sms_codec.cc:368 gsmlib/gsm_sms_codec.cc:382 +msgid "premature end of PDU" +msgstr "Vorzeitiges Ende der PDU" + +#: gsmlib/gsm_sms_codec.cc:473 +msgid "unknown time period format" +msgstr "Unbekanntes Zeitperiodenformat" + +#: gsmlib/gsm_unix_serial.cc:119 +msgid "interrupted when reading from TA" +msgstr "Unterbrechung beim Lesen vom TA" + +#: gsmlib/gsm_unix_serial.cc:144 +msgid "reading from TA" +msgstr "beim Lesen vom TA" + +#: gsmlib/gsm_unix_serial.cc:149 +msgid "timeout when reading from TA" +msgstr "Zeitüberschreitung beim Lesen vom TA" + +# , c-format +#: gsmlib/gsm_unix_serial.cc:176 +#, c-format +msgid "opening device '%s'" +msgstr "beim Öffnen von Gerät '%s'" + +#: gsmlib/gsm_unix_serial.cc:182 +msgid "getting file status flags failed" +msgstr "Lesen der Dateistatus-Flags fehlgeschlagen" + +#: gsmlib/gsm_unix_serial.cc:185 +msgid "switching of non-blocking mode failed" +msgstr "Abschalten des Non-Blocking Mode fehlgeschlagen" + +#: gsmlib/gsm_unix_serial.cc:198 +msgid "clearing DTR failed" +msgstr "Zurücksetzen von DTR fehlgeschlagen" + +#: gsmlib/gsm_unix_serial.cc:202 +msgid "setting DTR failed" +msgstr "Setzen von DTR fehlgeschlagen" + +# , c-format +#: gsmlib/gsm_unix_serial.cc:206 +#, c-format +msgid "tcgetattr device '%s'" +msgstr "tcgetattr Gerät '%s'" + +# , c-format +#: gsmlib/gsm_unix_serial.cc:233 +#, c-format +msgid "tcsetattr device '%s'" +msgstr "tcsetattr Gerät '%s'" + +# , c-format +#. no response after 3 tries +#: gsmlib/gsm_unix_serial.cc:287 +#, c-format +msgid "reset modem failed '%s'" +msgstr "Zurücksetzen des Modems '%s' fehlgeschlagen" + +#: gsmlib/gsm_unix_serial.cc:332 gsmlib/gsm_unix_serial.cc:364 +msgid "interrupted when writing to TA" +msgstr "Unterbrechnung beim Schreiben auf den TA" + +#: gsmlib/gsm_unix_serial.cc:347 gsmlib/gsm_unix_serial.cc:356 +msgid "writing to TA" +msgstr "beim Schreiben auf den TA" + +#: gsmlib/gsm_unix_serial.cc:377 +msgid "timeout when writing to TA" +msgstr "Zeitüberschreitung beim Schreiben auf den TA" + +# , c-format +#: gsmlib/gsm_unix_serial.cc:438 +#, c-format +msgid "unknown baudrate '%s'" +msgstr "unbekannte Baud-Rate '%s'" + +# , c-format +#: gsmlib/gsm_util.cc:205 +#, c-format +msgid "error when calling stat('%s') (errno: %d/%s)" +msgstr "Fehler beim Aufruf von stat('%s') (errno: %d/%s)" + +# , c-format +#: gsmlib/gsm_util.cc:236 +#, c-format +msgid "file '%s' is neither file nor character device" +msgstr "Datei '%s' ist weder eine reguläre Datei noch einen Zeichengerät" + +#: gsmlib/gsm_util.cc:240 +msgid "maxmimum number of symbolic links exceeded" +msgstr "maximale Anzahl der symbolischen Links überschritten" + +# , c-format +#: gsmlib/gsm_util.cc:250 +#, c-format +msgid "error renaming '%s' to '%s'" +msgstr "Fehler beim Umbenennen von '%s' zu '%s'" + +# , c-format +#: gsmlib/gsm_util.cc:348 +#, c-format +msgid "text '%s' contains illegal character '\"'" +msgstr "der Text '%s' enthält das illegale Zeichen '\"'" + +# , c-format +#: gsmlib/gsm_util.cc:358 +#, c-format +msgid "illegal character in telephone number '%s'" +msgstr "ungültiges Zeichen in der Telefonnummer '%s'" + +# , c-format +#: gsmlib/gsm_sorted_phonebook.cc:95 +#, c-format +msgid "error reading from file '%s" +msgstr "Fehler beim Lesen von Datei '%s'" + +# , c-format +#: gsmlib/gsm_sorted_phonebook.cc:109 +#, c-format +msgid "entry '%s' lacks index" +msgstr "Eintrag '%s' hat keinen Index" + +# , c-format +#: gsmlib/gsm_sorted_phonebook.cc:118 gsmlib/gsm_sorted_phonebook.cc:124 +#, c-format +msgid "line '%s' has invalid format" +msgstr "Zeile '%s' hat ungültiges Format" + +# , c-format +#: gsmlib/gsm_sorted_phonebook.cc:173 gsmlib/gsm_sorted_sms_store.cc:159 +#, c-format +msgid "error opening file '%s' for writing" +msgstr "Fehler beim Öffnen der Datei '%s' zum Schreiben" + +#: gsmlib/gsm_sorted_phonebook.cc:174 gsmlib/gsm_sorted_phonebook.cc:193 +#: gsmlib/gsm_sorted_sms_store.cc:67 gsmlib/gsm_sorted_sms_store.cc:160 +msgid "" +msgstr "" + +# , c-format +#: gsmlib/gsm_sorted_phonebook.cc:192 gsmlib/gsm_sorted_sms_store.cc:66 +#, c-format +msgid "error writing to file '%s'" +msgstr "Fehler beim Schreiben in die Datei '%s'" + +#: gsmlib/gsm_sorted_phonebook.cc:216 +msgid "attempt to change phonebook read from " +msgstr "Versuch, von der Standardeingabe gelesenes Telefonbuch zu verändern" + +# , c-format +#: gsmlib/gsm_sorted_phonebook.cc:229 gsmlib/gsm_sorted_sms_store.cc:215 +#, c-format +msgid "cannot open file '%s'" +msgstr "kann Datei '%s' nicht öffnen" + +#: gsmlib/gsm_sorted_phonebook.cc:244 gsmlib/gsm_sorted_sms_store.cc:55 +#: gsmlib/gsm_sorted_sms_store.cc:228 +msgid "" +msgstr "" + +#: gsmlib/gsm_sorted_phonebook.cc:361 +msgid "indices must be unique in phonebook" +msgstr "Indices im Telefonbuch müssen eindeutig sein" + +# , c-format +#: gsmlib/gsm_sorted_sms_store.cc:54 +#, c-format +msgid "error reading from file '%s'" +msgstr "Fehler beim Lesen aus der Datei '%s'" + +# , c-format +#: gsmlib/gsm_sorted_sms_store.cc:87 +#, c-format +msgid "file '%s' has wrong version" +msgstr "Datei '%s' hat die falsche Version" + +# , c-format +#: gsmlib/gsm_sorted_sms_store.cc:99 gsmlib/gsm_sorted_sms_store.cc:111 +#, c-format +msgid "corrupt SMS store file '%s'" +msgstr "beschädigte SMS-Speicherdatei '%s'" + +#: gsmlib/gsm_sorted_sms_store.cc:204 +msgid "attempt to change SMS store read from " +msgstr "" +"Versuch, SMS-Speicher zu verändern, der von der Standardeingabe gelesen wurde" + +#~ msgid "cannot read current network operator" +#~ msgstr "kann den aktuellen Netzbetreiber nicht lesen" + +#~ msgid "Message type: SMS" +#~ msgstr "Nachrichtentyp: SMS" + +#~ msgid "(no further information available)" +#~ msgstr "(keine weitere Information verfügbar)" diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/gsmlib.pot b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/gsmlib.pot new file mode 100644 index 0000000000..48ae57758f --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/gsmlib.pot @@ -0,0 +1,1689 @@ +# SOME DESCRIPTIVE TITLE. +# Copyright (C) YEAR THE PACKAGE'S COPYRIGHT HOLDER +# This file is distributed under the same license as the PACKAGE package. +# FIRST AUTHOR , YEAR. +# +#, fuzzy +msgid "" +msgstr "" +"Project-Id-Version: PACKAGE VERSION\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2007-09-29 18:24+0100\n" +"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" +"Last-Translator: FULL NAME \n" +"Language-Team: LANGUAGE \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=CHARSET\n" +"Content-Transfer-Encoding: 8bit\n" + +#: apps/gsmsmsd.cc:171 +#, c-format +msgid "could not execute '%s'" +msgstr "" + +#: apps/gsmsmsd.cc:175 +#, c-format +msgid "error writing to '%s'" +msgstr "" + +#: apps/gsmsmsd.cc:196 apps/gsmsmsd.cc:197 apps/gsmsmsd.cc:198 +#, c-format +msgid "%d" +msgstr "" + +#: apps/gsmsmsd.cc:215 +#, c-format +msgid "error when calling opendir('%s')(errno: %d/%s)" +msgstr "" + +#: apps/gsmsmsd.cc:259 +#, c-format +msgid "count not open SMS spool file %s" +msgstr "" + +#: apps/gsmsmsd.cc:435 apps/gsmsendsms.cc:144 apps/gsmpb.cc:311 +#: apps/gsmctl.cc:380 apps/gsmsmsstore.cc:179 +#, c-format +msgid ": version %s [compiled %s]" +msgstr "" + +#: apps/gsmsmsd.cc:440 +msgid "" +": [-a action][-b baudrate][-C sca][-d device][-f][-h][-I init string]\n" +" [-s spool dir][-t][-v]{sms_type}" +msgstr "" + +#: apps/gsmsmsd.cc:444 +msgid "" +" -a, --action the action to execute when an SMS arrives\n" +" (SMS is send to stdin of action)" +msgstr "" + +#: apps/gsmsmsd.cc:448 apps/gsmsendsms.cc:153 apps/gsmpb.cc:322 +#: apps/gsmctl.cc:389 apps/gsmsmsstore.cc:194 +msgid " -b, --baudrate baudrate to use for device (default: 38400)" +msgstr "" + +#: apps/gsmsmsd.cc:451 +msgid " -c, --concatenate start ID for concatenated SMS messages" +msgstr "" + +#: apps/gsmsmsd.cc:453 apps/gsmsendsms.cc:158 apps/gsmsmsstore.cc:200 +msgid " -C, --sca SMS service centre address" +msgstr "" + +#: apps/gsmsmsd.cc:454 +msgid " -d, --device sets the device to connect to" +msgstr "" + +#: apps/gsmsmsd.cc:455 +msgid " -D, --direct enable direct routing of SMSs" +msgstr "" + +#: apps/gsmsmsd.cc:456 +msgid " -f, --flush flush SMS from store" +msgstr "" + +#: apps/gsmsmsd.cc:457 +msgid " -F, --failed directory to move failed SMS to," +msgstr "" + +#: apps/gsmsmsd.cc:458 apps/gsmsmsd.cc:471 +msgid " if unset, the SMS will be deleted" +msgstr "" + +#: apps/gsmsmsd.cc:459 apps/gsmsendsms.cc:161 apps/gsmpb.cc:332 +#: apps/gsmctl.cc:394 apps/gsmsmsstore.cc:204 +msgid " -h, --help prints this message" +msgstr "" + +#: apps/gsmsmsd.cc:460 apps/gsmsendsms.cc:162 apps/gsmpb.cc:335 +#: apps/gsmctl.cc:395 apps/gsmsmsstore.cc:205 +msgid " -I, --init device AT init sequence" +msgstr "" + +#: apps/gsmsmsd.cc:462 +msgid " -L, --syslog log errors and information to syslog" +msgstr "" + +#: apps/gsmsmsd.cc:465 +msgid " -P, --priorities number of priority levels to use," +msgstr "" + +#: apps/gsmsmsd.cc:466 +msgid " (default: none)" +msgstr "" + +#: apps/gsmsmsd.cc:467 apps/gsmsendsms.cc:163 +msgid " -r, --requeststat request SMS status report" +msgstr "" + +#: apps/gsmsmsd.cc:468 +msgid " -s, --spool spool directory for outgoing SMS" +msgstr "" + +#: apps/gsmsmsd.cc:470 +msgid " -S, --sent directory to move sent SMS to," +msgstr "" + +#: apps/gsmsmsd.cc:472 +msgid "" +" -t, --store name of SMS store to use for flush\n" +" and/or temporary SMS storage" +msgstr "" + +#: apps/gsmsmsd.cc:475 apps/gsmsendsms.cc:167 apps/gsmpb.cc:343 +#: apps/gsmctl.cc:399 apps/gsmsmsstore.cc:213 +msgid " -v, --version prints version and exits" +msgstr "" + +#: apps/gsmsmsd.cc:476 apps/gsmsendsms.cc:169 apps/gsmpb.cc:346 +#: apps/gsmctl.cc:400 apps/gsmsmsstore.cc:218 +msgid " -X, --xonxoff switch on software handshake" +msgstr "" + +#: apps/gsmsmsd.cc:478 +msgid " sms_type may be any combination of" +msgstr "" + +#: apps/gsmsmsd.cc:479 +msgid " sms, no_sms controls reception of normal SMS" +msgstr "" + +#: apps/gsmsmsd.cc:481 +msgid " cb, no_cb controls reception of cell broadcast messages" +msgstr "" + +#: apps/gsmsmsd.cc:483 +msgid " stat, no_stat controls reception of status reports" +msgstr "" + +#: apps/gsmsmsd.cc:485 +msgid " default is \"sms cb stat\"" +msgstr "" + +#: apps/gsmsmsd.cc:486 +msgid "If no action is given, the SMS is printed to stdout" +msgstr "" + +#: apps/gsmsmsd.cc:488 +msgid "If -P is given, it activates the priority system and sets the" +msgstr "" + +#: apps/gsmsmsd.cc:489 +msgid "number or levels to use. For every level, there must be directories" +msgstr "" + +#: apps/gsmsmsd.cc:490 +msgid "named +." +msgstr "" + +#: apps/gsmsmsd.cc:491 +msgid "For example \"-P 2 -s queue -S send -F failed\" needs the following" +msgstr "" + +#: apps/gsmsmsd.cc:492 +msgid "directories: queue1/ queue2/ send1/ send2/ failed1/ failed2/" +msgstr "" + +#: apps/gsmsmsd.cc:493 +msgid "Before sending one SMS from queue2, all pending SMS from queue1" +msgstr "" + +#: apps/gsmsmsd.cc:494 +msgid "will be sent." +msgstr "" + +#: apps/gsmsmsd.cc:499 apps/gsmsendsms.cc:178 apps/gsmpb.cc:354 +#: apps/gsmctl.cc:414 apps/gsmsmsstore.cc:223 +msgid "unknown option" +msgstr "" + +#: apps/gsmsmsd.cc:538 +#, c-format +msgid "error when calling sigaction() (errno: %d/%s)" +msgstr "" + +#: apps/gsmsmsd.cc:558 +msgid "store name must be given for flush option" +msgstr "" + +#. process the new message +#: apps/gsmsmsd.cc:566 apps/gsmsmsd.cc:634 +msgid "Type of message: " +msgstr "" + +#: apps/gsmsmsd.cc:570 apps/gsmsmsd.cc:638 +msgid "SMS message\n" +msgstr "" + +#: apps/gsmsmsd.cc:573 +msgid "submit report message\n" +msgstr "" + +#: apps/gsmsmsd.cc:576 apps/gsmsmsd.cc:644 +msgid "status report message\n" +msgstr "" + +#: apps/gsmsmsd.cc:641 +msgid "cell broadcast message\n" +msgstr "" + +#: apps/gsmsmsd.cc:697 apps/gsmsmsd.cc:699 apps/gsmsendsms.cc:253 +#: apps/gsmpb.cc:503 apps/gsmctl.cc:631 apps/gsmsmsstore.cc:435 +msgid "[ERROR]: " +msgstr "" + +#: apps/gsmsmsd.cc:700 +msgid "(try setting sms_type, please refer to gsmsmsd manpage)" +msgstr "" + +#: apps/gsmsendsms.cc:149 +msgid "" +": [-b baudrate][-c concatenatedID][-C sca][-d device][-h][-I init string]\n" +" [-t][-v][-X] phonenumber [text]" +msgstr "" + +#: apps/gsmsendsms.cc:156 +msgid " -c, --concatenate ID for concatenated SMS messages" +msgstr "" + +#: apps/gsmsendsms.cc:159 apps/gsmctl.cc:392 +msgid " -d, --device sets the destination device to connect to" +msgstr "" + +#: apps/gsmsendsms.cc:164 +msgid "" +" -t, --test convert text to GSM alphabet and vice\n" +" versa, no SMS message is sent" +msgstr "" + +#: apps/gsmsendsms.cc:171 +msgid " phonenumber recipient's phone number" +msgstr "" + +#: apps/gsmsendsms.cc:172 +msgid "" +" text optional text of the SMS message\n" +" if omitted: read from stdin" +msgstr "" + +#: apps/gsmsendsms.cc:205 +msgid "phone number and text missing" +msgstr "" + +#: apps/gsmsendsms.cc:208 apps/gsmsmsstore.cc:261 +msgid "more than two parameters given" +msgstr "" + +#: apps/gsmsendsms.cc:224 +msgid "text is larger than 160 characters" +msgstr "" + +#: apps/gsmpb.cc:102 apps/gsmpb.cc:491 +#, c-format +msgid "inserting '%s' tel# %s" +msgstr "" + +#: apps/gsmpb.cc:105 apps/gsmpb.cc:230 apps/gsmpb.cc:494 +#, c-format +msgid " (index #%d)" +msgstr "" + +#: apps/gsmpb.cc:144 +#, c-format +msgid "updating '%s' tel# %s to new tel# %s" +msgstr "" + +#: apps/gsmpb.cc:177 +#, c-format +msgid "updating '%s' tel# %s to new tel# %s(index %d)" +msgstr "" + +#: apps/gsmpb.cc:227 +#, c-format +msgid "deleting '%s' tel# %s" +msgstr "" + +#: apps/gsmpb.cc:316 +msgid "" +": [-b baudrate][-c][-d device or file][-h][-I init string]\n" +" [-p phonebook name][-s device or file][-t charset][-v][-V][-y][-X]" +msgstr "" + +#: apps/gsmpb.cc:325 +msgid " -c, --copy copy source entries to destination" +msgstr "" + +#: apps/gsmpb.cc:327 +msgid "" +" -d, --destination sets the destination device to connect \n" +" to, or the file to write" +msgstr "" + +#: apps/gsmpb.cc:330 +msgid " -D, --destination-backend sets the destination backend" +msgstr "" + +#: apps/gsmpb.cc:333 +msgid " -i, --index takes index positions into account" +msgstr "" + +#: apps/gsmpb.cc:336 +msgid " -p, --phonebook name of phonebook to use" +msgstr "" + +#: apps/gsmpb.cc:337 apps/gsmsmsstore.cc:210 +msgid "" +" -s, --source sets the source device to connect to,\n" +" or the file to read" +msgstr "" + +#: apps/gsmpb.cc:339 +msgid "" +" -t, --charset sets the character set to use for\n" +" phonebook entries" +msgstr "" + +#: apps/gsmpb.cc:341 +msgid " -S, --source-backend sets the source backend" +msgstr "" + +#: apps/gsmpb.cc:344 apps/gsmsmsstore.cc:214 +msgid " -V, --verbose print detailed progress messages" +msgstr "" + +#: apps/gsmpb.cc:347 +msgid "" +" -y, --synchronize synchronize destination with source\n" +" entries (destination is overwritten)\n" +" (see gsmpb(1) for details)" +msgstr "" + +#: apps/gsmpb.cc:360 +msgid "both source and destination must be given" +msgstr "" + +#: apps/gsmpb.cc:374 apps/gsmpb.cc:416 +msgid "phonebook name must be given" +msgstr "" + +#: apps/gsmpb.cc:441 +#, c-format +msgid "" +"text '%s' is too large to fit into destination (maximum size %d characters)" +msgstr "" + +#: apps/gsmpb.cc:447 +#, c-format +msgid "" +"phone number '%s' is too large to fit into destination (maximum size %d " +"characters)" +msgstr "" + +#: apps/gsmctl.cc:90 +msgid "active " +msgstr "" + +#: apps/gsmctl.cc:90 +msgid "inactive " +msgstr "" + +#: apps/gsmctl.cc:91 +msgid "number: " +msgstr "" + +#: apps/gsmctl.cc:92 +msgid " subaddr: " +msgstr "" + +#: apps/gsmctl.cc:93 +msgid " time: " +msgstr "" + +#: apps/gsmctl.cc:105 +msgid " Manufacturer: " +msgstr "" + +#: apps/gsmctl.cc:106 +msgid " Model: " +msgstr "" + +#: apps/gsmctl.cc:107 +msgid " Revision: " +msgstr "" + +#: apps/gsmctl.cc:108 +msgid " Serial Number: " +msgstr "" + +#: apps/gsmctl.cc:116 apps/gsmctl.cc:118 +msgid " Functionality Level: " +msgstr "" + +#: apps/gsmctl.cc:118 +msgid "unsupported" +msgstr "" + +#: apps/gsmctl.cc:128 +msgid "> Status: " +msgstr "" + +#: apps/gsmctl.cc:131 gsmlib/gsm_error.cc:104 gsmlib/gsm_sms.cc:441 +#: gsmlib/gsm_sms_codec.cc:205 +msgid "unknown" +msgstr "" + +#: apps/gsmctl.cc:132 +msgid "current" +msgstr "" + +#: apps/gsmctl.cc:133 +msgid "available" +msgstr "" + +#: apps/gsmctl.cc:134 +msgid "forbidden" +msgstr "" + +#: apps/gsmctl.cc:136 apps/gsmctl.cc:147 +msgid " Long name: '" +msgstr "" + +#: apps/gsmctl.cc:137 apps/gsmctl.cc:148 +msgid " Short name: '" +msgstr "" + +#: apps/gsmctl.cc:138 apps/gsmctl.cc:149 +msgid " Numeric name: " +msgstr "" + +#: apps/gsmctl.cc:150 +msgid " Mode: " +msgstr "" + +#: apps/gsmctl.cc:153 +msgid "automatic" +msgstr "" + +#: apps/gsmctl.cc:154 +msgid "manual" +msgstr "" + +#: apps/gsmctl.cc:155 +msgid "deregister" +msgstr "" + +#: apps/gsmctl.cc:156 +msgid "manual/automatic" +msgstr "" + +#: apps/gsmctl.cc:172 apps/gsmctl.cc:247 +msgid " Voice" +msgstr "" + +#: apps/gsmctl.cc:176 apps/gsmctl.cc:185 apps/gsmctl.cc:194 +msgid " unknown" +msgstr "" + +#: apps/gsmctl.cc:181 apps/gsmctl.cc:249 +msgid " Data" +msgstr "" + +#: apps/gsmctl.cc:190 apps/gsmctl.cc:251 +msgid " Fax" +msgstr "" + +#: apps/gsmctl.cc:229 +msgid "on" +msgstr "" + +#: apps/gsmctl.cc:229 +msgid "off" +msgstr "" + +#: apps/gsmctl.cc:239 +msgid "UnconditionalReason" +msgstr "" + +#: apps/gsmctl.cc:240 +msgid "MobileBusyReason" +msgstr "" + +#: apps/gsmctl.cc:241 +msgid "NoReplyReason" +msgstr "" + +#: apps/gsmctl.cc:242 +msgid "NotReachableReason" +msgstr "" + +#: apps/gsmctl.cc:261 +msgid "0 ME is powered by the battery" +msgstr "" + +#: apps/gsmctl.cc:262 +msgid "1 ME has a battery connected, but is not powered by it" +msgstr "" + +#: apps/gsmctl.cc:264 +msgid "2 ME does not have a battery connected" +msgstr "" + +#: apps/gsmctl.cc:266 +msgid "3 Recognized power fault, calls inhibited" +msgstr "" + +#: apps/gsmctl.cc:323 +#, c-format +msgid "unknown facility class parameter '%c'" +msgstr "" + +#: apps/gsmctl.cc:336 +#, c-format +msgid "not enough parameters, minimum number of parameters is %d" +msgstr "" + +#: apps/gsmctl.cc:340 +#, c-format +msgid "too many parameters, maximum number of parameters is %d" +msgstr "" + +#: apps/gsmctl.cc:385 +msgid "" +": [-b baudrate][-d device][-h][-I init string][-o operation]\n" +" [-v][-X]{parameters}" +msgstr "" + +#: apps/gsmctl.cc:396 +msgid "" +" -o, --operation operation to perform on the mobile \n" +" phone with the specified parameters" +msgstr "" + +#: apps/gsmctl.cc:402 +msgid "" +" parameters parameters to use for the operation\n" +" (if an operation is given) or\n" +" a specification which kind of\n" +" information to read from the mobile phone" +msgstr "" + +#: apps/gsmctl.cc:408 +msgid "" +"Refer to gsmctl(1) for details on the available parameters and operations." +msgstr "" + +#: apps/gsmctl.cc:471 +#, c-format +msgid "unknown information parameter '%s'" +msgstr "" + +#: apps/gsmctl.cc:520 +#, c-format +msgid "unknown opmode parameter '%s'" +msgstr "" + +#: apps/gsmctl.cc:588 +#, c-format +msgid "unknown forward reason parameter '%s'" +msgstr "" + +#: apps/gsmctl.cc:604 +#, c-format +msgid "unknown forward mode parameter '%s'" +msgstr "" + +#: apps/gsmctl.cc:625 +#, c-format +msgid "unknown operation '%s'" +msgstr "" + +#: apps/gsmsmsstore.cc:91 apps/gsmsmsstore.cc:363 apps/gsmsmsstore.cc:380 +#, c-format +msgid "inserting entry #%d from source into destination" +msgstr "" + +#: apps/gsmsmsstore.cc:102 +#, c-format +msgid "incompatible options '%c' and '%c'" +msgstr "" + +#: apps/gsmsmsstore.cc:184 +msgid "" +": [-a][-b baudrate][-c][-C sca][-d device or file]\n" +" [-h][-I init string][-k][-l][-s device or file][-t SMS store name]\n" +" [-v][-V][-x][-X]{indices}|[phonenumber text]" +msgstr "" + +#: apps/gsmsmsstore.cc:191 +msgid "" +" -a, --add add new SMS submit message\n" +" (phonenumber and text) to destination" +msgstr "" + +#: apps/gsmsmsstore.cc:197 +msgid "" +" -c, --copy copy source entries to destination\n" +" (if indices are given, copy only these entries)" +msgstr "" + +#: apps/gsmsmsstore.cc:201 +msgid "" +" -d, --destination sets the destination device to\n" +" connect to, or the file to write to" +msgstr "" + +#: apps/gsmsmsstore.cc:206 +msgid "" +" -k, --backup backup new entries to destination\n" +" (if indices are given, copy only these entries)" +msgstr "" + +#: apps/gsmsmsstore.cc:209 +msgid " -l, --list list source to stdout" +msgstr "" + +#: apps/gsmsmsstore.cc:212 +msgid " -t, --store name of SMS store to use" +msgstr "" + +#: apps/gsmsmsstore.cc:216 +msgid " -x, --delete delete entries denoted by indices" +msgstr "" + +#: apps/gsmsmsstore.cc:229 +msgid "no operation option given" +msgstr "" + +#: apps/gsmsmsstore.cc:232 +msgid "both source and destination required" +msgstr "" + +#: apps/gsmsmsstore.cc:237 +msgid "destination must not be given" +msgstr "" + +#: apps/gsmsmsstore.cc:239 +msgid "source required" +msgstr "" + +#: apps/gsmsmsstore.cc:244 +msgid "source must not be given" +msgstr "" + +#: apps/gsmsmsstore.cc:246 +msgid "destination required" +msgstr "" + +#: apps/gsmsmsstore.cc:254 gsmlib/gsm_util.cc:286 +#, c-format +msgid "expected number, got '%s'" +msgstr "" + +#: apps/gsmsmsstore.cc:264 +msgid "not enough parameters given" +msgstr "" + +#: apps/gsmsmsstore.cc:269 +msgid "unexpected parameters" +msgstr "" + +#: apps/gsmsmsstore.cc:280 apps/gsmsmsstore.cc:317 +msgid "store name must be given" +msgstr "" + +#: apps/gsmsmsstore.cc:344 apps/gsmsmsstore.cc:377 +#, c-format +msgid "no index '%s' in source" +msgstr "" + +#: apps/gsmsmsstore.cc:392 +#, c-format +msgid "index #%d" +msgstr "" + +#: apps/gsmsmsstore.cc:406 +msgid "inserting new entry into destination" +msgstr "" + +#: apps/gsmsmsstore.cc:421 +#, c-format +msgid "deleting entry #%d from destination" +msgstr "" + +#: apps/gsmsmsstore.cc:426 +#, c-format +msgid "no index '%s' in destination" +msgstr "" + +#: gsmlib/gsm_at.cc:66 +msgid "unspecified ME/TA error" +msgstr "" + +#: gsmlib/gsm_at.cc:76 +msgid "ME/TA error '" +msgstr "" + +#: gsmlib/gsm_at.cc:80 +#, c-format +msgid "(code %s)" +msgstr "" + +#: gsmlib/gsm_at.cc:125 gsmlib/gsm_at.cc:215 gsmlib/gsm_at.cc:344 +msgid "ME/TA error '' (code not known)" +msgstr "" + +#: gsmlib/gsm_at.cc:184 gsmlib/gsm_at.cc:365 +#, c-format +msgid "unexpected response '%s' when sending 'AT%s'" +msgstr "" + +#: gsmlib/gsm_at.cc:318 +msgid "unexpected character in PDU handshake" +msgstr "" + +#: gsmlib/gsm_error.cc:29 +msgid "phone failure" +msgstr "" + +#: gsmlib/gsm_error.cc:32 +msgid "no connection to phone" +msgstr "" + +#: gsmlib/gsm_error.cc:35 +msgid "phone adaptor link reserved" +msgstr "" + +#: gsmlib/gsm_error.cc:38 gsmlib/gsm_error.cc:259 +msgid "operation not allowed" +msgstr "" + +#: gsmlib/gsm_error.cc:41 gsmlib/gsm_error.cc:262 +msgid "operation not supported" +msgstr "" + +#: gsmlib/gsm_error.cc:44 +msgid "ph SIM PIN required" +msgstr "" + +#: gsmlib/gsm_error.cc:47 gsmlib/gsm_error.cc:271 +msgid "SIM not inserted" +msgstr "" + +#: gsmlib/gsm_error.cc:50 gsmlib/gsm_error.cc:274 +msgid "SIM PIN required" +msgstr "" + +#: gsmlib/gsm_error.cc:53 gsmlib/gsm_error.cc:289 +msgid "SIM PUK required" +msgstr "" + +#: gsmlib/gsm_error.cc:56 gsmlib/gsm_error.cc:280 +msgid "SIM failure" +msgstr "" + +#: gsmlib/gsm_error.cc:59 gsmlib/gsm_error.cc:283 +msgid "SIM busy" +msgstr "" + +#: gsmlib/gsm_error.cc:62 gsmlib/gsm_error.cc:286 +msgid "SIM wrong" +msgstr "" + +#: gsmlib/gsm_error.cc:65 +msgid "incorrect password" +msgstr "" + +#: gsmlib/gsm_error.cc:68 gsmlib/gsm_error.cc:292 +msgid "SIM PIN2 required" +msgstr "" + +#: gsmlib/gsm_error.cc:71 gsmlib/gsm_error.cc:295 +msgid "SIM PUK2 required" +msgstr "" + +#: gsmlib/gsm_error.cc:74 gsmlib/gsm_error.cc:304 +msgid "memory full" +msgstr "" + +#: gsmlib/gsm_error.cc:77 +msgid "invalid index" +msgstr "" + +#: gsmlib/gsm_error.cc:80 +msgid "not found" +msgstr "" + +#: gsmlib/gsm_error.cc:83 gsmlib/gsm_error.cc:298 +msgid "memory failure" +msgstr "" + +#: gsmlib/gsm_error.cc:86 +msgid "text string too long" +msgstr "" + +#: gsmlib/gsm_error.cc:89 +msgid "invalid characters in text string" +msgstr "" + +#: gsmlib/gsm_error.cc:92 +msgid "dial string too long" +msgstr "" + +#: gsmlib/gsm_error.cc:95 +msgid "invalid characters in dial string" +msgstr "" + +#: gsmlib/gsm_error.cc:98 gsmlib/gsm_error.cc:310 +msgid "no network service" +msgstr "" + +#: gsmlib/gsm_error.cc:101 gsmlib/gsm_error.cc:313 +msgid "network timeout" +msgstr "" + +#: gsmlib/gsm_error.cc:107 +#, c-format +msgid "invalid ME error %d" +msgstr "" + +#: gsmlib/gsm_error.cc:117 +msgid "Unassigned (unallocated) number" +msgstr "" + +#: gsmlib/gsm_error.cc:120 +msgid "Operator determined barring" +msgstr "" + +#: gsmlib/gsm_error.cc:123 +msgid "Call barred" +msgstr "" + +#: gsmlib/gsm_error.cc:126 +msgid "Network failure" +msgstr "" + +#: gsmlib/gsm_error.cc:129 +msgid "Short message transfer rejected" +msgstr "" + +#: gsmlib/gsm_error.cc:133 gsmlib/gsm_error.cc:355 +msgid "Congestion" +msgstr "" + +#: gsmlib/gsm_error.cc:136 +msgid "Destination out of service" +msgstr "" + +#: gsmlib/gsm_error.cc:139 +msgid "Unidentified subscriber" +msgstr "" + +#: gsmlib/gsm_error.cc:142 +msgid "Facility rejected" +msgstr "" + +#: gsmlib/gsm_error.cc:145 +msgid "Unknown subscriber" +msgstr "" + +#: gsmlib/gsm_error.cc:148 +msgid "Network out of order" +msgstr "" + +#: gsmlib/gsm_error.cc:151 +msgid "Temporary failure" +msgstr "" + +#: gsmlib/gsm_error.cc:154 +msgid "Resources unavailable, unspecified" +msgstr "" + +#: gsmlib/gsm_error.cc:157 +msgid "Requested facility not subscribed" +msgstr "" + +#: gsmlib/gsm_error.cc:160 +msgid "Requested facility not implemented" +msgstr "" + +#: gsmlib/gsm_error.cc:163 +msgid "Invalid Transaction Identifier" +msgstr "" + +#: gsmlib/gsm_error.cc:166 +msgid "Semantically incorrect message" +msgstr "" + +#: gsmlib/gsm_error.cc:169 +msgid "Invalid mandatory information" +msgstr "" + +#: gsmlib/gsm_error.cc:172 +msgid "Message type non-existent or not implemented" +msgstr "" + +#: gsmlib/gsm_error.cc:175 +msgid "Message not compatible with short message protocol state" +msgstr "" + +#: gsmlib/gsm_error.cc:178 +msgid "Information element non-existent or not implemented" +msgstr "" + +#: gsmlib/gsm_error.cc:181 +msgid "Protocol error, unspecified" +msgstr "" + +#: gsmlib/gsm_error.cc:184 +msgid "Interworking, unspecified" +msgstr "" + +#: gsmlib/gsm_error.cc:187 +msgid "Telematic interworking not supported" +msgstr "" + +#: gsmlib/gsm_error.cc:190 +msgid "Short message Type 0 not supported" +msgstr "" + +#: gsmlib/gsm_error.cc:193 +msgid "Cannot replace short message" +msgstr "" + +#: gsmlib/gsm_error.cc:196 +msgid "Unspecified TP-PID error" +msgstr "" + +#: gsmlib/gsm_error.cc:199 +msgid "Data coding scheme (alphabet) not supported" +msgstr "" + +#: gsmlib/gsm_error.cc:202 +msgid "Message class not supported" +msgstr "" + +#: gsmlib/gsm_error.cc:205 +msgid "Unspecifiec TP-DCS error" +msgstr "" + +#: gsmlib/gsm_error.cc:208 +msgid "Command cannot be actioned" +msgstr "" + +#: gsmlib/gsm_error.cc:211 +msgid "Command unsupported" +msgstr "" + +#: gsmlib/gsm_error.cc:214 +msgid "Unspecified TP-Command error" +msgstr "" + +#: gsmlib/gsm_error.cc:217 +msgid "TPDU not supported" +msgstr "" + +#: gsmlib/gsm_error.cc:220 +msgid "SC busy" +msgstr "" + +#: gsmlib/gsm_error.cc:223 +msgid "No SC subscription" +msgstr "" + +#: gsmlib/gsm_error.cc:226 +msgid "SC system failure" +msgstr "" + +#: gsmlib/gsm_error.cc:229 +msgid "Invalid SME address" +msgstr "" + +#: gsmlib/gsm_error.cc:232 +msgid "Destination SME barred" +msgstr "" + +#: gsmlib/gsm_error.cc:235 +msgid "SM Rejected-Duplicated SM" +msgstr "" + +#: gsmlib/gsm_error.cc:238 +msgid "SIM SMS storage full" +msgstr "" + +#: gsmlib/gsm_error.cc:241 +msgid "No SMS storage capability in SIM" +msgstr "" + +#: gsmlib/gsm_error.cc:244 +msgid "Error in MS" +msgstr "" + +#: gsmlib/gsm_error.cc:247 +msgid "Memory Capacity Exceed" +msgstr "" + +#: gsmlib/gsm_error.cc:250 +msgid "Unspecified error cause" +msgstr "" + +#: gsmlib/gsm_error.cc:253 +msgid "ME failure" +msgstr "" + +#: gsmlib/gsm_error.cc:256 +msgid "SMS service of ME reserved" +msgstr "" + +#: gsmlib/gsm_error.cc:265 +msgid "invalid PDU mode parameter" +msgstr "" + +#: gsmlib/gsm_error.cc:268 +msgid "invalid text mode parameter" +msgstr "" + +#: gsmlib/gsm_error.cc:277 +msgid "PH-SIM PIN required" +msgstr "" + +#: gsmlib/gsm_error.cc:301 +msgid "invalid memory index" +msgstr "" + +#: gsmlib/gsm_error.cc:307 +msgid "SMSC address unknown" +msgstr "" + +#: gsmlib/gsm_error.cc:316 +msgid "no +CNMA acknowledgement expected" +msgstr "" + +#: gsmlib/gsm_error.cc:319 +msgid "unknown error" +msgstr "" + +#: gsmlib/gsm_error.cc:322 +#, c-format +msgid "invalid SMS error %d" +msgstr "" + +#: gsmlib/gsm_error.cc:335 +msgid "Short message received by the SME" +msgstr "" + +#: gsmlib/gsm_error.cc:338 +msgid "" +"Short message forwarded by the SC to the SME but the SC is unable to confirm " +"delivery" +msgstr "" + +#: gsmlib/gsm_error.cc:342 +msgid "Short message replaced by the SC" +msgstr "" + +#: gsmlib/gsm_error.cc:345 gsmlib/gsm_error.cc:373 gsmlib/gsm_error.cc:418 +msgid "reserved" +msgstr "" + +#: gsmlib/gsm_error.cc:358 +msgid "SME busy" +msgstr "" + +#: gsmlib/gsm_error.cc:361 +msgid "No response from SME" +msgstr "" + +#: gsmlib/gsm_error.cc:364 +msgid "Service rejected" +msgstr "" + +#: gsmlib/gsm_error.cc:367 gsmlib/gsm_error.cc:400 +msgid "Quality of service not available" +msgstr "" + +#: gsmlib/gsm_error.cc:370 +msgid "Error in SME" +msgstr "" + +#: gsmlib/gsm_error.cc:377 +msgid " (Temporary error, SC is not making any more transfer attempts)" +msgstr "" + +#: gsmlib/gsm_error.cc:380 +msgid " (Temporary error, SC still trying to transfer SM)" +msgstr "" + +#: gsmlib/gsm_error.cc:388 +msgid "Remote Procedure Error" +msgstr "" + +#: gsmlib/gsm_error.cc:391 +msgid "Incompatible destination" +msgstr "" + +#: gsmlib/gsm_error.cc:394 +msgid "Connection rejected by SME" +msgstr "" + +#: gsmlib/gsm_error.cc:397 +msgid "Not obtainable" +msgstr "" + +#: gsmlib/gsm_error.cc:403 +msgid "No interworking available" +msgstr "" + +#: gsmlib/gsm_error.cc:406 +msgid "SM validity period expired" +msgstr "" + +#: gsmlib/gsm_error.cc:409 +msgid "SM deleted by originating SME" +msgstr "" + +#: gsmlib/gsm_error.cc:412 +msgid "SM deleted by SC administration" +msgstr "" + +#: gsmlib/gsm_error.cc:415 +msgid "SM does not exit" +msgstr "" + +#: gsmlib/gsm_error.cc:421 +msgid " (Permanent Error, SC is not making any more transfer attempts)" +msgstr "" + +#: gsmlib/gsm_event.cc:80 +#, c-format +msgid "unexpected number format %d" +msgstr "" + +#: gsmlib/gsm_event.cc:100 +#, c-format +msgid "unexpected unsolicited event '%s'" +msgstr "" + +#: gsmlib/gsm_me_ta.cc:538 +msgid "unable to set operator" +msgstr "" + +#: gsmlib/gsm_me_ta.cc:665 +msgid "call forward time must be in the range 0..30" +msgstr "" + +#: gsmlib/gsm_me_ta.cc:813 +msgid "Functionality Level commands not supported by ME" +msgstr "" + +#. If the number was just out of range, we get here. +#: gsmlib/gsm_me_ta.cc:832 +msgid "Requested Functionality Level out of range" +msgstr "" + +#: gsmlib/gsm_me_ta.cc:943 +msgid "unsupported alphabet for SMS" +msgstr "" + +#: gsmlib/gsm_me_ta.cc:952 +msgid "SMS text is larger than allowed" +msgstr "" + +#: gsmlib/gsm_me_ta.cc:964 +msgid "not more than 255 concatenated SMSs allowed" +msgstr "" + +#: gsmlib/gsm_me_ta.cc:997 +msgid "only serviceLevel 0 or 1 supported" +msgstr "" + +#: gsmlib/gsm_me_ta.cc:1110 gsmlib/gsm_me_ta.cc:1152 +msgid "cannot route SMS messages to TE" +msgstr "" + +#: gsmlib/gsm_me_ta.cc:1124 gsmlib/gsm_me_ta.cc:1166 +msgid "cannot route cell broadcast messages to TE" +msgstr "" + +#: gsmlib/gsm_me_ta.cc:1136 +msgid "cannot route status reports messages to TE" +msgstr "" + +#: gsmlib/gsm_me_ta.cc:1180 +msgid "cannot route status report messages to TE" +msgstr "" + +#: gsmlib/gsm_parser.cc:51 +msgid "expected parameter" +msgstr "" + +#: gsmlib/gsm_parser.cc:71 +msgid "expected '\"'" +msgstr "" + +#: gsmlib/gsm_parser.cc:109 +msgid "expected number" +msgstr "" + +#: gsmlib/gsm_parser.cc:120 +#, c-format +msgid "unexpected end of string '%s'" +msgstr "" + +#: gsmlib/gsm_parser.cc:124 +#, c-format +msgid " (at position %d of string '%s')" +msgstr "" + +#: gsmlib/gsm_parser.cc:141 +#, c-format +msgid "expected '%c'" +msgstr "" + +#: gsmlib/gsm_parser.cc:165 +msgid "expected ')' or ','" +msgstr "" + +#: gsmlib/gsm_parser.cc:251 +msgid "expected ')', ',' or '-'" +msgstr "" + +#: gsmlib/gsm_parser.cc:257 +msgid "range of the form a-b-c not allowed" +msgstr "" + +#: gsmlib/gsm_parser.cc:264 +msgid "range of the form a- no allowed" +msgstr "" + +#: gsmlib/gsm_parser.cc:350 +msgid "expected comma" +msgstr "" + +#: gsmlib/gsm_parser.cc:367 +msgid "expected end of line" +msgstr "" + +#: gsmlib/gsm_phonebook.cc:47 +#, c-format +msgid "" +"length of text '%s' exceeds maximum text length (%d characters) of phonebook " +"'%s'" +msgstr "" + +#: gsmlib/gsm_phonebook.cc:55 +#, c-format +msgid "" +"length of telephone number '%s' exceeds maximum telephone number length (%d " +"characters) of phonebook '%s'" +msgstr "" + +#: gsmlib/gsm_phonebook.cc:275 +msgid "phonebook full" +msgstr "" + +#: gsmlib/gsm_phonebook.cc:291 +msgid "attempt to overwrite phonebook entry" +msgstr "" + +#: gsmlib/gsm_phonebook.cc:569 +msgid "SIM card changed while accessing phonebook" +msgstr "" + +#: gsmlib/gsm_sms.cc:66 gsmlib/gsm_sms.cc:85 gsmlib/gsm_sms.cc:175 +msgid "unhandled SMS TPDU type" +msgstr "" + +#: gsmlib/gsm_sms.cc:107 +msgid "can only send SMS-SUBMIT and SMS-COMMAND TPDUs" +msgstr "" + +#: gsmlib/gsm_sms.cc:111 +msgid "no device given for sending SMS" +msgstr "" + +#: gsmlib/gsm_sms.cc:283 +msgid "Message type: SMS-DELIVER" +msgstr "" + +#: gsmlib/gsm_sms.cc:284 gsmlib/gsm_sms.cc:426 gsmlib/gsm_sms.cc:531 +#: gsmlib/gsm_sms.cc:618 gsmlib/gsm_sms.cc:723 gsmlib/gsm_sms.cc:829 +msgid "SC address: '" +msgstr "" + +#: gsmlib/gsm_sms.cc:285 gsmlib/gsm_sms.cc:532 +msgid "More messages to send: " +msgstr "" + +#: gsmlib/gsm_sms.cc:286 gsmlib/gsm_sms.cc:445 +msgid "Reply path: " +msgstr "" + +#: gsmlib/gsm_sms.cc:287 gsmlib/gsm_sms.cc:446 +msgid "User data header indicator: " +msgstr "" + +#: gsmlib/gsm_sms.cc:289 +msgid "Status report indication: " +msgstr "" + +#: gsmlib/gsm_sms.cc:290 +msgid "Originating address: '" +msgstr "" + +#: gsmlib/gsm_sms.cc:292 gsmlib/gsm_sms.cc:452 gsmlib/gsm_sms.cc:621 +#: gsmlib/gsm_sms.cc:729 gsmlib/gsm_sms.cc:836 +msgid "Protocol identifier: 0x" +msgstr "" + +#: gsmlib/gsm_sms.cc:294 gsmlib/gsm_sms.cc:454 gsmlib/gsm_sms.cc:733 +#: gsmlib/gsm_sms.cc:840 +msgid "Data coding scheme: " +msgstr "" + +#: gsmlib/gsm_sms.cc:295 gsmlib/gsm_sms.cc:536 gsmlib/gsm_sms.cc:830 +msgid "SC timestamp: " +msgstr "" + +#: gsmlib/gsm_sms.cc:296 gsmlib/gsm_sms.cc:456 gsmlib/gsm_sms.cc:735 +#: gsmlib/gsm_sms.cc:842 +msgid "User data length: " +msgstr "" + +#: gsmlib/gsm_sms.cc:297 gsmlib/gsm_sms.cc:457 +msgid "User data header: 0x" +msgstr "" + +#: gsmlib/gsm_sms.cc:302 gsmlib/gsm_sms.cc:461 gsmlib/gsm_sms.cc:736 +#: gsmlib/gsm_sms.cc:843 +msgid "User data: '" +msgstr "" + +#: gsmlib/gsm_sms.cc:425 +msgid "Message type: SMS-SUBMIT" +msgstr "" + +#: gsmlib/gsm_sms.cc:427 +msgid "Reject duplicates: " +msgstr "" + +#: gsmlib/gsm_sms.cc:428 +msgid "Validity period format: " +msgstr "" + +#: gsmlib/gsm_sms.cc:432 gsmlib/gsm_sms_codec.cc:184 +msgid "not present" +msgstr "" + +#: gsmlib/gsm_sms.cc:435 +msgid "relative" +msgstr "" + +#: gsmlib/gsm_sms.cc:438 +msgid "absolute" +msgstr "" + +#: gsmlib/gsm_sms.cc:448 gsmlib/gsm_sms.cc:620 +msgid "Status report request: " +msgstr "" + +#: gsmlib/gsm_sms.cc:449 gsmlib/gsm_sms.cc:534 gsmlib/gsm_sms.cc:619 +msgid "Message reference: " +msgstr "" + +#: gsmlib/gsm_sms.cc:450 gsmlib/gsm_sms.cc:626 +msgid "Destination address: '" +msgstr "" + +#: gsmlib/gsm_sms.cc:455 +msgid "Validity period: " +msgstr "" + +#: gsmlib/gsm_sms.cc:530 +msgid "Message type: SMS-STATUS-REPORT" +msgstr "" + +#: gsmlib/gsm_sms.cc:533 +msgid "Status report qualifier: " +msgstr "" + +#: gsmlib/gsm_sms.cc:535 +msgid "Recipient address: '" +msgstr "" + +#: gsmlib/gsm_sms.cc:537 +msgid "Discharge time: " +msgstr "" + +#: gsmlib/gsm_sms.cc:538 +msgid "Status: 0x" +msgstr "" + +#: gsmlib/gsm_sms.cc:617 +msgid "Message type: SMS-COMMAND" +msgstr "" + +#: gsmlib/gsm_sms.cc:623 +msgid "Command type: 0x" +msgstr "" + +#: gsmlib/gsm_sms.cc:625 +msgid "Message number: " +msgstr "" + +#: gsmlib/gsm_sms.cc:628 +msgid "Command data length: " +msgstr "" + +#: gsmlib/gsm_sms.cc:629 +msgid "Command data: '" +msgstr "" + +#: gsmlib/gsm_sms.cc:722 +msgid "Message type: SMS-DELIVER-REPORT" +msgstr "" + +#: gsmlib/gsm_sms.cc:724 gsmlib/gsm_sms.cc:831 +msgid "Protocol identifier present: " +msgstr "" + +#: gsmlib/gsm_sms.cc:726 gsmlib/gsm_sms.cc:833 +msgid "Data coding scheme present: " +msgstr "" + +#: gsmlib/gsm_sms.cc:727 gsmlib/gsm_sms.cc:834 +msgid "User data length present: " +msgstr "" + +#: gsmlib/gsm_sms.cc:828 +msgid "Message type: SMS-SUBMIT-REPORT" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:189 gsmlib/gsm_sms_codec.cc:191 +msgid " minutes" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:193 +msgid " days" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:195 +msgid " weeks" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:214 +msgid "compressed " +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:219 +msgid "voicemail message waiting" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:222 +msgid "fax message waiting" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:225 +msgid "electronic mail message waiting" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:228 +msgid "other message waiting" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:235 +msgid "default alphabet" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:238 +msgid "8-bit alphabet" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:241 +msgid "16-bit alphabet" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:244 +msgid "reserved alphabet" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:257 +msgid "bad hexadecimal PDU format" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:286 gsmlib/gsm_sms_codec.cc:296 +#: gsmlib/gsm_sms_codec.cc:311 gsmlib/gsm_sms_codec.cc:319 +#: gsmlib/gsm_sms_codec.cc:340 gsmlib/gsm_sms_codec.cc:348 +#: gsmlib/gsm_sms_codec.cc:369 gsmlib/gsm_sms_codec.cc:383 +msgid "premature end of PDU" +msgstr "" + +#: gsmlib/gsm_sms_codec.cc:474 +msgid "unknown time period format" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:120 +msgid "interrupted when reading from TA" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:135 +msgid "end of file when reading from TA" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:145 +msgid "reading from TA" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:150 +msgid "timeout when reading from TA" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:177 +#, c-format +msgid "opening device '%s'" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:184 +msgid "getting file status flags failed" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:189 +msgid "switching of non-blocking mode failed" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:204 +msgid "clearing DTR failed" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:210 +msgid "setting DTR failed" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:215 +#, c-format +msgid "tcgetattr device '%s'" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:244 +#, c-format +msgid "tcsetattr device '%s'" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:302 +#, c-format +msgid "reset modem failed '%s'" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:347 gsmlib/gsm_unix_serial.cc:379 +msgid "interrupted when writing to TA" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:362 gsmlib/gsm_unix_serial.cc:371 +msgid "writing to TA" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:392 +msgid "timeout when writing to TA" +msgstr "" + +#: gsmlib/gsm_unix_serial.cc:453 +#, c-format +msgid "unknown baudrate '%s'" +msgstr "" + +#: gsmlib/gsm_util.cc:206 +#, c-format +msgid "error when calling stat('%s') (errno: %d/%s)" +msgstr "" + +#: gsmlib/gsm_util.cc:237 +#, c-format +msgid "file '%s' is neither file nor character device" +msgstr "" + +#: gsmlib/gsm_util.cc:241 +msgid "maxmimum number of symbolic links exceeded" +msgstr "" + +#: gsmlib/gsm_util.cc:251 +#, c-format +msgid "error renaming '%s' to '%s'" +msgstr "" + +#: gsmlib/gsm_util.cc:349 +#, c-format +msgid "text '%s' contains illegal character '\"'" +msgstr "" + +#: gsmlib/gsm_util.cc:359 +#, c-format +msgid "illegal character in telephone number '%s'" +msgstr "" + +#: gsmlib/gsm_sorted_phonebook.cc:95 +#, c-format +msgid "error reading from file '%s" +msgstr "" + +#: gsmlib/gsm_sorted_phonebook.cc:109 +#, c-format +msgid "entry '%s' lacks index" +msgstr "" + +#: gsmlib/gsm_sorted_phonebook.cc:118 gsmlib/gsm_sorted_phonebook.cc:124 +#, c-format +msgid "line '%s' has invalid format" +msgstr "" + +#: gsmlib/gsm_sorted_phonebook.cc:173 gsmlib/gsm_sorted_sms_store.cc:159 +#, c-format +msgid "error opening file '%s' for writing" +msgstr "" + +#: gsmlib/gsm_sorted_phonebook.cc:174 gsmlib/gsm_sorted_phonebook.cc:193 +#: gsmlib/gsm_sorted_sms_store.cc:67 gsmlib/gsm_sorted_sms_store.cc:160 +msgid "" +msgstr "" + +#: gsmlib/gsm_sorted_phonebook.cc:192 gsmlib/gsm_sorted_sms_store.cc:66 +#, c-format +msgid "error writing to file '%s'" +msgstr "" + +#: gsmlib/gsm_sorted_phonebook.cc:216 +msgid "attempt to change phonebook read from " +msgstr "" + +#: gsmlib/gsm_sorted_phonebook.cc:229 gsmlib/gsm_sorted_sms_store.cc:215 +#, c-format +msgid "cannot open file '%s'" +msgstr "" + +#: gsmlib/gsm_sorted_phonebook.cc:244 gsmlib/gsm_sorted_sms_store.cc:55 +#: gsmlib/gsm_sorted_sms_store.cc:228 +msgid "" +msgstr "" + +#: gsmlib/gsm_sorted_phonebook.cc:361 +msgid "indices must be unique in phonebook" +msgstr "" + +#: gsmlib/gsm_sorted_sms_store.cc:54 +#, c-format +msgid "error reading from file '%s'" +msgstr "" + +#: gsmlib/gsm_sorted_sms_store.cc:87 +#, c-format +msgid "file '%s' has wrong version" +msgstr "" + +#: gsmlib/gsm_sorted_sms_store.cc:99 gsmlib/gsm_sorted_sms_store.cc:111 +#, c-format +msgid "corrupt SMS store file '%s'" +msgstr "" + +#: gsmlib/gsm_sorted_sms_store.cc:204 +msgid "attempt to change SMS store read from " +msgstr "" diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/stamp-cat-id b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/stamp-cat-id new file mode 100644 index 0000000000..9788f70238 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/po/stamp-cat-id @@ -0,0 +1 @@ +timestamp diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/Makefile.am b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/Makefile.am new file mode 100644 index 0000000000..53f51ac19a --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/Makefile.am @@ -0,0 +1,15 @@ +## Process this file with automake to produce Makefile.in +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: scripts Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 5.6.1999 +# ************************************************************************* + +EXTRA_DIST = config.sub ltconfig missing \ + config.guess install-sh ltmain.sh mkinstalldirs debugconfig.sh diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/Makefile.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/Makefile.in new file mode 100644 index 0000000000..6129036172 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/Makefile.in @@ -0,0 +1,259 @@ +# Makefile.in generated by automake 1.6.3 from Makefile.am. +# @configure_input@ + +# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002 +# Free Software Foundation, Inc. +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +@SET_MAKE@ + +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: scripts Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 5.6.1999 +# ************************************************************************* +SHELL = @SHELL@ + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ + +bindir = @bindir@ +sbindir = @sbindir@ +libexecdir = @libexecdir@ +datadir = @datadir@ +sysconfdir = @sysconfdir@ +sharedstatedir = @sharedstatedir@ +localstatedir = @localstatedir@ +libdir = @libdir@ +infodir = @infodir@ +mandir = @mandir@ +includedir = @includedir@ +oldincludedir = /usr/include +pkgdatadir = $(datadir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ +top_builddir = .. + +ACLOCAL = @ACLOCAL@ +AUTOCONF = @AUTOCONF@ +AUTOMAKE = @AUTOMAKE@ +AUTOHEADER = @AUTOHEADER@ + +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd +INSTALL = @INSTALL@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_DATA = @INSTALL_DATA@ +install_sh_DATA = $(install_sh) -c -m 644 +install_sh_PROGRAM = $(install_sh) -c +install_sh_SCRIPT = $(install_sh) -c +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +INSTALL_HEADER = $(INSTALL_DATA) +transform = @program_transform_name@ +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +host_alias = @host_alias@ +host_triplet = @host@ + +EXEEXT = @EXEEXT@ +OBJEXT = @OBJEXT@ +PATH_SEPARATOR = @PATH_SEPARATOR@ +AMTAR = @AMTAR@ +AS = @AS@ +AWK = @AWK@ +BUILD_INCLUDED_LIBINTL = @BUILD_INCLUDED_LIBINTL@ +CATOBJEXT = @CATOBJEXT@ +CC = @CC@ +CPP = @CPP@ +CXX = @CXX@ +DATADIRNAME = @DATADIRNAME@ +DEPDIR = @DEPDIR@ +DLLTOOL = @DLLTOOL@ +ECHO = @ECHO@ +GENCAT = @GENCAT@ +GLIBC21 = @GLIBC21@ +GMSGFMT = @GMSGFMT@ +GSM_VERSION = @GSM_VERSION@ +HAVE_LIB = @HAVE_LIB@ +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ +INSTOBJEXT = @INSTOBJEXT@ +INTLBISON = @INTLBISON@ +INTLLIBS = @INTLLIBS@ +INTLOBJS = @INTLOBJS@ +INTL_LIBTOOL_SUFFIX_PREFIX = @INTL_LIBTOOL_SUFFIX_PREFIX@ +LIB = @LIB@ +LIBICONV = @LIBICONV@ +LIBINTL = @LIBINTL@ +LIBTOOL = @LIBTOOL@ +LN_S = @LN_S@ +LTLIB = @LTLIB@ +LTLIBICONV = @LTLIBICONV@ +LTLIBINTL = @LTLIBINTL@ +MKINSTALLDIRS = @MKINSTALLDIRS@ +OBJDUMP = @OBJDUMP@ +PACKAGE = @PACKAGE@ +POSUB = @POSUB@ +RANLIB = @RANLIB@ +STRIP = @STRIP@ +USE_INCLUDED_LIBINTL = @USE_INCLUDED_LIBINTL@ +USE_NLS = @USE_NLS@ +VERSION = @VERSION@ +am__include = @am__include@ +am__quote = @am__quote@ +install_sh = @install_sh@ + +EXTRA_DIST = config.sub ltconfig missing \ + config.guess install-sh ltmain.sh mkinstalldirs debugconfig.sh + +subdir = scripts +mkinstalldirs = $(SHELL) $(top_srcdir)/scripts/mkinstalldirs +CONFIG_HEADER = $(top_builddir)/gsm_config.h +CONFIG_CLEAN_FILES = +DIST_SOURCES = +DIST_COMMON = Makefile.am Makefile.in config.guess config.rpath \ + config.sub depcomp install-sh ltconfig ltmain.sh missing \ + mkinstalldirs +all: all-am + +.SUFFIXES: +$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4) + cd $(top_srcdir) && \ + $(AUTOMAKE) --gnu scripts/Makefile +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe) + +mostlyclean-libtool: + -rm -f *.lo + +clean-libtool: + -rm -rf .libs _libs + +distclean-libtool: + -rm -f libtool +uninstall-info-am: +tags: TAGS +TAGS: + +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) + +top_distdir = .. +distdir = $(top_distdir)/$(PACKAGE)-$(VERSION) + +distdir: $(DISTFILES) + @list='$(DISTFILES)'; for file in $$list; do \ + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ + dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \ + if test "$$dir" != "$$file" && test "$$dir" != "."; then \ + dir="/$$dir"; \ + $(mkinstalldirs) "$(distdir)$$dir"; \ + else \ + dir=''; \ + fi; \ + if test -d $$d/$$file; then \ + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ + cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ + fi; \ + cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ + else \ + test -f $(distdir)/$$file \ + || cp -p $$d/$$file $(distdir)/$$file \ + || exit 1; \ + fi; \ + done +check-am: all-am +check: check-am +all-am: Makefile + +installdirs: + +install: install-am +install-exec: install-exec-am +install-data: install-data-am +uninstall: uninstall-am + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am + +installcheck: installcheck-am +install-strip: + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + INSTALL_STRIP_FLAG=-s \ + `test -z '$(STRIP)' || \ + echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -rm -f Makefile $(CONFIG_CLEAN_FILES) + +maintainer-clean-generic: + @echo "This command is intended for maintainers to use" + @echo "it deletes files that may require special tools to rebuild." +clean: clean-am + +clean-am: clean-generic clean-libtool mostlyclean-am + +distclean: distclean-am + +distclean-am: clean-am distclean-generic distclean-libtool + +dvi: dvi-am + +dvi-am: + +info: info-am + +info-am: + +install-data-am: + +install-exec-am: + +install-info: install-info-am + +install-man: + +installcheck-am: + +maintainer-clean: maintainer-clean-am + +maintainer-clean-am: distclean-am maintainer-clean-generic + +mostlyclean: mostlyclean-am + +mostlyclean-am: mostlyclean-generic mostlyclean-libtool + +uninstall-am: uninstall-info-am + +.PHONY: all all-am check check-am clean clean-generic clean-libtool \ + distclean distclean-generic distclean-libtool distdir dvi \ + dvi-am info info-am install install-am install-data \ + install-data-am install-exec install-exec-am install-info \ + install-info-am install-man install-strip installcheck \ + installcheck-am installdirs maintainer-clean \ + maintainer-clean-generic mostlyclean mostlyclean-generic \ + mostlyclean-libtool uninstall uninstall-am uninstall-info-am + +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/config.guess b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/config.guess new file mode 100755 index 0000000000..0f0fe712ae --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/config.guess @@ -0,0 +1,1516 @@ +#! /bin/sh +# Attempt to guess a canonical system name. +# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, +# 2000, 2001, 2002, 2003, 2004, 2005, 2006 Free Software Foundation, +# Inc. + +timestamp='2007-03-06' + +# This file 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 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, 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 Per Bothner . +# Please send patches to . Submit a context +# diff and a properly formatted ChangeLog entry. +# +# This script attempts to guess a canonical system name similar to +# config.sub. If it succeeds, it prints the system name on stdout, and +# exits with 0. Otherwise, it exits with 1. +# +# The plan is that this can be called by configure scripts if you +# don't specify an explicit build system type. + +me=`echo "$0" | sed -e 's,.*/,,'` + +usage="\ +Usage: $0 [OPTION] + +Output the configuration name of the system \`$me' is run on. + +Operation modes: + -h, --help print this help, then exit + -t, --time-stamp print date of last modification, then exit + -v, --version print version number, then exit + +Report bugs and patches to ." + +version="\ +GNU config.guess ($timestamp) + +Originally written by Per Bothner. +Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005 +Free Software Foundation, Inc. + +This is free software; see the source for copying conditions. There is NO +warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." + +help=" +Try \`$me --help' for more information." + +# Parse command line +while test $# -gt 0 ; do + case $1 in + --time-stamp | --time* | -t ) + echo "$timestamp" ; exit ;; + --version | -v ) + echo "$version" ; exit ;; + --help | --h* | -h ) + echo "$usage"; exit ;; + -- ) # Stop option processing + shift; break ;; + - ) # Use stdin as input. + break ;; + -* ) + echo "$me: invalid option $1$help" >&2 + exit 1 ;; + * ) + break ;; + esac +done + +if test $# != 0; then + echo "$me: too many arguments$help" >&2 + exit 1 +fi + +trap 'exit 1' 1 2 15 + +# CC_FOR_BUILD -- compiler used by this script. Note that the use of a +# compiler to aid in system detection is discouraged as it requires +# temporary files to be created and, as you can see below, it is a +# headache to deal with in a portable fashion. + +# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still +# use `HOST_CC' if defined, but it is deprecated. + +# Portable tmp directory creation inspired by the Autoconf team. + +set_cc_for_build=' +trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ; +trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ; +: ${TMPDIR=/tmp} ; + { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } || + { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } || + { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } || + { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ; +dummy=$tmp/dummy ; +tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ; +case $CC_FOR_BUILD,$HOST_CC,$CC in + ,,) echo "int x;" > $dummy.c ; + for c in cc gcc c89 c99 ; do + if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then + CC_FOR_BUILD="$c"; break ; + fi ; + done ; + if test x"$CC_FOR_BUILD" = x ; then + CC_FOR_BUILD=no_compiler_found ; + fi + ;; + ,,*) CC_FOR_BUILD=$CC ;; + ,*,*) CC_FOR_BUILD=$HOST_CC ;; +esac ; set_cc_for_build= ;' + +# This is needed to find uname on a Pyramid OSx when run in the BSD universe. +# (ghazi@noc.rutgers.edu 1994-08-24) +if (test -f /.attbin/uname) >/dev/null 2>&1 ; then + PATH=$PATH:/.attbin ; export PATH +fi + +UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown +UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown +UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown +UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown + +# Note: order is significant - the case branches are not exclusive. + +case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in + *:NetBSD:*:*) + # NetBSD (nbsd) targets should (where applicable) match one or + # more of the tupples: *-*-netbsdelf*, *-*-netbsdaout*, + # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently + # switched to ELF, *-*-netbsd* would select the old + # object file format. This provides both forward + # compatibility and a consistent mechanism for selecting the + # object file format. + # + # Note: NetBSD doesn't particularly care about the vendor + # portion of the name. We always set it to "unknown". + sysctl="sysctl -n hw.machine_arch" + UNAME_MACHINE_ARCH=`(/sbin/$sysctl 2>/dev/null || \ + /usr/sbin/$sysctl 2>/dev/null || echo unknown)` + case "${UNAME_MACHINE_ARCH}" in + armeb) machine=armeb-unknown ;; + arm*) machine=arm-unknown ;; + sh3el) machine=shl-unknown ;; + sh3eb) machine=sh-unknown ;; + sh5el) machine=sh5le-unknown ;; + *) machine=${UNAME_MACHINE_ARCH}-unknown ;; + esac + # The Operating System including object format, if it has switched + # to ELF recently, or will in the future. + case "${UNAME_MACHINE_ARCH}" in + arm*|i386|m68k|ns32k|sh3*|sparc|vax) + eval $set_cc_for_build + if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \ + | grep __ELF__ >/dev/null + then + # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout). + # Return netbsd for either. FIX? + os=netbsd + else + os=netbsdelf + fi + ;; + *) + os=netbsd + ;; + esac + # The OS release + # Debian GNU/NetBSD machines have a different userland, and + # thus, need a distinct triplet. However, they do not need + # kernel version information, so it can be replaced with a + # suitable tag, in the style of linux-gnu. + case "${UNAME_VERSION}" in + Debian*) + release='-gnu' + ;; + *) + release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'` + ;; + esac + # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM: + # contains redundant information, the shorter form: + # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used. + echo "${machine}-${os}${release}" + exit ;; + *:OpenBSD:*:*) + UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'` + echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE} + exit ;; + *:ekkoBSD:*:*) + echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE} + exit ;; + *:SolidBSD:*:*) + echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE} + exit ;; + macppc:MirBSD:*:*) + echo powerpc-unknown-mirbsd${UNAME_RELEASE} + exit ;; + *:MirBSD:*:*) + echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE} + exit ;; + alpha:OSF1:*:*) + case $UNAME_RELEASE in + *4.0) + UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` + ;; + *5.*) + UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` + ;; + esac + # According to Compaq, /usr/sbin/psrinfo has been available on + # OSF/1 and Tru64 systems produced since 1995. I hope that + # covers most systems running today. This code pipes the CPU + # types through head -n 1, so we only detect the type of CPU 0. + ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1` + case "$ALPHA_CPU_TYPE" in + "EV4 (21064)") + UNAME_MACHINE="alpha" ;; + "EV4.5 (21064)") + UNAME_MACHINE="alpha" ;; + "LCA4 (21066/21068)") + UNAME_MACHINE="alpha" ;; + "EV5 (21164)") + UNAME_MACHINE="alphaev5" ;; + "EV5.6 (21164A)") + UNAME_MACHINE="alphaev56" ;; + "EV5.6 (21164PC)") + UNAME_MACHINE="alphapca56" ;; + "EV5.7 (21164PC)") + UNAME_MACHINE="alphapca57" ;; + "EV6 (21264)") + UNAME_MACHINE="alphaev6" ;; + "EV6.7 (21264A)") + UNAME_MACHINE="alphaev67" ;; + "EV6.8CB (21264C)") + UNAME_MACHINE="alphaev68" ;; + "EV6.8AL (21264B)") + UNAME_MACHINE="alphaev68" ;; + "EV6.8CX (21264D)") + UNAME_MACHINE="alphaev68" ;; + "EV6.9A (21264/EV69A)") + UNAME_MACHINE="alphaev69" ;; + "EV7 (21364)") + UNAME_MACHINE="alphaev7" ;; + "EV7.9 (21364A)") + UNAME_MACHINE="alphaev79" ;; + esac + # A Pn.n version is a patched version. + # A Vn.n version is a released version. + # A Tn.n version is a released field test version. + # A Xn.n version is an unreleased experimental baselevel. + # 1.2 uses "1.2" for uname -r. + echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` + exit ;; + Alpha\ *:Windows_NT*:*) + # How do we know it's Interix rather than the generic POSIX subsystem? + # Should we change UNAME_MACHINE based on the output of uname instead + # of the specific Alpha model? + echo alpha-pc-interix + exit ;; + 21064:Windows_NT:50:3) + echo alpha-dec-winnt3.5 + exit ;; + Amiga*:UNIX_System_V:4.0:*) + echo m68k-unknown-sysv4 + exit ;; + *:[Aa]miga[Oo][Ss]:*:*) + echo ${UNAME_MACHINE}-unknown-amigaos + exit ;; + *:[Mm]orph[Oo][Ss]:*:*) + echo ${UNAME_MACHINE}-unknown-morphos + exit ;; + *:OS/390:*:*) + echo i370-ibm-openedition + exit ;; + *:z/VM:*:*) + echo s390-ibm-zvmoe + exit ;; + *:OS400:*:*) + echo powerpc-ibm-os400 + exit ;; + arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*) + echo arm-acorn-riscix${UNAME_RELEASE} + exit ;; + arm:riscos:*:*|arm:RISCOS:*:*) + echo arm-unknown-riscos + exit ;; + SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*) + echo hppa1.1-hitachi-hiuxmpp + exit ;; + Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*) + # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE. + if test "`(/bin/universe) 2>/dev/null`" = att ; then + echo pyramid-pyramid-sysv3 + else + echo pyramid-pyramid-bsd + fi + exit ;; + NILE*:*:*:dcosx) + echo pyramid-pyramid-svr4 + exit ;; + DRS?6000:unix:4.0:6*) + echo sparc-icl-nx6 + exit ;; + DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*) + case `/usr/bin/uname -p` in + sparc) echo sparc-icl-nx7; exit ;; + esac ;; + sun4H:SunOS:5.*:*) + echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*) + echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + i86pc:SunOS:5.*:*) + echo i386-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + sun4*:SunOS:6*:*) + # According to config.sub, this is the proper way to canonicalize + # SunOS6. Hard to guess exactly what SunOS6 will be like, but + # it's likely to be more like Solaris than SunOS4. + echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + sun4*:SunOS:*:*) + case "`/usr/bin/arch -k`" in + Series*|S4*) + UNAME_RELEASE=`uname -v` + ;; + esac + # Japanese Language versions have a version number like `4.1.3-JL'. + echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'` + exit ;; + sun3*:SunOS:*:*) + echo m68k-sun-sunos${UNAME_RELEASE} + exit ;; + sun*:*:4.2BSD:*) + UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null` + test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3 + case "`/bin/arch`" in + sun3) + echo m68k-sun-sunos${UNAME_RELEASE} + ;; + sun4) + echo sparc-sun-sunos${UNAME_RELEASE} + ;; + esac + exit ;; + aushp:SunOS:*:*) + echo sparc-auspex-sunos${UNAME_RELEASE} + exit ;; + # The situation for MiNT is a little confusing. The machine name + # can be virtually everything (everything which is not + # "atarist" or "atariste" at least should have a processor + # > m68000). The system name ranges from "MiNT" over "FreeMiNT" + # to the lowercase version "mint" (or "freemint"). Finally + # the system name "TOS" denotes a system which is actually not + # MiNT. But MiNT is downward compatible to TOS, so this should + # be no problem. + atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*) + echo m68k-atari-mint${UNAME_RELEASE} + exit ;; + atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*) + echo m68k-atari-mint${UNAME_RELEASE} + exit ;; + *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) + echo m68k-atari-mint${UNAME_RELEASE} + exit ;; + milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) + echo m68k-milan-mint${UNAME_RELEASE} + exit ;; + hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) + echo m68k-hades-mint${UNAME_RELEASE} + exit ;; + *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) + echo m68k-unknown-mint${UNAME_RELEASE} + exit ;; + m68k:machten:*:*) + echo m68k-apple-machten${UNAME_RELEASE} + exit ;; + powerpc:machten:*:*) + echo powerpc-apple-machten${UNAME_RELEASE} + exit ;; + RISC*:Mach:*:*) + echo mips-dec-mach_bsd4.3 + exit ;; + RISC*:ULTRIX:*:*) + echo mips-dec-ultrix${UNAME_RELEASE} + exit ;; + VAX*:ULTRIX*:*:*) + echo vax-dec-ultrix${UNAME_RELEASE} + exit ;; + 2020:CLIX:*:* | 2430:CLIX:*:*) + echo clipper-intergraph-clix${UNAME_RELEASE} + exit ;; + mips:*:*:UMIPS | mips:*:*:RISCos) + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c +#ifdef __cplusplus +#include /* for printf() prototype */ + int main (int argc, char *argv[]) { +#else + int main (argc, argv) int argc; char *argv[]; { +#endif + #if defined (host_mips) && defined (MIPSEB) + #if defined (SYSTYPE_SYSV) + printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0); + #endif + #if defined (SYSTYPE_SVR4) + printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0); + #endif + #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) + printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0); + #endif + #endif + exit (-1); + } +EOF + $CC_FOR_BUILD -o $dummy $dummy.c && + dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` && + SYSTEM_NAME=`$dummy $dummyarg` && + { echo "$SYSTEM_NAME"; exit; } + echo mips-mips-riscos${UNAME_RELEASE} + exit ;; + Motorola:PowerMAX_OS:*:*) + echo powerpc-motorola-powermax + exit ;; + Motorola:*:4.3:PL8-*) + echo powerpc-harris-powermax + exit ;; + Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*) + echo powerpc-harris-powermax + exit ;; + Night_Hawk:Power_UNIX:*:*) + echo powerpc-harris-powerunix + exit ;; + m88k:CX/UX:7*:*) + echo m88k-harris-cxux7 + exit ;; + m88k:*:4*:R4*) + echo m88k-motorola-sysv4 + exit ;; + m88k:*:3*:R3*) + echo m88k-motorola-sysv3 + exit ;; + AViiON:dgux:*:*) + # DG/UX returns AViiON for all architectures + UNAME_PROCESSOR=`/usr/bin/uname -p` + if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ] + then + if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \ + [ ${TARGET_BINARY_INTERFACE}x = x ] + then + echo m88k-dg-dgux${UNAME_RELEASE} + else + echo m88k-dg-dguxbcs${UNAME_RELEASE} + fi + else + echo i586-dg-dgux${UNAME_RELEASE} + fi + exit ;; + M88*:DolphinOS:*:*) # DolphinOS (SVR3) + echo m88k-dolphin-sysv3 + exit ;; + M88*:*:R3*:*) + # Delta 88k system running SVR3 + echo m88k-motorola-sysv3 + exit ;; + XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) + echo m88k-tektronix-sysv3 + exit ;; + Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD) + echo m68k-tektronix-bsd + exit ;; + *:IRIX*:*:*) + echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'` + exit ;; + ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. + echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id + exit ;; # Note that: echo "'`uname -s`'" gives 'AIX ' + i*86:AIX:*:*) + echo i386-ibm-aix + exit ;; + ia64:AIX:*:*) + if [ -x /usr/bin/oslevel ] ; then + IBM_REV=`/usr/bin/oslevel` + else + IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} + fi + echo ${UNAME_MACHINE}-ibm-aix${IBM_REV} + exit ;; + *:AIX:2:3) + if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #include + + main() + { + if (!__power_pc()) + exit(1); + puts("powerpc-ibm-aix3.2.5"); + exit(0); + } +EOF + if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` + then + echo "$SYSTEM_NAME" + else + echo rs6000-ibm-aix3.2.5 + fi + elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then + echo rs6000-ibm-aix3.2.4 + else + echo rs6000-ibm-aix3.2 + fi + exit ;; + *:AIX:*:[45]) + IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'` + if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then + IBM_ARCH=rs6000 + else + IBM_ARCH=powerpc + fi + if [ -x /usr/bin/oslevel ] ; then + IBM_REV=`/usr/bin/oslevel` + else + IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE} + fi + echo ${IBM_ARCH}-ibm-aix${IBM_REV} + exit ;; + *:AIX:*:*) + echo rs6000-ibm-aix + exit ;; + ibmrt:4.4BSD:*|romp-ibm:BSD:*) + echo romp-ibm-bsd4.4 + exit ;; + ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and + echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to + exit ;; # report: romp-ibm BSD 4.3 + *:BOSX:*:*) + echo rs6000-bull-bosx + exit ;; + DPX/2?00:B.O.S.:*:*) + echo m68k-bull-sysv3 + exit ;; + 9000/[34]??:4.3bsd:1.*:*) + echo m68k-hp-bsd + exit ;; + hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*) + echo m68k-hp-bsd4.4 + exit ;; + 9000/[34678]??:HP-UX:*:*) + HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` + case "${UNAME_MACHINE}" in + 9000/31? ) HP_ARCH=m68000 ;; + 9000/[34]?? ) HP_ARCH=m68k ;; + 9000/[678][0-9][0-9]) + if [ -x /usr/bin/getconf ]; then + sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null` + sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null` + case "${sc_cpu_version}" in + 523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0 + 528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1 + 532) # CPU_PA_RISC2_0 + case "${sc_kernel_bits}" in + 32) HP_ARCH="hppa2.0n" ;; + 64) HP_ARCH="hppa2.0w" ;; + '') HP_ARCH="hppa2.0" ;; # HP-UX 10.20 + esac ;; + esac + fi + if [ "${HP_ARCH}" = "" ]; then + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + + #define _HPUX_SOURCE + #include + #include + + int main () + { + #if defined(_SC_KERNEL_BITS) + long bits = sysconf(_SC_KERNEL_BITS); + #endif + long cpu = sysconf (_SC_CPU_VERSION); + + switch (cpu) + { + case CPU_PA_RISC1_0: puts ("hppa1.0"); break; + case CPU_PA_RISC1_1: puts ("hppa1.1"); break; + case CPU_PA_RISC2_0: + #if defined(_SC_KERNEL_BITS) + switch (bits) + { + case 64: puts ("hppa2.0w"); break; + case 32: puts ("hppa2.0n"); break; + default: puts ("hppa2.0"); break; + } break; + #else /* !defined(_SC_KERNEL_BITS) */ + puts ("hppa2.0"); break; + #endif + default: puts ("hppa1.0"); break; + } + exit (0); + } +EOF + (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy` + test -z "$HP_ARCH" && HP_ARCH=hppa + fi ;; + esac + if [ ${HP_ARCH} = "hppa2.0w" ] + then + eval $set_cc_for_build + + # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating + # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler + # generating 64-bit code. GNU and HP use different nomenclature: + # + # $ CC_FOR_BUILD=cc ./config.guess + # => hppa2.0w-hp-hpux11.23 + # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess + # => hppa64-hp-hpux11.23 + + if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | + grep __LP64__ >/dev/null + then + HP_ARCH="hppa2.0w" + else + HP_ARCH="hppa64" + fi + fi + echo ${HP_ARCH}-hp-hpux${HPUX_REV} + exit ;; + ia64:HP-UX:*:*) + HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` + echo ia64-hp-hpux${HPUX_REV} + exit ;; + 3050*:HI-UX:*:*) + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #include + int + main () + { + long cpu = sysconf (_SC_CPU_VERSION); + /* The order matters, because CPU_IS_HP_MC68K erroneously returns + true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct + results, however. */ + if (CPU_IS_PA_RISC (cpu)) + { + switch (cpu) + { + case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break; + case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break; + case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break; + default: puts ("hppa-hitachi-hiuxwe2"); break; + } + } + else if (CPU_IS_HP_MC68K (cpu)) + puts ("m68k-hitachi-hiuxwe2"); + else puts ("unknown-hitachi-hiuxwe2"); + exit (0); + } +EOF + $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` && + { echo "$SYSTEM_NAME"; exit; } + echo unknown-hitachi-hiuxwe2 + exit ;; + 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* ) + echo hppa1.1-hp-bsd + exit ;; + 9000/8??:4.3bsd:*:*) + echo hppa1.0-hp-bsd + exit ;; + *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) + echo hppa1.0-hp-mpeix + exit ;; + hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* ) + echo hppa1.1-hp-osf + exit ;; + hp8??:OSF1:*:*) + echo hppa1.0-hp-osf + exit ;; + i*86:OSF1:*:*) + if [ -x /usr/sbin/sysversion ] ; then + echo ${UNAME_MACHINE}-unknown-osf1mk + else + echo ${UNAME_MACHINE}-unknown-osf1 + fi + exit ;; + parisc*:Lites*:*:*) + echo hppa1.1-hp-lites + exit ;; + C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) + echo c1-convex-bsd + exit ;; + C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) + if getsysinfo -f scalar_acc + then echo c32-convex-bsd + else echo c2-convex-bsd + fi + exit ;; + C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) + echo c34-convex-bsd + exit ;; + C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) + echo c38-convex-bsd + exit ;; + C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) + echo c4-convex-bsd + exit ;; + CRAY*Y-MP:*:*:*) + echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*[A-Z]90:*:*:*) + echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \ + | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \ + -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ + -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*TS:*:*:*) + echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*T3E:*:*:*) + echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*SV1:*:*:*) + echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + *:UNICOS/mp:*:*) + echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/' + exit ;; + F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*) + FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` + FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` + FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'` + echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" + exit ;; + 5000:UNIX_System_V:4.*:*) + FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'` + FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'` + echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" + exit ;; + i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*) + echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE} + exit ;; + sparc*:BSD/OS:*:*) + echo sparc-unknown-bsdi${UNAME_RELEASE} + exit ;; + *:BSD/OS:*:*) + echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE} + exit ;; + *:FreeBSD:*:*) + case ${UNAME_MACHINE} in + pc98) + echo i386-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; + amd64) + echo x86_64-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; + *) + echo ${UNAME_MACHINE}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;; + esac + exit ;; + i*:CYGWIN*:*) + echo ${UNAME_MACHINE}-pc-cygwin + exit ;; + *:MINGW*:*) + echo ${UNAME_MACHINE}-pc-mingw32 + exit ;; + i*:windows32*:*) + # uname -m includes "-pc" on this system. + echo ${UNAME_MACHINE}-mingw32 + exit ;; + i*:PW*:*) + echo ${UNAME_MACHINE}-pc-pw32 + exit ;; + *:Interix*:[3456]*) + case ${UNAME_MACHINE} in + x86) + echo i586-pc-interix${UNAME_RELEASE} + exit ;; + EM64T | authenticamd) + echo x86_64-unknown-interix${UNAME_RELEASE} + exit ;; + esac ;; + [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*) + echo i${UNAME_MACHINE}-pc-mks + exit ;; + i*:Windows_NT*:* | Pentium*:Windows_NT*:*) + # How do we know it's Interix rather than the generic POSIX subsystem? + # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we + # UNAME_MACHINE based on the output of uname instead of i386? + echo i586-pc-interix + exit ;; + i*:UWIN*:*) + echo ${UNAME_MACHINE}-pc-uwin + exit ;; + amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*) + echo x86_64-unknown-cygwin + exit ;; + p*:CYGWIN*:*) + echo powerpcle-unknown-cygwin + exit ;; + prep*:SunOS:5.*:*) + echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` + exit ;; + *:GNU:*:*) + # the GNU system + echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'` + exit ;; + *:GNU/*:*:*) + # other systems with GNU libc and userland + echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-gnu + exit ;; + i*86:Minix:*:*) + echo ${UNAME_MACHINE}-pc-minix + exit ;; + arm*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + avr32*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + cris:Linux:*:*) + echo cris-axis-linux-gnu + exit ;; + crisv32:Linux:*:*) + echo crisv32-axis-linux-gnu + exit ;; + frv:Linux:*:*) + echo frv-unknown-linux-gnu + exit ;; + ia64:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + m32r*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + m68*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + mips:Linux:*:*) + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #undef CPU + #undef mips + #undef mipsel + #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) + CPU=mipsel + #else + #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) + CPU=mips + #else + CPU= + #endif + #endif +EOF + eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' + /^CPU/{ + s: ::g + p + }'`" + test x"${CPU}" != x && { echo "${CPU}-unknown-linux-gnu"; exit; } + ;; + mips64:Linux:*:*) + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #undef CPU + #undef mips64 + #undef mips64el + #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) + CPU=mips64el + #else + #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) + CPU=mips64 + #else + CPU= + #endif + #endif +EOF + eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' + /^CPU/{ + s: ::g + p + }'`" + test x"${CPU}" != x && { echo "${CPU}-unknown-linux-gnu"; exit; } + ;; + or32:Linux:*:*) + echo or32-unknown-linux-gnu + exit ;; + ppc:Linux:*:*) + echo powerpc-unknown-linux-gnu + exit ;; + ppc64:Linux:*:*) + echo powerpc64-unknown-linux-gnu + exit ;; + alpha:Linux:*:*) + case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in + EV5) UNAME_MACHINE=alphaev5 ;; + EV56) UNAME_MACHINE=alphaev56 ;; + PCA56) UNAME_MACHINE=alphapca56 ;; + PCA57) UNAME_MACHINE=alphapca56 ;; + EV6) UNAME_MACHINE=alphaev6 ;; + EV67) UNAME_MACHINE=alphaev67 ;; + EV68*) UNAME_MACHINE=alphaev68 ;; + esac + objdump --private-headers /bin/sh | grep ld.so.1 >/dev/null + if test "$?" = 0 ; then LIBC="libc1" ; else LIBC="" ; fi + echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC} + exit ;; + parisc:Linux:*:* | hppa:Linux:*:*) + # Look for CPU level + case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in + PA7*) echo hppa1.1-unknown-linux-gnu ;; + PA8*) echo hppa2.0-unknown-linux-gnu ;; + *) echo hppa-unknown-linux-gnu ;; + esac + exit ;; + parisc64:Linux:*:* | hppa64:Linux:*:*) + echo hppa64-unknown-linux-gnu + exit ;; + s390:Linux:*:* | s390x:Linux:*:*) + echo ${UNAME_MACHINE}-ibm-linux + exit ;; + sh64*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + sh*:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + sparc:Linux:*:* | sparc64:Linux:*:*) + echo ${UNAME_MACHINE}-unknown-linux-gnu + exit ;; + vax:Linux:*:*) + echo ${UNAME_MACHINE}-dec-linux-gnu + exit ;; + x86_64:Linux:*:*) + echo x86_64-unknown-linux-gnu + exit ;; + xtensa:Linux:*:*) + echo xtensa-unknown-linux-gnu + exit ;; + i*86:Linux:*:*) + # The BFD linker knows what the default object file format is, so + # first see if it will tell us. cd to the root directory to prevent + # problems with other programs or directories called `ld' in the path. + # Set LC_ALL=C to ensure ld outputs messages in English. + ld_supported_targets=`cd /; LC_ALL=C ld --help 2>&1 \ + | sed -ne '/supported targets:/!d + s/[ ][ ]*/ /g + s/.*supported targets: *// + s/ .*// + p'` + case "$ld_supported_targets" in + elf32-i386) + TENTATIVE="${UNAME_MACHINE}-pc-linux-gnu" + ;; + a.out-i386-linux) + echo "${UNAME_MACHINE}-pc-linux-gnuaout" + exit ;; + coff-i386) + echo "${UNAME_MACHINE}-pc-linux-gnucoff" + exit ;; + "") + # Either a pre-BFD a.out linker (linux-gnuoldld) or + # one that does not give us useful --help. + echo "${UNAME_MACHINE}-pc-linux-gnuoldld" + exit ;; + esac + # Determine whether the default compiler is a.out or elf + eval $set_cc_for_build + sed 's/^ //' << EOF >$dummy.c + #include + #ifdef __ELF__ + # ifdef __GLIBC__ + # if __GLIBC__ >= 2 + LIBC=gnu + # else + LIBC=gnulibc1 + # endif + # else + LIBC=gnulibc1 + # endif + #else + #if defined(__INTEL_COMPILER) || defined(__PGI) || defined(__SUNPRO_C) || defined(__SUNPRO_CC) + LIBC=gnu + #else + LIBC=gnuaout + #endif + #endif + #ifdef __dietlibc__ + LIBC=dietlibc + #endif +EOF + eval "`$CC_FOR_BUILD -E $dummy.c 2>/dev/null | sed -n ' + /^LIBC/{ + s: ::g + p + }'`" + test x"${LIBC}" != x && { + echo "${UNAME_MACHINE}-pc-linux-${LIBC}" + exit + } + test x"${TENTATIVE}" != x && { echo "${TENTATIVE}"; exit; } + ;; + i*86:DYNIX/ptx:4*:*) + # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. + # earlier versions are messed up and put the nodename in both + # sysname and nodename. + echo i386-sequent-sysv4 + exit ;; + i*86:UNIX_SV:4.2MP:2.*) + # Unixware is an offshoot of SVR4, but it has its own version + # number series starting with 2... + # I am not positive that other SVR4 systems won't match this, + # I just have to hope. -- rms. + # Use sysv4.2uw... so that sysv4* matches it. + echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION} + exit ;; + i*86:OS/2:*:*) + # If we were able to find `uname', then EMX Unix compatibility + # is probably installed. + echo ${UNAME_MACHINE}-pc-os2-emx + exit ;; + i*86:XTS-300:*:STOP) + echo ${UNAME_MACHINE}-unknown-stop + exit ;; + i*86:atheos:*:*) + echo ${UNAME_MACHINE}-unknown-atheos + exit ;; + i*86:syllable:*:*) + echo ${UNAME_MACHINE}-pc-syllable + exit ;; + i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.0*:*) + echo i386-unknown-lynxos${UNAME_RELEASE} + exit ;; + i*86:*DOS:*:*) + echo ${UNAME_MACHINE}-pc-msdosdjgpp + exit ;; + i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*) + UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'` + if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then + echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL} + else + echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL} + fi + exit ;; + i*86:*:5:[678]*) + # UnixWare 7.x, OpenUNIX and OpenServer 6. + case `/bin/uname -X | grep "^Machine"` in + *486*) UNAME_MACHINE=i486 ;; + *Pentium) UNAME_MACHINE=i586 ;; + *Pent*|*Celeron) UNAME_MACHINE=i686 ;; + esac + echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION} + exit ;; + i*86:*:3.2:*) + if test -f /usr/options/cb.name; then + UNAME_REL=`sed -n 's/.*Version //p' /dev/null >/dev/null ; then + UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')` + (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486 + (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \ + && UNAME_MACHINE=i586 + (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \ + && UNAME_MACHINE=i686 + (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \ + && UNAME_MACHINE=i686 + echo ${UNAME_MACHINE}-pc-sco$UNAME_REL + else + echo ${UNAME_MACHINE}-pc-sysv32 + fi + exit ;; + pc:*:*:*) + # Left here for compatibility: + # uname -m prints for DJGPP always 'pc', but it prints nothing about + # the processor, so we play safe by assuming i386. + echo i386-pc-msdosdjgpp + exit ;; + Intel:Mach:3*:*) + echo i386-pc-mach3 + exit ;; + paragon:*:*:*) + echo i860-intel-osf1 + exit ;; + i860:*:4.*:*) # i860-SVR4 + if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then + echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4 + else # Add other i860-SVR4 vendors below as they are discovered. + echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4 + fi + exit ;; + mini*:CTIX:SYS*5:*) + # "miniframe" + echo m68010-convergent-sysv + exit ;; + mc68k:UNIX:SYSTEM5:3.51m) + echo m68k-convergent-sysv + exit ;; + M680?0:D-NIX:5.3:*) + echo m68k-diab-dnix + exit ;; + M68*:*:R3V[5678]*:*) + test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;; + 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0) + OS_REL='' + test -r /etc/.relid \ + && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` + /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ + && { echo i486-ncr-sysv4.3${OS_REL}; exit; } + /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ + && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;; + 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*) + /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ + && { echo i486-ncr-sysv4; exit; } ;; + m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) + echo m68k-unknown-lynxos${UNAME_RELEASE} + exit ;; + mc68030:UNIX_System_V:4.*:*) + echo m68k-atari-sysv4 + exit ;; + TSUNAMI:LynxOS:2.*:*) + echo sparc-unknown-lynxos${UNAME_RELEASE} + exit ;; + rs6000:LynxOS:2.*:*) + echo rs6000-unknown-lynxos${UNAME_RELEASE} + exit ;; + PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.0*:*) + echo powerpc-unknown-lynxos${UNAME_RELEASE} + exit ;; + SM[BE]S:UNIX_SV:*:*) + echo mips-dde-sysv${UNAME_RELEASE} + exit ;; + RM*:ReliantUNIX-*:*:*) + echo mips-sni-sysv4 + exit ;; + RM*:SINIX-*:*:*) + echo mips-sni-sysv4 + exit ;; + *:SINIX-*:*:*) + if uname -p 2>/dev/null >/dev/null ; then + UNAME_MACHINE=`(uname -p) 2>/dev/null` + echo ${UNAME_MACHINE}-sni-sysv4 + else + echo ns32k-sni-sysv + fi + exit ;; + PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort + # says + echo i586-unisys-sysv4 + exit ;; + *:UNIX_System_V:4*:FTX*) + # From Gerald Hewes . + # How about differentiating between stratus architectures? -djm + echo hppa1.1-stratus-sysv4 + exit ;; + *:*:*:FTX*) + # From seanf@swdc.stratus.com. + echo i860-stratus-sysv4 + exit ;; + i*86:VOS:*:*) + # From Paul.Green@stratus.com. + echo ${UNAME_MACHINE}-stratus-vos + exit ;; + *:VOS:*:*) + # From Paul.Green@stratus.com. + echo hppa1.1-stratus-vos + exit ;; + mc68*:A/UX:*:*) + echo m68k-apple-aux${UNAME_RELEASE} + exit ;; + news*:NEWS-OS:6*:*) + echo mips-sony-newsos6 + exit ;; + R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) + if [ -d /usr/nec ]; then + echo mips-nec-sysv${UNAME_RELEASE} + else + echo mips-unknown-sysv${UNAME_RELEASE} + fi + exit ;; + BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. + echo powerpc-be-beos + exit ;; + BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only. + echo powerpc-apple-beos + exit ;; + BePC:BeOS:*:*) # BeOS running on Intel PC compatible. + echo i586-pc-beos + exit ;; + SX-4:SUPER-UX:*:*) + echo sx4-nec-superux${UNAME_RELEASE} + exit ;; + SX-5:SUPER-UX:*:*) + echo sx5-nec-superux${UNAME_RELEASE} + exit ;; + SX-6:SUPER-UX:*:*) + echo sx6-nec-superux${UNAME_RELEASE} + exit ;; + SX-7:SUPER-UX:*:*) + echo sx7-nec-superux${UNAME_RELEASE} + exit ;; + SX-8:SUPER-UX:*:*) + echo sx8-nec-superux${UNAME_RELEASE} + exit ;; + SX-8R:SUPER-UX:*:*) + echo sx8r-nec-superux${UNAME_RELEASE} + exit ;; + Power*:Rhapsody:*:*) + echo powerpc-apple-rhapsody${UNAME_RELEASE} + exit ;; + *:Rhapsody:*:*) + echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE} + exit ;; + *:Darwin:*:*) + UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown + case $UNAME_PROCESSOR in + unknown) UNAME_PROCESSOR=powerpc ;; + esac + echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE} + exit ;; + *:procnto*:*:* | *:QNX:[0123456789]*:*) + UNAME_PROCESSOR=`uname -p` + if test "$UNAME_PROCESSOR" = "x86"; then + UNAME_PROCESSOR=i386 + UNAME_MACHINE=pc + fi + echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE} + exit ;; + *:QNX:*:4*) + echo i386-pc-qnx + exit ;; + NSE-?:NONSTOP_KERNEL:*:*) + echo nse-tandem-nsk${UNAME_RELEASE} + exit ;; + NSR-?:NONSTOP_KERNEL:*:*) + echo nsr-tandem-nsk${UNAME_RELEASE} + exit ;; + *:NonStop-UX:*:*) + echo mips-compaq-nonstopux + exit ;; + BS2000:POSIX*:*:*) + echo bs2000-siemens-sysv + exit ;; + DS/*:UNIX_System_V:*:*) + echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE} + exit ;; + *:Plan9:*:*) + # "uname -m" is not consistent, so use $cputype instead. 386 + # is converted to i386 for consistency with other x86 + # operating systems. + if test "$cputype" = "386"; then + UNAME_MACHINE=i386 + else + UNAME_MACHINE="$cputype" + fi + echo ${UNAME_MACHINE}-unknown-plan9 + exit ;; + *:TOPS-10:*:*) + echo pdp10-unknown-tops10 + exit ;; + *:TENEX:*:*) + echo pdp10-unknown-tenex + exit ;; + KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*) + echo pdp10-dec-tops20 + exit ;; + XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*) + echo pdp10-xkl-tops20 + exit ;; + *:TOPS-20:*:*) + echo pdp10-unknown-tops20 + exit ;; + *:ITS:*:*) + echo pdp10-unknown-its + exit ;; + SEI:*:*:SEIUX) + echo mips-sei-seiux${UNAME_RELEASE} + exit ;; + *:DragonFly:*:*) + echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` + exit ;; + *:*VMS:*:*) + UNAME_MACHINE=`(uname -p) 2>/dev/null` + case "${UNAME_MACHINE}" in + A*) echo alpha-dec-vms ; exit ;; + I*) echo ia64-dec-vms ; exit ;; + V*) echo vax-dec-vms ; exit ;; + esac ;; + *:XENIX:*:SysV) + echo i386-pc-xenix + exit ;; + i*86:skyos:*:*) + echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//' + exit ;; + i*86:rdos:*:*) + echo ${UNAME_MACHINE}-pc-rdos + exit ;; +esac + +#echo '(No uname command or uname output not recognized.)' 1>&2 +#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2 + +eval $set_cc_for_build +cat >$dummy.c < +# include +#endif +main () +{ +#if defined (sony) +#if defined (MIPSEB) + /* BFD wants "bsd" instead of "newsos". Perhaps BFD should be changed, + I don't know.... */ + printf ("mips-sony-bsd\n"); exit (0); +#else +#include + printf ("m68k-sony-newsos%s\n", +#ifdef NEWSOS4 + "4" +#else + "" +#endif + ); exit (0); +#endif +#endif + +#if defined (__arm) && defined (__acorn) && defined (__unix) + printf ("arm-acorn-riscix\n"); exit (0); +#endif + +#if defined (hp300) && !defined (hpux) + printf ("m68k-hp-bsd\n"); exit (0); +#endif + +#if defined (NeXT) +#if !defined (__ARCHITECTURE__) +#define __ARCHITECTURE__ "m68k" +#endif + int version; + version=`(hostinfo | sed -n 's/.*NeXT Mach \([0-9]*\).*/\1/p') 2>/dev/null`; + if (version < 4) + printf ("%s-next-nextstep%d\n", __ARCHITECTURE__, version); + else + printf ("%s-next-openstep%d\n", __ARCHITECTURE__, version); + exit (0); +#endif + +#if defined (MULTIMAX) || defined (n16) +#if defined (UMAXV) + printf ("ns32k-encore-sysv\n"); exit (0); +#else +#if defined (CMU) + printf ("ns32k-encore-mach\n"); exit (0); +#else + printf ("ns32k-encore-bsd\n"); exit (0); +#endif +#endif +#endif + +#if defined (__386BSD__) + printf ("i386-pc-bsd\n"); exit (0); +#endif + +#if defined (sequent) +#if defined (i386) + printf ("i386-sequent-dynix\n"); exit (0); +#endif +#if defined (ns32000) + printf ("ns32k-sequent-dynix\n"); exit (0); +#endif +#endif + +#if defined (_SEQUENT_) + struct utsname un; + + uname(&un); + + if (strncmp(un.version, "V2", 2) == 0) { + printf ("i386-sequent-ptx2\n"); exit (0); + } + if (strncmp(un.version, "V1", 2) == 0) { /* XXX is V1 correct? */ + printf ("i386-sequent-ptx1\n"); exit (0); + } + printf ("i386-sequent-ptx\n"); exit (0); + +#endif + +#if defined (vax) +# if !defined (ultrix) +# include +# if defined (BSD) +# if BSD == 43 + printf ("vax-dec-bsd4.3\n"); exit (0); +# else +# if BSD == 199006 + printf ("vax-dec-bsd4.3reno\n"); exit (0); +# else + printf ("vax-dec-bsd\n"); exit (0); +# endif +# endif +# else + printf ("vax-dec-bsd\n"); exit (0); +# endif +# else + printf ("vax-dec-ultrix\n"); exit (0); +# endif +#endif + +#if defined (alliant) && defined (i860) + printf ("i860-alliant-bsd\n"); exit (0); +#endif + + exit (1); +} +EOF + +$CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null && SYSTEM_NAME=`$dummy` && + { echo "$SYSTEM_NAME"; exit; } + +# Apollos put the system type in the environment. + +test -d /usr/apollo && { echo ${ISP}-apollo-${SYSTYPE}; exit; } + +# Convex versions that predate uname can use getsysinfo(1) + +if [ -x /usr/convex/getsysinfo ] +then + case `getsysinfo -f cpu_type` in + c1*) + echo c1-convex-bsd + exit ;; + c2*) + if getsysinfo -f scalar_acc + then echo c32-convex-bsd + else echo c2-convex-bsd + fi + exit ;; + c34*) + echo c34-convex-bsd + exit ;; + c38*) + echo c38-convex-bsd + exit ;; + c4*) + echo c4-convex-bsd + exit ;; + esac +fi + +cat >&2 < in order to provide the needed +information to handle your system. + +config.guess timestamp = $timestamp + +uname -m = `(uname -m) 2>/dev/null || echo unknown` +uname -r = `(uname -r) 2>/dev/null || echo unknown` +uname -s = `(uname -s) 2>/dev/null || echo unknown` +uname -v = `(uname -v) 2>/dev/null || echo unknown` + +/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null` +/bin/uname -X = `(/bin/uname -X) 2>/dev/null` + +hostinfo = `(hostinfo) 2>/dev/null` +/bin/universe = `(/bin/universe) 2>/dev/null` +/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null` +/bin/arch = `(/bin/arch) 2>/dev/null` +/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null` +/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null` + +UNAME_MACHINE = ${UNAME_MACHINE} +UNAME_RELEASE = ${UNAME_RELEASE} +UNAME_SYSTEM = ${UNAME_SYSTEM} +UNAME_VERSION = ${UNAME_VERSION} +EOF + +exit 1 + +# Local variables: +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "timestamp='" +# time-stamp-format: "%:y-%02m-%02d" +# time-stamp-end: "'" +# End: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/config.rpath b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/config.rpath new file mode 100644 index 0000000000..5ead7586a7 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/config.rpath @@ -0,0 +1,513 @@ +#! /bin/sh +# Output a system dependent set of variables, describing how to set the +# run time search path of shared libraries in an executable. +# +# Copyright 1996-2002 Free Software Foundation, Inc. +# Taken from GNU libtool, 2001 +# Originally by Gordon Matzigkeit , 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 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, 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. +# +# The first argument passed to this file is the canonical host specification, +# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM +# or +# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM +# The environment variables CC, GCC, LDFLAGS, LD, with_gnu_ld +# should be set by the caller. +# +# The set of defined variables is at the end of this script. + +# All known linkers require a `.a' archive for static linking (except M$VC, +# which needs '.lib'). +libext=a +shlibext= + +host="$1" +host_cpu=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'` +host_vendor=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\2/'` +host_os=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'` + +wl= +if test "$GCC" = yes; then + wl='-Wl,' +else + case "$host_os" in + aix3* | aix4* | aix5*) + wl='-Wl,' + ;; + hpux9* | hpux10* | hpux11*) + wl='-Wl,' + ;; + irix5* | irix6*) + wl='-Wl,' + ;; + linux*) + echo '__INTEL_COMPILER' > conftest.$ac_ext + if $CC -E conftest.$ac_ext >/dev/null | grep __INTEL_COMPILER >/dev/null + then + : + else + # Intel icc + wl='-Qoption,ld,' + fi + ;; + osf3* | osf4* | osf5*) + wl='-Wl,' + ;; + solaris*) + wl='-Wl,' + ;; + sunos4*) + wl='-Qoption ld ' + ;; + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + if test "x$host_vendor" = xsni; then + wl='-LD' + else + wl='-Wl,' + fi + ;; + esac +fi + +hardcode_libdir_flag_spec= +hardcode_libdir_separator= +hardcode_direct=no +hardcode_minus_L=no + +case "$host_os" in + cygwin* | mingw* | pw32*) + # FIXME: the MSVC++ port hasn't been tested in a loooong time + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + if test "$GCC" != yes; then + with_gnu_ld=no + fi + ;; + openbsd*) + with_gnu_ld=no + ;; +esac + +ld_shlibs=yes +if test "$with_gnu_ld" = yes; then + case "$host_os" in + aix3* | aix4* | aix5*) + # On AIX, the GNU linker is very broken + ld_shlibs=no + ;; + amigaos*) + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + # Samuel A. Falvo II reports + # that the semantics of dynamic libraries on AmigaOS, at least up + # to version 4, is to share data among multiple programs linked + # with the same dynamic library. Since this doesn't match the + # behavior of shared libraries on other platforms, we can use + # them. + ld_shlibs=no + ;; + beos*) + if $LD --help 2>&1 | egrep ': supported targets:.* elf' > /dev/null; then + : + else + ld_shlibs=no + fi + ;; + cygwin* | mingw* | pw32*) + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + hardcode_libdir_flag_spec='-L$libdir' + ;; + solaris* | sysv5*) + if $LD -v 2>&1 | egrep 'BFD 2\.8' > /dev/null; then + ld_shlibs=no + elif $LD --help 2>&1 | egrep ': supported targets:.* elf' > /dev/null; then + : + else + ld_shlibs=no + fi + ;; + sunos4*) + hardcode_direct=yes + ;; + *) + if $LD --help 2>&1 | egrep ': supported targets:.* elf' > /dev/null; then + : + else + ld_shlibs=no + fi + ;; + esac + if test "$ld_shlibs" = yes; then + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + fi +else + case "$host_os" in + aix3*) + # Note: this linker hardcodes the directories in LIBPATH if there + # are no directories specified by -L. + hardcode_minus_L=yes + if test "$GCC" = yes; then + # Neither direct hardcoding nor static linking is supported with a + # broken collect2. + hardcode_direct=unsupported + fi + ;; + aix4* | aix5*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + else + aix_use_runtimelinking=no + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # need to do runtime linking. + case $host_os in aix4.[23]|aix4.[23].*|aix5*) + for ld_flag in $LDFLAGS; do + if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then + aix_use_runtimelinking=yes + break + fi + done + esac + fi + hardcode_direct=yes + hardcode_libdir_separator=':' + if test "$GCC" = yes; then + case $host_os in aix4.[012]|aix4.[012].*) + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && \ + strings "$collect2name" | grep resolve_lib_name >/dev/null + then + # We have reworked collect2 + hardcode_direct=yes + else + # We have old collect2 + hardcode_direct=unsupported + hardcode_minus_L=yes + hardcode_libdir_flag_spec='-L$libdir' + hardcode_libdir_separator= + fi + esac + fi + if test "$aix_use_runtimelinking" = yes; then + hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:/usr/lib:/lib' + else + if test "$host_cpu" = ia64; then + hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib' + else + hardcode_libdir_flag_spec='${wl}-bnolibpath ${wl}-blibpath:$libdir:/usr/lib:/lib' + fi + fi + ;; + amigaos*) + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + # see comment about different semantics on the GNU ld section + ld_shlibs=no + ;; + cygwin* | mingw* | pw32*) + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + hardcode_libdir_flag_spec=' ' + libext=lib + ;; + darwin* | rhapsody*) + hardcode_direct=yes + ;; + freebsd1*) + ld_shlibs=no + ;; + freebsd2.2*) + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + ;; + freebsd2*) + hardcode_direct=yes + hardcode_minus_L=yes + ;; + freebsd*) + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + ;; + hpux9* | hpux10* | hpux11*) + hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' + hardcode_libdir_separator=: + hardcode_direct=yes + hardcode_minus_L=yes # Not in the search PATH, but as the default + # location of the library. + ;; + irix5* | irix6*) + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + ;; + netbsd*) + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + ;; + newsos6) + hardcode_direct=yes + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + ;; + openbsd*) + hardcode_direct=yes + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + hardcode_libdir_flag_spec='${wl}-rpath,$libdir' + else + case "$host_os" in + openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*) + hardcode_libdir_flag_spec='-R$libdir' + ;; + *) + hardcode_libdir_flag_spec='${wl}-rpath,$libdir' + ;; + esac + fi + ;; + os2*) + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + ;; + osf3*) + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + ;; + osf4* | osf5*) + if test "$GCC" = yes; then + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + else + # Both cc and cxx compiler support -rpath directly + hardcode_libdir_flag_spec='-rpath $libdir' + fi + hardcode_libdir_separator=: + ;; + sco3.2v5*) + ;; + solaris*) + hardcode_libdir_flag_spec='-R$libdir' + ;; + sunos4*) + hardcode_libdir_flag_spec='-L$libdir' + hardcode_direct=yes + hardcode_minus_L=yes + ;; + sysv4) + if test "x$host_vendor" = xsno; then + hardcode_direct=yes # is this really true??? + else + hardcode_direct=no # Motorola manual says yes, but my tests say they lie + fi + ;; + sysv4.3*) + ;; + sysv5*) + hardcode_libdir_flag_spec= + ;; + uts4*) + hardcode_libdir_flag_spec='-L$libdir' + ;; + dgux*) + hardcode_libdir_flag_spec='-L$libdir' + ;; + sysv4*MP*) + if test -d /usr/nec; then + ld_shlibs=yes + fi + ;; + sysv4.2uw2*) + hardcode_direct=yes + hardcode_minus_L=no + ;; + sysv5uw7* | unixware7*) + ;; + *) + ld_shlibs=no + ;; + esac +fi + +# Check dynamic linker characteristics +libname_spec='lib$name' +sys_lib_dlsearch_path_spec="/lib /usr/lib" +sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +case "$host_os" in + aix3*) + shlibext=so + ;; + aix4* | aix5*) + shlibext=so + ;; + amigaos*) + shlibext=ixlibrary + ;; + beos*) + shlibext=so + ;; + bsdi4*) + shlibext=so + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + ;; + cygwin* | mingw* | pw32*) + case $GCC,$host_os in + yes,cygwin*) + shlibext=dll.a + ;; + yes,mingw*) + shlibext=dll + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | sed -e "s/^libraries://" -e "s/;/ /g"` + ;; + yes,pw32*) + shlibext=dll + ;; + *) + shlibext=dll + ;; + esac + ;; + darwin* | rhapsody*) + shlibext=dylib + ;; + freebsd1*) + ;; + freebsd*) + shlibext=so + ;; + gnu*) + shlibext=so + ;; + hpux9* | hpux10* | hpux11*) + shlibext=sl + ;; + irix5* | irix6*) + shlibext=so + case "$host_os" in + irix5*) + libsuff= shlibsuff= + ;; + *) + case $LD in + *-32|*"-32 ") libsuff= shlibsuff= ;; + *-n32|*"-n32 ") libsuff=32 shlibsuff=N32 ;; + *-64|*"-64 ") libsuff=64 shlibsuff=64 ;; + *) libsuff= shlibsuff= ;; + esac + ;; + esac + sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" + sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" + ;; + linux-gnuoldld* | linux-gnuaout* | linux-gnucoff*) + ;; + linux-gnu*) + shlibext=so + ;; + netbsd*) + shlibext=so + ;; + newsos6) + shlibext=so + ;; + openbsd*) + shlibext=so + ;; + os2*) + libname_spec='$name' + shlibext=dll + ;; + osf3* | osf4* | osf5*) + shlibext=so + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" + ;; + sco3.2v5*) + shlibext=so + ;; + solaris*) + shlibext=so + ;; + sunos4*) + shlibext=so + ;; + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + shlibext=so + case "$host_vendor" in + motorola) + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + uts4*) + shlibext=so + ;; + dgux*) + shlibext=so + ;; + sysv4*MP*) + if test -d /usr/nec; then + shlibext=so + fi + ;; +esac + +sed_quote_subst='s/\(["`$\\]\)/\\\1/g' +escaped_wl=`echo "X$wl" | sed -e 's/^X//' -e "$sed_quote_subst"` +escaped_hardcode_libdir_flag_spec=`echo "X$hardcode_libdir_flag_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` +escaped_sys_lib_search_path_spec=`echo "X$sys_lib_search_path_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` +escaped_sys_lib_dlsearch_path_spec=`echo "X$sys_lib_dlsearch_path_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` + +sed -e 's/^\([a-zA-Z0-9_]*\)=/acl_cv_\1=/' <. Submit a context +# diff and a properly formatted ChangeLog entry. +# +# Configuration subroutine to validate and canonicalize a configuration type. +# Supply the specified configuration type as an argument. +# If it is invalid, we print an error message on stderr and exit with code 1. +# Otherwise, we print the canonical config type on stdout and succeed. + +# This file is supposed to be the same for all GNU packages +# and recognize all the CPU types, system types and aliases +# that are meaningful with *any* GNU software. +# Each package is responsible for reporting which valid configurations +# it does not support. The user should be able to distinguish +# a failure to support a valid configuration from a meaningless +# configuration. + +# The goal of this file is to map all the various variations of a given +# machine specification into a single specification in the form: +# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM +# or in some cases, the newer four-part form: +# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM +# It is wrong to echo any other type of specification. + +me=`echo "$0" | sed -e 's,.*/,,'` + +usage="\ +Usage: $0 [OPTION] CPU-MFR-OPSYS + $0 [OPTION] ALIAS + +Canonicalize a configuration name. + +Operation modes: + -h, --help print this help, then exit + -t, --time-stamp print date of last modification, then exit + -v, --version print version number, then exit + +Report bugs and patches to ." + +version="\ +GNU config.sub ($timestamp) + +Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005 +Free Software Foundation, Inc. + +This is free software; see the source for copying conditions. There is NO +warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." + +help=" +Try \`$me --help' for more information." + +# Parse command line +while test $# -gt 0 ; do + case $1 in + --time-stamp | --time* | -t ) + echo "$timestamp" ; exit ;; + --version | -v ) + echo "$version" ; exit ;; + --help | --h* | -h ) + echo "$usage"; exit ;; + -- ) # Stop option processing + shift; break ;; + - ) # Use stdin as input. + break ;; + -* ) + echo "$me: invalid option $1$help" + exit 1 ;; + + *local*) + # First pass through any local machine types. + echo $1 + exit ;; + + * ) + break ;; + esac +done + +case $# in + 0) echo "$me: missing argument$help" >&2 + exit 1;; + 1) ;; + *) echo "$me: too many arguments$help" >&2 + exit 1;; +esac + +# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any). +# Here we must recognize all the valid KERNEL-OS combinations. +maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'` +case $maybe_os in + nto-qnx* | linux-gnu* | linux-dietlibc | linux-newlib* | linux-uclibc* | \ + uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | knetbsd*-gnu* | netbsd*-gnu* | \ + storm-chaos* | os2-emx* | rtmk-nova*) + os=-$maybe_os + basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'` + ;; + *) + basic_machine=`echo $1 | sed 's/-[^-]*$//'` + if [ $basic_machine != $1 ] + then os=`echo $1 | sed 's/.*-/-/'` + else os=; fi + ;; +esac + +### Let's recognize common machines as not being operating systems so +### that things like config.sub decstation-3100 work. We also +### recognize some manufacturers as not being operating systems, so we +### can provide default operating systems below. +case $os in + -sun*os*) + # Prevent following clause from handling this invalid input. + ;; + -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \ + -att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \ + -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \ + -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\ + -c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \ + -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \ + -apple | -axis | -knuth | -cray) + os= + basic_machine=$1 + ;; + -sim | -cisco | -oki | -wec | -winbond) + os= + basic_machine=$1 + ;; + -scout) + ;; + -wrs) + os=-vxworks + basic_machine=$1 + ;; + -chorusos*) + os=-chorusos + basic_machine=$1 + ;; + -chorusrdb) + os=-chorusrdb + basic_machine=$1 + ;; + -hiux*) + os=-hiuxwe2 + ;; + -sco6) + os=-sco5v6 + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco5) + os=-sco3.2v5 + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco4) + os=-sco3.2v4 + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco3.2.[4-9]*) + os=`echo $os | sed -e 's/sco3.2./sco3.2v/'` + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco3.2v[4-9]*) + # Don't forget version if it is 3.2v4 or newer. + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco5v6*) + # Don't forget version if it is 3.2v4 or newer. + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -sco*) + os=-sco3.2v2 + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -udk*) + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -isc) + os=-isc2.2 + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -clix*) + basic_machine=clipper-intergraph + ;; + -isc*) + basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'` + ;; + -lynx*) + os=-lynxos + ;; + -ptx*) + basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'` + ;; + -windowsnt*) + os=`echo $os | sed -e 's/windowsnt/winnt/'` + ;; + -psos*) + os=-psos + ;; + -mint | -mint[0-9]*) + basic_machine=m68k-atari + os=-mint + ;; +esac + +# Decode aliases for certain CPU-COMPANY combinations. +case $basic_machine in + # Recognize the basic CPU types without company name. + # Some are omitted here because they have special meanings below. + 1750a | 580 \ + | a29k \ + | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \ + | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \ + | am33_2.0 \ + | arc | arm | arm[bl]e | arme[lb] | armv[2345] | armv[345][lb] | avr | avr32 \ + | bfin \ + | c4x | clipper \ + | d10v | d30v | dlx | dsp16xx \ + | fido | fr30 | frv \ + | h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \ + | i370 | i860 | i960 | ia64 \ + | ip2k | iq2000 \ + | m32c | m32r | m32rle | m68000 | m68k | m88k \ + | maxq | mb | microblaze | mcore | mep \ + | mips | mipsbe | mipseb | mipsel | mipsle \ + | mips16 \ + | mips64 | mips64el \ + | mips64vr | mips64vrel \ + | mips64orion | mips64orionel \ + | mips64vr4100 | mips64vr4100el \ + | mips64vr4300 | mips64vr4300el \ + | mips64vr5000 | mips64vr5000el \ + | mips64vr5900 | mips64vr5900el \ + | mipsisa32 | mipsisa32el \ + | mipsisa32r2 | mipsisa32r2el \ + | mipsisa64 | mipsisa64el \ + | mipsisa64r2 | mipsisa64r2el \ + | mipsisa64sb1 | mipsisa64sb1el \ + | mipsisa64sr71k | mipsisa64sr71kel \ + | mipstx39 | mipstx39el \ + | mn10200 | mn10300 \ + | mt \ + | msp430 \ + | nios | nios2 \ + | ns16k | ns32k \ + | or32 \ + | pdp10 | pdp11 | pj | pjl \ + | powerpc | powerpc64 | powerpc64le | powerpcle | ppcbe \ + | pyramid \ + | score \ + | sh | sh[1234] | sh[24]a | sh[23]e | sh[34]eb | sheb | shbe | shle | sh[1234]le | sh3ele \ + | sh64 | sh64le \ + | sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \ + | sparcv8 | sparcv9 | sparcv9b | sparcv9v \ + | spu | strongarm \ + | tahoe | thumb | tic4x | tic80 | tron \ + | v850 | v850e \ + | we32k \ + | x86 | xc16x | xscale | xscalee[bl] | xstormy16 | xtensa \ + | z8k) + basic_machine=$basic_machine-unknown + ;; + m6811 | m68hc11 | m6812 | m68hc12) + # Motorola 68HC11/12. + basic_machine=$basic_machine-unknown + os=-none + ;; + m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k) + ;; + ms1) + basic_machine=mt-unknown + ;; + + # We use `pc' rather than `unknown' + # because (1) that's what they normally are, and + # (2) the word "unknown" tends to confuse beginning users. + i*86 | x86_64) + basic_machine=$basic_machine-pc + ;; + # Object if more than one company name word. + *-*-*) + echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 + exit 1 + ;; + # Recognize the basic CPU types with company name. + 580-* \ + | a29k-* \ + | alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \ + | alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \ + | alphapca5[67]-* | alpha64pca5[67]-* | arc-* \ + | arm-* | armbe-* | armle-* | armeb-* | armv*-* \ + | avr-* | avr32-* \ + | bfin-* | bs2000-* \ + | c[123]* | c30-* | [cjt]90-* | c4x-* | c54x-* | c55x-* | c6x-* \ + | clipper-* | craynv-* | cydra-* \ + | d10v-* | d30v-* | dlx-* \ + | elxsi-* \ + | f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \ + | h8300-* | h8500-* \ + | hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \ + | i*86-* | i860-* | i960-* | ia64-* \ + | ip2k-* | iq2000-* \ + | m32c-* | m32r-* | m32rle-* \ + | m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \ + | m88110-* | m88k-* | maxq-* | mcore-* \ + | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \ + | mips16-* \ + | mips64-* | mips64el-* \ + | mips64vr-* | mips64vrel-* \ + | mips64orion-* | mips64orionel-* \ + | mips64vr4100-* | mips64vr4100el-* \ + | mips64vr4300-* | mips64vr4300el-* \ + | mips64vr5000-* | mips64vr5000el-* \ + | mips64vr5900-* | mips64vr5900el-* \ + | mipsisa32-* | mipsisa32el-* \ + | mipsisa32r2-* | mipsisa32r2el-* \ + | mipsisa64-* | mipsisa64el-* \ + | mipsisa64r2-* | mipsisa64r2el-* \ + | mipsisa64sb1-* | mipsisa64sb1el-* \ + | mipsisa64sr71k-* | mipsisa64sr71kel-* \ + | mipstx39-* | mipstx39el-* \ + | mmix-* \ + | mt-* \ + | msp430-* \ + | nios-* | nios2-* \ + | none-* | np1-* | ns16k-* | ns32k-* \ + | orion-* \ + | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \ + | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | ppcbe-* \ + | pyramid-* \ + | romp-* | rs6000-* \ + | sh-* | sh[1234]-* | sh[24]a-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \ + | shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \ + | sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \ + | sparclite-* \ + | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | strongarm-* | sv1-* | sx?-* \ + | tahoe-* | thumb-* \ + | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \ + | tron-* \ + | v850-* | v850e-* | vax-* \ + | we32k-* \ + | x86-* | x86_64-* | xc16x-* | xps100-* | xscale-* | xscalee[bl]-* \ + | xstormy16-* | xtensa-* \ + | ymp-* \ + | z8k-*) + ;; + # Recognize the various machine names and aliases which stand + # for a CPU type and a company and sometimes even an OS. + 386bsd) + basic_machine=i386-unknown + os=-bsd + ;; + 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc) + basic_machine=m68000-att + ;; + 3b*) + basic_machine=we32k-att + ;; + a29khif) + basic_machine=a29k-amd + os=-udi + ;; + abacus) + basic_machine=abacus-unknown + ;; + adobe68k) + basic_machine=m68010-adobe + os=-scout + ;; + alliant | fx80) + basic_machine=fx80-alliant + ;; + altos | altos3068) + basic_machine=m68k-altos + ;; + am29k) + basic_machine=a29k-none + os=-bsd + ;; + amd64) + basic_machine=x86_64-pc + ;; + amd64-*) + basic_machine=x86_64-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + amdahl) + basic_machine=580-amdahl + os=-sysv + ;; + amiga | amiga-*) + basic_machine=m68k-unknown + ;; + amigaos | amigados) + basic_machine=m68k-unknown + os=-amigaos + ;; + amigaunix | amix) + basic_machine=m68k-unknown + os=-sysv4 + ;; + apollo68) + basic_machine=m68k-apollo + os=-sysv + ;; + apollo68bsd) + basic_machine=m68k-apollo + os=-bsd + ;; + aux) + basic_machine=m68k-apple + os=-aux + ;; + balance) + basic_machine=ns32k-sequent + os=-dynix + ;; + c90) + basic_machine=c90-cray + os=-unicos + ;; + convex-c1) + basic_machine=c1-convex + os=-bsd + ;; + convex-c2) + basic_machine=c2-convex + os=-bsd + ;; + convex-c32) + basic_machine=c32-convex + os=-bsd + ;; + convex-c34) + basic_machine=c34-convex + os=-bsd + ;; + convex-c38) + basic_machine=c38-convex + os=-bsd + ;; + cray | j90) + basic_machine=j90-cray + os=-unicos + ;; + craynv) + basic_machine=craynv-cray + os=-unicosmp + ;; + cr16c) + basic_machine=cr16c-unknown + os=-elf + ;; + crds | unos) + basic_machine=m68k-crds + ;; + crisv32 | crisv32-* | etraxfs*) + basic_machine=crisv32-axis + ;; + cris | cris-* | etrax*) + basic_machine=cris-axis + ;; + crx) + basic_machine=crx-unknown + os=-elf + ;; + da30 | da30-*) + basic_machine=m68k-da30 + ;; + decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn) + basic_machine=mips-dec + ;; + decsystem10* | dec10*) + basic_machine=pdp10-dec + os=-tops10 + ;; + decsystem20* | dec20*) + basic_machine=pdp10-dec + os=-tops20 + ;; + delta | 3300 | motorola-3300 | motorola-delta \ + | 3300-motorola | delta-motorola) + basic_machine=m68k-motorola + ;; + delta88) + basic_machine=m88k-motorola + os=-sysv3 + ;; + djgpp) + basic_machine=i586-pc + os=-msdosdjgpp + ;; + dpx20 | dpx20-*) + basic_machine=rs6000-bull + os=-bosx + ;; + dpx2* | dpx2*-bull) + basic_machine=m68k-bull + os=-sysv3 + ;; + ebmon29k) + basic_machine=a29k-amd + os=-ebmon + ;; + elxsi) + basic_machine=elxsi-elxsi + os=-bsd + ;; + encore | umax | mmax) + basic_machine=ns32k-encore + ;; + es1800 | OSE68k | ose68k | ose | OSE) + basic_machine=m68k-ericsson + os=-ose + ;; + fx2800) + basic_machine=i860-alliant + ;; + genix) + basic_machine=ns32k-ns + ;; + gmicro) + basic_machine=tron-gmicro + os=-sysv + ;; + go32) + basic_machine=i386-pc + os=-go32 + ;; + h3050r* | hiux*) + basic_machine=hppa1.1-hitachi + os=-hiuxwe2 + ;; + h8300hms) + basic_machine=h8300-hitachi + os=-hms + ;; + h8300xray) + basic_machine=h8300-hitachi + os=-xray + ;; + h8500hms) + basic_machine=h8500-hitachi + os=-hms + ;; + harris) + basic_machine=m88k-harris + os=-sysv3 + ;; + hp300-*) + basic_machine=m68k-hp + ;; + hp300bsd) + basic_machine=m68k-hp + os=-bsd + ;; + hp300hpux) + basic_machine=m68k-hp + os=-hpux + ;; + hp3k9[0-9][0-9] | hp9[0-9][0-9]) + basic_machine=hppa1.0-hp + ;; + hp9k2[0-9][0-9] | hp9k31[0-9]) + basic_machine=m68000-hp + ;; + hp9k3[2-9][0-9]) + basic_machine=m68k-hp + ;; + hp9k6[0-9][0-9] | hp6[0-9][0-9]) + basic_machine=hppa1.0-hp + ;; + hp9k7[0-79][0-9] | hp7[0-79][0-9]) + basic_machine=hppa1.1-hp + ;; + hp9k78[0-9] | hp78[0-9]) + # FIXME: really hppa2.0-hp + basic_machine=hppa1.1-hp + ;; + hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893) + # FIXME: really hppa2.0-hp + basic_machine=hppa1.1-hp + ;; + hp9k8[0-9][13679] | hp8[0-9][13679]) + basic_machine=hppa1.1-hp + ;; + hp9k8[0-9][0-9] | hp8[0-9][0-9]) + basic_machine=hppa1.0-hp + ;; + hppa-next) + os=-nextstep3 + ;; + hppaosf) + basic_machine=hppa1.1-hp + os=-osf + ;; + hppro) + basic_machine=hppa1.1-hp + os=-proelf + ;; + i370-ibm* | ibm*) + basic_machine=i370-ibm + ;; +# I'm not sure what "Sysv32" means. Should this be sysv3.2? + i*86v32) + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` + os=-sysv32 + ;; + i*86v4*) + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` + os=-sysv4 + ;; + i*86v) + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` + os=-sysv + ;; + i*86sol2) + basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'` + os=-solaris2 + ;; + i386mach) + basic_machine=i386-mach + os=-mach + ;; + i386-vsta | vsta) + basic_machine=i386-unknown + os=-vsta + ;; + iris | iris4d) + basic_machine=mips-sgi + case $os in + -irix*) + ;; + *) + os=-irix4 + ;; + esac + ;; + isi68 | isi) + basic_machine=m68k-isi + os=-sysv + ;; + m88k-omron*) + basic_machine=m88k-omron + ;; + magnum | m3230) + basic_machine=mips-mips + os=-sysv + ;; + merlin) + basic_machine=ns32k-utek + os=-sysv + ;; + mingw32) + basic_machine=i386-pc + os=-mingw32 + ;; + miniframe) + basic_machine=m68000-convergent + ;; + *mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*) + basic_machine=m68k-atari + os=-mint + ;; + mips3*-*) + basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'` + ;; + mips3*) + basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown + ;; + monitor) + basic_machine=m68k-rom68k + os=-coff + ;; + morphos) + basic_machine=powerpc-unknown + os=-morphos + ;; + msdos) + basic_machine=i386-pc + os=-msdos + ;; + ms1-*) + basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'` + ;; + mvs) + basic_machine=i370-ibm + os=-mvs + ;; + ncr3000) + basic_machine=i486-ncr + os=-sysv4 + ;; + netbsd386) + basic_machine=i386-unknown + os=-netbsd + ;; + netwinder) + basic_machine=armv4l-rebel + os=-linux + ;; + news | news700 | news800 | news900) + basic_machine=m68k-sony + os=-newsos + ;; + news1000) + basic_machine=m68030-sony + os=-newsos + ;; + news-3600 | risc-news) + basic_machine=mips-sony + os=-newsos + ;; + necv70) + basic_machine=v70-nec + os=-sysv + ;; + next | m*-next ) + basic_machine=m68k-next + case $os in + -nextstep* ) + ;; + -ns2*) + os=-nextstep2 + ;; + *) + os=-nextstep3 + ;; + esac + ;; + nh3000) + basic_machine=m68k-harris + os=-cxux + ;; + nh[45]000) + basic_machine=m88k-harris + os=-cxux + ;; + nindy960) + basic_machine=i960-intel + os=-nindy + ;; + mon960) + basic_machine=i960-intel + os=-mon960 + ;; + nonstopux) + basic_machine=mips-compaq + os=-nonstopux + ;; + np1) + basic_machine=np1-gould + ;; + nsr-tandem) + basic_machine=nsr-tandem + ;; + op50n-* | op60c-*) + basic_machine=hppa1.1-oki + os=-proelf + ;; + openrisc | openrisc-*) + basic_machine=or32-unknown + ;; + os400) + basic_machine=powerpc-ibm + os=-os400 + ;; + OSE68000 | ose68000) + basic_machine=m68000-ericsson + os=-ose + ;; + os68k) + basic_machine=m68k-none + os=-os68k + ;; + pa-hitachi) + basic_machine=hppa1.1-hitachi + os=-hiuxwe2 + ;; + paragon) + basic_machine=i860-intel + os=-osf + ;; + pbd) + basic_machine=sparc-tti + ;; + pbb) + basic_machine=m68k-tti + ;; + pc532 | pc532-*) + basic_machine=ns32k-pc532 + ;; + pc98) + basic_machine=i386-pc + ;; + pc98-*) + basic_machine=i386-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + pentium | p5 | k5 | k6 | nexgen | viac3) + basic_machine=i586-pc + ;; + pentiumpro | p6 | 6x86 | athlon | athlon_*) + basic_machine=i686-pc + ;; + pentiumii | pentium2 | pentiumiii | pentium3) + basic_machine=i686-pc + ;; + pentium4) + basic_machine=i786-pc + ;; + pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*) + basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + pentiumpro-* | p6-* | 6x86-* | athlon-*) + basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*) + basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + pentium4-*) + basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + pn) + basic_machine=pn-gould + ;; + power) basic_machine=power-ibm + ;; + ppc) basic_machine=powerpc-unknown + ;; + ppc-*) basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + ppcle | powerpclittle | ppc-le | powerpc-little) + basic_machine=powerpcle-unknown + ;; + ppcle-* | powerpclittle-*) + basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + ppc64) basic_machine=powerpc64-unknown + ;; + ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + ppc64le | powerpc64little | ppc64-le | powerpc64-little) + basic_machine=powerpc64le-unknown + ;; + ppc64le-* | powerpc64little-*) + basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'` + ;; + ps2) + basic_machine=i386-ibm + ;; + pw32) + basic_machine=i586-unknown + os=-pw32 + ;; + rdos) + basic_machine=i386-pc + os=-rdos + ;; + rom68k) + basic_machine=m68k-rom68k + os=-coff + ;; + rm[46]00) + basic_machine=mips-siemens + ;; + rtpc | rtpc-*) + basic_machine=romp-ibm + ;; + s390 | s390-*) + basic_machine=s390-ibm + ;; + s390x | s390x-*) + basic_machine=s390x-ibm + ;; + sa29200) + basic_machine=a29k-amd + os=-udi + ;; + sb1) + basic_machine=mipsisa64sb1-unknown + ;; + sb1el) + basic_machine=mipsisa64sb1el-unknown + ;; + sde) + basic_machine=mipsisa32-sde + os=-elf + ;; + sei) + basic_machine=mips-sei + os=-seiux + ;; + sequent) + basic_machine=i386-sequent + ;; + sh) + basic_machine=sh-hitachi + os=-hms + ;; + sh5el) + basic_machine=sh5le-unknown + ;; + sh64) + basic_machine=sh64-unknown + ;; + sparclite-wrs | simso-wrs) + basic_machine=sparclite-wrs + os=-vxworks + ;; + sps7) + basic_machine=m68k-bull + os=-sysv2 + ;; + spur) + basic_machine=spur-unknown + ;; + st2000) + basic_machine=m68k-tandem + ;; + stratus) + basic_machine=i860-stratus + os=-sysv4 + ;; + sun2) + basic_machine=m68000-sun + ;; + sun2os3) + basic_machine=m68000-sun + os=-sunos3 + ;; + sun2os4) + basic_machine=m68000-sun + os=-sunos4 + ;; + sun3os3) + basic_machine=m68k-sun + os=-sunos3 + ;; + sun3os4) + basic_machine=m68k-sun + os=-sunos4 + ;; + sun4os3) + basic_machine=sparc-sun + os=-sunos3 + ;; + sun4os4) + basic_machine=sparc-sun + os=-sunos4 + ;; + sun4sol2) + basic_machine=sparc-sun + os=-solaris2 + ;; + sun3 | sun3-*) + basic_machine=m68k-sun + ;; + sun4) + basic_machine=sparc-sun + ;; + sun386 | sun386i | roadrunner) + basic_machine=i386-sun + ;; + sv1) + basic_machine=sv1-cray + os=-unicos + ;; + symmetry) + basic_machine=i386-sequent + os=-dynix + ;; + t3e) + basic_machine=alphaev5-cray + os=-unicos + ;; + t90) + basic_machine=t90-cray + os=-unicos + ;; + tic54x | c54x*) + basic_machine=tic54x-unknown + os=-coff + ;; + tic55x | c55x*) + basic_machine=tic55x-unknown + os=-coff + ;; + tic6x | c6x*) + basic_machine=tic6x-unknown + os=-coff + ;; + tx39) + basic_machine=mipstx39-unknown + ;; + tx39el) + basic_machine=mipstx39el-unknown + ;; + toad1) + basic_machine=pdp10-xkl + os=-tops20 + ;; + tower | tower-32) + basic_machine=m68k-ncr + ;; + tpf) + basic_machine=s390x-ibm + os=-tpf + ;; + udi29k) + basic_machine=a29k-amd + os=-udi + ;; + ultra3) + basic_machine=a29k-nyu + os=-sym1 + ;; + v810 | necv810) + basic_machine=v810-nec + os=-none + ;; + vaxv) + basic_machine=vax-dec + os=-sysv + ;; + vms) + basic_machine=vax-dec + os=-vms + ;; + vpp*|vx|vx-*) + basic_machine=f301-fujitsu + ;; + vxworks960) + basic_machine=i960-wrs + os=-vxworks + ;; + vxworks68) + basic_machine=m68k-wrs + os=-vxworks + ;; + vxworks29k) + basic_machine=a29k-wrs + os=-vxworks + ;; + w65*) + basic_machine=w65-wdc + os=-none + ;; + w89k-*) + basic_machine=hppa1.1-winbond + os=-proelf + ;; + xbox) + basic_machine=i686-pc + os=-mingw32 + ;; + xps | xps100) + basic_machine=xps100-honeywell + ;; + ymp) + basic_machine=ymp-cray + os=-unicos + ;; + z8k-*-coff) + basic_machine=z8k-unknown + os=-sim + ;; + none) + basic_machine=none-none + os=-none + ;; + +# Here we handle the default manufacturer of certain CPU types. It is in +# some cases the only manufacturer, in others, it is the most popular. + w89k) + basic_machine=hppa1.1-winbond + ;; + op50n) + basic_machine=hppa1.1-oki + ;; + op60c) + basic_machine=hppa1.1-oki + ;; + romp) + basic_machine=romp-ibm + ;; + mmix) + basic_machine=mmix-knuth + ;; + rs6000) + basic_machine=rs6000-ibm + ;; + vax) + basic_machine=vax-dec + ;; + pdp10) + # there are many clones, so DEC is not a safe bet + basic_machine=pdp10-unknown + ;; + pdp11) + basic_machine=pdp11-dec + ;; + we32k) + basic_machine=we32k-att + ;; + sh[1234] | sh[24]a | sh[34]eb | sh[1234]le | sh[23]ele) + basic_machine=sh-unknown + ;; + sparc | sparcv8 | sparcv9 | sparcv9b | sparcv9v) + basic_machine=sparc-sun + ;; + cydra) + basic_machine=cydra-cydrome + ;; + orion) + basic_machine=orion-highlevel + ;; + orion105) + basic_machine=clipper-highlevel + ;; + mac | mpw | mac-mpw) + basic_machine=m68k-apple + ;; + pmac | pmac-mpw) + basic_machine=powerpc-apple + ;; + *-unknown) + # Make sure to match an already-canonicalized machine name. + ;; + *) + echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 + exit 1 + ;; +esac + +# Here we canonicalize certain aliases for manufacturers. +case $basic_machine in + *-digital*) + basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'` + ;; + *-commodore*) + basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'` + ;; + *) + ;; +esac + +# Decode manufacturer-specific aliases for certain operating systems. + +if [ x"$os" != x"" ] +then +case $os in + # First match some system type aliases + # that might get confused with valid system types. + # -solaris* is a basic system type, with this one exception. + -solaris1 | -solaris1.*) + os=`echo $os | sed -e 's|solaris1|sunos4|'` + ;; + -solaris) + os=-solaris2 + ;; + -svr4*) + os=-sysv4 + ;; + -unixware*) + os=-sysv4.2uw + ;; + -gnu/linux*) + os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'` + ;; + # First accept the basic system types. + # The portable systems comes first. + # Each alternative MUST END IN A *, to match a version number. + # -sysv* is not here because it comes later, after sysvr4. + -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \ + | -*vms* | -sco* | -esix* | -isc* | -aix* | -sunos | -sunos[34]*\ + | -hpux* | -unos* | -osf* | -luna* | -dgux* | -solaris* | -sym* \ + | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \ + | -aos* \ + | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \ + | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \ + | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \ + | -openbsd* | -solidbsd* \ + | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \ + | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \ + | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ + | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \ + | -chorusos* | -chorusrdb* \ + | -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ + | -mingw32* | -linux-gnu* | -linux-newlib* | -linux-uclibc* \ + | -uxpv* | -beos* | -mpeix* | -udk* \ + | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \ + | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \ + | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \ + | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \ + | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \ + | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \ + | -skyos* | -haiku* | -rdos* | -toppers* | -drops*) + # Remember, each alternative MUST END IN *, to match a version number. + ;; + -qnx*) + case $basic_machine in + x86-* | i*86-*) + ;; + *) + os=-nto$os + ;; + esac + ;; + -nto-qnx*) + ;; + -nto*) + os=`echo $os | sed -e 's|nto|nto-qnx|'` + ;; + -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \ + | -windows* | -osx | -abug | -netware* | -os9* | -beos* | -haiku* \ + | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*) + ;; + -mac*) + os=`echo $os | sed -e 's|mac|macos|'` + ;; + -linux-dietlibc) + os=-linux-dietlibc + ;; + -linux*) + os=`echo $os | sed -e 's|linux|linux-gnu|'` + ;; + -sunos5*) + os=`echo $os | sed -e 's|sunos5|solaris2|'` + ;; + -sunos6*) + os=`echo $os | sed -e 's|sunos6|solaris3|'` + ;; + -opened*) + os=-openedition + ;; + -os400*) + os=-os400 + ;; + -wince*) + os=-wince + ;; + -osfrose*) + os=-osfrose + ;; + -osf*) + os=-osf + ;; + -utek*) + os=-bsd + ;; + -dynix*) + os=-bsd + ;; + -acis*) + os=-aos + ;; + -atheos*) + os=-atheos + ;; + -syllable*) + os=-syllable + ;; + -386bsd) + os=-bsd + ;; + -ctix* | -uts*) + os=-sysv + ;; + -nova*) + os=-rtmk-nova + ;; + -ns2 ) + os=-nextstep2 + ;; + -nsk*) + os=-nsk + ;; + # Preserve the version number of sinix5. + -sinix5.*) + os=`echo $os | sed -e 's|sinix|sysv|'` + ;; + -sinix*) + os=-sysv4 + ;; + -tpf*) + os=-tpf + ;; + -triton*) + os=-sysv3 + ;; + -oss*) + os=-sysv3 + ;; + -svr4) + os=-sysv4 + ;; + -svr3) + os=-sysv3 + ;; + -sysvr4) + os=-sysv4 + ;; + # This must come after -sysvr4. + -sysv*) + ;; + -ose*) + os=-ose + ;; + -es1800*) + os=-ose + ;; + -xenix) + os=-xenix + ;; + -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) + os=-mint + ;; + -aros*) + os=-aros + ;; + -kaos*) + os=-kaos + ;; + -zvmoe) + os=-zvmoe + ;; + -none) + ;; + *) + # Get rid of the `-' at the beginning of $os. + os=`echo $os | sed 's/[^-]*-//'` + echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2 + exit 1 + ;; +esac +else + +# Here we handle the default operating systems that come with various machines. +# The value should be what the vendor currently ships out the door with their +# machine or put another way, the most popular os provided with the machine. + +# Note that if you're going to try to match "-MANUFACTURER" here (say, +# "-sun"), then you have to tell the case statement up towards the top +# that MANUFACTURER isn't an operating system. Otherwise, code above +# will signal an error saying that MANUFACTURER isn't an operating +# system, and we'll never get to this point. + +case $basic_machine in + score-*) + os=-elf + ;; + spu-*) + os=-elf + ;; + *-acorn) + os=-riscix1.2 + ;; + arm*-rebel) + os=-linux + ;; + arm*-semi) + os=-aout + ;; + c4x-* | tic4x-*) + os=-coff + ;; + # This must come before the *-dec entry. + pdp10-*) + os=-tops20 + ;; + pdp11-*) + os=-none + ;; + *-dec | vax-*) + os=-ultrix4.2 + ;; + m68*-apollo) + os=-domain + ;; + i386-sun) + os=-sunos4.0.2 + ;; + m68000-sun) + os=-sunos3 + # This also exists in the configure program, but was not the + # default. + # os=-sunos4 + ;; + m68*-cisco) + os=-aout + ;; + mep-*) + os=-elf + ;; + mips*-cisco) + os=-elf + ;; + mips*-*) + os=-elf + ;; + or32-*) + os=-coff + ;; + *-tti) # must be before sparc entry or we get the wrong os. + os=-sysv3 + ;; + sparc-* | *-sun) + os=-sunos4.1.1 + ;; + *-be) + os=-beos + ;; + *-haiku) + os=-haiku + ;; + *-ibm) + os=-aix + ;; + *-knuth) + os=-mmixware + ;; + *-wec) + os=-proelf + ;; + *-winbond) + os=-proelf + ;; + *-oki) + os=-proelf + ;; + *-hp) + os=-hpux + ;; + *-hitachi) + os=-hiux + ;; + i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent) + os=-sysv + ;; + *-cbm) + os=-amigaos + ;; + *-dg) + os=-dgux + ;; + *-dolphin) + os=-sysv3 + ;; + m68k-ccur) + os=-rtu + ;; + m88k-omron*) + os=-luna + ;; + *-next ) + os=-nextstep + ;; + *-sequent) + os=-ptx + ;; + *-crds) + os=-unos + ;; + *-ns) + os=-genix + ;; + i370-*) + os=-mvs + ;; + *-next) + os=-nextstep3 + ;; + *-gould) + os=-sysv + ;; + *-highlevel) + os=-bsd + ;; + *-encore) + os=-bsd + ;; + *-sgi) + os=-irix + ;; + *-siemens) + os=-sysv4 + ;; + *-masscomp) + os=-rtu + ;; + f30[01]-fujitsu | f700-fujitsu) + os=-uxpv + ;; + *-rom68k) + os=-coff + ;; + *-*bug) + os=-coff + ;; + *-apple) + os=-macos + ;; + *-atari*) + os=-mint + ;; + *) + os=-none + ;; +esac +fi + +# Here we handle the case where we know the os, and the CPU type, but not the +# manufacturer. We pick the logical manufacturer. +vendor=unknown +case $basic_machine in + *-unknown) + case $os in + -riscix*) + vendor=acorn + ;; + -sunos*) + vendor=sun + ;; + -aix*) + vendor=ibm + ;; + -beos*) + vendor=be + ;; + -hpux*) + vendor=hp + ;; + -mpeix*) + vendor=hp + ;; + -hiux*) + vendor=hitachi + ;; + -unos*) + vendor=crds + ;; + -dgux*) + vendor=dg + ;; + -luna*) + vendor=omron + ;; + -genix*) + vendor=ns + ;; + -mvs* | -opened*) + vendor=ibm + ;; + -os400*) + vendor=ibm + ;; + -ptx*) + vendor=sequent + ;; + -tpf*) + vendor=ibm + ;; + -vxsim* | -vxworks* | -windiss*) + vendor=wrs + ;; + -aux*) + vendor=apple + ;; + -hms*) + vendor=hitachi + ;; + -mpw* | -macos*) + vendor=apple + ;; + -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) + vendor=atari + ;; + -vos*) + vendor=stratus + ;; + esac + basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"` + ;; +esac + +echo $basic_machine$os +exit + +# Local variables: +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "timestamp='" +# time-stamp-format: "%:y-%02m-%02d" +# time-stamp-end: "'" +# End: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/debugconfig.sh b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/debugconfig.sh new file mode 100644 index 0000000000..c9f597fed4 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/debugconfig.sh @@ -0,0 +1,3 @@ +#! /bin/sh + +CXXFLAGS="-g -Wall" ./configure --disable-shared diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/depcomp b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/depcomp new file mode 100644 index 0000000000..807b991f4a --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/depcomp @@ -0,0 +1,423 @@ +#! /bin/sh + +# depcomp - compile a program generating dependencies as side-effects +# Copyright 1999, 2000 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., 59 Temple Place - Suite 330, Boston, MA +# 02111-1307, 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 . + +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 +# `libtool' can also be set to `yes' or `no'. + +if test -z "$depfile"; then + base=`echo "$object" | sed -e 's,^.*/,,' -e 's,\.\([^.]*\)$,.P\1,'` + dir=`echo "$object" | sed 's,/.*$,/,'` + if test "$dir" = "$object"; then + dir= + fi + # FIXME: should be _deps on DOS. + depfile="$dir.deps/$base" +fi + +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. + "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" + 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. 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. + stripped=`echo "$object" | sed -e 's,^.*/,,' -e 's/\(.*\)\..*$/\1/'` + tmpdepfile="$stripped.u" + outname="$stripped.o" + if test "$libtool" = yes; then + "$@" -Wc,-M + else + "$@" -M + fi + + stat=$? + if test $stat -eq 0; then : + else + rm -f "$tmpdepfile" + exit $stat + fi + + if test -f "$tmpdepfile"; then + # 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" + ;; + +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 + tmpdepfile1="$dir.libs/$base.lo.d" + tmpdepfile2="$dir.libs/$base.d" + "$@" -Wc,-MD + else + tmpdepfile1="$dir$base.o.d" + tmpdepfile2="$dir$base.d" + "$@" -MD + fi + + stat=$? + if test $stat -eq 0; then : + else + rm -f "$tmpdepfile1" "$tmpdepfile2" + exit $stat + fi + + if test -f "$tmpdepfile1"; then + tmpdepfile="$tmpdepfile1" + else + tmpdepfile="$tmpdepfile2" + fi + if test -f "$tmpdepfile"; then + sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile" + # That's a space and a tab 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 proprocessed 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'. We will use -o /dev/null later, + # however we can't do the remplacement now because + # `-o $object' might simply not be used + 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 + "$@" -o /dev/null $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 $? + # 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 ;; + -*) + ;; + *) + 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 proprocessed 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 '/^# [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 proprocessed 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 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/install-sh b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/install-sh new file mode 100644 index 0000000000..e8436696c1 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/install-sh @@ -0,0 +1,250 @@ +#!/bin/sh +# +# install - install a program, script, or datafile +# This comes from X11R5 (mit/util/scripts/install.sh). +# +# Copyright 1991 by the Massachusetts Institute of Technology +# +# Permission to use, copy, modify, distribute, and sell this software and its +# documentation for any purpose is hereby granted without fee, provided that +# the above copyright notice appear in all copies and that both that +# copyright notice and this permission notice appear in supporting +# documentation, and that the name of M.I.T. not be used in advertising or +# publicity pertaining to distribution of the software without specific, +# written prior permission. M.I.T. makes no representations about the +# suitability of this software for any purpose. It is provided "as is" +# without express or implied warranty. +# +# 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. It can only install one file at a time, a restriction +# shared with many OS's install programs. + + +# set DOITPROG to echo to test this script + +# Don't use :- since 4.3BSD and earlier shells don't like it. +doit="${DOITPROG-}" + + +# put in absolute paths if you don't have them in your path; or use env. 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}" + +transformbasename="" +transform_arg="" +instcmd="$mvprog" +chmodcmd="$chmodprog 0755" +chowncmd="" +chgrpcmd="" +stripcmd="" +rmcmd="$rmprog -f" +mvcmd="$mvprog" +src="" +dst="" +dir_arg="" + +while [ x"$1" != x ]; do + case $1 in + -c) instcmd="$cpprog" + shift + continue;; + + -d) dir_arg=true + shift + continue;; + + -m) chmodcmd="$chmodprog $2" + shift + shift + continue;; + + -o) chowncmd="$chownprog $2" + shift + shift + continue;; + + -g) chgrpcmd="$chgrpprog $2" + shift + shift + continue;; + + -s) stripcmd="$stripprog" + shift + continue;; + + -t=*) transformarg=`echo $1 | sed 's/-t=//'` + shift + continue;; + + -b=*) transformbasename=`echo $1 | sed 's/-b=//'` + shift + continue;; + + *) if [ x"$src" = x ] + then + src=$1 + else + # this colon is to work around a 386BSD /bin/sh bug + : + dst=$1 + fi + shift + continue;; + esac +done + +if [ x"$src" = x ] +then + echo "install: no input file specified" + exit 1 +else + true +fi + +if [ x"$dir_arg" != x ]; then + dst=$src + src="" + + if [ -d $dst ]; then + instcmd=: + else + instcmd=mkdir + fi +else + +# Waiting for this to be detected by the "$instcmd $src $dsttmp" command +# might cause directories to be created, which would be especially bad +# if $src (and thus $dsttmp) contains '*'. + + if [ -f $src -o -d $src ] + then + true + else + echo "install: $src does not exist" + exit 1 + fi + + if [ x"$dst" = x ] + then + echo "install: no destination specified" + exit 1 + else + true + fi + +# If destination is a directory, append the input filename; if your system +# does not like double slashes in filenames, you may need to add some logic + + if [ -d $dst ] + then + dst="$dst"/`basename $src` + else + true + fi +fi + +## this sed command emulates the dirname command +dstdir=`echo $dst | sed -e 's,[^/]*$,,;s,/$,,;s,^$,.,'` + +# Make sure that the destination directory exists. +# this part is taken from Noah Friedman's mkinstalldirs script + +# Skip lots of stat calls in the usual case. +if [ ! -d "$dstdir" ]; then +defaultIFS=' +' +IFS="${IFS-${defaultIFS}}" + +oIFS="${IFS}" +# Some sh's can't handle IFS=/ for some reason. +IFS='%' +set - `echo ${dstdir} | sed -e 's@/@%@g' -e 's@^%@/@'` +IFS="${oIFS}" + +pathcomp='' + +while [ $# -ne 0 ] ; do + pathcomp="${pathcomp}${1}" + shift + + if [ ! -d "${pathcomp}" ] ; + then + $mkdirprog "${pathcomp}" + else + true + fi + + pathcomp="${pathcomp}/" +done +fi + +if [ x"$dir_arg" != x ] +then + $doit $instcmd $dst && + + if [ x"$chowncmd" != x ]; then $doit $chowncmd $dst; else true ; fi && + if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dst; else true ; fi && + if [ x"$stripcmd" != x ]; then $doit $stripcmd $dst; else true ; fi && + if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dst; else true ; fi +else + +# If we're going to rename the final executable, determine the name now. + + if [ x"$transformarg" = x ] + then + dstfile=`basename $dst` + else + dstfile=`basename $dst $transformbasename | + sed $transformarg`$transformbasename + fi + +# don't allow the sed command to completely eliminate the filename + + if [ x"$dstfile" = x ] + then + dstfile=`basename $dst` + else + true + fi + +# Make a temp file name in the proper directory. + + dsttmp=$dstdir/#inst.$$# + +# Move or copy the file name to the temp name + + $doit $instcmd $src $dsttmp && + + trap "rm -f ${dsttmp}" 0 && + +# 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 $instcmd $src $dsttmp" command. + + if [ x"$chowncmd" != x ]; then $doit $chowncmd $dsttmp; else true;fi && + if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dsttmp; else true;fi && + if [ x"$stripcmd" != x ]; then $doit $stripcmd $dsttmp; else true;fi && + if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dsttmp; else true;fi && + +# Now rename the file to the real destination. + + $doit $rmcmd -f $dstdir/$dstfile && + $doit $mvcmd $dsttmp $dstdir/$dstfile + +fi && + + +exit 0 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/ltconfig b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/ltconfig new file mode 100755 index 0000000000..e3afc39777 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/ltconfig @@ -0,0 +1,3115 @@ +#! /bin/sh + +# ltconfig - Create a system-specific libtool. +# Copyright (C) 1996-1999 Free Software Foundation, Inc. +# Originally by Gordon Matzigkeit , 1996 +# +# This file 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 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, 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. + +# A lot of this script is taken from autoconf-2.10. + +# Check that we are running under the correct shell. +SHELL=${CONFIG_SHELL-/bin/sh} +echo=echo +if test "X$1" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift +elif test "X$1" = X--fallback-echo; then + # Avoid inline document here, it may be left over + : +elif test "X`($echo '\t') 2>/dev/null`" = 'X\t'; then + # Yippee, $echo works! + : +else + # Restart under the correct shell. + exec "$SHELL" "$0" --no-reexec ${1+"$@"} +fi + +if test "X$1" = X--fallback-echo; then + # used as fallback echo + shift + cat </dev/null`} + case X$UNAME in + *-DOS) PATH_SEPARATOR=';' ;; + *) PATH_SEPARATOR=':' ;; + esac +fi + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +if test "X${CDPATH+set}" = Xset; then CDPATH=:; export CDPATH; fi + +if test "X${echo_test_string+set}" != Xset; then + # find a string as large as possible, as long as the shell can cope with it + for cmd in 'sed 50q "$0"' 'sed 20q "$0"' 'sed 10q "$0"' 'sed 2q "$0"' 'echo test'; do + # expected sizes: less than 2Kb, 1Kb, 512 bytes, 16 bytes, ... + if (echo_test_string="`eval $cmd`") 2>/dev/null && + echo_test_string="`eval $cmd`" && + (test "X$echo_test_string" = "X$echo_test_string") 2>/dev/null; then + break + fi + done +fi + +if test "X`($echo '\t') 2>/dev/null`" != 'X\t' || + test "X`($echo "$echo_test_string") 2>/dev/null`" != X"$echo_test_string"; then + # The Solaris, AIX, and Digital Unix default echo programs unquote + # backslashes. This makes it impossible to quote backslashes using + # echo "$something" | sed 's/\\/\\\\/g' + # + # So, first we look for a working echo in the user's PATH. + + IFS="${IFS= }"; save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR}" + for dir in $PATH /usr/ucb; do + if (test -f $dir/echo || test -f $dir/echo$ac_exeext) && + test "X`($dir/echo '\t') 2>/dev/null`" = 'X\t' && + test "X`($dir/echo "$echo_test_string") 2>/dev/null`" = X"$echo_test_string"; then + echo="$dir/echo" + break + fi + done + IFS="$save_ifs" + + if test "X$echo" = Xecho; then + # We didn't find a better echo, so look for alternatives. + if test "X`(print -r '\t') 2>/dev/null`" = 'X\t' && + test "X`(print -r "$echo_test_string") 2>/dev/null`" = X"$echo_test_string"; then + # This shell has a builtin print -r that does the trick. + echo='print -r' + elif (test -f /bin/ksh || test -f /bin/ksh$ac_exeext) && + test "X$CONFIG_SHELL" != X/bin/ksh; then + # If we have ksh, try running ltconfig again with it. + ORIGINAL_CONFIG_SHELL="${CONFIG_SHELL-/bin/sh}" + export ORIGINAL_CONFIG_SHELL + CONFIG_SHELL=/bin/ksh + export CONFIG_SHELL + exec "$CONFIG_SHELL" "$0" --no-reexec ${1+"$@"} + else + # Try using printf. + echo='printf "%s\n"' + if test "X`($echo '\t') 2>/dev/null`" = 'X\t' && + test "X`($echo "$echo_test_string") 2>/dev/null`" = X"$echo_test_string"; then + # Cool, printf works + : + elif test "X`("$ORIGINAL_CONFIG_SHELL" "$0" --fallback-echo '\t') 2>/dev/null`" = 'X\t' && + test "X`("$ORIGINAL_CONFIG_SHELL" "$0" --fallback-echo "$echo_test_string") 2>/dev/null`" = X"$echo_test_string"; then + CONFIG_SHELL="$ORIGINAL_CONFIG_SHELL" + export CONFIG_SHELL + SHELL="$CONFIG_SHELL" + export SHELL + echo="$CONFIG_SHELL $0 --fallback-echo" + elif test "X`("$CONFIG_SHELL" "$0" --fallback-echo '\t') 2>/dev/null`" = 'X\t' && + test "X`("$CONFIG_SHELL" "$0" --fallback-echo "$echo_test_string") 2>/dev/null`" = X"$echo_test_string"; then + echo="$CONFIG_SHELL $0 --fallback-echo" + else + # maybe with a smaller string... + prev=: + + for cmd in 'echo test' 'sed 2q "$0"' 'sed 10q "$0"' 'sed 20q "$0"' 'sed 50q "$0"'; do + if (test "X$echo_test_string" = "X`eval $cmd`") 2>/dev/null; then + break + fi + prev="$cmd" + done + + if test "$prev" != 'sed 50q "$0"'; then + echo_test_string=`eval $prev` + export echo_test_string + exec "${ORIGINAL_CONFIG_SHELL}" "$0" ${1+"$@"} + else + # Oops. We lost completely, so just stick with echo. + echo=echo + fi + fi + fi + fi +fi + +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +Xsed='sed -e s/^X//' +sed_quote_subst='s/\([\\"\\`$\\\\]\)/\\\1/g' + +# Same as above, but do not quote variable references. +double_quote_subst='s/\([\\"\\`\\\\]\)/\\\1/g' + +# Sed substitution to delay expansion of an escaped shell variable in a +# double_quote_subst'ed string. +delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' + +# The name of this program. +progname=`$echo "X$0" | $Xsed -e 's%^.*/%%'` + +# Constants: +PROGRAM=ltconfig +PACKAGE=libtool +VERSION=1.3.5 +TIMESTAMP=" (1.385.2.206 2000/05/27 11:12:27)" +ac_compile='${CC-cc} -c $CFLAGS $CPPFLAGS conftest.$ac_ext 1>&5' +ac_link='${CC-cc} -o conftest $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS 1>&5' +rm="rm -f" + +help="Try \`$progname --help' for more information." + +# Global variables: +default_ofile=libtool +can_build_shared=yes +enable_shared=yes +# All known linkers require a `.a' archive for static linking (except M$VC, +# which needs '.lib'). +enable_static=yes +enable_fast_install=yes +enable_dlopen=unknown +enable_win32_dll=no +ltmain= +silent= +srcdir= +ac_config_guess= +ac_config_sub= +host= +nonopt= +ofile="$default_ofile" +verify_host=yes +with_gcc=no +with_gnu_ld=no +need_locks=yes +ac_ext=c +objext=o +libext=a +exeext= +cache_file= + +old_AR="$AR" +old_CC="$CC" +old_CFLAGS="$CFLAGS" +old_CPPFLAGS="$CPPFLAGS" +old_LDFLAGS="$LDFLAGS" +old_LD="$LD" +old_LN_S="$LN_S" +old_LIBS="$LIBS" +old_NM="$NM" +old_RANLIB="$RANLIB" +old_DLLTOOL="$DLLTOOL" +old_OBJDUMP="$OBJDUMP" +old_AS="$AS" + +# Parse the command line options. +args= +prev= +for option +do + case "$option" in + -*=*) optarg=`echo "$option" | sed 's/[-_a-zA-Z0-9]*=//'` ;; + *) optarg= ;; + esac + + # If the previous option needs an argument, assign it. + if test -n "$prev"; then + eval "$prev=\$option" + prev= + continue + fi + + case "$option" in + --help) cat <&2 + echo "$help" 1>&2 + exit 1 + ;; + + *) + if test -z "$ltmain"; then + ltmain="$option" + elif test -z "$host"; then +# This generates an unnecessary warning for sparc-sun-solaris4.1.3_U1 +# if test -n "`echo $option| sed 's/[-a-z0-9.]//g'`"; then +# echo "$progname: warning \`$option' is not a valid host type" 1>&2 +# fi + host="$option" + else + echo "$progname: too many arguments" 1>&2 + echo "$help" 1>&2 + exit 1 + fi ;; + esac +done + +if test -z "$ltmain"; then + echo "$progname: you must specify a LTMAIN file" 1>&2 + echo "$help" 1>&2 + exit 1 +fi + +if test ! -f "$ltmain"; then + echo "$progname: \`$ltmain' does not exist" 1>&2 + echo "$help" 1>&2 + exit 1 +fi + +# Quote any args containing shell metacharacters. +ltconfig_args= +for arg +do + case "$arg" in + *" "*|*" "*|*[\[\]\~\#\$\^\&\*\(\)\{\}\\\|\;\<\>\?]*) + ltconfig_args="$ltconfig_args '$arg'" ;; + *) ltconfig_args="$ltconfig_args $arg" ;; + esac +done + +# A relevant subset of AC_INIT. + +# File descriptor usage: +# 0 standard input +# 1 file creation +# 2 errors and warnings +# 3 some systems may open it to /dev/tty +# 4 used on the Kubota Titan +# 5 compiler messages saved in config.log +# 6 checking for... messages and results +if test "$silent" = yes; then + exec 6>/dev/null +else + exec 6>&1 +fi +exec 5>>./config.log + +# NLS nuisances. +# Only set LANG and LC_ALL to C if already set. +# These must not be set unconditionally because not all systems understand +# e.g. LANG=C (notably SCO). +if test "X${LC_ALL+set}" = Xset; then LC_ALL=C; export LC_ALL; fi +if test "X${LANG+set}" = Xset; then LANG=C; export LANG; fi + +if test -n "$cache_file" && test -r "$cache_file"; then + echo "loading cache $cache_file within ltconfig" + . $cache_file +fi + +if (echo "testing\c"; echo 1,2,3) | grep c >/dev/null; then + # Stardent Vistra SVR4 grep lacks -e, says ghazi@caip.rutgers.edu. + if (echo -n testing; echo 1,2,3) | sed s/-n/xn/ | grep xn >/dev/null; then + ac_n= ac_c=' +' ac_t=' ' + else + ac_n=-n ac_c= ac_t= + fi +else + ac_n= ac_c='\c' ac_t= +fi + +if test -z "$srcdir"; then + # Assume the source directory is the same one as the path to LTMAIN. + srcdir=`$echo "X$ltmain" | $Xsed -e 's%/[^/]*$%%'` + test "$srcdir" = "$ltmain" && srcdir=. +fi + +trap "$rm conftest*; exit 1" 1 2 15 +if test "$verify_host" = yes; then + # Check for config.guess and config.sub. + ac_aux_dir= + for ac_dir in $srcdir $srcdir/.. $srcdir/../..; do + if test -f $ac_dir/config.guess; then + ac_aux_dir=$ac_dir + break + fi + done + if test -z "$ac_aux_dir"; then + echo "$progname: cannot find config.guess in $srcdir $srcdir/.. $srcdir/../.." 1>&2 + echo "$help" 1>&2 + exit 1 + fi + ac_config_guess=$ac_aux_dir/config.guess + ac_config_sub=$ac_aux_dir/config.sub + + # Make sure we can run config.sub. + if $SHELL $ac_config_sub sun4 >/dev/null 2>&1; then : + else + echo "$progname: cannot run $ac_config_sub" 1>&2 + echo "$help" 1>&2 + exit 1 + fi + + echo $ac_n "checking host system type""... $ac_c" 1>&6 + + host_alias=$host + case "$host_alias" in + "") + if host_alias=`$SHELL $ac_config_guess`; then : + else + echo "$progname: cannot guess host type; you must specify one" 1>&2 + echo "$help" 1>&2 + exit 1 + fi ;; + esac + host=`$SHELL $ac_config_sub $host_alias` + echo "$ac_t$host" 1>&6 + + # Make sure the host verified. + test -z "$host" && exit 1 + +elif test -z "$host"; then + echo "$progname: you must specify a host type if you use \`--no-verify'" 1>&2 + echo "$help" 1>&2 + exit 1 +else + host_alias=$host +fi + +# Transform linux* to *-*-linux-gnu*, to support old configure scripts. +case "$host_os" in +linux-gnu*) ;; +linux*) host=`echo $host | sed 's/^\(.*-.*-linux\)\(.*\)$/\1-gnu\2/'` +esac + +host_cpu=`echo $host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'` +host_vendor=`echo $host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\2/'` +host_os=`echo $host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'` + +case "$host_os" in +aix3*) + # AIX sometimes has problems with the GCC collect2 program. For some + # reason, if we set the COLLECT_NAMES environment variable, the problems + # vanish in a puff of smoke. + if test "X${COLLECT_NAMES+set}" != Xset; then + COLLECT_NAMES= + export COLLECT_NAMES + fi + ;; +esac + +# Determine commands to create old-style static archives. +old_archive_cmds='$AR cru $oldlib$oldobjs' +old_postinstall_cmds='chmod 644 $oldlib' +old_postuninstall_cmds= + +# Set a sane default for `AR'. +test -z "$AR" && AR=ar + +# Set a sane default for `OBJDUMP'. +test -z "$OBJDUMP" && OBJDUMP=objdump + +# If RANLIB is not set, then run the test. +if test "${RANLIB+set}" != "set"; then + result=no + + echo $ac_n "checking for ranlib... $ac_c" 1>&6 + IFS="${IFS= }"; save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR}" + for dir in $PATH; do + test -z "$dir" && dir=. + if test -f $dir/ranlib || test -f $dir/ranlib$ac_exeext; then + RANLIB="ranlib" + result="ranlib" + break + fi + done + IFS="$save_ifs" + + echo "$ac_t$result" 1>&6 +fi + +if test -n "$RANLIB"; then + old_archive_cmds="$old_archive_cmds~\$RANLIB \$oldlib" + old_postinstall_cmds="\$RANLIB \$oldlib~$old_postinstall_cmds" +fi + +# Set sane defaults for `DLLTOOL', `OBJDUMP', and `AS', used on cygwin. +test -z "$DLLTOOL" && DLLTOOL=dlltool +test -z "$OBJDUMP" && OBJDUMP=objdump +test -z "$AS" && AS=as + +# Check to see if we are using GCC. +if test "$with_gcc" != yes || test -z "$CC"; then + # If CC is not set, then try to find GCC or a usable CC. + if test -z "$CC"; then + echo $ac_n "checking for gcc... $ac_c" 1>&6 + IFS="${IFS= }"; save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR}" + for dir in $PATH; do + test -z "$dir" && dir=. + if test -f $dir/gcc || test -f $dir/gcc$ac_exeext; then + CC="gcc" + break + fi + done + IFS="$save_ifs" + + if test -n "$CC"; then + echo "$ac_t$CC" 1>&6 + else + echo "$ac_t"no 1>&6 + fi + fi + + # Not "gcc", so try "cc", rejecting "/usr/ucb/cc". + if test -z "$CC"; then + echo $ac_n "checking for cc... $ac_c" 1>&6 + IFS="${IFS= }"; save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR}" + cc_rejected=no + for dir in $PATH; do + test -z "$dir" && dir=. + if test -f $dir/cc || test -f $dir/cc$ac_exeext; then + if test "$dir/cc" = "/usr/ucb/cc"; then + cc_rejected=yes + continue + fi + CC="cc" + break + fi + done + IFS="$save_ifs" + if test $cc_rejected = yes; then + # We found a bogon in the path, so make sure we never use it. + set dummy $CC + shift + if test $# -gt 0; then + # We chose a different compiler from the bogus one. + # However, it has the same name, so the bogon will be chosen + # first if we set CC to just the name; use the full file name. + shift + set dummy "$dir/cc" "$@" + shift + CC="$@" + fi + fi + + if test -n "$CC"; then + echo "$ac_t$CC" 1>&6 + else + echo "$ac_t"no 1>&6 + fi + + if test -z "$CC"; then + echo "$progname: error: no acceptable cc found in \$PATH" 1>&2 + exit 1 + fi + fi + + # Now see if the compiler is really GCC. + with_gcc=no + echo $ac_n "checking whether we are using GNU C... $ac_c" 1>&6 + echo "$progname:581: checking whether we are using GNU C" >&5 + + $rm conftest.c + cat > conftest.c <&5; (eval $ac_try) 2>&5; }; } | egrep yes >/dev/null 2>&1; then + with_gcc=yes + fi + $rm conftest.c + echo "$ac_t$with_gcc" 1>&6 +fi + +# Allow CC to be a program name with arguments. +set dummy $CC +compiler="$2" + +echo $ac_n "checking for object suffix... $ac_c" 1>&6 +$rm conftest* +echo 'int i = 1;' > conftest.c +echo "$progname:603: checking for object suffix" >& 5 +if { (eval echo $progname:604: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>conftest.err; }; then + # Append any warnings to the config.log. + cat conftest.err 1>&5 + + for ac_file in conftest.*; do + case $ac_file in + *.c) ;; + *) objext=`echo $ac_file | sed -e s/conftest.//` ;; + esac + done +else + cat conftest.err 1>&5 + echo "$progname: failed program was:" >&5 + cat conftest.c >&5 +fi +$rm conftest* +echo "$ac_t$objext" 1>&6 + +echo $ac_n "checking for executable suffix... $ac_c" 1>&6 +if eval "test \"`echo '$''{'ac_cv_exeext'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_cv_exeext="no" + $rm conftest* + echo 'main () { return 0; }' > conftest.c + echo "$progname:629: checking for executable suffix" >& 5 + if { (eval echo $progname:630: \"$ac_link\") 1>&5; (eval $ac_link) 2>conftest.err; }; then + # Append any warnings to the config.log. + cat conftest.err 1>&5 + + for ac_file in conftest.*; do + case $ac_file in + *.c | *.err | *.$objext ) ;; + *) ac_cv_exeext=.`echo $ac_file | sed -e s/conftest.//` ;; + esac + done + else + cat conftest.err 1>&5 + echo "$progname: failed program was:" >&5 + cat conftest.c >&5 + fi + $rm conftest* +fi +if test "X$ac_cv_exeext" = Xno; then + exeext="" +else + exeext="$ac_cv_exeext" +fi +echo "$ac_t$ac_cv_exeext" 1>&6 + +echo $ac_n "checking for $compiler option to produce PIC... $ac_c" 1>&6 +pic_flag= +special_shlib_compile_flags= +wl= +link_static_flag= +no_builtin_flag= + +if test "$with_gcc" = yes; then + wl='-Wl,' + link_static_flag='-static' + + case "$host_os" in + beos* | irix5* | irix6* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + aix*) + # Below there is a dirty hack to force normal static linking with -ldl + # The problem is because libdl dynamically linked with both libc and + # libC (AIX C++ library), which obviously doesn't included in libraries + # list by gcc. This cause undefined symbols with -static flags. + # This hack allows C programs to be linked with "-static -ldl", but + # we not sure about C++ programs. + link_static_flag="$link_static_flag ${wl}-lC" + ;; + cygwin* | mingw* | os2*) + # We can build DLLs from non-PIC. + ;; + amigaos*) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + pic_flag='-m68020 -resident32 -malways-restore-a4' + ;; + sysv4*MP*) + if test -d /usr/nec; then + pic_flag=-Kconform_pic + fi + ;; + *) + pic_flag='-fPIC' + ;; + esac +else + # PORTME Check for PIC flags for the system compiler. + case "$host_os" in + aix3* | aix4*) + # All AIX code is PIC. + link_static_flag='-bnso -bI:/lib/syscalls.exp' + ;; + + hpux9* | hpux10* | hpux11*) + # Is there a better link_static_flag that works with the bundled CC? + wl='-Wl,' + link_static_flag="${wl}-a ${wl}archive" + pic_flag='+Z' + ;; + + irix5* | irix6*) + wl='-Wl,' + link_static_flag='-non_shared' + # PIC (with -KPIC) is the default. + ;; + + cygwin* | mingw* | os2*) + # We can build DLLs from non-PIC. + ;; + + osf3* | osf4* | osf5*) + # All OSF/1 code is PIC. + wl='-Wl,' + link_static_flag='-non_shared' + ;; + + sco3.2v5*) + pic_flag='-Kpic' + link_static_flag='-dn' + special_shlib_compile_flags='-belf' + ;; + + solaris*) + pic_flag='-KPIC' + link_static_flag='-Bstatic' + wl='-Wl,' + ;; + + sunos4*) + pic_flag='-PIC' + link_static_flag='-Bstatic' + wl='-Qoption ld ' + ;; + + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + pic_flag='-KPIC' + link_static_flag='-Bstatic' + wl='-Wl,' + ;; + + uts4*) + pic_flag='-pic' + link_static_flag='-Bstatic' + ;; + sysv4*MP*) + if test -d /usr/nec ;then + pic_flag='-Kconform_pic' + link_static_flag='-Bstatic' + fi + ;; + *) + can_build_shared=no + ;; + esac +fi + +if test -n "$pic_flag"; then + echo "$ac_t$pic_flag" 1>&6 + + # Check to make sure the pic_flag actually works. + echo $ac_n "checking if $compiler PIC flag $pic_flag works... $ac_c" 1>&6 + $rm conftest* + echo "int some_variable = 0;" > conftest.c + save_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS $pic_flag -DPIC" + echo "$progname:776: checking if $compiler PIC flag $pic_flag works" >&5 + if { (eval echo $progname:777: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>conftest.err; } && test -s conftest.$objext; then + # Append any warnings to the config.log. + cat conftest.err 1>&5 + + case "$host_os" in + hpux9* | hpux10* | hpux11*) + # On HP-UX, both CC and GCC only warn that PIC is supported... then they + # create non-PIC objects. So, if there were any warnings, we assume that + # PIC is not supported. + if test -s conftest.err; then + echo "$ac_t"no 1>&6 + can_build_shared=no + pic_flag= + else + echo "$ac_t"yes 1>&6 + pic_flag=" $pic_flag" + fi + ;; + *) + echo "$ac_t"yes 1>&6 + pic_flag=" $pic_flag" + ;; + esac + else + # Append any errors to the config.log. + cat conftest.err 1>&5 + can_build_shared=no + pic_flag= + echo "$ac_t"no 1>&6 + fi + CFLAGS="$save_CFLAGS" + $rm conftest* +else + echo "$ac_t"none 1>&6 +fi + +# Check to see if options -o and -c are simultaneously supported by compiler +echo $ac_n "checking if $compiler supports -c -o file.o... $ac_c" 1>&6 +$rm -r conftest 2>/dev/null +mkdir conftest +cd conftest +$rm conftest* +echo "int some_variable = 0;" > conftest.c +mkdir out +# According to Tom Tromey, Ian Lance Taylor reported there are C compilers +# that will create temporary files in the current directory regardless of +# the output directory. Thus, making CWD read-only will cause this test +# to fail, enabling locking or at least warning the user not to do parallel +# builds. +chmod -w . +save_CFLAGS="$CFLAGS" +CFLAGS="$CFLAGS -o out/conftest2.o" +echo "$progname:829: checking if $compiler supports -c -o file.o" >&5 +if { (eval echo $progname:830: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>out/conftest.err; } && test -s out/conftest2.o; then + + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s out/conftest.err; then + echo "$ac_t"no 1>&6 + compiler_c_o=no + else + echo "$ac_t"yes 1>&6 + compiler_c_o=yes + fi +else + # Append any errors to the config.log. + cat out/conftest.err 1>&5 + compiler_c_o=no + echo "$ac_t"no 1>&6 +fi +CFLAGS="$save_CFLAGS" +chmod u+w . +$rm conftest* out/* +rmdir out +cd .. +rmdir conftest +$rm -r conftest 2>/dev/null + +if test x"$compiler_c_o" = x"yes"; then + # Check to see if we can write to a .lo + echo $ac_n "checking if $compiler supports -c -o file.lo... $ac_c" 1>&6 + $rm conftest* + echo "int some_variable = 0;" > conftest.c + save_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS -c -o conftest.lo" + echo "$progname:862: checking if $compiler supports -c -o file.lo" >&5 +if { (eval echo $progname:863: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>conftest.err; } && test -s conftest.lo; then + + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + echo "$ac_t"no 1>&6 + compiler_o_lo=no + else + echo "$ac_t"yes 1>&6 + compiler_o_lo=yes + fi + else + # Append any errors to the config.log. + cat conftest.err 1>&5 + compiler_o_lo=no + echo "$ac_t"no 1>&6 + fi + CFLAGS="$save_CFLAGS" + $rm conftest* +else + compiler_o_lo=no +fi + +# Check to see if we can do hard links to lock some files if needed +hard_links="nottested" +if test "$compiler_c_o" = no && test "$need_locks" != no; then + # do not overwrite the value of need_locks provided by the user + echo $ac_n "checking if we can lock with hard links... $ac_c" 1>&6 + hard_links=yes + $rm conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + echo "$ac_t$hard_links" 1>&6 + $rm conftest* + if test "$hard_links" = no; then + echo "*** WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2 + need_locks=warn + fi +else + need_locks=no +fi + +if test "$with_gcc" = yes; then + # Check to see if options -fno-rtti -fno-exceptions are supported by compiler + echo $ac_n "checking if $compiler supports -fno-rtti -fno-exceptions ... $ac_c" 1>&6 + $rm conftest* + echo "int some_variable = 0;" > conftest.c + save_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS -fno-rtti -fno-exceptions -c conftest.c" + echo "$progname:914: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 + if { (eval echo $progname:915: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>conftest.err; } && test -s conftest.o; then + + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + echo "$ac_t"no 1>&6 + compiler_rtti_exceptions=no + else + echo "$ac_t"yes 1>&6 + compiler_rtti_exceptions=yes + fi + else + # Append any errors to the config.log. + cat conftest.err 1>&5 + compiler_rtti_exceptions=no + echo "$ac_t"no 1>&6 + fi + CFLAGS="$save_CFLAGS" + $rm conftest* + + if test "$compiler_rtti_exceptions" = "yes"; then + no_builtin_flag=' -fno-builtin -fno-rtti -fno-exceptions' + else + no_builtin_flag=' -fno-builtin' + fi + +fi + +# Check for any special shared library compilation flags. +if test -n "$special_shlib_compile_flags"; then + echo "$progname: warning: \`$CC' requires \`$special_shlib_compile_flags' to build shared libraries" 1>&2 + if echo "$old_CC $old_CFLAGS " | egrep -e "[ ]$special_shlib_compile_flags[ ]" >/dev/null; then : + else + echo "$progname: add \`$special_shlib_compile_flags' to the CC or CFLAGS env variable and reconfigure" 1>&2 + can_build_shared=no + fi +fi + +echo $ac_n "checking if $compiler static flag $link_static_flag works... $ac_c" 1>&6 +$rm conftest* +echo 'main(){return(0);}' > conftest.c +save_LDFLAGS="$LDFLAGS" +LDFLAGS="$LDFLAGS $link_static_flag" +echo "$progname:958: checking if $compiler static flag $link_static_flag works" >&5 +if { (eval echo $progname:959: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest; then + echo "$ac_t$link_static_flag" 1>&6 +else + echo "$ac_t"none 1>&6 + link_static_flag= +fi +LDFLAGS="$save_LDFLAGS" +$rm conftest* + +if test -z "$LN_S"; then + # Check to see if we can use ln -s, or we need hard links. + echo $ac_n "checking whether ln -s works... $ac_c" 1>&6 + $rm conftest.dat + if ln -s X conftest.dat 2>/dev/null; then + $rm conftest.dat + LN_S="ln -s" + else + LN_S=ln + fi + if test "$LN_S" = "ln -s"; then + echo "$ac_t"yes 1>&6 + else + echo "$ac_t"no 1>&6 + fi +fi + +# Make sure LD is an absolute path. +if test -z "$LD"; then + ac_prog=ld + if test "$with_gcc" = yes; then + # Check if gcc -print-prog-name=ld gives a path. + echo $ac_n "checking for ld used by GCC... $ac_c" 1>&6 + echo "$progname:991: checking for ld used by GCC" >&5 + ac_prog=`($CC -print-prog-name=ld) 2>&5` + case "$ac_prog" in + # Accept absolute paths. + [\\/]* | [A-Za-z]:[\\/]*) + re_direlt='/[^/][^/]*/\.\./' + # Canonicalize the path of ld + ac_prog=`echo $ac_prog| sed 's%\\\\%/%g'` + while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do + ac_prog=`echo $ac_prog| sed "s%$re_direlt%/%"` + done + test -z "$LD" && LD="$ac_prog" + ;; + "") + # If it fails, then pretend we are not using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac + elif test "$with_gnu_ld" = yes; then + echo $ac_n "checking for GNU ld... $ac_c" 1>&6 + echo "$progname:1015: checking for GNU ld" >&5 + else + echo $ac_n "checking for non-GNU ld""... $ac_c" 1>&6 + echo "$progname:1018: checking for non-GNU ld" >&5 + fi + + if test -z "$LD"; then + IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR}" + for ac_dir in $PATH; do + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + LD="$ac_dir/$ac_prog" + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some GNU ld's only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + if "$LD" -v 2>&1 < /dev/null | egrep '(GNU|with BFD)' > /dev/null; then + test "$with_gnu_ld" != no && break + else + test "$with_gnu_ld" != yes && break + fi + fi + done + IFS="$ac_save_ifs" + fi + + if test -n "$LD"; then + echo "$ac_t$LD" 1>&6 + else + echo "$ac_t"no 1>&6 + fi + + if test -z "$LD"; then + echo "$progname: error: no acceptable ld found in \$PATH" 1>&2 + exit 1 + fi +fi + +# Check to see if it really is or is not GNU ld. +echo $ac_n "checking if the linker ($LD) is GNU ld... $ac_c" 1>&6 +# I'd rather use --version here, but apparently some GNU ld's only accept -v. +if $LD -v 2>&1 &5; then + with_gnu_ld=yes +else + with_gnu_ld=no +fi +echo "$ac_t$with_gnu_ld" 1>&6 + +# See if the linker supports building shared libraries. +echo $ac_n "checking whether the linker ($LD) supports shared libraries... $ac_c" 1>&6 + +allow_undefined_flag= +no_undefined_flag= +need_lib_prefix=unknown +need_version=unknown +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +archive_cmds= +archive_expsym_cmds= +old_archive_from_new_cmds= +export_dynamic_flag_spec= +whole_archive_flag_spec= +thread_safe_flag_spec= +hardcode_libdir_flag_spec= +hardcode_libdir_separator= +hardcode_direct=no +hardcode_minus_L=no +hardcode_shlibpath_var=unsupported +runpath_var= +always_export_symbols=no +export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | sed '\''s/.* //'\'' | sort | uniq > $export_symbols' +# include_expsyms should be a list of space-separated symbols to be *always* +# included in the symbol list +include_expsyms= +# exclude_expsyms can be an egrep regular expression of symbols to exclude +# it will be wrapped by ` (' and `)$', so one must not match beginning or +# end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', +# as well as any symbol that contains `d'. +exclude_expsyms="_GLOBAL_OFFSET_TABLE_" +# Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out +# platforms (ab)use it in PIC code, but their linkers get confused if +# the symbol is explicitly referenced. Since portable code cannot +# rely on this symbol name, it's probably fine to never include it in +# preloaded symbol tables. + +case "$host_os" in +cygwin* | mingw*) + # FIXME: the MSVC++ port hasn't been tested in a loooong time + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + if test "$with_gcc" != yes; then + with_gnu_ld=no + fi + ;; + +esac + +ld_shlibs=yes +if test "$with_gnu_ld" = yes; then + # If archive_cmds runs LD, not CC, wlarc should be empty + wlarc='${wl}' + + # See if GNU ld supports shared libraries. + case "$host_os" in + aix3* | aix4*) + # On AIX, the GNU linker is very broken + ld_shlibs=no + cat <&2 + +*** Warning: the GNU linker, at least up to release 2.9.1, is reported +*** to be unable to reliably create shared libraries on AIX. +*** Therefore, libtool is disabling shared libraries support. If you +*** really care for shared libraries, you may want to modify your PATH +*** so that a non-GNU linker is found, and then restart. + +EOF + ;; + + amigaos*) + archive_cmds='$rm $objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $objdir/a2ixlibrary.data~$AR cru $lib $libobjs~$RANLIB $lib~(cd $objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + + # Samuel A. Falvo II reports + # that the semantics of dynamic libraries on AmigaOS, at least up + # to version 4, is to share data among multiple programs linked + # with the same dynamic library. Since this doesn't match the + # behavior of shared libraries on other platforms, we can use + # them. + ld_shlibs=no + ;; + + beos*) + if $LD --help 2>&1 | egrep ': supported targets:.* elf' > /dev/null; then + allow_undefined_flag=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + archive_cmds='$CC -nostart $libobjs $deplibs $linkopts ${wl}-soname $wl$soname -o $lib' + else + ld_shlibs=no + fi + ;; + + cygwin* | mingw*) + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + hardcode_libdir_flag_spec='-L$libdir' + allow_undefined_flag=unsupported + always_export_symbols=yes + + # Extract the symbol export list from an `--export-all' def file, + # then regenerate the def file from the symbol export list, so that + # the compiled dll only exports the symbol export list. + # Be careful not to strip the DATA tag left by newer dlltools. + export_symbols_cmds='test -f $objdir/$soname-ltdll.c || sed -e "/^# \/\* ltdll\.c starts here \*\//,/^# \/\* ltdll.c ends here \*\// { s/^# //; p; }" -e d < $0 > $objdir/$soname-ltdll.c~ + test -f $objdir/$soname-ltdll.$objext || (cd $objdir && $CC -c $soname-ltdll.c)~ + $DLLTOOL --export-all --exclude-symbols DllMain@12,_cygwin_dll_entry@12,_cygwin_noncygwin_dll_entry@12 --output-def $objdir/$soname-def $objdir/$soname-ltdll.$objext $libobjs $convenience~ + sed -e "1,/EXPORTS/d" -e "s/ @ [0-9]*//" -e "s/ *;.*$//" < $objdir/$soname-def > $export_symbols' + + # If DATA tags from a recent dlltool are present, honour them! + archive_expsym_cmds='echo EXPORTS > $objdir/$soname-def~ + _lt_hint=1; + cat $export_symbols | while read symbol; do + set dummy \$symbol; + case \$# in + 2) echo " \$2 @ \$_lt_hint ; " >> $objdir/$soname-def;; + *) echo " \$2 @ \$_lt_hint \$3 ; " >> $objdir/$soname-def;; + esac; + _lt_hint=`expr 1 + \$_lt_hint`; + done~ + test -f $objdir/$soname-ltdll.c || sed -e "/^# \/\* ltdll\.c starts here \*\//,/^# \/\* ltdll.c ends here \*\// { s/^# //; p; }" -e d < $0 > $objdir/$soname-ltdll.c~ + test -f $objdir/$soname-ltdll.$objext || (cd $objdir && $CC -c $soname-ltdll.c)~ + $CC -Wl,--base-file,$objdir/$soname-base -Wl,--dll -nostartfiles -Wl,-e,__cygwin_dll_entry@12 -o $lib $objdir/$soname-ltdll.$objext $libobjs $deplibs $linkopts~ + $DLLTOOL --as=$AS --dllname $soname --exclude-symbols DllMain@12,_cygwin_dll_entry@12,_cygwin_noncygwin_dll_entry@12 --def $objdir/$soname-def --base-file $objdir/$soname-base --output-exp $objdir/$soname-exp~ + $CC -Wl,--base-file,$objdir/$soname-base $objdir/$soname-exp -Wl,--dll -nostartfiles -Wl,-e,__cygwin_dll_entry@12 -o $lib $objdir/$soname-ltdll.$objext $libobjs $deplibs $linkopts~ + $DLLTOOL --as=$AS --dllname $soname --exclude-symbols DllMain@12,_cygwin_dll_entry@12,_cygwin_noncygwin_dll_entry@12 --def $objdir/$soname-def --base-file $objdir/$soname-base --output-exp $objdir/$soname-exp~ + $CC $objdir/$soname-exp -Wl,--dll -nostartfiles -Wl,-e,__cygwin_dll_entry@12 -o $lib $objdir/$soname-ltdll.$objext $libobjs $deplibs $linkopts' + + old_archive_from_new_cmds='$DLLTOOL --as=$AS --dllname $soname --def $objdir/$soname-def --output-lib $objdir/$libname.a' + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + archive_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + archive_cmds='$LD -Bshareable $libobjs $deplibs $linkopts -o $lib' + # can we support soname and/or expsyms with a.out? -oliva + fi + ;; + + solaris* | sysv5*) + if $LD -v 2>&1 | egrep 'BFD 2\.8' > /dev/null; then + ld_shlibs=no + cat <&2 + +*** Warning: The releases 2.8.* of the GNU linker cannot reliably +*** create shared libraries on Solaris systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.9.1 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +EOF + elif $LD --help 2>&1 | egrep ': supported targets:.* elf' > /dev/null; then + archive_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs=no + fi + ;; + + sunos4*) + archive_cmds='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linkopts' + wlarc= + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + *) + if $LD --help 2>&1 | egrep ': supported targets:.* elf' > /dev/null; then + archive_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs=no + fi + ;; + esac + + if test "$ld_shlibs" = yes; then + runpath_var=LD_RUN_PATH + hardcode_libdir_flag_spec='${wl}--rpath ${wl}$libdir' + export_dynamic_flag_spec='${wl}--export-dynamic' + case $host_os in + cygwin* | mingw*) + # dlltool doesn't understand --whole-archive et. al. + whole_archive_flag_spec= + ;; + *) + # ancient GNU ld didn't support --whole-archive et. al. + if $LD --help 2>&1 | egrep 'no-whole-archive' > /dev/null; then + whole_archive_flag_spec="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + whole_archive_flag_spec= + fi + ;; + esac + fi +else + # PORTME fill in a description of your system's linker (not GNU ld) + case "$host_os" in + aix3*) + allow_undefined_flag=unsupported + always_export_symbols=yes + archive_expsym_cmds='$LD -o $objdir/$soname $libobjs $deplibs $linkopts -bE:$export_symbols -T512 -H512 -bM:SRE~$AR cru $lib $objdir/$soname' + # Note: this linker hardcodes the directories in LIBPATH if there + # are no directories specified by -L. + hardcode_minus_L=yes + if test "$with_gcc" = yes && test -z "$link_static_flag"; then + # Neither direct hardcoding nor static linking is supported with a + # broken collect2. + hardcode_direct=unsupported + fi + ;; + + aix4*) + hardcode_libdir_flag_spec='${wl}-b ${wl}nolibpath ${wl}-b ${wl}libpath:$libdir:/usr/lib:/lib' + hardcode_libdir_separator=':' + if test "$with_gcc" = yes; then + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && \ + strings "$collect2name" | grep resolve_lib_name >/dev/null + then + # We have reworked collect2 + hardcode_direct=yes + else + # We have old collect2 + hardcode_direct=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + hardcode_minus_L=yes + hardcode_libdir_flag_spec='-L$libdir' + hardcode_libdir_separator= + fi + shared_flag='-shared' + else + shared_flag='${wl}-bM:SRE' + hardcode_direct=yes + fi + allow_undefined_flag=' ${wl}-berok' + archive_cmds="\$CC $shared_flag"' -o $objdir/$soname $libobjs $deplibs $linkopts ${wl}-bexpall ${wl}-bnoentry${allow_undefined_flag}' + archive_expsym_cmds="\$CC $shared_flag"' -o $objdir/$soname $libobjs $deplibs $linkopts ${wl}-bE:$export_symbols ${wl}-bnoentry${allow_undefined_flag}' + case "$host_os" in aix4.[01]|aix4.[01].*) + # According to Greg Wooledge, -bexpall is only supported from AIX 4.2 on + always_export_symbols=yes ;; + esac + ;; + + amigaos*) + archive_cmds='$rm $objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $objdir/a2ixlibrary.data~$AR cru $lib $libobjs~$RANLIB $lib~(cd $objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + # see comment about different semantics on the GNU ld section + ld_shlibs=no + ;; + + cygwin* | mingw*) + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + hardcode_libdir_flag_spec=' ' + allow_undefined_flag=unsupported + # Tell ltmain to make .lib files, not .a files. + libext=lib + # FIXME: Setting linknames here is a bad hack. + archive_cmds='$CC -o $lib $libobjs $linkopts `echo "$deplibs" | sed -e '\''s/ -lc$//'\''` -link -dll~linknames=' + # The linker will automatically build a .lib file if we build a DLL. + old_archive_from_new_cmds='true' + # FIXME: Should let the user specify the lib program. + old_archive_cmds='lib /OUT:$oldlib$oldobjs' + fix_srcfile_path='`cygpath -w $srcfile`' + ;; + + freebsd1*) + ld_shlibs=no + ;; + + # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor + # support. Future versions do this automatically, but an explicit c++rt0.o + # does not break anything, and helps significantly (at the cost of a little + # extra space). + freebsd2.2*) + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linkopts /usr/lib/c++rt0.o' + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + # Unfortunately, older versions of FreeBSD 2 do not have this feature. + freebsd2*) + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linkopts' + hardcode_direct=yes + hardcode_minus_L=yes + hardcode_shlibpath_var=no + ;; + + # FreeBSD 3 and greater uses gcc -shared to do shared libraries. + freebsd*) + archive_cmds='$CC -shared -o $lib $libobjs $deplibs $linkopts' + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + hpux9* | hpux10* | hpux11*) + case "$host_os" in + hpux9*) archive_cmds='$rm $objdir/$soname~$LD -b +b $install_libdir -o $objdir/$soname $libobjs $deplibs $linkopts~test $objdir/$soname = $lib || mv $objdir/$soname $lib' ;; + *) archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linkopts' ;; + esac + hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' + hardcode_libdir_separator=: + hardcode_direct=yes + hardcode_minus_L=yes # Not in the search PATH, but as the default + # location of the library. + export_dynamic_flag_spec='${wl}-E' + ;; + + irix5* | irix6*) + if test "$with_gcc" = yes; then + archive_cmds='$CC -shared $libobjs $deplibs $linkopts ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${objdir}/so_locations -o $lib' + else + archive_cmds='$LD -shared $libobjs $deplibs $linkopts -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${objdir}/so_locations -o $lib' + fi + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linkopts' # a.out + else + archive_cmds='$LD -shared -o $lib $libobjs $deplibs $linkopts' # ELF + fi + hardcode_libdir_flag_spec='${wl}-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + openbsd*) + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linkopts' + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + os2*) + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + allow_undefined_flag=unsupported + archive_cmds='$echo "LIBRARY $libname INITINSTANCE" > $objdir/$libname.def~$echo "DESCRIPTION \"$libname\"" >> $objdir/$libname.def~$echo DATA >> $objdir/$libname.def~$echo " SINGLE NONSHARED" >> $objdir/$libname.def~$echo EXPORTS >> $objdir/$libname.def~emxexp $libobjs >> $objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $linkopts $objdir/$libname.def' + old_archive_from_new_cmds='emximp -o $objdir/$libname.a $objdir/$libname.def' + ;; + + osf3*) + if test "$with_gcc" = yes; then + allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $linkopts ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${objdir}/so_locations -o $lib' + else + allow_undefined_flag=' -expect_unresolved \*' + archive_cmds='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linkopts -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${objdir}/so_locations -o $lib' + fi + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + ;; + + osf4* | osf5*) # As osf3* with the addition of the -msym flag + if test "$with_gcc" = yes; then + allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*' + archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $linkopts ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${objdir}/so_locations -o $lib' + else + allow_undefined_flag=' -expect_unresolved \*' + archive_cmds='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linkopts -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${objdir}/so_locations -o $lib' + fi + hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' + hardcode_libdir_separator=: + ;; + rhapsody*) + archive_cmds='$CC -bundle -undefined suppress -o $lib $libobjs $deplibs $linkopts' + hardcode_libdir_flags_spec='-L$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + sco3.2v5*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linkopts' + hardcode_shlibpath_var=no + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ;; + + solaris*) + no_undefined_flag=' -z text' + # $CC -shared without GNU ld will not create a library from C++ + # object files and a static libstdc++, better avoid it by now + archive_cmds='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linkopts' + archive_expsym_cmds='$echo "{ global:" > $lib.exp~cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linkopts~$rm $lib.exp' + hardcode_libdir_flag_spec='-R$libdir' + hardcode_shlibpath_var=no + case "$host_os" in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) # Supported since Solaris 2.6 (maybe 2.5.1?) + whole_archive_flag_spec='-z allextract$convenience -z defaultextract' ;; + esac + ;; + + sunos4*) + archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linkopts' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_direct=yes + hardcode_minus_L=yes + hardcode_shlibpath_var=no + ;; + + sysv4) + if test "x$host_vendor" = xsequent; then + # Use $CC to link under sequent, because it throws in some extra .o + # files that make .init and .fini sections work. + archive_cmds='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $linkopts' + else + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linkopts' + fi + runpath_var='LD_RUN_PATH' + hardcode_shlibpath_var=no + hardcode_direct=no #Motorola manual says yes, but my tests say they lie + ;; + + sysv4.3*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linkopts' + hardcode_shlibpath_var=no + export_dynamic_flag_spec='-Bexport' + ;; + + sysv5*) + no_undefined_flag=' -z text' + # $CC -shared without GNU ld will not create a library from C++ + # object files and a static libstdc++, better avoid it by now + archive_cmds='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linkopts' + archive_expsym_cmds='$echo "{ global:" > $lib.exp~cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linkopts~$rm $lib.exp' + hardcode_libdir_flag_spec= + hardcode_shlibpath_var=no + runpath_var='LD_RUN_PATH' + ;; + + uts4*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linkopts' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_shlibpath_var=no + ;; + + dgux*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linkopts' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_shlibpath_var=no + ;; + + sysv4*MP*) + if test -d /usr/nec; then + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linkopts' + hardcode_shlibpath_var=no + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ld_shlibs=yes + fi + ;; + + sysv4.2uw2*) + archive_cmds='$LD -G -o $lib $libobjs $deplibs $linkopts' + hardcode_direct=yes + hardcode_minus_L=no + hardcode_shlibpath_var=no + hardcode_runpath_var=yes + runpath_var=LD_RUN_PATH + ;; + + unixware7*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linkopts' + runpath_var='LD_RUN_PATH' + hardcode_shlibpath_var=no + ;; + + *) + ld_shlibs=no + ;; + esac +fi +echo "$ac_t$ld_shlibs" 1>&6 +test "$ld_shlibs" = no && can_build_shared=no + +if test -z "$NM"; then + echo $ac_n "checking for BSD-compatible nm... $ac_c" 1>&6 + case "$NM" in + [\\/]* | [A-Za-z]:[\\/]*) ;; # Let the user override the test with a path. + *) + IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}${PATH_SEPARATOR}" + for ac_dir in $PATH /usr/ucb /usr/ccs/bin /bin; do + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/nm || test -f $ac_dir/nm$ac_exeext; then + # Check to see if the nm accepts a BSD-compat flag. + # Adding the `sed 1q' prevents false positives on HP-UX, which says: + # nm: unknown option "B" ignored + if ($ac_dir/nm -B /dev/null 2>&1 | sed '1q'; exit 0) | egrep /dev/null >/dev/null; then + NM="$ac_dir/nm -B" + break + elif ($ac_dir/nm -p /dev/null 2>&1 | sed '1q'; exit 0) | egrep /dev/null >/dev/null; then + NM="$ac_dir/nm -p" + break + else + NM=${NM="$ac_dir/nm"} # keep the first match, but + continue # so that we can try to find one that supports BSD flags + fi + fi + done + IFS="$ac_save_ifs" + test -z "$NM" && NM=nm + ;; + esac + echo "$ac_t$NM" 1>&6 +fi + +# Check for command to grab the raw symbol name followed by C symbol from nm. +echo $ac_n "checking command to parse $NM output... $ac_c" 1>&6 + +# These are sane defaults that work on at least a few old systems. +# [They come from Ultrix. What could be older than Ultrix?!! ;)] + +# Character class describing NM global symbol codes. +symcode='[BCDEGRST]' + +# Regexp to match symbols that can be accessed directly from C. +sympat='\([_A-Za-z][_A-Za-z0-9]*\)' + +# Transform the above into a raw symbol and a C symbol. +symxfrm='\1 \2\3 \3' + +# Transform an extracted symbol line into a proper C declaration +global_symbol_to_cdecl="sed -n -e 's/^. .* \(.*\)$/extern char \1;/p'" + +# Define system-specific variables. +case "$host_os" in +aix*) + symcode='[BCDT]' + ;; +cygwin* | mingw*) + symcode='[ABCDGISTW]' + ;; +hpux*) # Its linker distinguishes data from code symbols + global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern char \1();/p' -e 's/^. .* \(.*\)$/extern char \1;/p'" + ;; +irix*) + symcode='[BCDEGRST]' + ;; +solaris*) + symcode='[BDT]' + ;; +sysv4) + symcode='[DFNSTU]' + ;; +esac + +# If we're using GNU nm, then use its standard symbol codes. +if $NM -V 2>&1 | egrep '(GNU|with BFD)' > /dev/null; then + symcode='[ABCDGISTW]' +fi + +# Try without a prefix undercore, then with it. +for ac_symprfx in "" "_"; do + + # Write the raw and C identifiers. + global_symbol_pipe="sed -n -e 's/^.*[ ]\($symcode\)[ ][ ]*\($ac_symprfx\)$sympat$/$symxfrm/p'" + + # Check to see that the pipe works correctly. + pipe_works=no + $rm conftest* + cat > conftest.c <&5 + if { (eval echo $progname:1654: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; } && test -s conftest.$objext; then + # Now try to grab the symbols. + nlist=conftest.nm + if { echo "$progname:1657: eval \"$NM conftest.$objext | $global_symbol_pipe > $nlist\"" >&5; eval "$NM conftest.$objext | $global_symbol_pipe > $nlist 2>&5"; } && test -s "$nlist"; then + + # Try sorting and uniquifying the output. + if sort "$nlist" | uniq > "$nlist"T; then + mv -f "$nlist"T "$nlist" + else + rm -f "$nlist"T + fi + + # Make sure that we snagged all the symbols we need. + if egrep ' nm_test_var$' "$nlist" >/dev/null; then + if egrep ' nm_test_func$' "$nlist" >/dev/null; then + cat < conftest.c +#ifdef __cplusplus +extern "C" { +#endif + +EOF + # Now generate the symbol file. + eval "$global_symbol_to_cdecl"' < "$nlist" >> conftest.c' + + cat <> conftest.c +#if defined (__STDC__) && __STDC__ +# define lt_ptr_t void * +#else +# define lt_ptr_t char * +# define const +#endif + +/* The mapping between symbol names and symbols. */ +const struct { + const char *name; + lt_ptr_t address; +} +lt_preloaded_symbols[] = +{ +EOF + sed 's/^. \(.*\) \(.*\)$/ {"\2", (lt_ptr_t) \&\2},/' < "$nlist" >> conftest.c + cat <<\EOF >> conftest.c + {0, (lt_ptr_t) 0} +}; + +#ifdef __cplusplus +} +#endif +EOF + # Now try linking the two files. + mv conftest.$objext conftstm.$objext + save_LIBS="$LIBS" + save_CFLAGS="$CFLAGS" + LIBS="conftstm.$objext" + CFLAGS="$CFLAGS$no_builtin_flag" + if { (eval echo $progname:1709: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest; then + pipe_works=yes + else + echo "$progname: failed program was:" >&5 + cat conftest.c >&5 + fi + LIBS="$save_LIBS" + else + echo "cannot find nm_test_func in $nlist" >&5 + fi + else + echo "cannot find nm_test_var in $nlist" >&5 + fi + else + echo "cannot run $global_symbol_pipe" >&5 + fi + else + echo "$progname: failed program was:" >&5 + cat conftest.c >&5 + fi + $rm conftest* conftst* + + # Do not use the global_symbol_pipe unless it works. + if test "$pipe_works" = yes; then + break + else + global_symbol_pipe= + fi +done +if test "$pipe_works" = yes; then + echo "${ac_t}ok" 1>&6 +else + echo "${ac_t}failed" 1>&6 +fi + +if test -z "$global_symbol_pipe"; then + global_symbol_to_cdecl= +fi + +# Check hardcoding attributes. +echo $ac_n "checking how to hardcode library paths into programs... $ac_c" 1>&6 +hardcode_action= +if test -n "$hardcode_libdir_flag_spec" || \ + test -n "$runpath_var"; then + + # We can hardcode non-existant directories. + if test "$hardcode_direct" != no && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test "$hardcode_shlibpath_var" != no && + test "$hardcode_minus_L" != no; then + # Linking always hardcodes the temporary library directory. + hardcode_action=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + hardcode_action=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + hardcode_action=unsupported +fi +echo "$ac_t$hardcode_action" 1>&6 + + +reload_flag= +reload_cmds='$LD$reload_flag -o $output$reload_objs' +echo $ac_n "checking for $LD option to reload object files... $ac_c" 1>&6 +# PORTME Some linkers may need a different reload flag. +reload_flag='-r' +echo "$ac_t$reload_flag" 1>&6 +test -n "$reload_flag" && reload_flag=" $reload_flag" + +# PORTME Fill in your ld.so characteristics +library_names_spec= +libname_spec='lib$name' +soname_spec= +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +file_magic_cmd= +file_magic_test_file= +deplibs_check_method='unknown' +# Need to set the preceding variable on all platforms that support +# interlibrary dependencies. +# 'none' -- dependencies not supported. +# `unknown' -- same as none, but documents that we really don't know. +# 'pass_all' -- all dependencies passed with no checks. +# 'test_compile' -- check by making test program. +# 'file_magic [regex]' -- check by looking for files in library path +# which responds to the $file_magic_cmd with a given egrep regex. +# If you have `file' or equivalent on your system and you're not sure +# whether `pass_all' will *always* work, you probably want this one. +echo $ac_n "checking dynamic linker characteristics... $ac_c" 1>&6 +case "$host_os" in +aix3*) + version_type=linux + library_names_spec='${libname}${release}.so$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX has no versioning support, so we append a major version to the name. + soname_spec='${libname}${release}.so$major' + ;; + +aix4*) + version_type=linux + # AIX has no versioning support, so currently we can not hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + # We preserve .a as extension for shared libraries though AIX4.2 + # and later linker supports .so + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so$major $libname.a' + shlibpath_var=LIBPATH + deplibs_check_method=pass_all + ;; + +amigaos*) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$echo "X$lib" | $Xsed -e '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $rm /sys/libs/${libname}_ixlibrary.a; $show "(cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a)"; (cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a) || exit 1; done' + ;; + +beos*) + library_names_spec='${libname}.so' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + deplibs_check_method=pass_all + lt_cv_dlopen="load_add_on" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ;; + +bsdi4*) + version_type=linux + need_version=no + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so$major $libname.so' + soname_spec='${libname}${release}.so$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib)' + file_magic_cmd=/usr/bin/file + file_magic_test_file=/shlib/libc.so + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + export_dynamic_flag_spec=-rdynamic + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw*) + version_type=windows + need_version=no + need_lib_prefix=no + if test "$with_gcc" = yes; then + library_names_spec='${libname}`echo ${release} | sed -e 's/[.]/-/g'`${versuffix}.dll $libname.a' + else + library_names_spec='${libname}`echo ${release} | sed -e 's/[.]/-/g'`${versuffix}.dll $libname.lib' + fi + dynamic_linker='Win32 ld.exe' + deplibs_check_method='file_magic file format pei*-i386(.*architecture: i386)?' + file_magic_cmd='${OBJDUMP} -f' + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + lt_cv_dlopen="LoadLibrary" + lt_cv_dlopen_libs= + ;; + +freebsd1*) + dynamic_linker=no + ;; + +freebsd*) + objformat=`test -x /usr/bin/objformat && /usr/bin/objformat || echo aout` + version_type=freebsd-$objformat + case "$version_type" in + freebsd-elf*) + deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [LM]SB shared object' + file_magic_cmd=/usr/bin/file + file_magic_test_file=`echo /usr/lib/libc.so*` + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so $libname.so' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + deplibs_check_method=unknown + library_names_spec='${libname}${release}.so$versuffix $libname.so$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case "$host_os" in + freebsd2* | freebsd3.[01]* | freebsdelf3.[01]*) + shlibpath_overrides_runpath=yes + ;; + *) # from 3.2 on + shlibpath_overrides_runpath=no + ;; + esac + ;; + +gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so${major} ${libname}.so' + soname_spec='${libname}${release}.so$major' + shlibpath_var=LD_LIBRARY_PATH + deplibs_check_method=pass_all + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + dynamic_linker="$host_os dld.sl" + version_type=sunos + need_lib_prefix=no + need_version=no + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='${libname}${release}.sl$versuffix ${libname}${release}.sl$major $libname.sl' + soname_spec='${libname}${release}.sl$major' + # HP-UX runs *really* slowly unless shared libraries are mode 555. + postinstall_cmds='chmod 555 $lib' + case "$host_os" in + hpux10.20*) + # TODO: Does this work for hpux-11 too? + deplibs_check_method='file_magic (s[0-9][0-9][0-9]|PA-RISC[0-9].[0-9]) shared library' + file_magic_cmd=/usr/bin/file + file_magic_test_file=/usr/lib/libc.sl + ;; + esac + ;; + +irix5* | irix6*) + version_type=irix + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}.so.$major' + library_names_spec='${libname}${release}.so.$versuffix ${libname}${release}.so.$major ${libname}${release}.so $libname.so' + case "$host_os" in + irix5*) + libsuff= shlibsuff= + # this will be overridden with pass_all, but let us keep it just in case + deplibs_check_method="file_magic ELF 32-bit MSB dynamic lib MIPS - version 1" + ;; + *) + case "$LD" in # libtool.m4 will add one of these switches to LD + *-32|*"-32 ") libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 ") libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" + sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" + file_magic_cmd=/usr/bin/file + file_magic_test_file=`echo /lib${libsuff}/libc.so*` + deplibs_check_method='pass_all' + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux-gnuoldld* | linux-gnuaout* | linux-gnucoff*) + dynamic_linker=no + ;; + +# This must be Linux ELF. +linux-gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so$major $libname.so' + soname_spec='${libname}${release}.so$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + deplibs_check_method=pass_all + + if test -f /lib/ld.so.1; then + dynamic_linker='GNU ld.so' + else + # Only the GNU ld.so supports shared libraries on MkLinux. + case "$host_cpu" in + powerpc*) dynamic_linker=no ;; + *) dynamic_linker='Linux ld.so' ;; + esac + fi + ;; + +netbsd*) + version_type=sunos + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + library_names_spec='${libname}${release}.so$versuffix ${libname}.so$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so$major ${libname}${release}.so ${libname}.so' + soname_spec='${libname}${release}.so$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + ;; + +openbsd*) + version_type=sunos + if test "$with_gnu_ld" = yes; then + need_lib_prefix=no + need_version=no + fi + library_names_spec='${libname}${release}.so$versuffix ${libname}.so$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + ;; + +os2*) + libname_spec='$name' + need_lib_prefix=no + library_names_spec='$libname.dll $libname.a' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=LIBPATH + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_version=no + soname_spec='${libname}${release}.so' + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so $libname.so' + shlibpath_var=LD_LIBRARY_PATH + # this will be overridden with pass_all, but let us keep it just in case + deplibs_check_method='file_magic COFF format alpha shared library' + file_magic_cmd=/usr/bin/file + file_magic_test_file=/shlib/libc.so + deplibs_check_method='pass_all' + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" + ;; + +rhapsody*) + version_type=sunos + library_names_spec='${libname}.so' + soname_spec='${libname}.so' + shlibpath_var=DYLD_LIBRARY_PATH + deplibs_check_method=pass_all + ;; + +sco3.2v5*) + version_type=osf + soname_spec='${libname}${release}.so$major' + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so$major $libname.so' + shlibpath_var=LD_LIBRARY_PATH + ;; + +solaris*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so$major $libname.so' + soname_spec='${libname}${release}.so$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + deplibs_check_method="file_magic ELF [0-9][0-9]-bit [LM]SB dynamic lib" + file_magic_cmd=/usr/bin/file + file_magic_test_file=/lib/libc.so + ;; + +sunos4*) + version_type=sunos + library_names_spec='${libname}${release}.so$versuffix ${libname}.so$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test "$with_gnu_ld" = yes; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + version_type=linux + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so$major $libname.so' + soname_spec='${libname}${release}.so$major' + shlibpath_var=LD_LIBRARY_PATH + case "$host_vendor" in + sequent) + file_magic_cmd='/bin/file' + deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [LM]SB (shared object|dynamic lib )' + ;; + ncr) + deplibs_check_method='pass_all' + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib) M[0-9][0-9]* Version [0-9]' + file_magic_cmd=/usr/bin/file + file_magic_test_file=`echo /usr/lib/libc.so*` + ;; + esac + ;; + +uts4*) + version_type=linux + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so$major $libname.so' + soname_spec='${libname}${release}.so$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +dgux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}.so$versuffix ${libname}${release}.so$major $libname.so' + soname_spec='${libname}${release}.so$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +sysv4*MP*) + if test -d /usr/nec ;then + version_type=linux + library_names_spec='$libname.so.$versuffix $libname.so.$major $libname.so' + soname_spec='$libname.so.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +*) + dynamic_linker=no + ;; +esac +echo "$ac_t$dynamic_linker" 1>&6 +test "$dynamic_linker" = no && can_build_shared=no + +# Report the final consequences. +echo "checking if libtool supports shared libraries... $can_build_shared" 1>&6 + +# Only try to build win32 dlls if AC_LIBTOOL_WIN32_DLL was used in +# configure.in, otherwise build static only libraries. +case "$host_os" in +cygwin* | mingw* | os2*) + if test x$can_build_shared = xyes; then + test x$enable_win32_dll = xno && can_build_shared=no + echo "checking if package supports dlls... $can_build_shared" 1>&6 + fi +;; +esac + +if test -n "$file_magic_test_file" && test -n "$file_magic_cmd"; then + case "$deplibs_check_method" in + "file_magic "*) + file_magic_regex="`expr \"$deplibs_check_method\" : \"file_magic \(.*\)\"`" + if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | + egrep "$file_magic_regex" > /dev/null; then + : + else + cat <&2 + +*** Warning: the command libtool uses to detect shared libraries, +*** $file_magic_cmd, produces output that libtool cannot recognize. +*** The result is that libtool may fail to recognize shared libraries +*** as such. This will affect the creation of libtool libraries that +*** depend on shared libraries, but programs linked with such libtool +*** libraries will work regardless of this problem. Nevertheless, you +*** may want to report the problem to your system manager and/or to +*** bug-libtool@gnu.org + +EOF + fi ;; + esac +fi + +echo $ac_n "checking whether to build shared libraries... $ac_c" 1>&6 +test "$can_build_shared" = "no" && enable_shared=no + +# On AIX, shared libraries and static libraries use the same namespace, and +# are all built from PIC. +case "$host_os" in +aix3*) + test "$enable_shared" = yes && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + +aix4*) + test "$enable_shared" = yes && enable_static=no + ;; +esac + +echo "$ac_t$enable_shared" 1>&6 + +# Make sure either enable_shared or enable_static is yes. +test "$enable_shared" = yes || enable_static=yes + +echo "checking whether to build static libraries... $enable_static" 1>&6 + +if test "$hardcode_action" = relink; then + # Fast installation is not supported + enable_fast_install=no +elif test "$shlibpath_overrides_runpath" = yes || + test "$enable_shared" = no; then + # Fast installation is not necessary + enable_fast_install=needless +fi + +echo $ac_n "checking for objdir... $ac_c" 1>&6 +rm -f .libs 2>/dev/null +mkdir .libs 2>/dev/null +if test -d .libs; then + objdir=.libs +else + # MS-DOS does not allow filenames that begin with a dot. + objdir=_libs +fi +rmdir .libs 2>/dev/null +echo "$ac_t$objdir" 1>&6 + +if test "x$enable_dlopen" != xyes; then + enable_dlopen=unknown + enable_dlopen_self=unknown + enable_dlopen_self_static=unknown +else +if eval "test \"`echo '$''{'lt_cv_dlopen'+set}'`\" != set"; then + lt_cv_dlopen=no lt_cv_dlopen_libs= +echo $ac_n "checking for dlopen in -ldl""... $ac_c" 1>&6 +echo "$progname:2248: checking for dlopen in -ldl" >&5 +ac_lib_var=`echo dl'_'dlopen | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-ldl $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "$progname: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl" +else + echo "$ac_t""no" 1>&6 +echo $ac_n "checking for dlopen""... $ac_c" 1>&6 +echo "$progname:2288: checking for dlopen" >&5 +if eval "test \"`echo '$''{'ac_cv_func_dlopen'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + cat > conftest.$ac_ext < +/* Override any gcc2 internal prototype to avoid an error. */ +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char dlopen(); + +int main() { + +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_dlopen) || defined (__stub___dlopen) +choke me +#else +dlopen(); +#endif + +; return 0; } +EOF +if { (eval echo $progname:2318: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_func_dlopen=yes" +else + echo "$progname: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_func_dlopen=no" +fi +rm -f conftest* +fi +if eval "test \"`echo '$ac_cv_func_'dlopen`\" = yes"; then + echo "$ac_t""yes" 1>&6 + lt_cv_dlopen="dlopen" +else + echo "$ac_t""no" 1>&6 +echo $ac_n "checking for dld_link in -ldld""... $ac_c" 1>&6 +echo "$progname:2335: checking for dld_link in -ldld" >&5 +ac_lib_var=`echo dld'_'dld_link | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-ldld $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "$progname: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld" +else + echo "$ac_t""no" 1>&6 +echo $ac_n "checking for shl_load""... $ac_c" 1>&6 +echo "$progname:2375: checking for shl_load" >&5 +if eval "test \"`echo '$''{'ac_cv_func_shl_load'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + cat > conftest.$ac_ext < +/* Override any gcc2 internal prototype to avoid an error. */ +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char shl_load(); + +int main() { + +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_shl_load) || defined (__stub___shl_load) +choke me +#else +shl_load(); +#endif + +; return 0; } +EOF +if { (eval echo $progname:2405: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_func_shl_load=yes" +else + echo "$progname: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_func_shl_load=no" +fi +rm -f conftest* +fi + +if eval "test \"`echo '$ac_cv_func_'shl_load`\" = yes"; then + echo "$ac_t""yes" 1>&6 + lt_cv_dlopen="shl_load" +else + echo "$ac_t""no" 1>&6 +echo $ac_n "checking for shl_load in -ldld""... $ac_c" 1>&6 +echo "$progname:2423: checking for shl_load in -ldld" >&5 +ac_lib_var=`echo dld'_'shl_load | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-ldld $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "$progname: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld" +else + echo "$ac_t""no" 1>&6 +fi + + +fi + + +fi + + +fi + + +fi + +fi + + if test "x$lt_cv_dlopen" != xno; then + enable_dlopen=yes + fi + + case "$lt_cv_dlopen" in + dlopen) +for ac_hdr in dlfcn.h; do +ac_safe=`echo "$ac_hdr" | sed 'y%./+-%__p_%'` +echo $ac_n "checking for $ac_hdr""... $ac_c" 1>&6 +echo "$progname:2488: checking for $ac_hdr" >&5 +if eval "test \"`echo '$''{'ac_cv_header_$ac_safe'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + cat > conftest.$ac_ext < +int fnord = 0; +EOF +ac_try="$ac_compile >/dev/null 2>conftest.out" +{ (eval echo $progname:2498: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } +ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` +if test -z "$ac_err"; then + rm -rf conftest* + eval "ac_cv_header_$ac_safe=yes" +else + echo "$ac_err" >&5 + echo "$progname: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_header_$ac_safe=no" +fi +rm -f conftest* +fi +if eval "test \"`echo '$ac_cv_header_'$ac_safe`\" = yes"; then + echo "$ac_t""yes" 1>&6 +else + echo "$ac_t""no" 1>&6 +fi +done + + if test "x$ac_cv_header_dlfcn_h" = xyes; then + CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" + fi + eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" + LIBS="$lt_cv_dlopen_libs $LIBS" + + echo $ac_n "checking whether a program can dlopen itself""... $ac_c" 1>&6 +echo "$progname:2526: checking whether a program can dlopen itself" >&5 +if test "${lt_cv_dlopen_self+set}" = set; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + if test "$cross_compiling" = yes; then + lt_cv_dlopen_self=cross + else + cat > conftest.c < +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LTDL_GLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LTDL_GLOBAL DL_GLOBAL +# else +# define LTDL_GLOBAL 0 +# endif +#endif + +/* We may have to define LTDL_LAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LTDL_LAZY_OR_NOW +# ifdef RTLD_LAZY +# define LTDL_LAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LTDL_LAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LTDL_LAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LTDL_LAZY_OR_NOW DL_NOW +# else +# define LTDL_LAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +fnord() { int i=42;} +main() { void *self, *ptr1, *ptr2; self=dlopen(0,LTDL_GLOBAL|LTDL_LAZY_OR_NOW); + if(self) { ptr1=dlsym(self,"fnord"); ptr2=dlsym(self,"_fnord"); + if(ptr1 || ptr2) { dlclose(self); exit(0); } } exit(1); } + +EOF +if { (eval echo $progname:2580: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest && (./conftest; exit) 2>/dev/null +then + lt_cv_dlopen_self=yes +else + echo "$progname: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -fr conftest* + lt_cv_dlopen_self=no +fi +rm -fr conftest* +fi + +fi + +echo "$ac_t""$lt_cv_dlopen_self" 1>&6 + + if test "$lt_cv_dlopen_self" = yes; then + LDFLAGS="$LDFLAGS $link_static_flag" + echo $ac_n "checking whether a statically linked program can dlopen itself""... $ac_c" 1>&6 +echo "$progname:2599: checking whether a statically linked program can dlopen itself" >&5 +if test "${lt_cv_dlopen_self_static+set}" = set; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + if test "$cross_compiling" = yes; then + lt_cv_dlopen_self_static=cross + else + cat > conftest.c < +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LTDL_GLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LTDL_GLOBAL DL_GLOBAL +# else +# define LTDL_GLOBAL 0 +# endif +#endif + +/* We may have to define LTDL_LAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LTDL_LAZY_OR_NOW +# ifdef RTLD_LAZY +# define LTDL_LAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LTDL_LAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LTDL_LAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LTDL_LAZY_OR_NOW DL_NOW +# else +# define LTDL_LAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +fnord() { int i=42;} +main() { void *self, *ptr1, *ptr2; self=dlopen(0,LTDL_GLOBAL|LTDL_LAZY_OR_NOW); + if(self) { ptr1=dlsym(self,"fnord"); ptr2=dlsym(self,"_fnord"); + if(ptr1 || ptr2) { dlclose(self); exit(0); } } exit(1); } + +EOF +if { (eval echo $progname:2653: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest && (./conftest; exit) 2>/dev/null +then + lt_cv_dlopen_self_static=yes +else + echo "$progname: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -fr conftest* + lt_cv_dlopen_self_static=no +fi +rm -fr conftest* +fi + +fi + +echo "$ac_t""$lt_cv_dlopen_self_static" 1>&6 +fi + ;; + esac + + case "$lt_cv_dlopen_self" in + yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; + *) enable_dlopen_self=unknown ;; + esac + + case "$lt_cv_dlopen_self_static" in + yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; + *) enable_dlopen_self_static=unknown ;; + esac +fi + +# Copy echo and quote the copy, instead of the original, because it is +# used later. +ltecho="$echo" +if test "X$ltecho" = "X$CONFIG_SHELL $0 --fallback-echo"; then + ltecho="$CONFIG_SHELL \$0 --fallback-echo" +fi +LTSHELL="$SHELL" + +LTCONFIG_VERSION="$VERSION" + +# Only quote variables if we're using ltmain.sh. +case "$ltmain" in +*.sh) + # Now quote all the things that may contain metacharacters. + for var in ltecho old_CC old_CFLAGS old_CPPFLAGS \ + old_LD old_LDFLAGS old_LIBS \ + old_NM old_RANLIB old_LN_S old_DLLTOOL old_OBJDUMP old_AS \ + AR CC LD LN_S NM LTSHELL LTCONFIG_VERSION \ + reload_flag reload_cmds wl \ + pic_flag link_static_flag no_builtin_flag export_dynamic_flag_spec \ + thread_safe_flag_spec whole_archive_flag_spec libname_spec \ + library_names_spec soname_spec \ + RANLIB old_archive_cmds old_archive_from_new_cmds old_postinstall_cmds \ + old_postuninstall_cmds archive_cmds archive_expsym_cmds postinstall_cmds postuninstall_cmds \ + file_magic_cmd export_symbols_cmds deplibs_check_method allow_undefined_flag no_undefined_flag \ + finish_cmds finish_eval global_symbol_pipe global_symbol_to_cdecl \ + hardcode_libdir_flag_spec hardcode_libdir_separator \ + sys_lib_search_path_spec sys_lib_dlsearch_path_spec \ + compiler_c_o compiler_o_lo need_locks exclude_expsyms include_expsyms; do + + case "$var" in + reload_cmds | old_archive_cmds | old_archive_from_new_cmds | \ + old_postinstall_cmds | old_postuninstall_cmds | \ + export_symbols_cmds | archive_cmds | archive_expsym_cmds | \ + postinstall_cmds | postuninstall_cmds | \ + finish_cmds | sys_lib_search_path_spec | sys_lib_dlsearch_path_spec) + # Double-quote double-evaled strings. + eval "$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\"" + ;; + *) + eval "$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\"" + ;; + esac + done + + case "$ltecho" in + *'\$0 --fallback-echo"') + ltecho=`$echo "X$ltecho" | $Xsed -e 's/\\\\\\\$0 --fallback-echo"$/$0 --fallback-echo"/'` + ;; + esac + + trap "$rm \"$ofile\"; exit 1" 1 2 15 + echo "creating $ofile" + $rm "$ofile" + cat < "$ofile" +#! $SHELL + +# `$echo "$ofile" | sed 's%^.*/%%'` - Provide generalized library-building support services. +# Generated automatically by $PROGRAM (GNU $PACKAGE $VERSION$TIMESTAMP) +# NOTE: Changes made to this file will be lost: look at ltconfig or ltmain.sh. +# +# Copyright (C) 1996-1999 Free Software Foundation, Inc. +# Originally by Gordon Matzigkeit , 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 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, 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. + +# Sed that helps us avoid accidentally triggering echo(1) options like -n. +Xsed="sed -e s/^X//" + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +if test "X\${CDPATH+set}" = Xset; then CDPATH=:; export CDPATH; fi + +### BEGIN LIBTOOL CONFIG +EOF + cfgfile="$ofile" + ;; + +*) + # Double-quote the variables that need it (for aesthetics). + for var in old_CC old_CFLAGS old_CPPFLAGS \ + old_LD old_LDFLAGS old_LIBS \ + old_NM old_RANLIB old_LN_S old_DLLTOOL old_OBJDUMP old_AS; do + eval "$var=\\\"\$var\\\"" + done + + # Just create a config file. + cfgfile="$ofile.cfg" + trap "$rm \"$cfgfile\"; exit 1" 1 2 15 + echo "creating $cfgfile" + $rm "$cfgfile" + cat < "$cfgfile" +# `$echo "$cfgfile" | sed 's%^.*/%%'` - Libtool configuration file. +# Generated automatically by $PROGRAM (GNU $PACKAGE $VERSION$TIMESTAMP) +EOF + ;; +esac + +cat <> "$cfgfile" +# Libtool was configured as follows, on host `(hostname || uname -n) 2>/dev/null | sed 1q`: +# +# CC=$old_CC CFLAGS=$old_CFLAGS CPPFLAGS=$old_CPPFLAGS \\ +# LD=$old_LD LDFLAGS=$old_LDFLAGS LIBS=$old_LIBS \\ +# NM=$old_NM RANLIB=$old_RANLIB LN_S=$old_LN_S \\ +# DLLTOOL=$old_DLLTOOL OBJDUMP=$old_OBJDUMP AS=$old_AS \\ +# $0$ltconfig_args +# +# Compiler and other test output produced by $progname, useful for +# debugging $progname, is in ./config.log if it exists. + +# The version of $progname that generated this script. +LTCONFIG_VERSION=$LTCONFIG_VERSION + +# Shell to use when invoking shell scripts. +SHELL=$LTSHELL + +# Whether or not to build shared libraries. +build_libtool_libs=$enable_shared + +# Whether or not to build static libraries. +build_old_libs=$enable_static + +# Whether or not to optimize for fast installation. +fast_install=$enable_fast_install + +# The host system. +host_alias=$host_alias +host=$host + +# An echo program that does not interpret backslashes. +echo=$ltecho + +# The archiver. +AR=$AR + +# The default C compiler. +CC=$CC + +# The linker used to build libraries. +LD=$LD + +# Whether we need hard or soft links. +LN_S=$LN_S + +# A BSD-compatible nm program. +NM=$NM + +# Used on cygwin: DLL creation program. +DLLTOOL="$DLLTOOL" + +# Used on cygwin: object dumper. +OBJDUMP="$OBJDUMP" + +# Used on cygwin: assembler. +AS="$AS" + +# The name of the directory that contains temporary libtool files. +objdir=$objdir + +# How to create reloadable object files. +reload_flag=$reload_flag +reload_cmds=$reload_cmds + +# How to pass a linker flag through the compiler. +wl=$wl + +# Object file suffix (normally "o"). +objext="$objext" + +# Old archive suffix (normally "a"). +libext="$libext" + +# Executable file suffix (normally ""). +exeext="$exeext" + +# Additional compiler flags for building library objects. +pic_flag=$pic_flag + +# Does compiler simultaneously support -c and -o options? +compiler_c_o=$compiler_c_o + +# Can we write directly to a .lo ? +compiler_o_lo=$compiler_o_lo + +# Must we lock files when doing compilation ? +need_locks=$need_locks + +# Do we need the lib prefix for modules? +need_lib_prefix=$need_lib_prefix + +# Do we need a version for libraries? +need_version=$need_version + +# Whether dlopen is supported. +dlopen=$enable_dlopen + +# Whether dlopen of programs is supported. +dlopen_self=$enable_dlopen_self + +# Whether dlopen of statically linked programs is supported. +dlopen_self_static=$enable_dlopen_self_static + +# Compiler flag to prevent dynamic linking. +link_static_flag=$link_static_flag + +# Compiler flag to turn off builtin functions. +no_builtin_flag=$no_builtin_flag + +# Compiler flag to allow reflexive dlopens. +export_dynamic_flag_spec=$export_dynamic_flag_spec + +# Compiler flag to generate shared objects directly from archives. +whole_archive_flag_spec=$whole_archive_flag_spec + +# Compiler flag to generate thread-safe objects. +thread_safe_flag_spec=$thread_safe_flag_spec + +# Library versioning type. +version_type=$version_type + +# Format of library name prefix. +libname_spec=$libname_spec + +# List of archive names. First name is the real one, the rest are links. +# The last name is the one that the linker finds with -lNAME. +library_names_spec=$library_names_spec + +# The coded name of the library, if different from the real name. +soname_spec=$soname_spec + +# Commands used to build and install an old-style archive. +RANLIB=$RANLIB +old_archive_cmds=$old_archive_cmds +old_postinstall_cmds=$old_postinstall_cmds +old_postuninstall_cmds=$old_postuninstall_cmds + +# Create an old-style archive from a shared archive. +old_archive_from_new_cmds=$old_archive_from_new_cmds + +# Commands used to build and install a shared archive. +archive_cmds=$archive_cmds +archive_expsym_cmds=$archive_expsym_cmds +postinstall_cmds=$postinstall_cmds +postuninstall_cmds=$postuninstall_cmds + +# Method to check whether dependent libraries are shared objects. +deplibs_check_method=$deplibs_check_method + +# Command to use when deplibs_check_method == file_magic. +file_magic_cmd=$file_magic_cmd + +# Flag that allows shared libraries with undefined symbols to be built. +allow_undefined_flag=$allow_undefined_flag + +# Flag that forces no undefined symbols. +no_undefined_flag=$no_undefined_flag + +# Commands used to finish a libtool library installation in a directory. +finish_cmds=$finish_cmds + +# Same as above, but a single script fragment to be evaled but not shown. +finish_eval=$finish_eval + +# Take the output of nm and produce a listing of raw symbols and C names. +global_symbol_pipe=$global_symbol_pipe + +# Transform the output of nm in a proper C declaration +global_symbol_to_cdecl=$global_symbol_to_cdecl + +# This is the shared library runtime path variable. +runpath_var=$runpath_var + +# This is the shared library path variable. +shlibpath_var=$shlibpath_var + +# Is shlibpath searched before the hard-coded library search path? +shlibpath_overrides_runpath=$shlibpath_overrides_runpath + +# How to hardcode a shared library path into an executable. +hardcode_action=$hardcode_action + +# Flag to hardcode \$libdir into a binary during linking. +# This must work even if \$libdir does not exist. +hardcode_libdir_flag_spec=$hardcode_libdir_flag_spec + +# Whether we need a single -rpath flag with a separated argument. +hardcode_libdir_separator=$hardcode_libdir_separator + +# Set to yes if using DIR/libNAME.so during linking hardcodes DIR into the +# resulting binary. +hardcode_direct=$hardcode_direct + +# Set to yes if using the -LDIR flag during linking hardcodes DIR into the +# resulting binary. +hardcode_minus_L=$hardcode_minus_L + +# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into +# the resulting binary. +hardcode_shlibpath_var=$hardcode_shlibpath_var + +# Compile-time system search path for libraries +sys_lib_search_path_spec=$sys_lib_search_path_spec + +# Run-time system search path for libraries +sys_lib_dlsearch_path_spec=$sys_lib_dlsearch_path_spec + +# Fix the shell variable \$srcfile for the compiler. +fix_srcfile_path="$fix_srcfile_path" + +# Set to yes if exported symbols are required. +always_export_symbols=$always_export_symbols + +# The commands to list exported symbols. +export_symbols_cmds=$export_symbols_cmds + +# Symbols that should not be listed in the preloaded symbols. +exclude_expsyms=$exclude_expsyms + +# Symbols that must always be exported. +include_expsyms=$include_expsyms + +EOF + +case "$ltmain" in +*.sh) + echo '### END LIBTOOL CONFIG' >> "$ofile" + echo >> "$ofile" + case "$host_os" in + aix3*) + cat <<\EOF >> "$ofile" + +# AIX sometimes has problems with the GCC collect2 program. For some +# reason, if we set the COLLECT_NAMES environment variable, the problems +# vanish in a puff of smoke. +if test "X${COLLECT_NAMES+set}" != Xset; then + COLLECT_NAMES= + export COLLECT_NAMES +fi +EOF + ;; + esac + + # Append the ltmain.sh script. + sed '$q' "$ltmain" >> "$ofile" || (rm -f "$ofile"; exit 1) + # We use sed instead of cat because bash on DJGPP gets confused if + # if finds mixed CR/LF and LF-only lines. Since sed operates in + # text mode, it properly converts lines to CR/LF. This bash problem + # is reportedly fixed, but why not run on old versions too? + + chmod +x "$ofile" + ;; + +*) + # Compile the libtool program. + echo "FIXME: would compile $ltmain" + ;; +esac + +test -n "$cache_file" || exit 0 + +# AC_CACHE_SAVE +trap '' 1 2 15 +cat > confcache <<\EOF +# This file is a shell script that caches the results of configure +# tests run on this system so they can be shared between configure +# scripts and configure runs. It is not useful on other systems. +# If it contains results you don't want to keep, you may remove or edit it. +# +# By default, configure uses ./config.cache as the cache file, +# creating it if it does not exist already. You can give configure +# the --cache-file=FILE option to use a different cache file; that is +# what configure does when it calls configure scripts in +# subdirectories, so they share the cache. +# Giving --cache-file=/dev/null disables caching, for debugging configure. +# config.status only pays attention to the cache file if you give it the +# --recheck option to rerun configure. +# +EOF +# The following way of writing the cache mishandles newlines in values, +# but we know of no workaround that is simple, portable, and efficient. +# So, don't put newlines in cache variables' values. +# Ultrix sh set writes to stderr and can't be redirected directly, +# and sets the high bit in the cache file unless we assign to the vars. +(set) 2>&1 | + case `(ac_space=' '; set | grep ac_space) 2>&1` in + *ac_space=\ *) + # `set' does not quote correctly, so add quotes (double-quote substitution + # turns \\\\ into \\, and sed turns \\ into \). + sed -n \ + -e "s/'/'\\\\''/g" \ + -e "s/^\\([a-zA-Z0-9_]*_cv_[a-zA-Z0-9_]*\\)=\\(.*\\)/\\1=\${\\1='\\2'}/p" + ;; + *) + # `set' quotes correctly as required by POSIX, so do not add quotes. + sed -n -e 's/^\([a-zA-Z0-9_]*_cv_[a-zA-Z0-9_]*\)=\(.*\)/\1=${\1=\2}/p' + ;; + esac >> confcache +if cmp -s $cache_file confcache; then + : +else + if test -w $cache_file; then + echo "updating cache $cache_file" + cat confcache > $cache_file + else + echo "not updating unwritable cache $cache_file" + fi +fi +rm -f confcache + +exit 0 + +# Local Variables: +# mode:shell-script +# sh-indentation:2 +# End: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/ltmain.sh b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/ltmain.sh new file mode 100644 index 0000000000..db4982d8a9 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/ltmain.sh @@ -0,0 +1,6538 @@ +# ltmain.sh - Provide generalized library-building support services. +# NOTE: Changing this file will not affect anything until you rerun configure. +# +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005 +# Free Software Foundation, Inc. +# Originally by Gordon Matzigkeit , 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 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, 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. + +basename="s,^.*/,,g" + +# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh +# is ksh but when the shell is invoked as "sh" and the current value of +# the _XPG environment variable is not equal to 1 (one), the special +# positional parameter $0, within a function call, is the name of the +# function. +progpath="$0" + +# The name of this program: +progname=`echo "$progpath" | $SED $basename` +modename="$progname" + +# Global variables: +EXIT_SUCCESS=0 +EXIT_FAILURE=1 + +PROGRAM=ltmain.sh +PACKAGE=libtool +VERSION="1.5.20 Debian 1.5.20-2" +TIMESTAMP=" (1.1220.2.287 2005/08/31 18:54:15)" + +# See if we are running on zsh, and set the options which allow our +# commands through without removal of \ escapes. +if test -n "${ZSH_VERSION+set}" ; then + setopt NO_GLOB_SUBST +fi + +# Check that we have a working $echo. +if test "X$1" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift +elif test "X$1" = X--fallback-echo; then + # Avoid inline document here, it may be left over + : +elif test "X`($echo '\t') 2>/dev/null`" = 'X\t'; then + # Yippee, $echo works! + : +else + # Restart under the correct shell, and then maybe $echo will work. + exec $SHELL "$progpath" --no-reexec ${1+"$@"} +fi + +if test "X$1" = X--fallback-echo; then + # used as fallback echo + shift + cat <&2 + $echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2 + exit $EXIT_FAILURE +fi + +# Global variables. +mode=$default_mode +nonopt= +prev= +prevopt= +run= +show="$echo" +show_help= +execute_dlfiles= +lo2o="s/\\.lo\$/.${objext}/" +o2lo="s/\\.${objext}\$/.lo/" + +##################################### +# Shell function definitions: +# This seems to be the best place for them + +# func_win32_libid arg +# return the library type of file 'arg' +# +# Need a lot of goo to handle *both* DLLs and import libs +# Has to be a shell function in order to 'eat' the argument +# that is supplied when $file_magic_command is called. +func_win32_libid () +{ + win32_libid_type="unknown" + win32_fileres=`file -L $1 2>/dev/null` + case $win32_fileres in + *ar\ archive\ import\ library*) # definitely import + win32_libid_type="x86 archive import" + ;; + *ar\ archive*) # could be an import, or static + if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | \ + $EGREP -e 'file format pe-i386(.*architecture: i386)?' >/dev/null ; then + win32_nmres=`eval $NM -f posix -A $1 | \ + sed -n -e '1,100{/ I /{x;/import/!{s/^/import/;h;p;};x;};}'` + if test "X$win32_nmres" = "Ximport" ; then + win32_libid_type="x86 archive import" + else + win32_libid_type="x86 archive static" + fi + fi + ;; + *DLL*) + win32_libid_type="x86 DLL" + ;; + *executable*) # but shell scripts are "executable" too... + case $win32_fileres in + *MS\ Windows\ PE\ Intel*) + win32_libid_type="x86 DLL" + ;; + esac + ;; + esac + $echo $win32_libid_type +} + + +# func_infer_tag arg +# Infer tagged configuration to use if any are available and +# if one wasn't chosen via the "--tag" command line option. +# Only attempt this if the compiler in the base compile +# command doesn't match the default compiler. +# arg is usually of the form 'gcc ...' +func_infer_tag () +{ + if test -n "$available_tags" && test -z "$tagname"; then + CC_quoted= + for arg in $CC; do + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + CC_quoted="$CC_quoted $arg" + done + case $@ in + # Blanks in the command may have been stripped by the calling shell, + # but not from the CC environment variable when configure was run. + " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*) ;; + # Blanks at the start of $base_compile will cause this to fail + # if we don't check for them as well. + *) + for z in $available_tags; do + if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then + # Evaluate the configuration. + eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" + CC_quoted= + for arg in $CC; do + # Double-quote args containing other shell metacharacters. + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + CC_quoted="$CC_quoted $arg" + done + case "$@ " in + " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*) + # The compiler in the base compile command matches + # the one in the tagged configuration. + # Assume this is the tagged configuration we want. + tagname=$z + break + ;; + esac + fi + done + # If $tagname still isn't set, then no tagged configuration + # was found and let the user know that the "--tag" command + # line option must be used. + if test -z "$tagname"; then + $echo "$modename: unable to infer tagged configuration" + $echo "$modename: specify a tag with \`--tag'" 1>&2 + exit $EXIT_FAILURE +# else +# $echo "$modename: using $tagname tagged configuration" + fi + ;; + esac + fi +} + + +# func_extract_an_archive dir oldlib +func_extract_an_archive () +{ + f_ex_an_ar_dir="$1"; shift + f_ex_an_ar_oldlib="$1" + + $show "(cd $f_ex_an_ar_dir && $AR x $f_ex_an_ar_oldlib)" + $run eval "(cd \$f_ex_an_ar_dir && $AR x \$f_ex_an_ar_oldlib)" || exit $? + if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then + : + else + $echo "$modename: ERROR: object name conflicts: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" 1>&2 + exit $EXIT_FAILURE + fi +} + +# func_extract_archives gentop oldlib ... +func_extract_archives () +{ + my_gentop="$1"; shift + my_oldlibs=${1+"$@"} + my_oldobjs="" + my_xlib="" + my_xabs="" + my_xdir="" + my_status="" + + $show "${rm}r $my_gentop" + $run ${rm}r "$my_gentop" + $show "$mkdir $my_gentop" + $run $mkdir "$my_gentop" + my_status=$? + if test "$my_status" -ne 0 && test ! -d "$my_gentop"; then + exit $my_status + fi + + for my_xlib in $my_oldlibs; do + # Extract the objects. + case $my_xlib in + [\\/]* | [A-Za-z]:[\\/]*) my_xabs="$my_xlib" ;; + *) my_xabs=`pwd`"/$my_xlib" ;; + esac + my_xlib=`$echo "X$my_xlib" | $Xsed -e 's%^.*/%%'` + my_xdir="$my_gentop/$my_xlib" + + $show "${rm}r $my_xdir" + $run ${rm}r "$my_xdir" + $show "$mkdir $my_xdir" + $run $mkdir "$my_xdir" + status=$? + if test "$status" -ne 0 && test ! -d "$my_xdir"; then + exit $status + fi + case $host in + *-darwin*) + $show "Extracting $my_xabs" + # Do not bother doing anything if just a dry run + if test -z "$run"; then + darwin_orig_dir=`pwd` + cd $my_xdir || exit $? + darwin_archive=$my_xabs + darwin_curdir=`pwd` + darwin_base_archive=`$echo "X$darwin_archive" | $Xsed -e 's%^.*/%%'` + darwin_arches=`lipo -info "$darwin_archive" 2>/dev/null | $EGREP Architectures 2>/dev/null` + if test -n "$darwin_arches"; then + darwin_arches=`echo "$darwin_arches" | $SED -e 's/.*are://'` + darwin_arch= + $show "$darwin_base_archive has multiple architectures $darwin_arches" + for darwin_arch in $darwin_arches ; do + mkdir -p "unfat-$$/${darwin_base_archive}-${darwin_arch}" + lipo -thin $darwin_arch -output "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" "${darwin_archive}" + cd "unfat-$$/${darwin_base_archive}-${darwin_arch}" + func_extract_an_archive "`pwd`" "${darwin_base_archive}" + cd "$darwin_curdir" + $rm "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" + done # $darwin_arches + ## Okay now we have a bunch of thin objects, gotta fatten them up :) + darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print| xargs basename | sort -u | $NL2SP` + darwin_file= + darwin_files= + for darwin_file in $darwin_filelist; do + darwin_files=`find unfat-$$ -name $darwin_file -print | $NL2SP` + lipo -create -output "$darwin_file" $darwin_files + done # $darwin_filelist + ${rm}r unfat-$$ + cd "$darwin_orig_dir" + else + cd "$darwin_orig_dir" + func_extract_an_archive "$my_xdir" "$my_xabs" + fi # $darwin_arches + fi # $run + ;; + *) + func_extract_an_archive "$my_xdir" "$my_xabs" + ;; + esac + my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | $NL2SP` + done + func_extract_archives_result="$my_oldobjs" +} +# End of Shell function definitions +##################################### + +# Darwin sucks +eval std_shrext=\"$shrext_cmds\" + +# Parse our command line options once, thoroughly. +while test "$#" -gt 0 +do + arg="$1" + shift + + case $arg in + -*=*) optarg=`$echo "X$arg" | $Xsed -e 's/[-_a-zA-Z0-9]*=//'` ;; + *) optarg= ;; + esac + + # If the previous option needs an argument, assign it. + if test -n "$prev"; then + case $prev in + execute_dlfiles) + execute_dlfiles="$execute_dlfiles $arg" + ;; + tag) + tagname="$arg" + preserve_args="${preserve_args}=$arg" + + # Check whether tagname contains only valid characters + case $tagname in + *[!-_A-Za-z0-9,/]*) + $echo "$progname: invalid tag name: $tagname" 1>&2 + exit $EXIT_FAILURE + ;; + esac + + case $tagname in + CC) + # Don't test for the "default" C tag, as we know, it's there, but + # not specially marked. + ;; + *) + if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$" < "$progpath" > /dev/null; then + taglist="$taglist $tagname" + # Evaluate the configuration. + eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$tagname'$/,/^# ### END LIBTOOL TAG CONFIG: '$tagname'$/p' < $progpath`" + else + $echo "$progname: ignoring unknown tag $tagname" 1>&2 + fi + ;; + esac + ;; + *) + eval "$prev=\$arg" + ;; + esac + + prev= + prevopt= + continue + fi + + # Have we seen a non-optional argument yet? + case $arg in + --help) + show_help=yes + ;; + + --version) + $echo "$PROGRAM (GNU $PACKAGE) $VERSION$TIMESTAMP" + $echo + $echo "Copyright (C) 2005 Free Software Foundation, Inc." + $echo "This is free software; see the source for copying conditions. There is NO" + $echo "warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." + exit $? + ;; + + --config) + ${SED} -e '1,/^# ### BEGIN LIBTOOL CONFIG/d' -e '/^# ### END LIBTOOL CONFIG/,$d' $progpath + # Now print the configurations for the tags. + for tagname in $taglist; do + ${SED} -n -e "/^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$/,/^# ### END LIBTOOL TAG CONFIG: $tagname$/p" < "$progpath" + done + exit $? + ;; + + --debug) + $echo "$progname: enabling shell trace mode" + set -x + preserve_args="$preserve_args $arg" + ;; + + --dry-run | -n) + run=: + ;; + + --features) + $echo "host: $host" + if test "$build_libtool_libs" = yes; then + $echo "enable shared libraries" + else + $echo "disable shared libraries" + fi + if test "$build_old_libs" = yes; then + $echo "enable static libraries" + else + $echo "disable static libraries" + fi + exit $? + ;; + + --finish) mode="finish" ;; + + --mode) prevopt="--mode" prev=mode ;; + --mode=*) mode="$optarg" ;; + + --preserve-dup-deps) duplicate_deps="yes" ;; + + --quiet | --silent) + show=: + preserve_args="$preserve_args $arg" + ;; + + --tag) prevopt="--tag" prev=tag ;; + --tag=*) + set tag "$optarg" ${1+"$@"} + shift + prev=tag + preserve_args="$preserve_args --tag" + ;; + + -dlopen) + prevopt="-dlopen" + prev=execute_dlfiles + ;; + + -*) + $echo "$modename: unrecognized option \`$arg'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + ;; + + *) + nonopt="$arg" + break + ;; + esac +done + +if test -n "$prevopt"; then + $echo "$modename: option \`$prevopt' requires an argument" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE +fi + +# If this variable is set in any of the actions, the command in it +# will be execed at the end. This prevents here-documents from being +# left over by shells. +exec_cmd= + +if test -z "$show_help"; then + + # Infer the operation mode. + if test -z "$mode"; then + $echo "*** Warning: inferring the mode of operation is deprecated." 1>&2 + $echo "*** Future versions of Libtool will require --mode=MODE be specified." 1>&2 + case $nonopt in + *cc | cc* | *++ | gcc* | *-gcc* | g++* | xlc*) + mode=link + for arg + do + case $arg in + -c) + mode=compile + break + ;; + esac + done + ;; + *db | *dbx | *strace | *truss) + mode=execute + ;; + *install*|cp|mv) + mode=install + ;; + *rm) + mode=uninstall + ;; + *) + # If we have no mode, but dlfiles were specified, then do execute mode. + test -n "$execute_dlfiles" && mode=execute + + # Just use the default operation mode. + if test -z "$mode"; then + if test -n "$nonopt"; then + $echo "$modename: warning: cannot infer operation mode from \`$nonopt'" 1>&2 + else + $echo "$modename: warning: cannot infer operation mode without MODE-ARGS" 1>&2 + fi + fi + ;; + esac + fi + + # Only execute mode is allowed to have -dlopen flags. + if test -n "$execute_dlfiles" && test "$mode" != execute; then + $echo "$modename: unrecognized option \`-dlopen'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + + # Change the help message to a mode-specific one. + generic_help="$help" + help="Try \`$modename --help --mode=$mode' for more information." + + # These modes are in order of execution frequency so that they run quickly. + case $mode in + # libtool compile mode + compile) + modename="$modename: compile" + # Get the compilation command and the source file. + base_compile= + srcfile="$nonopt" # always keep a non-empty value in "srcfile" + suppress_opt=yes + suppress_output= + arg_mode=normal + libobj= + later= + + for arg + do + case $arg_mode in + arg ) + # do not "continue". Instead, add this to base_compile + lastarg="$arg" + arg_mode=normal + ;; + + target ) + libobj="$arg" + arg_mode=normal + continue + ;; + + normal ) + # Accept any command-line options. + case $arg in + -o) + if test -n "$libobj" ; then + $echo "$modename: you cannot specify \`-o' more than once" 1>&2 + exit $EXIT_FAILURE + fi + arg_mode=target + continue + ;; + + -static | -prefer-pic | -prefer-non-pic) + later="$later $arg" + continue + ;; + + -no-suppress) + suppress_opt=no + continue + ;; + + -Xcompiler) + arg_mode=arg # the next one goes into the "base_compile" arg list + continue # The current "srcfile" will either be retained or + ;; # replaced later. I would guess that would be a bug. + + -Wc,*) + args=`$echo "X$arg" | $Xsed -e "s/^-Wc,//"` + lastarg= + save_ifs="$IFS"; IFS=',' + for arg in $args; do + IFS="$save_ifs" + + # Double-quote args containing other shell metacharacters. + # Many Bourne shells cannot handle close brackets correctly + # in scan sets, so we specify it separately. + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + lastarg="$lastarg $arg" + done + IFS="$save_ifs" + lastarg=`$echo "X$lastarg" | $Xsed -e "s/^ //"` + + # Add the arguments to base_compile. + base_compile="$base_compile $lastarg" + continue + ;; + + * ) + # Accept the current argument as the source file. + # The previous "srcfile" becomes the current argument. + # + lastarg="$srcfile" + srcfile="$arg" + ;; + esac # case $arg + ;; + esac # case $arg_mode + + # Aesthetically quote the previous argument. + lastarg=`$echo "X$lastarg" | $Xsed -e "$sed_quote_subst"` + + case $lastarg in + # Double-quote args containing other shell metacharacters. + # Many Bourne shells cannot handle close brackets correctly + # in scan sets, and some SunOS ksh mistreat backslash-escaping + # in scan sets (worked around with variable expansion), + # and furthermore cannot handle '|' '&' '(' ')' in scan sets + # at all, so we specify them separately. + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + lastarg="\"$lastarg\"" + ;; + esac + + base_compile="$base_compile $lastarg" + done # for arg + + case $arg_mode in + arg) + $echo "$modename: you must specify an argument for -Xcompile" + exit $EXIT_FAILURE + ;; + target) + $echo "$modename: you must specify a target with \`-o'" 1>&2 + exit $EXIT_FAILURE + ;; + *) + # Get the name of the library object. + [ -z "$libobj" ] && libobj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%'` + ;; + esac + + # Recognize several different file suffixes. + # If the user specifies -o file.o, it is replaced with file.lo + xform='[cCFSifmso]' + case $libobj in + *.ada) xform=ada ;; + *.adb) xform=adb ;; + *.ads) xform=ads ;; + *.asm) xform=asm ;; + *.c++) xform=c++ ;; + *.cc) xform=cc ;; + *.ii) xform=ii ;; + *.class) xform=class ;; + *.cpp) xform=cpp ;; + *.cxx) xform=cxx ;; + *.f90) xform=f90 ;; + *.for) xform=for ;; + *.java) xform=java ;; + esac + + libobj=`$echo "X$libobj" | $Xsed -e "s/\.$xform$/.lo/"` + + case $libobj in + *.lo) obj=`$echo "X$libobj" | $Xsed -e "$lo2o"` ;; + *) + $echo "$modename: cannot determine name of library object from \`$libobj'" 1>&2 + exit $EXIT_FAILURE + ;; + esac + + func_infer_tag $base_compile + + for arg in $later; do + case $arg in + -static) + build_old_libs=yes + continue + ;; + + -prefer-pic) + pic_mode=yes + continue + ;; + + -prefer-non-pic) + pic_mode=no + continue + ;; + esac + done + + qlibobj=`$echo "X$libobj" | $Xsed -e "$sed_quote_subst"` + case $qlibobj in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + qlibobj="\"$qlibobj\"" ;; + esac + test "X$libobj" != "X$qlibobj" \ + && $echo "X$libobj" | grep '[]~#^*{};<>?"'"'"' &()|`$[]' \ + && $echo "$modename: libobj name \`$libobj' may not contain shell special characters." + objname=`$echo "X$obj" | $Xsed -e 's%^.*/%%'` + xdir=`$echo "X$obj" | $Xsed -e 's%/[^/]*$%%'` + if test "X$xdir" = "X$obj"; then + xdir= + else + xdir=$xdir/ + fi + lobj=${xdir}$objdir/$objname + + if test -z "$base_compile"; then + $echo "$modename: you must specify a compilation command" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + + # Delete any leftover library objects. + if test "$build_old_libs" = yes; then + removelist="$obj $lobj $libobj ${libobj}T" + else + removelist="$lobj $libobj ${libobj}T" + fi + + $run $rm $removelist + trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15 + + # On Cygwin there's no "real" PIC flag so we must build both object types + case $host_os in + cygwin* | mingw* | pw32* | os2*) + pic_mode=default + ;; + esac + if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then + # non-PIC code in shared libraries is not supported + pic_mode=default + fi + + # Calculate the filename of the output object if compiler does + # not support -o with -c + if test "$compiler_c_o" = no; then + output_obj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%' -e 's%\.[^.]*$%%'`.${objext} + lockfile="$output_obj.lock" + removelist="$removelist $output_obj $lockfile" + trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15 + else + output_obj= + need_locks=no + lockfile= + fi + + # Lock this critical section if it is needed + # We use this script file to make the link, it avoids creating a new file + if test "$need_locks" = yes; then + until $run ln "$progpath" "$lockfile" 2>/dev/null; do + $show "Waiting for $lockfile to be removed" + sleep 2 + done + elif test "$need_locks" = warn; then + if test -f "$lockfile"; then + $echo "\ +*** ERROR, $lockfile exists and contains: +`cat $lockfile 2>/dev/null` + +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support \`-c' and \`-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." + + $run $rm $removelist + exit $EXIT_FAILURE + fi + $echo "$srcfile" > "$lockfile" + fi + + if test -n "$fix_srcfile_path"; then + eval srcfile=\"$fix_srcfile_path\" + fi + qsrcfile=`$echo "X$srcfile" | $Xsed -e "$sed_quote_subst"` + case $qsrcfile in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + qsrcfile="\"$qsrcfile\"" ;; + esac + + $run $rm "$libobj" "${libobj}T" + + # Create a libtool object file (analogous to a ".la" file), + # but don't create it if we're doing a dry run. + test -z "$run" && cat > ${libobj}T </dev/null`" != "X$srcfile"; then + $echo "\ +*** ERROR, $lockfile contains: +`cat $lockfile 2>/dev/null` + +but it should contain: +$srcfile + +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support \`-c' and \`-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." + + $run $rm $removelist + exit $EXIT_FAILURE + fi + + # Just move the object if needed, then go on to compile the next one + if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then + $show "$mv $output_obj $lobj" + if $run $mv $output_obj $lobj; then : + else + error=$? + $run $rm $removelist + exit $error + fi + fi + + # Append the name of the PIC object to the libtool object file. + test -z "$run" && cat >> ${libobj}T <> ${libobj}T </dev/null`" != "X$srcfile"; then + $echo "\ +*** ERROR, $lockfile contains: +`cat $lockfile 2>/dev/null` + +but it should contain: +$srcfile + +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support \`-c' and \`-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." + + $run $rm $removelist + exit $EXIT_FAILURE + fi + + # Just move the object if needed + if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then + $show "$mv $output_obj $obj" + if $run $mv $output_obj $obj; then : + else + error=$? + $run $rm $removelist + exit $error + fi + fi + + # Append the name of the non-PIC object the libtool object file. + # Only append if the libtool object file exists. + test -z "$run" && cat >> ${libobj}T <> ${libobj}T <&2 + fi + if test -n "$link_static_flag"; then + dlopen_self=$dlopen_self_static + fi + else + if test -z "$pic_flag" && test -n "$link_static_flag"; then + dlopen_self=$dlopen_self_static + fi + fi + build_libtool_libs=no + build_old_libs=yes + prefer_static_libs=yes + break + ;; + esac + done + + # See if our shared archives depend on static archives. + test -n "$old_archive_from_new_cmds" && build_old_libs=yes + + # Go through the arguments, transforming them on the way. + while test "$#" -gt 0; do + arg="$1" + shift + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + qarg=\"`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`\" ### testsuite: skip nested quoting test + ;; + *) qarg=$arg ;; + esac + libtool_args="$libtool_args $qarg" + + # If the previous option needs an argument, assign it. + if test -n "$prev"; then + case $prev in + output) + compile_command="$compile_command @OUTPUT@" + finalize_command="$finalize_command @OUTPUT@" + ;; + esac + + case $prev in + dlfiles|dlprefiles) + if test "$preload" = no; then + # Add the symbol object into the linking commands. + compile_command="$compile_command @SYMFILE@" + finalize_command="$finalize_command @SYMFILE@" + preload=yes + fi + case $arg in + *.la | *.lo) ;; # We handle these cases below. + force) + if test "$dlself" = no; then + dlself=needless + export_dynamic=yes + fi + prev= + continue + ;; + self) + if test "$prev" = dlprefiles; then + dlself=yes + elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then + dlself=yes + else + dlself=needless + export_dynamic=yes + fi + prev= + continue + ;; + *) + if test "$prev" = dlfiles; then + dlfiles="$dlfiles $arg" + else + dlprefiles="$dlprefiles $arg" + fi + prev= + continue + ;; + esac + ;; + expsyms) + export_symbols="$arg" + if test ! -f "$arg"; then + $echo "$modename: symbol file \`$arg' does not exist" + exit $EXIT_FAILURE + fi + prev= + continue + ;; + expsyms_regex) + export_symbols_regex="$arg" + prev= + continue + ;; + inst_prefix) + inst_prefix_dir="$arg" + prev= + continue + ;; + precious_regex) + precious_files_regex="$arg" + prev= + continue + ;; + release) + release="-$arg" + prev= + continue + ;; + objectlist) + if test -f "$arg"; then + save_arg=$arg + moreargs= + for fil in `cat $save_arg` + do +# moreargs="$moreargs $fil" + arg=$fil + # A libtool-controlled object. + + # Check to see that this really is a libtool object. + if (${SED} -e '2q' $arg | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + pic_object= + non_pic_object= + + # Read the .lo file + # If there is no directory component, then add one. + case $arg in + */* | *\\*) . $arg ;; + *) . ./$arg ;; + esac + + if test -z "$pic_object" || \ + test -z "$non_pic_object" || + test "$pic_object" = none && \ + test "$non_pic_object" = none; then + $echo "$modename: cannot find name of object for \`$arg'" 1>&2 + exit $EXIT_FAILURE + fi + + # Extract subdirectory from the argument. + xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'` + if test "X$xdir" = "X$arg"; then + xdir= + else + xdir="$xdir/" + fi + + if test "$pic_object" != none; then + # Prepend the subdirectory the object is found in. + pic_object="$xdir$pic_object" + + if test "$prev" = dlfiles; then + if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then + dlfiles="$dlfiles $pic_object" + prev= + continue + else + # If libtool objects are unsupported, then we need to preload. + prev=dlprefiles + fi + fi + + # CHECK ME: I think I busted this. -Ossama + if test "$prev" = dlprefiles; then + # Preload the old-style object. + dlprefiles="$dlprefiles $pic_object" + prev= + fi + + # A PIC object. + libobjs="$libobjs $pic_object" + arg="$pic_object" + fi + + # Non-PIC object. + if test "$non_pic_object" != none; then + # Prepend the subdirectory the object is found in. + non_pic_object="$xdir$non_pic_object" + + # A standard non-PIC object + non_pic_objects="$non_pic_objects $non_pic_object" + if test -z "$pic_object" || test "$pic_object" = none ; then + arg="$non_pic_object" + fi + fi + else + # Only an error if not doing a dry-run. + if test -z "$run"; then + $echo "$modename: \`$arg' is not a valid libtool object" 1>&2 + exit $EXIT_FAILURE + else + # Dry-run case. + + # Extract subdirectory from the argument. + xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'` + if test "X$xdir" = "X$arg"; then + xdir= + else + xdir="$xdir/" + fi + + pic_object=`$echo "X${xdir}${objdir}/${arg}" | $Xsed -e "$lo2o"` + non_pic_object=`$echo "X${xdir}${arg}" | $Xsed -e "$lo2o"` + libobjs="$libobjs $pic_object" + non_pic_objects="$non_pic_objects $non_pic_object" + fi + fi + done + else + $echo "$modename: link input file \`$save_arg' does not exist" + exit $EXIT_FAILURE + fi + arg=$save_arg + prev= + continue + ;; + rpath | xrpath) + # We need an absolute path. + case $arg in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + $echo "$modename: only absolute run-paths are allowed" 1>&2 + exit $EXIT_FAILURE + ;; + esac + if test "$prev" = rpath; then + case "$rpath " in + *" $arg "*) ;; + *) rpath="$rpath $arg" ;; + esac + else + case "$xrpath " in + *" $arg "*) ;; + *) xrpath="$xrpath $arg" ;; + esac + fi + prev= + continue + ;; + xcompiler) + compiler_flags="$compiler_flags $qarg" + prev= + compile_command="$compile_command $qarg" + finalize_command="$finalize_command $qarg" + continue + ;; + xlinker) + linker_flags="$linker_flags $qarg" + compiler_flags="$compiler_flags $wl$qarg" + prev= + compile_command="$compile_command $wl$qarg" + finalize_command="$finalize_command $wl$qarg" + continue + ;; + xcclinker) + linker_flags="$linker_flags $qarg" + compiler_flags="$compiler_flags $qarg" + prev= + compile_command="$compile_command $qarg" + finalize_command="$finalize_command $qarg" + continue + ;; + shrext) + shrext_cmds="$arg" + prev= + continue + ;; + darwin_framework) + compiler_flags="$compiler_flags $arg" + compile_command="$compile_command $arg" + finalize_command="$finalize_command $arg" + prev= + continue + ;; + *) + eval "$prev=\"\$arg\"" + prev= + continue + ;; + esac + fi # test -n "$prev" + + prevarg="$arg" + + case $arg in + -all-static) + if test -n "$link_static_flag"; then + compile_command="$compile_command $link_static_flag" + finalize_command="$finalize_command $link_static_flag" + fi + continue + ;; + + -allow-undefined) + # FIXME: remove this flag sometime in the future. + $echo "$modename: \`-allow-undefined' is deprecated because it is the default" 1>&2 + continue + ;; + + -avoid-version) + avoid_version=yes + continue + ;; + + -dlopen) + prev=dlfiles + continue + ;; + + -dlpreopen) + prev=dlprefiles + continue + ;; + + -export-dynamic) + export_dynamic=yes + continue + ;; + + -export-symbols | -export-symbols-regex) + if test -n "$export_symbols" || test -n "$export_symbols_regex"; then + $echo "$modename: more than one -exported-symbols argument is not allowed" + exit $EXIT_FAILURE + fi + if test "X$arg" = "X-export-symbols"; then + prev=expsyms + else + prev=expsyms_regex + fi + continue + ;; + + -framework|-arch) + prev=darwin_framework + compiler_flags="$compiler_flags $arg" + compile_command="$compile_command $arg" + finalize_command="$finalize_command $arg" + continue + ;; + + -inst-prefix-dir) + prev=inst_prefix + continue + ;; + + # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:* + # so, if we see these flags be careful not to treat them like -L + -L[A-Z][A-Z]*:*) + case $with_gcc/$host in + no/*-*-irix* | /*-*-irix*) + compile_command="$compile_command $arg" + finalize_command="$finalize_command $arg" + ;; + esac + continue + ;; + + -L*) + dir=`$echo "X$arg" | $Xsed -e 's/^-L//'` + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + absdir=`cd "$dir" && pwd` + if test -z "$absdir"; then + $echo "$modename: cannot determine absolute directory name of \`$dir'" 1>&2 + exit $EXIT_FAILURE + fi + dir="$absdir" + ;; + esac + case "$deplibs " in + *" -L$dir "*) ;; + *) + deplibs="$deplibs -L$dir" + lib_search_path="$lib_search_path $dir" + ;; + esac + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*) + case :$dllsearchpath: in + *":$dir:"*) ;; + *) dllsearchpath="$dllsearchpath:$dir";; + esac + ;; + esac + continue + ;; + + -l*) + if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then + case $host in + *-*-cygwin* | *-*-pw32* | *-*-beos*) + # These systems don't actually have a C or math library (as such) + continue + ;; + *-*-mingw* | *-*-os2*) + # These systems don't actually have a C library (as such) + test "X$arg" = "X-lc" && continue + ;; + *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) + # Do not include libc due to us having libc/libc_r. + test "X$arg" = "X-lc" && continue + ;; + *-*-rhapsody* | *-*-darwin1.[012]) + # Rhapsody C and math libraries are in the System framework + deplibs="$deplibs -framework System" + continue + esac + elif test "X$arg" = "X-lc_r"; then + case $host in + *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) + # Do not include libc_r directly, use -pthread flag. + continue + ;; + esac + fi + deplibs="$deplibs $arg" + continue + ;; + + # Tru64 UNIX uses -model [arg] to determine the layout of C++ + # classes, name mangling, and exception handling. + -model) + compile_command="$compile_command $arg" + compiler_flags="$compiler_flags $arg" + finalize_command="$finalize_command $arg" + prev=xcompiler + continue + ;; + + -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe) + compiler_flags="$compiler_flags $arg" + compile_command="$compile_command $arg" + finalize_command="$finalize_command $arg" + continue + ;; + + -module) + module=yes + continue + ;; + + # -64, -mips[0-9] enable 64-bit mode on the SGI compiler + # -r[0-9][0-9]* specifies the processor on the SGI compiler + # -xarch=*, -xtarget=* enable 64-bit mode on the Sun compiler + # +DA*, +DD* enable 64-bit mode on the HP compiler + # -q* pass through compiler args for the IBM compiler + # -m* pass through architecture-specific compiler args for GCC + -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*) + + # Unknown arguments in both finalize_command and compile_command need + # to be aesthetically quoted because they are evaled later. + arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + compile_command="$compile_command $arg" + finalize_command="$finalize_command $arg" + if test "$with_gcc" = "yes" ; then + compiler_flags="$compiler_flags $arg" + fi + continue + ;; + + -shrext) + prev=shrext + continue + ;; + + -no-fast-install) + fast_install=no + continue + ;; + + -no-install) + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*) + # The PATH hackery in wrapper scripts is required on Windows + # in order for the loader to find any dlls it needs. + $echo "$modename: warning: \`-no-install' is ignored for $host" 1>&2 + $echo "$modename: warning: assuming \`-no-fast-install' instead" 1>&2 + fast_install=no + ;; + *) no_install=yes ;; + esac + continue + ;; + + -no-undefined) + allow_undefined=no + continue + ;; + + -objectlist) + prev=objectlist + continue + ;; + + -o) prev=output ;; + + -precious-files-regex) + prev=precious_regex + continue + ;; + + -release) + prev=release + continue + ;; + + -rpath) + prev=rpath + continue + ;; + + -R) + prev=xrpath + continue + ;; + + -R*) + dir=`$echo "X$arg" | $Xsed -e 's/^-R//'` + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + $echo "$modename: only absolute run-paths are allowed" 1>&2 + exit $EXIT_FAILURE + ;; + esac + case "$xrpath " in + *" $dir "*) ;; + *) xrpath="$xrpath $dir" ;; + esac + continue + ;; + + -static) + # The effects of -static are defined in a previous loop. + # We used to do the same as -all-static on platforms that + # didn't have a PIC flag, but the assumption that the effects + # would be equivalent was wrong. It would break on at least + # Digital Unix and AIX. + continue + ;; + + -thread-safe) + thread_safe=yes + continue + ;; + + -version-info) + prev=vinfo + continue + ;; + -version-number) + prev=vinfo + vinfo_number=yes + continue + ;; + + -Wc,*) + args=`$echo "X$arg" | $Xsed -e "$sed_quote_subst" -e 's/^-Wc,//'` + arg= + save_ifs="$IFS"; IFS=',' + for flag in $args; do + IFS="$save_ifs" + case $flag in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + flag="\"$flag\"" + ;; + esac + arg="$arg $wl$flag" + compiler_flags="$compiler_flags $flag" + done + IFS="$save_ifs" + arg=`$echo "X$arg" | $Xsed -e "s/^ //"` + ;; + + -Wl,*) + args=`$echo "X$arg" | $Xsed -e "$sed_quote_subst" -e 's/^-Wl,//'` + arg= + save_ifs="$IFS"; IFS=',' + for flag in $args; do + IFS="$save_ifs" + case $flag in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + flag="\"$flag\"" + ;; + esac + arg="$arg $wl$flag" + compiler_flags="$compiler_flags $wl$flag" + linker_flags="$linker_flags $flag" + done + IFS="$save_ifs" + arg=`$echo "X$arg" | $Xsed -e "s/^ //"` + ;; + + -Xcompiler) + prev=xcompiler + continue + ;; + + -Xlinker) + prev=xlinker + continue + ;; + + -XCClinker) + prev=xcclinker + continue + ;; + + # Some other compiler flag. + -* | +*) + # Unknown arguments in both finalize_command and compile_command need + # to be aesthetically quoted because they are evaled later. + arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + ;; + + *.$objext) + # A standard object. + objs="$objs $arg" + ;; + + *.lo) + # A libtool-controlled object. + + # Check to see that this really is a libtool object. + if (${SED} -e '2q' $arg | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + pic_object= + non_pic_object= + + # Read the .lo file + # If there is no directory component, then add one. + case $arg in + */* | *\\*) . $arg ;; + *) . ./$arg ;; + esac + + if test -z "$pic_object" || \ + test -z "$non_pic_object" || + test "$pic_object" = none && \ + test "$non_pic_object" = none; then + $echo "$modename: cannot find name of object for \`$arg'" 1>&2 + exit $EXIT_FAILURE + fi + + # Extract subdirectory from the argument. + xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'` + if test "X$xdir" = "X$arg"; then + xdir= + else + xdir="$xdir/" + fi + + if test "$pic_object" != none; then + # Prepend the subdirectory the object is found in. + pic_object="$xdir$pic_object" + + if test "$prev" = dlfiles; then + if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then + dlfiles="$dlfiles $pic_object" + prev= + continue + else + # If libtool objects are unsupported, then we need to preload. + prev=dlprefiles + fi + fi + + # CHECK ME: I think I busted this. -Ossama + if test "$prev" = dlprefiles; then + # Preload the old-style object. + dlprefiles="$dlprefiles $pic_object" + prev= + fi + + # A PIC object. + libobjs="$libobjs $pic_object" + arg="$pic_object" + fi + + # Non-PIC object. + if test "$non_pic_object" != none; then + # Prepend the subdirectory the object is found in. + non_pic_object="$xdir$non_pic_object" + + # A standard non-PIC object + non_pic_objects="$non_pic_objects $non_pic_object" + if test -z "$pic_object" || test "$pic_object" = none ; then + arg="$non_pic_object" + fi + fi + else + # Only an error if not doing a dry-run. + if test -z "$run"; then + $echo "$modename: \`$arg' is not a valid libtool object" 1>&2 + exit $EXIT_FAILURE + else + # Dry-run case. + + # Extract subdirectory from the argument. + xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'` + if test "X$xdir" = "X$arg"; then + xdir= + else + xdir="$xdir/" + fi + + pic_object=`$echo "X${xdir}${objdir}/${arg}" | $Xsed -e "$lo2o"` + non_pic_object=`$echo "X${xdir}${arg}" | $Xsed -e "$lo2o"` + libobjs="$libobjs $pic_object" + non_pic_objects="$non_pic_objects $non_pic_object" + fi + fi + ;; + + *.$libext) + # An archive. + deplibs="$deplibs $arg" + old_deplibs="$old_deplibs $arg" + continue + ;; + + *.la) + # A libtool-controlled library. + + if test "$prev" = dlfiles; then + # This library was specified with -dlopen. + dlfiles="$dlfiles $arg" + prev= + elif test "$prev" = dlprefiles; then + # The library was specified with -dlpreopen. + dlprefiles="$dlprefiles $arg" + prev= + else + deplibs="$deplibs $arg" + fi + continue + ;; + + # Some other compiler argument. + *) + # Unknown arguments in both finalize_command and compile_command need + # to be aesthetically quoted because they are evaled later. + arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + ;; + esac # arg + + # Now actually substitute the argument into the commands. + if test -n "$arg"; then + compile_command="$compile_command $arg" + finalize_command="$finalize_command $arg" + fi + done # argument parsing loop + + if test -n "$prev"; then + $echo "$modename: the \`$prevarg' option requires an argument" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + + if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then + eval arg=\"$export_dynamic_flag_spec\" + compile_command="$compile_command $arg" + finalize_command="$finalize_command $arg" + fi + + oldlibs= + # calculate the name of the file, without its directory + outputname=`$echo "X$output" | $Xsed -e 's%^.*/%%'` + libobjs_save="$libobjs" + + if test -n "$shlibpath_var"; then + # get the directories listed in $shlibpath_var + eval shlib_search_path=\`\$echo \"X\${$shlibpath_var}\" \| \$Xsed -e \'s/:/ /g\'\` + else + shlib_search_path= + fi + eval sys_lib_search_path=\"$sys_lib_search_path_spec\" + eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" + + output_objdir=`$echo "X$output" | $Xsed -e 's%/[^/]*$%%'` + if test "X$output_objdir" = "X$output"; then + output_objdir="$objdir" + else + output_objdir="$output_objdir/$objdir" + fi + # Create the object directory. + if test ! -d "$output_objdir"; then + $show "$mkdir $output_objdir" + $run $mkdir $output_objdir + status=$? + if test "$status" -ne 0 && test ! -d "$output_objdir"; then + exit $status + fi + fi + + # Determine the type of output + case $output in + "") + $echo "$modename: you must specify an output file" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + ;; + *.$libext) linkmode=oldlib ;; + *.lo | *.$objext) linkmode=obj ;; + *.la) linkmode=lib ;; + *) linkmode=prog ;; # Anything else should be a program. + esac + + case $host in + *cygwin* | *mingw* | *pw32*) + # don't eliminate duplications in $postdeps and $predeps + duplicate_compiler_generated_deps=yes + ;; + *) + duplicate_compiler_generated_deps=$duplicate_deps + ;; + esac + specialdeplibs= + + libs= + # Find all interdependent deplibs by searching for libraries + # that are linked more than once (e.g. -la -lb -la) + for deplib in $deplibs; do + if test "X$duplicate_deps" = "Xyes" ; then + case "$libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac + fi + libs="$libs $deplib" + done + + if test "$linkmode" = lib; then + libs="$predeps $libs $compiler_lib_search_path $postdeps" + + # Compute libraries that are listed more than once in $predeps + # $postdeps and mark them as special (i.e., whose duplicates are + # not to be eliminated). + pre_post_deps= + if test "X$duplicate_compiler_generated_deps" = "Xyes" ; then + for pre_post_dep in $predeps $postdeps; do + case "$pre_post_deps " in + *" $pre_post_dep "*) specialdeplibs="$specialdeplibs $pre_post_deps" ;; + esac + pre_post_deps="$pre_post_deps $pre_post_dep" + done + fi + pre_post_deps= + fi + + deplibs= + newdependency_libs= + newlib_search_path= + need_relink=no # whether we're linking any uninstalled libtool libraries + notinst_deplibs= # not-installed libtool libraries + notinst_path= # paths that contain not-installed libtool libraries + case $linkmode in + lib) + passes="conv link" + for file in $dlfiles $dlprefiles; do + case $file in + *.la) ;; + *) + $echo "$modename: libraries can \`-dlopen' only libtool libraries: $file" 1>&2 + exit $EXIT_FAILURE + ;; + esac + done + ;; + prog) + compile_deplibs= + finalize_deplibs= + alldeplibs=no + newdlfiles= + newdlprefiles= + passes="conv scan dlopen dlpreopen link" + ;; + *) passes="conv" + ;; + esac + for pass in $passes; do + if test "$linkmode,$pass" = "lib,link" || + test "$linkmode,$pass" = "prog,scan"; then + libs="$deplibs" + deplibs= + fi + if test "$linkmode" = prog; then + case $pass in + dlopen) libs="$dlfiles" ;; + dlpreopen) libs="$dlprefiles" ;; + link) + libs="$deplibs %DEPLIBS%" + test "X$link_all_deplibs" != Xno && libs="$libs $dependency_libs" + ;; + esac + fi + if test "$pass" = dlopen; then + # Collect dlpreopened libraries + save_deplibs="$deplibs" + deplibs= + fi + for deplib in $libs; do + lib= + found=no + case $deplib in + -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe) + if test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + compiler_flags="$compiler_flags $deplib" + fi + continue + ;; + -l*) + if test "$linkmode" != lib && test "$linkmode" != prog; then + $echo "$modename: warning: \`-l' is ignored for archives/objects" 1>&2 + continue + fi + name=`$echo "X$deplib" | $Xsed -e 's/^-l//'` + for searchdir in $newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path; do + for search_ext in .la $std_shrext .so .a; do + # Search the libtool library + lib="$searchdir/lib${name}${search_ext}" + if test -f "$lib"; then + if test "$search_ext" = ".la"; then + found=yes + else + found=no + fi + break 2 + fi + done + done + if test "$found" != yes; then + # deplib doesn't seem to be a libtool library + if test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + deplibs="$deplib $deplibs" + test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs" + fi + continue + else # deplib is a libtool library + # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib, + # We need to do some special things here, and not later. + if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then + case " $predeps $postdeps " in + *" $deplib "*) + if (${SED} -e '2q' $lib | + grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + library_names= + old_library= + case $lib in + */* | *\\*) . $lib ;; + *) . ./$lib ;; + esac + for l in $old_library $library_names; do + ll="$l" + done + if test "X$ll" = "X$old_library" ; then # only static version available + found=no + ladir=`$echo "X$lib" | $Xsed -e 's%/[^/]*$%%'` + test "X$ladir" = "X$lib" && ladir="." + lib=$ladir/$old_library + if test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + deplibs="$deplib $deplibs" + test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs" + fi + continue + fi + fi + ;; + *) ;; + esac + fi + fi + ;; # -l + -L*) + case $linkmode in + lib) + deplibs="$deplib $deplibs" + test "$pass" = conv && continue + newdependency_libs="$deplib $newdependency_libs" + newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'` + ;; + prog) + if test "$pass" = conv; then + deplibs="$deplib $deplibs" + continue + fi + if test "$pass" = scan; then + deplibs="$deplib $deplibs" + else + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + fi + newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'` + ;; + *) + $echo "$modename: warning: \`-L' is ignored for archives/objects" 1>&2 + ;; + esac # linkmode + continue + ;; # -L + -R*) + if test "$pass" = link; then + dir=`$echo "X$deplib" | $Xsed -e 's/^-R//'` + # Make sure the xrpath contains only unique directories. + case "$xrpath " in + *" $dir "*) ;; + *) xrpath="$xrpath $dir" ;; + esac + fi + deplibs="$deplib $deplibs" + continue + ;; + *.la) lib="$deplib" ;; + *.$libext) + if test "$pass" = conv; then + deplibs="$deplib $deplibs" + continue + fi + case $linkmode in + lib) + valid_a_lib=no + case $deplibs_check_method in + match_pattern*) + set dummy $deplibs_check_method + match_pattern_regex=`expr "$deplibs_check_method" : "$2 \(.*\)"` + if eval $echo \"$deplib\" 2>/dev/null \ + | $SED 10q \ + | $EGREP "$match_pattern_regex" > /dev/null; then + valid_a_lib=yes + fi + ;; + pass_all) + valid_a_lib=yes + ;; + esac + if test "$valid_a_lib" != yes; then + $echo + $echo "*** Warning: Trying to link with static lib archive $deplib." + $echo "*** I have the capability to make that library automatically link in when" + $echo "*** you link to this library. But I can only do this if you have a" + $echo "*** shared version of the library, which you do not appear to have" + $echo "*** because the file extensions .$libext of this argument makes me believe" + $echo "*** that it is just a static archive that I should not used here." + else + $echo + $echo "*** Warning: Linking the shared library $output against the" + $echo "*** static library $deplib is not portable!" + deplibs="$deplib $deplibs" + fi + continue + ;; + prog) + if test "$pass" != link; then + deplibs="$deplib $deplibs" + else + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + fi + continue + ;; + esac # linkmode + ;; # *.$libext + *.lo | *.$objext) + if test "$pass" = conv; then + deplibs="$deplib $deplibs" + elif test "$linkmode" = prog; then + if test "$pass" = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then + # If there is no dlopen support or we're linking statically, + # we need to preload. + newdlprefiles="$newdlprefiles $deplib" + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + newdlfiles="$newdlfiles $deplib" + fi + fi + continue + ;; + %DEPLIBS%) + alldeplibs=yes + continue + ;; + esac # case $deplib + if test "$found" = yes || test -f "$lib"; then : + else + $echo "$modename: cannot find the library \`$lib'" 1>&2 + exit $EXIT_FAILURE + fi + + # Check to see that this really is a libtool archive. + if (${SED} -e '2q' $lib | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then : + else + $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2 + exit $EXIT_FAILURE + fi + + ladir=`$echo "X$lib" | $Xsed -e 's%/[^/]*$%%'` + test "X$ladir" = "X$lib" && ladir="." + + dlname= + dlopen= + dlpreopen= + libdir= + library_names= + old_library= + # If the library was installed with an old release of libtool, + # it will not redefine variables installed, or shouldnotlink + installed=yes + shouldnotlink=no + avoidtemprpath= + + + # Read the .la file + case $lib in + */* | *\\*) . $lib ;; + *) . ./$lib ;; + esac + + if test "$linkmode,$pass" = "lib,link" || + test "$linkmode,$pass" = "prog,scan" || + { test "$linkmode" != prog && test "$linkmode" != lib; }; then + test -n "$dlopen" && dlfiles="$dlfiles $dlopen" + test -n "$dlpreopen" && dlprefiles="$dlprefiles $dlpreopen" + fi + + if test "$pass" = conv; then + # Only check for convenience libraries + deplibs="$lib $deplibs" + if test -z "$libdir"; then + if test -z "$old_library"; then + $echo "$modename: cannot find name of link library for \`$lib'" 1>&2 + exit $EXIT_FAILURE + fi + # It is a libtool convenience library, so add in its objects. + convenience="$convenience $ladir/$objdir/$old_library" + old_convenience="$old_convenience $ladir/$objdir/$old_library" + tmp_libs= + for deplib in $dependency_libs; do + deplibs="$deplib $deplibs" + if test "X$duplicate_deps" = "Xyes" ; then + case "$tmp_libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac + fi + tmp_libs="$tmp_libs $deplib" + done + elif test "$linkmode" != prog && test "$linkmode" != lib; then + $echo "$modename: \`$lib' is not a convenience library" 1>&2 + exit $EXIT_FAILURE + fi + continue + fi # $pass = conv + + + # Get the name of the library we link against. + linklib= + for l in $old_library $library_names; do + linklib="$l" + done + if test -z "$linklib"; then + $echo "$modename: cannot find name of link library for \`$lib'" 1>&2 + exit $EXIT_FAILURE + fi + + # This library was specified with -dlopen. + if test "$pass" = dlopen; then + if test -z "$libdir"; then + $echo "$modename: cannot -dlopen a convenience library: \`$lib'" 1>&2 + exit $EXIT_FAILURE + fi + if test -z "$dlname" || + test "$dlopen_support" != yes || + test "$build_libtool_libs" = no; then + # If there is no dlname, no dlopen support or we're linking + # statically, we need to preload. We also need to preload any + # dependent libraries so libltdl's deplib preloader doesn't + # bomb out in the load deplibs phase. + dlprefiles="$dlprefiles $lib $dependency_libs" + else + newdlfiles="$newdlfiles $lib" + fi + continue + fi # $pass = dlopen + + # We need an absolute path. + case $ladir in + [\\/]* | [A-Za-z]:[\\/]*) abs_ladir="$ladir" ;; + *) + abs_ladir=`cd "$ladir" && pwd` + if test -z "$abs_ladir"; then + $echo "$modename: warning: cannot determine absolute directory name of \`$ladir'" 1>&2 + $echo "$modename: passing it literally to the linker, although it might fail" 1>&2 + abs_ladir="$ladir" + fi + ;; + esac + laname=`$echo "X$lib" | $Xsed -e 's%^.*/%%'` + + # Find the relevant object directory and library name. + if test "X$installed" = Xyes; then + if test ! -f "$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then + $echo "$modename: warning: library \`$lib' was moved." 1>&2 + dir="$ladir" + absdir="$abs_ladir" + libdir="$abs_ladir" + else + dir="$libdir" + absdir="$libdir" + fi + test "X$hardcode_automatic" = Xyes && avoidtemprpath=yes + else + if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then + dir="$ladir" + absdir="$abs_ladir" + # Remove this search path later + notinst_path="$notinst_path $abs_ladir" + else + dir="$ladir/$objdir" + absdir="$abs_ladir/$objdir" + # Remove this search path later + notinst_path="$notinst_path $abs_ladir" + fi + fi # $installed = yes + name=`$echo "X$laname" | $Xsed -e 's/\.la$//' -e 's/^lib//'` + + # This library was specified with -dlpreopen. + if test "$pass" = dlpreopen; then + if test -z "$libdir"; then + $echo "$modename: cannot -dlpreopen a convenience library: \`$lib'" 1>&2 + exit $EXIT_FAILURE + fi + # Prefer using a static library (so that no silly _DYNAMIC symbols + # are required to link). + if test -n "$old_library"; then + newdlprefiles="$newdlprefiles $dir/$old_library" + # Otherwise, use the dlname, so that lt_dlopen finds it. + elif test -n "$dlname"; then + newdlprefiles="$newdlprefiles $dir/$dlname" + else + newdlprefiles="$newdlprefiles $dir/$linklib" + fi + fi # $pass = dlpreopen + + if test -z "$libdir"; then + # Link the convenience library + if test "$linkmode" = lib; then + deplibs="$dir/$old_library $deplibs" + elif test "$linkmode,$pass" = "prog,link"; then + compile_deplibs="$dir/$old_library $compile_deplibs" + finalize_deplibs="$dir/$old_library $finalize_deplibs" + else + deplibs="$lib $deplibs" # used for prog,scan pass + fi + continue + fi + + + if test "$linkmode" = prog && test "$pass" != link; then + newlib_search_path="$newlib_search_path $ladir" + deplibs="$lib $deplibs" + + linkalldeplibs=no + if test "$link_all_deplibs" != no || test -z "$library_names" || + test "$build_libtool_libs" = no; then + linkalldeplibs=yes + fi + + tmp_libs= + for deplib in $dependency_libs; do + case $deplib in + -L*) newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`;; ### testsuite: skip nested quoting test + esac + # Need to link against all dependency_libs? + if test "$linkalldeplibs" = yes; then + deplibs="$deplib $deplibs" + else + # Need to hardcode shared library paths + # or/and link against static libraries + newdependency_libs="$deplib $newdependency_libs" + fi + if test "X$duplicate_deps" = "Xyes" ; then + case "$tmp_libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac + fi + tmp_libs="$tmp_libs $deplib" + done # for deplib + continue + fi # $linkmode = prog... + + if test "$linkmode,$pass" = "prog,link"; then + if test -n "$library_names" && + { test "$prefer_static_libs" = no || test -z "$old_library"; }; then + # We need to hardcode the library path + if test -n "$shlibpath_var" && test -z "$avoidtemprpath" ; then + # Make sure the rpath contains only unique directories. + case "$temp_rpath " in + *" $dir "*) ;; + *" $absdir "*) ;; + *) temp_rpath="$temp_rpath $absdir" ;; + esac + fi + + # Hardcode the library path. + # Skip directories that are in the system default run-time + # search path. + case " $sys_lib_dlsearch_path " in + *" $absdir "*) ;; + *) + case "$compile_rpath " in + *" $absdir "*) ;; + *) compile_rpath="$compile_rpath $absdir" + esac + ;; + esac + case " $sys_lib_dlsearch_path " in + *" $libdir "*) ;; + *) + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" + esac + ;; + esac + fi # $linkmode,$pass = prog,link... + + if test "$alldeplibs" = yes && + { test "$deplibs_check_method" = pass_all || + { test "$build_libtool_libs" = yes && + test -n "$library_names"; }; }; then + # We only need to search for static libraries + continue + fi + fi + + link_static=no # Whether the deplib will be linked statically + if test -n "$library_names" && + { test "$prefer_static_libs" = no || test -z "$old_library"; }; then + if test "$installed" = no; then + notinst_deplibs="$notinst_deplibs $lib" + need_relink=yes + fi + # This is a shared library + + # Warn about portability, can't link against -module's on + # some systems (darwin) + if test "$shouldnotlink" = yes && test "$pass" = link ; then + $echo + if test "$linkmode" = prog; then + $echo "*** Warning: Linking the executable $output against the loadable module" + else + $echo "*** Warning: Linking the shared library $output against the loadable module" + fi + $echo "*** $linklib is not portable!" + fi + if test "$linkmode" = lib && + test "$hardcode_into_libs" = yes; then + # Hardcode the library path. + # Skip directories that are in the system default run-time + # search path. + case " $sys_lib_dlsearch_path " in + *" $absdir "*) ;; + *) + case "$compile_rpath " in + *" $absdir "*) ;; + *) compile_rpath="$compile_rpath $absdir" + esac + ;; + esac + case " $sys_lib_dlsearch_path " in + *" $libdir "*) ;; + *) + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" + esac + ;; + esac + fi + + if test -n "$old_archive_from_expsyms_cmds"; then + # figure out the soname + set dummy $library_names + realname="$2" + shift; shift + libname=`eval \\$echo \"$libname_spec\"` + # use dlname if we got it. it's perfectly good, no? + if test -n "$dlname"; then + soname="$dlname" + elif test -n "$soname_spec"; then + # bleh windows + case $host in + *cygwin* | mingw*) + major=`expr $current - $age` + versuffix="-$major" + ;; + esac + eval soname=\"$soname_spec\" + else + soname="$realname" + fi + + # Make a new name for the extract_expsyms_cmds to use + soroot="$soname" + soname=`$echo $soroot | ${SED} -e 's/^.*\///'` + newlib="libimp-`$echo $soname | ${SED} 's/^lib//;s/\.dll$//'`.a" + + # If the library has no export list, then create one now + if test -f "$output_objdir/$soname-def"; then : + else + $show "extracting exported symbol list from \`$soname'" + save_ifs="$IFS"; IFS='~' + cmds=$extract_expsyms_cmds + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" + fi + + # Create $newlib + if test -f "$output_objdir/$newlib"; then :; else + $show "generating import library for \`$soname'" + save_ifs="$IFS"; IFS='~' + cmds=$old_archive_from_expsyms_cmds + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" + fi + # make sure the library variables are pointing to the new library + dir=$output_objdir + linklib=$newlib + fi # test -n "$old_archive_from_expsyms_cmds" + + if test "$linkmode" = prog || test "$mode" != relink; then + add_shlibpath= + add_dir= + add= + lib_linked=yes + case $hardcode_action in + immediate | unsupported) + if test "$hardcode_direct" = no; then + add="$dir/$linklib" + case $host in + *-*-sco3.2v5* ) add_dir="-L$dir" ;; + *-*-darwin* ) + # if the lib is a module then we can not link against + # it, someone is ignoring the new warnings I added + if /usr/bin/file -L $add 2> /dev/null | $EGREP "bundle" >/dev/null ; then + $echo "** Warning, lib $linklib is a module, not a shared library" + if test -z "$old_library" ; then + $echo + $echo "** And there doesn't seem to be a static archive available" + $echo "** The link will probably fail, sorry" + else + add="$dir/$old_library" + fi + fi + esac + elif test "$hardcode_minus_L" = no; then + case $host in + *-*-sunos*) add_shlibpath="$dir" ;; + esac + add_dir="-L$dir" + add="-l$name" + elif test "$hardcode_shlibpath_var" = no; then + add_shlibpath="$dir" + add="-l$name" + else + lib_linked=no + fi + ;; + relink) + if test "$hardcode_direct" = yes; then + add="$dir/$linklib" + elif test "$hardcode_minus_L" = yes; then + add_dir="-L$dir" + # Try looking first in the location we're being installed to. + if test -n "$inst_prefix_dir"; then + case $libdir in + [\\/]*) + add_dir="$add_dir -L$inst_prefix_dir$libdir" + ;; + esac + fi + add="-l$name" + elif test "$hardcode_shlibpath_var" = yes; then + add_shlibpath="$dir" + add="-l$name" + else + lib_linked=no + fi + ;; + *) lib_linked=no ;; + esac + + if test "$lib_linked" != yes; then + $echo "$modename: configuration error: unsupported hardcode properties" + exit $EXIT_FAILURE + fi + + if test -n "$add_shlibpath"; then + case :$compile_shlibpath: in + *":$add_shlibpath:"*) ;; + *) compile_shlibpath="$compile_shlibpath$add_shlibpath:" ;; + esac + fi + if test "$linkmode" = prog; then + test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs" + test -n "$add" && compile_deplibs="$add $compile_deplibs" + else + test -n "$add_dir" && deplibs="$add_dir $deplibs" + test -n "$add" && deplibs="$add $deplibs" + if test "$hardcode_direct" != yes && \ + test "$hardcode_minus_L" != yes && \ + test "$hardcode_shlibpath_var" = yes; then + case :$finalize_shlibpath: in + *":$libdir:"*) ;; + *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;; + esac + fi + fi + fi + + if test "$linkmode" = prog || test "$mode" = relink; then + add_shlibpath= + add_dir= + add= + # Finalize command for both is simple: just hardcode it. + if test "$hardcode_direct" = yes; then + add="$libdir/$linklib" + elif test "$hardcode_minus_L" = yes; then + add_dir="-L$libdir" + add="-l$name" + elif test "$hardcode_shlibpath_var" = yes; then + case :$finalize_shlibpath: in + *":$libdir:"*) ;; + *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;; + esac + add="-l$name" + elif test "$hardcode_automatic" = yes; then + if test -n "$inst_prefix_dir" && + test -f "$inst_prefix_dir$libdir/$linklib" ; then + add="$inst_prefix_dir$libdir/$linklib" + else + add="$libdir/$linklib" + fi + else + # We cannot seem to hardcode it, guess we'll fake it. + add_dir="-L$libdir" + # Try looking first in the location we're being installed to. + if test -n "$inst_prefix_dir"; then + case $libdir in + [\\/]*) + add_dir="$add_dir -L$inst_prefix_dir$libdir" + ;; + esac + fi + add="-l$name" + fi + + if test "$linkmode" = prog; then + test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs" + test -n "$add" && finalize_deplibs="$add $finalize_deplibs" + else + test -n "$add_dir" && deplibs="$add_dir $deplibs" + test -n "$add" && deplibs="$add $deplibs" + fi + fi + elif test "$linkmode" = prog; then + # Here we assume that one of hardcode_direct or hardcode_minus_L + # is not unsupported. This is valid on all known static and + # shared platforms. + if test "$hardcode_direct" != unsupported; then + test -n "$old_library" && linklib="$old_library" + compile_deplibs="$dir/$linklib $compile_deplibs" + finalize_deplibs="$dir/$linklib $finalize_deplibs" + else + compile_deplibs="-l$name -L$dir $compile_deplibs" + finalize_deplibs="-l$name -L$dir $finalize_deplibs" + fi + elif test "$build_libtool_libs" = yes; then + # Not a shared library + if test "$deplibs_check_method" != pass_all; then + # We're trying link a shared library against a static one + # but the system doesn't support it. + + # Just print a warning and add the library to dependency_libs so + # that the program can be linked against the static library. + $echo + $echo "*** Warning: This system can not link to static lib archive $lib." + $echo "*** I have the capability to make that library automatically link in when" + $echo "*** you link to this library. But I can only do this if you have a" + $echo "*** shared version of the library, which you do not appear to have." + if test "$module" = yes; then + $echo "*** But as you try to build a module library, libtool will still create " + $echo "*** a static module, that should work as long as the dlopening application" + $echo "*** is linked with the -dlopen flag to resolve symbols at runtime." + if test -z "$global_symbol_pipe"; then + $echo + $echo "*** However, this would only work if libtool was able to extract symbol" + $echo "*** lists from a program, using \`nm' or equivalent, but libtool could" + $echo "*** not find such a program. So, this module is probably useless." + $echo "*** \`nm' from GNU binutils and a full rebuild may help." + fi + if test "$build_old_libs" = no; then + build_libtool_libs=module + build_old_libs=yes + else + build_libtool_libs=no + fi + fi + else + deplibs="$dir/$old_library $deplibs" + link_static=yes + fi + fi # link shared/static library? + + if test "$linkmode" = lib; then + if test -n "$dependency_libs" && + { test "$hardcode_into_libs" != yes || + test "$build_old_libs" = yes || + test "$link_static" = yes; }; then + # Extract -R from dependency_libs + temp_deplibs= + for libdir in $dependency_libs; do + case $libdir in + -R*) temp_xrpath=`$echo "X$libdir" | $Xsed -e 's/^-R//'` + case " $xrpath " in + *" $temp_xrpath "*) ;; + *) xrpath="$xrpath $temp_xrpath";; + esac;; + *) temp_deplibs="$temp_deplibs $libdir";; + esac + done + dependency_libs="$temp_deplibs" + fi + + newlib_search_path="$newlib_search_path $absdir" + # Link against this library + test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs" + # ... and its dependency_libs + tmp_libs= + for deplib in $dependency_libs; do + newdependency_libs="$deplib $newdependency_libs" + if test "X$duplicate_deps" = "Xyes" ; then + case "$tmp_libs " in + *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;; + esac + fi + tmp_libs="$tmp_libs $deplib" + done + + if test "$link_all_deplibs" != no; then + # Add the search paths of all dependency libraries + for deplib in $dependency_libs; do + case $deplib in + -L*) path="$deplib" ;; + *.la) + dir=`$echo "X$deplib" | $Xsed -e 's%/[^/]*$%%'` + test "X$dir" = "X$deplib" && dir="." + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) absdir="$dir" ;; + *) + absdir=`cd "$dir" && pwd` + if test -z "$absdir"; then + $echo "$modename: warning: cannot determine absolute directory name of \`$dir'" 1>&2 + absdir="$dir" + fi + ;; + esac + if grep "^installed=no" $deplib > /dev/null; then + path="$absdir/$objdir" + else + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` + if test -z "$libdir"; then + $echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2 + exit $EXIT_FAILURE + fi + if test "$absdir" != "$libdir"; then + $echo "$modename: warning: \`$deplib' seems to be moved" 1>&2 + fi + path="$absdir" + fi + depdepl= + case $host in + *-*-darwin*) + # we do not want to link against static libs, + # but need to link against shared + eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib` + if test -n "$deplibrary_names" ; then + for tmp in $deplibrary_names ; do + depdepl=$tmp + done + if test -f "$path/$depdepl" ; then + depdepl="$path/$depdepl" + fi + # do not add paths which are already there + case " $newlib_search_path " in + *" $path "*) ;; + *) newlib_search_path="$newlib_search_path $path";; + esac + fi + path="" + ;; + *) + path="-L$path" + ;; + esac + ;; + -l*) + case $host in + *-*-darwin*) + # Again, we only want to link against shared libraries + eval tmp_libs=`$echo "X$deplib" | $Xsed -e "s,^\-l,,"` + for tmp in $newlib_search_path ; do + if test -f "$tmp/lib$tmp_libs.dylib" ; then + eval depdepl="$tmp/lib$tmp_libs.dylib" + break + fi + done + path="" + ;; + *) continue ;; + esac + ;; + *) continue ;; + esac + case " $deplibs " in + *" $path "*) ;; + *) deplibs="$path $deplibs" ;; + esac + case " $deplibs " in + *" $depdepl "*) ;; + *) deplibs="$depdepl $deplibs" ;; + esac + done + fi # link_all_deplibs != no + fi # linkmode = lib + done # for deplib in $libs + dependency_libs="$newdependency_libs" + if test "$pass" = dlpreopen; then + # Link the dlpreopened libraries before other libraries + for deplib in $save_deplibs; do + deplibs="$deplib $deplibs" + done + fi + if test "$pass" != dlopen; then + if test "$pass" != conv; then + # Make sure lib_search_path contains only unique directories. + lib_search_path= + for dir in $newlib_search_path; do + case "$lib_search_path " in + *" $dir "*) ;; + *) lib_search_path="$lib_search_path $dir" ;; + esac + done + newlib_search_path= + fi + + if test "$linkmode,$pass" != "prog,link"; then + vars="deplibs" + else + vars="compile_deplibs finalize_deplibs" + fi + for var in $vars dependency_libs; do + # Add libraries to $var in reverse order + eval tmp_libs=\"\$$var\" + new_libs= + for deplib in $tmp_libs; do + # FIXME: Pedantically, this is the right thing to do, so + # that some nasty dependency loop isn't accidentally + # broken: + #new_libs="$deplib $new_libs" + # Pragmatically, this seems to cause very few problems in + # practice: + case $deplib in + -L*) new_libs="$deplib $new_libs" ;; + -R*) ;; + *) + # And here is the reason: when a library appears more + # than once as an explicit dependence of a library, or + # is implicitly linked in more than once by the + # compiler, it is considered special, and multiple + # occurrences thereof are not removed. Compare this + # with having the same library being listed as a + # dependency of multiple other libraries: in this case, + # we know (pedantically, we assume) the library does not + # need to be listed more than once, so we keep only the + # last copy. This is not always right, but it is rare + # enough that we require users that really mean to play + # such unportable linking tricks to link the library + # using -Wl,-lname, so that libtool does not consider it + # for duplicate removal. + case " $specialdeplibs " in + *" $deplib "*) new_libs="$deplib $new_libs" ;; + *) + case " $new_libs " in + *" $deplib "*) ;; + *) new_libs="$deplib $new_libs" ;; + esac + ;; + esac + ;; + esac + done + tmp_libs= + for deplib in $new_libs; do + case $deplib in + -L*) + case " $tmp_libs " in + *" $deplib "*) ;; + *) tmp_libs="$tmp_libs $deplib" ;; + esac + ;; + *) tmp_libs="$tmp_libs $deplib" ;; + esac + done + eval $var=\"$tmp_libs\" + done # for var + fi + # Last step: remove runtime libs from dependency_libs + # (they stay in deplibs) + tmp_libs= + for i in $dependency_libs ; do + case " $predeps $postdeps $compiler_lib_search_path " in + *" $i "*) + i="" + ;; + esac + if test -n "$i" ; then + tmp_libs="$tmp_libs $i" + fi + done + dependency_libs=$tmp_libs + done # for pass + if test "$linkmode" = prog; then + dlfiles="$newdlfiles" + dlprefiles="$newdlprefiles" + fi + + case $linkmode in + oldlib) + if test -n "$deplibs"; then + $echo "$modename: warning: \`-l' and \`-L' are ignored for archives" 1>&2 + fi + + if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then + $echo "$modename: warning: \`-dlopen' is ignored for archives" 1>&2 + fi + + if test -n "$rpath"; then + $echo "$modename: warning: \`-rpath' is ignored for archives" 1>&2 + fi + + if test -n "$xrpath"; then + $echo "$modename: warning: \`-R' is ignored for archives" 1>&2 + fi + + if test -n "$vinfo"; then + $echo "$modename: warning: \`-version-info/-version-number' is ignored for archives" 1>&2 + fi + + if test -n "$release"; then + $echo "$modename: warning: \`-release' is ignored for archives" 1>&2 + fi + + if test -n "$export_symbols" || test -n "$export_symbols_regex"; then + $echo "$modename: warning: \`-export-symbols' is ignored for archives" 1>&2 + fi + + # Now set the variables for building old libraries. + build_libtool_libs=no + oldlibs="$output" + objs="$objs$old_deplibs" + ;; + + lib) + # Make sure we only generate libraries of the form `libNAME.la'. + case $outputname in + lib*) + name=`$echo "X$outputname" | $Xsed -e 's/\.la$//' -e 's/^lib//'` + eval shared_ext=\"$shrext_cmds\" + eval libname=\"$libname_spec\" + ;; + *) + if test "$module" = no; then + $echo "$modename: libtool library \`$output' must begin with \`lib'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + if test "$need_lib_prefix" != no; then + # Add the "lib" prefix for modules if required + name=`$echo "X$outputname" | $Xsed -e 's/\.la$//'` + eval shared_ext=\"$shrext_cmds\" + eval libname=\"$libname_spec\" + else + libname=`$echo "X$outputname" | $Xsed -e 's/\.la$//'` + fi + ;; + esac + + if test -n "$objs"; then + if test "$deplibs_check_method" != pass_all; then + $echo "$modename: cannot build libtool library \`$output' from non-libtool objects on this host:$objs" 2>&1 + exit $EXIT_FAILURE + else + $echo + $echo "*** Warning: Linking the shared library $output against the non-libtool" + $echo "*** objects $objs is not portable!" + libobjs="$libobjs $objs" + fi + fi + + if test "$dlself" != no; then + $echo "$modename: warning: \`-dlopen self' is ignored for libtool libraries" 1>&2 + fi + + set dummy $rpath + if test "$#" -gt 2; then + $echo "$modename: warning: ignoring multiple \`-rpath's for a libtool library" 1>&2 + fi + install_libdir="$2" + + oldlibs= + if test -z "$rpath"; then + if test "$build_libtool_libs" = yes; then + # Building a libtool convenience library. + # Some compilers have problems with a `.al' extension so + # convenience libraries should have the same extension an + # archive normally would. + oldlibs="$output_objdir/$libname.$libext $oldlibs" + build_libtool_libs=convenience + build_old_libs=yes + fi + + if test -n "$vinfo"; then + $echo "$modename: warning: \`-version-info/-version-number' is ignored for convenience libraries" 1>&2 + fi + + if test -n "$release"; then + $echo "$modename: warning: \`-release' is ignored for convenience libraries" 1>&2 + fi + else + + # Parse the version information argument. + save_ifs="$IFS"; IFS=':' + set dummy $vinfo 0 0 0 + IFS="$save_ifs" + + if test -n "$8"; then + $echo "$modename: too many parameters to \`-version-info'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + + # convert absolute version numbers to libtool ages + # this retains compatibility with .la files and attempts + # to make the code below a bit more comprehensible + + case $vinfo_number in + yes) + number_major="$2" + number_minor="$3" + number_revision="$4" + # + # There are really only two kinds -- those that + # use the current revision as the major version + # and those that subtract age and use age as + # a minor version. But, then there is irix + # which has an extra 1 added just for fun + # + case $version_type in + darwin|linux|osf|windows) + current=`expr $number_major + $number_minor` + age="$number_minor" + revision="$number_revision" + ;; + freebsd-aout|freebsd-elf|sunos) + current="$number_major" + revision="$number_minor" + age="0" + ;; + irix|nonstopux) + current=`expr $number_major + $number_minor - 1` + age="$number_minor" + revision="$number_minor" + ;; + *) + $echo "$modename: unknown library version type \`$version_type'" 1>&2 + $echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2 + exit $EXIT_FAILURE + ;; + esac + ;; + no) + current="$2" + revision="$3" + age="$4" + ;; + esac + + # Check that each of the things are valid numbers. + case $current in + 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; + *) + $echo "$modename: CURRENT \`$current' must be a nonnegative integer" 1>&2 + $echo "$modename: \`$vinfo' is not valid version information" 1>&2 + exit $EXIT_FAILURE + ;; + esac + + case $revision in + 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; + *) + $echo "$modename: REVISION \`$revision' must be a nonnegative integer" 1>&2 + $echo "$modename: \`$vinfo' is not valid version information" 1>&2 + exit $EXIT_FAILURE + ;; + esac + + case $age in + 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; + *) + $echo "$modename: AGE \`$age' must be a nonnegative integer" 1>&2 + $echo "$modename: \`$vinfo' is not valid version information" 1>&2 + exit $EXIT_FAILURE + ;; + esac + + if test "$age" -gt "$current"; then + $echo "$modename: AGE \`$age' is greater than the current interface number \`$current'" 1>&2 + $echo "$modename: \`$vinfo' is not valid version information" 1>&2 + exit $EXIT_FAILURE + fi + + # Calculate the version variables. + major= + versuffix= + verstring= + case $version_type in + none) ;; + + darwin) + # Like Linux, but with the current version available in + # verstring for coding it into the library header + major=.`expr $current - $age` + versuffix="$major.$age.$revision" + # Darwin ld doesn't like 0 for these options... + minor_current=`expr $current + 1` + verstring="${wl}-compatibility_version ${wl}$minor_current ${wl}-current_version ${wl}$minor_current.$revision" + ;; + + freebsd-aout) + major=".$current" + versuffix=".$current.$revision"; + ;; + + freebsd-elf) + major=".$current" + versuffix=".$current"; + ;; + + irix | nonstopux) + major=`expr $current - $age + 1` + + case $version_type in + nonstopux) verstring_prefix=nonstopux ;; + *) verstring_prefix=sgi ;; + esac + verstring="$verstring_prefix$major.$revision" + + # Add in all the interfaces that we are compatible with. + loop=$revision + while test "$loop" -ne 0; do + iface=`expr $revision - $loop` + loop=`expr $loop - 1` + verstring="$verstring_prefix$major.$iface:$verstring" + done + + # Before this point, $major must not contain `.'. + major=.$major + versuffix="$major.$revision" + ;; + + linux) + major=.`expr $current - $age` + versuffix="$major.$age.$revision" + ;; + + osf) + major=.`expr $current - $age` + versuffix=".$current.$age.$revision" + verstring="$current.$age.$revision" + + # Add in all the interfaces that we are compatible with. + loop=$age + while test "$loop" -ne 0; do + iface=`expr $current - $loop` + loop=`expr $loop - 1` + verstring="$verstring:${iface}.0" + done + + # Make executables depend on our current version. + verstring="$verstring:${current}.0" + ;; + + sunos) + major=".$current" + versuffix=".$current.$revision" + ;; + + windows) + # Use '-' rather than '.', since we only want one + # extension on DOS 8.3 filesystems. + major=`expr $current - $age` + versuffix="-$major" + ;; + + *) + $echo "$modename: unknown library version type \`$version_type'" 1>&2 + $echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2 + exit $EXIT_FAILURE + ;; + esac + + # Clear the version info if we defaulted, and they specified a release. + if test -z "$vinfo" && test -n "$release"; then + major= + case $version_type in + darwin) + # we can't check for "0.0" in archive_cmds due to quoting + # problems, so we reset it completely + verstring= + ;; + *) + verstring="0.0" + ;; + esac + if test "$need_version" = no; then + versuffix= + else + versuffix=".0.0" + fi + fi + + # Remove version info from name if versioning should be avoided + if test "$avoid_version" = yes && test "$need_version" = no; then + major= + versuffix= + verstring="" + fi + + # Check to see if the archive will have undefined symbols. + if test "$allow_undefined" = yes; then + if test "$allow_undefined_flag" = unsupported; then + $echo "$modename: warning: undefined symbols not allowed in $host shared libraries" 1>&2 + build_libtool_libs=no + build_old_libs=yes + fi + else + # Don't allow undefined symbols. + allow_undefined_flag="$no_undefined_flag" + fi + fi + + if test "$mode" != relink; then + # Remove our outputs, but don't remove object files since they + # may have been created when compiling PIC objects. + removelist= + tempremovelist=`$echo "$output_objdir/*"` + for p in $tempremovelist; do + case $p in + *.$objext) + ;; + $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/${libname}${release}.*) + if test "X$precious_files_regex" != "X"; then + if echo $p | $EGREP -e "$precious_files_regex" >/dev/null 2>&1 + then + continue + fi + fi + removelist="$removelist $p" + ;; + *) ;; + esac + done + if test -n "$removelist"; then + $show "${rm}r $removelist" + $run ${rm}r $removelist + fi + fi + + # Now set the variables for building old libraries. + if test "$build_old_libs" = yes && test "$build_libtool_libs" != convenience ; then + oldlibs="$oldlibs $output_objdir/$libname.$libext" + + # Transform .lo files to .o files. + oldobjs="$objs "`$echo "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}'$/d' -e "$lo2o" | $NL2SP` + fi + + # Eliminate all temporary directories. + for path in $notinst_path; do + lib_search_path=`$echo "$lib_search_path " | ${SED} -e 's% $path % %g'` + deplibs=`$echo "$deplibs " | ${SED} -e 's% -L$path % %g'` + dependency_libs=`$echo "$dependency_libs " | ${SED} -e 's% -L$path % %g'` + done + + if test -n "$xrpath"; then + # If the user specified any rpath flags, then add them. + temp_xrpath= + for libdir in $xrpath; do + temp_xrpath="$temp_xrpath -R$libdir" + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" ;; + esac + done + if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then + dependency_libs="$temp_xrpath $dependency_libs" + fi + fi + + # Make sure dlfiles contains only unique files that won't be dlpreopened + old_dlfiles="$dlfiles" + dlfiles= + for lib in $old_dlfiles; do + case " $dlprefiles $dlfiles " in + *" $lib "*) ;; + *) dlfiles="$dlfiles $lib" ;; + esac + done + + # Make sure dlprefiles contains only unique files + old_dlprefiles="$dlprefiles" + dlprefiles= + for lib in $old_dlprefiles; do + case "$dlprefiles " in + *" $lib "*) ;; + *) dlprefiles="$dlprefiles $lib" ;; + esac + done + + if test "$build_libtool_libs" = yes; then + if test -n "$rpath"; then + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos*) + # these systems don't actually have a c library (as such)! + ;; + *-*-rhapsody* | *-*-darwin1.[012]) + # Rhapsody C library is in the System framework + deplibs="$deplibs -framework System" + ;; + *-*-netbsd*) + # Don't link with libc until the a.out ld.so is fixed. + ;; + *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) + # Do not include libc due to us having libc/libc_r. + test "X$arg" = "X-lc" && continue + ;; + *) + # Add libc to deplibs on all other systems if necessary. + if test "$build_libtool_need_lc" = "yes"; then + deplibs="$deplibs -lc" + fi + ;; + esac + fi + + # Transform deplibs into only deplibs that can be linked in shared. + name_save=$name + libname_save=$libname + release_save=$release + versuffix_save=$versuffix + major_save=$major + # I'm not sure if I'm treating the release correctly. I think + # release should show up in the -l (ie -lgmp5) so we don't want to + # add it in twice. Is that correct? + release="" + versuffix="" + major="" + newdeplibs= + droppeddeps=no + case $deplibs_check_method in + pass_all) + # Don't check for shared/static. Everything works. + # This might be a little naive. We might want to check + # whether the library exists or not. But this is on + # osf3 & osf4 and I'm not really sure... Just + # implementing what was already the behavior. + newdeplibs=$deplibs + ;; + test_compile) + # This code stresses the "libraries are programs" paradigm to its + # limits. Maybe even breaks it. We compile a program, linking it + # against the deplibs as a proxy for the library. Then we can check + # whether they linked in statically or dynamically with ldd. + $rm conftest.c + cat > conftest.c </dev/null` + for potent_lib in $potential_libs; do + # Follow soft links. + if ls -lLd "$potent_lib" 2>/dev/null \ + | grep " -> " >/dev/null; then + continue + fi + # The statement above tries to avoid entering an + # endless loop below, in case of cyclic links. + # We might still enter an endless loop, since a link + # loop can be closed while we follow links, + # but so what? + potlib="$potent_lib" + while test -h "$potlib" 2>/dev/null; do + potliblink=`ls -ld $potlib | ${SED} 's/.* -> //'` + case $potliblink in + [\\/]* | [A-Za-z]:[\\/]*) potlib="$potliblink";; + *) potlib=`$echo "X$potlib" | $Xsed -e 's,[^/]*$,,'`"$potliblink";; + esac + done + if eval $file_magic_cmd \"\$potlib\" 2>/dev/null \ + | ${SED} 10q \ + | $EGREP "$file_magic_regex" > /dev/null; then + newdeplibs="$newdeplibs $a_deplib" + a_deplib="" + break 2 + fi + done + done + fi + if test -n "$a_deplib" ; then + droppeddeps=yes + $echo + $echo "*** Warning: linker path does not have real file for library $a_deplib." + $echo "*** I have the capability to make that library automatically link in when" + $echo "*** you link to this library. But I can only do this if you have a" + $echo "*** shared version of the library, which you do not appear to have" + $echo "*** because I did check the linker path looking for a file starting" + if test -z "$potlib" ; then + $echo "*** with $libname but no candidates were found. (...for file magic test)" + else + $echo "*** with $libname and none of the candidates passed a file format test" + $echo "*** using a file magic. Last file checked: $potlib" + fi + fi + else + # Add a -L argument. + newdeplibs="$newdeplibs $a_deplib" + fi + done # Gone through all deplibs. + ;; + match_pattern*) + set dummy $deplibs_check_method + match_pattern_regex=`expr "$deplibs_check_method" : "$2 \(.*\)"` + for a_deplib in $deplibs; do + name=`expr $a_deplib : '-l\(.*\)'` + # If $name is empty we are operating on a -L argument. + if test -n "$name" && test "$name" != "0"; then + if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then + case " $predeps $postdeps " in + *" $a_deplib "*) + newdeplibs="$newdeplibs $a_deplib" + a_deplib="" + ;; + esac + fi + if test -n "$a_deplib" ; then + libname=`eval \\$echo \"$libname_spec\"` + for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do + potential_libs=`ls $i/$libname[.-]* 2>/dev/null` + for potent_lib in $potential_libs; do + potlib="$potent_lib" # see symlink-check above in file_magic test + if eval $echo \"$potent_lib\" 2>/dev/null \ + | ${SED} 10q \ + | $EGREP "$match_pattern_regex" > /dev/null; then + newdeplibs="$newdeplibs $a_deplib" + a_deplib="" + break 2 + fi + done + done + fi + if test -n "$a_deplib" ; then + droppeddeps=yes + $echo + $echo "*** Warning: linker path does not have real file for library $a_deplib." + $echo "*** I have the capability to make that library automatically link in when" + $echo "*** you link to this library. But I can only do this if you have a" + $echo "*** shared version of the library, which you do not appear to have" + $echo "*** because I did check the linker path looking for a file starting" + if test -z "$potlib" ; then + $echo "*** with $libname but no candidates were found. (...for regex pattern test)" + else + $echo "*** with $libname and none of the candidates passed a file format test" + $echo "*** using a regex pattern. Last file checked: $potlib" + fi + fi + else + # Add a -L argument. + newdeplibs="$newdeplibs $a_deplib" + fi + done # Gone through all deplibs. + ;; + none | unknown | *) + newdeplibs="" + tmp_deplibs=`$echo "X $deplibs" | $Xsed -e 's/ -lc$//' \ + -e 's/ -[LR][^ ]*//g'` + if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then + for i in $predeps $postdeps ; do + # can't use Xsed below, because $i might contain '/' + tmp_deplibs=`$echo "X $tmp_deplibs" | ${SED} -e "1s,^X,," -e "s,$i,,"` + done + fi + if $echo "X $tmp_deplibs" | $Xsed -e 's/[ ]//g' \ + | grep . >/dev/null; then + $echo + if test "X$deplibs_check_method" = "Xnone"; then + $echo "*** Warning: inter-library dependencies are not supported in this platform." + else + $echo "*** Warning: inter-library dependencies are not known to be supported." + fi + $echo "*** All declared inter-library dependencies are being dropped." + droppeddeps=yes + fi + ;; + esac + versuffix=$versuffix_save + major=$major_save + release=$release_save + libname=$libname_save + name=$name_save + + case $host in + *-*-rhapsody* | *-*-darwin1.[012]) + # On Rhapsody replace the C library is the System framework + newdeplibs=`$echo "X $newdeplibs" | $Xsed -e 's/ -lc / -framework System /'` + ;; + esac + + if test "$droppeddeps" = yes; then + if test "$module" = yes; then + $echo + $echo "*** Warning: libtool could not satisfy all declared inter-library" + $echo "*** dependencies of module $libname. Therefore, libtool will create" + $echo "*** a static module, that should work as long as the dlopening" + $echo "*** application is linked with the -dlopen flag." + if test -z "$global_symbol_pipe"; then + $echo + $echo "*** However, this would only work if libtool was able to extract symbol" + $echo "*** lists from a program, using \`nm' or equivalent, but libtool could" + $echo "*** not find such a program. So, this module is probably useless." + $echo "*** \`nm' from GNU binutils and a full rebuild may help." + fi + if test "$build_old_libs" = no; then + oldlibs="$output_objdir/$libname.$libext" + build_libtool_libs=module + build_old_libs=yes + else + build_libtool_libs=no + fi + else + $echo "*** The inter-library dependencies that have been dropped here will be" + $echo "*** automatically added whenever a program is linked with this library" + $echo "*** or is declared to -dlopen it." + + if test "$allow_undefined" = no; then + $echo + $echo "*** Since this library must not contain undefined symbols," + $echo "*** because either the platform does not support them or" + $echo "*** it was explicitly requested with -no-undefined," + $echo "*** libtool will only create a static version of it." + if test "$build_old_libs" = no; then + oldlibs="$output_objdir/$libname.$libext" + build_libtool_libs=module + build_old_libs=yes + else + build_libtool_libs=no + fi + fi + fi + fi + # Done checking deplibs! + deplibs=$newdeplibs + fi + + # All the library-specific variables (install_libdir is set above). + library_names= + old_library= + dlname= + + # Test again, we may have decided not to build it any more + if test "$build_libtool_libs" = yes; then + if test "$hardcode_into_libs" = yes; then + # Hardcode the library paths + hardcode_libdirs= + dep_rpath= + rpath="$finalize_rpath" + test "$mode" != relink && rpath="$compile_rpath$rpath" + for libdir in $rpath; do + if test -n "$hardcode_libdir_flag_spec"; then + if test -n "$hardcode_libdir_separator"; then + if test -z "$hardcode_libdirs"; then + hardcode_libdirs="$libdir" + else + # Just accumulate the unique libdirs. + case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in + *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) + ;; + *) + hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" + ;; + esac + fi + else + eval flag=\"$hardcode_libdir_flag_spec\" + dep_rpath="$dep_rpath $flag" + fi + elif test -n "$runpath_var"; then + case "$perm_rpath " in + *" $libdir "*) ;; + *) perm_rpath="$perm_rpath $libdir" ;; + esac + fi + done + # Substitute the hardcoded libdirs into the rpath. + if test -n "$hardcode_libdir_separator" && + test -n "$hardcode_libdirs"; then + libdir="$hardcode_libdirs" + if test -n "$hardcode_libdir_flag_spec_ld"; then + eval dep_rpath=\"$hardcode_libdir_flag_spec_ld\" + else + eval dep_rpath=\"$hardcode_libdir_flag_spec\" + fi + fi + if test -n "$runpath_var" && test -n "$perm_rpath"; then + # We should set the runpath_var. + rpath= + for dir in $perm_rpath; do + rpath="$rpath$dir:" + done + eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var" + fi + test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs" + fi + + shlibpath="$finalize_shlibpath" + test "$mode" != relink && shlibpath="$compile_shlibpath$shlibpath" + if test -n "$shlibpath"; then + eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var" + fi + + # Get the real and link names of the library. + eval shared_ext=\"$shrext_cmds\" + eval library_names=\"$library_names_spec\" + set dummy $library_names + realname="$2" + shift; shift + + if test -n "$soname_spec"; then + eval soname=\"$soname_spec\" + else + soname="$realname" + fi + if test -z "$dlname"; then + dlname=$soname + fi + + lib="$output_objdir/$realname" + for link + do + linknames="$linknames $link" + done + + # Use standard objects if they are pic + test -z "$pic_flag" && libobjs=`$echo "X$libobjs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` + + # Prepare the list of exported symbols + if test -z "$export_symbols"; then + if test "$always_export_symbols" = yes || test -n "$export_symbols_regex"; then + $show "generating symbol list for \`$libname.la'" + export_symbols="$output_objdir/$libname.exp" + $run $rm $export_symbols + cmds=$export_symbols_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + if len=`expr "X$cmd" : ".*"` && + test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then + $show "$cmd" + $run eval "$cmd" || exit $? + skipped_export=false + else + # The command line is too long to execute in one step. + $show "using reloadable object file for export list..." + skipped_export=: + # Break out early, otherwise skipped_export may be + # set to false by a later but shorter cmd. + break + fi + done + IFS="$save_ifs" + if test -n "$export_symbols_regex"; then + $show "$EGREP -e \"$export_symbols_regex\" \"$export_symbols\" > \"${export_symbols}T\"" + $run eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' + $show "$mv \"${export_symbols}T\" \"$export_symbols\"" + $run eval '$mv "${export_symbols}T" "$export_symbols"' + fi + fi + fi + + if test -n "$export_symbols" && test -n "$include_expsyms"; then + $run eval '$echo "X$include_expsyms" | $SP2NL >> "$export_symbols"' + fi + + tmp_deplibs= + for test_deplib in $deplibs; do + case " $convenience " in + *" $test_deplib "*) ;; + *) + tmp_deplibs="$tmp_deplibs $test_deplib" + ;; + esac + done + deplibs="$tmp_deplibs" + + if test -n "$convenience"; then + if test -n "$whole_archive_flag_spec"; then + save_libobjs=$libobjs + eval libobjs=\"\$libobjs $whole_archive_flag_spec\" + else + gentop="$output_objdir/${outputname}x" + generated="$generated $gentop" + + func_extract_archives $gentop $convenience + libobjs="$libobjs $func_extract_archives_result" + fi + fi + + if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then + eval flag=\"$thread_safe_flag_spec\" + linker_flags="$linker_flags $flag" + fi + + # Make a backup of the uninstalled library when relinking + if test "$mode" = relink; then + $run eval '(cd $output_objdir && $rm ${realname}U && $mv $realname ${realname}U)' || exit $? + fi + + # Do each of the archive commands. + if test "$module" = yes && test -n "$module_cmds" ; then + if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then + eval test_cmds=\"$module_expsym_cmds\" + cmds=$module_expsym_cmds + else + eval test_cmds=\"$module_cmds\" + cmds=$module_cmds + fi + else + if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then + eval test_cmds=\"$archive_expsym_cmds\" + cmds=$archive_expsym_cmds + else + eval test_cmds=\"$archive_cmds\" + cmds=$archive_cmds + fi + fi + + if test "X$skipped_export" != "X:" && + len=`expr "X$test_cmds" : ".*" 2>/dev/null` && + test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then + : + else + # The command line is too long to link in one step, link piecewise. + $echo "creating reloadable object files..." + + # Save the value of $output and $libobjs because we want to + # use them later. If we have whole_archive_flag_spec, we + # want to use save_libobjs as it was before + # whole_archive_flag_spec was expanded, because we can't + # assume the linker understands whole_archive_flag_spec. + # This may have to be revisited, in case too many + # convenience libraries get linked in and end up exceeding + # the spec. + if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then + save_libobjs=$libobjs + fi + save_output=$output + output_la=`$echo "X$output" | $Xsed -e "$basename"` + + # Clear the reloadable object creation command queue and + # initialize k to one. + test_cmds= + concat_cmds= + objlist= + delfiles= + last_robj= + k=1 + output=$output_objdir/$output_la-${k}.$objext + # Loop over the list of objects to be linked. + for obj in $save_libobjs + do + eval test_cmds=\"$reload_cmds $objlist $last_robj\" + if test "X$objlist" = X || + { len=`expr "X$test_cmds" : ".*" 2>/dev/null` && + test "$len" -le "$max_cmd_len"; }; then + objlist="$objlist $obj" + else + # The command $test_cmds is almost too long, add a + # command to the queue. + if test "$k" -eq 1 ; then + # The first file doesn't have a previous command to add. + eval concat_cmds=\"$reload_cmds $objlist $last_robj\" + else + # All subsequent reloadable object files will link in + # the last one created. + eval concat_cmds=\"\$concat_cmds~$reload_cmds $objlist $last_robj\" + fi + last_robj=$output_objdir/$output_la-${k}.$objext + k=`expr $k + 1` + output=$output_objdir/$output_la-${k}.$objext + objlist=$obj + len=1 + fi + done + # Handle the remaining objects by creating one last + # reloadable object file. All subsequent reloadable object + # files will link in the last one created. + test -z "$concat_cmds" || concat_cmds=$concat_cmds~ + eval concat_cmds=\"\${concat_cmds}$reload_cmds $objlist $last_robj\" + + if ${skipped_export-false}; then + $show "generating symbol list for \`$libname.la'" + export_symbols="$output_objdir/$libname.exp" + $run $rm $export_symbols + libobjs=$output + # Append the command to create the export file. + eval concat_cmds=\"\$concat_cmds~$export_symbols_cmds\" + fi + + # Set up a command to remove the reloadable object files + # after they are used. + i=0 + while test "$i" -lt "$k" + do + i=`expr $i + 1` + delfiles="$delfiles $output_objdir/$output_la-${i}.$objext" + done + + $echo "creating a temporary reloadable object file: $output" + + # Loop through the commands generated above and execute them. + save_ifs="$IFS"; IFS='~' + for cmd in $concat_cmds; do + IFS="$save_ifs" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" + + libobjs=$output + # Restore the value of output. + output=$save_output + + if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then + eval libobjs=\"\$libobjs $whole_archive_flag_spec\" + fi + # Expand the library linking commands again to reset the + # value of $libobjs for piecewise linking. + + # Do each of the archive commands. + if test "$module" = yes && test -n "$module_cmds" ; then + if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then + cmds=$module_expsym_cmds + else + cmds=$module_cmds + fi + else + if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then + cmds=$archive_expsym_cmds + else + cmds=$archive_cmds + fi + fi + + # Append the command to remove the reloadable object files + # to the just-reset $cmds. + eval cmds=\"\$cmds~\$rm $delfiles\" + fi + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || { + lt_exit=$? + + # Restore the uninstalled library and exit + if test "$mode" = relink; then + $run eval '(cd $output_objdir && $rm ${realname}T && $mv ${realname}U $realname)' + fi + + exit $lt_exit + } + done + IFS="$save_ifs" + + # Restore the uninstalled library and exit + if test "$mode" = relink; then + $run eval '(cd $output_objdir && $rm ${realname}T && $mv $realname ${realname}T && $mv "$realname"U $realname)' || exit $? + + if test -n "$convenience"; then + if test -z "$whole_archive_flag_spec"; then + $show "${rm}r $gentop" + $run ${rm}r "$gentop" + fi + fi + + exit $EXIT_SUCCESS + fi + + # Create links to the real library. + for linkname in $linknames; do + if test "$realname" != "$linkname"; then + $show "(cd $output_objdir && $rm $linkname && $LN_S $realname $linkname)" + $run eval '(cd $output_objdir && $rm $linkname && $LN_S $realname $linkname)' || exit $? + fi + done + + # If -module or -export-dynamic was specified, set the dlname. + if test "$module" = yes || test "$export_dynamic" = yes; then + # On all known operating systems, these are identical. + dlname="$soname" + fi + fi + ;; + + obj) + if test -n "$deplibs"; then + $echo "$modename: warning: \`-l' and \`-L' are ignored for objects" 1>&2 + fi + + if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then + $echo "$modename: warning: \`-dlopen' is ignored for objects" 1>&2 + fi + + if test -n "$rpath"; then + $echo "$modename: warning: \`-rpath' is ignored for objects" 1>&2 + fi + + if test -n "$xrpath"; then + $echo "$modename: warning: \`-R' is ignored for objects" 1>&2 + fi + + if test -n "$vinfo"; then + $echo "$modename: warning: \`-version-info' is ignored for objects" 1>&2 + fi + + if test -n "$release"; then + $echo "$modename: warning: \`-release' is ignored for objects" 1>&2 + fi + + case $output in + *.lo) + if test -n "$objs$old_deplibs"; then + $echo "$modename: cannot build library object \`$output' from non-libtool objects" 1>&2 + exit $EXIT_FAILURE + fi + libobj="$output" + obj=`$echo "X$output" | $Xsed -e "$lo2o"` + ;; + *) + libobj= + obj="$output" + ;; + esac + + # Delete the old objects. + $run $rm $obj $libobj + + # Objects from convenience libraries. This assumes + # single-version convenience libraries. Whenever we create + # different ones for PIC/non-PIC, this we'll have to duplicate + # the extraction. + reload_conv_objs= + gentop= + # reload_cmds runs $LD directly, so let us get rid of + # -Wl from whole_archive_flag_spec + wl= + + if test -n "$convenience"; then + if test -n "$whole_archive_flag_spec"; then + eval reload_conv_objs=\"\$reload_objs $whole_archive_flag_spec\" + else + gentop="$output_objdir/${obj}x" + generated="$generated $gentop" + + func_extract_archives $gentop $convenience + reload_conv_objs="$reload_objs $func_extract_archives_result" + fi + fi + + # Create the old-style object. + reload_objs="$objs$old_deplibs "`$echo "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}$'/d' -e '/\.lib$/d' -e "$lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test + + output="$obj" + cmds=$reload_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" + + # Exit if we aren't doing a library object file. + if test -z "$libobj"; then + if test -n "$gentop"; then + $show "${rm}r $gentop" + $run ${rm}r $gentop + fi + + exit $EXIT_SUCCESS + fi + + if test "$build_libtool_libs" != yes; then + if test -n "$gentop"; then + $show "${rm}r $gentop" + $run ${rm}r $gentop + fi + + # Create an invalid libtool object if no PIC, so that we don't + # accidentally link it into a program. + # $show "echo timestamp > $libobj" + # $run eval "echo timestamp > $libobj" || exit $? + exit $EXIT_SUCCESS + fi + + if test -n "$pic_flag" || test "$pic_mode" != default; then + # Only do commands if we really have different PIC objects. + reload_objs="$libobjs $reload_conv_objs" + output="$libobj" + cmds=$reload_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" + fi + + if test -n "$gentop"; then + $show "${rm}r $gentop" + $run ${rm}r $gentop + fi + + exit $EXIT_SUCCESS + ;; + + prog) + case $host in + *cygwin*) output=`$echo $output | ${SED} -e 's,.exe$,,;s,$,.exe,'` ;; + esac + if test -n "$vinfo"; then + $echo "$modename: warning: \`-version-info' is ignored for programs" 1>&2 + fi + + if test -n "$release"; then + $echo "$modename: warning: \`-release' is ignored for programs" 1>&2 + fi + + if test "$preload" = yes; then + if test "$dlopen_support" = unknown && test "$dlopen_self" = unknown && + test "$dlopen_self_static" = unknown; then + $echo "$modename: warning: \`AC_LIBTOOL_DLOPEN' not used. Assuming no dlopen support." + fi + fi + + case $host in + *-*-rhapsody* | *-*-darwin1.[012]) + # On Rhapsody replace the C library is the System framework + compile_deplibs=`$echo "X $compile_deplibs" | $Xsed -e 's/ -lc / -framework System /'` + finalize_deplibs=`$echo "X $finalize_deplibs" | $Xsed -e 's/ -lc / -framework System /'` + ;; + esac + + case $host in + *darwin*) + # Don't allow lazy linking, it breaks C++ global constructors + if test "$tagname" = CXX ; then + compile_command="$compile_command ${wl}-bind_at_load" + finalize_command="$finalize_command ${wl}-bind_at_load" + fi + ;; + esac + + compile_command="$compile_command $compile_deplibs" + finalize_command="$finalize_command $finalize_deplibs" + + if test -n "$rpath$xrpath"; then + # If the user specified any rpath flags, then add them. + for libdir in $rpath $xrpath; do + # This is the magic to use -rpath. + case "$finalize_rpath " in + *" $libdir "*) ;; + *) finalize_rpath="$finalize_rpath $libdir" ;; + esac + done + fi + + # Now hardcode the library paths + rpath= + hardcode_libdirs= + for libdir in $compile_rpath $finalize_rpath; do + if test -n "$hardcode_libdir_flag_spec"; then + if test -n "$hardcode_libdir_separator"; then + if test -z "$hardcode_libdirs"; then + hardcode_libdirs="$libdir" + else + # Just accumulate the unique libdirs. + case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in + *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) + ;; + *) + hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" + ;; + esac + fi + else + eval flag=\"$hardcode_libdir_flag_spec\" + rpath="$rpath $flag" + fi + elif test -n "$runpath_var"; then + case "$perm_rpath " in + *" $libdir "*) ;; + *) perm_rpath="$perm_rpath $libdir" ;; + esac + fi + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*) + case :$dllsearchpath: in + *":$libdir:"*) ;; + *) dllsearchpath="$dllsearchpath:$libdir";; + esac + ;; + esac + done + # Substitute the hardcoded libdirs into the rpath. + if test -n "$hardcode_libdir_separator" && + test -n "$hardcode_libdirs"; then + libdir="$hardcode_libdirs" + eval rpath=\" $hardcode_libdir_flag_spec\" + fi + compile_rpath="$rpath" + + rpath= + hardcode_libdirs= + for libdir in $finalize_rpath; do + if test -n "$hardcode_libdir_flag_spec"; then + if test -n "$hardcode_libdir_separator"; then + if test -z "$hardcode_libdirs"; then + hardcode_libdirs="$libdir" + else + # Just accumulate the unique libdirs. + case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in + *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) + ;; + *) + hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir" + ;; + esac + fi + else + eval flag=\"$hardcode_libdir_flag_spec\" + rpath="$rpath $flag" + fi + elif test -n "$runpath_var"; then + case "$finalize_perm_rpath " in + *" $libdir "*) ;; + *) finalize_perm_rpath="$finalize_perm_rpath $libdir" ;; + esac + fi + done + # Substitute the hardcoded libdirs into the rpath. + if test -n "$hardcode_libdir_separator" && + test -n "$hardcode_libdirs"; then + libdir="$hardcode_libdirs" + eval rpath=\" $hardcode_libdir_flag_spec\" + fi + finalize_rpath="$rpath" + + if test -n "$libobjs" && test "$build_old_libs" = yes; then + # Transform all the library objects into standard objects. + compile_command=`$echo "X$compile_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` + finalize_command=`$echo "X$finalize_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` + fi + + dlsyms= + if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then + if test -n "$NM" && test -n "$global_symbol_pipe"; then + dlsyms="${outputname}S.c" + else + $echo "$modename: not configured to extract global symbols from dlpreopened files" 1>&2 + fi + fi + + if test -n "$dlsyms"; then + case $dlsyms in + "") ;; + *.c) + # Discover the nlist of each of the dlfiles. + nlist="$output_objdir/${outputname}.nm" + + $show "$rm $nlist ${nlist}S ${nlist}T" + $run $rm "$nlist" "${nlist}S" "${nlist}T" + + # Parse the name list into a source file. + $show "creating $output_objdir/$dlsyms" + + test -z "$run" && $echo > "$output_objdir/$dlsyms" "\ +/* $dlsyms - symbol resolution table for \`$outputname' dlsym emulation. */ +/* Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP */ + +#ifdef __cplusplus +extern \"C\" { +#endif + +/* Prevent the only kind of declaration conflicts we can make. */ +#define lt_preloaded_symbols some_other_symbol + +/* External symbol declarations for the compiler. */\ +" + + if test "$dlself" = yes; then + $show "generating symbol list for \`$output'" + + test -z "$run" && $echo ': @PROGRAM@ ' > "$nlist" + + # Add our own program objects to the symbol list. + progfiles=`$echo "X$objs$old_deplibs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP` + for arg in $progfiles; do + $show "extracting global C symbols from \`$arg'" + $run eval "$NM $arg | $global_symbol_pipe >> '$nlist'" + done + + if test -n "$exclude_expsyms"; then + $run eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T' + $run eval '$mv "$nlist"T "$nlist"' + fi + + if test -n "$export_symbols_regex"; then + $run eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T' + $run eval '$mv "$nlist"T "$nlist"' + fi + + # Prepare the list of exported symbols + if test -z "$export_symbols"; then + export_symbols="$output_objdir/$outputname.exp" + $run $rm $export_symbols + $run eval "${SED} -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"' + else + $run eval "${SED} -e 's/\([ ][.*^$]\)/\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"' + $run eval 'grep -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T' + $run eval 'mv "$nlist"T "$nlist"' + fi + fi + + for arg in $dlprefiles; do + $show "extracting global C symbols from \`$arg'" + name=`$echo "$arg" | ${SED} -e 's%^.*/%%'` + $run eval '$echo ": $name " >> "$nlist"' + $run eval "$NM $arg | $global_symbol_pipe >> '$nlist'" + done + + if test -z "$run"; then + # Make sure we have at least an empty file. + test -f "$nlist" || : > "$nlist" + + if test -n "$exclude_expsyms"; then + $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T + $mv "$nlist"T "$nlist" + fi + + # Try sorting and uniquifying the output. + if grep -v "^: " < "$nlist" | + if sort -k 3 /dev/null 2>&1; then + sort -k 3 + else + sort +2 + fi | + uniq > "$nlist"S; then + : + else + grep -v "^: " < "$nlist" > "$nlist"S + fi + + if test -f "$nlist"S; then + eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$dlsyms"' + else + $echo '/* NONE */' >> "$output_objdir/$dlsyms" + fi + + $echo >> "$output_objdir/$dlsyms" "\ + +#undef lt_preloaded_symbols + +#if defined (__STDC__) && __STDC__ +# define lt_ptr void * +#else +# define lt_ptr char * +# define const +#endif + +/* The mapping between symbol names and symbols. */ +" + + case $host in + *cygwin* | *mingw* ) + $echo >> "$output_objdir/$dlsyms" "\ +/* DATA imports from DLLs on WIN32 can't be const, because + runtime relocations are performed -- see ld's documentation + on pseudo-relocs */ +struct { +" + ;; + * ) + $echo >> "$output_objdir/$dlsyms" "\ +const struct { +" + ;; + esac + + + $echo >> "$output_objdir/$dlsyms" "\ + const char *name; + lt_ptr address; +} +lt_preloaded_symbols[] = +{\ +" + + eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$dlsyms" + + $echo >> "$output_objdir/$dlsyms" "\ + {0, (lt_ptr) 0} +}; + +/* This works around a problem in FreeBSD linker */ +#ifdef FREEBSD_WORKAROUND +static const void *lt_preloaded_setup() { + return lt_preloaded_symbols; +} +#endif + +#ifdef __cplusplus +} +#endif\ +" + fi + + pic_flag_for_symtable= + case $host in + # compiling the symbol table file with pic_flag works around + # a FreeBSD bug that causes programs to crash when -lm is + # linked before any other PIC object. But we must not use + # pic_flag when linking with -static. The problem exists in + # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1. + *-*-freebsd2*|*-*-freebsd3.0*|*-*-freebsdelf3.0*) + case "$compile_command " in + *" -static "*) ;; + *) pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND";; + esac;; + *-*-hpux*) + case "$compile_command " in + *" -static "*) ;; + *) pic_flag_for_symtable=" $pic_flag";; + esac + esac + + # Now compile the dynamic symbol file. + $show "(cd $output_objdir && $LTCC -c$no_builtin_flag$pic_flag_for_symtable \"$dlsyms\")" + $run eval '(cd $output_objdir && $LTCC -c$no_builtin_flag$pic_flag_for_symtable "$dlsyms")' || exit $? + + # Clean up the generated files. + $show "$rm $output_objdir/$dlsyms $nlist ${nlist}S ${nlist}T" + $run $rm "$output_objdir/$dlsyms" "$nlist" "${nlist}S" "${nlist}T" + + # Transform the symbol file into the correct name. + compile_command=`$echo "X$compile_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%"` + finalize_command=`$echo "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%"` + ;; + *) + $echo "$modename: unknown suffix for \`$dlsyms'" 1>&2 + exit $EXIT_FAILURE + ;; + esac + else + # We keep going just in case the user didn't refer to + # lt_preloaded_symbols. The linker will fail if global_symbol_pipe + # really was required. + + # Nullify the symbol file. + compile_command=`$echo "X$compile_command" | $Xsed -e "s% @SYMFILE@%%"` + finalize_command=`$echo "X$finalize_command" | $Xsed -e "s% @SYMFILE@%%"` + fi + + if test "$need_relink" = no || test "$build_libtool_libs" != yes; then + # Replace the output file specification. + compile_command=`$echo "X$compile_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'` + link_command="$compile_command$compile_rpath" + + # We have no uninstalled library dependencies, so finalize right now. + $show "$link_command" + $run eval "$link_command" + status=$? + + # Delete the generated files. + if test -n "$dlsyms"; then + $show "$rm $output_objdir/${outputname}S.${objext}" + $run $rm "$output_objdir/${outputname}S.${objext}" + fi + + exit $status + fi + + if test -n "$shlibpath_var"; then + # We should set the shlibpath_var + rpath= + for dir in $temp_rpath; do + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) + # Absolute path. + rpath="$rpath$dir:" + ;; + *) + # Relative path: add a thisdir entry. + rpath="$rpath\$thisdir/$dir:" + ;; + esac + done + temp_rpath="$rpath" + fi + + if test -n "$compile_shlibpath$finalize_shlibpath"; then + compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command" + fi + if test -n "$finalize_shlibpath"; then + finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command" + fi + + compile_var= + finalize_var= + if test -n "$runpath_var"; then + if test -n "$perm_rpath"; then + # We should set the runpath_var. + rpath= + for dir in $perm_rpath; do + rpath="$rpath$dir:" + done + compile_var="$runpath_var=\"$rpath\$$runpath_var\" " + fi + if test -n "$finalize_perm_rpath"; then + # We should set the runpath_var. + rpath= + for dir in $finalize_perm_rpath; do + rpath="$rpath$dir:" + done + finalize_var="$runpath_var=\"$rpath\$$runpath_var\" " + fi + fi + + if test "$no_install" = yes; then + # We don't need to create a wrapper script. + link_command="$compile_var$compile_command$compile_rpath" + # Replace the output file specification. + link_command=`$echo "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'` + # Delete the old output file. + $run $rm $output + # Link the executable and exit + $show "$link_command" + $run eval "$link_command" || exit $? + exit $EXIT_SUCCESS + fi + + if test "$hardcode_action" = relink; then + # Fast installation is not supported + link_command="$compile_var$compile_command$compile_rpath" + relink_command="$finalize_var$finalize_command$finalize_rpath" + + $echo "$modename: warning: this platform does not like uninstalled shared libraries" 1>&2 + $echo "$modename: \`$output' will be relinked during installation" 1>&2 + else + if test "$fast_install" != no; then + link_command="$finalize_var$compile_command$finalize_rpath" + if test "$fast_install" = yes; then + relink_command=`$echo "X$compile_var$compile_command$compile_rpath" | $Xsed -e 's%@OUTPUT@%\$progdir/\$file%g'` + else + # fast_install is set to needless + relink_command= + fi + else + link_command="$compile_var$compile_command$compile_rpath" + relink_command="$finalize_var$finalize_command$finalize_rpath" + fi + fi + + # Replace the output file specification. + link_command=`$echo "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'` + + # Delete the old output files. + $run $rm $output $output_objdir/$outputname $output_objdir/lt-$outputname + + $show "$link_command" + $run eval "$link_command" || exit $? + + # Now create the wrapper script. + $show "creating $output" + + # Quote the relink command for shipping. + if test -n "$relink_command"; then + # Preserve any variables that may affect compiler behavior + for var in $variables_saved_for_relink; do + if eval test -z \"\${$var+set}\"; then + relink_command="{ test -z \"\${$var+set}\" || unset $var || { $var=; export $var; }; }; $relink_command" + elif eval var_value=\$$var; test -z "$var_value"; then + relink_command="$var=; export $var; $relink_command" + else + var_value=`$echo "X$var_value" | $Xsed -e "$sed_quote_subst"` + relink_command="$var=\"$var_value\"; export $var; $relink_command" + fi + done + relink_command="(cd `pwd`; $relink_command)" + relink_command=`$echo "X$relink_command" | $Xsed -e "$sed_quote_subst"` + fi + + # Quote $echo for shipping. + if test "X$echo" = "X$SHELL $progpath --fallback-echo"; then + case $progpath in + [\\/]* | [A-Za-z]:[\\/]*) qecho="$SHELL $progpath --fallback-echo";; + *) qecho="$SHELL `pwd`/$progpath --fallback-echo";; + esac + qecho=`$echo "X$qecho" | $Xsed -e "$sed_quote_subst"` + else + qecho=`$echo "X$echo" | $Xsed -e "$sed_quote_subst"` + fi + + # Only actually do things if our run command is non-null. + if test -z "$run"; then + # win32 will think the script is a binary if it has + # a .exe suffix, so we strip it off here. + case $output in + *.exe) output=`$echo $output|${SED} 's,.exe$,,'` ;; + esac + # test for cygwin because mv fails w/o .exe extensions + case $host in + *cygwin*) + exeext=.exe + outputname=`$echo $outputname|${SED} 's,.exe$,,'` ;; + *) exeext= ;; + esac + case $host in + *cygwin* | *mingw* ) + cwrappersource=`$echo ${objdir}/lt-${outputname}.c` + cwrapper=`$echo ${output}.exe` + $rm $cwrappersource $cwrapper + trap "$rm $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15 + + cat > $cwrappersource <> $cwrappersource<<"EOF" +#include +#include +#include +#include +#include +#include + +#if defined(PATH_MAX) +# define LT_PATHMAX PATH_MAX +#elif defined(MAXPATHLEN) +# define LT_PATHMAX MAXPATHLEN +#else +# define LT_PATHMAX 1024 +#endif + +#ifndef DIR_SEPARATOR +#define DIR_SEPARATOR '/' +#endif + +#if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \ + defined (__OS2__) +#define HAVE_DOS_BASED_FILE_SYSTEM +#ifndef DIR_SEPARATOR_2 +#define DIR_SEPARATOR_2 '\\' +#endif +#endif + +#ifndef DIR_SEPARATOR_2 +# define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR) +#else /* DIR_SEPARATOR_2 */ +# define IS_DIR_SEPARATOR(ch) \ + (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2)) +#endif /* DIR_SEPARATOR_2 */ + +#define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) +#define XFREE(stale) do { \ + if (stale) { free ((void *) stale); stale = 0; } \ +} while (0) + +const char *program_name = NULL; + +void * xmalloc (size_t num); +char * xstrdup (const char *string); +char * basename (const char *name); +char * fnqualify(const char *path); +char * strendzap(char *str, const char *pat); +void lt_fatal (const char *message, ...); + +int +main (int argc, char *argv[]) +{ + char **newargz; + int i; + + program_name = (char *) xstrdup ((char *) basename (argv[0])); + newargz = XMALLOC(char *, argc+2); +EOF + + cat >> $cwrappersource <> $cwrappersource <<"EOF" + newargz[1] = fnqualify(argv[0]); + /* we know the script has the same name, without the .exe */ + /* so make sure newargz[1] doesn't end in .exe */ + strendzap(newargz[1],".exe"); + for (i = 1; i < argc; i++) + newargz[i+1] = xstrdup(argv[i]); + newargz[argc+1] = NULL; +EOF + + cat >> $cwrappersource <> $cwrappersource <<"EOF" + return 127; +} + +void * +xmalloc (size_t num) +{ + void * p = (void *) malloc (num); + if (!p) + lt_fatal ("Memory exhausted"); + + return p; +} + +char * +xstrdup (const char *string) +{ + return string ? strcpy ((char *) xmalloc (strlen (string) + 1), string) : NULL +; +} + +char * +basename (const char *name) +{ + const char *base; + +#if defined (HAVE_DOS_BASED_FILE_SYSTEM) + /* Skip over the disk name in MSDOS pathnames. */ + if (isalpha (name[0]) && name[1] == ':') + name += 2; +#endif + + for (base = name; *name; name++) + if (IS_DIR_SEPARATOR (*name)) + base = name + 1; + return (char *) base; +} + +char * +fnqualify(const char *path) +{ + size_t size; + char *p; + char tmp[LT_PATHMAX + 1]; + + assert(path != NULL); + + /* Is it qualified already? */ +#if defined (HAVE_DOS_BASED_FILE_SYSTEM) + if (isalpha (path[0]) && path[1] == ':') + return xstrdup (path); +#endif + if (IS_DIR_SEPARATOR (path[0])) + return xstrdup (path); + + /* prepend the current directory */ + /* doesn't handle '~' */ + if (getcwd (tmp, LT_PATHMAX) == NULL) + lt_fatal ("getcwd failed"); + size = strlen(tmp) + 1 + strlen(path) + 1; /* +2 for '/' and '\0' */ + p = XMALLOC(char, size); + sprintf(p, "%s%c%s", tmp, DIR_SEPARATOR, path); + return p; +} + +char * +strendzap(char *str, const char *pat) +{ + size_t len, patlen; + + assert(str != NULL); + assert(pat != NULL); + + len = strlen(str); + patlen = strlen(pat); + + if (patlen <= len) + { + str += len - patlen; + if (strcmp(str, pat) == 0) + *str = '\0'; + } + return str; +} + +static void +lt_error_core (int exit_status, const char * mode, + const char * message, va_list ap) +{ + fprintf (stderr, "%s: %s: ", program_name, mode); + vfprintf (stderr, message, ap); + fprintf (stderr, ".\n"); + + if (exit_status >= 0) + exit (exit_status); +} + +void +lt_fatal (const char *message, ...) +{ + va_list ap; + va_start (ap, message); + lt_error_core (EXIT_FAILURE, "FATAL", message, ap); + va_end (ap); +} +EOF + # we should really use a build-platform specific compiler + # here, but OTOH, the wrappers (shell script and this C one) + # are only useful if you want to execute the "real" binary. + # Since the "real" binary is built for $host, then this + # wrapper might as well be built for $host, too. + $run $LTCC -s -o $cwrapper $cwrappersource + ;; + esac + $rm $output + trap "$rm $output; exit $EXIT_FAILURE" 1 2 15 + + $echo > $output "\ +#! $SHELL + +# $output - temporary wrapper script for $objdir/$outputname +# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP +# +# The $output program cannot be directly executed until all the libtool +# libraries that it depends on are installed. +# +# This wrapper script should never be moved out of the build directory. +# If it is, it will not operate correctly. + +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +Xsed='${SED} -e 1s/^X//' +sed_quote_subst='$sed_quote_subst' + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +relink_command=\"$relink_command\" + +# This environment variable determines our operation mode. +if test \"\$libtool_install_magic\" = \"$magic\"; then + # install mode needs the following variable: + notinst_deplibs='$notinst_deplibs' +else + # When we are sourced in execute mode, \$file and \$echo are already set. + if test \"\$libtool_execute_magic\" != \"$magic\"; then + echo=\"$qecho\" + file=\"\$0\" + # Make sure echo works. + if test \"X\$1\" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift + elif test \"X\`(\$echo '\t') 2>/dev/null\`\" = 'X\t'; then + # Yippee, \$echo works! + : + else + # Restart under the correct shell, and then maybe \$echo will work. + exec $SHELL \"\$0\" --no-reexec \${1+\"\$@\"} + fi + fi\ +" + $echo >> $output "\ + + # Find the directory that this script lives in. + thisdir=\`\$echo \"X\$file\" | \$Xsed -e 's%/[^/]*$%%'\` + test \"x\$thisdir\" = \"x\$file\" && thisdir=. + + # Follow symbolic links until we get to the real thisdir. + file=\`ls -ld \"\$file\" | ${SED} -n 's/.*-> //p'\` + while test -n \"\$file\"; do + destdir=\`\$echo \"X\$file\" | \$Xsed -e 's%/[^/]*\$%%'\` + + # If there was a directory component, then change thisdir. + if test \"x\$destdir\" != \"x\$file\"; then + case \"\$destdir\" in + [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;; + *) thisdir=\"\$thisdir/\$destdir\" ;; + esac + fi + + file=\`\$echo \"X\$file\" | \$Xsed -e 's%^.*/%%'\` + file=\`ls -ld \"\$thisdir/\$file\" | ${SED} -n 's/.*-> //p'\` + done + + # Try to get the absolute directory name. + absdir=\`cd \"\$thisdir\" && pwd\` + test -n \"\$absdir\" && thisdir=\"\$absdir\" +" + + if test "$fast_install" = yes; then + $echo >> $output "\ + program=lt-'$outputname'$exeext + progdir=\"\$thisdir/$objdir\" + + if test ! -f \"\$progdir/\$program\" || \\ + { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | ${SED} 1q\`; \\ + test \"X\$file\" != \"X\$progdir/\$program\"; }; then + + file=\"\$\$-\$program\" + + if test ! -d \"\$progdir\"; then + $mkdir \"\$progdir\" + else + $rm \"\$progdir/\$file\" + fi" + + $echo >> $output "\ + + # relink executable if necessary + if test -n \"\$relink_command\"; then + if relink_command_output=\`eval \$relink_command 2>&1\`; then : + else + $echo \"\$relink_command_output\" >&2 + $rm \"\$progdir/\$file\" + exit $EXIT_FAILURE + fi + fi + + $mv \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null || + { $rm \"\$progdir/\$program\"; + $mv \"\$progdir/\$file\" \"\$progdir/\$program\"; } + $rm \"\$progdir/\$file\" + fi" + else + $echo >> $output "\ + program='$outputname' + progdir=\"\$thisdir/$objdir\" +" + fi + + $echo >> $output "\ + + if test -f \"\$progdir/\$program\"; then" + + # Export our shlibpath_var if we have one. + if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then + $echo >> $output "\ + # Add our own library path to $shlibpath_var + $shlibpath_var=\"$temp_rpath\$$shlibpath_var\" + + # Some systems cannot cope with colon-terminated $shlibpath_var + # The second colon is a workaround for a bug in BeOS R4 sed + $shlibpath_var=\`\$echo \"X\$$shlibpath_var\" | \$Xsed -e 's/::*\$//'\` + + export $shlibpath_var +" + fi + + # fixup the dll searchpath if we need to. + if test -n "$dllsearchpath"; then + $echo >> $output "\ + # Add the dll search path components to the executable PATH + PATH=$dllsearchpath:\$PATH +" + fi + + $echo >> $output "\ + if test \"\$libtool_execute_magic\" != \"$magic\"; then + # Run the actual program with our arguments. +" + case $host in + # Backslashes separate directories on plain windows + *-*-mingw | *-*-os2*) + $echo >> $output "\ + exec \"\$progdir\\\\\$program\" \${1+\"\$@\"} +" + ;; + + *) + $echo >> $output "\ + exec \"\$progdir/\$program\" \${1+\"\$@\"} +" + ;; + esac + $echo >> $output "\ + \$echo \"\$0: cannot exec \$program \${1+\"\$@\"}\" + exit $EXIT_FAILURE + fi + else + # The program doesn't exist. + \$echo \"\$0: error: \\\`\$progdir/\$program' does not exist\" 1>&2 + \$echo \"This script is just a wrapper for \$program.\" 1>&2 + $echo \"See the $PACKAGE documentation for more information.\" 1>&2 + exit $EXIT_FAILURE + fi +fi\ +" + chmod +x $output + fi + exit $EXIT_SUCCESS + ;; + esac + + # See if we need to build an old-fashioned archive. + for oldlib in $oldlibs; do + + if test "$build_libtool_libs" = convenience; then + oldobjs="$libobjs_save" + addlibs="$convenience" + build_libtool_libs=no + else + if test "$build_libtool_libs" = module; then + oldobjs="$libobjs_save" + build_libtool_libs=no + else + oldobjs="$old_deplibs $non_pic_objects" + fi + addlibs="$old_convenience" + fi + + if test -n "$addlibs"; then + gentop="$output_objdir/${outputname}x" + generated="$generated $gentop" + + func_extract_archives $gentop $addlibs + oldobjs="$oldobjs $func_extract_archives_result" + fi + + # Do each command in the archive commands. + if test -n "$old_archive_from_new_cmds" && test "$build_libtool_libs" = yes; then + cmds=$old_archive_from_new_cmds + else + # POSIX demands no paths to be encoded in archives. We have + # to avoid creating archives with duplicate basenames if we + # might have to extract them afterwards, e.g., when creating a + # static archive out of a convenience library, or when linking + # the entirety of a libtool archive into another (currently + # not supported by libtool). + if (for obj in $oldobjs + do + $echo "X$obj" | $Xsed -e 's%^.*/%%' + done | sort | sort -uc >/dev/null 2>&1); then + : + else + $echo "copying selected object files to avoid basename conflicts..." + + if test -z "$gentop"; then + gentop="$output_objdir/${outputname}x" + generated="$generated $gentop" + + $show "${rm}r $gentop" + $run ${rm}r "$gentop" + $show "$mkdir $gentop" + $run $mkdir "$gentop" + status=$? + if test "$status" -ne 0 && test ! -d "$gentop"; then + exit $status + fi + fi + + save_oldobjs=$oldobjs + oldobjs= + counter=1 + for obj in $save_oldobjs + do + objbase=`$echo "X$obj" | $Xsed -e 's%^.*/%%'` + case " $oldobjs " in + " ") oldobjs=$obj ;; + *[\ /]"$objbase "*) + while :; do + # Make sure we don't pick an alternate name that also + # overlaps. + newobj=lt$counter-$objbase + counter=`expr $counter + 1` + case " $oldobjs " in + *[\ /]"$newobj "*) ;; + *) if test ! -f "$gentop/$newobj"; then break; fi ;; + esac + done + $show "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj" + $run ln "$obj" "$gentop/$newobj" || + $run cp "$obj" "$gentop/$newobj" + oldobjs="$oldobjs $gentop/$newobj" + ;; + *) oldobjs="$oldobjs $obj" ;; + esac + done + fi + + eval cmds=\"$old_archive_cmds\" + + if len=`expr "X$cmds" : ".*"` && + test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then + cmds=$old_archive_cmds + else + # the command line is too long to link in one step, link in parts + $echo "using piecewise archive linking..." + save_RANLIB=$RANLIB + RANLIB=: + objlist= + concat_cmds= + save_oldobjs=$oldobjs + + # Is there a better way of finding the last object in the list? + for obj in $save_oldobjs + do + last_oldobj=$obj + done + for obj in $save_oldobjs + do + oldobjs="$objlist $obj" + objlist="$objlist $obj" + eval test_cmds=\"$old_archive_cmds\" + if len=`expr "X$test_cmds" : ".*" 2>/dev/null` && + test "$len" -le "$max_cmd_len"; then + : + else + # the above command should be used before it gets too long + oldobjs=$objlist + if test "$obj" = "$last_oldobj" ; then + RANLIB=$save_RANLIB + fi + test -z "$concat_cmds" || concat_cmds=$concat_cmds~ + eval concat_cmds=\"\${concat_cmds}$old_archive_cmds\" + objlist= + fi + done + RANLIB=$save_RANLIB + oldobjs=$objlist + if test "X$oldobjs" = "X" ; then + eval cmds=\"\$concat_cmds\" + else + eval cmds=\"\$concat_cmds~\$old_archive_cmds\" + fi + fi + fi + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + eval cmd=\"$cmd\" + IFS="$save_ifs" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" + done + + if test -n "$generated"; then + $show "${rm}r$generated" + $run ${rm}r$generated + fi + + # Now create the libtool archive. + case $output in + *.la) + old_library= + test "$build_old_libs" = yes && old_library="$libname.$libext" + $show "creating $output" + + # Preserve any variables that may affect compiler behavior + for var in $variables_saved_for_relink; do + if eval test -z \"\${$var+set}\"; then + relink_command="{ test -z \"\${$var+set}\" || unset $var || { $var=; export $var; }; }; $relink_command" + elif eval var_value=\$$var; test -z "$var_value"; then + relink_command="$var=; export $var; $relink_command" + else + var_value=`$echo "X$var_value" | $Xsed -e "$sed_quote_subst"` + relink_command="$var=\"$var_value\"; export $var; $relink_command" + fi + done + # Quote the link command for shipping. + relink_command="(cd `pwd`; $SHELL $progpath $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)" + relink_command=`$echo "X$relink_command" | $Xsed -e "$sed_quote_subst"` + if test "$hardcode_automatic" = yes ; then + relink_command= + fi + + + # Only create the output if not a dry run. + if test -z "$run"; then + for installed in no yes; do + if test "$installed" = yes; then + if test -z "$install_libdir"; then + break + fi + output="$output_objdir/$outputname"i + # Replace all uninstalled libtool libraries with the installed ones + newdependency_libs= + for deplib in $dependency_libs; do + case $deplib in + *.la) + name=`$echo "X$deplib" | $Xsed -e 's%^.*/%%'` + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` + if test -z "$libdir"; then + $echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2 + exit $EXIT_FAILURE + fi + newdependency_libs="$newdependency_libs $libdir/$name" + ;; + *) newdependency_libs="$newdependency_libs $deplib" ;; + esac + done + dependency_libs="$newdependency_libs" + newdlfiles= + for lib in $dlfiles; do + name=`$echo "X$lib" | $Xsed -e 's%^.*/%%'` + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` + if test -z "$libdir"; then + $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2 + exit $EXIT_FAILURE + fi + newdlfiles="$newdlfiles $libdir/$name" + done + dlfiles="$newdlfiles" + newdlprefiles= + for lib in $dlprefiles; do + name=`$echo "X$lib" | $Xsed -e 's%^.*/%%'` + eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib` + if test -z "$libdir"; then + $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2 + exit $EXIT_FAILURE + fi + newdlprefiles="$newdlprefiles $libdir/$name" + done + dlprefiles="$newdlprefiles" + else + newdlfiles= + for lib in $dlfiles; do + case $lib in + [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;; + *) abs=`pwd`"/$lib" ;; + esac + newdlfiles="$newdlfiles $abs" + done + dlfiles="$newdlfiles" + newdlprefiles= + for lib in $dlprefiles; do + case $lib in + [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;; + *) abs=`pwd`"/$lib" ;; + esac + newdlprefiles="$newdlprefiles $abs" + done + dlprefiles="$newdlprefiles" + fi + $rm $output + # place dlname in correct position for cygwin + tdlname=$dlname + case $host,$output,$installed,$module,$dlname in + *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll) tdlname=../bin/$dlname ;; + esac + $echo > $output "\ +# $outputname - a libtool library file +# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP +# +# Please DO NOT delete this file! +# It is necessary for linking the library. + +# The name that we can dlopen(3). +dlname='$tdlname' + +# Names of this library. +library_names='$library_names' + +# The name of the static archive. +old_library='$old_library' + +# Libraries that this one depends upon. +dependency_libs='$dependency_libs' + +# Version information for $libname. +current=$current +age=$age +revision=$revision + +# Is this an already installed library? +installed=$installed + +# Should we warn about portability when linking against -modules? +shouldnotlink=$module + +# Files to dlopen/dlpreopen +dlopen='$dlfiles' +dlpreopen='$dlprefiles' + +# Directory that this library needs to be installed in: +libdir='$install_libdir'" + if test "$installed" = no && test "$need_relink" = yes; then + $echo >> $output "\ +relink_command=\"$relink_command\"" + fi + done + fi + + # Do a symbolic link so that the libtool archive can be found in + # LD_LIBRARY_PATH before the program is installed. + $show "(cd $output_objdir && $rm $outputname && $LN_S ../$outputname $outputname)" + $run eval '(cd $output_objdir && $rm $outputname && $LN_S ../$outputname $outputname)' || exit $? + ;; + esac + exit $EXIT_SUCCESS + ;; + + # libtool install mode + install) + modename="$modename: install" + + # There may be an optional sh(1) argument at the beginning of + # install_prog (especially on Windows NT). + if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh || + # Allow the use of GNU shtool's install command. + $echo "X$nonopt" | grep shtool > /dev/null; then + # Aesthetically quote it. + arg=`$echo "X$nonopt" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + install_prog="$arg " + arg="$1" + shift + else + install_prog= + arg=$nonopt + fi + + # The real first argument should be the name of the installation program. + # Aesthetically quote it. + arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + install_prog="$install_prog$arg" + + # We need to accept at least all the BSD install flags. + dest= + files= + opts= + prev= + install_type= + isdir=no + stripme= + for arg + do + if test -n "$dest"; then + files="$files $dest" + dest=$arg + continue + fi + + case $arg in + -d) isdir=yes ;; + -f) + case " $install_prog " in + *[\\\ /]cp\ *) ;; + *) prev=$arg ;; + esac + ;; + -g | -m | -o) prev=$arg ;; + -s) + stripme=" -s" + continue + ;; + -*) + ;; + *) + # If the previous option needed an argument, then skip it. + if test -n "$prev"; then + prev= + else + dest=$arg + continue + fi + ;; + esac + + # Aesthetically quote the argument. + arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"` + case $arg in + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + arg="\"$arg\"" + ;; + esac + install_prog="$install_prog $arg" + done + + if test -z "$install_prog"; then + $echo "$modename: you must specify an install program" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + + if test -n "$prev"; then + $echo "$modename: the \`$prev' option requires an argument" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + + if test -z "$files"; then + if test -z "$dest"; then + $echo "$modename: no file or destination specified" 1>&2 + else + $echo "$modename: you must specify a destination" 1>&2 + fi + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + + # Strip any trailing slash from the destination. + dest=`$echo "X$dest" | $Xsed -e 's%/$%%'` + + # Check to see that the destination is a directory. + test -d "$dest" && isdir=yes + if test "$isdir" = yes; then + destdir="$dest" + destname= + else + destdir=`$echo "X$dest" | $Xsed -e 's%/[^/]*$%%'` + test "X$destdir" = "X$dest" && destdir=. + destname=`$echo "X$dest" | $Xsed -e 's%^.*/%%'` + + # Not a directory, so check to see that there is only one file specified. + set dummy $files + if test "$#" -gt 2; then + $echo "$modename: \`$dest' is not a directory" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + fi + case $destdir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + for file in $files; do + case $file in + *.lo) ;; + *) + $echo "$modename: \`$destdir' must be an absolute directory name" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + ;; + esac + done + ;; + esac + + # This variable tells wrapper scripts just to set variables rather + # than running their programs. + libtool_install_magic="$magic" + + staticlibs= + future_libdirs= + current_libdirs= + for file in $files; do + + # Do each installation. + case $file in + *.$libext) + # Do the static libraries later. + staticlibs="$staticlibs $file" + ;; + + *.la) + # Check to see that this really is a libtool archive. + if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then : + else + $echo "$modename: \`$file' is not a valid libtool archive" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + + library_names= + old_library= + relink_command= + # If there is no directory component, then add one. + case $file in + */* | *\\*) . $file ;; + *) . ./$file ;; + esac + + # Add the libdir to current_libdirs if it is the destination. + if test "X$destdir" = "X$libdir"; then + case "$current_libdirs " in + *" $libdir "*) ;; + *) current_libdirs="$current_libdirs $libdir" ;; + esac + else + # Note the libdir as a future libdir. + case "$future_libdirs " in + *" $libdir "*) ;; + *) future_libdirs="$future_libdirs $libdir" ;; + esac + fi + + dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'`/ + test "X$dir" = "X$file/" && dir= + dir="$dir$objdir" + + if test -n "$relink_command"; then + # Determine the prefix the user has applied to our future dir. + inst_prefix_dir=`$echo "$destdir" | $SED "s%$libdir\$%%"` + + # Don't allow the user to place us outside of our expected + # location b/c this prevents finding dependent libraries that + # are installed to the same prefix. + # At present, this check doesn't affect windows .dll's that + # are installed into $libdir/../bin (currently, that works fine) + # but it's something to keep an eye on. + if test "$inst_prefix_dir" = "$destdir"; then + $echo "$modename: error: cannot install \`$file' to a directory not ending in $libdir" 1>&2 + exit $EXIT_FAILURE + fi + + if test -n "$inst_prefix_dir"; then + # Stick the inst_prefix_dir data into the link command. + relink_command=`$echo "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"` + else + relink_command=`$echo "$relink_command" | $SED "s%@inst_prefix_dir@%%"` + fi + + $echo "$modename: warning: relinking \`$file'" 1>&2 + $show "$relink_command" + if $run eval "$relink_command"; then : + else + $echo "$modename: error: relink \`$file' with the above command before installing it" 1>&2 + exit $EXIT_FAILURE + fi + fi + + # See the names of the shared library. + set dummy $library_names + if test -n "$2"; then + realname="$2" + shift + shift + + srcname="$realname" + test -n "$relink_command" && srcname="$realname"T + + # Install the shared library and build the symlinks. + $show "$install_prog $dir/$srcname $destdir/$realname" + $run eval "$install_prog $dir/$srcname $destdir/$realname" || exit $? + if test -n "$stripme" && test -n "$striplib"; then + $show "$striplib $destdir/$realname" + $run eval "$striplib $destdir/$realname" || exit $? + fi + + if test "$#" -gt 0; then + # Delete the old symlinks, and create new ones. + # Try `ln -sf' first, because the `ln' binary might depend on + # the symlink we replace! Solaris /bin/ln does not understand -f, + # so we also need to try rm && ln -s. + for linkname + do + if test "$linkname" != "$realname"; then + $show "(cd $destdir && { $LN_S -f $realname $linkname || { $rm $linkname && $LN_S $realname $linkname; }; })" + $run eval "(cd $destdir && { $LN_S -f $realname $linkname || { $rm $linkname && $LN_S $realname $linkname; }; })" + fi + done + fi + + # Do each command in the postinstall commands. + lib="$destdir/$realname" + cmds=$postinstall_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || { + lt_exit=$? + + # Restore the uninstalled library and exit + if test "$mode" = relink; then + $run eval '(cd $output_objdir && $rm ${realname}T && $mv ${realname}U $realname)' + fi + + exit $lt_exit + } + done + IFS="$save_ifs" + fi + + # Install the pseudo-library for information purposes. + name=`$echo "X$file" | $Xsed -e 's%^.*/%%'` + instname="$dir/$name"i + $show "$install_prog $instname $destdir/$name" + $run eval "$install_prog $instname $destdir/$name" || exit $? + + # Maybe install the static library, too. + test -n "$old_library" && staticlibs="$staticlibs $dir/$old_library" + ;; + + *.lo) + # Install (i.e. copy) a libtool object. + + # Figure out destination file name, if it wasn't already specified. + if test -n "$destname"; then + destfile="$destdir/$destname" + else + destfile=`$echo "X$file" | $Xsed -e 's%^.*/%%'` + destfile="$destdir/$destfile" + fi + + # Deduce the name of the destination old-style object file. + case $destfile in + *.lo) + staticdest=`$echo "X$destfile" | $Xsed -e "$lo2o"` + ;; + *.$objext) + staticdest="$destfile" + destfile= + ;; + *) + $echo "$modename: cannot copy a libtool object to \`$destfile'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + ;; + esac + + # Install the libtool object if requested. + if test -n "$destfile"; then + $show "$install_prog $file $destfile" + $run eval "$install_prog $file $destfile" || exit $? + fi + + # Install the old object if enabled. + if test "$build_old_libs" = yes; then + # Deduce the name of the old-style object file. + staticobj=`$echo "X$file" | $Xsed -e "$lo2o"` + + $show "$install_prog $staticobj $staticdest" + $run eval "$install_prog \$staticobj \$staticdest" || exit $? + fi + exit $EXIT_SUCCESS + ;; + + *) + # Figure out destination file name, if it wasn't already specified. + if test -n "$destname"; then + destfile="$destdir/$destname" + else + destfile=`$echo "X$file" | $Xsed -e 's%^.*/%%'` + destfile="$destdir/$destfile" + fi + + # If the file is missing, and there is a .exe on the end, strip it + # because it is most likely a libtool script we actually want to + # install + stripped_ext="" + case $file in + *.exe) + if test ! -f "$file"; then + file=`$echo $file|${SED} 's,.exe$,,'` + stripped_ext=".exe" + fi + ;; + esac + + # Do a test to see if this is really a libtool program. + case $host in + *cygwin*|*mingw*) + wrapper=`$echo $file | ${SED} -e 's,.exe$,,'` + ;; + *) + wrapper=$file + ;; + esac + if (${SED} -e '4q' $wrapper | grep "^# Generated by .*$PACKAGE")>/dev/null 2>&1; then + notinst_deplibs= + relink_command= + + # Note that it is not necessary on cygwin/mingw to append a dot to + # foo even if both foo and FILE.exe exist: automatic-append-.exe + # behavior happens only for exec(3), not for open(2)! Also, sourcing + # `FILE.' does not work on cygwin managed mounts. + # + # If there is no directory component, then add one. + case $wrapper in + */* | *\\*) . ${wrapper} ;; + *) . ./${wrapper} ;; + esac + + # Check the variables that should have been set. + if test -z "$notinst_deplibs"; then + $echo "$modename: invalid libtool wrapper script \`$wrapper'" 1>&2 + exit $EXIT_FAILURE + fi + + finalize=yes + for lib in $notinst_deplibs; do + # Check to see that each library is installed. + libdir= + if test -f "$lib"; then + # If there is no directory component, then add one. + case $lib in + */* | *\\*) . $lib ;; + *) . ./$lib ;; + esac + fi + libfile="$libdir/"`$echo "X$lib" | $Xsed -e 's%^.*/%%g'` ### testsuite: skip nested quoting test + if test -n "$libdir" && test ! -f "$libfile"; then + $echo "$modename: warning: \`$lib' has not been installed in \`$libdir'" 1>&2 + finalize=no + fi + done + + relink_command= + # Note that it is not necessary on cygwin/mingw to append a dot to + # foo even if both foo and FILE.exe exist: automatic-append-.exe + # behavior happens only for exec(3), not for open(2)! Also, sourcing + # `FILE.' does not work on cygwin managed mounts. + # + # If there is no directory component, then add one. + case $wrapper in + */* | *\\*) . ${wrapper} ;; + *) . ./${wrapper} ;; + esac + + outputname= + if test "$fast_install" = no && test -n "$relink_command"; then + if test "$finalize" = yes && test -z "$run"; then + tmpdir="/tmp" + test -n "$TMPDIR" && tmpdir="$TMPDIR" + tmpdir="$tmpdir/libtool-$$" + save_umask=`umask` + umask 0077 + if $mkdir "$tmpdir"; then + umask $save_umask + else + umask $save_umask + $echo "$modename: error: cannot create temporary directory \`$tmpdir'" 1>&2 + continue + fi + file=`$echo "X$file$stripped_ext" | $Xsed -e 's%^.*/%%'` + outputname="$tmpdir/$file" + # Replace the output file specification. + relink_command=`$echo "X$relink_command" | $Xsed -e 's%@OUTPUT@%'"$outputname"'%g'` + + $show "$relink_command" + if $run eval "$relink_command"; then : + else + $echo "$modename: error: relink \`$file' with the above command before installing it" 1>&2 + ${rm}r "$tmpdir" + continue + fi + file="$outputname" + else + $echo "$modename: warning: cannot relink \`$file'" 1>&2 + fi + else + # Install the binary that we compiled earlier. + file=`$echo "X$file$stripped_ext" | $Xsed -e "s%\([^/]*\)$%$objdir/\1%"` + fi + fi + + # remove .exe since cygwin /usr/bin/install will append another + # one anyway + case $install_prog,$host in + */usr/bin/install*,*cygwin*) + case $file:$destfile in + *.exe:*.exe) + # this is ok + ;; + *.exe:*) + destfile=$destfile.exe + ;; + *:*.exe) + destfile=`$echo $destfile | ${SED} -e 's,.exe$,,'` + ;; + esac + ;; + esac + $show "$install_prog$stripme $file $destfile" + $run eval "$install_prog\$stripme \$file \$destfile" || exit $? + test -n "$outputname" && ${rm}r "$tmpdir" + ;; + esac + done + + for file in $staticlibs; do + name=`$echo "X$file" | $Xsed -e 's%^.*/%%'` + + # Set up the ranlib parameters. + oldlib="$destdir/$name" + + $show "$install_prog $file $oldlib" + $run eval "$install_prog \$file \$oldlib" || exit $? + + if test -n "$stripme" && test -n "$old_striplib"; then + $show "$old_striplib $oldlib" + $run eval "$old_striplib $oldlib" || exit $? + fi + + # Do each command in the postinstall commands. + cmds=$old_postinstall_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || exit $? + done + IFS="$save_ifs" + done + + if test -n "$future_libdirs"; then + $echo "$modename: warning: remember to run \`$progname --finish$future_libdirs'" 1>&2 + fi + + if test -n "$current_libdirs"; then + # Maybe just do a dry run. + test -n "$run" && current_libdirs=" -n$current_libdirs" + exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs' + else + exit $EXIT_SUCCESS + fi + ;; + + # libtool finish mode + finish) + modename="$modename: finish" + libdirs="$nonopt" + admincmds= + + if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then + for dir + do + libdirs="$libdirs $dir" + done + + for libdir in $libdirs; do + if test -n "$finish_cmds"; then + # Do each command in the finish commands. + cmds=$finish_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" || admincmds="$admincmds + $cmd" + done + IFS="$save_ifs" + fi + if test -n "$finish_eval"; then + # Do the single finish_eval. + eval cmds=\"$finish_eval\" + $run eval "$cmds" || admincmds="$admincmds + $cmds" + fi + done + fi + + # Exit here if they wanted silent mode. + test "$show" = : && exit $EXIT_SUCCESS + + $echo "----------------------------------------------------------------------" + $echo "Libraries have been installed in:" + for libdir in $libdirs; do + $echo " $libdir" + done + $echo + $echo "If you ever happen to want to link against installed libraries" + $echo "in a given directory, LIBDIR, you must either use libtool, and" + $echo "specify the full pathname of the library, or use the \`-LLIBDIR'" + $echo "flag during linking and do at least one of the following:" + if test -n "$shlibpath_var"; then + $echo " - add LIBDIR to the \`$shlibpath_var' environment variable" + $echo " during execution" + fi + if test -n "$runpath_var"; then + $echo " - add LIBDIR to the \`$runpath_var' environment variable" + $echo " during linking" + fi + if test -n "$hardcode_libdir_flag_spec"; then + libdir=LIBDIR + eval flag=\"$hardcode_libdir_flag_spec\" + + $echo " - use the \`$flag' linker flag" + fi + if test -n "$admincmds"; then + $echo " - have your system administrator run these commands:$admincmds" + fi + if test -f /etc/ld.so.conf; then + $echo " - have your system administrator add LIBDIR to \`/etc/ld.so.conf'" + fi + $echo + $echo "See any operating system documentation about shared libraries for" + $echo "more information, such as the ld(1) and ld.so(8) manual pages." + $echo "----------------------------------------------------------------------" + exit $EXIT_SUCCESS + ;; + + # libtool execute mode + execute) + modename="$modename: execute" + + # The first argument is the command name. + cmd="$nonopt" + if test -z "$cmd"; then + $echo "$modename: you must specify a COMMAND" 1>&2 + $echo "$help" + exit $EXIT_FAILURE + fi + + # Handle -dlopen flags immediately. + for file in $execute_dlfiles; do + if test ! -f "$file"; then + $echo "$modename: \`$file' is not a file" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + + dir= + case $file in + *.la) + # Check to see that this really is a libtool archive. + if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then : + else + $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + + # Read the libtool library. + dlname= + library_names= + + # If there is no directory component, then add one. + case $file in + */* | *\\*) . $file ;; + *) . ./$file ;; + esac + + # Skip this library if it cannot be dlopened. + if test -z "$dlname"; then + # Warn if it was a shared library. + test -n "$library_names" && $echo "$modename: warning: \`$file' was not linked with \`-export-dynamic'" + continue + fi + + dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'` + test "X$dir" = "X$file" && dir=. + + if test -f "$dir/$objdir/$dlname"; then + dir="$dir/$objdir" + else + $echo "$modename: cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'" 1>&2 + exit $EXIT_FAILURE + fi + ;; + + *.lo) + # Just add the directory containing the .lo file. + dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'` + test "X$dir" = "X$file" && dir=. + ;; + + *) + $echo "$modename: warning \`-dlopen' is ignored for non-libtool libraries and objects" 1>&2 + continue + ;; + esac + + # Get the absolute pathname. + absdir=`cd "$dir" && pwd` + test -n "$absdir" && dir="$absdir" + + # Now add the directory to shlibpath_var. + if eval "test -z \"\$$shlibpath_var\""; then + eval "$shlibpath_var=\"\$dir\"" + else + eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\"" + fi + done + + # This variable tells wrapper scripts just to set shlibpath_var + # rather than running their programs. + libtool_execute_magic="$magic" + + # Check if any of the arguments is a wrapper script. + args= + for file + do + case $file in + -*) ;; + *) + # Do a test to see if this is really a libtool program. + if (${SED} -e '4q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + # If there is no directory component, then add one. + case $file in + */* | *\\*) . $file ;; + *) . ./$file ;; + esac + + # Transform arg to wrapped name. + file="$progdir/$program" + fi + ;; + esac + # Quote arguments (to preserve shell metacharacters). + file=`$echo "X$file" | $Xsed -e "$sed_quote_subst"` + args="$args \"$file\"" + done + + if test -z "$run"; then + if test -n "$shlibpath_var"; then + # Export the shlibpath_var. + eval "export $shlibpath_var" + fi + + # Restore saved environment variables + if test "${save_LC_ALL+set}" = set; then + LC_ALL="$save_LC_ALL"; export LC_ALL + fi + if test "${save_LANG+set}" = set; then + LANG="$save_LANG"; export LANG + fi + + # Now prepare to actually exec the command. + exec_cmd="\$cmd$args" + else + # Display what would be done. + if test -n "$shlibpath_var"; then + eval "\$echo \"\$shlibpath_var=\$$shlibpath_var\"" + $echo "export $shlibpath_var" + fi + $echo "$cmd$args" + exit $EXIT_SUCCESS + fi + ;; + + # libtool clean and uninstall mode + clean | uninstall) + modename="$modename: $mode" + rm="$nonopt" + files= + rmforce= + exit_status=0 + + # This variable tells wrapper scripts just to set variables rather + # than running their programs. + libtool_install_magic="$magic" + + for arg + do + case $arg in + -f) rm="$rm $arg"; rmforce=yes ;; + -*) rm="$rm $arg" ;; + *) files="$files $arg" ;; + esac + done + + if test -z "$rm"; then + $echo "$modename: you must specify an RM program" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + fi + + rmdirs= + + origobjdir="$objdir" + for file in $files; do + dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'` + if test "X$dir" = "X$file"; then + dir=. + objdir="$origobjdir" + else + objdir="$dir/$origobjdir" + fi + name=`$echo "X$file" | $Xsed -e 's%^.*/%%'` + test "$mode" = uninstall && objdir="$dir" + + # Remember objdir for removal later, being careful to avoid duplicates + if test "$mode" = clean; then + case " $rmdirs " in + *" $objdir "*) ;; + *) rmdirs="$rmdirs $objdir" ;; + esac + fi + + # Don't error if the file doesn't exist and rm -f was used. + if (test -L "$file") >/dev/null 2>&1 \ + || (test -h "$file") >/dev/null 2>&1 \ + || test -f "$file"; then + : + elif test -d "$file"; then + exit_status=1 + continue + elif test "$rmforce" = yes; then + continue + fi + + rmfiles="$file" + + case $name in + *.la) + # Possibly a libtool archive, so verify it. + if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + . $dir/$name + + # Delete the libtool libraries and symlinks. + for n in $library_names; do + rmfiles="$rmfiles $objdir/$n" + done + test -n "$old_library" && rmfiles="$rmfiles $objdir/$old_library" + test "$mode" = clean && rmfiles="$rmfiles $objdir/$name $objdir/${name}i" + + if test "$mode" = uninstall; then + if test -n "$library_names"; then + # Do each command in the postuninstall commands. + cmds=$postuninstall_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" + if test "$?" -ne 0 && test "$rmforce" != yes; then + exit_status=1 + fi + done + IFS="$save_ifs" + fi + + if test -n "$old_library"; then + # Do each command in the old_postuninstall commands. + cmds=$old_postuninstall_cmds + save_ifs="$IFS"; IFS='~' + for cmd in $cmds; do + IFS="$save_ifs" + eval cmd=\"$cmd\" + $show "$cmd" + $run eval "$cmd" + if test "$?" -ne 0 && test "$rmforce" != yes; then + exit_status=1 + fi + done + IFS="$save_ifs" + fi + # FIXME: should reinstall the best remaining shared library. + fi + fi + ;; + + *.lo) + # Possibly a libtool object, so verify it. + if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + + # Read the .lo file + . $dir/$name + + # Add PIC object to the list of files to remove. + if test -n "$pic_object" \ + && test "$pic_object" != none; then + rmfiles="$rmfiles $dir/$pic_object" + fi + + # Add non-PIC object to the list of files to remove. + if test -n "$non_pic_object" \ + && test "$non_pic_object" != none; then + rmfiles="$rmfiles $dir/$non_pic_object" + fi + fi + ;; + + *) + if test "$mode" = clean ; then + noexename=$name + case $file in + *.exe) + file=`$echo $file|${SED} 's,.exe$,,'` + noexename=`$echo $name|${SED} 's,.exe$,,'` + # $file with .exe has already been added to rmfiles, + # add $file without .exe + rmfiles="$rmfiles $file" + ;; + esac + # Do a test to see if this is a libtool program. + if (${SED} -e '4q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then + relink_command= + . $dir/$noexename + + # note $name still contains .exe if it was in $file originally + # as does the version of $file that was added into $rmfiles + rmfiles="$rmfiles $objdir/$name $objdir/${name}S.${objext}" + if test "$fast_install" = yes && test -n "$relink_command"; then + rmfiles="$rmfiles $objdir/lt-$name" + fi + if test "X$noexename" != "X$name" ; then + rmfiles="$rmfiles $objdir/lt-${noexename}.c" + fi + fi + fi + ;; + esac + $show "$rm $rmfiles" + $run $rm $rmfiles || exit_status=1 + done + objdir="$origobjdir" + + # Try to remove the ${objdir}s in the directories where we deleted files + for dir in $rmdirs; do + if test -d "$dir"; then + $show "rmdir $dir" + $run rmdir $dir >/dev/null 2>&1 + fi + done + + exit $exit_status + ;; + + "") + $echo "$modename: you must specify a MODE" 1>&2 + $echo "$generic_help" 1>&2 + exit $EXIT_FAILURE + ;; + esac + + if test -z "$exec_cmd"; then + $echo "$modename: invalid operation mode \`$mode'" 1>&2 + $echo "$generic_help" 1>&2 + exit $EXIT_FAILURE + fi +fi # test -z "$show_help" + +if test -n "$exec_cmd"; then + eval exec $exec_cmd + exit $EXIT_FAILURE +fi + +# We need to display help for each of the modes. +case $mode in +"") $echo \ +"Usage: $modename [OPTION]... [MODE-ARG]... + +Provide generalized library-building support services. + + --config show all configuration variables + --debug enable verbose shell tracing +-n, --dry-run display commands without modifying any files + --features display basic configuration information and exit + --finish same as \`--mode=finish' + --help display this help message and exit + --mode=MODE use operation mode MODE [default=inferred from MODE-ARGS] + --quiet same as \`--silent' + --silent don't print informational messages + --tag=TAG use configuration variables from tag TAG + --version print version information + +MODE must be one of the following: + + clean remove files from the build directory + compile compile a source file into a libtool object + execute automatically set library path, then run a program + finish complete the installation of libtool libraries + install install libraries or executables + link create a library or an executable + uninstall remove libraries from an installed directory + +MODE-ARGS vary depending on the MODE. Try \`$modename --help --mode=MODE' for +a more detailed description of MODE. + +Report bugs to ." + exit $EXIT_SUCCESS + ;; + +clean) + $echo \ +"Usage: $modename [OPTION]... --mode=clean RM [RM-OPTION]... FILE... + +Remove files from the build directory. + +RM is the name of the program to use to delete files associated with each FILE +(typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed +to RM. + +If FILE is a libtool library, object or program, all the files associated +with it are deleted. Otherwise, only FILE itself is deleted using RM." + ;; + +compile) + $echo \ +"Usage: $modename [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE + +Compile a source file into a libtool library object. + +This mode accepts the following additional options: + + -o OUTPUT-FILE set the output file name to OUTPUT-FILE + -prefer-pic try to building PIC objects only + -prefer-non-pic try to building non-PIC objects only + -static always build a \`.o' file suitable for static linking + +COMPILE-COMMAND is a command to be used in creating a \`standard' object file +from the given SOURCEFILE. + +The output file name is determined by removing the directory component from +SOURCEFILE, then substituting the C source code suffix \`.c' with the +library object suffix, \`.lo'." + ;; + +execute) + $echo \ +"Usage: $modename [OPTION]... --mode=execute COMMAND [ARGS]... + +Automatically set library path, then run a program. + +This mode accepts the following additional options: + + -dlopen FILE add the directory containing FILE to the library path + +This mode sets the library path environment variable according to \`-dlopen' +flags. + +If any of the ARGS are libtool executable wrappers, then they are translated +into their corresponding uninstalled binary, and any of their required library +directories are added to the library path. + +Then, COMMAND is executed, with ARGS as arguments." + ;; + +finish) + $echo \ +"Usage: $modename [OPTION]... --mode=finish [LIBDIR]... + +Complete the installation of libtool libraries. + +Each LIBDIR is a directory that contains libtool libraries. + +The commands that this mode executes may require superuser privileges. Use +the \`--dry-run' option if you just want to see what would be executed." + ;; + +install) + $echo \ +"Usage: $modename [OPTION]... --mode=install INSTALL-COMMAND... + +Install executables or libraries. + +INSTALL-COMMAND is the installation command. The first component should be +either the \`install' or \`cp' program. + +The rest of the components are interpreted as arguments to that command (only +BSD-compatible install options are recognized)." + ;; + +link) + $echo \ +"Usage: $modename [OPTION]... --mode=link LINK-COMMAND... + +Link object files or libraries together to form another library, or to +create an executable program. + +LINK-COMMAND is a command using the C compiler that you would use to create +a program from several object files. + +The following components of LINK-COMMAND are treated specially: + + -all-static do not do any dynamic linking at all + -avoid-version do not add a version suffix if possible + -dlopen FILE \`-dlpreopen' FILE if it cannot be dlopened at runtime + -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols + -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3) + -export-symbols SYMFILE + try to export only the symbols listed in SYMFILE + -export-symbols-regex REGEX + try to export only the symbols matching REGEX + -LLIBDIR search LIBDIR for required installed libraries + -lNAME OUTPUT-FILE requires the installed library libNAME + -module build a library that can dlopened + -no-fast-install disable the fast-install mode + -no-install link a not-installable executable + -no-undefined declare that a library does not refer to external symbols + -o OUTPUT-FILE create OUTPUT-FILE from the specified objects + -objectlist FILE Use a list of object files found in FILE to specify objects + -precious-files-regex REGEX + don't remove output files matching REGEX + -release RELEASE specify package release information + -rpath LIBDIR the created library will eventually be installed in LIBDIR + -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries + -static do not do any dynamic linking of libtool libraries + -version-info CURRENT[:REVISION[:AGE]] + specify library version info [each variable defaults to 0] + +All other options (arguments beginning with \`-') are ignored. + +Every other argument is treated as a filename. Files ending in \`.la' are +treated as uninstalled libtool libraries, other files are standard or library +object files. + +If the OUTPUT-FILE ends in \`.la', then a libtool library is created, +only library objects (\`.lo' files) may be specified, and \`-rpath' is +required, except when creating a convenience library. + +If OUTPUT-FILE ends in \`.a' or \`.lib', then a standard library is created +using \`ar' and \`ranlib', or on Windows using \`lib'. + +If OUTPUT-FILE ends in \`.lo' or \`.${objext}', then a reloadable object file +is created, otherwise an executable program is created." + ;; + +uninstall) + $echo \ +"Usage: $modename [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE... + +Remove libraries from an installation directory. + +RM is the name of the program to use to delete files associated with each FILE +(typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed +to RM. + +If FILE is a libtool library, all the files associated with it are deleted. +Otherwise, only FILE itself is deleted using RM." + ;; + +*) + $echo "$modename: invalid operation mode \`$mode'" 1>&2 + $echo "$help" 1>&2 + exit $EXIT_FAILURE + ;; +esac + +$echo +$echo "Try \`$modename --help' for more information about other modes." + +exit $? + +# The TAGs below are defined such that we never get into a situation +# in which we disable both kinds of libraries. Given conflicting +# choices, we go for a static library, that is the most portable, +# since we can't tell whether shared libraries were disabled because +# the user asked for that or because the platform doesn't support +# them. This is particularly important on AIX, because we don't +# support having both static and shared libraries enabled at the same +# time on that platform, so we default to a shared-only configuration. +# If a disable-shared tag is given, we'll fallback to a static-only +# configuration. But we'll never go from static-only to shared-only. + +# ### BEGIN LIBTOOL TAG CONFIG: disable-shared +build_libtool_libs=no +build_old_libs=yes +# ### END LIBTOOL TAG CONFIG: disable-shared + +# ### BEGIN LIBTOOL TAG CONFIG: disable-static +build_old_libs=`case $build_libtool_libs in yes) $echo no;; *) $echo yes;; esac` +# ### END LIBTOOL TAG CONFIG: disable-static + +# Local Variables: +# mode:shell-script +# sh-indentation:2 +# End: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/missing b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/missing new file mode 100644 index 0000000000..6a37006e8f --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/missing @@ -0,0 +1,336 @@ +#! /bin/sh +# Common stub for a few missing GNU programs while installing. +# Copyright (C) 1996, 1997, 1999, 2000, 2002 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., 59 Temple Place - Suite 330, Boston, MA +# 02111-1307, 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=: + +# 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 + +case "$1" in +--run) + # Try to run requested program, and just exit if it succeeds. + run= + shift + "$@" && exit 0 + ;; +esac + +# If it does not exist, or fails to run (possibly an outdated version), +# try to emulate it. +case "$1" in + + -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' + 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]" + ;; + + -v|--v|--ve|--ver|--vers|--versi|--versio|--version) + echo "missing 0.4 - GNU automake" + ;; + + -*) + echo 1>&2 "$0: Unknown \`$1' option" + echo 1>&2 "Try \`$0 --help' for more information" + exit 1 + ;; + + aclocal*) + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then + # We have it, but it failed. + exit 1 + fi + + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. 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) + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then + # We have it, but it failed. + exit 1 + fi + + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. 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) + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then + # We have it, but it failed. + exit 1 + fi + + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. 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*) + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then + # We have it, but it failed. + exit 1 + fi + + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. 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) + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then + # We have it, but it failed. + exit 1 + fi + + echo 1>&2 "\ +WARNING: \`$1' is needed, and you do not seem to have it handy on your + system. You might have modified some files without having the + proper tools for further handling them. + You can get \`$1Help2man' as part of \`Autoconf' from any GNU + archive site." + + file=`echo "$*" | sed -n 's/.*--output[ =]*\([^ ]*\).*/\1/p'` + test -z "$file" && file=`echo "$*" | sed -n 's/.*-o[ ]*\([^ ]*\).*/\1/p'` + 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' is missing on your system. 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 [ $# -ne 1 ]; then + eval LASTARG="\${$#}" + case "$LASTARG" in + *.y) + SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'` + if [ -f "$SRCFILE" ]; then + cp "$SRCFILE" y.tab.c + fi + SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'` + if [ -f "$SRCFILE" ]; then + cp "$SRCFILE" y.tab.h + fi + ;; + esac + fi + if [ ! -f y.tab.h ]; then + echo >y.tab.h + fi + if [ ! -f y.tab.c ]; then + echo 'main() { return 0; }' >y.tab.c + fi + ;; + + lex|flex) + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. 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 [ $# -ne 1 ]; then + eval LASTARG="\${$#}" + case "$LASTARG" in + *.l) + SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'` + if [ -f "$SRCFILE" ]; then + cp "$SRCFILE" lex.yy.c + fi + ;; + esac + fi + if [ ! -f lex.yy.c ]; then + echo 'main() { return 0; }' >lex.yy.c + fi + ;; + + help2man) + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then + # We have it, but it failed. + exit 1 + fi + + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. 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 's/.*-o \([^ ]*\).*/\1/p'` + if test -z "$file"; then + file=`echo "$*" | sed -n 's/.*--output=\([^ ]*\).*/\1/p'` + fi + if [ -f "$file" ]; then + touch $file + else + test -z "$file" || exec >$file + echo ".ab help2man is required to generate this page" + exit 1 + fi + ;; + + makeinfo) + if test -z "$run" && (makeinfo --version) > /dev/null 2>&1; then + # We have makeinfo, but it failed. + exit 1 + fi + + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. 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." + file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'` + if test -z "$file"; then + file=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'` + file=`sed -n '/^@setfilename/ { s/.* \([^ ]*\) *$/\1/; p; q; }' $file` + fi + touch $file + ;; + + tar) + shift + if test -n "$run"; then + echo 1>&2 "ERROR: \`tar' requires --run" + exit 1 + fi + + # 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 you do not seem to have it handy on your + system. 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 prerequirements 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 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/mkinstalldirs b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/mkinstalldirs new file mode 100755 index 0000000000..4324e052bb --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/scripts/mkinstalldirs @@ -0,0 +1,40 @@ +#! /bin/sh +# mkinstalldirs --- make directory hierarchy +# Author: Noah Friedman +# Created: 1993-05-16 +# Public domain + +# $Id: mkinstalldirs,v 1.1 1999/06/27 07:45:05 cvs Exp $ + +errstatus=0 + +for file +do + set fnord `echo ":$file" | sed -ne 's/^:\//#/;s/^://;s/\// /g;s/^#/\//;p'` + shift + + pathcomp= + for d + do + pathcomp="$pathcomp$d" + case "$pathcomp" in + -* ) pathcomp=./$pathcomp ;; + esac + + if test ! -d "$pathcomp"; then + echo "mkdir $pathcomp" 1>&2 + + mkdir "$pathcomp" || lasterr=$? + + if test ! -d "$pathcomp"; then + errstatus=$lasterr + fi + fi + + pathcomp="$pathcomp/" + done +done + +exit $errstatus + +# mkinstalldirs ends here diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/stamp-h.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/stamp-h.in new file mode 100644 index 0000000000..9788f70238 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/stamp-h.in @@ -0,0 +1 @@ +timestamp diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/Makefile.am b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/Makefile.am new file mode 100644 index 0000000000..5213164a76 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/Makefile.am @@ -0,0 +1,65 @@ +## Process this file with automake to produce Makefile.in +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: tests Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 21.5.1999 +# ************************************************************************* + +INCLUDES = -I.. + +noinst_PROGRAMS = testsms testsms2 testparser testgsmlib testpb testpb2 \ + testspb testssms testcb + +TESTS = runspb.sh runspb2.sh runssms.sh runsms.sh \ + runparser.sh runspbi.sh + +# test files used for file-based phonebook and SMS testing +EXTRA_DIST = spb.pb runspb.sh runspb2.sh runssms.sh runsms.sh \ + runparser.sh \ + spb.pb spb2.pb \ + testparser-output.txt testspb-output.txt \ + testssms-output.txt testsms-output.txt \ + testspb2-output.txt \ + runspbi.sh spbi2-orig.pb spbi1.pb testspbi-output.txt + +# build testsms from testsms.cc and libgsmme.la +testsms_SOURCES = testsms.cc +testsms_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testsms2 from testsms2.cc and libgsmme.la +testsms2_SOURCES = testsms2.cc +testsms2_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testparser from testparser.cc and libgsmme.la +testparser_SOURCES = testparser.cc +testparser_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testgsmlib from testgsmlib.cc and libgsmme.la +testgsmlib_SOURCES = testgsmlib.cc +testgsmlib_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testpb from testpb.cc and libgsmme.la +testpb_SOURCES = testpb.cc +testpb_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testpb2 from testpb2.cc and libgsmme.la +testpb2_SOURCES = testpb2.cc +testpb2_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testspb from testspb.cc and libgsmme.la +testspb_SOURCES = testspb.cc +testspb_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testssms from testssms.cc and libgsmme.la +testssms_SOURCES = testssms.cc +testssms_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testcb from testcb.cc and libgsmme.la +testcb_SOURCES = testcb.cc +testcb_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/Makefile.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/Makefile.in new file mode 100644 index 0000000000..e949e268ff --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/Makefile.in @@ -0,0 +1,544 @@ +# Makefile.in generated by automake 1.6.3 from Makefile.am. +# @configure_input@ + +# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002 +# Free Software Foundation, Inc. +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +@SET_MAKE@ + +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: tests Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 21.5.1999 +# ************************************************************************* +SHELL = @SHELL@ + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ + +bindir = @bindir@ +sbindir = @sbindir@ +libexecdir = @libexecdir@ +datadir = @datadir@ +sysconfdir = @sysconfdir@ +sharedstatedir = @sharedstatedir@ +localstatedir = @localstatedir@ +libdir = @libdir@ +infodir = @infodir@ +mandir = @mandir@ +includedir = @includedir@ +oldincludedir = /usr/include +pkgdatadir = $(datadir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ +top_builddir = .. + +ACLOCAL = @ACLOCAL@ +AUTOCONF = @AUTOCONF@ +AUTOMAKE = @AUTOMAKE@ +AUTOHEADER = @AUTOHEADER@ + +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd +INSTALL = @INSTALL@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_DATA = @INSTALL_DATA@ +install_sh_DATA = $(install_sh) -c -m 644 +install_sh_PROGRAM = $(install_sh) -c +install_sh_SCRIPT = $(install_sh) -c +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +INSTALL_HEADER = $(INSTALL_DATA) +transform = @program_transform_name@ +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +host_alias = @host_alias@ +host_triplet = @host@ + +EXEEXT = @EXEEXT@ +OBJEXT = @OBJEXT@ +PATH_SEPARATOR = @PATH_SEPARATOR@ +AMTAR = @AMTAR@ +AS = @AS@ +AWK = @AWK@ +BUILD_INCLUDED_LIBINTL = @BUILD_INCLUDED_LIBINTL@ +CATOBJEXT = @CATOBJEXT@ +CC = @CC@ +CPP = @CPP@ +CXX = @CXX@ +DATADIRNAME = @DATADIRNAME@ +DEPDIR = @DEPDIR@ +DLLTOOL = @DLLTOOL@ +ECHO = @ECHO@ +GENCAT = @GENCAT@ +GLIBC21 = @GLIBC21@ +GMSGFMT = @GMSGFMT@ +GSM_VERSION = @GSM_VERSION@ +HAVE_LIB = @HAVE_LIB@ +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ +INSTOBJEXT = @INSTOBJEXT@ +INTLBISON = @INTLBISON@ +INTLLIBS = @INTLLIBS@ +INTLOBJS = @INTLOBJS@ +INTL_LIBTOOL_SUFFIX_PREFIX = @INTL_LIBTOOL_SUFFIX_PREFIX@ +LIB = @LIB@ +LIBICONV = @LIBICONV@ +LIBINTL = @LIBINTL@ +LIBTOOL = @LIBTOOL@ +LN_S = @LN_S@ +LTLIB = @LTLIB@ +LTLIBICONV = @LTLIBICONV@ +LTLIBINTL = @LTLIBINTL@ +MKINSTALLDIRS = @MKINSTALLDIRS@ +OBJDUMP = @OBJDUMP@ +PACKAGE = @PACKAGE@ +POSUB = @POSUB@ +RANLIB = @RANLIB@ +STRIP = @STRIP@ +USE_INCLUDED_LIBINTL = @USE_INCLUDED_LIBINTL@ +USE_NLS = @USE_NLS@ +VERSION = @VERSION@ +am__include = @am__include@ +am__quote = @am__quote@ +install_sh = @install_sh@ + +INCLUDES = -I.. + +noinst_PROGRAMS = testsms testsms2 testparser testgsmlib testpb testpb2 \ + testspb testssms testcb + + +TESTS = runspb.sh runspb2.sh runssms.sh runsms.sh \ + runparser.sh runspbi.sh + + +# test files used for file-based phonebook and SMS testing +EXTRA_DIST = spb.pb runspb.sh runspb2.sh runssms.sh runsms.sh \ + runparser.sh \ + spb.pb spb2.pb \ + testparser-output.txt testspb-output.txt \ + testssms-output.txt testsms-output.txt \ + testspb2-output.txt \ + runspbi.sh spbi2-orig.pb spbi1.pb testspbi-output.txt + + +# build testsms from testsms.cc and libgsmme.la +testsms_SOURCES = testsms.cc +testsms_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testsms2 from testsms2.cc and libgsmme.la +testsms2_SOURCES = testsms2.cc +testsms2_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testparser from testparser.cc and libgsmme.la +testparser_SOURCES = testparser.cc +testparser_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testgsmlib from testgsmlib.cc and libgsmme.la +testgsmlib_SOURCES = testgsmlib.cc +testgsmlib_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testpb from testpb.cc and libgsmme.la +testpb_SOURCES = testpb.cc +testpb_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testpb2 from testpb2.cc and libgsmme.la +testpb2_SOURCES = testpb2.cc +testpb2_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testspb from testspb.cc and libgsmme.la +testspb_SOURCES = testspb.cc +testspb_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testssms from testssms.cc and libgsmme.la +testssms_SOURCES = testssms.cc +testssms_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) + +# build testcb from testcb.cc and libgsmme.la +testcb_SOURCES = testcb.cc +testcb_LDADD = ../gsmlib/libgsmme.la $(INTLLIBS) +subdir = tests +mkinstalldirs = $(SHELL) $(top_srcdir)/scripts/mkinstalldirs +CONFIG_HEADER = $(top_builddir)/gsm_config.h +CONFIG_CLEAN_FILES = +noinst_PROGRAMS = testsms$(EXEEXT) testsms2$(EXEEXT) testparser$(EXEEXT) \ + testgsmlib$(EXEEXT) testpb$(EXEEXT) testpb2$(EXEEXT) \ + testspb$(EXEEXT) testssms$(EXEEXT) testcb$(EXEEXT) +PROGRAMS = $(noinst_PROGRAMS) + +am_testcb_OBJECTS = testcb.$(OBJEXT) +testcb_OBJECTS = $(am_testcb_OBJECTS) +testcb_DEPENDENCIES = ../gsmlib/libgsmme.la +testcb_LDFLAGS = +am_testgsmlib_OBJECTS = testgsmlib.$(OBJEXT) +testgsmlib_OBJECTS = $(am_testgsmlib_OBJECTS) +testgsmlib_DEPENDENCIES = ../gsmlib/libgsmme.la +testgsmlib_LDFLAGS = +am_testparser_OBJECTS = testparser.$(OBJEXT) +testparser_OBJECTS = $(am_testparser_OBJECTS) +testparser_DEPENDENCIES = ../gsmlib/libgsmme.la +testparser_LDFLAGS = +am_testpb_OBJECTS = testpb.$(OBJEXT) +testpb_OBJECTS = $(am_testpb_OBJECTS) +testpb_DEPENDENCIES = ../gsmlib/libgsmme.la +testpb_LDFLAGS = +am_testpb2_OBJECTS = testpb2.$(OBJEXT) +testpb2_OBJECTS = $(am_testpb2_OBJECTS) +testpb2_DEPENDENCIES = ../gsmlib/libgsmme.la +testpb2_LDFLAGS = +am_testsms_OBJECTS = testsms.$(OBJEXT) +testsms_OBJECTS = $(am_testsms_OBJECTS) +testsms_DEPENDENCIES = ../gsmlib/libgsmme.la +testsms_LDFLAGS = +am_testsms2_OBJECTS = testsms2.$(OBJEXT) +testsms2_OBJECTS = $(am_testsms2_OBJECTS) +testsms2_DEPENDENCIES = ../gsmlib/libgsmme.la +testsms2_LDFLAGS = +am_testspb_OBJECTS = testspb.$(OBJEXT) +testspb_OBJECTS = $(am_testspb_OBJECTS) +testspb_DEPENDENCIES = ../gsmlib/libgsmme.la +testspb_LDFLAGS = +am_testssms_OBJECTS = testssms.$(OBJEXT) +testssms_OBJECTS = $(am_testssms_OBJECTS) +testssms_DEPENDENCIES = ../gsmlib/libgsmme.la +testssms_LDFLAGS = + +DEFS = @DEFS@ +DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) +CPPFLAGS = @CPPFLAGS@ +LDFLAGS = @LDFLAGS@ +LIBS = @LIBS@ +depcomp = $(SHELL) $(top_srcdir)/scripts/depcomp +am__depfiles_maybe = depfiles +@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/testcb.Po ./$(DEPDIR)/testgsmlib.Po \ +@AMDEP_TRUE@ ./$(DEPDIR)/testparser.Po ./$(DEPDIR)/testpb.Po \ +@AMDEP_TRUE@ ./$(DEPDIR)/testpb2.Po ./$(DEPDIR)/testsms.Po \ +@AMDEP_TRUE@ ./$(DEPDIR)/testsms2.Po ./$(DEPDIR)/testspb.Po \ +@AMDEP_TRUE@ ./$(DEPDIR)/testssms.Po +CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ + $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) +LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) \ + $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ + $(AM_CXXFLAGS) $(CXXFLAGS) +CXXLD = $(CXX) +CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) \ + $(AM_LDFLAGS) $(LDFLAGS) -o $@ +CXXFLAGS = @CXXFLAGS@ +DIST_SOURCES = $(testcb_SOURCES) $(testgsmlib_SOURCES) \ + $(testparser_SOURCES) $(testpb_SOURCES) $(testpb2_SOURCES) \ + $(testsms_SOURCES) $(testsms2_SOURCES) $(testspb_SOURCES) \ + $(testssms_SOURCES) +DIST_COMMON = Makefile.am Makefile.in +SOURCES = $(testcb_SOURCES) $(testgsmlib_SOURCES) $(testparser_SOURCES) $(testpb_SOURCES) $(testpb2_SOURCES) $(testsms_SOURCES) $(testsms2_SOURCES) $(testspb_SOURCES) $(testssms_SOURCES) + +all: all-am + +.SUFFIXES: +.SUFFIXES: .cc .lo .o .obj +$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4) + cd $(top_srcdir) && \ + $(AUTOMAKE) --gnu tests/Makefile +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe) + +clean-noinstPROGRAMS: + @list='$(noinst_PROGRAMS)'; for p in $$list; do \ + f=`echo $$p|sed 's/$(EXEEXT)$$//'`; \ + echo " rm -f $$p $$f"; \ + rm -f $$p $$f ; \ + done +testcb$(EXEEXT): $(testcb_OBJECTS) $(testcb_DEPENDENCIES) + @rm -f testcb$(EXEEXT) + $(CXXLINK) $(testcb_LDFLAGS) $(testcb_OBJECTS) $(testcb_LDADD) $(LIBS) +testgsmlib$(EXEEXT): $(testgsmlib_OBJECTS) $(testgsmlib_DEPENDENCIES) + @rm -f testgsmlib$(EXEEXT) + $(CXXLINK) $(testgsmlib_LDFLAGS) $(testgsmlib_OBJECTS) $(testgsmlib_LDADD) $(LIBS) +testparser$(EXEEXT): $(testparser_OBJECTS) $(testparser_DEPENDENCIES) + @rm -f testparser$(EXEEXT) + $(CXXLINK) $(testparser_LDFLAGS) $(testparser_OBJECTS) $(testparser_LDADD) $(LIBS) +testpb$(EXEEXT): $(testpb_OBJECTS) $(testpb_DEPENDENCIES) + @rm -f testpb$(EXEEXT) + $(CXXLINK) $(testpb_LDFLAGS) $(testpb_OBJECTS) $(testpb_LDADD) $(LIBS) +testpb2$(EXEEXT): $(testpb2_OBJECTS) $(testpb2_DEPENDENCIES) + @rm -f testpb2$(EXEEXT) + $(CXXLINK) $(testpb2_LDFLAGS) $(testpb2_OBJECTS) $(testpb2_LDADD) $(LIBS) +testsms$(EXEEXT): $(testsms_OBJECTS) $(testsms_DEPENDENCIES) + @rm -f testsms$(EXEEXT) + $(CXXLINK) $(testsms_LDFLAGS) $(testsms_OBJECTS) $(testsms_LDADD) $(LIBS) +testsms2$(EXEEXT): $(testsms2_OBJECTS) $(testsms2_DEPENDENCIES) + @rm -f testsms2$(EXEEXT) + $(CXXLINK) $(testsms2_LDFLAGS) $(testsms2_OBJECTS) $(testsms2_LDADD) $(LIBS) +testspb$(EXEEXT): $(testspb_OBJECTS) $(testspb_DEPENDENCIES) + @rm -f testspb$(EXEEXT) + $(CXXLINK) $(testspb_LDFLAGS) $(testspb_OBJECTS) $(testspb_LDADD) $(LIBS) +testssms$(EXEEXT): $(testssms_OBJECTS) $(testssms_DEPENDENCIES) + @rm -f testssms$(EXEEXT) + $(CXXLINK) $(testssms_LDFLAGS) $(testssms_OBJECTS) $(testssms_LDADD) $(LIBS) + +mostlyclean-compile: + -rm -f *.$(OBJEXT) core *.core + +distclean-compile: + -rm -f *.tab.c + +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testcb.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testgsmlib.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testparser.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testpb.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testpb2.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testsms.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testsms2.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testspb.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/testssms.Po@am__quote@ + +distclean-depend: + -rm -rf ./$(DEPDIR) + +.cc.o: +@AMDEP_TRUE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(CXXCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$< + +.cc.obj: +@AMDEP_TRUE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(CXXCOMPILE) -c -o $@ `cygpath -w $<` + +.cc.lo: +@AMDEP_TRUE@ source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ +@AMDEP_TRUE@ depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@ +@AMDEP_TRUE@ $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ + $(LTCXXCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$< +CXXDEPMODE = @CXXDEPMODE@ + +mostlyclean-libtool: + -rm -f *.lo + +clean-libtool: + -rm -rf .libs _libs + +distclean-libtool: + -rm -f libtool +uninstall-info-am: + +ETAGS = etags +ETAGSFLAGS = + +tags: TAGS + +ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | \ + $(AWK) ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + mkid -fID $$unique + +TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \ + $(TAGS_FILES) $(LISP) + tags=; \ + here=`pwd`; \ + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | \ + $(AWK) ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + test -z "$(ETAGS_ARGS)$$tags$$unique" \ + || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ + $$tags $$unique + +GTAGS: + here=`$(am__cd) $(top_builddir) && pwd` \ + && cd $(top_srcdir) \ + && gtags -i $(GTAGS_ARGS) $$here + +distclean-tags: + -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH + +check-TESTS: $(TESTS) + @failed=0; all=0; xfail=0; xpass=0; \ + srcdir=$(srcdir); export srcdir; \ + list='$(TESTS)'; \ + if test -n "$$list"; then \ + for tst in $$list; do \ + if test -f ./$$tst; then dir=./; \ + elif test -f $$tst; then dir=; \ + else dir="$(srcdir)/"; fi; \ + if $(TESTS_ENVIRONMENT) $${dir}$$tst; then \ + all=`expr $$all + 1`; \ + case " $(XFAIL_TESTS) " in \ + *" $$tst "*) \ + xpass=`expr $$xpass + 1`; \ + failed=`expr $$failed + 1`; \ + echo "XPASS: $$tst"; \ + ;; \ + *) \ + echo "PASS: $$tst"; \ + ;; \ + esac; \ + elif test $$? -ne 77; then \ + all=`expr $$all + 1`; \ + case " $(XFAIL_TESTS) " in \ + *" $$tst "*) \ + xfail=`expr $$xfail + 1`; \ + echo "XFAIL: $$tst"; \ + ;; \ + *) \ + failed=`expr $$failed + 1`; \ + echo "FAIL: $$tst"; \ + ;; \ + esac; \ + fi; \ + done; \ + if test "$$failed" -eq 0; then \ + if test "$$xfail" -eq 0; then \ + banner="All $$all tests passed"; \ + else \ + banner="All $$all tests behaved as expected ($$xfail expected failures)"; \ + fi; \ + else \ + if test "$$xpass" -eq 0; then \ + banner="$$failed of $$all tests failed"; \ + else \ + banner="$$failed of $$all tests did not behave as expected ($$xpass unexpected passes)"; \ + fi; \ + fi; \ + dashes=`echo "$$banner" | sed s/./=/g`; \ + echo "$$dashes"; \ + echo "$$banner"; \ + echo "$$dashes"; \ + test "$$failed" -eq 0; \ + else :; fi +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) + +top_distdir = .. +distdir = $(top_distdir)/$(PACKAGE)-$(VERSION) + +distdir: $(DISTFILES) + @list='$(DISTFILES)'; for file in $$list; do \ + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ + dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \ + if test "$$dir" != "$$file" && test "$$dir" != "."; then \ + dir="/$$dir"; \ + $(mkinstalldirs) "$(distdir)$$dir"; \ + else \ + dir=''; \ + fi; \ + if test -d $$d/$$file; then \ + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ + cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ + fi; \ + cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ + else \ + test -f $(distdir)/$$file \ + || cp -p $$d/$$file $(distdir)/$$file \ + || exit 1; \ + fi; \ + done +check-am: all-am + $(MAKE) $(AM_MAKEFLAGS) check-TESTS +check: check-am +all-am: Makefile $(PROGRAMS) + +installdirs: + +install: install-am +install-exec: install-exec-am +install-data: install-data-am +uninstall: uninstall-am + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am + +installcheck: installcheck-am +install-strip: + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + INSTALL_STRIP_FLAG=-s \ + `test -z '$(STRIP)' || \ + echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -rm -f Makefile $(CONFIG_CLEAN_FILES) + +maintainer-clean-generic: + @echo "This command is intended for maintainers to use" + @echo "it deletes files that may require special tools to rebuild." +clean: clean-am + +clean-am: clean-generic clean-libtool clean-noinstPROGRAMS \ + mostlyclean-am + +distclean: distclean-am + +distclean-am: clean-am distclean-compile distclean-depend \ + distclean-generic distclean-libtool distclean-tags + +dvi: dvi-am + +dvi-am: + +info: info-am + +info-am: + +install-data-am: + +install-exec-am: + +install-info: install-info-am + +install-man: + +installcheck-am: + +maintainer-clean: maintainer-clean-am + +maintainer-clean-am: distclean-am maintainer-clean-generic + +mostlyclean: mostlyclean-am + +mostlyclean-am: mostlyclean-compile mostlyclean-generic \ + mostlyclean-libtool + +uninstall-am: uninstall-info-am + +.PHONY: GTAGS all all-am check check-TESTS check-am clean clean-generic \ + clean-libtool clean-noinstPROGRAMS distclean distclean-compile \ + distclean-depend distclean-generic distclean-libtool \ + distclean-tags distdir dvi dvi-am info info-am install \ + install-am install-data install-data-am install-exec \ + install-exec-am install-info install-info-am install-man \ + install-strip installcheck installcheck-am installdirs \ + maintainer-clean maintainer-clean-generic mostlyclean \ + mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ + tags uninstall uninstall-am uninstall-info-am + +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runparser.sh b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runparser.sh new file mode 100644 index 0000000000..9ee9d312f5 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runparser.sh @@ -0,0 +1,12 @@ +#!/bin/sh + +errorexit() { + echo $1 + exit 1 +} + +# run the test +./testparser > testparser.log + +# check if output differs from what it should be +diff testparser.log testparser-output.txt diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runsms.sh b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runsms.sh new file mode 100644 index 0000000000..f027544ee7 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runsms.sh @@ -0,0 +1,18 @@ +#!/bin/sh + +errorexit() { + echo $1 + exit 1 +} + +# prepare locales to make date format reproducible +LC_ALL=en_US +LANG=en +LINGUAS=en +export LC_ALL LANG LINGUAS + +# run the test +./testsms > testsms.log + +# check if output differs from what it should be +diff testsms.log testsms-output.txt diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspb.sh b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspb.sh new file mode 100644 index 0000000000..fb8c6200f8 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspb.sh @@ -0,0 +1,17 @@ +#!/bin/sh + +errorexit() { + echo $1 + exit 1 +} + +cp spb.pb spb-copy.pb || errorexit "could not copy spb.pb to spb-copy.pb" + +# run the test +./testspb > testspb.log + +# add new contents of phonebook file to the test log +cat spb-copy.pb >> testspb.log + +# check if output differs from what it should be +diff testspb.log testspb-output.txt diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspb2.sh b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspb2.sh new file mode 100644 index 0000000000..df8f123cae --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspb2.sh @@ -0,0 +1,17 @@ +#!/bin/sh + +errorexit() { + echo $1 + exit 1 +} + +cp spb2.pb spb-copy.pb || errorexit "could not copy spb2.pb to spb2-copy.pb" + +# run the test +./testspb > testspb2.log + +# add new contents of phonebook file to the test log +cat spb-copy.pb >> testspb2.log + +# check if output differs from what it should be +diff testspb2.log testspb2-output.txt diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspbi.sh b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspbi.sh new file mode 100644 index 0000000000..94b5b459a4 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runspbi.sh @@ -0,0 +1,18 @@ +#!/bin/sh + +errorexit() { + echo $1 + exit 1 +} + +cp spbi2-orig.pb spbi2.pb || + errorexit "could not copy spbi2-orig.pb to spbi2.pb" + +# run the test +../apps/gsmpb -V -i -s spbi1.pb -d spbi2.pb > testspbi.log + +# add new contents of phonebook file to the test log +cat spbi2.pb >> testspbi.log + +# check if output differs from what it should be +diff testspbi.log testspbi-output.txt diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runssms.sh b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runssms.sh new file mode 100644 index 0000000000..5b11442189 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/runssms.sh @@ -0,0 +1,21 @@ +#!/bin/sh + +errorexit() { + echo $1 + exit 1 +} + +rm -f sms.sms || errorexit "could not delete sms.sms" +touch sms.sms || errorexit "could not create sms.sms" + +# prepare locales to make date format reproducible +LC_ALL=en_US +LANG=en +LINGUAS=en +export LC_ALL LANG LINGUAS + +# run the test +./testssms > testssms.log + +# check if output differs from what it should be +diff testssms.log testssms-output.txt diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spb.pb b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spb.pb new file mode 100644 index 0000000000..debd672369 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spb.pb @@ -0,0 +1,11 @@ +|Dieter Meier|793045 +|Edgar Hofmann|42345 +|Goethe|847159 +|Hans Hofmann|12345 +|Hans-Dieter Schmidt|82345 +|Hans-Dieter Schmidt|13333345 +|Heiner Müller|7890 +|line with \||0815 +|line with\\|0815 +|One line\rback to start|0815 +|two\nline|0815 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spb2.pb b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spb2.pb new file mode 100644 index 0000000000..ed0c16cc73 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spb2.pb @@ -0,0 +1,11 @@ +|Dieter Meier|017793045 +|Edgar Hofmann|+4942345 +|Goethe|847159 +|Hans Hofmann|0171 +|Hans-Dieter Schmidt|82345 +|Hans-Dieter Schmidt|13333345 +|Heiner Müller|7890 +|line with \||0815 +|line with\\|0815 +|One line\rback to start|0815 +|two\nline|0815 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spbi1.pb b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spbi1.pb new file mode 100644 index 0000000000..11b913f254 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spbi1.pb @@ -0,0 +1,3 @@ +1|Nummer 4|4444444 +3|Nummer 3|3333333 +5|same name|12345 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spbi2-orig.pb b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spbi2-orig.pb new file mode 100644 index 0000000000..90f2337bbd --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/spbi2-orig.pb @@ -0,0 +1,4 @@ +2|Nummer 3|3333333 +4|Nummer 4|4444444 +5|same name|23456 + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testcb.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testcb.cc new file mode 100644 index 0000000000..59617d864f --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testcb.cc @@ -0,0 +1,40 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: testcb.cc +// * +// * Purpose: Test cell broadcast SMS +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 3.8.2001 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +int main(int argc, char *argv[]) +{ + try + { + CBMessageRef cbm = new CBMessage("001000320111C3343D0F82C51A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D100"); + + cout << cbm->toString(); + + cbm = new CBMessage("001000320111C4EAB3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D168341A8D46A3D100"); + + cout << cbm->toString(); + } + catch (GsmException &ge) + { + cerr << argv[0] << _("[ERROR]: ") << ge.what() << endl; + } +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testgsmlib.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testgsmlib.cc new file mode 100644 index 0000000000..d3fac84f5c --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testgsmlib.cc @@ -0,0 +1,178 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: testgsmlib.cc +// * +// * Purpose: Test general gsm functions (without SMS/phonebook) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 17.5.1999 +// ************************************************************************* +#ifdef HAVE_CONFIG_H +#include +#endif +#ifdef WIN32 +#include +#else +#include +#endif +#include +#include + +using namespace std; +using namespace gsmlib; + +// some time-consuming tests can be switched off by commenting out the +// following macros +#define TEST_OPERATOR_INFO + +void printForwardReason(string s, ForwardInfo &info) +{ + cout << " " << s << ": " + << (info._active ? "active " : "inactive ") + << "number: " << info._number + << " subaddr: " << info._subAddr + << " time: " << info._time << endl; +} + +int main(int argc, char *argv[]) +{ + try + { + cout << (string)"Opening device " + argv[1] << endl; +#ifdef WIN32 + Ref port = new Win32SerialPort((string)argv[1], 38400); +#else + Ref port = new UnixSerialPort((string)argv[1], B38400); +#endif + + cout << "Creating MeTa object" << endl; + MeTa m(port); + + cout << "Getting ME info" << endl; + MEInfo mei = m.getMEInfo(); + + cout << " Manufacturer: " << mei._manufacturer << endl + << " Model: " << mei._model << endl + << " Revision: " << mei._revision << endl + << " Serial Number: " << mei._serialNumber << endl << endl; + +#ifdef TEST_OPERATOR_INFO + try + { + cout << "Getting operator info" << endl; + vector opis = m.getAvailableOPInfo(); + for (vector::iterator i = opis.begin(); i != opis.end(); ++i) + { + cout << " Status: "; + switch (i->_status) + { + case 0: cout << "unknown"; break; + case 1: cout << "current"; break; + case 2: cout << "available"; break; + case 3: cout << "forbidden"; break; + } + cout << endl + << " Long name: '" << i->_longName << "' " + << " Short name: '" << i->_shortName << "' " + << " Numeric name: " << i->_numericName << endl; + } + } + catch (GsmException &ge) + { + if (ge.getErrorCode() == 0) + cout << "phone failure ignored" << endl; + else + throw; + } + cout << endl; +#endif // TEST_OPERATOR_INFO + + cout << "Current operator info" << endl; + OPInfo opi = m.getCurrentOPInfo(); + cout << " Long name: '" << opi._longName << "' " + << " Short name: '" << opi._shortName << "' " + << " Numeric name: " << opi._numericName << endl + << " Mode: "; + switch (opi._mode) + { + case 0: cout << "automatic"; break; + case 1: cout << "manual"; break; + case 2: cout << "deregister"; break; + case 4: cout << "manual/automatic"; break; + } + cout << endl; + + cout << "Facility lock capabilities" << endl << " "; + vector fclc = m.getFacilityLockCapabilities(); + for (vector::iterator i = fclc.begin(); i != fclc.end(); ++i) + cout << *i << " "; + cout << endl << endl; + + cout << "Facility lock states" << endl; + for (vector::iterator k = fclc.begin(); k != fclc.end(); ++k) + if (*k != "AB" && *k != "AG" && *k != "AC") + { + cout << " " << *k; + if (m.getFacilityLockStatus(*k, VoiceFacility)) + cout << " Voice"; + if (m.getFacilityLockStatus(*k, DataFacility)) + cout << " Data"; + if (m.getFacilityLockStatus(*k, FaxFacility)) + cout << " Fax"; + } + cout << endl; + + cout << "Facilities with password" << endl; + vector pwi = m.getPasswords(); + for (vector::iterator j = pwi.begin(); j != pwi.end(); ++j) + cout << " " << j->_facility << " len " << j->_maxPasswdLen << endl; + cout << endl; + + cout << "Network caller line identification identification: " + << (m.getNetworkCLIP() ? "on" : "off") << endl << endl; + + cout << "Call forwarding information" << endl; + for (int r = 0; r < 4; ++r) + { + switch (r) + { + case 0: cout << "UnconditionalReason" << endl; break; + case 1: cout << "MobileBusyReason" << endl; break; + case 2: cout << "NoReplyReason" << endl; break; + case 3: cout << "NotReachableReason" << endl; break; + } + ForwardInfo voice, fax, data; + m.getCallForwardInfo((ForwardReason)r, voice, fax, data); + printForwardReason("Voice", voice); + printForwardReason("Data", data); + printForwardReason("Fax", fax); + } + cout << endl; + + cout << "Battery charge status" << endl; + int bcs = m.getBatteryChargeStatus(); + switch (bcs) + { + case 0: cout << "ME is powered by the battery" << endl; break; + case 1: cout << "ME has a battery connected, but is not powered by it" + << endl; break; + case 2: cout << "ME does not have a battery connected" << endl; break; + case 3: cout << "Recognized power fault, calls inhibited" << endl; break; + } + cout << endl; + + cout << "Battery charge: " << m.getBatteryCharge() << endl << endl; + + cout << "Signal strength: " << m.getSignalStrength() << endl << endl; + + cout << "Bit error rate: " << m.getBitErrorRate() << endl << endl; + } + catch (GsmException &ge) + { + cerr << "GsmException '" << ge.what() << "'" << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testparser-output.txt b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testparser-output.txt new file mode 100644 index 0000000000..a5b16e7fb3 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testparser-output.txt @@ -0,0 +1,22 @@ +Test 1 +(),("ME","SM","Which of the three items does not belong here?") + +Test 2 +(1-5),425,"+abcd"efgh" + +Test 3 +(1,2,3,4,5,7,11,12,25),425,Thisisatest."+a"ef"andsoforth + +Test 4 +(1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125),(20),16 + +Test 5 +SM,7 + +Test 6 +(2,"S TELIA MOBITEL","S TELIA",24001) + +Error 1: expected ')' (at position 4 of string '(4-5') + +Error 3: expected end of line (at position 5 of string '"bla"bla"') + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testparser.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testparser.cc new file mode 100644 index 0000000000..99b178d197 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testparser.cc @@ -0,0 +1,200 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: testparser.cc +// * +// * Purpose: Test AT result code parser +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 17.5.1999 +// ************************************************************************* + +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +void printIntList(vector &vb) +{ + cout << "("; + int j = 0; + bool first = true; + for (vector::iterator i = vb.begin(); + i != vb.end(); ++i) + { + if (*i) + { + if (! first) cout << ","; + cout << j; + first = false; + } + ++j; + } + cout << ")"; +} + +void printIntRange(IntRange ir) +{ + cout << "(" << ir._low << "-" << ir._high << ")"; +} + +void printStringList(vector vs) +{ + bool first = true; + cout << "("; + for (vector::iterator i = vs.begin(); + i != vs.end(); ++i) + { + if (! first) cout << ","; + cout << "\"" << *i << "\""; + first = false; + } + cout << ")"; +} + +int main(int argc, char *argv[]) +{ + try + { + { + cout << "Test 1" << endl; + Parser p((string)",(\"ME\", \"SM\"," + + "\"Which of the three items does not belong here?\")"); + + vector vs1 = p.parseStringList(true); + p.parseComma(); + vector vs2 = p.parseStringList(); + bool comma = p.parseComma(true); + + printStringList(vs1); + cout << ","; + printStringList(vs2); + if (comma) cout << ","; + cout << endl << endl; + } + { + cout << "Test 2" << endl; + Parser p("(1-5),425,\"+abcd\"efgh\""); + + IntRange ir = p.parseRange(); + p.parseComma(); + int i = p.parseInt(); + p.parseComma(); + string s = p.parseString(false, true); + + printIntRange(ir); + cout << "," << i << ",\"" << s << "\"" << endl << endl; + } + { + cout << "Test 3" << endl; + Parser p("(7,1-5,12-11,25),425,This is a test.\"+a\"ef\" and so forth"); + + vector vb = p.parseIntList(); + p.parseComma(); + int i = p.parseInt(); + p.parseComma(); + string s = p.parseEol(); + + printIntList(vb); + cout << "," << i << "," << s << endl << endl; + } + { + cout << "Test 4" << endl; + Parser p("(1-125),20,16"); + + vector vb = p.parseIntList(); + p.parseComma(); + vector vb2 = p.parseIntList(); + p.parseComma(); + int j = p.parseInt(); + + printIntList(vb); + cout << ","; + printIntList(vb2); + cout << "," << j << endl << endl; + } + { + cout << "Test 5" << endl; + Parser p("SM,7"); + + string s = p.parseString(); + p.parseComma(); + int i = p.parseInt(); + + cout << s << "," << i << endl << endl; + } + { + cout << "Test 6" << endl; + Parser p("(2,\"S TELIA MOBITEL\",\"S TELIA\",\"24001\")"); + + p.parseChar('('); + int status = p.parseInt(); + p.parseComma(); + string longName = p.parseString(true); + p.parseComma(); + string shortName = p.parseString(true); + p.parseComma(); + int numericName; + try + { + numericName = p.parseInt(true); + } + catch (GsmException &e) + { + if (e.getErrorClass() == ParserError) + { + // the Ericsson GM12 GSM modem returns the numeric ID as string + string s = p.parseString(); + numericName = checkNumber(s); + } + else + throw e; + } + p.parseChar(')'); + + cout << "(" << status << ",\"" << longName << "\",\"" + << shortName << "\"," + << numericName << ")" << endl << endl; + } + } + catch (GsmException &p) + { + // these tests shouldn't throw exceptions + assert(0); + } + + // Now some tests that should provoke an error + try + { + Parser p("(4-5"); + p.parseRange(); + } + catch (GsmException &p) + { + cout << "Error 1: " << p.what() << endl << endl; + } + try + { + Parser p("(4-5,3-4-5)"); + p.parseIntList(); + } + catch (GsmException &p) + { + cout << "Error 2: " << p.what() << endl << endl; + } + try + { + Parser p("\"bla\"bla\""); + p.parseString(); + p.checkEol(); + } + catch (GsmException &p) + { + cout << "Error 3: " << p.what() << endl << endl; + } + +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testpb.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testpb.cc new file mode 100644 index 0000000000..6f161349ef --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testpb.cc @@ -0,0 +1,52 @@ +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +void printPb(PhonebookEntry &e) +{ + cout << "number: " << e.telephone() + << " text: " << e.text() << endl; +} + +int main(int argc, char *argv[]) +{ + try + { + cout << (string)"Opening device " + argv[1] << endl; + Ref port = new UnixSerialPort((string)argv[1], B38400); + + cout << "Creating MeTa object" << endl; + MeTa m(port); + + cout << "Getting phonebook entries" << endl; + vector pbs = m.getPhoneBookStrings(); + for (vector::iterator i = pbs.begin(); i != pbs.end(); ++i) + { + PhonebookRef pb = m.getPhonebook(*i); + + cout << "Phonebook \"" << *i << "\" " << endl + << " Max number length: " << pb->getMaxTelephoneLen() << endl + << " Max text length: " << pb->getMaxTextLen() << endl + << " Capacity: " << pb->capacity() << endl + << " Size: " << pb->size() << endl; + + for (Phonebook::iterator j = pb->begin(); j != pb->end(); ++j) + if (! j->empty()) + cout << " Entry #" << j - pb->begin() + << "Number: \"" << j->telephone() << "\"" + << "Text: \"" << j->text() << "\"" << endl; + } + } + catch (GsmException &ge) + { + cerr << "GsmException '" << ge.what() << "'" << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testpb2.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testpb2.cc new file mode 100644 index 0000000000..f9769f9bfc --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testpb2.cc @@ -0,0 +1,75 @@ +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +bool isbla(PhonebookEntry &e) +{ + // cerr << "****'" << e.text() << "'" << endl; + return e.text() == "blabla"; +} + +int main(int argc, char *argv[]) +{ + try + { + cout << (string)"Opening device " + argv[1] << endl; + Ref port = new UnixSerialPort((string)argv[1], B38400); + + cout << "Creating MeTa object" << endl; + MeTa m(port); + + cout << "Getting phonebook entries" << endl; + vector pbs = m.getPhoneBookStrings(); + if (pbs.begin() == pbs.end()) + { + cerr << "no phonebooks available" << endl; + exit(1); + } + + PhonebookRef pb = m.getPhonebook(*pbs.begin()); + + cout << "Phonebook \"" << pb->name() << "\" " << endl + << " Max number length: " << pb->getMaxTelephoneLen() << endl + << " Max text length: " << pb->getMaxTextLen() << endl + << " Capacity: " << pb->capacity() << endl; + + cout << "Inserting entry 'blabla'" << endl; + PhonebookEntry e("123456", "blabla"); + pb->insert(pb->end(), e); + + int j = -1; + for (int i = 50; i < 60; ++i) + if (pb()[i].empty()) + { + pb()[i].set("23456", "blabla"); + j = i; + break; + } + + pb->erase(pb->begin() + j); + + Phonebook::iterator k; + do + { + k = find_if(pb->begin(), pb->end(), isbla); + if (k != pb->end()) + { + cerr << "Erasing #" << k - pb->begin() << endl; + pb->erase(k, k + 1); + } + } + while (k != pb->end()); + } + catch (GsmException &ge) + { + cerr << "GsmException '" << ge.what() << "'" << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms-output.txt b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms-output.txt new file mode 100644 index 0000000000..bee3c53bac --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms-output.txt @@ -0,0 +1,167 @@ +--------------------------------------------------------------------------- +Message type: SMS-DELIVER +SC address: '491710762100' +More messages to send: 1 +Reply path: 0 +User data header indicator: 0 +Status report indication: 0 +Originating address: '171' +Protocol identifier: 0x39 +Data coding scheme: default alphabet +SC timestamp: 04/16/1999 08:09:44 AM (+0200) +User data length: 160 +User data header: 0x +User data: 'T-D1 News bis 31.05.99 kostenlos testen! Über 90 Programme aus Politik, Wirtschaft, Börse, Sport direkt per SMS aufs Handy. Mehr darüber unter der Kurzwahl 2323' +--------------------------------------------------------------------------- + + +--------------------------------------------------------------------------- +Message type: SMS-DELIVER +SC address: '491710762100' +More messages to send: 1 +Reply path: 0 +User data header indicator: 0 +Status report indication: 0 +Originating address: '01805000102' +Protocol identifier: 0x39 +Data coding scheme: default alphabet +SC timestamp: 12/17/1998 02:10:55 PM (+0100) +User data length: 159 +User data header: 0x +User data: 'Nicht vergessen! Die XtraWeihnachtsverlosung läuft noch bis zum 24.12. Nutzen Sie jetzt Ihre Gewinnchance und faxen Sie Ihren Teiln.-Gutschein an 0180/5000 056' +--------------------------------------------------------------------------- + + +--------------------------------------------------------------------------- +Message type: SMS-DELIVER +SC address: '41794991200' +More messages to send: 1 +Reply path: 0 +User data header indicator: 0 +Status report indication: 0 +Originating address: 'dialing.de ' +Protocol identifier: 0x39 +Data coding scheme: default alphabet +SC timestamp: 04/21/2001 12:15:28 PM (+0000) +User data length: 0 +User data header: 0x +User data: '' +--------------------------------------------------------------------------- + + +--------------------------------------------------------------------------- +Message type: SMS-DELIVER +SC address: '41794991200' +More messages to send: 1 +Reply path: 0 +User data header indicator: 0 +Status report indication: 0 +Originating address: 'dialing.de ' +Protocol identifier: 0x39 +Data coding scheme: default alphabet +SC timestamp: 04/21/2001 12:15:28 PM (+0000) +User data length: 0 +User data header: 0x +User data: '' +--------------------------------------------------------------------------- + + +--------------------------------------------------------------------------- +Message type: SMS-DELIVER +SC address: '' +More messages to send: 0 +Reply path: 0 +User data header indicator: 0 +Status report indication: 0 +Originating address: '' +Protocol identifier: 0x0 +Data coding scheme: default alphabet +SC timestamp: 00/00/2000 12:00:00 AM (+0000) +User data length: 0 +User data header: 0x +User data: '' +--------------------------------------------------------------------------- + + +--------------------------------------------------------------------------- +Message type: SMS-DELIVER +SC address: '' +More messages to send: 0 +Reply path: 0 +User data header indicator: 0 +Status report indication: 0 +Originating address: '' +Protocol identifier: 0x0 +Data coding scheme: default alphabet +SC timestamp: 00/00/2000 12:00:00 AM (+0000) +User data length: 0 +User data header: 0x +User data: '' +--------------------------------------------------------------------------- + + +--------------------------------------------------------------------------- +Message type: SMS-DELIVER-REPORT +SC address: '' +Protocol identifier present: 0 +Data coding scheme present: 0 +User data length present: 0 +--------------------------------------------------------------------------- + + +--------------------------------------------------------------------------- +Message type: SMS-STATUS-REPORT +SC address: '' +More messages to send: 0 +Status report qualifier: 0 +Message reference: 0 +Recipient address: '' +SC timestamp: 00/00/2000 12:00:00 AM (+0000) +Discharge time: 00/00/2000 12:00:00 AM (+0000) +Status: 0x0 'Short message received by the SME' +--------------------------------------------------------------------------- + + +--------------------------------------------------------------------------- +Message type: SMS-COMMAND +SC address: '' +Message reference: 0 +Status report request: 1 +Protocol identifier: 0x0 +Command type: 0x0 +Message number: 0 +Destination address: '' +Command data length: 0 +Command data: '' +--------------------------------------------------------------------------- + + +--------------------------------------------------------------------------- +Message type: SMS-SUBMIT +SC address: '' +Reject duplicates: 1 +Validity period format: relative +Reply path: 0 +User data header indicator: 0 +Status report request: 0 +Message reference: 0 +Destination address: '' +Protocol identifier: 0x0 +Data coding scheme: default alphabet +Validity period: 2 days +User data length: 35 +User data header: 0x +User data: 'This is a submit message, isn't it?' +--------------------------------------------------------------------------- + + +--------------------------------------------------------------------------- +Message type: SMS-SUBMIT-REPORT +SC address: '' +SC timestamp: 00/00/2000 12:00:00 AM (+0000) +Protocol identifier present: 0 +Data coding scheme present: 0 +User data length present: 0 +--------------------------------------------------------------------------- + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms.cc new file mode 100644 index 0000000000..bf5423b057 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms.cc @@ -0,0 +1,80 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: testsms.cc +// * +// * Purpose: Test coder and encoder for SMS TPDUs +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 17.5.1999 +// ************************************************************************* + +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include + +using namespace std; +using namespace gsmlib; + +int main(int argc, char *argv[]) +{ + string pdu; + SMSMessageRef sms; + // test two SMS message I have received + sms = SMSMessage::decode("079194710167120004038571F1390099406180904480A0D41631067296EF7390383D07CD622E58CD95CB81D6EF39BDEC66BFE7207A794E2FBB4320AFB82C07E56020A8FC7D9687DBED32285C9F83A06F769A9E5EB340D7B49C3E1FA3C3663A0B24E4CBE76516680A7FCBE920725A5E5ED341F0B21C346D4E41E1BA790E4286DDE4BC0BD42CA3E5207258EE1797E5A0BA9B5E9683C86539685997EBEF61341B249BC966"); + cout << sms->toString() << endl; + + sms = SMSMessage::decode("0791947101671200040B851008050001F23900892171410155409FCEF4184D07D9CBF273793E2FBB432062BA0CC2D2E5E16B398D7687C768FADC5E96B3DFF3BAFB0C62EFEB663AC8FD1EA341E2F41CA4AFB741329A2B2673819C75BABEEC064DD36590BA4CD7D34149B4BC0C3A96EF69B77B8C0EBBC76550DD4D0699C3F8B21B344D974149B4BCEC0651CB69B6DBD53AD6E9F331BA9C7683C26E102C8683BD6A30180C04ABD900"); + cout << sms->toString() << endl; + + // test SMS decoding and encoding for messages with alphanumeric + // destination address + sms = SMSMessage::decode("07911497941902F00414D0E474989D769F5DE4320839001040122151820000"); + cout << sms->toString() << endl; + pdu = sms->encode(); + sms = SMSMessage::decode(pdu); + cout << sms->toString() << endl; + + // test all message types + sms = new SMSDeliverMessage(); + cout << sms->toString() << endl; + pdu = sms->encode(); + sms = SMSMessage::decode(pdu); + cout << sms->toString() << endl; + + // test all message types + sms = new SMSDeliverReportMessage(); + pdu = sms->encode(); + sms = SMSMessage::decode(pdu, false); + cout << sms->toString() << endl; + + // test all message types + sms = new SMSStatusReportMessage(); + pdu = sms->encode(); + sms = SMSMessage::decode(pdu); + cout << sms->toString() << endl; + + // test all message types + sms = new SMSCommandMessage(); + pdu = sms->encode(); + sms = SMSMessage::decode(pdu, false); + cout << sms->toString() << endl; + + // test all message types + SMSSubmitMessage *subsms = new SMSSubmitMessage(); + subsms->setUserData("This is a submit message, isn't it?"); + sms = subsms; + pdu = sms->encode(); + sms = SMSMessage::decode(pdu, false); + cout << sms->toString() << endl; + + // test all message types + sms = new SMSSubmitReportMessage(); + pdu = sms->encode(); + sms = SMSMessage::decode(pdu); + cout << sms->toString() << endl; + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms2.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms2.cc new file mode 100644 index 0000000000..cb9b395a86 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testsms2.cc @@ -0,0 +1,89 @@ +#ifdef HAVE_CONFIG_H +#include +#endif +#ifdef WIN32 +#include +#else +#include +#endif +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +int main(int argc, char *argv[]) +{ + try + { + cout << (string)"Opening device " + argv[1] << endl; +#ifdef WIN32 + Ref port = new Win32SerialPort((string)argv[1], 38400); +#else + Ref port = new UnixSerialPort((string)argv[1], B38400); +#endif + + cout << "Creating MeTa object" << endl; + MeTa m(port); + + cout << "Setting message service level to 1" << endl; + m.setMessageService(1); + + vector storeList = m.getSMSStoreNames(); + + for (vector::iterator stn = storeList.begin(); + stn != storeList.end(); ++stn) + { + cout << "Getting store \"" << *stn << "\"" << endl; + SMSStoreRef st = m.getSMSStore(*stn); + + SMSMessageRef sms; + cout << "Creating SMS Submit Message and putting it into store" << endl; + SMSSubmitMessage *subsms = new SMSSubmitMessage(); +// Address scAddr("+491710760000"); +// subsms->setServiceCentreAddress(scAddr); + Address destAddr("0177123456"); + subsms->setDestinationAddress(destAddr); + subsms->setUserData("This message was sent from the store."); + TimePeriod tp; + tp._format = TimePeriod::Relative; + tp._relativeTime = 100; + /*subsms->setValidityPeriod(tp); + subsms->setValidityPeriodFormat(tp._format); + subsms->setStatusReportRequest(true);*/ + sms = subsms; + SMSStore::iterator smsIter = st->insert(st->end(), SMSStoreEntry(sms)); + cout << "Message entered at index #" + << smsIter - st->begin() << endl; + + //m.sendSMS(sms); + SMSMessageRef ackPdu; + int messageRef = smsIter->send(ackPdu); + cout << "Message reference: " << messageRef << endl + << "ACK PDU:" << endl + << (ackPdu.isnull() ? "no ack pdu" : ackPdu->toString()) + << endl; + + /* cout << "Erasing all unsent messages" << endl; + for (SMSStore::iterator s = st->begin(); s != st->end(); ++s) + if (! s->empty() && s->status() == SMSStoreEntry::StoredUnsent) + st->erase(s);*/ + + cout << "Printing store \"" << *stn << "\"" << endl; + for (SMSStore::iterator s = st->begin(); s != st->end(); ++s) + if (! s->empty()) + cout << s->message()->toString(); + + break; // only do one store + } + } + catch (GsmException &ge) + { + cerr << "GsmException '" << ge.what() << "'" << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb-output.txt b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb-output.txt new file mode 100644 index 0000000000..83a56fa9f9 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb-output.txt @@ -0,0 +1,47 @@ +Entries in pbs-copy.pb: + Text: Dieter Meier Telephone: 793045 + Text: Edgar Hofmann Telephone: 42345 + Text: Goethe Telephone: 847159 + Text: Hans Hofmann Telephone: 12345 + Text: Hans-Dieter Schmidt Telephone: 82345 + Text: Hans-Dieter Schmidt Telephone: 13333345 + Text: Heiner Müller Telephone: 7890 + Text: line with | Telephone: 0815 + Text: line with\ Telephone: 0815 + Text: One line back to start Telephone: 0815 + Text: two +line Telephone: 0815 +Removing entries with telephone == 0815 +Entries in pbs-copy.pb<2>: + Text: Hans Hofmann Telephone: 12345 + Text: Hans-Dieter Schmidt Telephone: 13333345 + Text: Edgar Hofmann Telephone: 42345 + Text: Heiner Müller Telephone: 7890 + Text: Dieter Meier Telephone: 793045 + Text: Hans-Dieter Schmidt Telephone: 82345 + Text: Goethe Telephone: 847159 +Inserting some entries +Entries in pbs-copy.pb<3>: + Text: Dieter Meier Telephone: 793045 + Text: Edgar Hofmann Telephone: 42345 + Text: Goethe Telephone: 847159 + Text: Hans Hofmann Telephone: 12345 + Text: Hans-Dieter Schmidt Telephone: 13333345 + Text: Hans-Dieter Schmidt Telephone: 41598254 + Text: Hans-Dieter Schmidt Telephone: 82345 + Text: Hans-Dieter|Hofmann Telephone: 34058 + Text: Heiner Müller Telephone: 7890 + Text: new line with continued Telephone: 08152 +Erasing all Hans-Dieter Schmidt entries +About to erase: + Text: Hans-Dieter Schmidt Telephone: 13333345 + Text: Hans-Dieter Schmidt Telephone: 41598254 + Text: Hans-Dieter Schmidt Telephone: 82345 +Writing back to file +|Dieter Meier|793045 +|Edgar Hofmann|42345 +|Goethe|847159 +|Hans Hofmann|12345 +|Hans-Dieter\|Hofmann|34058 +|Heiner Müller|7890 +|new line with \r continued|08152 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb.cc new file mode 100644 index 0000000000..43b9f512db --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb.cc @@ -0,0 +1,81 @@ +#ifdef HAVE_CONFIG_H +#include +#endif +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +void printPb(PhonebookEntry &e) +{ + cout << "number: " << e.telephone() + << " text: " << e.text() << endl; +} + +int main(int argc, char *argv[]) +{ + try + { + // open phonebook file + SortedPhonebook pb((string)"spb-copy.pb", false); + + // print all entries + cout << "Entries in pbs-copy.pb:" << endl; + for (SortedPhonebook::iterator i = pb.begin(); i != pb.end(); ++i) + cout << " Text: " << i->text() + << " Telephone: " << i->telephone() << endl; + + // remove all entries with telephone == "0815" + cout << "Removing entries with telephone == 0815" << endl; + pb.setSortOrder(ByTelephone); + + string s = "0815"; + pb.erase(s); + + cout << "Entries in pbs-copy.pb<2>:" << endl; + for (SortedPhonebook::iterator i = pb.begin(); i != pb.end(); ++i) + cout << " Text: " << i->text() + << " Telephone: " << i->telephone() << endl; + + // insert some entries + cout << "Inserting some entries" << endl; + pb.insert(PhonebookEntryBase("08152", "new line with \r continued")); + pb.insert(PhonebookEntryBase("41598254", "Hans-Dieter Schmidt")); + pb.insert(PhonebookEntryBase("34058", "Hans-Dieter|Hofmann")); + + pb.setSortOrder(ByText); + cout << "Entries in pbs-copy.pb<3>:" << endl; + for (SortedPhonebook::iterator i = pb.begin(); i != pb.end(); ++i) + cout << " Text: " << i->text() + << " Telephone: " << i->telephone() << endl; + + // test erasing all "Hans-Dieter Schmidt" entries + cout << "Erasing all Hans-Dieter Schmidt entries" << endl; + s = "Hans-Dieter Schmidt"; + pair range = + pb.equal_range(s); + cout << "About to erase:" << endl; + for (SortedPhonebook::iterator i = range.first; i != range.second; ++i) + cout << " Text: " << i->text() + << " Telephone: " << i->telephone() << endl; + + pb.erase(range.first, range.second); + + // write back to file + cout << "Writing back to file" << endl; + pb.sync(); + + // tests the NoCopy class + //SortedPhonebook pb2("spb.pb"); + //pb2 = pb; + } + catch (GsmException &ge) + { + cerr << "GsmException '" << ge.what() << "'" << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb2-output.txt b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb2-output.txt new file mode 100644 index 0000000000..60e54ba669 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspb2-output.txt @@ -0,0 +1,47 @@ +Entries in pbs-copy.pb: + Text: Dieter Meier Telephone: 017793045 + Text: Edgar Hofmann Telephone: +4942345 + Text: Goethe Telephone: 847159 + Text: Hans Hofmann Telephone: 0171 + Text: Hans-Dieter Schmidt Telephone: 82345 + Text: Hans-Dieter Schmidt Telephone: 13333345 + Text: Heiner Müller Telephone: 7890 + Text: line with | Telephone: 0815 + Text: line with\ Telephone: 0815 + Text: One line back to start Telephone: 0815 + Text: two +line Telephone: 0815 +Removing entries with telephone == 0815 +Entries in pbs-copy.pb<2>: + Text: Edgar Hofmann Telephone: +4942345 + Text: Hans Hofmann Telephone: 0171 + Text: Dieter Meier Telephone: 017793045 + Text: Hans-Dieter Schmidt Telephone: 13333345 + Text: Heiner Müller Telephone: 7890 + Text: Hans-Dieter Schmidt Telephone: 82345 + Text: Goethe Telephone: 847159 +Inserting some entries +Entries in pbs-copy.pb<3>: + Text: Dieter Meier Telephone: 017793045 + Text: Edgar Hofmann Telephone: +4942345 + Text: Goethe Telephone: 847159 + Text: Hans Hofmann Telephone: 0171 + Text: Hans-Dieter Schmidt Telephone: 13333345 + Text: Hans-Dieter Schmidt Telephone: 41598254 + Text: Hans-Dieter Schmidt Telephone: 82345 + Text: Hans-Dieter|Hofmann Telephone: 34058 + Text: Heiner Müller Telephone: 7890 + Text: new line with continued Telephone: 08152 +Erasing all Hans-Dieter Schmidt entries +About to erase: + Text: Hans-Dieter Schmidt Telephone: 13333345 + Text: Hans-Dieter Schmidt Telephone: 41598254 + Text: Hans-Dieter Schmidt Telephone: 82345 +Writing back to file +|Dieter Meier|017793045 +|Edgar Hofmann|+4942345 +|Goethe|847159 +|Hans Hofmann|0171 +|Hans-Dieter\|Hofmann|34058 +|Heiner Müller|7890 +|new line with \r continued|08152 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspbi-output.txt b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspbi-output.txt new file mode 100644 index 0000000000..e4a33e2fa6 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testspbi-output.txt @@ -0,0 +1,8 @@ +updating 'same name' tel# 23456 to new tel# 12345(index 5) +deleting 'Nummer 3' tel# 3333333 (index #2) +deleting 'Nummer 4' tel# 4444444 (index #4) +inserting 'Nummer 4' tel# 4444444 (index #1) +inserting 'Nummer 3' tel# 3333333 (index #3) +1|Nummer 4|4444444 +3|Nummer 3|3333333 +5|same name|12345 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testssms-output.txt b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testssms-output.txt new file mode 100644 index 0000000000..a0e7905939 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testssms-output.txt @@ -0,0 +1,157 @@ +Entries in sms.sms<0>: +Inserting some entries +Entries in sms.sms<1>: +Entry#2: +--------------------------------------------------------------------------- +Message type: SMS-SUBMIT +SC address: '' +Reject duplicates: 1 +Validity period format: relative +Reply path: 0 +User data header indicator: 0 +Status report request: 0 +Message reference: 0 +Destination address: '0177123456' +Protocol identifier: 0x0 +Data coding scheme: default alphabet +Validity period: 2 days +User data length: 9 +User data header: 0x +User data: 'submit me' +--------------------------------------------------------------------------- + + +Entry#3: +--------------------------------------------------------------------------- +Message type: SMS-SUBMIT +SC address: '' +Reject duplicates: 1 +Validity period format: relative +Reply path: 0 +User data header indicator: 0 +Status report request: 0 +Message reference: 0 +Destination address: '' +Protocol identifier: 0x0 +Data coding scheme: default alphabet +Validity period: 2 days +User data length: 35 +User data header: 0x +User data: 'This is a submit message, isn't it?' +--------------------------------------------------------------------------- + + +Entry#1: +--------------------------------------------------------------------------- +Message type: SMS-DELIVER +SC address: '491710762100' +More messages to send: 1 +Reply path: 0 +User data header indicator: 0 +Status report indication: 0 +Originating address: '01805000102' +Protocol identifier: 0x39 +Data coding scheme: default alphabet +SC timestamp: 12/17/1998 02:10:55 PM (+0100) +User data length: 159 +User data header: 0x +User data: 'Nicht vergessen! Die XtraWeihnachtsverlosung läuft noch bis zum 24.12. Nutzen Sie jetzt Ihre Gewinnchance und faxen Sie Ihren Teiln.-Gutschein an 0180/5000 056' +--------------------------------------------------------------------------- + + +Entry#0: +--------------------------------------------------------------------------- +Message type: SMS-DELIVER +SC address: '491710762100' +More messages to send: 1 +Reply path: 0 +User data header indicator: 0 +Status report indication: 0 +Originating address: '171' +Protocol identifier: 0x39 +Data coding scheme: default alphabet +SC timestamp: 04/16/1999 08:09:44 AM (+0200) +User data length: 160 +User data header: 0x +User data: 'T-D1 News bis 31.05.99 kostenlos testen! Über 90 Programme aus Politik, Wirtschaft, Börse, Sport direkt per SMS aufs Handy. Mehr darüber unter der Kurzwahl 2323' +--------------------------------------------------------------------------- + + +Entries in sms.sms<2>: +Entry#3: +--------------------------------------------------------------------------- +Message type: SMS-SUBMIT +SC address: '' +Reject duplicates: 1 +Validity period format: relative +Reply path: 0 +User data header indicator: 0 +Status report request: 0 +Message reference: 0 +Destination address: '' +Protocol identifier: 0x0 +Data coding scheme: default alphabet +Validity period: 2 days +User data length: 35 +User data header: 0x +User data: 'This is a submit message, isn't it?' +--------------------------------------------------------------------------- + + +Entry#2: +--------------------------------------------------------------------------- +Message type: SMS-SUBMIT +SC address: '' +Reject duplicates: 1 +Validity period format: relative +Reply path: 0 +User data header indicator: 0 +Status report request: 0 +Message reference: 0 +Destination address: '0177123456' +Protocol identifier: 0x0 +Data coding scheme: default alphabet +Validity period: 2 days +User data length: 9 +User data header: 0x +User data: 'submit me' +--------------------------------------------------------------------------- + + +Entry#1: +--------------------------------------------------------------------------- +Message type: SMS-DELIVER +SC address: '491710762100' +More messages to send: 1 +Reply path: 0 +User data header indicator: 0 +Status report indication: 0 +Originating address: '01805000102' +Protocol identifier: 0x39 +Data coding scheme: default alphabet +SC timestamp: 12/17/1998 02:10:55 PM (+0100) +User data length: 159 +User data header: 0x +User data: 'Nicht vergessen! Die XtraWeihnachtsverlosung läuft noch bis zum 24.12. Nutzen Sie jetzt Ihre Gewinnchance und faxen Sie Ihren Teiln.-Gutschein an 0180/5000 056' +--------------------------------------------------------------------------- + + +Entry#0: +--------------------------------------------------------------------------- +Message type: SMS-DELIVER +SC address: '491710762100' +More messages to send: 1 +Reply path: 0 +User data header indicator: 0 +Status report indication: 0 +Originating address: '171' +Protocol identifier: 0x39 +Data coding scheme: default alphabet +SC timestamp: 04/16/1999 08:09:44 AM (+0200) +User data length: 160 +User data header: 0x +User data: 'T-D1 News bis 31.05.99 kostenlos testen! Über 90 Programme aus Politik, Wirtschaft, Börse, Sport direkt per SMS aufs Handy. Mehr darüber unter der Kurzwahl 2323' +--------------------------------------------------------------------------- + + +Writing back to file diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testssms.cc b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testssms.cc new file mode 100644 index 0000000000..4c30bd544f --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/tests/testssms.cc @@ -0,0 +1,68 @@ +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace gsmlib; + +int main(int argc, char *argv[]) +{ + try + { + // open SMS store file + SortedSMSStore sms((string)"sms.sms"); + + // print all entries + cout << "Entries in sms.sms<0>:" << endl; + for (SortedSMSStore::iterator i = sms.begin(); i != sms.end(); ++i) + cout << "Entry#" << i->index() << ":" << endl + << i->message()->toString() << endl; + + // insert some entries + cout << "Inserting some entries" << endl; + SMSMessageRef smsMessage; + // test two SMS message I have received + smsMessage = SMSMessage::decode("079194710167120004038571F1390099406180904480A0D41631067296EF7390383D07CD622E58CD95CB81D6EF39BDEC66BFE7207A794E2FBB4320AFB82C07E56020A8FC7D9687DBED32285C9F83A06F769A9E5EB340D7B49C3E1FA3C3663A0B24E4CBE76516680A7FCBE920725A5E5ED341F0B21C346D4E41E1BA790E4286DDE4BC0BD42CA3E5207258EE1797E5A0BA9B5E9683C86539685997EBEF61341B249BC966"); + sms.insert(SMSStoreEntry(smsMessage)); + + smsMessage = SMSMessage::decode("0791947101671200040B851008050001F23900892171410155409FCEF4184D07D9CBF273793E2FBB432062BA0CC2D2E5E16B398D7687C768FADC5E96B3DFF3BAFB0C62EFEB663AC8FD1EA341E2F41CA4AFB741329A2B2673819C75BABEEC064DD36590BA4CD7D34149B4BC0C3A96EF69B77B8C0EBBC76550DD4D0699C3F8B21B344D974149B4BCEC0651CB69B6DBD53AD6E9F331BA9C7683C26E102C8683BD6A30180C04ABD900"); + sms.insert(SMSStoreEntry(smsMessage)); + + smsMessage = new SMSSubmitMessage("submit me", "0177123456"); + sms.insert(SMSStoreEntry(smsMessage)); + + SMSSubmitMessage *subsms = new SMSSubmitMessage(); + subsms->setUserData("This is a submit message, isn't it?"); + smsMessage = subsms; + sms.insert(SMSStoreEntry(smsMessage)); + + // print all entries + cout << "Entries in sms.sms<1>:" << endl; + for (SortedSMSStore::iterator i = sms.begin(); i != sms.end(); ++i) + cout << "Entry#" << i->index() << ":" << endl + << i->message()->toString() << endl; + + // sort by telephone number + sms.setSortOrder(ByAddress); + + // print all entries + cout << "Entries in sms.sms<2>:" << endl; + for (SortedSMSStore::iterator i = sms.begin(); i != sms.end(); ++i) + cout << "Entry#" << i->index() << ":" << endl + << i->message()->toString() << endl; + + // write back to file + cout << "Writing back to file" << endl; + sms.sync(); + + } + catch (GsmException &ge) + { + cerr << "GsmException '" << ge.what() << "'" << endl; + return 1; + } + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/COPYING b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/COPYING new file mode 100644 index 0000000000..78e994dd75 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/COPYING @@ -0,0 +1,5 @@ +WARNING + + The files getopt.c and getopt.h in this subdirectory (win32) are + not covered by the GNU LIBRARY GENERAL PUBLIC LICENSE as + reproduced in ../COPYING. They carry their own license instead. diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/Makefile.am b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/Makefile.am new file mode 100644 index 0000000000..a666fabf31 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/Makefile.am @@ -0,0 +1,17 @@ +## Process this file with automake to produce Makefile.in +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: win32 Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 19.1.2001 +# ************************************************************************* + +EXTRA_DIST = getopt.c gsmctl.dsp gsmpb.dsp testgsmlib.dsp \ + getopt.h gsmlib.dsp gsmsendsms.dsp testsms.dsp \ + README.win gsm_config.h gsmlib.dsw gsmsmsstore.dsp \ + gsmsmsd.dsp testsms2.dsp diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/Makefile.in b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/Makefile.in new file mode 100644 index 0000000000..4117eea211 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/Makefile.in @@ -0,0 +1,259 @@ +# Makefile.in generated by automake 1.6.3 from Makefile.am. +# @configure_input@ + +# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002 +# Free Software Foundation, Inc. +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +@SET_MAKE@ + +# ************************************************************************* +# * GSM TA/ME library +# * +# * File: Makefile.am +# * +# * Purpose: win32 Makefile +# * +# * Author: Peter Hofmann (software@pxh.de) +# * +# * Created: 19.1.2001 +# ************************************************************************* +SHELL = @SHELL@ + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ + +bindir = @bindir@ +sbindir = @sbindir@ +libexecdir = @libexecdir@ +datadir = @datadir@ +sysconfdir = @sysconfdir@ +sharedstatedir = @sharedstatedir@ +localstatedir = @localstatedir@ +libdir = @libdir@ +infodir = @infodir@ +mandir = @mandir@ +includedir = @includedir@ +oldincludedir = /usr/include +pkgdatadir = $(datadir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ +top_builddir = .. + +ACLOCAL = @ACLOCAL@ +AUTOCONF = @AUTOCONF@ +AUTOMAKE = @AUTOMAKE@ +AUTOHEADER = @AUTOHEADER@ + +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd +INSTALL = @INSTALL@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_DATA = @INSTALL_DATA@ +install_sh_DATA = $(install_sh) -c -m 644 +install_sh_PROGRAM = $(install_sh) -c +install_sh_SCRIPT = $(install_sh) -c +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +INSTALL_HEADER = $(INSTALL_DATA) +transform = @program_transform_name@ +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +host_alias = @host_alias@ +host_triplet = @host@ + +EXEEXT = @EXEEXT@ +OBJEXT = @OBJEXT@ +PATH_SEPARATOR = @PATH_SEPARATOR@ +AMTAR = @AMTAR@ +AS = @AS@ +AWK = @AWK@ +BUILD_INCLUDED_LIBINTL = @BUILD_INCLUDED_LIBINTL@ +CATOBJEXT = @CATOBJEXT@ +CC = @CC@ +CPP = @CPP@ +CXX = @CXX@ +DATADIRNAME = @DATADIRNAME@ +DEPDIR = @DEPDIR@ +DLLTOOL = @DLLTOOL@ +ECHO = @ECHO@ +GENCAT = @GENCAT@ +GLIBC21 = @GLIBC21@ +GMSGFMT = @GMSGFMT@ +GSM_VERSION = @GSM_VERSION@ +HAVE_LIB = @HAVE_LIB@ +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ +INSTOBJEXT = @INSTOBJEXT@ +INTLBISON = @INTLBISON@ +INTLLIBS = @INTLLIBS@ +INTLOBJS = @INTLOBJS@ +INTL_LIBTOOL_SUFFIX_PREFIX = @INTL_LIBTOOL_SUFFIX_PREFIX@ +LIB = @LIB@ +LIBICONV = @LIBICONV@ +LIBINTL = @LIBINTL@ +LIBTOOL = @LIBTOOL@ +LN_S = @LN_S@ +LTLIB = @LTLIB@ +LTLIBICONV = @LTLIBICONV@ +LTLIBINTL = @LTLIBINTL@ +MKINSTALLDIRS = @MKINSTALLDIRS@ +OBJDUMP = @OBJDUMP@ +PACKAGE = @PACKAGE@ +POSUB = @POSUB@ +RANLIB = @RANLIB@ +STRIP = @STRIP@ +USE_INCLUDED_LIBINTL = @USE_INCLUDED_LIBINTL@ +USE_NLS = @USE_NLS@ +VERSION = @VERSION@ +am__include = @am__include@ +am__quote = @am__quote@ +install_sh = @install_sh@ + +EXTRA_DIST = getopt.c gsmctl.dsp gsmpb.dsp testgsmlib.dsp \ + getopt.h gsmlib.dsp gsmsendsms.dsp testsms.dsp \ + README.win gsm_config.h gsmlib.dsw gsmsmsstore.dsp \ + gsmsmsd.dsp testsms2.dsp + +subdir = win32 +mkinstalldirs = $(SHELL) $(top_srcdir)/scripts/mkinstalldirs +CONFIG_HEADER = $(top_builddir)/gsm_config.h +CONFIG_CLEAN_FILES = +DIST_SOURCES = +DIST_COMMON = COPYING Makefile.am Makefile.in +all: all-am + +.SUFFIXES: +$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4) + cd $(top_srcdir) && \ + $(AUTOMAKE) --gnu win32/Makefile +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe) + +mostlyclean-libtool: + -rm -f *.lo + +clean-libtool: + -rm -rf .libs _libs + +distclean-libtool: + -rm -f libtool +uninstall-info-am: +tags: TAGS +TAGS: + +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) + +top_distdir = .. +distdir = $(top_distdir)/$(PACKAGE)-$(VERSION) + +distdir: $(DISTFILES) + @list='$(DISTFILES)'; for file in $$list; do \ + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ + dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \ + if test "$$dir" != "$$file" && test "$$dir" != "."; then \ + dir="/$$dir"; \ + $(mkinstalldirs) "$(distdir)$$dir"; \ + else \ + dir=''; \ + fi; \ + if test -d $$d/$$file; then \ + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ + cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ + fi; \ + cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ + else \ + test -f $(distdir)/$$file \ + || cp -p $$d/$$file $(distdir)/$$file \ + || exit 1; \ + fi; \ + done +check-am: all-am +check: check-am +all-am: Makefile + +installdirs: + +install: install-am +install-exec: install-exec-am +install-data: install-data-am +uninstall: uninstall-am + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am + +installcheck: installcheck-am +install-strip: + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + INSTALL_STRIP_FLAG=-s \ + `test -z '$(STRIP)' || \ + echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -rm -f Makefile $(CONFIG_CLEAN_FILES) + +maintainer-clean-generic: + @echo "This command is intended for maintainers to use" + @echo "it deletes files that may require special tools to rebuild." +clean: clean-am + +clean-am: clean-generic clean-libtool mostlyclean-am + +distclean: distclean-am + +distclean-am: clean-am distclean-generic distclean-libtool + +dvi: dvi-am + +dvi-am: + +info: info-am + +info-am: + +install-data-am: + +install-exec-am: + +install-info: install-info-am + +install-man: + +installcheck-am: + +maintainer-clean: maintainer-clean-am + +maintainer-clean-am: distclean-am maintainer-clean-generic + +mostlyclean: mostlyclean-am + +mostlyclean-am: mostlyclean-generic mostlyclean-libtool + +uninstall-am: uninstall-info-am + +.PHONY: all all-am check check-am clean clean-generic clean-libtool \ + distclean distclean-generic distclean-libtool distdir dvi \ + dvi-am info info-am install install-am install-data \ + install-data-am install-exec install-exec-am install-info \ + install-info-am install-man install-strip installcheck \ + installcheck-am installdirs maintainer-clean \ + maintainer-clean-generic mostlyclean mostlyclean-generic \ + mostlyclean-libtool uninstall uninstall-am uninstall-info-am + +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/README.win b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/README.win new file mode 100644 index 0000000000..17aa648dd1 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/README.win @@ -0,0 +1,41 @@ +INTRODUCTION + + This is a Win32 port of gsmlib contributed by Frediano Ziglio + (Frediano.Ziglio@omnitel.it) and adapted by me. You can use the + library for inclusion in your own programs or the command line tools + which have been ported (with the exception of gsmsmsd). + +COMPILATION + + You need Microsoft VC++ 6.0 to compile the library and command + line tools. Because I prefer to use the ending .cc for C++ files you + need to make some changes to your development environment. These are + documented by Microsoft under this URL (one line): + + http://support.microsoft.com/support/kb/articles/Q181/5/ + 06.ASP?LN=EN-US&SD=gn&FR=0&qry=.cc&rnk=1&src=DHCS_MSPSS_gn_SRCH&SPR=VCC + + The title of the document is "HOWTO: Make VC++ Recognize File + Extensions as C/C++ Files". + + Then open the workspace gsmlib.dsw with Developer + Studio. Compilation should be straightforward after that, just make a + batch build of everything. + + If you encounter problems you can use the debug versions and set + the environment variable GSMLIB_DEBUG to 1 or 2 to get debugging + output. + +HINTS + - Use COMx: (x is the number of the COM device) instead of the UNIX + device name. If this doesn't work use "\\.\COMx:". + + - The files under Release are without debugging code. If you see + errors please use the Debug versions and execute + + set GSMLIB_DEBUG=2 + + for executing the programs. Please send me the debugging + output: + + gsmsmsstore ..... 2> \temp\debug.log diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/getopt.c b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/getopt.c new file mode 100644 index 0000000000..45fcedc063 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/getopt.c @@ -0,0 +1,185 @@ +/***************************************************************************** + * + * MODULE NAME : GETOPT.C + * + * COPYRIGHTS: + * This module contains code made available by IBM + * Corporation on an AS IS basis. Any one receiving the + * module is considered to be licensed under IBM copyrights + * to use the IBM-provided source code in any way he or she + * deems fit, including copying it, compiling it, modifying + * it, and redistributing it, with or without + * modifications. No license under any IBM patents or + * patent applications is to be implied from this copyright + * license. + * + * A user of the module should understand that IBM cannot + * provide technical support for the module and will not be + * responsible for any consequences of use of the program. + * + * Any notices, including this one, are not to be removed + * from the module without the prior written consent of + * IBM. + * + * AUTHOR: Original author: + * G. R. Blair (BOBBLAIR at AUSVM1) + * Internet: bobblair@bobblair.austin.ibm.com + * + * Extensively revised by: + * John Q. Walker II, Ph.D. (JOHHQ at RALVM6) + * Internet: johnq@ralvm6.vnet.ibm.com + * + *****************************************************************************/ + +/****************************************************************************** + * getopt() + * + * The getopt() function is a command line parser. It returns the next + * option character in argv that matches an option character in opstring. + * + * The argv argument points to an array of argc+1 elements containing argc + * pointers to character strings followed by a null pointer. + * + * The opstring argument points to a string of option characters; if an + * option character is followed by a colon, the option is expected to have + * an argument that may or may not be separated from it by white space. + * The external variable optarg is set to point to the start of the option + * argument on return from getopt(). + * + * The getopt() function places in optind the argv index of the next argument + * to be processed. The system initializes the external variable optind to + * 1 before the first call to getopt(). + * + * When all options have been processed (that is, up to the first nonoption + * argument), getopt() returns EOF. The special option "--" may be used to + * delimit the end of the options; EOF will be returned, and "--" will be + * skipped. + * + * The getopt() function returns a question mark (?) when it encounters an + * option character not included in opstring. This error message can be + * disabled by setting opterr to zero. Otherwise, it returns the option + * character that was detected. + * + * If the special option "--" is detected, or all options have been + * processed, EOF is returned. + * + * Options are marked by either a minus sign (-) or a slash (/). + * + * No errors are defined. + *****************************************************************************/ + +#include /* for EOF */ +#include /* for strchr() */ + + +#ifdef __cplusplus +extern "C" { +#endif + +/* static (global) variables that are specified as exported by getopt() */ +char *optarg = NULL; /* pointer to the start of the option argument */ +int optind = 1; /* number of the next argv[] to be evaluated */ +int opterr = 1; /* non-zero if a question mark should be returned + when a non-valid option character is detected */ + +/* handle possible future character set concerns by putting this in a macro */ +#define _next_char(string) (char)(*(string+1)) + +int getopt(int argc, char *argv[], char *opstring) +{ + static char *pIndexPosition = NULL; /* place inside current argv string */ + char *pArgString = NULL; /* where to start from next */ + char *pOptString; /* the string in our program */ + + + if (pIndexPosition != NULL) { + /* we last left off inside an argv string */ + if (*(++pIndexPosition)) { + /* there is more to come in the most recent argv */ + pArgString = pIndexPosition; + } + } + + if (pArgString == NULL) { + /* we didn't leave off in the middle of an argv string */ + if (optind >= argc) { + /* more command-line arguments than the argument count */ + pIndexPosition = NULL; /* not in the middle of anything */ + return EOF; /* used up all command-line arguments */ + } + + /*--------------------------------------------------------------------- + * If the next argv[] is not an option, there can be no more options. + *-------------------------------------------------------------------*/ + pArgString = argv[optind++]; /* set this to the next argument ptr */ + + if (('/' != *pArgString) && /* doesn't start with a slash or a dash? */ + ('-' != *pArgString)) { + --optind; /* point to current arg once we're done */ + optarg = NULL; /* no argument follows the option */ + pIndexPosition = NULL; /* not in the middle of anything */ + return EOF; /* used up all the command-line flags */ + } + + /* check for special end-of-flags markers */ + if ((strcmp(pArgString, "-") == 0) || + (strcmp(pArgString, "--") == 0)) { + optarg = NULL; /* no argument follows the option */ + pIndexPosition = NULL; /* not in the middle of anything */ + return EOF; /* encountered the special flag */ + } + + pArgString++; /* look past the / or - */ + } + + if (':' == *pArgString) { /* is it a colon? */ + /*--------------------------------------------------------------------- + * Rare case: if opterr is non-zero, return a question mark; + * otherwise, just return the colon we're on. + *-------------------------------------------------------------------*/ + return (opterr ? (int)'?' : (int)':'); + } + else if ((pOptString = strchr(opstring, *pArgString)) == 0) { + /*--------------------------------------------------------------------- + * The letter on the command-line wasn't any good. + *-------------------------------------------------------------------*/ + optarg = NULL; /* no argument follows the option */ + pIndexPosition = NULL; /* not in the middle of anything */ + return (opterr ? (int)'?' : (int)*pArgString); + } + else { + /*--------------------------------------------------------------------- + * The letter on the command-line matches one we expect to see + *-------------------------------------------------------------------*/ + if (':' == _next_char(pOptString)) { /* is the next letter a colon? */ + /* It is a colon. Look for an argument string. */ + if ('\0' != _next_char(pArgString)) { /* argument in this argv? */ + optarg = &pArgString[1]; /* Yes, it is */ + } + else { + /*------------------------------------------------------------- + * The argument string must be in the next argv. + * But, what if there is none (bad input from the user)? + * In that case, return the letter, and optarg as NULL. + *-----------------------------------------------------------*/ + if (optind < argc) + optarg = argv[optind++]; + else { + optarg = NULL; + return (opterr ? (int)'?' : (int)*pArgString); + } + } + pIndexPosition = NULL; /* not in the middle of anything */ + } + else { + /* it's not a colon, so just return the letter */ + optarg = NULL; /* no argument follows the option */ + pIndexPosition = pArgString; /* point to the letter we're on */ + } + return (int)*pArgString; /* return the letter that matched */ + } +} + +#ifdef __cplusplus +} +#endif diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/getopt.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/getopt.h new file mode 100644 index 0000000000..f7446f1c50 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/getopt.h @@ -0,0 +1,49 @@ +/***************************************************************************** + * + * MODULE NAME : GETOPT.H + * + * COPYRIGHTS: + * This module contains code made available by IBM + * Corporation on an AS IS basis. Any one receiving the + * module is considered to be licensed under IBM copyrights + * to use the IBM-provided source code in any way he or she + * deems fit, including copying it, compiling it, modifying + * it, and redistributing it, with or without + * modifications. No license under any IBM patents or + * patent applications is to be implied from this copyright + * license. + * + * A user of the module should understand that IBM cannot + * provide technical support for the module and will not be + * responsible for any consequences of use of the program. + * + * Any notices, including this one, are not to be removed + * from the module without the prior written consent of + * IBM. + * + * AUTHOR: Original author: + * G. R. Blair (BOBBLAIR at AUSVM1) + * Internet: bobblair@bobblair.austin.ibm.com + * + * Extensively revised by: + * John Q. Walker II, Ph.D. (JOHHQ at RALVM6) + * Internet: johnq@ralvm6.vnet.ibm.com + * + *****************************************************************************/ +#ifndef WIN32_GETOPT_H +#define WIN32_GETOPT_H + +#ifdef __cplusplus +extern "C" { +#endif + +extern char * optarg; +extern int optind; + +int getopt ( int argc, char **argv, char *optstring); + +#ifdef __cplusplus +} +#endif + +#endif // WIN32_GETOPT_H diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsm_config.h b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsm_config.h new file mode 100644 index 0000000000..fbf1d18a47 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsm_config.h @@ -0,0 +1,171 @@ +/* gsm_config.h.in. Generated automatically from configure.in by autoheader. */ + +/* Define if using alloca.c. */ +#undef C_ALLOCA + +/* Define to empty if the keyword does not work. */ +#undef const + +/* Define to one of _getb67, GETB67, getb67 for Cray-2 and Cray-YMP systems. + This function is required for alloca.c support on those systems. */ +#undef CRAY_STACKSEG_END + +/* Define if you have alloca, as a function or macro. */ +#define HAVE_ALLOCA 1 +#define alloca _alloca // Microsoft + +/* Define if you have and it should be used (not on Ultrix). */ +#undef HAVE_ALLOCA_H + +/* Define if you have a working `mmap' system call. */ +#undef HAVE_MMAP + +/* Define as __inline if that's what the C compiler calls it. */ +#undef inline + +/* Define to `long' if doesn't define. */ +#undef off_t + +/* Define if you need to in order for stat and other things to work. */ +#undef _POSIX_SOURCE + +/* Define to `unsigned' if doesn't define. */ +#undef size_t + +/* If using the C implementation of alloca, define if you know the + direction of stack growth for your system; otherwise it will be + automatically deduced at run-time. + STACK_DIRECTION > 0 => grows toward higher addresses + STACK_DIRECTION < 0 => grows toward lower addresses + STACK_DIRECTION = 0 => direction of growth unknown + */ +#undef STACK_DIRECTION + +/* Define if you have the ANSI C header files. */ +#define STDC_HEADERS 1 + +/* used by libtool*/ +#define PACKAGE 0 + +/* used by libtool*/ +#define VERSION 0 + +/* Define if getopt_long() available */ +#undef HAVE_GETOPT_LONG + +/* Define if alarm() available */ +#undef HAVE_ALARM + +/* Define for NLS */ +#undef ENABLE_NLS +#undef HAVE_CATGETS +#undef HAVE_GETTEXT +#undef HAVE_LC_MESSAGES +#undef HAVE_STPCPY + +/* Define LOCALEDIR */ +#define LOCALEDIR "/usr/share/locale" + +/* Define if vsnprintf() function available */ +#define HAVE_VSNPRINTF 1 +#ifndef WIN32 +#define vsnprintf _vsnprintf +#endif //WIN32 + +/* The number of bytes in a unsigned int. */ +#define SIZEOF_UNSIGNED_INT 4 + +/* The number of bytes in a unsigned long int. */ +#define SIZEOF_UNSIGNED_LONG_INT 4 + +/* The number of bytes in a unsigned short int. */ +#define SIZEOF_UNSIGNED_SHORT_INT 2 + +/* Define if you have the __argz_count function. */ +#undef HAVE___ARGZ_COUNT + +/* Define if you have the __argz_next function. */ +#undef HAVE___ARGZ_NEXT + +/* Define if you have the __argz_stringify function. */ +#undef HAVE___ARGZ_STRINGIFY + +/* Define if you have the dcgettext function. */ +#undef HAVE_DCGETTEXT + +/* Define if you have the getcwd function. */ +#undef HAVE_GETCWD + +/* Define if you have the getpagesize function. */ +#undef HAVE_GETPAGESIZE + +/* Define if you have the munmap function. */ +#undef HAVE_MUNMAP + +/* Define if you have the putenv function. */ +#undef HAVE_PUTENV + +/* Define if you have the setenv function. */ +#undef HAVE_SETENV + +/* Define if you have the setlocale function. */ +#define HAVE_SETLOCALE 1 + +/* Define if you have the stpcpy function. */ +#undef HAVE_STPCPY + +/* Define if you have the strcasecmp function. */ +#undef HAVE_STRCASECMP +#define strcasecmp _strcmpi + +/* Define if you have the strchr function. */ +#define HAVE_STRCHR 1 + +/* Define if you have the strdup function. */ +#define HAVE_STRDUP 1 + +/* Define if you have the header file. */ +#undef HAVE_ARGZ_H + +/* Define if you have the header file. */ +#undef HAVE_LIBINTL_H + +/* Define if you have the header file. */ +#define HAVE_LIMITS_H 1 + +/* Define if you have the header file. */ +#define HAVE_LOCALE_H 1 + +/* Define if you have the header file. */ +#define HAVE_MALLOC_H 1 + +/* Define if you have the header file. */ +#undef HAVE_NETINET_IN_H + +/* Define if you have the header file. */ +#undef HAVE_NL_TYPES_H + +/* Define if you have the header file. */ +#define HAVE_STRING_H 1 + +/* Define if you have the header file. */ +#undef HAVE_SYS_PARAM_H + +/* Define if you have the header file. */ +#undef HAVE_UNISTD_H + +/* Define if you have the i library (-li). */ +#undef HAVE_LIBI + +/* Define if you have the intl library (-lintl). */ +#undef HAVE_LIBINTL + +// WIN32 specific defines +#pragma warning( disable : 4786 ) // Disable warning messages + // 4786 (id too long) + +// Win32 strftime() does not return length of output when passing +// NULL pointer +#define BROKEN_STRFTIME +// Win32 STL erase() for maps makes iterators invalid +#define BUGGY_MAP_ERASE diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmctl.vcproj b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmctl.vcproj new file mode 100644 index 0000000000..f079939e50 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmctl.vcproj @@ -0,0 +1,250 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmlib.sln b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmlib.sln new file mode 100644 index 0000000000..1236577fb5 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmlib.sln @@ -0,0 +1,92 @@ + +Microsoft Visual Studio Solution File, Format Version 10.00 +# Visual C++ Express 2008 +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gsmctl", "gsmctl.vcproj", "{54A7F660-F430-4533-8151-63BEFD12232B}" + ProjectSection(ProjectDependencies) = postProject + {982662D6-47D2-40D6-A873-E970D407BB2B} = {982662D6-47D2-40D6-A873-E970D407BB2B} + EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gsmlib", "gsmlib.vcproj", "{982662D6-47D2-40D6-A873-E970D407BB2B}" +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gsmpb", "gsmpb.vcproj", "{7E44C592-6CBC-4A35-817E-D6EA48E4AB1B}" + ProjectSection(ProjectDependencies) = postProject + {982662D6-47D2-40D6-A873-E970D407BB2B} = {982662D6-47D2-40D6-A873-E970D407BB2B} + EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gsmsendsms", "gsmsendsms.vcproj", "{D9879143-D549-4877-AEB2-667BC5D35F32}" + ProjectSection(ProjectDependencies) = postProject + {982662D6-47D2-40D6-A873-E970D407BB2B} = {982662D6-47D2-40D6-A873-E970D407BB2B} + EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gsmsmsd", "gsmsmsd.vcproj", "{98F03909-E60D-4797-A35F-F0E535FF4A75}" + ProjectSection(ProjectDependencies) = postProject + {982662D6-47D2-40D6-A873-E970D407BB2B} = {982662D6-47D2-40D6-A873-E970D407BB2B} + EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gsmsmsstore", "gsmsmsstore.vcproj", "{A99A0B10-EB66-40FF-A994-B6D6E0D9167F}" + ProjectSection(ProjectDependencies) = postProject + {982662D6-47D2-40D6-A873-E970D407BB2B} = {982662D6-47D2-40D6-A873-E970D407BB2B} + EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "testgsmlib", "testgsmlib.vcproj", "{33DFBB83-99BD-449D-A486-B4BCE37544C6}" + ProjectSection(ProjectDependencies) = postProject + {982662D6-47D2-40D6-A873-E970D407BB2B} = {982662D6-47D2-40D6-A873-E970D407BB2B} + EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "testsms", "testsms.vcproj", "{D3147DAC-F5E2-4ED8-B73C-43A96B042698}" + ProjectSection(ProjectDependencies) = postProject + {982662D6-47D2-40D6-A873-E970D407BB2B} = {982662D6-47D2-40D6-A873-E970D407BB2B} + EndProjectSection +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "testsms2", "testsms2.vcproj", "{AFAD00BB-1A68-4696-A3EA-4CAD26D9E051}" + ProjectSection(ProjectDependencies) = postProject + {982662D6-47D2-40D6-A873-E970D407BB2B} = {982662D6-47D2-40D6-A873-E970D407BB2B} + EndProjectSection +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Win32 = Debug|Win32 + Release|Win32 = Release|Win32 + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {54A7F660-F430-4533-8151-63BEFD12232B}.Debug|Win32.ActiveCfg = Debug|Win32 + {54A7F660-F430-4533-8151-63BEFD12232B}.Debug|Win32.Build.0 = Debug|Win32 + {54A7F660-F430-4533-8151-63BEFD12232B}.Release|Win32.ActiveCfg = Release|Win32 + {54A7F660-F430-4533-8151-63BEFD12232B}.Release|Win32.Build.0 = Release|Win32 + {982662D6-47D2-40D6-A873-E970D407BB2B}.Debug|Win32.ActiveCfg = Debug|Win32 + {982662D6-47D2-40D6-A873-E970D407BB2B}.Debug|Win32.Build.0 = Debug|Win32 + {982662D6-47D2-40D6-A873-E970D407BB2B}.Release|Win32.ActiveCfg = Release|Win32 + {982662D6-47D2-40D6-A873-E970D407BB2B}.Release|Win32.Build.0 = Release|Win32 + {7E44C592-6CBC-4A35-817E-D6EA48E4AB1B}.Debug|Win32.ActiveCfg = Debug|Win32 + {7E44C592-6CBC-4A35-817E-D6EA48E4AB1B}.Debug|Win32.Build.0 = Debug|Win32 + {7E44C592-6CBC-4A35-817E-D6EA48E4AB1B}.Release|Win32.ActiveCfg = Release|Win32 + {7E44C592-6CBC-4A35-817E-D6EA48E4AB1B}.Release|Win32.Build.0 = Release|Win32 + {D9879143-D549-4877-AEB2-667BC5D35F32}.Debug|Win32.ActiveCfg = Debug|Win32 + {D9879143-D549-4877-AEB2-667BC5D35F32}.Debug|Win32.Build.0 = Debug|Win32 + {D9879143-D549-4877-AEB2-667BC5D35F32}.Release|Win32.ActiveCfg = Release|Win32 + {D9879143-D549-4877-AEB2-667BC5D35F32}.Release|Win32.Build.0 = Release|Win32 + {98F03909-E60D-4797-A35F-F0E535FF4A75}.Debug|Win32.ActiveCfg = Debug|Win32 + {98F03909-E60D-4797-A35F-F0E535FF4A75}.Debug|Win32.Build.0 = Debug|Win32 + {98F03909-E60D-4797-A35F-F0E535FF4A75}.Release|Win32.ActiveCfg = Release|Win32 + {98F03909-E60D-4797-A35F-F0E535FF4A75}.Release|Win32.Build.0 = Release|Win32 + {A99A0B10-EB66-40FF-A994-B6D6E0D9167F}.Debug|Win32.ActiveCfg = Debug|Win32 + {A99A0B10-EB66-40FF-A994-B6D6E0D9167F}.Debug|Win32.Build.0 = Debug|Win32 + {A99A0B10-EB66-40FF-A994-B6D6E0D9167F}.Release|Win32.ActiveCfg = Release|Win32 + {A99A0B10-EB66-40FF-A994-B6D6E0D9167F}.Release|Win32.Build.0 = Release|Win32 + {33DFBB83-99BD-449D-A486-B4BCE37544C6}.Debug|Win32.ActiveCfg = Debug|Win32 + {33DFBB83-99BD-449D-A486-B4BCE37544C6}.Debug|Win32.Build.0 = Debug|Win32 + {33DFBB83-99BD-449D-A486-B4BCE37544C6}.Release|Win32.ActiveCfg = Release|Win32 + {33DFBB83-99BD-449D-A486-B4BCE37544C6}.Release|Win32.Build.0 = Release|Win32 + {D3147DAC-F5E2-4ED8-B73C-43A96B042698}.Debug|Win32.ActiveCfg = Debug|Win32 + {D3147DAC-F5E2-4ED8-B73C-43A96B042698}.Debug|Win32.Build.0 = Debug|Win32 + {D3147DAC-F5E2-4ED8-B73C-43A96B042698}.Release|Win32.ActiveCfg = Release|Win32 + {D3147DAC-F5E2-4ED8-B73C-43A96B042698}.Release|Win32.Build.0 = Release|Win32 + {AFAD00BB-1A68-4696-A3EA-4CAD26D9E051}.Debug|Win32.ActiveCfg = Debug|Win32 + {AFAD00BB-1A68-4696-A3EA-4CAD26D9E051}.Debug|Win32.Build.0 = Debug|Win32 + {AFAD00BB-1A68-4696-A3EA-4CAD26D9E051}.Release|Win32.ActiveCfg = Release|Win32 + {AFAD00BB-1A68-4696-A3EA-4CAD26D9E051}.Release|Win32.Build.0 = Release|Win32 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmlib.vcproj b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmlib.vcproj new file mode 100644 index 0000000000..7c668458d4 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmlib.vcproj @@ -0,0 +1,332 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmpb.vcproj b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmpb.vcproj new file mode 100644 index 0000000000..49a608f6c7 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmpb.vcproj @@ -0,0 +1,250 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsendsms.vcproj b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsendsms.vcproj new file mode 100644 index 0000000000..04e6531f1e --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsendsms.vcproj @@ -0,0 +1,250 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsmsd.vcproj b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsmsd.vcproj new file mode 100644 index 0000000000..f6c7eb999b --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsmsd.vcproj @@ -0,0 +1,250 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsmsstore.vcproj b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsmsstore.vcproj new file mode 100644 index 0000000000..de1b20ff1b --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/gsmsmsstore.vcproj @@ -0,0 +1,252 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testgsmlib.vcproj b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testgsmlib.vcproj new file mode 100644 index 0000000000..766f863d6f --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testgsmlib.vcproj @@ -0,0 +1,221 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testsms.vcproj b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testsms.vcproj new file mode 100644 index 0000000000..54ae74c491 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testsms.vcproj @@ -0,0 +1,222 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testsms2.vcproj b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testsms2.vcproj new file mode 100644 index 0000000000..824eb4971e --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10-patched-12ubuntu1/win32/testsms2.vcproj @@ -0,0 +1,222 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10.tar.gz b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib-1.10.tar.gz new file mode 100644 index 0000000000000000000000000000000000000000..c3e2c3bb743da9a3ff5fd23c22226e7e9c20d6c2 GIT binary patch literal 474591 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 z

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%0DubDZM$+f1e_=;-1vhv(8c|?W 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%0D9K~s-3w^me^`;Zd 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 E0O0hWHUIzs literal 0 HcmV?d00001 diff --git a/src/mod/endpoints/mod_gsmopen/gsmopen.h b/src/mod/endpoints/mod_gsmopen/gsmopen.h new file mode 100644 index 0000000000..fd94bccc2a --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmopen.h @@ -0,0 +1,665 @@ +/* + * FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application + * Copyright (C) 2005/2006, Anthony Minessale II + * + * Version: MPL 1.1 + * + * The contents of this file are subject to the Mozilla Public License Version + * 1.1 (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * http://www.mozilla.org/MPL/ + * + * Software distributed under the License is distributed on an "AS IS" basis, + * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License + * for the specific language governing rights and limitations under the + * License. + * + * The Original Code is FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application + * + * The Initial Developer of the Original Code is + * Anthony Minessale II + * Portions created by the Initial Developer are Copyright (C) + * the Initial Developer. All Rights Reserved. + * + * This module (mod_gsmopen) has been contributed by: + * + * Giovanni Maruzzelli (gmaruzz@gmail.com) + * + * + * Further Contributors: + * + * + * + * mod_gsmopen.c -- GSM compatible Endpoint Module + * + */ + +#define __STDC_LIMIT_MACROS + +#ifdef WIN32 +#define HAVE_VSNPRINTF +#pragma warning(disable: 4290) +#endif //WIN32 + +#define MY_EVENT_INCOMING_SMS "gsmopen::incoming_sms" +#define MY_EVENT_DUMP "gsmopen::dump_event" +#define MY_EVENT_ALARM "gsmopen::alarm" + +#define ALARM_FAILED_INTERFACE 0 +#define ALARM_NO_NETWORK_REGISTRATION 1 +#define ALARM_ROAMING_NETWORK_REGISTRATION 2 +#define ALARM_NETWORK_NO_SERVICE 3 +#define ALARM_NETWORK_NO_SIGNAL 4 +#define ALARM_NETWORK_LOW_SIGNAL 5 + + + + + +#undef GIOVA48 + +#ifndef GIOVA48 +#define SAMPLES_PER_FRAME 160 +#else // GIOVA48 +#define SAMPLES_PER_FRAME 960 +#endif // GIOVA48 + + +#ifndef GIOVA48 +#define GSMOPEN_FRAME_SIZE 160 +#else //GIOVA48 +#define GSMOPEN_FRAME_SIZE 960 +#endif //GIOVA48 +#define SAMPLERATE_GSMOPEN 8000 + +#ifndef NO_ALSA +#define GSMOPEN_ALSA +#endif // NO_ALSA +#include +#include +#ifndef WIN32 +#include +#include +#include +#endif //WIN32 +//#include + +#ifdef GSMOPEN_ALSA +#define ALSA_PCM_NEW_HW_PARAMS_API +#define ALSA_PCM_NEW_SW_PARAMS_API +#include +#endif /* GSMOPEN_ALSA */ + +#ifdef GSMOPEN_PORTAUDIO +#include "pablio.h" +#undef WANT_SPEEX +#ifdef WANT_SPEEX +#include "speex/speex_preprocess.h" +#include "speex/speex_echo.h" +#endif /* WANT_SPEEX */ +#endif// GSMOPEN_PORTAUDIO + +//#include "celliax_spandsp.h" +#ifndef WIN32 +#include +//#include +//#include +//#include +#endif //WIN32 + +#define SPANDSP_EXPOSE_INTERNAL_STRUCTURES +#include +#include + +#ifdef _MSC_VER +//Windows macro for FD_SET includes a warning C4127: conditional expression is constant +#pragma warning(push) +#pragma warning(disable:4127) +#endif + +#define PROTOCOL_ALSA_VOICEMODEM 4 +#define PROTOCOL_AT 2 +#define PROTOCOL_FBUS2 1 +#define PROTOCOL_NO_SERIAL 3 + +#define AT_BUFSIZ 8192 +//FIXME FIXME FIXME #define AT_MESG_MAX_LENGTH 2048 /* much more than 10 SMSs */ +#define AT_MESG_MAX_LENGTH 2048 /* much more than 10 SMSs */ +//FIXME FIXME FIXME #define AT_MESG_MAX_LINES 256 /* 256 lines, so it can contains the results of AT+CLAC, that gives all the AT commands the phone supports */ +#define AT_MESG_MAX_LINES 20 /* 256 lines, so it can contains the results of AT+CLAC, that gives all the AT commands the phone supports */ + +//#define SAMPLERATE_GSMOPEN 16000 +//#define SAMPLES_PER_FRAME SAMPLERATE_GSMOPEN/50 + +#ifndef GSMOPEN_SVN_VERSION +#define GSMOPEN_SVN_VERSION SWITCH_VERSION_REVISION +#endif /* GSMOPEN_SVN_VERSION */ + +typedef enum { + TFLAG_IO = (1 << 0), + TFLAG_INBOUND = (1 << 1), + TFLAG_OUTBOUND = (1 << 2), + TFLAG_DTMF = (1 << 3), + TFLAG_VOICE = (1 << 4), + TFLAG_HANGUP = (1 << 5), + TFLAG_LINEAR = (1 << 6), + TFLAG_CODEC = (1 << 7), + TFLAG_BREAK = (1 << 8) +} TFLAGS; + +typedef enum { + GFLAG_MY_CODEC_PREFS = (1 << 0) +} GFLAGS; + +#define DEBUGA_GSMOPEN(...) switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "rev "GSMOPEN_SVN_VERSION "[%p|%-7lx][DEBUG_GSMOPEN %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define DEBUGA_CALL(...) switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "rev "GSMOPEN_SVN_VERSION "[%p|%-7lx][DEBUG_CALL %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define DEBUGA_PBX(...) switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "rev "GSMOPEN_SVN_VERSION "[%p|%-7lx][DEBUG_PBX %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define ERRORA(...) switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "rev "GSMOPEN_SVN_VERSION "[%p|%-7lx][ERRORA %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define WARNINGA(...) switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, "rev "GSMOPEN_SVN_VERSION "[%p|%-7lx][WARNINGA %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); +#define NOTICA(...) switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_NOTICE, "rev "GSMOPEN_SVN_VERSION "[%p|%-7lx][NOTICA %-5d][%-10s][%2d,%2d,%2d] " __VA_ARGS__ ); + +#define GSMOPEN_P_LOG NULL, (unsigned long)55, __LINE__, tech_pvt ? tech_pvt->name ? tech_pvt->name : "none" : "none", -1, tech_pvt ? tech_pvt->interface_state : -1, tech_pvt ? tech_pvt->phone_callflow : -1 + +/*********************************/ +#define GSMOPEN_CAUSE_NORMAL 1 +#define GSMOPEN_CAUSE_FAILURE 2 +#define GSMOPEN_CAUSE_NO_ANSWER 3 +/*********************************/ +#define GSMOPEN_FRAME_DTMF 1 +/*********************************/ +#define GSMOPEN_CONTROL_RINGING 1 +#define GSMOPEN_CONTROL_ANSWER 2 +#define GSMOPEN_CONTROL_HANGUP 3 +#define GSMOPEN_CONTROL_BUSY 4 + +/*********************************/ +#define GSMOPEN_STATE_IDLE 0 +#define GSMOPEN_STATE_DOWN 1 +#define GSMOPEN_STATE_RING 2 +#define GSMOPEN_STATE_DIALING 3 +#define GSMOPEN_STATE_BUSY 4 +#define GSMOPEN_STATE_UP 5 +#define GSMOPEN_STATE_RINGING 6 +#define GSMOPEN_STATE_PRERING 7 +#define GSMOPEN_STATE_ERROR_DOUBLE_CALL 8 +#define GSMOPEN_STATE_SELECTED 9 +#define GSMOPEN_STATE_HANGUP_REQUESTED 10 +#define GSMOPEN_STATE_PREANSWER 11 +/*********************************/ +/* call flow from the device */ +#define CALLFLOW_CALL_IDLE 0 +#define CALLFLOW_CALL_DOWN 1 +#define CALLFLOW_INCOMING_RING 2 +#define CALLFLOW_CALL_DIALING 3 +#define CALLFLOW_CALL_LINEBUSY 4 +#define CALLFLOW_CALL_ACTIVE 5 +#define CALLFLOW_INCOMING_HANGUP 6 +#define CALLFLOW_CALL_RELEASED 7 +#define CALLFLOW_CALL_NOCARRIER 8 +#define CALLFLOW_CALL_INFLUX 9 +#define CALLFLOW_CALL_INCOMING 10 +#define CALLFLOW_CALL_FAILED 11 +#define CALLFLOW_CALL_NOSERVICE 12 +#define CALLFLOW_CALL_OUTGOINGRESTRICTED 13 +#define CALLFLOW_CALL_SECURITYFAIL 14 +#define CALLFLOW_CALL_NOANSWER 15 +#define CALLFLOW_STATUS_FINISHED 16 +#define CALLFLOW_STATUS_CANCELLED 17 +#define CALLFLOW_STATUS_FAILED 18 +#define CALLFLOW_STATUS_REFUSED 19 +#define CALLFLOW_STATUS_RINGING 20 +#define CALLFLOW_STATUS_INPROGRESS 21 +#define CALLFLOW_STATUS_UNPLACED 22 +#define CALLFLOW_STATUS_ROUTING 23 +#define CALLFLOW_STATUS_EARLYMEDIA 24 +#define CALLFLOW_INCOMING_CALLID 25 +#define CALLFLOW_STATUS_REMOTEHOLD 26 +#define CALLFLOW_CALL_REMOTEANSWER 27 +#define CALLFLOW_CALL_HANGUP_REQUESTED 28 + +/*********************************/ + +#define AT_OK 0 +#define AT_ERROR 1 + +#define GSMOPEN_MAX_INTERFACES 64 + +#ifndef WIN32 +struct GSMopenHandles { + //Window gsmopen_win; + //Display *disp; + //Window win; + int currentuserhandle; + int api_connected; + int fdesc[2]; +}; +#else //WIN32 + +struct GSMopenHandles { + HWND win32_hInit_MainWindowHandle; + HWND win32_hGlobal_GSMAPIWindowHandle; + HINSTANCE win32_hInit_ProcessHandle; + char win32_acInit_WindowClassName[128]; + UINT win32_uiGlobal_MsgID_GSMControlAPIAttach; + UINT win32_uiGlobal_MsgID_GSMControlAPIDiscover; + int currentuserhandle; + int api_connected; + switch_file_t *fdesc[2]; +}; + +#endif //WIN32 + +/*! + * \brief structure for storing the results of AT commands, in an array of AT_MESG_MAX_LINES * AT_MESG_MAX_LENGTH chars + */ +struct s_result { + int elemcount; + char result[AT_MESG_MAX_LINES][AT_MESG_MAX_LENGTH]; +}; + +struct ciapa_struct { + int state; + int hangupcause; +}; +typedef struct ciapa_struct ciapa_t; + +struct private_object { + unsigned int flags; + switch_codec_t read_codec; + switch_codec_t write_codec; + switch_frame_t read_frame; + unsigned char databuf[SWITCH_RECOMMENDED_BUFFER_SIZE]; + char session_uuid_str[SWITCH_UUID_FORMATTED_LENGTH + 1]; + switch_caller_profile_t *caller_profile; + switch_mutex_t *mutex; + switch_mutex_t *flag_mutex; + + char id[80]; + char name[80]; + char dialplan[80]; + char context[80]; + char dial_regex[256]; + char fail_dial_regex[256]; + char hold_music[256]; + char type[256]; + char X11_display[256]; +#ifdef WIN32 + unsigned short tcp_cli_port; + unsigned short tcp_srv_port; +#else + int tcp_cli_port; + int tcp_srv_port; +#endif + struct GSMopenHandles GSMopenHandles; + + int interface_state; /*!< \brief 'state' of the interface (channel) */ + char language[80]; /*!< \brief default Asterisk dialplan language for this interface */ + char exten[80]; /*!< \brief default Asterisk dialplan extension for this interface */ + int gsmopen_sound_rate; /*!< \brief rate of the sound device, in Hz, eg: 8000 */ + char callid_name[50]; + char callid_number[50]; + double playback_boost; + double capture_boost; + int stripmsd; + char gsmopen_call_id[512]; + int gsmopen_call_ongoing; + char gsmopen_friends[4096]; + char gsmopen_fullname[512]; + char gsmopen_displayname[512]; + int phone_callflow; /*!< \brief 'callflow' of the gsmopen interface (as opposed to phone interface) */ + int gsmopen; /*!< \brief config flag, bool, GSM support on this interface (0 if false, -1 if true) */ + int control_to_send; +#ifdef WIN32 + switch_file_t *audiopipe[2]; + switch_file_t *audiogsmopenpipe[2]; + switch_file_t *gsmopen_sound_capt_fd; /*!< \brief file descriptor for sound capture dev */ +#else /* WIN32 */ + int audiopipe[2]; + int audiogsmopenpipe[2]; + int gsmopen_sound_capt_fd; /*!< \brief file descriptor for sound capture dev */ +#endif /* WIN32 */ + switch_thread_t *tcp_srv_thread; + switch_thread_t *tcp_cli_thread; + switch_thread_t *gsmopen_signaling_thread; + switch_thread_t *gsmopen_api_thread; + //short audiobuf[SAMPLES_PER_FRAME]; + //int audiobuf_is_loaded; + + //int phonebook_listing; + //int phonebook_querying; + //int phonebook_listing_received_calls; + + //int phonebook_first_entry; + //int phonebook_last_entry; + //int phonebook_number_lenght; + //int phonebook_text_lenght; + int gsmopen_dir_entry_extension_prefix; + char gsmopen_user[256]; + char gsmopen_password[256]; + char destination[256]; + struct timeval answer_time; + + struct timeval transfer_time; + char transfer_callid_number[50]; + char gsmopen_transfer_call_id[512]; + int running; + unsigned long ib_calls; + unsigned long ob_calls; + unsigned long ib_failed_calls; + unsigned long ob_failed_calls; + + + char controldevice_name[50]; /*!< \brief name of the serial device controlling the interface, possibly none */ + int controldevprotocol; /*!< \brief which protocol is used for serial control of this interface */ + char controldevprotocolname[50]; /*!< \brief name of the serial device controlling protocol, one of "at" "fbus2" "no_serial" "alsa_voicemodem" */ + int controldevfd; /*!< \brief serial controlling file descriptor for this interface */ + //pthread_t controldev_thread; /*!< \brief serial control thread for this interface, running during the call */ +#ifdef WIN32 + int controldevice_speed; +#else + speed_t controldevice_speed; +#endif// WIN32 + int controldev_dead; + + char at_dial_pre_number[64]; + char at_dial_post_number[64]; + char at_dial_expect[64]; + unsigned int at_early_audio; + char at_hangup[64]; + char at_hangup_expect[64]; + char at_answer[64]; + char at_answer_expect[64]; + unsigned int at_initial_pause; + char at_preinit_1[64]; + char at_preinit_1_expect[64]; + char at_preinit_2[64]; + char at_preinit_2_expect[64]; + char at_preinit_3[64]; + char at_preinit_3_expect[64]; + char at_preinit_4[64]; + char at_preinit_4_expect[64]; + char at_preinit_5[64]; + char at_preinit_5_expect[64]; + unsigned int at_after_preinit_pause; + + char at_postinit_1[64]; + char at_postinit_1_expect[64]; + char at_postinit_2[64]; + char at_postinit_2_expect[64]; + char at_postinit_3[64]; + char at_postinit_3_expect[64]; + char at_postinit_4[64]; + char at_postinit_4_expect[64]; + char at_postinit_5[64]; + char at_postinit_5_expect[64]; + + char at_send_dtmf[64]; + + char at_query_battchg[64]; + char at_query_battchg_expect[64]; + char at_query_signal[64]; + char at_query_signal_expect[64]; + char at_call_idle[64]; + char at_call_incoming[64]; + char at_call_active[64]; + char at_call_failed[64]; + char at_call_calling[64]; + +#define CIEV_STRING_SIZE 64 + char at_indicator_noservice_string[64]; + char at_indicator_nosignal_string[64]; + char at_indicator_lowsignal_string[64]; + char at_indicator_lowbattchg_string[64]; + char at_indicator_nobattchg_string[64]; + char at_indicator_callactive_string[64]; + char at_indicator_nocallactive_string[64]; + char at_indicator_nocallsetup_string[64]; + char at_indicator_callsetupincoming_string[64]; + char at_indicator_callsetupoutgoing_string[64]; + char at_indicator_callsetupremoteringing_string[64]; + + int at_indicator_callp; + int at_indicator_callsetupp; + int at_indicator_roamp; + int at_indicator_battchgp; + int at_indicator_servicep; + int at_indicator_signalp; + + int at_has_clcc; + int at_has_ecam; + + char at_cmgw[16]; + int no_ucs2; + time_t gsmopen_serial_sync_period; + + time_t gsmopen_serial_synced_timestamp; + struct s_result line_array; + + + int unread_sms_msg_id; + int reading_sms_msg; + char sms_message[4800]; + char sms_sender[256]; + char sms_date[256]; + char sms_body[4800]; + char sms_datacodingscheme[256]; + char sms_servicecentreaddress[256]; + int sms_messagetype; + int sms_cnmi_not_supported; + int sms_pdu_not_supported; + //char sms_receiving_program[256]; + + + struct timeval call_incoming_time; + switch_mutex_t *controldev_lock; + + int phonebook_listing; + int phonebook_querying; + int phonebook_listing_received_calls; + + int phonebook_first_entry; + int phonebook_last_entry; + int phonebook_number_lenght; + int phonebook_text_lenght; + FILE *phonebook_writing_fp; + + struct timeval ringtime; + ciapa_t *owner; +#ifdef GSMOPEN_ALSA + snd_pcm_t *alsac; /*!< \brief handle of the ALSA capture audio device */ + snd_pcm_t *alsap; /*!< \brief handle of the ALSA playback audio device */ + char alsacname[50]; /*!< \brief name of the ALSA capture audio device */ + char alsapname[50]; /*!< \brief name of the ALSA playback audio device */ + int alsa_period_size; /*!< \brief ALSA period_size, in byte */ + int alsa_periods_in_buffer; /*!< \brief how many periods in ALSA buffer, to calculate buffer_size */ + unsigned long int alsa_buffer_size; /*!< \brief ALSA buffer_size, in byte */ + int alsawrite_filled; + int alsa_capture_is_mono; + int alsa_play_is_mono; + struct pollfd pfd; +#endif // GSMOPEN_ALSA + + time_t audio_play_reset_timestamp; + int audio_play_reset_period; + + switch_timer_t timer_read; + switch_timer_t timer_write; + teletone_dtmf_detect_state_t dtmf_detect; + switch_time_t old_dtmf_timestamp; + + int no_sound; + +#ifdef GSMOPEN_PORTAUDIO + int speexecho; + int speexpreprocess; + int portaudiocindex; /*!< \brief Index of the Portaudio capture audio device */ + int portaudiopindex; /*!< \brief Index of the Portaudio playback audio device */ + PABLIO_Stream *stream; + +#ifdef WANT_SPEEX + SpeexPreprocessState *preprocess; + SpeexEchoState *echo_state; +#endif// WANT_SPEEX +#endif// GSMOPEN_PORTAUDIO + dtmf_rx_state_t dtmf_state; + int active; + int home_network_registered; + int roaming_registered; + int not_registered; + int got_signal; + char imei[128]; + int requesting_imei; + char imsi[128]; + int requesting_imsi; + int network_creg_not_supported; + char creg[128]; + +}; + +typedef struct private_object private_t; + +void *SWITCH_THREAD_FUNC gsmopen_api_thread_func(switch_thread_t * thread, void *obj); +int gsmopen_audio_read(private_t * tech_pvt); +int gsmopen_audio_init(private_t * tech_pvt); +int gsmopen_signaling_read(private_t * tech_pvt); + +int gsmopen_call(private_t * tech_pvt, char *idest, int timeout); +int gsmopen_senddigit(private_t * tech_pvt, char digit); + +void *gsmopen_do_tcp_srv_thread_func(void *obj); +void *SWITCH_THREAD_FUNC gsmopen_do_tcp_srv_thread(switch_thread_t * thread, void *obj); + +void *gsmopen_do_tcp_cli_thread_func(void *obj); +void *SWITCH_THREAD_FUNC gsmopen_do_tcp_cli_thread(switch_thread_t * thread, void *obj); + +void *gsmopen_do_gsmopenapi_thread_func(void *obj); +void *SWITCH_THREAD_FUNC gsmopen_do_gsmopenapi_thread(switch_thread_t * thread, void *obj); +int dtmf_received(private_t * tech_pvt, char *value); +int start_audio_threads(private_t * tech_pvt); +int new_inbound_channel(private_t * tech_pvt); +int outbound_channel_answered(private_t * tech_pvt); +//int gsmopen_signaling_write(private_t * tech_pvt, char *msg_to_gsmopen); +#if defined(WIN32) && !defined(__CYGWIN__) +int gsmopen_pipe_read(switch_file_t * pipe, short *buf, int howmany); +int gsmopen_pipe_write(switch_file_t * pipe, short *buf, int howmany); +/* Visual C do not have strsep ? */ +char *strsep(char **stringp, const char *delim); +#else +int gsmopen_pipe_read(int pipe, short *buf, int howmany); +int gsmopen_pipe_write(int pipe, short *buf, int howmany); +#endif /* WIN32 */ +int gsmopen_close_socket(unsigned int fd); +private_t *find_available_gsmopen_interface_rr(private_t * tech_pvt_calling); +int remote_party_is_ringing(private_t * tech_pvt); +int remote_party_is_early_media(private_t * tech_pvt); +//int gsmopen_answer(private_t * tech_pvt, char *id, char *value); +#if 0 +int gsmopen_transfer(private_t * tech_pvt, char *id, char *value); +#endif //0 +int gsmopen_socket_create_and_bind(private_t * tech_pvt, int *which_port); + + + + + +void *gsmopen_do_controldev_thread(void *data); +#ifdef WIN32 +int gsmopen_serial_init(private_t * tech_pvt, int controldevice_speed); +#else +int gsmopen_serial_init(private_t * tech_pvt, speed_t controldevice_speed); +#endif //WIN32 +int gsmopen_serial_monitor(private_t * tech_pvt); +int gsmopen_serial_sync(private_t * tech_pvt); +int gsmopen_serial_sync_AT(private_t * tech_pvt); +int gsmopen_serial_config(private_t * tech_pvt); +int gsmopen_serial_config_AT(private_t * tech_pvt); + +#define gsmopen_serial_write_AT_expect(P, D, S) gsmopen_serial_write_AT_expect1(P, D, S, 1, 2) +#define gsmopen_serial_write_AT_expect_noexpcr(P, D, S) gsmopen_serial_write_AT_expect1(P, D, S, 0, 2) +#define gsmopen_serial_write_AT_expect_noexpcr_tout(P, D, S, T) gsmopen_serial_write_AT_expect1(P, D, S, 0, T) +// 20.5 sec timeout, used for querying the SIM and sending SMSs +#define gsmopen_serial_write_AT_expect_longtime(P, D, S) gsmopen_serial_write_AT_expect1(P, D, S, 1, 20) +#define gsmopen_serial_write_AT_expect_longtime_noexpcr(P, D, S) gsmopen_serial_write_AT_expect1(P, D, S, 0, 20) +int gsmopen_serial_write_AT(private_t * tech_pvt, const char *data); +int gsmopen_serial_write_AT_nocr(private_t * tech_pvt, const char *data); +int gsmopen_serial_write_AT_ack(private_t * tech_pvt, const char *data); +int gsmopen_serial_write_AT_ack_nocr_longtime(private_t * tech_pvt, const char *data); +int gsmopen_serial_write_AT_noack(private_t * tech_pvt, const char *data); +int gsmopen_serial_write_AT_expect1(private_t * tech_pvt, const char *data, const char *expected_string, int expect_crlf, int seconds); +int gsmopen_serial_AT_expect(private_t * tech_pvt, const char *expected_string, int expect_crlf, int seconds); +int gsmopen_serial_read_AT(private_t * tech_pvt, int look_for_ack, int timeout_usec, int timeout_sec, const char *expected_string, int expect_crlf); +int gsmopen_serial_read(private_t * tech_pvt); +#ifdef NOTDEF +int gsmopen_serial_getstatus(private_t * tech_pvt); +int gsmopen_serial_hangup(private_t * tech_pvt); +int gsmopen_serial_answer(private_t * tech_pvt); +int gsmopen_serial_answer_AT(private_t * tech_pvt); +int gsmopen_serial_hangup_AT(private_t * tech_pvt); +int gsmopen_serial_call_AT(private_t * tech_pvt, char *dstr); +int gsmopen_serial_getstatus_AT(private_t * tech_pvt); +#endif // NOTDEF +#define RESULT_FAILURE 0 +#define RESULT_SUCCESS 1 +int utf_to_ucs2(private_t * tech_pvt, char *utf_in, size_t inbytesleft, char *ucs2_out, size_t outbytesleft); +int ucs2_to_utf8(private_t * tech_pvt, char *ucs2_in, char *utf8_out, size_t outbytesleft); +//#define PUSHA_UNLOCKA(x) pthread_cleanup_push(gsmopen_unlocka_log, (void *) x); +//#define POPPA_UNLOCKA(x) pthread_cleanup_pop(0); + +#define PUSHA_UNLOCKA(x) if(option_debug > 100) ERRORA("PUSHA_UNLOCKA: %p\n", GSMOPEN_P_LOG, (void *)x); +#define POPPA_UNLOCKA(x) if(option_debug > 100) ERRORA("POPPA_UNLOCKA: %p\n", GSMOPEN_P_LOG, (void *)x); +//#define LOKKA(x) if(option_debug > 100) ERRORA("LOKKA: %p\n", GSMOPEN_P_LOG, (void *)x); +#define LOKKA(x) switch_mutex_lock(x); +#define UNLOCKA(x) switch_mutex_unlock(x); +//#define UNLOCKA(x) if(option_debug > 100) ERRORA("UNLOCKA: %p\n", GSMOPEN_P_LOG, (void *)x); + +#define gsmopen_queue_control(x, y) ERRORA("gsmopen_queue_control: %p, %d\n", GSMOPEN_P_LOG, (void *)x, y); + +#define ast_setstate(x, y) ERRORA("ast_setstate: %p, %d\n", GSMOPEN_P_LOG, (void *)x, y); + +int gsmopen_serial_read(private_t * tech_pvt); +int gsmopen_answer(private_t * tech_pvt); +int gsmopen_serial_answer(private_t * tech_pvt); +int gsmopen_serial_answer_AT(private_t * tech_pvt); +int gsmopen_serial_hangup(private_t * tech_pvt); +int gsmopen_serial_hangup_AT(private_t * tech_pvt); +int gsmopen_hangup(private_t * tech_pvt); +int gsmopen_serial_call(private_t * tech_pvt, char *dstr); +int gsmopen_serial_call_AT(private_t * tech_pvt, char *dstr); +int gsmopen_sendsms(private_t * tech_pvt, char *dest, char *text); + +#ifdef GSMOPEN_ALSA +int alsa_init(private_t * tech_pvt); +int alsa_shutdown(private_t * tech_pvt); +snd_pcm_t *alsa_open_dev(private_t * tech_pvt, snd_pcm_stream_t stream); +int alsa_write(private_t * tech_pvt, short *data, int datalen); +int alsa_read(private_t * tech_pvt, short *data, int datalen); + +#endif /* GSMOPEN_ALSA */ + + +void gsmopen_store_boost(char *s, double *boost); +int gsmopen_sound_boost(void *data, int samples_num, double boost); +int sms_incoming(private_t * tech_pvt); +int gsmopen_ring(private_t * tech_pvt); + +int iso_8859_1_to_utf8(private_t * tech_pvt, char *iso_8859_1_in, char *utf8_out, size_t outbytesleft); +int gsmopen_serial_getstatus_AT(private_t * tech_pvt); + + +#ifdef GSMOPEN_PORTAUDIO + +int gsmopen_portaudio_devlist(private_t *tech_pvt); + +int gsmopen_portaudio_init(private_t *tech_pvt); + +int gsmopen_portaudio_write(private_t * tech_pvt, short *data, int datalen); + +int gsmopen_portaudio_read(private_t * tech_pvt, short *data, int datalen); + + +int gsmopen_portaudio_shutdown(private_t *tech_pvt); + +#endif // GSMOPEN_PORTAUDIO +int dump_event(private_t *tech_pvt); +int alarm_event(private_t * tech_pvt, int alarm_code, const char *alarm_message); +int dump_event_full(private_t * tech_pvt, int is_alarm, int alarm_code, const char *alarm_message); diff --git a/src/mod/endpoints/mod_gsmopen/gsmopen_protocol.cpp b/src/mod/endpoints/mod_gsmopen/gsmopen_protocol.cpp new file mode 100644 index 0000000000..e4bb6b9200 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/gsmopen_protocol.cpp @@ -0,0 +1,3994 @@ +#include "gsmopen.h" +//#include + +#ifndef NO_GSMLIB +#include +#ifdef WIN32 +#include +#else +#include +#endif +#include +#include + + +using namespace std; +using namespace gsmlib; +#endif// NO_GSMLIB + +#ifdef ASTERISK +#define gsmopen_sleep usleep +#define gsmopen_strncpy strncpy +#define tech_pvt p +extern int gsmopen_debug; +extern char *gsmopen_console_active; +#else /* FREESWITCH */ +#define gsmopen_sleep switch_sleep +#define gsmopen_strncpy switch_copy_string +extern switch_memory_pool_t *gsmopen_module_pool; +extern switch_endpoint_interface_t *gsmopen_endpoint_interface; +#endif /* ASTERISK */ +//int samplerate_gsmopen = SAMPLERATE_GSMOPEN; + +extern int running; +int gsmopen_dir_entry_extension = 1; + +int option_debug = 100; + + +#ifdef WIN32 +#define GSMLIBGIO +#else //WIN32 +#undef GSMLIBGIO +#endif //WIN32 + +#ifdef WIN32 +/***************/ +// from http://www.openasthra.com/c-tidbits/gettimeofday-function-for-windows/ + +#include + +#if defined(_MSC_VER) || defined(_MSC_EXTENSIONS) +#define DELTA_EPOCH_IN_MICROSECS 11644473600000000Ui64 +#else /* */ +#define DELTA_EPOCH_IN_MICROSECS 11644473600000000ULL +#endif /* */ +struct sk_timezone { + int tz_minuteswest; /* minutes W of Greenwich */ + int tz_dsttime; /* type of dst correction */ +}; +int gettimeofday(struct timeval *tv, struct sk_timezone *tz) +{ + FILETIME ft; + unsigned __int64 tmpres = 0; + static int tzflag; + if (NULL != tv) { + GetSystemTimeAsFileTime(&ft); + tmpres |= ft.dwHighDateTime; + tmpres <<= 32; + tmpres |= ft.dwLowDateTime; + + /*converting file time to unix epoch */ + tmpres /= 10; /*convert into microseconds */ + tmpres -= DELTA_EPOCH_IN_MICROSECS; + tv->tv_sec = (long) (tmpres / 1000000UL); + tv->tv_usec = (long) (tmpres % 1000000UL); + } + if (NULL != tz) { + if (!tzflag) { + _tzset(); + tzflag++; + } + tz->tz_minuteswest = _timezone / 60; + tz->tz_dsttime = _daylight; + } + return 0; +} + +/***************/ +#endif /* WIN32 */ + +#ifdef GSMOPEN_PORTAUDIO +#include "pablio.h" + +#ifndef GIOVA48 +#define SAMPLES_PER_FRAME 160 +#else // GIOVA48 +#define SAMPLES_PER_FRAME 960 +#endif // GIOVA48 + +int gsmopen_portaudio_devlist(private_t *tech_pvt) +{ + int i, numDevices; + const PaDeviceInfo *deviceInfo; + + numDevices = Pa_GetDeviceCount(); + if (numDevices < 0) { + return 0; + } + for (i = 0; i < numDevices; i++) { + deviceInfo = Pa_GetDeviceInfo(i); + NOTICA + ("Found PORTAUDIO device: id=%d\tname=%s\tmax input channels=%d\tmax output channels=%d\n", + GSMOPEN_P_LOG, i, deviceInfo->name, deviceInfo->maxInputChannels, + deviceInfo->maxOutputChannels); + } + + return numDevices; +} + +int gsmopen_portaudio_init(private_t *tech_pvt) +{ + PaError err; + int c; + PaStreamParameters inputParameters, outputParameters; + int numdevices; + const PaDeviceInfo *deviceInfo; + +#ifndef GIOVA48 + setenv("PA_ALSA_PLUGHW", "1", 1); +#endif // GIOVA48 + + err = Pa_Initialize(); + if (err != paNoError) + return err; + + numdevices = gsmopen_portaudio_devlist(tech_pvt); + + if (tech_pvt->portaudiocindex > (numdevices - 1)) { + ERRORA("Portaudio Capture id=%d is out of range: valid id are from 0 to %d\n", + GSMOPEN_P_LOG, tech_pvt->portaudiocindex, (numdevices - 1)); + return -1; + } + + if (tech_pvt->portaudiopindex > (numdevices - 1)) { + ERRORA("Portaudio Playback id=%d is out of range: valid id are from 0 to %d\n", + GSMOPEN_P_LOG, tech_pvt->portaudiopindex, (numdevices - 1)); + return -1; + } + //inputParameters.device = 0; + if (tech_pvt->portaudiocindex != -1) { + inputParameters.device = tech_pvt->portaudiocindex; + } else { + inputParameters.device = Pa_GetDefaultInputDevice(); + } + deviceInfo = Pa_GetDeviceInfo(inputParameters.device); + NOTICA + ("Using INPUT PORTAUDIO device: id=%d\tname=%s\tmax input channels=%d\tmax output channels=%d\n", + GSMOPEN_P_LOG, inputParameters.device, deviceInfo->name, + deviceInfo->maxInputChannels, deviceInfo->maxOutputChannels); + if (deviceInfo->maxInputChannels == 0) { + ERRORA + ("No INPUT channels on device: id=%d\tname=%s\tmax input channels=%d\tmax output channels=%d\n", + GSMOPEN_P_LOG, inputParameters.device, deviceInfo->name, + deviceInfo->maxInputChannels, deviceInfo->maxOutputChannels); + return -1; + } + inputParameters.channelCount = 1; + inputParameters.sampleFormat = paInt16; + //inputParameters.suggestedLatency = Pa_GetDeviceInfo(inputParameters.device)->defaultHighInputLatency; + inputParameters.suggestedLatency = 0.1; + inputParameters.hostApiSpecificStreamInfo = NULL; + + //outputParameters.device = 3; + if (tech_pvt->portaudiopindex != -1) { + outputParameters.device = tech_pvt->portaudiopindex; + } else { + outputParameters.device = Pa_GetDefaultOutputDevice(); + } + deviceInfo = Pa_GetDeviceInfo(outputParameters.device); + NOTICA + ("Using OUTPUT PORTAUDIO device: id=%d\tname=%s\tmax input channels=%d\tmax output channels=%d\n", + GSMOPEN_P_LOG, outputParameters.device, deviceInfo->name, + deviceInfo->maxInputChannels, deviceInfo->maxOutputChannels); + if (deviceInfo->maxOutputChannels == 0) { + ERRORA + ("No OUTPUT channels on device: id=%d\tname=%s\tmax input channels=%d\tmax output channels=%d\n", + GSMOPEN_P_LOG, inputParameters.device, deviceInfo->name, + deviceInfo->maxInputChannels, deviceInfo->maxOutputChannels); + return -1; + } +#ifndef GIOVA48 + outputParameters.channelCount = 1; +#else // GIOVA48 + outputParameters.channelCount = 2; +#endif // GIOVA48 + outputParameters.sampleFormat = paInt16; + //outputParameters.suggestedLatency = Pa_GetDeviceInfo(outputParameters.device)->defaultHighOutputLatency; + outputParameters.suggestedLatency = 0.1; + outputParameters.hostApiSpecificStreamInfo = NULL; + +/* build the pipe that will be polled on by pbx */ + c = pipe(tech_pvt->audiopipe); + if (c) { + ERRORA("Unable to create audio pipe\n", GSMOPEN_P_LOG); + return -1; + } + fcntl(tech_pvt->audiopipe[0], F_SETFL, O_NONBLOCK); + fcntl(tech_pvt->audiopipe[1], F_SETFL, O_NONBLOCK); + + err = +#ifndef GIOVA48 + OpenAudioStream(&tech_pvt->stream, &inputParameters, &outputParameters, 8000, + paClipOff|paDitherOff, SAMPLES_PER_FRAME, 0); + //&tech_pvt->speexecho, &tech_pvt->speexpreprocess, &tech_pvt->owner); + +#else // GIOVA48 + OpenAudioStream(&tech_pvt->stream, &inputParameters, &outputParameters, 48000, + paDitherOff | paClipOff, SAMPLES_PER_FRAME, tech_pvt->audiopipe[1], + &tech_pvt->speexecho, &tech_pvt->speexpreprocess, &tech_pvt->owner); + + +#endif// GIOVA48 + if (err != paNoError) { + ERRORA("Unable to open audio stream: %s\n", GSMOPEN_P_LOG, Pa_GetErrorText(err)); + return -1; + } + +/* the pipe is our audio fd for pbx to poll on */ + tech_pvt->gsmopen_sound_capt_fd = tech_pvt->audiopipe[0]; + + return 0; +} +//int gsmopen_portaudio_write(private_t *tech_pvt, struct ast_frame *f) +int gsmopen_portaudio_write(private_t * tech_pvt, short *data, int datalen) +{ + int samples; +#ifdef GIOVA48 + //short buf[GSMOPEN_FRAME_SIZE * 2]; + short buf[3840]; + short *buf2; + + //ERRORA("1 f->datalen=: %d\n", GSMOPEN_P_LOG, f->datalen); + + + + + memset(buf, '\0', GSMOPEN_FRAME_SIZE *2); + + buf2 = f->data; + + int i=0, a=0; + + for(i=0; i< f->datalen / sizeof(short); i++){ +//stereo, 2 chan 48 -> mono 8 + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + buf[a] = buf2[i]; + a++; + /* + */ + } + f->data = &buf; + f->datalen = f->datalen * 6; + //ERRORA("2 f->datalen=: %d\n", GSMOPEN_P_LOG, f->datalen); + //f->datalen = f->datalen; +#endif // GIOVA48 + + + samples = + WriteAudioStream(tech_pvt->stream, (short *) data, (int) (datalen / sizeof(short)), &tech_pvt->timer_write); + + if (samples != (int) (datalen / sizeof(short))) + ERRORA("WriteAudioStream wrote: %d of %d\n", GSMOPEN_P_LOG, samples, + (int) (datalen / sizeof(short))); + + return samples; +} +//struct ast_frame *gsmopen_portaudio_read(private_t *tech_pvt) +#define AST_FRIENDLY_OFFSET 0 +int gsmopen_portaudio_read(private_t * tech_pvt, short *data, int datalen) +{ +#if 0 + //static struct ast_frame f; + static short __buf[GSMOPEN_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2]; + short *buf; + static short __buf2[GSMOPEN_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2]; + short *buf2; + int samples; + //char c; + + memset(__buf, '\0', (GSMOPEN_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2)); + + buf = __buf + AST_FRIENDLY_OFFSET / 2; + + memset(__buf2, '\0', (GSMOPEN_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2)); + + buf2 = __buf2 + AST_FRIENDLY_OFFSET / 2; + +#if 0 + f.frametype = AST_FRAME_NULL; + f.subclass = 0; + f.samples = 0; + f.datalen = 0; + +#ifdef ASTERISK_VERSION_1_6_1 + f.data.ptr = NULL; +#else + f.data = NULL; +#endif /* ASTERISK_VERSION_1_6_1 */ + f.offset = 0; + f.src = gsmopen_type; + f.mallocd = 0; + f.delivery.tv_sec = 0; + f.delivery.tv_usec = 0; +#endif //0 + + //if ((samples = ReadAudioStream(tech_pvt->stream, buf, SAMPLES_PER_FRAME)) == 0) + //if ((samples = ReadAudioStream(tech_pvt->stream, data, datalen/sizeof(short))) == 0) + if (samples = ReadAudioStream(tech_pvt->stream, (short *)data, datalen, &tech_pvt->timer_read) == 0) { + //do nothing + } else { +#ifdef GIOVA48 + int i=0, a=0; + + samples = samples / 6; + for(i=0; i< samples; i++){ + buf2[i] = buf[a]; + a = a + 6; //mono, 1 chan 48 -> 8 + } + buf = buf2; + +#if 0 + /* A real frame */ + f.frametype = AST_FRAME_VOICE; + f.subclass = AST_FORMAT_SLINEAR; + f.samples = GSMOPEN_FRAME_SIZE/6; + f.datalen = GSMOPEN_FRAME_SIZE * 2/6; +#endif //0 +#else// GIOVA48 +#if 0 + /* A real frame */ + f.frametype = AST_FRAME_VOICE; + f.subclass = AST_FORMAT_SLINEAR; + f.samples = GSMOPEN_FRAME_SIZE; + f.datalen = GSMOPEN_FRAME_SIZE * 2; +#endif //0 +#endif// GIOVA48 + +#if 0 +#ifdef ASTERISK_VERSION_1_6_1 + f.data.ptr = buf; +#else + f.data = buf; +#endif /* ASTERISK_VERSION_1_6_1 */ + f.offset = AST_FRIENDLY_OFFSET; + f.src = gsmopen_type; + f.mallocd = 0; +#endif //0 + } + +#if 0 + read(tech_pvt->audiopipe[0], &c, 1); + + return &f; +#endif //0 +#endif //0 + + int samples; + samples = ReadAudioStream(tech_pvt->stream, (short *)data, datalen, &tech_pvt->timer_read); + //WARNINGA("samples=%d\n", GSMOPEN_P_LOG, samples); + + return samples; +} +int gsmopen_portaudio_shutdown(private_t *tech_pvt) +{ + PaError err; + + err = CloseAudioStream(tech_pvt->stream); + + if (err != paNoError) + ERRORA("not able to CloseAudioStream\n", GSMOPEN_P_LOG); + + Pa_Terminate(); + return 0; +} + + + + +#endif // GSMOPEN_PORTAUDIO +#ifndef GSMLIBGIO +int gsmopen_serial_init(private_t * tech_pvt, speed_t controldevice_speed) +{ + int fd; + int rt; + struct termios tp; + unsigned int status = 0; + unsigned int flags = TIOCM_DTR; + +/* if there is a file descriptor, close it. But it is probably just an old value, so don't check for close success*/ + fd = tech_pvt->controldevfd; + if (fd) { + close(fd); + } +/* open the serial port */ +//#ifdef __CYGWIN__ + fd = open(tech_pvt->controldevice_name, O_RDWR | O_NOCTTY | O_NONBLOCK); + sleep(1); + close(fd); +//#endif /* __CYGWIN__ */ + fd = open(tech_pvt->controldevice_name, O_RDWR | O_NOCTTY | O_NONBLOCK); + if (fd == -1) { + perror("open error "); + DEBUGA_GSMOPEN("serial error: %s\n", GSMOPEN_P_LOG, strerror(errno)); + tech_pvt->controldevfd = fd; + return -1; + } +/* flush it */ + rt = tcflush(fd, TCIFLUSH); + if (rt == -1) { + ERRORA("serial error: %s", GSMOPEN_P_LOG, strerror(errno)); + } +/* attributes */ + tp.c_cflag = B0 | CS8 | CLOCAL | CREAD | HUPCL; + tp.c_iflag = IGNPAR; + tp.c_cflag &= ~CRTSCTS; + tp.c_oflag = 0; + tp.c_lflag = 0; + tp.c_cc[VMIN] = 1; + tp.c_cc[VTIME] = 0; +/* set controldevice_speed */ + rt = cfsetispeed(&tp, tech_pvt->controldevice_speed); + if (rt == -1) { + ERRORA("serial error: %s, speed was: %d", GSMOPEN_P_LOG, strerror(errno), tech_pvt->controldevice_speed); + } + rt = cfsetospeed(&tp, tech_pvt->controldevice_speed); + if (rt == -1) { + ERRORA("serial error: %s", GSMOPEN_P_LOG, strerror(errno)); + } +/* set port attributes */ + if (tcsetattr(fd, TCSADRAIN, &tp) == -1) { + ERRORA("serial error: %s", GSMOPEN_P_LOG, strerror(errno)); + } + rt = tcsetattr(fd, TCSANOW, &tp); + if (rt == -1) { + ERRORA("serial error: %s", GSMOPEN_P_LOG, strerror(errno)); + } +#ifndef __CYGWIN__ + ioctl(fd, TIOCMGET, &status); + status |= TIOCM_DTR; /* Set DTR high */ + status &= ~TIOCM_RTS; /* Set RTS low */ + ioctl(fd, TIOCMSET, &status); + ioctl(fd, TIOCMGET, &status); + ioctl(fd, TIOCMBIS, &flags); + flags = TIOCM_RTS; + ioctl(fd, TIOCMBIC, &flags); + ioctl(fd, TIOCMGET, &status); +#else /* __CYGWIN__ */ + ioctl(fd, TIOCMGET, &status); + status |= TIOCM_DTR; /* Set DTR high */ + status &= ~TIOCM_RTS; /* Set RTS low */ + ioctl(fd, TIOCMSET, &status); +#endif /* __CYGWIN__ */ + tech_pvt->controldevfd = fd; + DEBUGA_GSMOPEN("Syncing Serial, fd=%d, protocol=%d\n", GSMOPEN_P_LOG, fd, tech_pvt->controldevprotocol); + rt = gsmopen_serial_sync(tech_pvt); + if (rt == -1) { + ERRORA("Serial init error\n", GSMOPEN_P_LOG); + return -1; + } + return (fd); +} +#else //GSMLIBGIO +#ifdef WIN32 +int gsmopen_serial_init(private_t * tech_pvt, int controldevice_speed) +#else +int gsmopen_serial_init(private_t * tech_pvt, speed_t controldevice_speed) +#endif //WIN32 +{ + int i; + string ciapa; + SMSMessageRef sms; + char content2[1000]; + int size; + +#ifdef WIN32 + Ref port = new Win32SerialPort((string) tech_pvt->controldevice_name, 38400); +#else + //Ref port = new UnixSerialPort((string)argv[1], B38400); + Ref < Port > port = new UnixSerialPort((string) tech_pvt->controldevice_name, B115200); +#endif + MeTa m(port); + + //cout << "Creating GsmAt object" << endl; + Ref gsmat = new GsmAt(m); + + //cout << "Using GsmAt object" << endl; + //cout << gsmat->chat("AT", "OK", false, false) << endl; + //cout << gsmat->chat("D3472665618;") << endl; + gsmat->putLine("AT+cgmm", true); + for (i = 0; i < 4; i++) { + ciapa = gsmat->getLine(); + //cout << "PRESO: |||" << ciapa << "|||" << endl; + NOTICA("PRESO %d |||%s|||\n", GSMOPEN_P_LOG, i, ciapa.c_str()); + //gsmopen_sleep(5000); + } + + sms = SMSMessage::decode("079194710167120004038571F1390099406180904480A0D41631067296EF7390383D07CD622E58CD95CB81D6EF39BDEC66BFE7207A794E2FBB4320AFB82C07E56020A8FC7D9687DBED32285C9F83A06F769A9E5EB340D7B49C3E1FA3C3663A0B24E4CBE76516680A7FCBE920725A5E5ED341F0B21C346D4E41E1BA790E4286DDE4BC0BD42CA3E5207258EE1797E5A0BA9B5E9683C86539685997EBEF61341B249BC966"); // dataCodingScheme = 0 + NOTICA("SMS=\n%s\n", GSMOPEN_P_LOG, sms->toString().c_str()); + sms = SMSMessage::decode("0791934329002000040C9193432766658100009001211133318004D4F29C0E"); // dataCodingScheme = 0 + NOTICA("SMS=\n%s\n", GSMOPEN_P_LOG, sms->toString().c_str()); + sms = SMSMessage::decode("0791934329002000040C919343276665810008900121612521801600CC00E800E900F900F200E00020006300690061006F"); // dataCodingScheme = 8 + NOTICA("SMS=\n%s\n", GSMOPEN_P_LOG, sms->toString().c_str()); + sms = SMSMessage::decode("0791934329002000040C919343276665810008900172002293404C006300690061006F0020003100320033002000620065006C00E80020043D043E0432043E044104420438002005DC05E7002005E805D005EA0020FE8EFEE0FEA0FEE4FECBFE9300204EBA5927"); // dataCodingScheme = 8 , text=ciao 123 belè новоÑти לק ר×ת ﺎﻠﺠﻤﻋﺓ 人大 + NOTICA("SMS=\n%s\n", GSMOPEN_P_LOG, sms->toString().c_str()); + sms = SMSMessage::decode("07911497941902F00414D0E474989D769F5DE4320839001040122151820000"); // dataCodingScheme = 0 + NOTICA("SMS=\n%s\n", GSMOPEN_P_LOG, sms->toString().c_str()); + +#if 0 + size = MultiByteToWideChar(CP_OEMCP, 0, username, strlen(username)+1, UserName, 0); + UserName=(wchar_t*)GlobalAlloc(GME­ M_ZEROINIT, size); + ret = MultiByteToWideChar(CP_OEMCP, 0, username, strlen(username)+1, UserName, size); + if(ret == 0) + getError(GetLastError()); +#endif //0 + return (-1); +} + +#endif //GSMLIBGIO + + +int gsmopen_serial_read(private_t * tech_pvt) +{ + if (tech_pvt->controldevprotocol == PROTOCOL_AT) + return gsmopen_serial_read_AT(tech_pvt, 0, 100000, 0, NULL, 1); // a 10th of a second timeout +#ifdef GSMOPEN_FBUS2 + if (tech_pvt->controldevprotocol == PROTOCOL_FBUS2) + return gsmopen_serial_read_FBUS2(tech_pvt); +#endif /* GSMOPEN_FBUS2 */ +#ifdef GSMOPEN_CVM + if (tech_pvt->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return gsmopen_serial_read_CVM_BUSMAIL(tech_pvt); +#endif /* GSMOPEN_CVM */ + return -1; +} + + +int gsmopen_serial_sync(private_t * tech_pvt) +{ + if (tech_pvt->controldevprotocol == PROTOCOL_AT) + return gsmopen_serial_sync_AT(tech_pvt); +#ifdef GSMOPEN_FBUS2 + if (tech_pvt->controldevprotocol == PROTOCOL_FBUS2) + return gsmopen_serial_sync_FBUS2(tech_pvt); +#endif /* GSMOPEN_FBUS2 */ +#ifdef GSMOPEN_CVM + if (tech_pvt->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return gsmopen_serial_sync_CVM_BUSMAIL(tech_pvt); +#endif /* GSMOPEN_CVM */ + + return -1; +} + +int gsmopen_serial_config(private_t * tech_pvt) +{ +#ifndef NO_GSMLIB + SMSMessageRef sms; + char content2[1000]; + //sms = SMSMessage::decode("079194710167120004038571F1390099406180904480A0D41631067296EF7390383D07CD622E58CD95CB81D6EF39BDEC66BFE7207A794E2FBB4320AFB82C07E56020A8FC7D9687DBED32285C9F83A06F769A9E5EB340D7B49C3E1FA3C3663A0B24E4CBE76516680A7FCBE920725A5E5ED341F0B21C346D4E41E1BA790E4286DDE4BC0BD42CA3E5207258EE1797E5A0BA9B5E9683C86539685997EBEF61341B249BC966"); // dataCodingScheme = 0 + //sms = SMSMessage::decode("0791934329002000040C9193432766658100009001211133318004D4F29C0E"); // dataCodingScheme = 0 + //sms = SMSMessage::decode("0791934329002000040C919343276665810008900121612521801600CC00E800E900F900F200E00020006300690061006F"); // dataCodingScheme = 8 + sms = SMSMessage::decode("0791934329002000040C919343276665810008900172002293404C006300690061006F0020003100320033002000620065006C00E80020043D043E0432043E044104420438002005DC05E7002005E805D005EA0020FE8EFEE0FEA0FEE4FECBFE9300204EBA5927"); // dataCodingScheme = 8 , text=ciao 123 belè новоÑти לק ר×ת ﺎﻠﺠﻤﻋﺓ 人大 + //sms = SMSMessage::decode("07911497941902F00414D0E474989D769F5DE4320839001040122151820000"); // dataCodingScheme = 0 + //NOTICA("SMS=\n%s\n", GSMOPEN_P_LOG, sms->toString().c_str()); + + memset(content2, '\0', sizeof(content2)); + if (sms->dataCodingScheme().getAlphabet() == DCS_DEFAULT_ALPHABET) { + iso_8859_1_to_utf8(tech_pvt, (char *) sms->userData().c_str(), content2, sizeof(content2)); + } else if (sms->dataCodingScheme().getAlphabet() == DCS_SIXTEEN_BIT_ALPHABET) { + ucs2_to_utf8(tech_pvt, (char *) bufToHex((unsigned char *) sms->userData().data(), sms->userData().length()).c_str(), content2, + sizeof(content2)); + } else { + ERRORA("dataCodingScheme not supported=%d\n", GSMOPEN_P_LOG, sms->dataCodingScheme().getAlphabet()); + + } + //NOTICA("dataCodingScheme=%d\n", GSMOPEN_P_LOG, sms->dataCodingScheme().getAlphabet()); + //NOTICA("userData= |||%s|||\n", GSMOPEN_P_LOG, content2); +#endif// NO_GSMLIB + + if (tech_pvt->controldevprotocol == PROTOCOL_AT) + return gsmopen_serial_config_AT(tech_pvt); +#ifdef GSMOPEN_FBUS2 + if (tech_pvt->controldevprotocol == PROTOCOL_FBUS2) + return gsmopen_serial_config_FBUS2(tech_pvt); +#endif /* GSMOPEN_FBUS2 */ +#ifdef GSMOPEN_CVM + if (tech_pvt->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return gsmopen_serial_config_CVM_BUSMAIL(tech_pvt); +#endif /* GSMOPEN_CVM */ + + return -1; +} + +int gsmopen_serial_config_AT(private_t * tech_pvt) +{ + int res; + char at_command[5]; + int i; + +/* initial_pause? */ + if (tech_pvt->at_initial_pause) { + DEBUGA_GSMOPEN("sleeping for %d usec\n", GSMOPEN_P_LOG, tech_pvt->at_initial_pause); + gsmopen_sleep(tech_pvt->at_initial_pause); + } + +/* go until first empty preinit string, or last preinit string */ + while (1) { + + if (strlen(tech_pvt->at_preinit_1)) { + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_preinit_1, tech_pvt->at_preinit_1_expect); + if (res) { + DEBUGA_GSMOPEN("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, tech_pvt->at_preinit_1, tech_pvt->at_preinit_1_expect); + } + } else { + break; + } + + if (strlen(tech_pvt->at_preinit_2)) { + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_preinit_2, tech_pvt->at_preinit_2_expect); + if (res) { + DEBUGA_GSMOPEN("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, tech_pvt->at_preinit_2, tech_pvt->at_preinit_2_expect); + } + } else { + break; + } + + if (strlen(tech_pvt->at_preinit_3)) { + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_preinit_3, tech_pvt->at_preinit_3_expect); + if (res) { + DEBUGA_GSMOPEN("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, tech_pvt->at_preinit_3, tech_pvt->at_preinit_3_expect); + } + } else { + break; + } + + if (strlen(tech_pvt->at_preinit_4)) { + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_preinit_4, tech_pvt->at_preinit_4_expect); + if (res) { + DEBUGA_GSMOPEN("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, tech_pvt->at_preinit_4, tech_pvt->at_preinit_4_expect); + } + } else { + break; + } + + if (strlen(tech_pvt->at_preinit_5)) { + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_preinit_5, tech_pvt->at_preinit_5_expect); + if (res) { + DEBUGA_GSMOPEN("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, tech_pvt->at_preinit_5, tech_pvt->at_preinit_5_expect); + } + } else { + break; + } + + break; + } + +/* after_preinit_pause? */ + if (tech_pvt->at_after_preinit_pause) { + DEBUGA_GSMOPEN("sleeping for %d usec\n", GSMOPEN_P_LOG, tech_pvt->at_after_preinit_pause); + gsmopen_sleep(tech_pvt->at_after_preinit_pause); + } + + /* phone, brother, art you alive? */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT"); + if (res) { + ERRORA("no response to AT\n", GSMOPEN_P_LOG); + return -1; + } + /* for motorola, bring it back to "normal" mode if it happens to be in another mode */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+mode=0"); + if (res) { + DEBUGA_GSMOPEN("AT+mode=0 does not get OK from the phone. If it is NOT Motorola," " no problem.\n", GSMOPEN_P_LOG); + } + gsmopen_sleep(50000); + /* for motorola end */ + + /* reset AT configuration to phone default */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "ATZ"); + if (res) { + DEBUGA_GSMOPEN("ATZ failed\n", GSMOPEN_P_LOG); + } + + /* disable AT command echo */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "ATE0"); + if (res) { + DEBUGA_GSMOPEN("ATE0 failed\n", GSMOPEN_P_LOG); + } + + /* disable extended error reporting */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CMEE=0"); + if (res) { + DEBUGA_GSMOPEN("AT+CMEE failed\n", GSMOPEN_P_LOG); + } + + /* various phone manufacturer identifier */ + for (i = 0; i < 10; i++) { + memset(at_command, 0, sizeof(at_command)); + sprintf(at_command, "ATI%d", i); + res = gsmopen_serial_write_AT_ack(tech_pvt, at_command); + if (res) { + DEBUGA_GSMOPEN("ATI%d command failed, continue\n", GSMOPEN_P_LOG, i); + } + } + + /* phone manufacturer */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CGMI"); + if (res) { + DEBUGA_GSMOPEN("AT+CGMI failed\n", GSMOPEN_P_LOG); + } + + /* phone model */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CGMM"); + if (res) { + DEBUGA_GSMOPEN("AT+CGMM failed\n", GSMOPEN_P_LOG); + } + + /* signal network registration with a +CREG unsolicited msg */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CREG=1"); + if (res) { + DEBUGA_GSMOPEN("AT+CREG=1 failed\n", GSMOPEN_P_LOG); + tech_pvt->network_creg_not_supported = 1; + } + if(!tech_pvt->network_creg_not_supported){ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CREG?"); + if (res) { + DEBUGA_GSMOPEN("AT+CREG? failed\n", GSMOPEN_P_LOG); + } + } + /* query signal strength */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSQ"); + if (res) { + DEBUGA_GSMOPEN("AT+CSQ failed\n", GSMOPEN_P_LOG); + } + /* IMEI */ + tech_pvt->requesting_imei = 1; + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+GSN"); + tech_pvt->requesting_imei = 0; + if (res) { + DEBUGA_GSMOPEN("AT+GSN failed\n", GSMOPEN_P_LOG); + tech_pvt->requesting_imei = 1; + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CGSN"); + tech_pvt->requesting_imei = 0; + if (res) { + DEBUGA_GSMOPEN("AT+CGSN failed\n", GSMOPEN_P_LOG); + } + } + /* IMSI */ + tech_pvt->requesting_imsi = 1; + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CIMI"); + tech_pvt->requesting_imsi = 0; + if (res) { + DEBUGA_GSMOPEN("AT+CIMI failed\n", GSMOPEN_P_LOG); + } + + /* signal incoming SMS with a +CMTI unsolicited msg */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CNMI=3,1,0,0,0"); + if (res) { + DEBUGA_GSMOPEN("AT+CNMI=3,1,0,0,0 failed, continue\n", GSMOPEN_P_LOG); + tech_pvt->sms_cnmi_not_supported = 1; + tech_pvt->gsmopen_serial_sync_period = 30; //FIXME in config + } + /* what is the Message Center address (number) to which the SMS has to be sent? */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSCA?"); + if (res) { + DEBUGA_GSMOPEN("AT+CSCA? failed, continue\n", GSMOPEN_P_LOG); + } + /* what is the Message Format of SMSs? */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CMGF?"); + if (res) { + DEBUGA_GSMOPEN("AT+CMGF? failed, continue\n", GSMOPEN_P_LOG); + } +#ifdef NO_GSMLIB + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CMGF=1"); + if (res) { + ERRORA("Error setting SMS sending mode to TEXT on the cellphone, let's hope is TEXT by default. Continuing\n", GSMOPEN_P_LOG); + } + tech_pvt->sms_pdu_not_supported = 1; +#else // NO_GSMLIB + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CMGF=0"); + if (res) { + WARNINGA("Error setting SMS sending mode to PDU on the cellphone, falling back to TEXT mode. Continuing\n", GSMOPEN_P_LOG); + tech_pvt->sms_pdu_not_supported = 1; + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CMGF=1"); + if (res) { + ERRORA("Error setting SMS sending mode to TEXT on the cellphone, let's hope is TEXT by default. Continuing\n", GSMOPEN_P_LOG); + } + } +#endif // NO_GSMLIB + /* what is the Charset of SMSs? */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSCS?"); + if (res) { + DEBUGA_GSMOPEN("AT+CSCS? failed, continue\n", GSMOPEN_P_LOG); + } + + tech_pvt->no_ucs2 = 0; + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSCS=\"UCS2\""); + if (res) { + WARNINGA("AT+CSCS=\"UCS2\" (set TE messages to ucs2) do not got OK from the phone, let's try with 'GSM'\n", GSMOPEN_P_LOG); + tech_pvt->no_ucs2 = 1; + } + + if (tech_pvt->no_ucs2) { + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSCS=\"GSM\""); + if (res) { + WARNINGA("AT+CSCS=\"GSM\" (set TE messages to GSM) do not got OK from the phone\n", GSMOPEN_P_LOG); + } + //res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSMP=17,167,0,16"); //"flash", class 0 sms 7 bit + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSMP=17,167,0,0"); //normal, 7 bit message + if (res) { + WARNINGA("AT+CSMP do not got OK from the phone, continuing\n", GSMOPEN_P_LOG); + } + } else { + //res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSMP=17,167,0,20"); //"flash", class 0 sms 16 bit unicode + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSMP=17,167,0,8"); //unicode, 16 bit message + if (res) { + WARNINGA("AT+CSMP do not got OK from the phone, continuing\n", GSMOPEN_P_LOG); + } + } + + /* is the unsolicited reporting of mobile equipment event supported? */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CMER=?"); + if (res) { + DEBUGA_GSMOPEN("AT+CMER=? failed, continue\n", GSMOPEN_P_LOG); + } + /* request unsolicited reporting of mobile equipment indicators' events, to be screened by categories reported by +CIND=? */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CMER=3,0,0,1"); + if (res) { + DEBUGA_GSMOPEN("AT+CMER=? failed, continue\n", GSMOPEN_P_LOG); + } + + /* is the solicited reporting of mobile equipment indications supported? */ + + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CIND=?"); + if (res) { + DEBUGA_GSMOPEN("AT+CIND=? failed, continue\n", GSMOPEN_P_LOG); + } + + /* is the unsolicited reporting of call monitoring supported? sony-ericsson specific */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT*ECAM=?"); + if (res) { + DEBUGA_GSMOPEN("AT*ECAM=? failed, continue\n", GSMOPEN_P_LOG); + } + /* enable the unsolicited reporting of call monitoring. sony-ericsson specific */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT*ECAM=1"); + if (res) { + DEBUGA_GSMOPEN("AT*ECAM=1 failed, continue\n", GSMOPEN_P_LOG); + tech_pvt->at_has_ecam = 0; + } else { + tech_pvt->at_has_ecam = 1; + } + + /* disable unsolicited signaling of call list */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CLCC=0"); + if (res) { + DEBUGA_GSMOPEN("AT+CLCC=0 failed, continue\n", GSMOPEN_P_LOG); + tech_pvt->at_has_clcc = 0; + } else { + tech_pvt->at_has_clcc = 1; + } + + /* give unsolicited caller id when incoming call */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CLIP=1"); + if (res) { + DEBUGA_GSMOPEN("AT+CLIP failed, continue\n", GSMOPEN_P_LOG); + } + /* for motorola */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+MCST=1"); /* motorola call control codes + (to know when call is disconnected (they + don't give you "no carrier") */ + if (res) { + DEBUGA_GSMOPEN("AT+MCST=1 does not get OK from the phone. If it is NOT Motorola," " no problem.\n", GSMOPEN_P_LOG); + } + /* for motorola end */ + +/* go until first empty postinit string, or last postinit string */ + while (1) { + + if (strlen(tech_pvt->at_postinit_1)) { + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_postinit_1, tech_pvt->at_postinit_1_expect); + if (res) { + DEBUGA_GSMOPEN("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, tech_pvt->at_postinit_1, tech_pvt->at_postinit_1_expect); + } + } else { + break; + } + + if (strlen(tech_pvt->at_postinit_2)) { + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_postinit_2, tech_pvt->at_postinit_2_expect); + if (res) { + DEBUGA_GSMOPEN("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, tech_pvt->at_postinit_2, tech_pvt->at_postinit_2_expect); + } + } else { + break; + } + + if (strlen(tech_pvt->at_postinit_3)) { + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_postinit_3, tech_pvt->at_postinit_3_expect); + if (res) { + DEBUGA_GSMOPEN("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, tech_pvt->at_postinit_3, tech_pvt->at_postinit_3_expect); + } + } else { + break; + } + + if (strlen(tech_pvt->at_postinit_4)) { + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_postinit_4, tech_pvt->at_postinit_4_expect); + if (res) { + DEBUGA_GSMOPEN("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, tech_pvt->at_postinit_4, tech_pvt->at_postinit_4_expect); + } + } else { + break; + } + + if (strlen(tech_pvt->at_postinit_5)) { + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_postinit_5, tech_pvt->at_postinit_5_expect); + if (res) { + DEBUGA_GSMOPEN("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, tech_pvt->at_postinit_5, tech_pvt->at_postinit_5_expect); + } + } else { + break; + } + + break; + } + + return 0; +} + + +int gsmopen_serial_sync_AT(private_t * tech_pvt) +{ + gsmopen_sleep(10000); /* 10msec */ + time(&tech_pvt->gsmopen_serial_synced_timestamp); + return 0; +} +int gsmopen_serial_read_AT(private_t * tech_pvt, int look_for_ack, int timeout_usec, int timeout_sec, const char *expected_string, int expect_crlf) +{ + int select_err = 1; + int res; + fd_set read_fds; + struct timeval timeout; + char tmp_answer[AT_BUFSIZ]; + char tmp_answer2[AT_BUFSIZ]; + char *tmp_answer_ptr; + char *last_line_ptr; + int i = 0; + int read_count = 0; + int la_counter = 0; + int at_ack = -1; + int la_read = 0; + + if(!running || !tech_pvt->running){ + return -1; + } + + FD_ZERO(&read_fds); + FD_SET(tech_pvt->controldevfd, &read_fds); + + //NOTICA (" INSIDE this gsmopen_serial_device %s \n", GSMOPEN_P_LOG, tech_pvt->controldevice_name); + tmp_answer_ptr = tmp_answer; + memset(tmp_answer, 0, sizeof(char) * AT_BUFSIZ); + + timeout.tv_sec = timeout_sec; + timeout.tv_usec = timeout_usec; + PUSHA_UNLOCKA(tech_pvt->controldev_lock); + LOKKA(tech_pvt->controldev_lock); + + while ((!tech_pvt->controldev_dead) && ((select_err = select(tech_pvt->controldevfd + 1, &read_fds, NULL, NULL, &timeout)) > 0)) { + char *token_ptr; + timeout.tv_sec = timeout_sec; //reset the timeout, linux modify it + timeout.tv_usec = timeout_usec; //reset the timeout, linux modify it + read_count = read(tech_pvt->controldevfd, tmp_answer_ptr, AT_BUFSIZ - (tmp_answer_ptr - tmp_answer)); + + if (read_count == 0) { + ERRORA + ("read 0 bytes!!! Nenormalno! Marking this gsmopen_serial_device %s as dead, andif it is owned by a channel, hanging up. Maybe the phone is stuck, switched off, power down or battery exhausted\n", + GSMOPEN_P_LOG, tech_pvt->controldevice_name); + tech_pvt->controldev_dead = 1; + close(tech_pvt->controldevfd); + ERRORA("gsmopen_serial_monitor failed, declaring %s dead\n", GSMOPEN_P_LOG, tech_pvt->controldevice_name); + tech_pvt->running=0; + alarm_event(tech_pvt, ALARM_FAILED_INTERFACE, "gsmopen_serial_monitor failed, declaring interface dead"); + tech_pvt->active=0; + tech_pvt->name[0]='\0'; + + UNLOCKA(tech_pvt->controldev_lock); + if (tech_pvt->owner) { + tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_FAILURE; + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + } + switch_sleep(1000000); + return -1; + } + + if (option_debug > 90) { + //DEBUGA_GSMOPEN("1 read %d bytes, --|%s|--\n", GSMOPEN_P_LOG, read_count, tmp_answer_ptr); + //DEBUGA_GSMOPEN("2 read %d bytes, --|%s|--\n", GSMOPEN_P_LOG, read_count, tmp_answer); + } + tmp_answer_ptr = tmp_answer_ptr + read_count; + + + la_counter = 0; + memset(tmp_answer2, 0, sizeof(char) * AT_BUFSIZ); + strcpy(tmp_answer2, tmp_answer); + if ((token_ptr = strtok(tmp_answer2, "\n\r"))) { + last_line_ptr = token_ptr; + strncpy(tech_pvt->line_array.result[la_counter], token_ptr, AT_MESG_MAX_LENGTH); + if (strlen(token_ptr) > AT_MESG_MAX_LENGTH) { + WARNINGA + ("AT mesg longer than buffer, original message was: |%s|, in buffer only: |%s|\n", + GSMOPEN_P_LOG, token_ptr, tech_pvt->line_array.result[la_counter]); + } + la_counter++; + while ((token_ptr = strtok(NULL, "\n\r"))) { + last_line_ptr = token_ptr; + strncpy(tech_pvt->line_array.result[la_counter], token_ptr, AT_MESG_MAX_LENGTH); + if (strlen(token_ptr) > AT_MESG_MAX_LENGTH) { + WARNINGA + ("AT mesg longer than buffer, original message was: |%s|, in buffer only: |%s|\n", + GSMOPEN_P_LOG, token_ptr, tech_pvt->line_array.result[la_counter]); + } + la_counter++; + } + } else { + last_line_ptr = tmp_answer; + } + + if (expected_string && !expect_crlf) { + DEBUGA_GSMOPEN + ("last_line_ptr=|%s|, expected_string=|%s|, expect_crlf=%d, memcmp(last_line_ptr, expected_string, strlen(expected_string)) = %d\n", + GSMOPEN_P_LOG, last_line_ptr, expected_string, expect_crlf, memcmp(last_line_ptr, expected_string, strlen(expected_string))); + } + + if (expected_string && !expect_crlf && !memcmp(last_line_ptr, expected_string, strlen(expected_string)) + ) { + strncpy(tech_pvt->line_array.result[la_counter], last_line_ptr, AT_MESG_MAX_LENGTH); + // match expected string -> accept it withtout CRLF + la_counter++; + + } + /* if the last line read was not a complete line, we'll read the rest in the future */ + else if (tmp_answer[strlen(tmp_answer) - 1] != '\r' && tmp_answer[strlen(tmp_answer) - 1] != '\n') + la_counter--; + + /* let's list the complete lines read so far, without re-listing the lines that has yet been listed */ + if (option_debug > 1) { + for (i = la_read; i < la_counter; i++) + DEBUGA_GSMOPEN("Read line %d: |%s|\n", GSMOPEN_P_LOG, i, tech_pvt->line_array.result[i]); + } + + /* let's interpret the complete lines read so far (WITHOUT looking for OK, ERROR, and EXPECTED_STRING), without re-interpreting the lines that has been yet interpreted, so we're sure we don't miss anything */ + for (i = la_read; i < la_counter; i++) { + + if ((strcmp(tech_pvt->line_array.result[i], "RING") == 0)) { + /* with first RING we wait for callid */ + gettimeofday(&(tech_pvt->ringtime), NULL); + /* give CALLID (+CLIP) a chance, wait for the next RING before answering */ + if (tech_pvt->phone_callflow == CALLFLOW_INCOMING_RING) { + /* we're at the second ring, set the interface state, will be answered by gsmopen_do_monitor */ + DEBUGA_GSMOPEN("|%s| got second RING\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + tech_pvt->interface_state = GSMOPEN_STATE_RING; + } else { + /* we're at the first ring, so there is no CALLID yet thus clean the previous one + just in case we don't receive the caller identification in this new call */ + memset(tech_pvt->callid_name, 0, sizeof(tech_pvt->callid_name)); + memset(tech_pvt->callid_number, 0, sizeof(tech_pvt->callid_number)); + /* only send AT+CLCC? if the device previously reported its support */ + if (tech_pvt->at_has_clcc != 0) { + /* we're at the first ring, try to get CALLID (with +CLCC) */ + DEBUGA_GSMOPEN("|%s| got first RING, sending AT+CLCC?\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + res = gsmopen_serial_write_AT_noack(tech_pvt, "AT+CLCC?"); + if (res) { + ERRORA("AT+CLCC? (call list) was not correctly sent to the phone\n", GSMOPEN_P_LOG); + } + } else { + DEBUGA_GSMOPEN("|%s| got first RING, but not sending AT+CLCC? as this device " + "seems not to support\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + } + tech_pvt->phone_callflow = CALLFLOW_INCOMING_RING; + } + + if ((strncmp(tech_pvt->line_array.result[i], "+CLCC", 5) == 0)) { + int commacount = 0; + int a = 0; + int b = 0; + int c = 0; + /* with clcc we wait for clip */ + memset(tech_pvt->callid_name, 0, sizeof(tech_pvt->callid_name)); + memset(tech_pvt->callid_number, 0, sizeof(tech_pvt->callid_number)); + + for (a = 0; a < strlen(tech_pvt->line_array.result[i]); a++) { + + if (tech_pvt->line_array.result[i][a] == ',') { + commacount++; + } + if (commacount == 5) { + if (tech_pvt->line_array.result[i][a] != ',' && tech_pvt->line_array.result[i][a] != '"') { + tech_pvt->callid_number[b] = tech_pvt->line_array.result[i][a]; + b++; + } + } + if (commacount == 7) { + if (tech_pvt->line_array.result[i][a] != ',' && tech_pvt->line_array.result[i][a] != '"') { + tech_pvt->callid_name[c] = tech_pvt->line_array.result[i][a]; + c++; + } + } + } + + tech_pvt->phone_callflow = CALLFLOW_INCOMING_RING; + DEBUGA_GSMOPEN("|%s| CLCC CALLID: name is %s, number is %s\n", GSMOPEN_P_LOG, + tech_pvt->line_array.result[i], + tech_pvt->callid_name[0] ? tech_pvt->callid_name : "not available", + tech_pvt->callid_number[0] ? tech_pvt->callid_number : "not available"); + } + + if ((strncmp(tech_pvt->line_array.result[i], "+CLIP", 5) == 0)) { + int commacount = 0; + int a = 0; + int b = 0; + int c = 0; + /* with CLIP, we want to answer right away */ + memset(tech_pvt->callid_name, 0, sizeof(tech_pvt->callid_name)); + memset(tech_pvt->callid_number, 0, sizeof(tech_pvt->callid_number)); + + + for (a = 7; a < strlen(tech_pvt->line_array.result[i]); a++) { + if (tech_pvt->line_array.result[i][a] == ',') { + commacount++; + } + if (commacount == 0) { + if (tech_pvt->line_array.result[i][a] != ',' && tech_pvt->line_array.result[i][a] != '"') { + tech_pvt->callid_number[b] = tech_pvt->line_array.result[i][a]; + b++; + } + } + if (commacount == 4) { + if (tech_pvt->line_array.result[i][a] != ',' && tech_pvt->line_array.result[i][a] != '"') { + tech_pvt->callid_name[c] = tech_pvt->line_array.result[i][a]; + c++; + } + } + } + + if (tech_pvt->interface_state != GSMOPEN_STATE_RING) { + gettimeofday(&(tech_pvt->call_incoming_time), NULL); + DEBUGA_GSMOPEN("GSMOPEN_STATE_RING call_incoming_time.tv_sec=%ld\n", GSMOPEN_P_LOG, tech_pvt->call_incoming_time.tv_sec); + + } + + tech_pvt->interface_state = GSMOPEN_STATE_RING; + tech_pvt->phone_callflow = CALLFLOW_INCOMING_RING; + DEBUGA_GSMOPEN("|%s| CLIP INCOMING CALLID: name is %s, number is %s\n", GSMOPEN_P_LOG, + tech_pvt->line_array.result[i], + (strlen(tech_pvt->callid_name) && tech_pvt->callid_name[0] != 1) ? tech_pvt->callid_name : "not available", + strlen(tech_pvt->callid_number) ? tech_pvt->callid_number : "not available"); + + if (!strlen(tech_pvt->callid_number)) { + strcpy(tech_pvt->callid_number, "not available"); + } + + if (!strlen(tech_pvt->callid_name) && tech_pvt->callid_name[0] != 1) { + strncpy(tech_pvt->callid_name, tech_pvt->callid_number, sizeof(tech_pvt->callid_name)); + //strncpy(tech_pvt->callid_name, tech_pvt->callid_number, sizeof(tech_pvt->callid_name)) ; + snprintf(tech_pvt->callid_name, sizeof(tech_pvt->callid_name), "GSMopen: %s", tech_pvt->callid_number); + } + + DEBUGA_GSMOPEN("|%s| CLIP INCOMING CALLID: NOW name is %s, number is %s\n", GSMOPEN_P_LOG, + tech_pvt->line_array.result[i], tech_pvt->callid_name, tech_pvt->callid_number); + } + + if ((strcmp(tech_pvt->line_array.result[i], "BUSY") == 0)) { + tech_pvt->phone_callflow = CALLFLOW_CALL_LINEBUSY; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_LINEBUSY\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + //if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN && tech_pvt->owner && tech_pvt->phone_callflow != CALLFLOW_CALL_DOWN) { + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN && tech_pvt->phone_callflow != CALLFLOW_CALL_DOWN) { + //ast_setstate(tech_pvt->owner, GSMOPEN_STATE_BUSY); + //gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_BUSY); + //cicopet + switch_core_session_t *session = NULL; + switch_channel_t *channel = NULL; + + tech_pvt->interface_state = GSMOPEN_STATE_DOWN; + + session = switch_core_session_locate(tech_pvt->session_uuid_str); + if (session) { + channel = switch_core_session_get_channel(session); + //gsmopen_hangup(tech_pvt); + switch_core_session_rwunlock(session); + switch_channel_hangup(channel, SWITCH_CAUSE_NONE); + } + // + //tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_FAILURE; + //gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + + } else { + ERRORA("Why BUSY now?\n", GSMOPEN_P_LOG); + } + } + if ((strcmp(tech_pvt->line_array.result[i], "NO ANSWER") == 0)) { + tech_pvt->phone_callflow = CALLFLOW_CALL_NOANSWER; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_NOANSWER\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN && tech_pvt->owner) { + tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_NO_ANSWER; + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + } else { + ERRORA("Why NO ANSWER now?\n", GSMOPEN_P_LOG); + } + } + if ((strcmp(tech_pvt->line_array.result[i], "NO CARRIER") == 0)) { + tech_pvt->phone_callflow = CALLFLOW_CALL_NOCARRIER; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_NOCARRIER\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN) { + //cicopet + switch_core_session_t *session = NULL; + switch_channel_t *channel = NULL; + + tech_pvt->interface_state = GSMOPEN_STATE_DOWN; + + session = switch_core_session_locate(tech_pvt->session_uuid_str); + if (session) { + channel = switch_core_session_get_channel(session); + //gsmopen_hangup(tech_pvt); + switch_core_session_rwunlock(session); + switch_channel_hangup(channel, SWITCH_CAUSE_NONE); + } + // + //tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_FAILURE; + //gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + } else { + ERRORA("Why NO CARRIER now?\n", GSMOPEN_P_LOG); + } + } + + if ((strncmp(tech_pvt->line_array.result[i], "+CBC:", 5) == 0)) { + int power_supply, battery_strenght, err; + + power_supply = battery_strenght = 0; + + err = sscanf(&tech_pvt->line_array.result[i][6], "%d,%d", &power_supply, &battery_strenght); + if (err < 2) { + DEBUGA_GSMOPEN("|%s| is not formatted as: |+CBC: xx,yy| now trying |+CBC:xx,yy|\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + + err = sscanf(&tech_pvt->line_array.result[i][5], "%d,%d", &power_supply, &battery_strenght); + DEBUGA_GSMOPEN("|%s| +CBC: Powered by %s, battery strenght=%d\n", GSMOPEN_P_LOG, + tech_pvt->line_array.result[i], power_supply ? "power supply" : "battery", battery_strenght); + + } + + if (err < 2) { + DEBUGA_GSMOPEN("|%s| is not formatted as: |+CBC:xx,yy| giving up\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + else { + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| +CBC: Powered by %s, battery strenght=%d\n", GSMOPEN_P_LOG, + tech_pvt->line_array.result[i], power_supply ? "power supply" : "battery", battery_strenght); + if (!power_supply) { + if (battery_strenght < 10) { + ERRORA("|%s| BATTERY ALMOST EXHAUSTED\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } else if (battery_strenght < 20) { + WARNINGA("|%s| BATTERY LOW\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + + } + + } + } + + } + + if ((strncmp(tech_pvt->line_array.result[i], "+CSQ:", 5) == 0)) { + int signal_quality, ber, err; + + signal_quality = ber = 0; + + err = sscanf(&tech_pvt->line_array.result[i][6], "%d,%d", &signal_quality, &ber); + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| +CSQ: Signal Quality: %d, Error Rate=%d\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i], signal_quality, ber); + if (err < 2) { + ERRORA("|%s| is not formatted as: |+CSQ: xx,yy|\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } else { + if (signal_quality < 11 || signal_quality == 99) { + ERRORA + ("|%s| CELLPHONE GETS ALMOST NO SIGNAL, consider to move it or additional antenna\n", + GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + tech_pvt->got_signal=0; + alarm_event(tech_pvt, ALARM_NETWORK_NO_SIGNAL, "CELLPHONE GETS ALMOST NO SIGNAL, consider to move it or additional antenna"); + } else if (signal_quality < 15) { + WARNINGA("|%s| CELLPHONE GETS SIGNAL LOW\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + tech_pvt->got_signal=1; + alarm_event(tech_pvt, ALARM_NETWORK_LOW_SIGNAL, "CELLPHONE GETS SIGNAL LOW"); + } else { + tech_pvt->got_signal=2; + } + + } + + } + if ((strncmp(tech_pvt->line_array.result[i], "+CREG:", 6) == 0)) { + int n, stat, err; + + n = stat = 0; + + err = sscanf(&tech_pvt->line_array.result[i][6], "%d,%d", &n, &stat); + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| +CREG: Display: %d, Registration=%d\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i], n, stat); + if (err < 2) { + ERRORA("|%s| is not formatted as: |+CREG: xx,yy|\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } else { + if (stat==0) { + ERRORA + ("|%s| CELLPHONE is not registered to network, consider to move it or additional antenna\n", + GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + tech_pvt->not_registered=1; + tech_pvt->home_network_registered=0; + tech_pvt->roaming_registered=0; + alarm_event(tech_pvt, ALARM_NO_NETWORK_REGISTRATION, "CELLPHONE is not registered to network, consider to move it or additional antenna"); + } else if (stat==1) { + DEBUGA_GSMOPEN("|%s| CELLPHONE is registered to the HOME network\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + tech_pvt->not_registered=0; + tech_pvt->home_network_registered=1; + tech_pvt->roaming_registered=0; + } else { + ERRORA("|%s| CELLPHONE is registered to a ROAMING network\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + tech_pvt->not_registered=0; + tech_pvt->home_network_registered=0; + tech_pvt->roaming_registered=1; + alarm_event(tech_pvt, ALARM_ROAMING_NETWORK_REGISTRATION, "CELLPHONE is registered to a ROAMING network"); + } + + } + + } + + if ((strncmp(tech_pvt->line_array.result[i], "+CMGW:", 6) == 0)) { + int err; + + err = sscanf(&tech_pvt->line_array.result[i][7], "%s", tech_pvt->at_cmgw); + DEBUGA_GSMOPEN("|%s| +CMGW: %s\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i], tech_pvt->at_cmgw); + if (err < 1) { + ERRORA("|%s| is not formatted as: |+CMGW: xxxx|\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + } + + /* at_call_* are unsolicited messages sent by the modem to signal us about call processing activity and events */ + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_call_idle) == 0)) { + tech_pvt->phone_callflow = CALLFLOW_CALL_IDLE; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_IDLE\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN && tech_pvt->owner) { + DEBUGA_GSMOPEN("just received a remote HANGUP\n", GSMOPEN_P_LOG); + tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_NORMAL; + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + DEBUGA_GSMOPEN("just sent GSMOPEN_CONTROL_HANGUP\n", GSMOPEN_P_LOG); + } + + tech_pvt->phone_callflow = CALLFLOW_CALL_NOCARRIER; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_NOCARRIER\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN) { + //cicopet + switch_core_session_t *session = NULL; + switch_channel_t *channel = NULL; + + tech_pvt->interface_state = GSMOPEN_STATE_DOWN; + + session = switch_core_session_locate(tech_pvt->session_uuid_str); + if (session) { + channel = switch_core_session_get_channel(session); + //gsmopen_hangup(tech_pvt); + switch_core_session_rwunlock(session); + switch_channel_hangup(channel, SWITCH_CAUSE_NONE); + } + // + //tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_FAILURE; + //gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + } else { + ERRORA("Why NO CARRIER now?\n", GSMOPEN_P_LOG); + } + + + + + + + + + + + + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_call_incoming) == 0)) { + + //char list_command[64]; + + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_INCOMING\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + + if (tech_pvt->phone_callflow != CALLFLOW_CALL_INCOMING && tech_pvt->phone_callflow != CALLFLOW_INCOMING_RING) { + //mark the time of CALLFLOW_CALL_INCOMING + gettimeofday(&(tech_pvt->call_incoming_time), NULL); + tech_pvt->phone_callflow = CALLFLOW_CALL_INCOMING; + DEBUGA_GSMOPEN("CALLFLOW_CALL_INCOMING call_incoming_time.tv_sec=%ld\n", GSMOPEN_P_LOG, tech_pvt->call_incoming_time.tv_sec); + + } + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_call_active) == 0)) { + tech_pvt->phone_callflow = CALLFLOW_CALL_ACTIVE; + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_ACTIVE\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + + if (tech_pvt->interface_state == CALLFLOW_CALL_DIALING || tech_pvt->interface_state == CALLFLOW_STATUS_EARLYMEDIA) { + DEBUGA_PBX("just received a remote ANSWER\n", GSMOPEN_P_LOG); + if (tech_pvt->phone_callflow == GSMOPEN_STATE_UP) { + //gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_RINGING); + DEBUGA_PBX("just sent GSMOPEN_CONTROL_RINGING\n", GSMOPEN_P_LOG); + DEBUGA_PBX("going to send GSMOPEN_CONTROL_ANSWER\n", GSMOPEN_P_LOG); + //gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_ANSWER); + tech_pvt->interface_state = CALLFLOW_CALL_REMOTEANSWER; + DEBUGA_PBX("just sent GSMOPEN_CONTROL_ANSWER\n", GSMOPEN_P_LOG); + } + } else { + } + //tech_pvt->interface_state = GSMOPEN_STATE_UP; + //DEBUGA_PBX("just interface_state UP\n", GSMOPEN_P_LOG); + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_call_calling) == 0)) { + tech_pvt->phone_callflow = CALLFLOW_CALL_DIALING; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_DIALING\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_call_failed) == 0)) { + tech_pvt->phone_callflow = CALLFLOW_CALL_FAILED; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_FAILED\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN && tech_pvt->owner) { + tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_FAILURE; + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + } + } + + if ((strncmp(tech_pvt->line_array.result[i], "+CSCA:", 6) == 0)) { //TODO SMS FIXME in config! + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| +CSCA: Message Center Address!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + if ((strncmp(tech_pvt->line_array.result[i], "+CMGF:", 6) == 0)) { //TODO SMS FIXME in config! + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| +CMGF: Message Format!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + if ((strncmp(tech_pvt->line_array.result[i], "+CMTI:", 6) == 0)) { //TODO SMS FIXME in config! + int err; + int pos; + + //FIXME all the following commands in config! + if (option_debug) + DEBUGA_GSMOPEN("|%s| +CMTI: Incoming SMS!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + + err = sscanf(&tech_pvt->line_array.result[i][12], "%d", &pos); + if (err < 1) { + ERRORA("|%s| is not formatted as: |+CMTI: \"MT\",xx|\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } else { + DEBUGA_GSMOPEN("|%s| +CMTI: Incoming SMS in position: %d!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i], pos); + tech_pvt->unread_sms_msg_id = pos; + gsmopen_sleep(1000); + + if (tech_pvt->unread_sms_msg_id) { + char at_command[256]; + + if (tech_pvt->no_ucs2 == 0) { + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSCS=\"UCS2\""); + if (res) { + ERRORA("AT+CSCS=\"UCS2\" (set TE messages to ucs2) do not got OK from the phone, continuing\n", GSMOPEN_P_LOG); + //memset(tech_pvt->sms_message, 0, sizeof(tech_pvt->sms_message)); + } + } + + memset(at_command, 0, sizeof(at_command)); + sprintf(at_command, "AT+CMGR=%d", tech_pvt->unread_sms_msg_id); + //memset(tech_pvt->sms_message, 0, sizeof(tech_pvt->sms_message)); + + tech_pvt->reading_sms_msg = 1; + res = gsmopen_serial_write_AT_ack(tech_pvt, at_command); + tech_pvt->reading_sms_msg = 0; + if (res) { + ERRORA("AT+CMGR (read SMS) do not got OK from the phone, message sent was:|||%s|||\n", GSMOPEN_P_LOG, at_command); + } + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSCS=\"GSM\""); + if (res) { + ERRORA("AT+CSCS=\"GSM\" (set TE messages to GSM) do not got OK from the phone\n", GSMOPEN_P_LOG); + } + memset(at_command, 0, sizeof(at_command)); + sprintf(at_command, "AT+CMGD=%d", tech_pvt->unread_sms_msg_id); /* delete the message */ + tech_pvt->unread_sms_msg_id = 0; + res = gsmopen_serial_write_AT_ack(tech_pvt, at_command); + if (res) { + ERRORA("AT+CMGD (Delete SMS) do not got OK from the phone, message sent was:|||%s|||\n", GSMOPEN_P_LOG, at_command); + } + + res = sms_incoming(tech_pvt); + +#if 0 + if (strlen(tech_pvt->sms_message)) { + //FIXME manager_event(EVENT_FLAG_SYSTEM, "GSMOPENincomingsms", + //FIXME "Interface: %s\r\nSMS_Message: %s\r\n", tech_pvt->name, + //FIXME tech_pvt->sms_message); + + res = sms_incoming(tech_pvt, tech_pvt->sms_message); + + if (strlen(tech_pvt->sms_receiving_program)) { + int fd1[2]; + pid_t pid1; + char *arg1[] = { tech_pvt->sms_receiving_program, (char *) NULL }; + int i; + + DEBUGA_GSMOPEN("incoming SMS message:>>>%s<<<\n", GSMOPEN_P_LOG, tech_pvt->sms_message); + res = pipe(fd1); + pid1 = fork(); + + if (pid1 == 0) { //child + int err; + + dup2(fd1[0], 0); // Connect stdin to pipe output + close(fd1[1]); // close input pipe side + close(tech_pvt->controldevfd); + setsid(); //session id + err = execvp(arg1[0], arg1); //exec our program, with stdin connected to pipe output + if (err) { + ERRORA + ("'sms_receiving_program' is set in config file to '%s', and it gave us back this error: %d, (%s). SMS received was:---%s---\n", + GSMOPEN_P_LOG, tech_pvt->sms_receiving_program, err, strerror(errno), tech_pvt->sms_message); + } + close(fd1[0]); // close output pipe side + } +//starting here continue the parent + close(fd1[0]); // close output pipe side + // write the msg on the pipe input + for (i = 0; i < strlen(tech_pvt->sms_message); i++) { + res = write(fd1[1], &tech_pvt->sms_message[i], 1); + } + close(fd1[1]); // close pipe input, let our program know we've finished + } else { + ERRORA + ("got SMS incoming message, but 'sms_receiving_program' is not set in config file. SMS received was:---%s---\n", + GSMOPEN_P_LOG, tech_pvt->sms_message); + } + } +#endif //0 +#if 1 //is this one needed? maybe it can interrupt an incoming call that is just to announce itself + if (tech_pvt->phone_callflow == CALLFLOW_CALL_IDLE && tech_pvt->interface_state == GSMOPEN_STATE_DOWN && tech_pvt->owner == NULL) { + /* we're not in a call, neither calling */ + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CKPD=\"EEE\""); + if (res) { + ERRORA("AT+CKPD=\"EEE\" (cellphone screen back to user) do not got OK from the phone\n", GSMOPEN_P_LOG); + } + } +#endif + } //unread_msg_id + + } //CMTI well formatted + + } //CMTI + + if ((strncmp(tech_pvt->line_array.result[i], "+MMGL:", 6) == 0)) { //TODO MOTOROLA SMS FIXME in config! + int err = 0; + //int unread_msg_id=0; + + if (option_debug) + DEBUGA_GSMOPEN("|%s| +MMGL: Listing Motorola SMSs!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + + err = sscanf(&tech_pvt->line_array.result[i][7], "%d", &tech_pvt->unread_sms_msg_id); + if (err < 1) { + ERRORA("|%s| is not formatted as: |+MMGL: xx|\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + } + if ((strncmp(tech_pvt->line_array.result[i], "+CMGL:", 6) == 0)) { //TODO SMS FIXME in config! + if (option_debug) + DEBUGA_GSMOPEN("|%s| +CMGL: Listing SMSs!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + if ((strncmp(tech_pvt->line_array.result[i], "+MMGR:", 6) == 0)) { //TODO MOTOROLA SMS FIXME in config! + if (option_debug) + DEBUGA_GSMOPEN("|%s| +MMGR: Reading Motorola SMS!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->reading_sms_msg) + tech_pvt->reading_sms_msg++; + } + if ((strncmp(tech_pvt->line_array.result[i], "+CMGR: \"STO U", 13) == 0)) { //TODO SMS FIXME in config! + if (option_debug) + DEBUGA_GSMOPEN("|%s| +CMGR: Reading stored UNSENT SMS!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } else if ((strncmp(tech_pvt->line_array.result[i], "+CMGR: \"STO S", 13) == 0)) { //TODO SMS FIXME in config! + if (option_debug) + DEBUGA_GSMOPEN("|%s| +CMGR: Reading stored SENT SMS!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } else if ((strncmp(tech_pvt->line_array.result[i], "+CMGR: \"REC R", 13) == 0)) { //TODO SMS FIXME in config! + if (option_debug) + DEBUGA_GSMOPEN("|%s| +CMGR: Reading received READ SMS!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } else if ((strncmp(tech_pvt->line_array.result[i], "+CMGR: \"REC U", 13) == 0)) { //TODO SMS FIXME in config! + if (option_debug) + DEBUGA_GSMOPEN("|%s| +CMGR: Reading received UNREAD SMS!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->reading_sms_msg) + tech_pvt->reading_sms_msg++; + } else if ((strncmp(tech_pvt->line_array.result[i], "+CMGR: ", 6) == 0)) { //TODO SMS FIXME in config! + if (option_debug) + DEBUGA_GSMOPEN("|%s| +CMGR: Reading SMS!\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->reading_sms_msg) + tech_pvt->reading_sms_msg++; + } + + + if ((strcmp(tech_pvt->line_array.result[i], "+MCST: 17") == 0)) { /* motorola call processing unsolicited messages */ + tech_pvt->phone_callflow = CALLFLOW_CALL_INFLUX; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_INFLUX\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + if ((strcmp(tech_pvt->line_array.result[i], "+MCST: 68") == 0)) { /* motorola call processing unsolicited messages */ + tech_pvt->phone_callflow = CALLFLOW_CALL_NOSERVICE; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_NOSERVICE\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN && tech_pvt->owner) { + tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_FAILURE; + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + } + } + if ((strcmp(tech_pvt->line_array.result[i], "+MCST: 70") == 0)) { /* motorola call processing unsolicited messages */ + tech_pvt->phone_callflow = CALLFLOW_CALL_OUTGOINGRESTRICTED; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_OUTGOINGRESTRICTED\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN && tech_pvt->owner) { + tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_FAILURE; + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + } + } + if ((strcmp(tech_pvt->line_array.result[i], "+MCST: 72") == 0)) { /* motorola call processing unsolicited messages */ + tech_pvt->phone_callflow = CALLFLOW_CALL_SECURITYFAIL; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| CALLFLOW_CALL_SECURITYFAIL\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN && tech_pvt->owner) { + tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_FAILURE; + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + } + } + + if ((strncmp(tech_pvt->line_array.result[i], "+CPBR", 5) == 0)) { /* phonebook stuff begins */ + + if (tech_pvt->phonebook_querying) { /* probably phonebook struct begins */ + int err, first_entry, last_entry, number_lenght, text_lenght; + + if (option_debug) + DEBUGA_GSMOPEN("phonebook struct: |%s|\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + + err = sscanf(&tech_pvt->line_array.result[i][8], "%d-%d),%d,%d", &first_entry, &last_entry, &number_lenght, &text_lenght); + if (err < 4) { + + err = sscanf(&tech_pvt->line_array.result[i][7], "%d-%d,%d,%d", &first_entry, &last_entry, &number_lenght, &text_lenght); + } + + if (err < 4) { + ERRORA + ("phonebook struct: |%s| is nor formatted as: |+CPBR: (1-750),40,14| neither as: |+CPBR: 1-750,40,14|\n", + GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } else { + + if (option_debug) + DEBUGA_GSMOPEN + ("First entry: %d, last entry: %d, phone number max lenght: %d, text max lenght: %d\n", + GSMOPEN_P_LOG, first_entry, last_entry, number_lenght, text_lenght); + tech_pvt->phonebook_first_entry = first_entry; + tech_pvt->phonebook_last_entry = last_entry; + tech_pvt->phonebook_number_lenght = number_lenght; + tech_pvt->phonebook_text_lenght = text_lenght; + } + + } else { /* probably phonebook entry begins */ + + if (tech_pvt->phonebook_listing) { + int err, entry_id, entry_type; + + char entry_number[256]; + char entry_text[256]; + + if (option_debug) + DEBUGA_GSMOPEN("phonebook entry: |%s|\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + + err = + sscanf(&tech_pvt->line_array.result[i][7], "%d,\"%255[0-9+]\",%d,\"%255[^\"]\"", &entry_id, entry_number, &entry_type, + entry_text); + if (err < 4) { + ERRORA + ("err=%d, phonebook entry: |%s| is not formatted as: |+CPBR: 504,\"+39025458068\",145,\"ciao a tutti\"|\n", + GSMOPEN_P_LOG, err, tech_pvt->line_array.result[i]); + } else { + //TODO: sanitize entry_text + if (option_debug) + DEBUGA_GSMOPEN("Number: %s, Text: %s, Type: %d\n", GSMOPEN_P_LOG, entry_number, entry_text, entry_type); + /* write entry in phonebook file */ + if (tech_pvt->phonebook_writing_fp) { + gsmopen_dir_entry_extension++; + + fprintf(tech_pvt->phonebook_writing_fp, + "%s => ,%sSKO,,,hidefromdir=%s|phonebook_direct_calling_ext=%d%s%.4d|phonebook_entry_fromcell=%s|phonebook_entry_owner=%s\n", + entry_number, entry_text, "no", + tech_pvt->gsmopen_dir_entry_extension_prefix, "2", gsmopen_dir_entry_extension, "yes", "not_specified"); + fprintf(tech_pvt->phonebook_writing_fp, + "%s => ,%sDO,,,hidefromdir=%s|phonebook_direct_calling_ext=%d%s%.4d|phonebook_entry_fromcell=%s|phonebook_entry_owner=%s\n", + entry_number, entry_text, "no", + tech_pvt->gsmopen_dir_entry_extension_prefix, "3", gsmopen_dir_entry_extension, "yes", "not_specified"); + } + } + + } + + if (tech_pvt->phonebook_listing_received_calls) { + int err, entry_id, entry_type; + + char entry_number[256] = ""; + char entry_text[256] = ""; + + if (option_debug) + DEBUGA_GSMOPEN("phonebook entry: |%s|\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + + err = + sscanf(&tech_pvt->line_array.result[i][7], "%d,\"%255[0-9+]\",%d,\"%255[^\"]\"", &entry_id, entry_number, &entry_type, + entry_text); + if (err < 1) { //we match only on the progressive id, maybe the remote party has not sent its number, and/or there is no corresponding text entry in the phone directory + ERRORA + ("err=%d, phonebook entry: |%s| is not formatted as: |+CPBR: 504,\"+39025458068\",145,\"ciao a tutti\"|\n", + GSMOPEN_P_LOG, err, tech_pvt->line_array.result[i]); + } else { + //TODO: sanitize entry_text + + if (option_debug) + DEBUGA_GSMOPEN("Number: %s, Text: %s, Type: %d\n", GSMOPEN_P_LOG, entry_number, entry_text, entry_type); + memset(tech_pvt->callid_name, 0, sizeof(tech_pvt->callid_name)); + memset(tech_pvt->callid_number, 0, sizeof(tech_pvt->callid_number)); + strncpy(tech_pvt->callid_name, entry_text, sizeof(tech_pvt->callid_name)); + strncpy(tech_pvt->callid_number, entry_number, sizeof(tech_pvt->callid_number)); + if (option_debug) + DEBUGA_GSMOPEN("incoming callid: Text: %s, Number: %s\n", GSMOPEN_P_LOG, tech_pvt->callid_name, tech_pvt->callid_number); + + DEBUGA_GSMOPEN("|%s| CPBR INCOMING CALLID: name is %s, number is %s\n", + GSMOPEN_P_LOG, tech_pvt->line_array.result[i], + tech_pvt->callid_name[0] != 1 ? tech_pvt->callid_name : "not available", + tech_pvt->callid_number[0] ? tech_pvt->callid_number : "not available"); + + /* mark the time of RING */ + gettimeofday(&(tech_pvt->ringtime), NULL); + tech_pvt->interface_state = GSMOPEN_STATE_RING; + tech_pvt->phone_callflow = CALLFLOW_INCOMING_RING; + + } + + } + + else { + DEBUGA_GSMOPEN("phonebook entry: |%s|\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + + } + } + + } + + if ((strncmp(tech_pvt->line_array.result[i], "*ECAV", 5) == 0) || (strncmp(tech_pvt->line_array.result[i], "*ECAM", 5) == 0)) { /* sony-ericsson call processing unsolicited messages */ + int res, ccid, ccstatus, calltype, processid, exitcause, number, type; + res = ccid = ccstatus = calltype = processid = exitcause = number = type = 0; + res = + sscanf(&tech_pvt->line_array.result[i][6], "%d,%d,%d,%d,%d,%d,%d", &ccid, &ccstatus, &calltype, &processid, &exitcause, &number, + &type); + /* only changes the phone_callflow if enought parameters were parsed */ + if (res >= 3) { + switch (ccstatus) { + case 0: + if (tech_pvt->owner) { + ast_setstate(tech_pvt->owner, GSMOPEN_STATE_DOWN); + tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_NORMAL; + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + } + tech_pvt->phone_callflow = CALLFLOW_CALL_IDLE; + tech_pvt->interface_state = GSMOPEN_STATE_DOWN; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| Sony-Ericsson *ECAM/*ECAV: IDLE\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + break; + case 1: + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| Sony-Ericsson *ECAM/*ECAV: CALLING\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + break; + case 2: + if (tech_pvt->owner) { + ast_setstate(tech_pvt->owner, GSMOPEN_STATE_DIALING); + } + tech_pvt->interface_state = CALLFLOW_CALL_DIALING; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| Sony-Ericsson *ECAM/*ECAV: CONNECTING\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + break; + case 3: + if (tech_pvt->owner) { + ast_setstate(tech_pvt->owner, GSMOPEN_STATE_UP); + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_ANSWER); + } + tech_pvt->phone_callflow = CALLFLOW_CALL_ACTIVE; + tech_pvt->interface_state = GSMOPEN_STATE_UP; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| Sony-Ericsson *ECAM/*ECAV: ACTIVE\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + break; + case 4: + if (option_debug > 1) + DEBUGA_GSMOPEN + ("|%s| Sony-Ericsson *ECAM/*ECAV: don't know how to handle HOLD event\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + break; + case 5: + if (option_debug > 1) + DEBUGA_GSMOPEN + ("|%s| Sony-Ericsson *ECAM/*ECAV: don't know how to handle WAITING event\n", GSMOPEN_P_LOG, + tech_pvt->line_array.result[i]); + break; + case 6: + if (option_debug > 1) + DEBUGA_GSMOPEN + ("|%s| Sony-Ericsson *ECAM/*ECAV: don't know how to handle ALERTING event\n", GSMOPEN_P_LOG, + tech_pvt->line_array.result[i]); + break; + case 7: + if (tech_pvt->owner) { + ast_setstate(tech_pvt->owner, GSMOPEN_STATE_BUSY); + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_BUSY); + } + tech_pvt->phone_callflow = CALLFLOW_CALL_LINEBUSY; + tech_pvt->interface_state = GSMOPEN_STATE_BUSY; + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| Sony-Ericsson *ECAM/*ECAV: BUSY\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + break; + } + } else { + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| Sony-Ericsson *ECAM/*ECAV: could not parse parameters\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + } + + /* at_indicator_* are unsolicited messages sent by the phone to signal us that some of its visual indicators on its screen has changed, based on CIND CMER ETSI docs */ + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_indicator_noservice_string) == 0)) { + ERRORA("|%s| at_indicator_noservice_string\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + alarm_event(tech_pvt, ALARM_NETWORK_NO_SERVICE, "at_indicator_noservice_string"); + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_indicator_nosignal_string) == 0)) { + ERRORA("|%s| at_indicator_nosignal_string\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + alarm_event(tech_pvt, ALARM_NETWORK_NO_SIGNAL, "at_indicator_nosignal_string"); + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_indicator_lowsignal_string) == 0)) { + WARNINGA("|%s| at_indicator_lowsignal_string\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + alarm_event(tech_pvt, ALARM_NETWORK_LOW_SIGNAL, "at_indicator_lowsignal_string"); + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_indicator_lowbattchg_string) == 0)) { + WARNINGA("|%s| at_indicator_lowbattchg_string\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_indicator_nobattchg_string) == 0)) { + ERRORA("|%s| at_indicator_nobattchg_string\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_indicator_callactive_string) == 0)) { + DEBUGA_GSMOPEN("|%s| at_indicator_callactive_string\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_indicator_nocallactive_string) == 0)) { + DEBUGA_GSMOPEN("|%s| at_indicator_nocallactive_string\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_indicator_nocallsetup_string) == 0)) { + DEBUGA_GSMOPEN("|%s| at_indicator_nocallsetup_string\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_indicator_callsetupincoming_string) == 0)) { + DEBUGA_GSMOPEN("|%s| at_indicator_callsetupincoming_string\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_indicator_callsetupoutgoing_string) == 0)) { + DEBUGA_GSMOPEN("|%s| at_indicator_callsetupoutgoing_string\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + if ((strcmp(tech_pvt->line_array.result[i], tech_pvt->at_indicator_callsetupremoteringing_string) + == 0)) { + DEBUGA_GSMOPEN("|%s| at_indicator_callsetupremoteringing_string\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + } + + } + + /* let's look for OK, ERROR and EXPECTED_STRING in the complete lines read so far, without re-looking at the lines that has been yet looked at */ + for (i = la_read; i < la_counter; i++) { + if (expected_string) { + if ((strncmp(tech_pvt->line_array.result[i], expected_string, strlen(expected_string)) + == 0)) { + if (option_debug > 1) + DEBUGA_GSMOPEN("|%s| got what EXPECTED\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + at_ack = AT_OK; + } + } else { + if ((strcmp(tech_pvt->line_array.result[i], "OK") == 0)) { + if (option_debug > 1) + DEBUGA_GSMOPEN("got OK\n", GSMOPEN_P_LOG); + at_ack = AT_OK; + } + } + if ((strcmp(tech_pvt->line_array.result[i], "ERROR") == 0)) { + if (option_debug > 1) + DEBUGA_GSMOPEN("got ERROR\n", GSMOPEN_P_LOG); + at_ack = AT_ERROR; + } + + /* if we are requesting IMEI, put the line into the imei buffer if the line is not "OK" or "ERROR" */ + if (tech_pvt->requesting_imei && at_ack == -1) { + if (strlen(tech_pvt->line_array.result[i])) { /* we are reading the IMEI */ + strncpy(tech_pvt->imei, tech_pvt->line_array.result[i], sizeof(tech_pvt->imei)); + } + } + + /* if we are requesting IMSI, put the line into the imei buffer if the line is not "OK" or "ERROR" */ + if (tech_pvt->requesting_imsi && at_ack == -1) { + if (strlen(tech_pvt->line_array.result[i])) { /* we are reading the IMSI */ + strncpy(tech_pvt->imsi, tech_pvt->line_array.result[i], sizeof(tech_pvt->imsi)); + } + } + /* if we are reading an sms message from memory, put the line into the sms buffer if the line is not "OK" or "ERROR" */ + if (tech_pvt->reading_sms_msg > 1 && at_ack == -1) { + int c; + char sms_body[16000]; + int err = 0; + memset(sms_body, '\0', sizeof(sms_body)); + + if (strncmp(tech_pvt->line_array.result[i], "+CMGR", 5) == 0) { /* we are reading the "header" of an SMS */ +#if 1 + char content[512]; + char content2[512]; + int inside_comma = 0; + int inside_quote = 0; + int which_field = 0; + int d = 0; + + DEBUGA_GSMOPEN("HERE\n", GSMOPEN_P_LOG); + + memset(content, '\0', sizeof(content)); + + + for (c = 0; c < strlen(tech_pvt->line_array.result[i]); c++) { + if (tech_pvt->line_array.result[i][c] == ',' && tech_pvt->line_array.result[i][c - 1] != '\\' && inside_quote == 0) { + if (inside_comma) { + inside_comma = 0; + DEBUGA_GSMOPEN("inside_comma=%d, inside_quote=%d, we're at=%s\n", GSMOPEN_P_LOG, inside_comma, inside_quote, + &tech_pvt->line_array.result[i][c]); + } else { + inside_comma = 1; + DEBUGA_GSMOPEN("inside_comma=%d, inside_quote=%d, we're at=%s\n", GSMOPEN_P_LOG, inside_comma, inside_quote, + &tech_pvt->line_array.result[i][c]); + } + } + if (tech_pvt->line_array.result[i][c] == '"' && tech_pvt->line_array.result[i][c - 1] != '\\') { + if (inside_quote) { + inside_quote = 0; + DEBUGA_GSMOPEN("END_CONTENT inside_comma=%d, inside_quote=%d, we're at=%s\n", GSMOPEN_P_LOG, inside_comma, inside_quote, + &tech_pvt->line_array.result[i][c]); + DEBUGA_GSMOPEN("%d content=%s\n", GSMOPEN_P_LOG, which_field, content); + + //strncat(tech_pvt->sms_message, "---", ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + //strncat(tech_pvt->sms_message, content, ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + //strncat(tech_pvt->sms_message, "|||", ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + + memset(content2, '\0', sizeof(content2)); + if (which_field == 1) { + //FIXME why this? err = ucs2_to_utf8(tech_pvt, content, content2, sizeof(content2)); + //err = ucs2_to_utf8(tech_pvt, content, content2, sizeof(content2)); + err = 0; + strncpy(content2, content, sizeof(content2)); + } else { + err = 0; + strncpy(content2, content, sizeof(content2)); + } + DEBUGA_GSMOPEN("%d content2=%s\n", GSMOPEN_P_LOG, which_field, content2); + DEBUGA_GSMOPEN("%d content=%s\n", GSMOPEN_P_LOG, which_field, content2); + + //strncat(tech_pvt->sms_message, "---", ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + //if (!err) + //strncat(tech_pvt->sms_message, content2, ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + //strncat(tech_pvt->sms_message, "|||", ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + memset(content, '\0', sizeof(content)); + d = 0; + if (which_field == 1) { + strncpy(tech_pvt->sms_sender, content2, sizeof(tech_pvt->sms_sender)); + DEBUGA_GSMOPEN("%d content=%s\n", GSMOPEN_P_LOG, which_field, content2); + + } else if (which_field == 2) { + strncpy(tech_pvt->sms_date, content2, sizeof(tech_pvt->sms_date)); + DEBUGA_GSMOPEN("%d content=%s\n", GSMOPEN_P_LOG, which_field, content2); + } else if (which_field > 2) { + WARNINGA("WHY which_field is > 2 ? (which_field is %d)\n", GSMOPEN_P_LOG, which_field); + } + which_field++; + } else { + inside_quote = 1; + DEBUGA_GSMOPEN("START_CONTENT inside_comma=%d, inside_quote=%d, we're at=%s\n", GSMOPEN_P_LOG, inside_comma, inside_quote, + &tech_pvt->line_array.result[i][c]); + } + } + if (inside_quote && tech_pvt->line_array.result[i][c] != '"') { + + content[d] = tech_pvt->line_array.result[i][c]; + d++; + + } + + } +#endif //0 + } //it was the +CMGR answer from the cellphone + else { + DEBUGA_GSMOPEN("body=%s\n", GSMOPEN_P_LOG, sms_body); + DEBUGA_GSMOPEN("tech_pvt->line_array.result[i]=%s\n", GSMOPEN_P_LOG, tech_pvt->line_array.result[i]); + if (tech_pvt->sms_pdu_not_supported) { + char content3[1000]; + strncpy(tech_pvt->sms_message, tech_pvt->line_array.result[i], sizeof(tech_pvt->sms_message)); + + //int howmanyleft; + + + DEBUGA_GSMOPEN("sms_message=%s\n", GSMOPEN_P_LOG, tech_pvt->sms_message); + ucs2_to_utf8(tech_pvt, tech_pvt->sms_message, content3, sizeof(content3)); + DEBUGA_GSMOPEN("content3=%s\n", GSMOPEN_P_LOG, content3); + strncpy(tech_pvt->sms_body, content3, sizeof(tech_pvt->sms_body)); + //sleep(10); + //cicopet + if (tech_pvt->sms_cnmi_not_supported) { + sms_incoming(tech_pvt); + DEBUGA_GSMOPEN("2 content3=%s\n", GSMOPEN_P_LOG, content3); + } + } else { +#ifndef NO_GSMLIB + char content2[1000]; + SMSMessageRef sms; +//MessageType messagetype; +//Address servicecentreaddress; +//Timestamp servicecentretimestamp; +//Address sender_recipient_address; + + sms = SMSMessage::decode(tech_pvt->line_array.result[i]); // dataCodingScheme = 8 , text=ciao 123 belè новоÑти לק ר×ת ﺎﻠﺠﻤﻋﺓ 人大 + + DEBUGA_GSMOPEN("SMS=\n%s\n", GSMOPEN_P_LOG, sms->toString().c_str()); + + memset(content2, '\0', sizeof(content2)); + if (sms->dataCodingScheme().getAlphabet() == DCS_DEFAULT_ALPHABET) { + iso_8859_1_to_utf8(tech_pvt, (char *) sms->userData().c_str(), content2, sizeof(content2)); + } else if (sms->dataCodingScheme().getAlphabet() == DCS_SIXTEEN_BIT_ALPHABET) { + ucs2_to_utf8(tech_pvt, (char *) bufToHex((unsigned char *) sms->userData().data(), sms->userData().length()).c_str(), content2, + sizeof(content2)); + } else { + ERRORA("dataCodingScheme not supported=%d\n", GSMOPEN_P_LOG, sms->dataCodingScheme().getAlphabet()); + + } + DEBUGA_GSMOPEN("dataCodingScheme=%d\n", GSMOPEN_P_LOG, sms->dataCodingScheme().getAlphabet()); + DEBUGA_GSMOPEN("dataCodingScheme=%s\n", GSMOPEN_P_LOG, sms->dataCodingScheme().toString().c_str()); + DEBUGA_GSMOPEN("address=%s\n", GSMOPEN_P_LOG, sms->address().toString().c_str()); + DEBUGA_GSMOPEN("serviceCentreAddress=%s\n", GSMOPEN_P_LOG, sms->serviceCentreAddress().toString().c_str()); + DEBUGA_GSMOPEN("serviceCentreTimestamp=%s\n", GSMOPEN_P_LOG, sms->serviceCentreTimestamp().toString().c_str()); + DEBUGA_GSMOPEN("messageType=%d\n", GSMOPEN_P_LOG, sms->messageType()); + DEBUGA_GSMOPEN("userData= |||%s|||\n", GSMOPEN_P_LOG, content2); + + + memset(sms_body, '\0', sizeof(sms_body)); + strncpy(sms_body, content2, sizeof(sms_body)); + DEBUGA_GSMOPEN("body=%s\n", GSMOPEN_P_LOG, sms_body); + strncpy(tech_pvt->sms_body, sms_body, sizeof(tech_pvt->sms_body)); + strncpy(tech_pvt->sms_sender, sms->address().toString().c_str(), sizeof(tech_pvt->sms_sender)); + strncpy(tech_pvt->sms_date, sms->serviceCentreTimestamp().toString().c_str(), sizeof(tech_pvt->sms_date)); + strncpy(tech_pvt->sms_datacodingscheme, sms->dataCodingScheme().toString().c_str(), sizeof(tech_pvt->sms_datacodingscheme)); + strncpy(tech_pvt->sms_servicecentreaddress, sms->serviceCentreAddress().toString().c_str(), + sizeof(tech_pvt->sms_servicecentreaddress)); + tech_pvt->sms_messagetype = sms->messageType(); +//messagetype = sms->messageType(); +//servicecentreaddress = sms->serviceCentreAddress(); +//servicecentretimestamp = sms->serviceCentreTimestamp(); +//sender_recipient_address = sms->address(); + +#endif// NO_GSMLIB + } + +#if 0 + //strncat(tech_pvt->sms_message, "---", ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + //strncat(tech_pvt->sms_message, tech_pvt->line_array.result[i], ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + //strncat(tech_pvt->sms_message, "|||", ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + + memset(sms_body, '\0', sizeof(sms_body)); + err = ucs2_to_utf8(tech_pvt, tech_pvt->line_array.result[i], sms_body, sizeof(sms_body)); + DEBUGA_GSMOPEN("body=%s\n", GSMOPEN_P_LOG, sms_body); + strncpy(tech_pvt->sms_body, sms_body, sizeof(tech_pvt->sms_body)); + + //strncat(tech_pvt->sms_message, "---", ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + //if (!err) + //strncat(tech_pvt->sms_message, sms_body, ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + //strncat(tech_pvt->sms_message, "|||", ((sizeof(tech_pvt->sms_message) - strlen(tech_pvt->sms_message)) - 1)); + + //DEBUGA_GSMOPEN("sms_message=%s\n", GSMOPEN_P_LOG, tech_pvt->sms_message); +#endif //0 + } //it was the UCS2 from cellphone + + } //we were reading the SMS + + } + + la_read = la_counter; + + if (look_for_ack && at_ack > -1) + break; + + if (la_counter > AT_MESG_MAX_LINES) { + ERRORA("Too many lines in result (>%d). Stopping reader.\n", GSMOPEN_P_LOG, AT_MESG_MAX_LINES); + at_ack = AT_ERROR; + break; + } + } + + UNLOCKA(tech_pvt->controldev_lock); + POPPA_UNLOCKA(tech_pvt->controldev_lock); + if (select_err == -1) { + ERRORA("select returned -1 on %s, setting controldev_dead, error was: %s\n", GSMOPEN_P_LOG, tech_pvt->controldevice_name, strerror(errno)); + tech_pvt->controldev_dead = 1; + close(tech_pvt->controldevfd); + + tech_pvt->running=0; + alarm_event(tech_pvt, ALARM_FAILED_INTERFACE, "select returned -1 on interface, setting controldev_dead"); + tech_pvt->active=0; + tech_pvt->name[0]='\0'; + if (tech_pvt->owner) + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + switch_sleep(1000000); + return -1; + } + + if (tech_pvt->phone_callflow == CALLFLOW_CALL_INCOMING && tech_pvt->call_incoming_time.tv_sec) { //after three sec of CALLFLOW_CALL_INCOMING, we assume the phone is incapable of notifying RING (eg: motorola c350), so we try to answer + char list_command[64]; + struct timeval call_incoming_timeout; + gettimeofday(&call_incoming_timeout, NULL); + call_incoming_timeout.tv_sec -= 3; + DEBUGA_GSMOPEN + ("CALLFLOW_CALL_INCOMING call_incoming_time.tv_sec=%ld, call_incoming_timeout.tv_sec=%ld\n", + GSMOPEN_P_LOG, tech_pvt->call_incoming_time.tv_sec, call_incoming_timeout.tv_sec); + if (call_incoming_timeout.tv_sec > tech_pvt->call_incoming_time.tv_sec) { + + tech_pvt->call_incoming_time.tv_sec = 0; + tech_pvt->call_incoming_time.tv_usec = 0; + DEBUGA_GSMOPEN + ("CALLFLOW_CALL_INCOMING call_incoming_time.tv_sec=%ld, call_incoming_timeout.tv_sec=%ld\n", + GSMOPEN_P_LOG, tech_pvt->call_incoming_time.tv_sec, call_incoming_timeout.tv_sec); + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CPBS=RC"); + if (res) { + ERRORA("AT+CPBS=RC (select memory of received calls) was not answered by the phone\n", GSMOPEN_P_LOG); + } + tech_pvt->phonebook_querying = 1; + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CPBR=?"); + if (res) { + ERRORA("AT+CPBS=RC (select memory of received calls) was not answered by the phone\n", GSMOPEN_P_LOG); + } + tech_pvt->phonebook_querying = 0; + sprintf(list_command, "AT+CPBR=%d,%d", tech_pvt->phonebook_first_entry, tech_pvt->phonebook_last_entry); + tech_pvt->phonebook_listing_received_calls = 1; + res = gsmopen_serial_write_AT_expect_longtime(tech_pvt, list_command, "OK"); + if (res) { + WARNINGA("AT+CPBR=%d,%d failed, continue\n", GSMOPEN_P_LOG, tech_pvt->phonebook_first_entry, tech_pvt->phonebook_last_entry); + } + tech_pvt->phonebook_listing_received_calls = 0; + } + } + + if (tech_pvt->phone_callflow == CALLFLOW_INCOMING_RING) { + struct timeval call_incoming_timeout; + gettimeofday(&call_incoming_timeout, NULL); + call_incoming_timeout.tv_sec -= 10; + // DEBUGA_GSMOPEN ("CALLFLOW_CALL_INCOMING call_incoming_time.tv_sec=%ld, call_incoming_timeout.tv_sec=%ld\n", GSMOPEN_P_LOG, tech_pvt->call_incoming_time.tv_sec, call_incoming_timeout.tv_sec); + if (call_incoming_timeout.tv_sec > tech_pvt->ringtime.tv_sec) { + ERRORA("Ringing stopped and I have not answered. Why?\n", GSMOPEN_P_LOG); + DEBUGA_GSMOPEN + ("CALLFLOW_CALL_INCOMING call_incoming_time.tv_sec=%ld, call_incoming_timeout.tv_sec=%ld\n", + GSMOPEN_P_LOG, tech_pvt->call_incoming_time.tv_sec, call_incoming_timeout.tv_sec); + if (tech_pvt->owner) { + gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_HANGUP); + tech_pvt->owner->hangupcause = GSMOPEN_CAUSE_FAILURE; + } + } + } + tech_pvt->line_array.elemcount = la_counter; + //NOTICA (" OUTSIDE this gsmopen_serial_device %s \n", GSMOPEN_P_LOG, tech_pvt->controldevice_name); + if (look_for_ack) + return at_ack; + else + return 0; +} + +int gsmopen_serial_write_AT(private_t * tech_pvt, const char *data) +{ + int howmany; + int i; + int res; + int count; + + howmany = strlen(data); + + for (i = 0; i < howmany; i++) { + res = write(tech_pvt->controldevfd, &data[i], 1); + + if (res != 1) { + DEBUGA_GSMOPEN("Error sending (%.1s): %d (%s)\n", GSMOPEN_P_LOG, &data[i], res, strerror(errno)); + gsmopen_sleep(100000); + for (count = 0; count < 10; count++) { + res = write(tech_pvt->controldevfd, &data[i], 1); + if (res == 1) { + DEBUGA_GSMOPEN("Successfully RE-sent (%.1s): %d %d (%s)\n", GSMOPEN_P_LOG, &data[i], count, res, strerror(errno)); + break; + } else + DEBUGA_GSMOPEN("Error RE-sending (%.1s): %d %d (%s)\n", GSMOPEN_P_LOG, &data[i], count, res, strerror(errno)); + gsmopen_sleep(100000); + + } + if (res != 1) { + ERRORA("Error RE-sending (%.1s): %d %d (%s)\n", GSMOPEN_P_LOG, &data[i], count, res, strerror(errno)); + return -1; + } + } + if (option_debug > 1) + DEBUGA_GSMOPEN("sent data... (%.1s)\n", GSMOPEN_P_LOG, &data[i]); + gsmopen_sleep(1000); /* release the cpu */ + } + + res = write(tech_pvt->controldevfd, "\r", 1); + + if (res != 1) { + DEBUGA_GSMOPEN("Error sending (carriage return): %d (%s)\n", GSMOPEN_P_LOG, res, strerror(errno)); + gsmopen_sleep(100000); + for (count = 0; count < 10; count++) { + res = write(tech_pvt->controldevfd, "\r", 1); + + if (res == 1) { + DEBUGA_GSMOPEN("Successfully RE-sent carriage return: %d %d (%s)\n", GSMOPEN_P_LOG, count, res, strerror(errno)); + break; + } else + DEBUGA_GSMOPEN("Error RE-sending (carriage return): %d %d (%s)\n", GSMOPEN_P_LOG, count, res, strerror(errno)); + gsmopen_sleep(100000); + + } + if (res != 1) { + ERRORA("Error RE-sending (carriage return): %d %d (%s)\n", GSMOPEN_P_LOG, count, res, strerror(errno)); + return -1; + } + } + if (option_debug > 1) + DEBUGA_GSMOPEN("sent (carriage return)\n", GSMOPEN_P_LOG); + gsmopen_sleep(1000); /* release the cpu */ + + return howmany; +} + +int gsmopen_serial_write_AT_nocr(private_t * tech_pvt, const char *data) +{ + int howmany; + int i; + int res; + int count; + + howmany = strlen(data); + + for (i = 0; i < howmany; i++) { + res = write(tech_pvt->controldevfd, &data[i], 1); + + if (res != 1) { + DEBUGA_GSMOPEN("Error sending (%.1s): %d (%s)\n", GSMOPEN_P_LOG, &data[i], res, strerror(errno)); + gsmopen_sleep(100000); + for (count = 0; count < 10; count++) { + res = write(tech_pvt->controldevfd, &data[i], 1); + if (res == 1) + break; + else + DEBUGA_GSMOPEN("Error RE-sending (%.1s): %d %d (%s)\n", GSMOPEN_P_LOG, &data[i], count, res, strerror(errno)); + gsmopen_sleep(100000); + + } + if (res != 1) { + ERRORA("Error RE-sending (%.1s): %d %d (%s)\n", GSMOPEN_P_LOG, &data[i], count, res, strerror(errno)); + return -1; + } + } + if (option_debug > 1) + DEBUGA_GSMOPEN("sent data... (%.1s)\n", GSMOPEN_P_LOG, &data[i]); + gsmopen_sleep(1000); /* release the cpu */ + } + + gsmopen_sleep(1000); /* release the cpu */ + + return howmany; +} + +int gsmopen_serial_write_AT_noack(private_t * tech_pvt, const char *data) +{ + + if (option_debug > 1) + DEBUGA_GSMOPEN("gsmopen_serial_write_AT_noack: %s\n", GSMOPEN_P_LOG, data); + + PUSHA_UNLOCKA(tech_pvt->controldev_lock); + LOKKA(tech_pvt->controldev_lock); + if (gsmopen_serial_write_AT(tech_pvt, data) != strlen(data)) { + + ERRORA("Error sending data... (%s)\n", GSMOPEN_P_LOG, strerror(errno)); + UNLOCKA(tech_pvt->controldev_lock); + return -1; + } + UNLOCKA(tech_pvt->controldev_lock); + POPPA_UNLOCKA(tech_pvt->controldev_lock); + + return 0; +} + +int gsmopen_serial_write_AT_ack(private_t * tech_pvt, const char *data) +{ + int at_result = AT_ERROR; + + PUSHA_UNLOCKA(tech_pvt->controldev_lock); + LOKKA(tech_pvt->controldev_lock); + if (option_debug > 1) + DEBUGA_GSMOPEN("sending: %s\n", GSMOPEN_P_LOG, data); + if (gsmopen_serial_write_AT(tech_pvt, data) != strlen(data)) { + ERRORA("Error sending data... (%s) \n", GSMOPEN_P_LOG, strerror(errno)); + UNLOCKA(tech_pvt->controldev_lock); + return -1; + } + + at_result = gsmopen_serial_read_AT(tech_pvt, 1, 500000, 2, NULL, 1); // 2.5 sec timeout + UNLOCKA(tech_pvt->controldev_lock); + POPPA_UNLOCKA(tech_pvt->controldev_lock); + + return at_result; + +} + +int gsmopen_serial_write_AT_ack_nocr_longtime(private_t * tech_pvt, const char *data) +{ + int at_result = AT_ERROR; + + PUSHA_UNLOCKA(tech_pvt->controldev_lock); + LOKKA(tech_pvt->controldev_lock); + if (option_debug > 1) + DEBUGA_GSMOPEN("sending: %s\n", GSMOPEN_P_LOG, data); + if (gsmopen_serial_write_AT_nocr(tech_pvt, data) != strlen(data)) { + ERRORA("Error sending data... (%s) \n", GSMOPEN_P_LOG, strerror(errno)); + UNLOCKA(tech_pvt->controldev_lock); + return -1; + } + + at_result = gsmopen_serial_read_AT(tech_pvt, 1, 500000, 20, NULL, 1); // 20.5 sec timeout + UNLOCKA(tech_pvt->controldev_lock); + POPPA_UNLOCKA(tech_pvt->controldev_lock); + + return at_result; + +} + +int gsmopen_serial_write_AT_expect1(private_t * tech_pvt, const char *data, const char *expected_string, int expect_crlf, int seconds) +{ + int at_result = AT_ERROR; + + PUSHA_UNLOCKA(tech_pvt->controldev_lock); + LOKKA(tech_pvt->controldev_lock); + if (option_debug > 1) + DEBUGA_GSMOPEN("sending: %s, expecting: %s\n", GSMOPEN_P_LOG, data, expected_string); + if (gsmopen_serial_write_AT(tech_pvt, data) != strlen(data)) { + ERRORA("Error sending data... (%s) \n", GSMOPEN_P_LOG, strerror(errno)); + UNLOCKA(tech_pvt->controldev_lock); + return -1; + } + + at_result = gsmopen_serial_read_AT(tech_pvt, 1, 500000, seconds, expected_string, expect_crlf); // 20.5 sec timeout, used for querying the SIM and sending SMSs + UNLOCKA(tech_pvt->controldev_lock); + POPPA_UNLOCKA(tech_pvt->controldev_lock); + + return at_result; + +} + +int gsmopen_serial_AT_expect(private_t * tech_pvt, const char *expected_string, int expect_crlf, int seconds) +{ + int at_result = AT_ERROR; + + PUSHA_UNLOCKA(tech_pvt->controldev_lock); + LOKKA(tech_pvt->controldev_lock); + if (option_debug > 1) + DEBUGA_GSMOPEN("expecting: %s\n", GSMOPEN_P_LOG, expected_string); + + at_result = gsmopen_serial_read_AT(tech_pvt, 1, 500000, seconds, expected_string, expect_crlf); // 20.5 sec timeout, used for querying the SIM and sending SMSs + UNLOCKA(tech_pvt->controldev_lock); + POPPA_UNLOCKA(tech_pvt->controldev_lock); + + return at_result; + +} + +int gsmopen_serial_answer(private_t * tech_pvt) +{ + if (tech_pvt->controldevprotocol == PROTOCOL_AT) + return gsmopen_serial_answer_AT(tech_pvt); +#ifdef GSMOPEN_FBUS2 + if (tech_pvt->controldevprotocol == PROTOCOL_FBUS2) + return gsmopen_serial_answer_FBUS2(tech_pvt); +#endif /* GSMOPEN_FBUS2 */ +#ifdef GSMOPEN_CVM + if (tech_pvt->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return gsmopen_serial_answer_CVM_BUSMAIL(tech_pvt); +#endif /* GSMOPEN_CVM */ + return -1; +} + + +int gsmopen_serial_answer_AT(private_t * tech_pvt) +{ + int res; + + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_answer, tech_pvt->at_answer_expect); + if (res) { + DEBUGA_GSMOPEN + ("at_answer command failed, command used: %s, expecting: %s, trying with AT+CKPD=\"S\"\n", + GSMOPEN_P_LOG, tech_pvt->at_answer, tech_pvt->at_answer_expect); + + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CKPD=\"S\""); + if (res) { + ERRORA("at_answer command failed, command used: 'AT+CKPD=\"S\"', giving up\n", GSMOPEN_P_LOG); + return -1; + } + } + //tech_pvt->interface_state = GSMOPEN_STATE_UP; + //tech_pvt->phone_callflow = CALLFLOW_CALL_ACTIVE; + DEBUGA_GSMOPEN("AT: call answered\n", GSMOPEN_P_LOG); + return 0; +} + +int gsmopen_serial_hangup(private_t * tech_pvt) +{ + if (tech_pvt->controldevprotocol == PROTOCOL_AT) + return gsmopen_serial_hangup_AT(tech_pvt); +#ifdef GSMOPEN_FBUS2 + if (tech_pvt->controldevprotocol == PROTOCOL_FBUS2) + return gsmopen_serial_hangup_FBUS2(tech_pvt); +#endif /* GSMOPEN_FBUS2 */ +#ifdef GSMOPEN_CVM + if (tech_pvt->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return gsmopen_serial_hangup_CVM_BUSMAIL(tech_pvt); +#endif /* GSMOPEN_CVM */ + return -1; +} + + +int gsmopen_serial_hangup_AT(private_t * tech_pvt) +{ + int res; + + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN) { + res = gsmopen_serial_write_AT_expect(tech_pvt, tech_pvt->at_hangup, tech_pvt->at_hangup_expect); + if (res) { + DEBUGA_GSMOPEN("at_hangup command failed, command used: %s, trying to use AT+CKPD=\"EEE\"\n", GSMOPEN_P_LOG, tech_pvt->at_hangup); + res = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CKPD=\"EEE\""); + if (res) { + ERRORA("at_hangup command failed, command used: 'AT+CKPD=\"EEE\"'\n", GSMOPEN_P_LOG); + return -1; + } + } + } + tech_pvt->interface_state = GSMOPEN_STATE_DOWN; + tech_pvt->phone_callflow = CALLFLOW_CALL_IDLE; + return 0; +} + + +int gsmopen_serial_call(private_t * tech_pvt, char *dstr) +{ + if (tech_pvt->controldevprotocol == PROTOCOL_AT) + return gsmopen_serial_call_AT(tech_pvt, dstr); +#ifdef GSMOPEN_FBUS2 + if (tech_pvt->controldevprotocol == PROTOCOL_FBUS2) + return gsmopen_serial_call_FBUS2(tech_pvt, dstr); +#endif /* GSMOPEN_FBUS2 */ + if (tech_pvt->controldevprotocol == PROTOCOL_NO_SERIAL) + return 0; +#ifdef GSMOPEN_CVM + if (tech_pvt->controldevprotocol == PROTOCOL_CVM_BUSMAIL) + return gsmopen_serial_call_CVM_BUSMAIL(tech_pvt, dstr); +#endif /* GSMOPEN_CVM */ + return -1; +} + +int gsmopen_serial_call_AT(private_t * tech_pvt, char *dstr) +{ + int res; + char at_command[256]; + + if (option_debug) + DEBUGA_PBX("Dialing %s\n", GSMOPEN_P_LOG, dstr); + memset(at_command, 0, sizeof(at_command)); + tech_pvt->phone_callflow = CALLFLOW_CALL_DIALING; + tech_pvt->interface_state = GSMOPEN_STATE_DIALING; + //ast_uri_decode(dstr); +/* + size_t fixdstr = strspn(dstr, AST_DIGIT_ANYDIG); + if (fixdstr == 0) { + ERRORA("dial command failed because of invalid dial number. dial string was: %s\n", + GSMOPEN_P_LOG, dstr); + return -1; + } +*/ + //dstr[fixdstr] = '\0'; + sprintf(at_command, "%s%s%s", tech_pvt->at_dial_pre_number, dstr, tech_pvt->at_dial_post_number); + DEBUGA_PBX("Dialstring %s\n", GSMOPEN_P_LOG, at_command); + res = gsmopen_serial_write_AT_expect(tech_pvt, at_command, tech_pvt->at_dial_expect); + if (res) { + ERRORA("dial command failed, dial string was: %s\n", GSMOPEN_P_LOG, at_command); + return -1; + } + // jet - early audio + //if (tech_pvt->at_early_audio) { + //ast_queue_control(tech_pvt->owner, AST_CONTROL_ANSWER); + //} + + return 0; +} + +int ucs2_to_utf8(private_t * tech_pvt, char *ucs2_in, char *utf8_out, size_t outbytesleft) +{ + char converted[16000]; +#ifndef WIN32 + iconv_t iconv_format; + int iconv_res; + char *outbuf; + char *inbuf; + size_t inbytesleft; + int c; + char stringa[5]; + double hexnum; + int i = 0; + + memset(converted, '\0', sizeof(converted)); + + DEBUGA_GSMOPEN("ucs2_in=%s\n", GSMOPEN_P_LOG, ucs2_in); + /* cicopet */ + for (c = 0; c < strlen(ucs2_in); c++) { + sprintf(stringa, "0x%c%c", ucs2_in[c], ucs2_in[c + 1]); + c++; + hexnum = strtod(stringa, NULL); + converted[i] = (char) hexnum; + i++; + } + + outbuf = utf8_out; + inbuf = converted; + + iconv_format = iconv_open("UTF8", "UCS-2BE"); + if (iconv_format == (iconv_t) - 1) { + ERRORA("error: %s\n", GSMOPEN_P_LOG, strerror(errno)); + return -1; + } + + inbytesleft = i; + DEBUGA_GSMOPEN("1 ciao in=%s, inleft=%d, out=%s, outleft=%d, converted=%s, utf8_out=%s\n", + GSMOPEN_P_LOG, inbuf, (int) inbytesleft, outbuf, (int) outbytesleft, converted, utf8_out); + + iconv_res = iconv(iconv_format, &inbuf, &inbytesleft, &outbuf, &outbytesleft); + if (iconv_res == (size_t) -1) { + DEBUGA_GSMOPEN("2 ciao in=%s, inleft=%d, out=%s, outleft=%d, converted=%s, utf8_out=%s\n", + GSMOPEN_P_LOG, inbuf, (int) inbytesleft, outbuf, (int) outbytesleft, converted, utf8_out); + DEBUGA_GSMOPEN("3 error: %s %d\n", GSMOPEN_P_LOG, strerror(errno), errno); + iconv_close(iconv_format); + return -1; + } + DEBUGA_GSMOPEN + ("iconv_res=%d, in=%s, inleft=%d, out=%s, outleft=%d, converted=%s, utf8_out=%s\n", + GSMOPEN_P_LOG, iconv_res, inbuf, (int) inbytesleft, outbuf, (int) outbytesleft, converted, utf8_out); + iconv_close(iconv_format); + +#endif //WIN32 + return 0; +} + +int iso_8859_1_to_utf8(private_t * tech_pvt, char *iso_8859_1_in, char *utf8_out, size_t outbytesleft) +{ + char converted[16000]; +#ifndef WIN32 + iconv_t iconv_format; + int iconv_res; + char *outbuf; + char *inbuf; + size_t inbytesleft; + //int c; + //char stringa[5]; + //double hexnum; + //int i = 0; + + memset(converted, '\0', sizeof(converted)); + + DEBUGA_GSMOPEN("iso_8859_1_in=%s\n", GSMOPEN_P_LOG, iso_8859_1_in); + + outbuf = utf8_out; + inbuf = iso_8859_1_in; + + iconv_format = iconv_open("UTF8", "ISO_8859-1"); + if (iconv_format == (iconv_t) - 1) { + ERRORA("error: %s\n", GSMOPEN_P_LOG, strerror(errno)); + return -1; + } + + + inbytesleft = strlen(iso_8859_1_in) * 2; + iconv_res = iconv(iconv_format, &inbuf, &inbytesleft, &outbuf, &outbytesleft); + if (iconv_res == (size_t) -1) { + DEBUGA_GSMOPEN("ciao in=%s, inleft=%d, out=%s, outleft=%d, utf8_out=%s\n", + GSMOPEN_P_LOG, inbuf, (int) inbytesleft, outbuf, (int) outbytesleft, utf8_out); + DEBUGA_GSMOPEN("error: %s %d\n", GSMOPEN_P_LOG, strerror(errno), errno); + return -1; + } + DEBUGA_GSMOPEN + (" strlen(iso_8859_1_in)=%d, iconv_res=%d, inbuf=%s, inleft=%d, out=%s, outleft=%d, utf8_out=%s\n", + GSMOPEN_P_LOG, (int) strlen(iso_8859_1_in), iconv_res, inbuf, (int) inbytesleft, outbuf, (int) outbytesleft, utf8_out); + + + + iconv_close(iconv_format); + +#endif //WIN32 + return 0; +} + + +int utf_to_ucs2(private_t * tech_pvt, char *utf_in, size_t inbytesleft, char *ucs2_out, size_t outbytesleft) +{ + /* cicopet */ +#ifndef WIN32 + iconv_t iconv_format; + int iconv_res; + char *outbuf; + char *inbuf; + char converted[16000]; + int i; + char stringa[16]; + char stringa2[16]; + + memset(converted, '\0', sizeof(converted)); + + outbuf = converted; + inbuf = utf_in; + + iconv_format = iconv_open("UCS-2BE", "UTF8"); + if (iconv_format == (iconv_t) - 1) { + ERRORA("error: %s\n", GSMOPEN_P_LOG, strerror(errno)); + return -1; + } + outbytesleft = 16000; + + DEBUGA_GSMOPEN("in=%s, inleft=%d, out=%s, outleft=%d, utf_in=%s, converted=%s\n", + GSMOPEN_P_LOG, inbuf, (int) inbytesleft, outbuf, (int) outbytesleft, utf_in, converted); + iconv_res = iconv(iconv_format, &inbuf, &inbytesleft, &outbuf, &outbytesleft); + if (iconv_res == (size_t) -1) { + ERRORA("error: %s %d\n", GSMOPEN_P_LOG, strerror(errno), errno); + return -1; + } + DEBUGA_GSMOPEN + ("iconv_res=%d, in=%s, inleft=%d, out=%s, outleft=%d, utf_in=%s, converted=%s\n", + GSMOPEN_P_LOG, iconv_res, inbuf, (int) inbytesleft, outbuf, (int) outbytesleft, utf_in, converted); + iconv_close(iconv_format); + + for (i = 0; i < 16000 - outbytesleft; i++) { + memset(stringa, '\0', sizeof(stringa)); + memset(stringa2, '\0', sizeof(stringa2)); + sprintf(stringa, "%02X", converted[i]); + DEBUGA_GSMOPEN("character is |%02X|\n", GSMOPEN_P_LOG, converted[i]); + stringa2[0] = stringa[strlen(stringa) - 2]; + stringa2[1] = stringa[strlen(stringa) - 1]; + strncat(ucs2_out, stringa2, ((outbytesleft - strlen(ucs2_out)) - 1)); //add the received line to the buffer + DEBUGA_GSMOPEN("stringa=%s, stringa2=%s, ucs2_out=%s\n", GSMOPEN_P_LOG, stringa, stringa2, ucs2_out); + } +#endif //WIN32 + return 0; +} + + +/*! \brief Answer incoming call, + * Part of PBX interface */ +int gsmopen_answer(private_t * tech_pvt) +{ + int res; + + if (option_debug) { + DEBUGA_PBX("ENTERING FUNC\n", GSMOPEN_P_LOG); + } + /* do something to actually answer the call, if needed (eg. pick up the phone) */ + if (tech_pvt->controldevprotocol != PROTOCOL_NO_SERIAL) { + if (gsmopen_serial_answer(tech_pvt)) { + ERRORA("gsmopen_answer FAILED\n", GSMOPEN_P_LOG); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", GSMOPEN_P_LOG); + } + return -1; + } + } + tech_pvt->interface_state = GSMOPEN_STATE_UP; + tech_pvt->phone_callflow = CALLFLOW_CALL_ACTIVE; + + while (tech_pvt->interface_state == GSMOPEN_STATE_RING) { + gsmopen_sleep(10000); //10msec + } + if (tech_pvt->interface_state != GSMOPEN_STATE_UP) { + ERRORA("call answering failed\n", GSMOPEN_P_LOG); + res = -1; + } else { + if (option_debug) + DEBUGA_PBX("call answered\n", GSMOPEN_P_LOG); + res = 0; +#ifdef GSMOPEN_PORTAUDIO + //speex_echo_state_reset(tech_pvt->stream->echo_state); +#endif // GSMOPEN_PORTAUDIO + + new_inbound_channel(tech_pvt); + if (tech_pvt->owner) { + DEBUGA_PBX("going to send GSMOPEN_STATE_UP\n", GSMOPEN_P_LOG); + ast_setstate(tech_pvt->owner, GSMOPEN_STATE_UP); + //ast_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_ANSWER); + //gsmopen_queue_control(tech_pvt->owner, GSMOPEN_CONTROL_ANSWER); + DEBUGA_PBX("just sent GSMOPEN_STATE_UP\n", GSMOPEN_P_LOG); + } + } + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", GSMOPEN_P_LOG); + } + return res; +} + +int gsmopen_ring(private_t * tech_pvt) +{ + int res = 0; + switch_core_session_t *session = NULL; + switch_channel_t *channel = NULL; + + if (option_debug) { + //DEBUGA_PBX("ENTERING FUNC\n", GSMOPEN_P_LOG); + } + + session = switch_core_session_locate(tech_pvt->session_uuid_str); + if (session) { + switch_core_session_rwunlock(session); + return 0; + } + + new_inbound_channel(tech_pvt); + + gsmopen_sleep(10000); + + session = switch_core_session_locate(tech_pvt->session_uuid_str); + if (session) { + channel = switch_core_session_get_channel(session); + + switch_core_session_queue_indication(session, SWITCH_MESSAGE_INDICATE_RINGING); + if (channel) { + switch_channel_mark_ring_ready(channel); + } else { + ERRORA("no session\n", GSMOPEN_P_LOG); + } + switch_core_session_rwunlock(session); + } else { + ERRORA("no session\n", GSMOPEN_P_LOG); + + } + + + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", GSMOPEN_P_LOG); + } + return res; +} + + +/*! \brief Hangup gsmopen call + * Part of PBX interface, called from ast_hangup */ + +int gsmopen_hangup(private_t * tech_pvt) +{ + + /* if there is not gsmopen pvt why we are here ? */ + if (!tech_pvt) { + ERRORA("Asked to hangup channel not connected\n", GSMOPEN_P_LOG); + return 0; + } + + DEBUGA_GSMOPEN("ENTERING FUNC\n", GSMOPEN_P_LOG); + + + if (tech_pvt->controldevprotocol != PROTOCOL_NO_SERIAL) { + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN) { + /* actually hangup through the serial port */ + if (tech_pvt->controldevprotocol != PROTOCOL_NO_SERIAL) { + int res; + res = gsmopen_serial_hangup(tech_pvt); + if (res) { + ERRORA("gsmopen_serial_hangup error: %d\n", GSMOPEN_P_LOG, res); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", GSMOPEN_P_LOG); + } + return -1; + } + } + + while (tech_pvt->interface_state != GSMOPEN_STATE_DOWN) { + gsmopen_sleep(10000); //10msec + } + if (tech_pvt->interface_state != GSMOPEN_STATE_DOWN) { + ERRORA("call hangup failed\n", GSMOPEN_P_LOG); + return -1; + } else { + DEBUGA_GSMOPEN("call hungup\n", GSMOPEN_P_LOG); + } + } + } else { + tech_pvt->interface_state = GSMOPEN_STATE_DOWN; + tech_pvt->phone_callflow = CALLFLOW_CALL_IDLE; + } + + switch_set_flag(tech_pvt, TFLAG_HANGUP); + if (option_debug) { + DEBUGA_PBX("EXITING FUNC\n", GSMOPEN_P_LOG); + } + return 0; +} + + + +#ifdef GSMOPEN_ALSA +/*! \brief ALSA pcm format, according to endianess */ +#if __BYTE_ORDER == __LITTLE_ENDIAN +snd_pcm_format_t gsmopen_format = SND_PCM_FORMAT_S16_LE; +#else +snd_pcm_format_t gsmopen_format = SND_PCM_FORMAT_S16_BE; +#endif + +/*! + * \brief Initialize the ALSA soundcard channels (capture AND playback) used by one interface (a multichannel soundcard can be used by multiple interfaces) + * \param p the gsmopen_pvt of the interface + * + * This function call alsa_open_dev to initialize the ALSA soundcard for each channel (capture AND playback) used by one interface (a multichannel soundcard can be used by multiple interfaces). Called by sound_init + * + * \return zero on success, -1 on error. + */ +int alsa_init(private_t * tech_pvt) +{ + tech_pvt->alsac = alsa_open_dev(tech_pvt, SND_PCM_STREAM_CAPTURE); + if (!tech_pvt->alsac) { + ERRORA("Failed opening ALSA capture device: %s\n", GSMOPEN_P_LOG, tech_pvt->alsacname); + if (alsa_shutdown(tech_pvt)) { + ERRORA("alsa_shutdown failed\n", GSMOPEN_P_LOG); + return -1; + } + return -1; + } + tech_pvt->alsap = alsa_open_dev(tech_pvt, SND_PCM_STREAM_PLAYBACK); + if (!tech_pvt->alsap) { + ERRORA("Failed opening ALSA playback device: %s\n", GSMOPEN_P_LOG, tech_pvt->alsapname); + if (alsa_shutdown(tech_pvt)) { + ERRORA("alsa_shutdown failed\n", GSMOPEN_P_LOG); + return -1; + } + return -1; + } + + /* make valgrind very happy */ + snd_config_update_free_global(); + return 0; +} + +/*! + * \brief Shutdown the ALSA soundcard channels (input and output) used by one interface (a multichannel soundcard can be used by multiple interfaces) + * \param p the gsmopen_pvt of the interface + * + * This function shutdown the ALSA soundcard channels (input and output) used by one interface (a multichannel soundcard can be used by multiple interfaces). Called by sound_init + * + * \return zero on success, -1 on error. + */ + +int alsa_shutdown(private_t * tech_pvt) +{ + + int err; + + if (tech_pvt->alsap) { + err = snd_pcm_drop(tech_pvt->alsap); + if (err < 0) { + ERRORA("device [%s], snd_pcm_drop failed with error '%s'\n", GSMOPEN_P_LOG, tech_pvt->alsapname, snd_strerror(err)); + return -1; + } + err = snd_pcm_close(tech_pvt->alsap); + if (err < 0) { + ERRORA("device [%s], snd_pcm_close failed with error '%s'\n", GSMOPEN_P_LOG, tech_pvt->alsapname, snd_strerror(err)); + return -1; + } + tech_pvt->alsap = NULL; + } + if (tech_pvt->alsac) { + err = snd_pcm_drop(tech_pvt->alsac); + if (err < 0) { + ERRORA("device [%s], snd_pcm_drop failed with error '%s'\n", GSMOPEN_P_LOG, tech_pvt->alsacname, snd_strerror(err)); + return -1; + } + err = snd_pcm_close(tech_pvt->alsac); + if (err < 0) { + ERRORA("device [%s], snd_pcm_close failed with error '%s'\n", GSMOPEN_P_LOG, tech_pvt->alsacname, snd_strerror(err)); + return -1; + } + tech_pvt->alsac = NULL; + } + + return 0; +} + +/*! + * \brief Setup and open the ALSA device (capture OR playback) + * \param p the gsmopen_pvt of the interface + * \param stream the ALSA capture/playback definition + * + * This function setup and open the ALSA device (capture OR playback). Called by alsa_init + * + * \return zero on success, -1 on error. + */ +snd_pcm_t *alsa_open_dev(private_t * tech_pvt, snd_pcm_stream_t stream) +{ + + snd_pcm_t *handle = NULL; + snd_pcm_hw_params_t *params; + snd_pcm_sw_params_t *swparams; + snd_pcm_uframes_t buffer_size; + int err; + size_t n; + //snd_pcm_uframes_t xfer_align; + unsigned int rate; + snd_pcm_uframes_t start_threshold, stop_threshold; + snd_pcm_uframes_t period_size = 0; + snd_pcm_uframes_t chunk_size = 0; + int start_delay = 0; + int stop_delay = 0; + snd_pcm_state_t state; + snd_pcm_info_t *info; + unsigned int chan_num; + + period_size = tech_pvt->alsa_period_size; + + snd_pcm_hw_params_alloca(¶ms); + snd_pcm_sw_params_alloca(&swparams); + + if (stream == SND_PCM_STREAM_CAPTURE) { + err = snd_pcm_open(&handle, tech_pvt->alsacname, stream, 0 | SND_PCM_NONBLOCK); + } else { + err = snd_pcm_open(&handle, tech_pvt->alsapname, stream, 0 | SND_PCM_NONBLOCK); + } + if (err < 0) { + ERRORA + ("snd_pcm_open failed with error '%s' on device '%s', if you are using a plughw:n device please change it to be a default:n device (so to allow it to be shared with other concurrent programs), or maybe you are using an ALSA voicemodem and slmodemd" + " is running?\n", GSMOPEN_P_LOG, snd_strerror(err), stream == SND_PCM_STREAM_CAPTURE ? tech_pvt->alsacname : tech_pvt->alsapname); + return NULL; + } + + snd_pcm_info_alloca(&info); + + if ((err = snd_pcm_info(handle, info)) < 0) { + ERRORA("info error: %s", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + + err = snd_pcm_nonblock(handle, 1); + if (err < 0) { + ERRORA("nonblock setting error: %s", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + + err = snd_pcm_hw_params_any(handle, params); + if (err < 0) { + ERRORA("Broken configuration for this PCM, no configurations available: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + + err = snd_pcm_hw_params_set_access(handle, params, SND_PCM_ACCESS_RW_INTERLEAVED); + if (err < 0) { + ERRORA("Access type not available: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + err = snd_pcm_hw_params_set_format(handle, params, gsmopen_format); + if (err < 0) { + ERRORA("Sample format non available: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + err = snd_pcm_hw_params_set_channels(handle, params, 1); + if (err < 0) { + DEBUGA_GSMOPEN("Channels count set failed: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + } +#if 1 + err = snd_pcm_hw_params_get_channels(params, &chan_num); + if (err < 0) { + ERRORA("Channels count non available: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + if (chan_num < 1 || chan_num > 2) { + ERRORA("Channels count MUST BE 1 or 2, it is: %d\n", GSMOPEN_P_LOG, chan_num); + ERRORA("Channels count MUST BE 1 or 2, it is: %d on %s %s\n", GSMOPEN_P_LOG, chan_num, tech_pvt->alsapname, tech_pvt->alsacname); + return NULL; + } else { + if (chan_num == 1) { + if (stream == SND_PCM_STREAM_CAPTURE) + tech_pvt->alsa_capture_is_mono = 1; + else + tech_pvt->alsa_play_is_mono = 1; + } else { + if (stream == SND_PCM_STREAM_CAPTURE) + tech_pvt->alsa_capture_is_mono = 0; + else + tech_pvt->alsa_play_is_mono = 0; + } + } +#else + tech_pvt->alsa_capture_is_mono = 1; + tech_pvt->alsa_play_is_mono = 1; +#endif + +#if 1 + rate = tech_pvt->gsmopen_sound_rate; + err = snd_pcm_hw_params_set_rate_near(handle, params, &rate, 0); + if ((float) tech_pvt->gsmopen_sound_rate * 1.05 < rate || (float) tech_pvt->gsmopen_sound_rate * 0.95 > rate) { + WARNINGA("Rate is not accurate (requested = %iHz, got = %iHz)\n", GSMOPEN_P_LOG, tech_pvt->gsmopen_sound_rate, rate); + } + + if (err < 0) { + ERRORA("Error setting rate: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + tech_pvt->gsmopen_sound_rate = rate; + + err = snd_pcm_hw_params_set_period_size_near(handle, params, &period_size, 0); + + if (err < 0) { + ERRORA("Error setting period_size: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + + tech_pvt->alsa_period_size = period_size; + + tech_pvt->alsa_buffer_size = tech_pvt->alsa_period_size * tech_pvt->alsa_periods_in_buffer; + + err = snd_pcm_hw_params_set_buffer_size_near(handle, params, &tech_pvt->alsa_buffer_size); + + if (err < 0) { + ERRORA("Error setting buffer_size: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } +#endif + + err = snd_pcm_hw_params(handle, params); + if (err < 0) { + ERRORA("Unable to install hw params: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + + snd_pcm_hw_params_get_period_size(params, &chunk_size, 0); + snd_pcm_hw_params_get_buffer_size(params, &buffer_size); + if (chunk_size == buffer_size) { + ERRORA("Can't use period equal to buffer size (%lu == %lu)\n", GSMOPEN_P_LOG, chunk_size, buffer_size); + return NULL; + } + + snd_pcm_sw_params_current(handle, swparams); + + /* + if (sleep_min) + xfer_align = 1; + err = snd_pcm_sw_params_set_sleep_min(handle, swparams, + 0); + + if (err < 0) { + ERRORA("Error setting slep_min: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + } + */ + n = chunk_size; + err = snd_pcm_sw_params_set_avail_min(handle, swparams, n); + if (err < 0) { + ERRORA("Error setting avail_min: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + } + if (stream == SND_PCM_STREAM_CAPTURE) { + start_delay = 1; + } + if (start_delay <= 0) { + start_threshold = n + (snd_pcm_uframes_t) rate *start_delay / 1000000; + } else { + start_threshold = (snd_pcm_uframes_t) rate *start_delay / 1000000; + } + if (start_threshold < 1) + start_threshold = 1; + if (start_threshold > n) + start_threshold = n; + err = snd_pcm_sw_params_set_start_threshold(handle, swparams, start_threshold); + if (err < 0) { + ERRORA("Error setting start_threshold: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + } + + if (stop_delay <= 0) + stop_threshold = buffer_size + (snd_pcm_uframes_t) rate *stop_delay / 1000000; + else + stop_threshold = (snd_pcm_uframes_t) rate *stop_delay / 1000000; + + if (stream == SND_PCM_STREAM_CAPTURE) { + stop_threshold = -1; + } + + err = snd_pcm_sw_params_set_stop_threshold(handle, swparams, stop_threshold); + + if (err < 0) { + ERRORA("Error setting stop_threshold: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + } + + if (snd_pcm_sw_params(handle, swparams) < 0) { + ERRORA("Error installing software parameters: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + } + + err = snd_pcm_poll_descriptors_count(handle); + if (err <= 0) { + ERRORA("Unable to get a poll descriptors count, error is %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + + if (err != 1) { //number of poll descriptors + DEBUGA_GSMOPEN("Can't handle more than one device\n", GSMOPEN_P_LOG); + return NULL; + } + + err = snd_pcm_poll_descriptors(handle, &tech_pvt->pfd, err); + if (err != 1) { + ERRORA("snd_pcm_poll_descriptors failed, %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + DEBUGA_GSMOPEN("Acquired fd %d from the poll descriptor\n", GSMOPEN_P_LOG, tech_pvt->pfd.fd); + + if (stream == SND_PCM_STREAM_CAPTURE) { + tech_pvt->gsmopen_sound_capt_fd = tech_pvt->pfd.fd; + } + + state = snd_pcm_state(handle); + + if (state != SND_PCM_STATE_RUNNING) { + if (state != SND_PCM_STATE_PREPARED) { + err = snd_pcm_prepare(handle); + if (err) { + ERRORA("snd_pcm_prepare failed, %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + DEBUGA_GSMOPEN("prepared!\n", GSMOPEN_P_LOG); + } + if (stream == SND_PCM_STREAM_CAPTURE) { + err = snd_pcm_start(handle); + if (err) { + ERRORA("snd_pcm_start failed, %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + return NULL; + } + DEBUGA_GSMOPEN("started!\n", GSMOPEN_P_LOG); + } + } + if (option_debug > 1) { + snd_output_t *output = NULL; + err = snd_output_stdio_attach(&output, stdout, 0); + if (err < 0) { + ERRORA("snd_output_stdio_attach failed: %s\n", GSMOPEN_P_LOG, snd_strerror(err)); + } + snd_pcm_dump(handle, output); + +#ifndef NO_GSMLIB + SMSMessageRef sms; + char content2[1000]; + //sms = SMSMessage::decode("079194710167120004038571F1390099406180904480A0D41631067296EF7390383D07CD622E58CD95CB81D6EF39BDEC66BFE7207A794E2FBB4320AFB82C07E56020A8FC7D9687DBED32285C9F83A06F769A9E5EB340D7B49C3E1FA3C3663A0B24E4CBE76516680A7FCBE920725A5E5ED341F0B21C346D4E41E1BA790E4286DDE4BC0BD42CA3E5207258EE1797E5A0BA9B5E9683C86539685997EBEF61341B249BC966"); // dataCodingScheme = 0 + //sms = SMSMessage::decode("0791934329002000040C9193432766658100009001211133318004D4F29C0E"); // dataCodingScheme = 0 + //sms = SMSMessage::decode("0791934329002000040C919343276665810008900121612521801600CC00E800E900F900F200E00020006300690061006F"); // dataCodingScheme = 8 + sms = SMSMessage::decode("0791934329002000040C919343276665810008900172002293404C006300690061006F0020003100320033002000620065006C00E80020043D043E0432043E044104420438002005DC05E7002005E805D005EA0020FE8EFEE0FEA0FEE4FECBFE9300204EBA5927"); // dataCodingScheme = 8 , text=ciao 123 belè новоÑти לק ר×ת ﺎﻠﺠﻤﻋﺓ 人大 + //sms = SMSMessage::decode("07911497941902F00414D0E474989D769F5DE4320839001040122151820000"); // dataCodingScheme = 0 + //NOTICA("SMS=\n%s\n", GSMOPEN_P_LOG, sms->toString().c_str()); + + memset(content2, '\0', sizeof(content2)); + if (sms->dataCodingScheme().getAlphabet() == DCS_DEFAULT_ALPHABET) { + iso_8859_1_to_utf8(tech_pvt, (char *) sms->userData().c_str(), content2, sizeof(content2)); + } else if (sms->dataCodingScheme().getAlphabet() == DCS_SIXTEEN_BIT_ALPHABET) { + ucs2_to_utf8(tech_pvt, (char *) bufToHex((unsigned char *) sms->userData().data(), sms->userData().length()).c_str(), content2, + sizeof(content2)); + } else { + ERRORA("dataCodingScheme not supported=%d\n", GSMOPEN_P_LOG, sms->dataCodingScheme().getAlphabet()); + + } + //NOTICA("dataCodingScheme=%d\n", GSMOPEN_P_LOG, sms->dataCodingScheme().getAlphabet()); + //NOTICA("userData= |||%s|||\n", GSMOPEN_P_LOG, content2); +#endif// NO_GSMLIB + + } + if (option_debug > 1) + DEBUGA_GSMOPEN("ALSA handle = %ld\n", GSMOPEN_P_LOG, (long int) handle); + return handle; + +} + +/*! \brief Write audio frames to interface */ +#endif /* GSMOPEN_ALSA */ + +int gsmopen_call(private_t * tech_pvt, char *rdest, int timeout) +{ + + //gsmopen_sleep(5000); + DEBUGA_GSMOPEN("Calling GSM, rdest is: %s\n", GSMOPEN_P_LOG, rdest); + //gsmopen_signaling_write(tech_pvt, "SET AGC OFF"); + //gsmopen_sleep(10000); + //gsmopen_signaling_write(tech_pvt, "SET AEC OFF"); + //gsmopen_sleep(10000); + + gsmopen_serial_call(tech_pvt, rdest); + //ERRORA("failed to communicate with GSM client, now exit\n", GSMOPEN_P_LOG); + //return -1; + //} + return 0; +} + + +int gsmopen_senddigit(private_t * tech_pvt, char digit) +{ + + DEBUGA_GSMOPEN("DIGIT received: %c\n", GSMOPEN_P_LOG, digit); + if (tech_pvt->controldevprotocol == PROTOCOL_AT && tech_pvt->at_send_dtmf[0]) { + int res = 0; + char at_command[256]; + + memset(at_command, '\0', 256); + sprintf(at_command, "%s=\"%c\"", tech_pvt->at_send_dtmf, digit); + res = gsmopen_serial_write_AT_ack(tech_pvt, at_command); + if (res) { + ERRORA("senddigit command failed, command used: '%s=\"%c\"', giving up\n", GSMOPEN_P_LOG, tech_pvt->at_send_dtmf, digit); + } + } + + return 0; +} + +#ifdef GSMOPEN_ALSA +/*! \brief Write audio frames to interface */ +int alsa_write(private_t * tech_pvt, short *data, int datalen) +{ + static char sizbuf[8000]; + static char sizbuf2[16000]; + static char silencebuf[8000]; + static int sizpos = 0; + int len = sizpos; + int pos; + int res = 0; + time_t now_timestamp; + /* size_t frames = 0; */ + snd_pcm_state_t state; + snd_pcm_sframes_t delayp1; + snd_pcm_sframes_t delayp2; + + if(tech_pvt->no_sound==1){ + return res; + } + //ERRORA("data=%p, datalen=%d\n", GSMOPEN_P_LOG, (void *)data, datalen); + /* We have to digest the frame in 160-byte portions */ + if (datalen > sizeof(sizbuf) - sizpos) { + ERRORA("Frame too large\n", GSMOPEN_P_LOG); + res = -1; + } else { + memcpy(sizbuf + sizpos, data, datalen); + len += datalen; + pos = 0; +#ifdef ALSA_MONITOR + alsa_monitor_write(sizbuf, len); +#endif + state = snd_pcm_state(tech_pvt->alsap); + if (state == SND_PCM_STATE_XRUN) { + int i; + + DEBUGA_GSMOPEN + ("You've got an ALSA write XRUN in the past (gsmopen can't fill the soundcard buffer fast enough). If this happens often (not after silence or after a pause in the speech, that's OK), and appear to damage the sound quality, first check if you have some IRQ problem, maybe sharing the soundcard IRQ with a broken or heavy loaded ethernet or graphic card. Then consider to increase the alsa_periods_in_buffer (now is set to %d) for this interface in the config file\n", + GSMOPEN_P_LOG, tech_pvt->alsa_periods_in_buffer); + res = snd_pcm_prepare(tech_pvt->alsap); + if (res) { + ERRORA("audio play prepare failed: %s\n", GSMOPEN_P_LOG, snd_strerror(res)); + } else { + res = snd_pcm_format_set_silence(gsmopen_format, silencebuf, len / 2); + if (res < 0) { + DEBUGA_GSMOPEN("Silence error %s\n", GSMOPEN_P_LOG, snd_strerror(res)); + res = -1; + } + for (i = 0; i < (tech_pvt->alsa_periods_in_buffer - 1); i++) { + res = snd_pcm_writei(tech_pvt->alsap, silencebuf, len / 2); + if (res != len / 2) { + DEBUGA_GSMOPEN("Write returned a different quantity: %d\n", GSMOPEN_P_LOG, res); + res = -1; + } else if (res < 0) { + DEBUGA_GSMOPEN("Write error %s\n", GSMOPEN_P_LOG, snd_strerror(res)); + res = -1; + } + } + } + + } + + res = snd_pcm_delay(tech_pvt->alsap, &delayp1); + if (res < 0) { + DEBUGA_GSMOPEN("Error %d on snd_pcm_delay: \"%s\"\n", GSMOPEN_P_LOG, res, snd_strerror(res)); + res = snd_pcm_prepare(tech_pvt->alsap); + if (res) { + DEBUGA_GSMOPEN("snd_pcm_prepare failed: '%s'\n", GSMOPEN_P_LOG, snd_strerror(res)); + } + res = snd_pcm_delay(tech_pvt->alsap, &delayp1); + } + + delayp2 = snd_pcm_avail_update(tech_pvt->alsap); + if (delayp2 < 0) { + DEBUGA_GSMOPEN("Error %d on snd_pcm_avail_update: \"%s\"\n", GSMOPEN_P_LOG, (int) delayp2, snd_strerror(delayp2)); + + res = snd_pcm_prepare(tech_pvt->alsap); + if (res) { + DEBUGA_GSMOPEN("snd_pcm_prepare failed: '%s'\n", GSMOPEN_P_LOG, snd_strerror(res)); + } + delayp2 = snd_pcm_avail_update(tech_pvt->alsap); + } + + if ( /* delayp1 != 0 && delayp1 != 160 */ + delayp1 < 160 || delayp2 > tech_pvt->alsa_buffer_size) { + + res = snd_pcm_prepare(tech_pvt->alsap); + if (res) { + DEBUGA_GSMOPEN + ("snd_pcm_prepare failed while trying to prevent an ALSA write XRUN: %s, delayp1=%d, delayp2=%d\n", + GSMOPEN_P_LOG, snd_strerror(res), (int) delayp1, (int) delayp2); + } else { + + int i; + for (i = 0; i < (tech_pvt->alsa_periods_in_buffer - 1); i++) { + res = snd_pcm_format_set_silence(gsmopen_format, silencebuf, len / 2); + if (res < 0) { + DEBUGA_GSMOPEN("Silence error %s\n", GSMOPEN_P_LOG, snd_strerror(res)); + res = -1; + } + res = snd_pcm_writei(tech_pvt->alsap, silencebuf, len / 2); + if (res < 0) { + DEBUGA_GSMOPEN("Write error %s\n", GSMOPEN_P_LOG, snd_strerror(res)); + res = -1; + } else if (res != len / 2) { + DEBUGA_GSMOPEN("Write returned a different quantity: %d\n", GSMOPEN_P_LOG, res); + res = -1; + } + } + + DEBUGA_GSMOPEN + ("PREVENTING an ALSA write XRUN (gsmopen can't fill the soundcard buffer fast enough). If this happens often (not after silence or after a pause in the speech, that's OK), and appear to damage the sound quality, first check if you have some IRQ problem, maybe sharing the soundcard IRQ with a broken or heavy loaded ethernet or graphic card. Then consider to increase the alsa_periods_in_buffer (now is set to %d) for this interface in the config file. delayp1=%d, delayp2=%d\n", + GSMOPEN_P_LOG, tech_pvt->alsa_periods_in_buffer, (int) delayp1, (int) delayp2); + } + + } + + memset(sizbuf2, 0, sizeof(sizbuf2)); + if (tech_pvt->alsa_play_is_mono) { + res = snd_pcm_writei(tech_pvt->alsap, sizbuf, len / 2); + } else { + int a = 0; + int i = 0; + for (i = 0; i < 8000;) { + sizbuf2[a] = sizbuf[i]; + a++; + i++; + sizbuf2[a] = sizbuf[i]; + a++; + i--; + sizbuf2[a] = sizbuf[i]; // comment out this line to use only left + a++; + i++; + sizbuf2[a] = sizbuf[i]; // comment out this line to use only left + a++; + i++; + } + res = snd_pcm_writei(tech_pvt->alsap, sizbuf2, len); + } + if (res == -EPIPE) { + DEBUGA_GSMOPEN + ("ALSA write EPIPE (XRUN) (gsmopen can't fill the soundcard buffer fast enough). If this happens often (not after silence or after a pause in the speech, that's OK), and appear to damage the sound quality, first check if you have some IRQ problem, maybe sharing the soundcard IRQ with a broken or heavy loaded ethernet or graphic card. Then consider to increase the alsa_periods_in_buffer (now is set to %d) for this interface in the config file. delayp1=%d, delayp2=%d\n", + GSMOPEN_P_LOG, tech_pvt->alsa_periods_in_buffer, (int) delayp1, (int) delayp2); + res = snd_pcm_prepare(tech_pvt->alsap); + if (res) { + ERRORA("audio play prepare failed: %s\n", GSMOPEN_P_LOG, snd_strerror(res)); + } else { + + if (tech_pvt->alsa_play_is_mono) { + res = snd_pcm_writei(tech_pvt->alsap, sizbuf, len / 2); + } else { + int a = 0; + int i = 0; + for (i = 0; i < 8000;) { + sizbuf2[a] = sizbuf[i]; + a++; + i++; + sizbuf2[a] = sizbuf[i]; + a++; + i--; + sizbuf2[a] = sizbuf[i]; + a++; + i++; + sizbuf2[a] = sizbuf[i]; + a++; + i++; + } + res = snd_pcm_writei(tech_pvt->alsap, sizbuf2, len); + } + + } + + } else { + if (res == -ESTRPIPE) { + ERRORA("You've got some big problems\n", GSMOPEN_P_LOG); + } else if (res == -EAGAIN) { + res = 0; + } else if (res < 0) { + ERRORA("Error %d on audio write: \"%s\"\n", GSMOPEN_P_LOG, res, snd_strerror(res)); + } + } + } + + if (tech_pvt->audio_play_reset_period) { + time(&now_timestamp); + if ((now_timestamp - tech_pvt->audio_play_reset_timestamp) > tech_pvt->audio_play_reset_period) { + if (option_debug) + DEBUGA_GSMOPEN("reset audio play\n", GSMOPEN_P_LOG); + res = snd_pcm_wait(tech_pvt->alsap, 1000); + if (res < 0) { + ERRORA("audio play wait failed: %s\n", GSMOPEN_P_LOG, snd_strerror(res)); + } + res = snd_pcm_drop(tech_pvt->alsap); + if (res) { + ERRORA("audio play drop failed: %s\n", GSMOPEN_P_LOG, snd_strerror(res)); + } + res = snd_pcm_prepare(tech_pvt->alsap); + if (res) { + ERRORA("audio play prepare failed: %s\n", GSMOPEN_P_LOG, snd_strerror(res)); + } + res = snd_pcm_wait(tech_pvt->alsap, 1000); + if (res < 0) { + ERRORA("audio play wait failed: %s\n", GSMOPEN_P_LOG, snd_strerror(res)); + } + time(&tech_pvt->audio_play_reset_timestamp); + } + } + //res = 0; + //if (res > 0) + //res = 0; + return res; +} + +#define AST_FRIENDLY_OFFSET 0 +int alsa_read(private_t * tech_pvt, short *data, int datalen) +{ + //static struct ast_frame f; + static short __buf[GSMOPEN_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2]; + static short __buf2[(GSMOPEN_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2) * 2]; + short *buf; + short *buf2; + static int readpos = 0; + //static int left = GSMOPEN_FRAME_SIZE; + static int left; + snd_pcm_state_t state; + int r = 0; + int off = 0; + int error = 0; + //time_t now_timestamp; + + //DEBUGA_GSMOPEN("buf=%p, datalen=%d, left=%d\n", GSMOPEN_P_LOG, (void *)buf, datalen, left); + //memset(&f, 0, sizeof(struct ast_frame)); //giova + + + + if(tech_pvt->no_sound==1){ + return r; + } + + left = datalen; + + + state = snd_pcm_state(tech_pvt->alsac); + if (state != SND_PCM_STATE_RUNNING) { + DEBUGA_GSMOPEN("ALSA read state is not SND_PCM_STATE_RUNNING\n", GSMOPEN_P_LOG); + + if (state != SND_PCM_STATE_PREPARED) { + error = snd_pcm_prepare(tech_pvt->alsac); + if (error) { + ERRORA("snd_pcm_prepare failed, %s\n", GSMOPEN_P_LOG, snd_strerror(error)); + return r; + } + DEBUGA_GSMOPEN("prepared!\n", GSMOPEN_P_LOG); + } + gsmopen_sleep(1000); + error = snd_pcm_start(tech_pvt->alsac); + if (error) { + ERRORA("snd_pcm_start failed, %s\n", GSMOPEN_P_LOG, snd_strerror(error)); + return r; + } + DEBUGA_GSMOPEN("started!\n", GSMOPEN_P_LOG); + gsmopen_sleep(1000); + } + + buf = __buf + AST_FRIENDLY_OFFSET / 2; + buf2 = __buf2 + ((AST_FRIENDLY_OFFSET / 2) * 2); + + if (tech_pvt->alsa_capture_is_mono) { + r = snd_pcm_readi(tech_pvt->alsac, buf + readpos, left); + //DEBUGA_GSMOPEN("r=%d, buf=%p, buf+readpos=%p, datalen=%d, left=%d\n", GSMOPEN_P_LOG, r, (void *)buf, (void *)(buf + readpos), datalen, left); + } else { + int a = 0; + int i = 0; + r = snd_pcm_readi(tech_pvt->alsac, buf2 + (readpos * 2), left); + + for (i = 0; i < (GSMOPEN_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2) * 2;) { + __buf[a] = (__buf2[i] + __buf2[i + 1]) / 2; //comment out this line to use only left + //__buf[a] = __buf2[i]; // enable this line to use only left + a++; + i++; + i++; + } + } + + if (r == -EPIPE) { + DEBUGA_GSMOPEN("ALSA XRUN on read\n", GSMOPEN_P_LOG); + return r; + } else if (r == -ESTRPIPE) { + ERRORA("-ESTRPIPE\n", GSMOPEN_P_LOG); + return r; + + } else if (r == -EAGAIN) { + DEBUGA_GSMOPEN("ALSA read -EAGAIN, the soundcard is not ready to be read by gsmopen\n", GSMOPEN_P_LOG); + while (r == -EAGAIN) { + gsmopen_sleep(1000); + + if (tech_pvt->alsa_capture_is_mono) { + r = snd_pcm_readi(tech_pvt->alsac, buf + readpos, left); + } else { + int a = 0; + int i = 0; + r = snd_pcm_readi(tech_pvt->alsac, buf2 + (readpos * 2), left); + + for (i = 0; i < (GSMOPEN_FRAME_SIZE + AST_FRIENDLY_OFFSET / 2) * 2;) { + __buf[a] = (__buf2[i] + __buf2[i + 1]) / 2; + a++; + i++; + i++; + } + } + + } + } else if (r < 0) { + WARNINGA("ALSA Read error: %s\n", GSMOPEN_P_LOG, snd_strerror(r)); + } else if (r >= 0) { + //DEBUGA_GSMOPEN("read: r=%d, readpos=%d, left=%d, off=%d\n", GSMOPEN_P_LOG, r, readpos, left, off); + off -= r; //what is the meaning of this? a leftover, probably + } + /* Update positions */ + readpos += r; + left -= r; + + if (readpos >= GSMOPEN_FRAME_SIZE) { + int i; + /* A real frame */ + readpos = 0; + left = GSMOPEN_FRAME_SIZE; + for (i = 0; i < r; i++) + data[i] = buf[i]; + + } + return r; +} + +#endif // GSMOPEN_ALSA + + + + + +int gsmopen_sendsms(private_t * tech_pvt, char *dest, char *text) +{ + //char *idest = data; + //char rdest[256]; + //private_t *p = NULL; + //char *device; + //char *dest; + //char *text; + //char *stringp = NULL; + //int found = 0; + int failed = 0; + int err = 0; + + //strncpy(rdest, idest, sizeof(rdest) - 1); + DEBUGA_GSMOPEN("GSMopenSendsms: dest=%s text=%s\n", GSMOPEN_P_LOG, dest, text); + DEBUGA_GSMOPEN("START\n", GSMOPEN_P_LOG); + /* we can use gsmopen_request to get the channel, but gsmopen_request would look for onowned channels, and probably we can send SMSs while a call is ongoing + * + */ + + if (tech_pvt->controldevprotocol != PROTOCOL_AT) { + ERRORA(", GSMOPEN_P_LOGGSMopenSendsms supports only AT command cellphones at the moment :-( !\n", GSMOPEN_P_LOG); + return RESULT_FAILURE; + } + + if (tech_pvt->controldevprotocol == PROTOCOL_AT) { + char smscommand[16000]; + memset(smscommand, '\0', sizeof(smscommand)); + + PUSHA_UNLOCKA(&tech_pvt->controldev_lock); + LOKKA(tech_pvt->controldev_lock); + + err = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CMGF=1"); + if (err) { + ERRORA("AT+CMGF=1 (set message sending to TEXT (as opposed to PDU) do not got OK from the phone\n", GSMOPEN_P_LOG); + } + + + if (tech_pvt->no_ucs2) { + sprintf(smscommand, "AT+CMGS=\"%s\"", dest); //TODO: support phones that only accept pdu mode + } else { + char dest2[1048]; + + err = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CSCS=\"UCS2\""); + if (err) { + ERRORA("AT+CSCS=\"UCS2\" (set TE messages to ucs2) do not got OK from the phone\n", GSMOPEN_P_LOG); + } + + memset(dest2, '\0', sizeof(dest2)); + utf_to_ucs2(tech_pvt, dest, strlen(dest), dest2, sizeof(dest2)); + sprintf(smscommand, "AT+CMGS=\"%s\"", dest2); //TODO: support phones that only accept pdu mode + } + //TODO: support phones that only accept pdu mode + //TODO would be better to lock controldev here + //sprintf(smscommand, "AT+CMGS=\"%s\"", dest); //FIXME: nokia e63 want this + err = gsmopen_serial_write_AT_noack(tech_pvt, smscommand); + if (err) { + ERRORA("Error sending SMS\n", GSMOPEN_P_LOG); + failed = 1; + goto uscita; + } + err = gsmopen_serial_AT_expect(tech_pvt, "> ", 0, 1); // wait 1.5s for the prompt, no crlf +#if 1 + if (err) { + DEBUGA_GSMOPEN + ("Error or timeout getting prompt '> ' for sending sms directly to the remote party. BTW, seems that we cannot do that with Motorola c350, so we'll write to cellphone memory, then send from memory\n", + GSMOPEN_P_LOG); + + err = gsmopen_serial_write_AT_ack(tech_pvt, "ATE1"); //motorola (at least c350) do not echo the '>' prompt when in ATE0... go figure!!!! + if (err) { + ERRORA("Error activating echo from modem\n", GSMOPEN_P_LOG); + } + tech_pvt->at_cmgw[0] = '\0'; + sprintf(smscommand, "AT+CMGW=\"%s\"", dest); //TODO: support phones that only accept pdu mode + err = gsmopen_serial_write_AT_noack(tech_pvt, smscommand); + if (err) { + ERRORA("Error writing SMS destination to the cellphone memory\n", GSMOPEN_P_LOG); + failed = 1; + goto uscita; + } + err = gsmopen_serial_AT_expect(tech_pvt, "> ", 0, 1); // wait 1.5s for the prompt, no crlf + if (err) { + ERRORA("Error or timeout getting prompt '> ' for writing sms text in cellphone memory\n", GSMOPEN_P_LOG); + failed = 1; + goto uscita; + } + } +#endif + + //sprintf(text,"ciao 123 belè новоÑти לק ר×ת ﺎﻠﺠﻤﻋﺓ 人大"); //let's test the beauty of utf + memset(smscommand, '\0', sizeof(smscommand)); + if (tech_pvt->no_ucs2) { + sprintf(smscommand, "%s", text); + } else { + utf_to_ucs2(tech_pvt, text, strlen(text), smscommand, sizeof(smscommand)); + } + + smscommand[strlen(smscommand)] = 0x1A; + DEBUGA_GSMOPEN("smscommand len is: %d, text is:|||%s|||\n", GSMOPEN_P_LOG, (int) strlen(smscommand), smscommand); + + err = gsmopen_serial_write_AT_ack_nocr_longtime(tech_pvt, smscommand); + //TODO would be better to unlock controldev here + if (err) { + ERRORA("Error writing SMS text to the cellphone memory\n", GSMOPEN_P_LOG); + //return RESULT_FAILURE; + failed = 1; + goto uscita; + } + if (tech_pvt->at_cmgw[0]) { + sprintf(smscommand, "AT+CMSS=%s", tech_pvt->at_cmgw); + err = gsmopen_serial_write_AT_expect_longtime(tech_pvt, smscommand, "OK"); + if (err) { + ERRORA("Error sending SMS from the cellphone memory\n", GSMOPEN_P_LOG); + //return RESULT_FAILURE; + failed = 1; + goto uscita; + } + + err = gsmopen_serial_write_AT_ack(tech_pvt, "ATE0"); //motorola (at least c350) do not echo the '>' prompt when in ATE0... go figure!!!! + if (err) { + ERRORA("Error de-activating echo from modem\n", GSMOPEN_P_LOG); + } + } + uscita: + gsmopen_sleep(1000); + + if (tech_pvt->at_cmgw[0]) { + + /* let's see what we've sent, just for check TODO: Motorola it's not reliable! Motorola c350 tells that all was sent, but is not true! It just sends how much it fits into one SMS FIXME: need an algorithm to calculate how many ucs2 chars fits into an SMS. It make difference based, probably, on the GSM alphabet translation, or so */ + sprintf(smscommand, "AT+CMGR=%s", tech_pvt->at_cmgw); + err = gsmopen_serial_write_AT_ack(tech_pvt, smscommand); + if (err) { + ERRORA("Error reading SMS back from the cellphone memory\n", GSMOPEN_P_LOG); + } + + /* let's delete from cellphone memory what we've sent */ + sprintf(smscommand, "AT+CMGD=%s", tech_pvt->at_cmgw); + err = gsmopen_serial_write_AT_ack(tech_pvt, smscommand); + if (err) { + ERRORA("Error deleting SMS from the cellphone memory\n", GSMOPEN_P_LOG); + } + + tech_pvt->at_cmgw[0] = '\0'; + } + //gsmopen_sleep(500000); //.5 secs + UNLOCKA(tech_pvt->controldev_lock); + POPPA_UNLOCKA(&tech_pvt->controldev_lock); + } + + err = gsmopen_serial_write_AT_ack(tech_pvt, "AT+CMGF=0"); + if (err) { + DEBUGA_GSMOPEN("AT+CMGF=0 (set message sending to PDU (as opposed to TEXT) do not got OK from the phone, continuing\n", GSMOPEN_P_LOG); + } + + + DEBUGA_GSMOPEN("FINISH\n", GSMOPEN_P_LOG); + if (failed) + return -1; + else + return RESULT_SUCCESS; +} + +/************************************************/ + +/* LUIGI RIZZO's magic */ +/* boost support. BOOST_SCALE * 10 ^(BOOST_MAX/20) must + * be representable in 16 bits to avoid overflows. + */ +#define BOOST_SCALE (1<<9) +#define BOOST_MAX 40 /* slightly less than 7 bits */ + +/* + * store the boost factor + */ +void gsmopen_store_boost(char *s, double *boost) +{ + private_t *tech_pvt = NULL; + + if (sscanf(s, "%lf", boost) != 1) { + ERRORA("invalid boost <%s>\n", GSMOPEN_P_LOG, s); + return; + } + if (*boost < -BOOST_MAX) { + WARNINGA("boost %s too small, using %d\n", GSMOPEN_P_LOG, s, -BOOST_MAX); + *boost = -BOOST_MAX; + } else if (*boost > BOOST_MAX) { + WARNINGA("boost %s too large, using %d\n", GSMOPEN_P_LOG, s, BOOST_MAX); + *boost = BOOST_MAX; + } +#ifdef WIN32 + *boost = exp(log ((double)10) * *boost / 20) * BOOST_SCALE; +#else + *boost = exp(log(10) * *boost / 20) * BOOST_SCALE; +#endif //WIN32 + if (option_debug > 1) + DEBUGA_GSMOPEN("setting boost %s to %f\n", GSMOPEN_P_LOG, s, *boost); +} + + +int gsmopen_sound_boost(void *data, int samples_num, double boost) +{ +/* LUIGI RIZZO's magic */ + if (boost != 0 && (boost < 511 || boost > 513)) { /* scale and clip values */ + int i, x; + + int16_t *ptr = (int16_t *) data; + + for (i = 0; i < samples_num; i++) { + x = (int) (ptr[i] * boost) / BOOST_SCALE; + if (x > 32767) { + x = 32767; + } else if (x < -32768) { + x = -32768; + } + ptr[i] = x; + } + } else { + //printf("BOOST=%f\n", boost); + } + + return 0; +} + + +int gsmopen_serial_getstatus_AT(private_t * tech_pvt) +{ + int res; + private_t *p = tech_pvt; + +#if 0 + if (p->owner) { + if (p->owner->_state != AST_STATE_UP && p->owner->_state != AST_STATE_DOWN) { + DEBUGA_AT("No getstatus, we're neither UP nor DOWN\n", GSMOPEN_P_LOG); + return 0; + } + } +#endif + + + PUSHA_UNLOCKA(p->controldev_lock); + LOKKA(p->controldev_lock); + res = gsmopen_serial_write_AT_ack(p, "AT"); + if (res) { + ERRORA("AT was not acknowledged, continuing but maybe there is a problem\n", GSMOPEN_P_LOG); + } + gsmopen_sleep(1000); + + if (strlen(p->at_query_battchg)) { + res = gsmopen_serial_write_AT_expect(p, p->at_query_battchg, p->at_query_battchg_expect); + if (res) { + WARNINGA("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, p->at_query_battchg, p->at_query_battchg_expect); + } + gsmopen_sleep(1000); + } + + if (strlen(p->at_query_signal)) { + res = gsmopen_serial_write_AT_expect(p, p->at_query_signal, p->at_query_signal_expect); + if (res) { + WARNINGA("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, p->at_query_signal, p->at_query_signal_expect); + } + gsmopen_sleep(1000); + } + + if (!p->network_creg_not_supported) { + res = gsmopen_serial_write_AT_ack(p, "AT+CREG?"); + if (res) { + WARNINGA("%s does not get %s from the phone. Continuing.\n", GSMOPEN_P_LOG, "AT+CREG?", "OK"); + } + gsmopen_sleep(1000); + } + + //FIXME all the following commands in config! + + if (p->sms_cnmi_not_supported) { + res = gsmopen_serial_write_AT_ack(p, "AT+MMGL=\"HEADER ONLY\""); + if (res) { + WARNINGA + ("%s does not get %s from the phone. If your phone is not Motorola, please contact the gsmopen developers. Else, if your phone IS a Motorola, probably a long msg was incoming and ther first part was read and then deleted. The second part is now orphan. If you got this warning repeatedly, and you cannot correctly receive SMSs from this interface, please manually clean all messages (and the residual parts of them) from the cellphone/SIM. Continuing.\n", + GSMOPEN_P_LOG, "AT+MMGL=\"HEADER ONLY\"", "OK"); + } else { + gsmopen_sleep(1000); + if (p->unread_sms_msg_id) { + char at_command[256]; + + res = gsmopen_serial_write_AT_ack(p, "AT+CSCS=\"UCS2\""); + if (res) { + ERRORA("AT+CSCS=\"UCS2\" (set TE messages to ucs2) do not got OK from the phone\n", GSMOPEN_P_LOG); + memset(p->sms_message, 0, sizeof(p->sms_message)); + } + + memset(at_command, 0, sizeof(at_command)); + sprintf(at_command, "AT+CMGR=%d", p->unread_sms_msg_id); + memset(p->sms_message, 0, sizeof(p->sms_message)); + + p->reading_sms_msg = 1; + res = gsmopen_serial_write_AT_ack(p, at_command); + p->reading_sms_msg = 0; + if (res) { + ERRORA("AT+CMGR (read SMS) do not got OK from the phone, message sent was:|||%s|||\n", GSMOPEN_P_LOG, at_command); + } + res = gsmopen_serial_write_AT_ack(p, "AT+CSCS=\"GSM\""); + if (res) { + ERRORA("AT+CSCS=\"GSM\" (set TE messages to GSM) do not got OK from the phone\n", GSMOPEN_P_LOG); + } + memset(at_command, 0, sizeof(at_command)); + sprintf(at_command, "AT+CMGD=%d", p->unread_sms_msg_id); /* delete the message */ + p->unread_sms_msg_id = 0; + res = gsmopen_serial_write_AT_ack(p, at_command); + if (res) { + ERRORA("AT+CMGD (Delete SMS) do not got OK from the phone, message sent was:|||%s|||\n", GSMOPEN_P_LOG, at_command); + } + + if (strlen(p->sms_message)) { +#if 0 + + manager_event(EVENT_FLAG_SYSTEM, "GSMOPENincomingsms", "Interface: %s\r\nSMS_Message: %s\r\n", p->name, p->sms_message); + + if (strlen(p->sms_receiving_program)) { + int fd1[2]; + pid_t pid1; + char *arg1[] = { p->sms_receiving_program, (char *) NULL }; + int i; + + DEBUGA_AT("incoming SMS message:---%s---\n", GSMOPEN_P_LOG, p->sms_message); + pipe(fd1); + pid1 = fork(); + + if (pid1 == 0) { //child + int err; + + dup2(fd1[0], 0); // Connect stdin to pipe output + close(fd1[1]); // close input pipe side + setsid(); //session id + err = execvp(arg1[0], arg1); //exec our program, with stdin connected to pipe output + if (err) { + ERRORA + ("'sms_receiving_program' is set in config file to '%s', and it gave us back this error: %d, (%s). SMS received was:---%s---\n", + GSMOPEN_P_LOG, p->sms_receiving_program, err, strerror(errno), p->sms_message); + } + close(fd1[0]); // close output pipe side + } //starting here continue the parent + close(fd1[0]); // close output pipe side + // write the msg on the pipe input + for (i = 0; i < strlen(p->sms_message); i++) { + write(fd1[1], &p->sms_message[i], 1); + } + close(fd1[1]); // close pipe input, let our program know we've finished + } else { + ERRORA + ("got SMS incoming message, but 'sms_receiving_program' is not set in config file. SMS received was:---%s---\n", + GSMOPEN_P_LOG, p->sms_message); + } +#endif //0 + DEBUGA_GSMOPEN("got SMS incoming message. SMS received was:---%s---\n", GSMOPEN_P_LOG, p->sms_message); + } +#if 0 //is this one needed? maybe it can interrupt an incoming call that is just to announce itself + if (p->phone_callflow == CALLFLOW_CALL_IDLE && p->interface_state == AST_STATE_DOWN && p->owner == NULL) { + /* we're not in a call, neither calling */ + res = gsmopen_serial_write_AT_ack(p, "AT+CKPD=\"EEE\""); + if (res) { + ERRORA("AT+CKPD=\"EEE\" (cellphone screen back to user) do not got OK from the phone\n", GSMOPEN_P_LOG); + } + } +#endif + } + } + } + + UNLOCKA(p->controldev_lock); + POPPA_UNLOCKA(p->controldev_lock); + return 0; +} diff --git a/src/mod/endpoints/mod_gsmopen/mod_gsmopen.2008.vcproj b/src/mod/endpoints/mod_gsmopen/mod_gsmopen.2008.vcproj new file mode 100644 index 0000000000..edfccb09e5 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/mod_gsmopen.2008.vcproj @@ -0,0 +1,168 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/mod/endpoints/mod_gsmopen/mod_gsmopen.cpp b/src/mod/endpoints/mod_gsmopen/mod_gsmopen.cpp new file mode 100644 index 0000000000..02d031f289 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/mod_gsmopen.cpp @@ -0,0 +1,3421 @@ +/* + * FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application + * Copyright (C) 2005/2006, Anthony Minessale II + * + * Version: MPL 1.1 + * + * The contents of this file are subject to the Mozilla Public License Version + * 1.1 (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * http://www.mozilla.org/MPL/ + * + * Software distributed under the License is distributed on an "AS IS" basis, + * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License + * for the specific language governing rights and limitations under the + * License. + * + * The Original Code is FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application + * + * The Initial Developer of the Original Code is + * Anthony Minessale II + * Portions created by the Initial Developer are Copyright (C) + * the Initial Developer. All Rights Reserved. + * + * This module (mod_gsmopen) has been contributed by: + * + * Giovanni Maruzzelli (gmaruzz@gmail.com) + * + * + * Further Contributors: + * + * + * + * mod_gsmopen.c -- GSM compatible Endpoint Module + * + */ + +#include "gsmopen.h" + +#if 0 +#ifdef WIN32 +/***************/ +// from http://www.openasthra.com/c-tidbits/gettimeofday-function-for-windows/ + +#include + +#if defined(_MSC_VER) || defined(_MSC_EXTENSIONS) +#define DELTA_EPOCH_IN_MICROSECS 11644473600000000Ui64 +#else /* */ +#define DELTA_EPOCH_IN_MICROSECS 11644473600000000ULL +#endif /* */ +struct sk_timezone { + int tz_minuteswest; /* minutes W of Greenwich */ + int tz_dsttime; /* type of dst correction */ +}; +int gettimeofday(struct timeval *tv, struct sk_timezone *tz) +{ + FILETIME ft; + unsigned __int64 tmpres = 0; + static int tzflag; + if (NULL != tv) { + GetSystemTimeAsFileTime(&ft); + tmpres |= ft.dwHighDateTime; + tmpres <<= 32; + tmpres |= ft.dwLowDateTime; + + /*converting file time to unix epoch */ + tmpres /= 10; /*convert into microseconds */ + tmpres -= DELTA_EPOCH_IN_MICROSECS; + tv->tv_sec = (long) (tmpres / 1000000UL); + tv->tv_usec = (long) (tmpres % 1000000UL); + } + if (NULL != tz) { + if (!tzflag) { + _tzset(); + tzflag++; + } + tz->tz_minuteswest = _timezone / 60; + tz->tz_dsttime = _daylight; + } + return 0; +} + +/***************/ +#endif /* WIN32 */ +#endif //0 +SWITCH_BEGIN_EXTERN_C +SWITCH_MODULE_LOAD_FUNCTION(mod_gsmopen_load); +SWITCH_MODULE_SHUTDOWN_FUNCTION(mod_gsmopen_shutdown); +SWITCH_MODULE_DEFINITION(mod_gsmopen, mod_gsmopen_load, mod_gsmopen_shutdown, NULL); +SWITCH_END_EXTERN_C +#define MDL_CHAT_PROTO "SMS" +#if 1 +SWITCH_STANDARD_API(gsm_function); +/* BEGIN: Changes here */ +#define GSM_SYNTAX "list [full] || console || AT_command || remove < interface_name | interface_id > || reload" +/* END: Changes heres */ +SWITCH_STANDARD_API(gsmopen_function); +#define GSMOPEN_SYNTAX "interface_name AT_command" +#endif //0 + +SWITCH_STANDARD_API(gsmopen_boost_audio_function); +#define GSMOPEN_BOOST_AUDIO_SYNTAX "interface_name [ ]" +SWITCH_STANDARD_API(sendsms_function); +#define SENDSMS_SYNTAX "gsmopen_sendsms interface_name destination_number SMS_text" +SWITCH_STANDARD_API(gsmopen_dump_function); +#define GSMOPEN_DUMP_SYNTAX "gsmopen_dump " +/* BEGIN: Changes here */ +#define FULL_RELOAD 0 +#define SOFT_RELOAD 1 +/* END: Changes heres */ + +const char *interface_status[] = { /* should match GSMOPEN_STATE_xxx in gsmopen.h */ + "IDLE", + "DOWN", + "RING", + "DIALING", + "BUSY", + "UP", + "RINGING", + "PRERING", + "DOUBLE", + "SELECTD", + "HANG_RQ", + "PREANSW" +}; +const char *phone_callflow[] = { /* should match CALLFLOW_XXX in gsmopen.h */ + "CALL_IDLE", + "CALL_DOWN", + "INCOMING_RNG", + "CALL_DIALING", + "CALL_LINEBUSY", + "CALL_ACTIVE", + "INCOMING_HNG", + "CALL_RLEASD", + "CALL_NOCARR", + "CALL_INFLUX", + "CALL_INCOMING", + "CALL_FAILED", + "CALL_NOSRVC", + "CALL_OUTRESTR", + "CALL_SECFAIL", + "CALL_NOANSWER", + "STATUS_FNSHED", + "STATUS_CANCLED", + "STATUS_FAILED", + "STATUS_REFUSED", + "STATUS_RINGING", + "STATUS_INPROGRS", + "STATUS_UNPLACD", + "STATUS_ROUTING", + "STATUS_EARLYMD", + "INCOMING_CLID", + "STATUS_RMTEHOLD" +}; + + +static struct { + int debug; + char *ip; + int port; + char *dialplan; + char *destination; + char *context; + char *codec_string; + char *codec_order[SWITCH_MAX_CODECS]; + int codec_order_last; + char *codec_rates_string; + char *codec_rates[SWITCH_MAX_CODECS]; + int codec_rates_last; + unsigned int flags; + int fd; + int calls; + int real_interfaces; + int next_interface; + char hold_music[256]; + private_t GSMOPEN_INTERFACES[GSMOPEN_MAX_INTERFACES]; + switch_mutex_t *mutex; + private_t *gsm_console; +} globals; + +switch_endpoint_interface_t *gsmopen_endpoint_interface; +switch_memory_pool_t *gsmopen_module_pool = NULL; +int running = 0; + +SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_dialplan, globals.dialplan); +SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_context, globals.context); +SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_destination, globals.destination); +//SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_codec_string, globals.codec_string); +//SWITCH_DECLARE_GLOBAL_STRING_FUNC(set_global_codec_rates_string, globals.codec_rates_string); + +/* BEGIN: Changes here */ +static switch_status_t interface_exists(char *the_interface); +#if 1 +static switch_status_t remove_interface(char *the_interface); +#endif //0 +/* END: Changes here */ + +static switch_status_t channel_on_init(switch_core_session_t *session); +static switch_status_t channel_on_hangup(switch_core_session_t *session); +static switch_status_t channel_on_destroy(switch_core_session_t *session); +static switch_status_t channel_on_routing(switch_core_session_t *session); +static switch_status_t channel_on_exchange_media(switch_core_session_t *session); +static switch_status_t channel_on_consume_media(switch_core_session_t *session); +static switch_status_t channel_on_soft_execute(switch_core_session_t *session); +static switch_call_cause_t channel_outgoing_channel(switch_core_session_t *session, + switch_event_t *var_event, + switch_caller_profile_t *outbound_profile, + switch_core_session_t **new_session, switch_memory_pool_t **pool, switch_originate_flag_t flags, + switch_call_cause_t *cancel_cause); +static switch_status_t channel_read_frame(switch_core_session_t *session, switch_frame_t **frame, switch_io_flag_t flags, int stream_id); +static switch_status_t channel_write_frame(switch_core_session_t *session, switch_frame_t *frame, switch_io_flag_t flags, int stream_id); +static switch_status_t channel_kill_channel(switch_core_session_t *session, int sig); +static switch_status_t gsmopen_tech_init(private_t * tech_pvt, switch_core_session_t *session); + +static switch_status_t gsmopen_codec(private_t * tech_pvt, int sample_rate, int codec_ms) +{ + switch_core_session_t *session = NULL; + + if (switch_core_codec_init + (&tech_pvt->read_codec, "L16", NULL, sample_rate, codec_ms, 1, + SWITCH_CODEC_FLAG_ENCODE | SWITCH_CODEC_FLAG_DECODE, NULL, NULL) != SWITCH_STATUS_SUCCESS) { + ERRORA("Can't load codec?\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_FALSE; + } + + if (switch_core_codec_init + (&tech_pvt->write_codec, "L16", NULL, sample_rate, codec_ms, 1, + SWITCH_CODEC_FLAG_ENCODE | SWITCH_CODEC_FLAG_DECODE, NULL, NULL) != SWITCH_STATUS_SUCCESS) { + ERRORA("Can't load codec?\n", GSMOPEN_P_LOG); + switch_core_codec_destroy(&tech_pvt->read_codec); + return SWITCH_STATUS_FALSE; + } + + tech_pvt->read_frame.rate = sample_rate; + tech_pvt->read_frame.codec = &tech_pvt->read_codec; + + session = switch_core_session_locate(tech_pvt->session_uuid_str); + + if (session) { + switch_core_session_set_read_codec(session, &tech_pvt->read_codec); + switch_core_session_set_write_codec(session, &tech_pvt->write_codec); + switch_core_session_rwunlock(session); + } else { + ERRORA("no session\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_FALSE; + } + + return SWITCH_STATUS_SUCCESS; + +} + +switch_status_t gsmopen_tech_init(private_t * tech_pvt, switch_core_session_t *session) +{ + +#ifdef WANT_SPEEX + int ciapa; + long level; + int tmp; +#endif// WANT_SPEEX + switch_assert(tech_pvt != NULL); + switch_assert(session != NULL); + tech_pvt->read_frame.data = tech_pvt->databuf; + tech_pvt->read_frame.buflen = sizeof(tech_pvt->databuf); + switch_mutex_init(&tech_pvt->mutex, SWITCH_MUTEX_NESTED, switch_core_session_get_pool(session)); + switch_mutex_init(&tech_pvt->flag_mutex, SWITCH_MUTEX_NESTED, switch_core_session_get_pool(session)); + switch_core_session_set_private(session, tech_pvt); + switch_copy_string(tech_pvt->session_uuid_str, switch_core_session_get_uuid(session), sizeof(tech_pvt->session_uuid_str)); + if (!strlen(tech_pvt->session_uuid_str)) { + ERRORA("no tech_pvt->session_uuid_str\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_FALSE; + } + if (gsmopen_codec(tech_pvt, SAMPLERATE_GSMOPEN, 20) != SWITCH_STATUS_SUCCESS) { + ERRORA("gsmopen_codec FAILED\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_FALSE; + } + //teletone_dtmf_detect_init(&tech_pvt->dtmf_detect, tech_pvt->read_codec.implementation->actual_samples_per_second); + //teletone_dtmf_detect_init(&tech_pvt->dtmf_detect, 8000); + dtmf_rx_init(&tech_pvt->dtmf_state, NULL, NULL); + dtmf_rx_parms(&tech_pvt->dtmf_state, 0, 10, 10, -99); + +#ifdef GSMOPEN_ALSA + if(tech_pvt->no_sound==0){ + if (alsa_init(tech_pvt)) { + ERRORA("alsa_init failed\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_FALSE; + + } + } +#endif// GSMOPEN_ALSA +#ifdef GSMOPEN_PORTAUDIO + if(tech_pvt->no_sound==0){ + if (gsmopen_portaudio_init(tech_pvt)) { + ERRORA("gsmopen_portaudio_init failed\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_FALSE; + + } + } +#endif// GSMOPEN_PORTAUDIO + + if (switch_core_timer_init(&tech_pvt->timer_read, "soft", 20, tech_pvt->read_codec.implementation->samples_per_packet, gsmopen_module_pool) != + SWITCH_STATUS_SUCCESS) { + ERRORA("setup timer failed\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_FALSE; + } + + switch_core_timer_sync(&tech_pvt->timer_read); + + if (switch_core_timer_init(&tech_pvt->timer_write, "soft", 20, tech_pvt->write_codec.implementation->samples_per_packet, gsmopen_module_pool) != + SWITCH_STATUS_SUCCESS) { + ERRORA("setup timer failed\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_FALSE; + } + + switch_core_timer_sync(&tech_pvt->timer_write); + +#ifdef WANT_SPEEX + /* Echo canceller with 100 ms tail length */ +#ifndef GIOVA48 + tech_pvt->echo_state = speex_echo_state_init(160, 1024); + ciapa = 8000; +#else// GIOVA48 + tech_pvt->echo_state = speex_echo_state_init(960, 4800); + ciapa = 48000; +#endif // GIOVA48 + speex_echo_ctl(tech_pvt->echo_state, SPEEX_ECHO_SET_SAMPLING_RATE, &ciapa); + +#if 1 //NO MORE + /* Setup preprocessor and associate with echo canceller for residual echo suppression */ +#ifndef GIOVA48 + tech_pvt->preprocess = speex_preprocess_state_init(160, 8000); +#else// GIOVA48 + tech_pvt->preprocess = speex_preprocess_state_init(960, 48000); +#endif // GIOVA48 + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_SET_ECHO_STATE, + tech_pvt->echo_state); + +#if 0 + /* Setup preprocessor various other goodies */ + tmp = 0; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_SET_AGC, &tmp); + //level=8000.1; + //speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_SET_AGC_LEVEL, &level); + + // Let's turn off all of the 'denoisers' (eg denoise and dereverb, and vad too) because they start automatic gain on mic input on cm108 usb, also if it (the agc on usb) disbled through mixer + tmp = 0; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_SET_DENOISE, &tmp); + tmp = 0; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_SET_DEREVERB, &tmp); + tmp = 0; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_SET_VAD, &tmp); +#endif + + tmp = 0; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_SET_DENOISE, &tmp); + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_AGC, &tmp); + fprintf(stderr, "AGC is: %d\n", tmp); + level = 1.0; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_AGC_LEVEL, &level); + fprintf(stderr, "AGC_LEVEL is: %f\n", level); + //tmp=1; + //speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_AGC_TARGET, &tmp); + //fprintf( stderr, "AGC_TARGET is: %d\n", tmp ); + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_DENOISE, &tmp); + fprintf(stderr, "DENOISE is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_DEREVERB, &tmp); + fprintf(stderr, "DEREVERB is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_VAD, &tmp); + fprintf(stderr, "VAD is: %d\n", tmp); + +#if 0 + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_NOISE_SUPPRESS, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_NOISE_SUPPRESS is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_ECHO_SUPPRESS, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_ECHO_SUPPRESS is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_ECHO_SUPPRESS_ACTIVE, + &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_ECHO_SUPPRESS_ACTIVE is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_AGC_MAX_GAIN, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_MAX_GAIN is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_AGC_INCREMENT, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_INCREMENT is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_AGC_DECREMENT, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_DECREMENT is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_PROB_START, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_PROB_START is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(tech_pvt->preprocess, SPEEX_PREPROCESS_GET_PROB_CONTINUE, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_PROB_CONTINUE is: %d\n", tmp); +#endif //0 +#endif// 0 //NO MORE + +#endif // WANT_SPEEX + + + + switch_clear_flag(tech_pvt, TFLAG_HANGUP); + DEBUGA_GSMOPEN("gsmopen_codec SUCCESS\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_SUCCESS; +} + +/* BEGIN: Changes here */ +static switch_status_t interface_exists(char *the_interface) +{ + int i; + int interface_id; + + if (*the_interface == '#') { /* look by interface id or interface name */ + the_interface++; + switch_assert(the_interface); + interface_id = atoi(the_interface); + + /* take a number as interface id */ + if (interface_id > 0 || (interface_id == 0 && strcmp(the_interface, "0") == 0)) { + if (strlen(globals.GSMOPEN_INTERFACES[interface_id].name)) { + return SWITCH_STATUS_SUCCESS; + } + } else { + /* interface name */ + for (interface_id = 0; interface_id < GSMOPEN_MAX_INTERFACES; interface_id++) { + if (strcmp(globals.GSMOPEN_INTERFACES[interface_id].name, the_interface) == 0) { + return SWITCH_STATUS_SUCCESS; + break; + } + } + } + } else { /* look by gsmopen_user */ + + + for (i = 0; i < GSMOPEN_MAX_INTERFACES; i++) { + if (strlen(globals.GSMOPEN_INTERFACES[i].gsmopen_user)) { + if (strcmp(globals.GSMOPEN_INTERFACES[i].gsmopen_user, the_interface) == 0) { + return SWITCH_STATUS_SUCCESS; + } + } + } + } + return SWITCH_STATUS_FALSE; +} + +#if 1 +static switch_status_t remove_interface(char *the_interface) +{ + int x = 10; + unsigned int howmany = 8; + int interface_id = -1; + private_t *tech_pvt = NULL; + switch_status_t status; + + //running = 0; + + + //XXX if (*the_interface == '#') { /* remove by interface id or interface name */ + //XXX the_interface++; + switch_assert(the_interface); + interface_id = atoi(the_interface); + + if (interface_id > 0 || (interface_id == 0 && strcmp(the_interface, "0") == 0)) { + /* take a number as interface id */ + tech_pvt = &globals.GSMOPEN_INTERFACES[interface_id]; + } else { + + for (interface_id = 0; interface_id < GSMOPEN_MAX_INTERFACES; interface_id++) { + if (strcmp(globals.GSMOPEN_INTERFACES[interface_id].name, the_interface) == 0) { + tech_pvt = &globals.GSMOPEN_INTERFACES[interface_id]; + break; + } + } + } + //XXX } //else { /* remove by gsmopen_user */ + //for (interface_id = 0; interface_id < GSMOPEN_MAX_INTERFACES; interface_id++) { + //if (strcmp(globals.GSMOPEN_INTERFACES[interface_id].gsmopen_user, the_interface) == 0) { + //tech_pvt = &globals.GSMOPEN_INTERFACES[interface_id]; + //break; + //} + //} + //} + + if (!tech_pvt) { + DEBUGA_GSMOPEN("interface '%s' does not exist\n", GSMOPEN_P_LOG, the_interface); + goto end; + } + + if (strlen(globals.GSMOPEN_INTERFACES[interface_id].session_uuid_str)) { + DEBUGA_GSMOPEN("interface '%s' is busy\n", GSMOPEN_P_LOG, the_interface); + goto end; + } + + globals.GSMOPEN_INTERFACES[interface_id].running = 0; + + if (globals.GSMOPEN_INTERFACES[interface_id].gsmopen_signaling_thread) { +#if 1 +#ifdef WIN32 + switch_file_write(tech_pvt->GSMopenHandles.fdesc[1], "sciutati", &howmany); // let's the controldev_thread die +#else /* WIN32 */ + howmany = write(tech_pvt->GSMopenHandles.fdesc[1], "sciutati", howmany); +#endif /* WIN32 */ +#endif //0 + DEBUGA_GSMOPEN("HERE will shutdown gsmopen_signaling_thread of '%s'\n", GSMOPEN_P_LOG, the_interface); + } + + if (globals.GSMOPEN_INTERFACES[interface_id].gsmopen_api_thread) { +#if 0 +#ifdef WIN32 + if (SendMessage(tech_pvt->GSMopenHandles.win32_hInit_MainWindowHandle, WM_DESTROY, 0, 0) == FALSE) { // let's the gsmopen_api_thread_func die + DEBUGA_GSMOPEN("got FALSE here, thread probably was already dead. GetLastError returned: %d\n", GSMOPEN_P_LOG, GetLastError()); + globals.GSMOPEN_INTERFACES[interface_id].gsmopen_api_thread = NULL; + } +#else + XEvent e; + Atom atom1 = XInternAtom(tech_pvt->GSMopenHandles.disp, "GSMOPENCONTROLAPI_MESSAGE_BEGIN", False); + memset(&e, 0, sizeof(e)); + e.xclient.type = ClientMessage; + e.xclient.message_type = atom1; /* leading message */ + e.xclient.display = tech_pvt->GSMopenHandles.disp; + e.xclient.window = tech_pvt->GSMopenHandles.gsmopen_win; + e.xclient.format = 8; + + XSendEvent(tech_pvt->GSMopenHandles.disp, tech_pvt->GSMopenHandles.win, False, 0, &e); + XSync(tech_pvt->GSMopenHandles.disp, False); +#endif //WIN32 +#endif //0 + + DEBUGA_GSMOPEN("HERE will shutdown gsmopen_api_thread of '%s'\n", GSMOPEN_P_LOG, the_interface); + } + + while (x) { + x--; + switch_yield(50000); + } + + if (globals.GSMOPEN_INTERFACES[interface_id].gsmopen_signaling_thread) { + switch_thread_join(&status, globals.GSMOPEN_INTERFACES[interface_id].gsmopen_signaling_thread); + } + + if (globals.GSMOPEN_INTERFACES[interface_id].gsmopen_api_thread) { + switch_thread_join(&status, globals.GSMOPEN_INTERFACES[interface_id].gsmopen_api_thread); + } + + switch_mutex_lock(globals.mutex); + if (globals.gsm_console == &globals.GSMOPEN_INTERFACES[interface_id]) { + DEBUGA_GSMOPEN("interface '%s' no more console\n", GSMOPEN_P_LOG, the_interface); + globals.gsm_console = NULL; + } else { + DEBUGA_GSMOPEN("interface '%s' STILL console\n", GSMOPEN_P_LOG, the_interface); + } + memset(&globals.GSMOPEN_INTERFACES[interface_id], '\0', sizeof(private_t)); + globals.real_interfaces--; + switch_mutex_unlock(globals.mutex); + + DEBUGA_GSMOPEN("interface '%s' deleted successfully\n", GSMOPEN_P_LOG, the_interface); + globals.GSMOPEN_INTERFACES[interface_id].running = 1; + end: + //running = 1; + return SWITCH_STATUS_SUCCESS; +} +#endif //0 + +/* END: Changes here */ + +/* + State methods they get called when the state changes to the specific state + returning SWITCH_STATUS_SUCCESS tells the core to execute the standard state method next + so if you fully implement the state you can return SWITCH_STATUS_FALSE to skip it. +*/ +static switch_status_t channel_on_init(switch_core_session_t *session) +{ + switch_channel_t *channel; + private_t *tech_pvt = NULL; + + tech_pvt = (private_t *) switch_core_session_get_private(session); + switch_assert(tech_pvt != NULL); + + channel = switch_core_session_get_channel(session); + switch_assert(channel != NULL); + //ERRORA("%s CHANNEL INIT\n", GSMOPEN_P_LOG, tech_pvt->name); + switch_set_flag(tech_pvt, TFLAG_IO); + + /* Move channel's state machine to ROUTING. This means the call is trying + to get from the initial start where the call because, to the point + where a destination has been identified. If the channel is simply + left in the initial state, nothing will happen. */ + switch_channel_set_state(channel, CS_ROUTING); + switch_mutex_lock(globals.mutex); + globals.calls++; + + switch_mutex_unlock(globals.mutex); + DEBUGA_GSMOPEN("%s CHANNEL INIT %s\n", GSMOPEN_P_LOG, tech_pvt->name, switch_core_session_get_uuid(session)); + + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t channel_on_destroy(switch_core_session_t *session) +{ + private_t *tech_pvt = NULL; + + tech_pvt = (private_t *) switch_core_session_get_private(session); + + + if (tech_pvt) { + DEBUGA_GSMOPEN("%s CHANNEL DESTROY %s\n", GSMOPEN_P_LOG, tech_pvt->name, switch_core_session_get_uuid(session)); + + if (switch_core_codec_ready(&tech_pvt->read_codec)) { + switch_core_codec_destroy(&tech_pvt->read_codec); + } + + if (switch_core_codec_ready(&tech_pvt->write_codec)) { + switch_core_codec_destroy(&tech_pvt->write_codec); + } + + switch_core_timer_destroy(&tech_pvt->timer_read); + switch_core_timer_destroy(&tech_pvt->timer_write); + +#ifdef GSMOPEN_ALSA + if(tech_pvt->no_sound==0){ + alsa_shutdown(tech_pvt); + } +#endif// GSMOPEN_ALSA +#ifdef GSMOPEN_PORTAUDIO + if(tech_pvt->no_sound==0){ + if (gsmopen_portaudio_shutdown(tech_pvt)) { + ERRORA("gsmopen_portaudio_shutdown failed\n", GSMOPEN_P_LOG); + + } + } +#endif// GSMOPEN_PORTAUDIO + + + *tech_pvt->session_uuid_str = '\0'; + tech_pvt->interface_state = GSMOPEN_STATE_IDLE; + if (tech_pvt->phone_callflow == CALLFLOW_STATUS_FINISHED) { + tech_pvt->phone_callflow = CALLFLOW_CALL_IDLE; + } + switch_core_session_set_private(session, NULL); + } else { + DEBUGA_GSMOPEN("!!!!!!NO tech_pvt!!!! CHANNEL DESTROY %s\n", GSMOPEN_P_LOG, switch_core_session_get_uuid(session)); + } + + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t channel_on_hangup(switch_core_session_t *session) +{ + switch_channel_t *channel = NULL; + private_t *tech_pvt = NULL; + + + channel = switch_core_session_get_channel(session); + switch_assert(channel != NULL); + + tech_pvt = (private_t *) switch_core_session_get_private(session); + switch_assert(tech_pvt != NULL); + + tech_pvt->phone_callflow = CALLFLOW_CALL_HANGUP_REQUESTED; + + if (!switch_channel_test_flag(channel, CF_ANSWERED)) { + if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) { + tech_pvt->ob_failed_calls++; + } else { + tech_pvt->ib_failed_calls++; + } + } + + + DEBUGA_GSMOPEN("%s CHANNEL HANGUP\n", GSMOPEN_P_LOG, tech_pvt->name); + switch_clear_flag(tech_pvt, TFLAG_IO); + switch_clear_flag(tech_pvt, TFLAG_VOICE); + switch_set_flag(tech_pvt, TFLAG_HANGUP); + + gsmopen_hangup(tech_pvt); + + //memset(tech_pvt->session_uuid_str, '\0', sizeof(tech_pvt->session_uuid_str)); + //*tech_pvt->session_uuid_str = '\0'; + DEBUGA_GSMOPEN("%s CHANNEL HANGUP\n", GSMOPEN_P_LOG, tech_pvt->name); + switch_mutex_lock(globals.mutex); + globals.calls--; + if (globals.calls < 0) { + globals.calls = 0; + } + + tech_pvt->interface_state = GSMOPEN_STATE_IDLE; + //FIXME if (tech_pvt->phone_callflow == CALLFLOW_STATUS_FINISHED) { + tech_pvt->phone_callflow = CALLFLOW_CALL_IDLE; + //FIXME } + switch_mutex_unlock(globals.mutex); + + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t channel_on_routing(switch_core_session_t *session) +{ + switch_channel_t *channel = NULL; + private_t *tech_pvt = NULL; + + channel = switch_core_session_get_channel(session); + switch_assert(channel != NULL); + + tech_pvt = (private_t *) switch_core_session_get_private(session); + switch_assert(tech_pvt != NULL); + + DEBUGA_GSMOPEN("%s CHANNEL ROUTING\n", GSMOPEN_P_LOG, tech_pvt->name); + + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t channel_on_execute(switch_core_session_t *session) +{ + + switch_channel_t *channel = NULL; + private_t *tech_pvt = NULL; + + channel = switch_core_session_get_channel(session); + switch_assert(channel != NULL); + + tech_pvt = (private_t *) switch_core_session_get_private(session); + switch_assert(tech_pvt != NULL); + + DEBUGA_GSMOPEN("%s CHANNEL EXECUTE\n", GSMOPEN_P_LOG, tech_pvt->name); + + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t channel_kill_channel(switch_core_session_t *session, int sig) +{ + switch_channel_t *channel = NULL; + private_t *tech_pvt = NULL; + + channel = switch_core_session_get_channel(session); + switch_assert(channel != NULL); + + tech_pvt = (private_t *) switch_core_session_get_private(session); + switch_assert(tech_pvt != NULL); + + DEBUGA_GSMOPEN("%s CHANNEL KILL_CHANNEL\n", GSMOPEN_P_LOG, tech_pvt->name); + switch (sig) { + case SWITCH_SIG_KILL: + DEBUGA_GSMOPEN("%s CHANNEL got SWITCH_SIG_KILL\n", GSMOPEN_P_LOG, switch_channel_get_name(channel)); + //switch_mutex_lock(tech_pvt->flag_mutex); + switch_clear_flag(tech_pvt, TFLAG_IO); + switch_clear_flag(tech_pvt, TFLAG_VOICE); + switch_set_flag(tech_pvt, TFLAG_HANGUP); + //switch_mutex_unlock(tech_pvt->flag_mutex); + break; + case SWITCH_SIG_BREAK: + DEBUGA_GSMOPEN("%s CHANNEL got SWITCH_SIG_BREAK\n", GSMOPEN_P_LOG, switch_channel_get_name(channel)); + //switch_set_flag(tech_pvt, TFLAG_BREAK); + //switch_mutex_lock(tech_pvt->flag_mutex); + switch_set_flag(tech_pvt, TFLAG_BREAK); + //switch_mutex_unlock(tech_pvt->flag_mutex); + break; + default: + break; + } + + return SWITCH_STATUS_SUCCESS; +} +static switch_status_t channel_on_consume_media(switch_core_session_t *session) +{ + private_t *tech_pvt = NULL; + + tech_pvt = (private_t *) switch_core_session_get_private(session); + + DEBUGA_GSMOPEN("%s CHANNEL CONSUME_MEDIA\n", GSMOPEN_P_LOG, tech_pvt->name); + return SWITCH_STATUS_SUCCESS; +} + + +static switch_status_t channel_on_exchange_media(switch_core_session_t *session) +{ + private_t *tech_pvt = NULL; + tech_pvt = (private_t *) switch_core_session_get_private(session); + DEBUGA_GSMOPEN("%s CHANNEL EXCHANGE_MEDIA\n", GSMOPEN_P_LOG, tech_pvt->name); + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t channel_on_soft_execute(switch_core_session_t *session) +{ + private_t *tech_pvt = NULL; + tech_pvt = (private_t *) switch_core_session_get_private(session); + DEBUGA_GSMOPEN("%s CHANNEL SOFT_EXECUTE\n", GSMOPEN_P_LOG, tech_pvt->name); + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t channel_send_dtmf(switch_core_session_t *session, const switch_dtmf_t *dtmf) +{ + private_t *tech_pvt = (private_t *) switch_core_session_get_private(session); + switch_assert(tech_pvt != NULL); + + DEBUGA_GSMOPEN("%s CHANNEL SEND_DTMF\n", GSMOPEN_P_LOG, tech_pvt->name); + DEBUGA_GSMOPEN("DTMF: %c\n", GSMOPEN_P_LOG, dtmf->digit); + + gsmopen_senddigit(tech_pvt, dtmf->digit); + + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t channel_read_frame(switch_core_session_t *session, switch_frame_t **frame, switch_io_flag_t flags, int stream_id) +{ + switch_channel_t *channel = NULL; + private_t *tech_pvt = NULL; + switch_byte_t *data; +#if defined(GSMOPEN_ALSA) || defined(GSMOPEN_PORTAUDIO) + int samples; + char digit_str[256]; +#endif // defined(GSMOPEN_ALSA) || defined(GSMOPEN_PORTAUDIO) +#ifdef GSMOPEN_PORTAUDIO +#ifdef WANT_SPEEX + spx_int16_t *speexptr; + spx_int16_t pcm2[160]; + int i; +#endif// GSMOPEN_ALSA +#endif// WANT_SPEEX + + + channel = switch_core_session_get_channel(session); + switch_assert(channel != NULL); + + tech_pvt = (private_t *) switch_core_session_get_private(session); + switch_assert(tech_pvt != NULL); + + if (!switch_channel_ready(channel) || !switch_test_flag(tech_pvt, TFLAG_IO)) { + ERRORA("channel not ready \n", GSMOPEN_P_LOG); + //TODO: kill the bastard + return SWITCH_STATUS_FALSE; + } + + + tech_pvt->read_frame.flags = SFF_NONE; + *frame = NULL; + + if (switch_test_flag(tech_pvt, TFLAG_HANGUP)) { + return SWITCH_STATUS_FALSE; + } + +#ifndef GSMOPEN_PORTAUDIO + switch_core_timer_next(&tech_pvt->timer_read); +#endif// GSMOPEN_PORTAUDIO + + if(tech_pvt->no_sound==1){ + goto cng; + } +#if defined(GSMOPEN_ALSA) || defined(GSMOPEN_PORTAUDIO) +#ifdef GSMOPEN_ALSA + //if ((samples = snd_pcm_readi(tech_pvt->alsac, tech_pvt->read_frame.data, tech_pvt->read_codec.implementation->samples_per_packet)) > 0) + if ((samples = alsa_read(tech_pvt, (short *) tech_pvt->read_frame.data, tech_pvt->read_codec.implementation->samples_per_packet)) > 0) +#endif// GSMOPEN_ALSA +#ifdef GSMOPEN_PORTAUDIO + if ((samples = gsmopen_portaudio_read(tech_pvt, (short *) tech_pvt->read_frame.data, tech_pvt->read_codec.implementation->samples_per_packet)) > 0) +#endif// GSMOPEN_PORTAUDIO + { + +#ifdef GSMOPEN_PORTAUDIO +#ifdef WANT_SPEEX + + if (tech_pvt->speexecho) { + speexptr = ((spx_int16_t *) tech_pvt->read_frame.data); + /* Perform echo cancellation */ + speex_echo_capture(tech_pvt->echo_state, speexptr, pcm2); +#ifndef GIOVA48 + for (i = 0; i < 160; i++) +#else //GIOVA48 + for (i = 0; i < 960; i++) +#endif //GIOVA48 + speexptr[i] = pcm2[i]; + } + /* Apply noise/echo residual suppression */ + if (tech_pvt->speexpreprocess) { + speex_preprocess_run(tech_pvt->preprocess, speexptr); + } + + DEBUGA_GSMOPEN("read\n", GSMOPEN_P_LOG); +#endif //WANT_SPEEX +#endif // GSMOPEN_PORTAUDIO + + + + + + tech_pvt->read_frame.datalen = samples * 2; + tech_pvt->read_frame.samples = samples; + +#ifndef GSMOPEN_PORTAUDIO + tech_pvt->read_frame.timestamp = tech_pvt->timer_read.samplecount; +#endif// GSMOPEN_PORTAUDIO + + *frame = &tech_pvt->read_frame; + + //status = SWITCH_STATUS_SUCCESS; + switch_set_flag(tech_pvt, TFLAG_VOICE); + } + + //WARNINGA("samples=%d\n", GSMOPEN_P_LOG, samples); + if (samples != 160) { + ERRORA("samples=%d\n", GSMOPEN_P_LOG, samples); + goto cng; + } +//DEBUGA_GSMOPEN("samples=%d tech_pvt->read_frame.timestamp=%d\n", GSMOPEN_P_LOG, samples, tech_pvt->read_frame.timestamp); + +//usleep(17000); +//usleep(17000); + + + + + + memset(digit_str, 0, sizeof(digit_str)); + //teletone_dtmf_detect(&tech_pvt->dtmf_detect, (int16_t *) tech_pvt->read_frame.data, tech_pvt->read_frame.samples); + //teletone_dtmf_get(&tech_pvt->dtmf_detect, digit_str, sizeof(digit_str)); + dtmf_rx(&tech_pvt->dtmf_state, (int16_t *) tech_pvt->read_frame.data, tech_pvt->read_frame.samples); + dtmf_rx_get(&tech_pvt->dtmf_state, digit_str, sizeof(digit_str)); + + gsmopen_sound_boost(tech_pvt->read_frame.data, tech_pvt->read_frame.samples, tech_pvt->capture_boost); + + if (digit_str[0]) { + switch_time_t new_dtmf_timestamp = switch_time_now(); + if ((new_dtmf_timestamp - tech_pvt->old_dtmf_timestamp) > 350000) { //FIXME: make it configurable + char *p = digit_str; + switch_channel_t *channel = switch_core_session_get_channel(session); + + while (p && *p) { + switch_dtmf_t dtmf; + dtmf.digit = *p; + dtmf.duration = SWITCH_DEFAULT_DTMF_DURATION; + switch_channel_queue_dtmf(channel, &dtmf); + p++; + } + NOTICA("DTMF DETECTED: [%s] new_dtmf_timestamp: %u, delta_t: %u\n", GSMOPEN_P_LOG, digit_str, (unsigned int) new_dtmf_timestamp, + (unsigned int) (new_dtmf_timestamp - tech_pvt->old_dtmf_timestamp)); + tech_pvt->old_dtmf_timestamp = new_dtmf_timestamp; + } + } + while (switch_test_flag(tech_pvt, TFLAG_IO)) { + if (switch_test_flag(tech_pvt, TFLAG_BREAK)) { + switch_clear_flag(tech_pvt, TFLAG_BREAK); + DEBUGA_GSMOPEN("CHANNEL READ FRAME goto CNG\n", GSMOPEN_P_LOG); + goto cng; + } + + if (!switch_test_flag(tech_pvt, TFLAG_IO)) { + DEBUGA_GSMOPEN("CHANNEL READ FRAME not IO\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_FALSE; + } + + if (switch_test_flag(tech_pvt, TFLAG_IO) && switch_test_flag(tech_pvt, TFLAG_VOICE)) { + switch_clear_flag(tech_pvt, TFLAG_VOICE); + if (!tech_pvt->read_frame.datalen) { + DEBUGA_GSMOPEN("CHANNEL READ CONTINUE\n", GSMOPEN_P_LOG); + continue; + } + *frame = &tech_pvt->read_frame; +#ifdef BIGENDIAN + if (switch_test_flag(tech_pvt, TFLAG_LINEAR)) { + switch_swap_linear((*frame)->data, (int) (*frame)->datalen / 2); + } +#endif + //WARNINGA("HERE\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_SUCCESS; + } + + WARNINGA("HERE\n", GSMOPEN_P_LOG); + DEBUGA_GSMOPEN("CHANNEL READ no TFLAG_VOICE\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_FALSE; + + } + + DEBUGA_GSMOPEN("CHANNEL READ FALSE\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_FALSE; +#endif // defined(GSMOPEN_ALSA) || defined(GSMOPEN_PORTAUDIO) + cng: + data = (switch_byte_t *) tech_pvt->read_frame.data; + data[0] = 65; + data[1] = 0; + tech_pvt->read_frame.datalen = 2; + tech_pvt->read_frame.flags = SFF_CNG; + *frame = &tech_pvt->read_frame; +#ifdef GSMOPEN_PORTAUDIO + //speex_echo_state_reset(tech_pvt->stream->echo_state); +#endif // GSMOPEN_PORTAUDIO + return SWITCH_STATUS_SUCCESS; + +} + +static switch_status_t channel_write_frame(switch_core_session_t *session, switch_frame_t *frame, switch_io_flag_t flags, int stream_id) +{ + switch_channel_t *channel = NULL; + private_t *tech_pvt = NULL; +#if defined(GSMOPEN_ALSA) || defined(GSMOPEN_PORTAUDIO) + unsigned int sent; +#endif // defined(GSMOPEN_ALSA) || defined(GSMOPEN_PORTAUDIO) +#ifdef GSMOPEN_PORTAUDIO +#ifdef WANT_SPEEX + spx_int16_t *speexptr; +#endif// GSMOPEN_ALSA +#endif// WANT_SPEEX + + channel = switch_core_session_get_channel(session); + switch_assert(channel != NULL); + + tech_pvt = (private_t *) switch_core_session_get_private(session); + switch_assert(tech_pvt != NULL); + + if (!switch_channel_ready(channel) || !switch_test_flag(tech_pvt, TFLAG_IO)) { + ERRORA("channel not ready \n", GSMOPEN_P_LOG); + //TODO: kill the bastard + return SWITCH_STATUS_FALSE; + } +#ifdef BIGENDIAN + if (switch_test_flag(tech_pvt, TFLAG_LINEAR)) { +#ifdef WIN32 + switch_swap_linear((int16_t *)frame->data, (int) frame->datalen / 2); +#else + switch_swap_linear(frame->data, (int) frame->datalen / 2); +#endif //WIN32 + } +#endif + + //switch_core_timer_next(&tech_pvt->timer_write); + //sent = frame->datalen; + + //ERRORA("PLAY \n", GSMOPEN_P_LOG); + //snd_pcm_writei(tech_pvt->alsap, (short *) frame->data, (int) (frame->datalen / 2)); + + gsmopen_sound_boost(frame->data, frame->samples, tech_pvt->playback_boost); +#ifdef GSMOPEN_ALSA + + switch_core_timer_next(&tech_pvt->timer_write); + sent = alsa_write(tech_pvt, (short *) frame->data, (int) (frame->datalen)); +//DEBUGA_GSMOPEN("sent=%d \n", GSMOPEN_P_LOG, sent); + + if (sent && sent != frame->datalen / 2 && sent != -1) { + DEBUGA_GSMOPEN("sent %d\n", GSMOPEN_P_LOG, sent); + } +#endif// GSMOPEN_ALSA +#ifdef GSMOPEN_PORTAUDIO + sent = gsmopen_portaudio_write(tech_pvt, (short *) frame->data, (int) (frame->datalen)); +//DEBUGA_GSMOPEN("sent=%d \n", GSMOPEN_P_LOG, sent); + + if (sent && sent != frame->datalen / 2 && sent != -1) { + DEBUGA_GSMOPEN("sent %d\n", GSMOPEN_P_LOG, sent); + } + +#ifdef WANT_SPEEX + if (tech_pvt->speexecho) { + speexptr = (spx_int16_t *) frame->data; + /* Put frame into playback buffer */ + speex_echo_playback(tech_pvt->echo_state, speexptr); + DEBUGA_GSMOPEN("write\n", GSMOPEN_P_LOG); + } +#endif //WANT_SPEEX +#endif // GSMOPEN_PORTAUDIO + //NOTICA("sent=%d\n", GSMOPEN_P_LOG, sent); + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t channel_answer_channel(switch_core_session_t *session) +{ + private_t *tech_pvt; + switch_channel_t *channel = NULL; + + channel = switch_core_session_get_channel(session); + switch_assert(channel != NULL); + + tech_pvt = (private_t *) switch_core_session_get_private(session); + switch_assert(tech_pvt != NULL); + + //ERRORA("%s CHANNEL INIT\n", GSMOPEN_P_LOG, tech_pvt->name); + switch_set_flag(tech_pvt, TFLAG_IO); + gsmopen_serial_answer(tech_pvt); + + /* Move channel's state machine to ROUTING. This means the call is trying + to get from the initial start where the call because, to the point + where a destination has been identified. If the channel is simply + left in the initial state, nothing will happen. */ + switch_channel_set_state(channel, CS_ROUTING); + switch_mutex_lock(globals.mutex); + globals.calls++; + + switch_mutex_unlock(globals.mutex); + DEBUGA_GSMOPEN("%s CHANNEL ANSWER %s\n", GSMOPEN_P_LOG, tech_pvt->name, switch_core_session_get_uuid(session)); + + + + + + + + + + + + + + + + + DEBUGA_GSMOPEN("ANSWERED! \n", GSMOPEN_P_LOG); + + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t channel_receive_message(switch_core_session_t *session, switch_core_session_message_t *msg) +{ + switch_channel_t *channel; + private_t *tech_pvt; +#if defined(GSMOPEN_ALSA) + int samples; + short tmp_buffer[1280]; +#endif // defined(GSMOPEN_ALSA) || defined(GSMOPEN_PORTAUDIO) + + channel = switch_core_session_get_channel(session); + switch_assert(channel != NULL); + + tech_pvt = (private_t *) switch_core_session_get_private(session); + switch_assert(tech_pvt != NULL); + + switch (msg->message_id) { + case SWITCH_MESSAGE_INDICATE_ANSWER: + { + DEBUGA_GSMOPEN("MSG_ID=%d, TO BE ANSWERED!\n", GSMOPEN_P_LOG, msg->message_id); + channel_answer_channel(session); + } + break; + case SWITCH_MESSAGE_INDICATE_AUDIO_SYNC: + + DEBUGA_GSMOPEN("%s CHANNEL got SWITCH_MESSAGE_INDICATE_AUDIO_SYNC\n", GSMOPEN_P_LOG, switch_channel_get_name(channel)); + switch_core_timer_sync(&tech_pvt->timer_read); + switch_core_timer_sync(&tech_pvt->timer_write); + +#ifdef GSMOPEN_ALSA + while ((samples = alsa_read(tech_pvt, tmp_buffer, tech_pvt->read_codec.implementation->samples_per_packet * 4)) > 160) { + //WARNINGA("read %d samples\n", GSMOPEN_P_LOG, samples); + } +#endif// GSMOPEN_ALSA +#ifdef GSMOPEN_PORTAUDIO + //while ((samples = gsmopen_portaudio_read(tech_pvt, tmp_buffer, tech_pvt->read_codec.implementation->samples_per_packet * 2)) > 160) { + //WARNINGA("read %d samples\n", GSMOPEN_P_LOG, samples); + //} +#ifdef WANT_SPEEX + speex_echo_state_reset(tech_pvt->echo_state); +#endif// WANT_SPEEX +#endif// GSMOPEN_PORTAUDIO + break; + + + default: + { + DEBUGA_GSMOPEN("MSG_ID=%d\n", GSMOPEN_P_LOG, msg->message_id); + } + break; + } + + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t channel_receive_event(switch_core_session_t *session, switch_event_t *event) +{ + struct private_object *tech_pvt = (struct private_object *) switch_core_session_get_private(session); + char *body = switch_event_get_body(event); + switch_assert(tech_pvt != NULL); + + if (!body) { + body = (char *) ""; + } + + WARNINGA("event: |||%s|||\n", GSMOPEN_P_LOG, body); + + return SWITCH_STATUS_SUCCESS; +} + +switch_state_handler_table_t gsmopen_state_handlers = { + /*.on_init */ channel_on_init, + /*.on_routing */ channel_on_routing, + /*.on_execute */ channel_on_execute, + /*.on_hangup */ channel_on_hangup, + /*.on_exchange_media */ channel_on_exchange_media, + /*.on_soft_execute */ channel_on_soft_execute, + /*.on_consume_media */ channel_on_consume_media, + /*.on_hibernate */ NULL, + /*.on_reset */ NULL, + /*.on_park */ NULL, + /*.on_reporting */ NULL, + /*.on_destroy */ channel_on_destroy +}; + +switch_io_routines_t gsmopen_io_routines = { + /*.outgoing_channel */ channel_outgoing_channel, + /*.read_frame */ channel_read_frame, + /*.write_frame */ channel_write_frame, + /*.kill_channel */ channel_kill_channel, + /*.send_dtmf */ channel_send_dtmf, + /*.receive_message */ channel_receive_message, + /*.receive_event */ channel_receive_event +}; + +static switch_call_cause_t channel_outgoing_channel(switch_core_session_t *session, + switch_event_t *var_event, + switch_caller_profile_t *outbound_profile, + switch_core_session_t **new_session, switch_memory_pool_t **pool, switch_originate_flag_t flags, + switch_call_cause_t *cancel_cause) +{ + private_t *tech_pvt = NULL; + if ((*new_session = switch_core_session_request(gsmopen_endpoint_interface, SWITCH_CALL_DIRECTION_OUTBOUND, pool)) != 0) { + switch_channel_t *channel = NULL; + switch_caller_profile_t *caller_profile; + char *rdest; + int found = 0; + char interface_name[256]; + + DEBUGA_GSMOPEN("1 SESSION_REQUEST %s\n", GSMOPEN_P_LOG, switch_core_session_get_uuid(*new_session)); + switch_core_session_add_stream(*new_session, NULL); + + + if (!zstr(outbound_profile->destination_number)) { + int i; + char *slash; + + switch_copy_string(interface_name, outbound_profile->destination_number, 255); + slash = strrchr(interface_name, '/'); + *slash = '\0'; + + switch_mutex_lock(globals.mutex); + if (strncmp("ANY", interface_name, strlen(interface_name)) == 0 || strncmp("RR", interface_name, strlen(interface_name)) == 0) { + /* we've been asked for the "ANY" interface, let's find the first idle interface */ + //DEBUGA_GSMOPEN("Finding one available gsmopen interface\n", GSMOPEN_P_LOG); + //tech_pvt = find_available_gsmopen_interface(NULL); + //if (tech_pvt) + //found = 1; + //} else if (strncmp("RR", interface_name, strlen(interface_name)) == 0) { + /* Find the first idle interface using Round Robin */ + DEBUGA_GSMOPEN("Finding one available gsmopen interface RR\n", GSMOPEN_P_LOG); + tech_pvt = find_available_gsmopen_interface_rr(NULL); + if (tech_pvt) { + found = 1; + DEBUGA_GSMOPEN("FOUND one available gsmopen interface RR\n", GSMOPEN_P_LOG); + } + } + + for (i = 0; !found && i < GSMOPEN_MAX_INTERFACES; i++) { + /* we've been asked for a normal interface name, or we have not found idle interfaces to serve as the "ANY" interface */ + if (strlen(globals.GSMOPEN_INTERFACES[i].name) + && (strncmp(globals.GSMOPEN_INTERFACES[i].name, interface_name, strlen(interface_name)) == 0)) { + if (strlen(globals.GSMOPEN_INTERFACES[i].session_uuid_str)) { + DEBUGA_GSMOPEN + ("globals.GSMOPEN_INTERFACES[%d].name=|||%s||| session_uuid_str=|||%s||| is BUSY\n", + GSMOPEN_P_LOG, i, globals.GSMOPEN_INTERFACES[i].name, globals.GSMOPEN_INTERFACES[i].session_uuid_str); + DEBUGA_GSMOPEN("1 SESSION_DESTROY %s\n", GSMOPEN_P_LOG, switch_core_session_get_uuid(*new_session)); + switch_core_session_destroy(new_session); + switch_mutex_unlock(globals.mutex); + return SWITCH_CAUSE_NORMAL_CIRCUIT_CONGESTION; + } + + DEBUGA_GSMOPEN("globals.GSMOPEN_INTERFACES[%d].name=|||%s|||?\n", GSMOPEN_P_LOG, i, globals.GSMOPEN_INTERFACES[i].name); + tech_pvt = &globals.GSMOPEN_INTERFACES[i]; + found = 1; + break; + } + + } + + } else { + ERRORA("Doh! no destination number?\n", GSMOPEN_P_LOG); + switch_core_session_destroy(new_session); + return SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER; + } + + if (!found) { + DEBUGA_GSMOPEN("Doh! no available interface for |||%s|||?\n", GSMOPEN_P_LOG, interface_name); + DEBUGA_GSMOPEN("2 SESSION_DESTROY %s\n", GSMOPEN_P_LOG, switch_core_session_get_uuid(*new_session)); + switch_core_session_destroy(new_session); + switch_mutex_unlock(globals.mutex); + //return SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER; + return SWITCH_CAUSE_NORMAL_CIRCUIT_CONGESTION; + } + + channel = switch_core_session_get_channel(*new_session); + if (!channel) { + ERRORA("Doh! no channel?\n", GSMOPEN_P_LOG); + switch_core_session_destroy(new_session); + switch_mutex_unlock(globals.mutex); + return SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER; + } + if (gsmopen_tech_init(tech_pvt, *new_session) != SWITCH_STATUS_SUCCESS) { + ERRORA("Doh! no tech_init?\n", GSMOPEN_P_LOG); + switch_core_session_destroy(new_session); + switch_mutex_unlock(globals.mutex); + return SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER; + } + + + if (outbound_profile) { + char name[128]; + + snprintf(name, sizeof(name), "gsmopen/%s", outbound_profile->destination_number); + //snprintf(name, sizeof(name), "gsmopen/%s", tech_pvt->name); + switch_channel_set_name(channel, name); + caller_profile = switch_caller_profile_clone(*new_session, outbound_profile); + switch_channel_set_caller_profile(channel, caller_profile); + tech_pvt->caller_profile = caller_profile; + } else { + ERRORA("Doh! no caller profile\n", GSMOPEN_P_LOG); + switch_core_session_destroy(new_session); + switch_mutex_unlock(globals.mutex); + return SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER; + } + + tech_pvt->ob_calls++; + + rdest = strchr(caller_profile->destination_number, '/'); + *rdest++ = '\0'; + + //gsmopen_call(tech_pvt, rdest, 30); + + switch_copy_string(tech_pvt->session_uuid_str, switch_core_session_get_uuid(*new_session), sizeof(tech_pvt->session_uuid_str)); + caller_profile = tech_pvt->caller_profile; + caller_profile->destination_number = rdest; + + switch_channel_set_flag(channel, CF_OUTBOUND); + switch_set_flag(tech_pvt, TFLAG_OUTBOUND); + switch_channel_set_state(channel, CS_INIT); + gsmopen_call(tech_pvt, rdest, 30); + switch_mutex_unlock(globals.mutex); + return SWITCH_CAUSE_SUCCESS; + } + + ERRORA("Doh! no new_session\n", GSMOPEN_P_LOG); + return SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER; +} + +/*! + * \brief This thread runs during a call, and monitor the interface for signaling, like hangup, caller id, etc most of signaling is handled inside the gsmopen_signaling_read function + * + */ + +static switch_status_t load_config(int reload_type) +{ + const char *cf = "gsmopen.conf"; + switch_xml_t cfg, xml, global_settings, param, interfaces, myinterface; + private_t *tech_pvt = NULL; + + switch_mutex_init(&globals.mutex, SWITCH_MUTEX_NESTED, gsmopen_module_pool); + if (!(xml = switch_xml_open_cfg(cf, &cfg, NULL))) { + ERRORA("open of %s failed\n", GSMOPEN_P_LOG, cf); + running = 0; + switch_xml_free(xml); + return SWITCH_STATUS_TERM; + } + + switch_mutex_lock(globals.mutex); + if ((global_settings = switch_xml_child(cfg, "global_settings"))) { + for (param = switch_xml_child(global_settings, "param"); param; param = param->next) { + char *var = (char *) switch_xml_attr_soft(param, "name"); + char *val = (char *) switch_xml_attr_soft(param, "value"); + + if (!strcasecmp(var, "debug")) { + DEBUGA_GSMOPEN("globals.debug=%d\n", GSMOPEN_P_LOG, globals.debug); + globals.debug = atoi(val); + DEBUGA_GSMOPEN("globals.debug=%d\n", GSMOPEN_P_LOG, globals.debug); + } else if (!strcasecmp(var, "hold-music")) { + switch_set_string(globals.hold_music, val); + DEBUGA_GSMOPEN("globals.hold_music=%s\n", GSMOPEN_P_LOG, globals.hold_music); + } else if (!strcmp(var, "dialplan")) { + set_global_dialplan(val); + DEBUGA_GSMOPEN("globals.dialplan=%s\n", GSMOPEN_P_LOG, globals.dialplan); + } else if (!strcmp(var, "destination")) { + set_global_destination(val); + DEBUGA_GSMOPEN("globals.destination=%s\n", GSMOPEN_P_LOG, globals.destination); + } else if (!strcmp(var, "context")) { + set_global_context(val); + DEBUGA_GSMOPEN("globals.context=%s\n", GSMOPEN_P_LOG, globals.context); + + } + + } + } + + if ((interfaces = switch_xml_child(cfg, "per_interface_settings"))) { + int i = 0; + + for (myinterface = switch_xml_child(interfaces, "interface"); myinterface; myinterface = myinterface->next) { + char *id = (char *) switch_xml_attr(myinterface, "id"); + char *name = (char *) switch_xml_attr(myinterface, "name"); + const char *context = "default"; + const char *dialplan = "XML"; + const char *destination = "5000"; + const char *controldevice_name = "/dev/ttyACM0"; + char *digit_timeout = NULL; + char *max_digits = NULL; + char *hotline = NULL; + char *dial_regex = NULL; + char *hold_music = NULL; + char *fail_dial_regex = NULL; + const char *enable_callerid = "true"; + + + const char *at_dial_pre_number = "ATD"; + const char *at_dial_post_number = ";"; + const char *at_dial_expect = "OK"; + const char *at_hangup = "ATH"; + const char *at_hangup_expect = "OK"; + const char *at_answer = "ATA"; + const char *at_answer_expect = "OK"; + const char *at_send_dtmf = "AT+VTS"; + const char *at_preinit_1 = ""; + const char *at_preinit_1_expect = ""; + const char *at_preinit_2 = ""; + const char *at_preinit_2_expect = ""; + const char *at_preinit_3 = ""; + const char *at_preinit_3_expect = ""; + const char *at_preinit_4 = ""; + const char *at_preinit_4_expect = ""; + const char *at_preinit_5 = ""; + const char *at_preinit_5_expect = ""; + const char *at_postinit_1 = "at+cmic=0,9"; + const char *at_postinit_1_expect = "OK"; + const char *at_postinit_2 = "AT+CKPD=\"EEE\""; + const char *at_postinit_2_expect = "OK"; + const char *at_postinit_3 = "AT+CSSN=1,0"; + const char *at_postinit_3_expect = "OK"; + const char *at_postinit_4 = "at+sidet=0"; + const char *at_postinit_4_expect = "OK"; + const char *at_postinit_5 = "at+clvl=99"; + const char *at_postinit_5_expect = "OK"; + const char *at_query_battchg = "AT+CBC"; + const char *at_query_battchg_expect = "OK"; + const char *at_query_signal = "AT+CSQ"; + const char *at_query_signal_expect = "OK"; + const char *at_call_idle = "+MCST: 1"; + const char *at_call_incoming = "+MCST: 2"; + const char *at_call_active = "+CSSI: 7"; + const char *at_call_failed = "+MCST: 65"; + const char *at_call_calling = "+CSSI: 1"; + const char *at_indicator_noservice_string = "CIEV: 2;0"; + const char *at_indicator_nosignal_string = "CIEV: 5;0"; + const char *at_indicator_lowsignal_string = "CIEV: 5;1"; + const char *at_indicator_lowbattchg_string = "CIEV: 0;1"; + const char *at_indicator_nobattchg_string = "CIEV: 0;0"; + const char *at_indicator_callactive_string = "CIEV: 3;1"; + const char *at_indicator_nocallactive_string = "CIEV: 3;0"; + const char *at_indicator_nocallsetup_string = "CIEV: 6;0"; + const char *at_indicator_callsetupincoming_string = "CIEV: 6;1"; + const char *at_indicator_callsetupoutgoing_string = "CIEV: 6;2"; + const char *at_indicator_callsetupremoteringing_string = "CIEV: 6;3"; + //const char *sms_receiving_program = "/usr/local/bin/ciapalo"; + const char *alsacname = "plughw:1"; + const char *alsapname = "plughw:1"; + const char *at_early_audio = "0"; + const char *at_after_preinit_pause = "500000"; + const char *at_initial_pause = "500000"; + const char *at_has_clcc = "0"; + const char *at_has_ecam = "0"; + const char *alsa_period_size = "160"; + const char *alsa_periods_in_buffer = "4"; + const char *gsmopen_sound_rate = "8000"; + const char *alsa_play_is_mono = "1"; + const char *alsa_capture_is_mono = "1"; + const char *capture_boost = "5"; + const char *playback_boost = "10"; +#if defined(GSMOPEN_ALSA) || defined(GSMOPEN_PORTAUDIO) + const char *no_sound = "0"; +#else + const char *no_sound = "1"; +#endif // defined(GSMOPEN_ALSA) || defined(GSMOPEN_PORTAUDIO) + const char *portaudiocindex = "1"; + const char *portaudiopindex = "1"; + const char *speexecho = "1"; + const char *speexpreprocess = "1"; + + uint32_t interface_id = 0; +#ifdef WIN32 + int controldevice_speed = 115200; //FIXME TODO +#else + uint32_t controldevice_speed = B115200; //FIXME TODO +#endif //WIN32 + uint32_t controldevprotocol = PROTOCOL_AT; //FIXME TODO + uint32_t running = 1; //FIXME TODO + const char *gsmopen_serial_sync_period = "300"; //FIXME TODO + + + + tech_pvt = NULL; + + for (param = switch_xml_child(myinterface, "param"); param; param = param->next) { + char *var = (char *) switch_xml_attr_soft(param, "name"); + char *val = (char *) switch_xml_attr_soft(param, "value"); + + if (!strcasecmp(var, "id")) { + id = val; + } else if (!strcasecmp(var, "name")) { + name = val; + } else if (!strcasecmp(var, "context")) { + context = val; + } else if (!strcasecmp(var, "dialplan")) { + dialplan = val; + } else if (!strcasecmp(var, "destination")) { + destination = val; + } else if (!strcasecmp(var, "controldevice_name")) { + controldevice_name = val; + } else if (!strcasecmp(var, "digit_timeout")) { + digit_timeout = val; + } else if (!strcasecmp(var, "max_digits")) { + max_digits = val; + } else if (!strcasecmp(var, "hotline")) { + hotline = val; + } else if (!strcasecmp(var, "dial_regex")) { + dial_regex = val; + } else if (!strcasecmp(var, "hold_music")) { + hold_music = val; + } else if (!strcasecmp(var, "fail_dial_regex")) { + fail_dial_regex = val; + } else if (!strcasecmp(var, "enable_callerid")) { + enable_callerid = val; + } else if (!strcasecmp(var, "at_dial_pre_number")) { + at_dial_pre_number = val; + } else if (!strcasecmp(var, "at_dial_post_number")) { + at_dial_post_number = val; + } else if (!strcasecmp(var, "at_dial_expect")) { + at_dial_expect = val; + } else if (!strcasecmp(var, "at_hangup")) { + at_hangup = val; + } else if (!strcasecmp(var, "at_hangup_expect")) { + at_hangup_expect = val; + } else if (!strcasecmp(var, "at_answer")) { + at_answer = val; + } else if (!strcasecmp(var, "at_answer_expect")) { + at_answer_expect = val; + } else if (!strcasecmp(var, "at_send_dtmf")) { + at_send_dtmf = val; + } else if (!strcasecmp(var, "at_preinit_1")) { + at_preinit_1 = val; + } else if (!strcasecmp(var, "at_preinit_1_expect")) { + at_preinit_1_expect = val; + } else if (!strcasecmp(var, "at_preinit_2")) { + at_preinit_2 = val; + } else if (!strcasecmp(var, "at_preinit_2_expect")) { + at_preinit_2_expect = val; + } else if (!strcasecmp(var, "at_preinit_3")) { + at_preinit_3 = val; + } else if (!strcasecmp(var, "at_preinit_3_expect")) { + at_preinit_3_expect = val; + } else if (!strcasecmp(var, "at_preinit_4")) { + at_preinit_4 = val; + } else if (!strcasecmp(var, "at_preinit_4_expect")) { + at_preinit_4_expect = val; + } else if (!strcasecmp(var, "at_preinit_5")) { + at_preinit_5 = val; + } else if (!strcasecmp(var, "at_preinit_5_expect")) { + at_preinit_5_expect = val; + } else if (!strcasecmp(var, "at_postinit_1")) { + at_postinit_1 = val; + } else if (!strcasecmp(var, "at_postinit_1_expect")) { + at_postinit_1_expect = val; + } else if (!strcasecmp(var, "at_postinit_2")) { + at_postinit_2 = val; + } else if (!strcasecmp(var, "at_postinit_2_expect")) { + at_postinit_2_expect = val; + } else if (!strcasecmp(var, "at_postinit_3")) { + at_postinit_3 = val; + } else if (!strcasecmp(var, "at_postinit_3_expect")) { + at_postinit_3_expect = val; + } else if (!strcasecmp(var, "at_postinit_4")) { + at_postinit_4 = val; + } else if (!strcasecmp(var, "at_postinit_4_expect")) { + at_postinit_4_expect = val; + } else if (!strcasecmp(var, "at_postinit_5")) { + at_postinit_5 = val; + } else if (!strcasecmp(var, "at_postinit_5_expect")) { + at_postinit_5_expect = val; + } else if (!strcasecmp(var, "at_query_battchg")) { + at_query_battchg = val; + } else if (!strcasecmp(var, "at_query_battchg_expect")) { + at_query_battchg_expect = val; + } else if (!strcasecmp(var, "at_query_signal")) { + at_query_signal = val; + } else if (!strcasecmp(var, "at_query_signal_expect")) { + at_query_signal_expect = val; + } else if (!strcasecmp(var, "at_call_idle")) { + at_call_idle = val; + } else if (!strcasecmp(var, "at_call_incoming")) { + at_call_incoming = val; + } else if (!strcasecmp(var, "at_call_active")) { + at_call_active = val; + } else if (!strcasecmp(var, "at_call_failed")) { + at_call_failed = val; + } else if (!strcasecmp(var, "at_call_calling")) { + at_call_calling = val; + } else if (!strcasecmp(var, "at_indicator_noservice_string")) { + at_indicator_noservice_string = val; + } else if (!strcasecmp(var, "at_indicator_nosignal_string")) { + at_indicator_nosignal_string = val; + } else if (!strcasecmp(var, "at_indicator_lowsignal_string")) { + at_indicator_lowsignal_string = val; + } else if (!strcasecmp(var, "at_indicator_lowbattchg_string")) { + at_indicator_lowbattchg_string = val; + } else if (!strcasecmp(var, "at_indicator_nobattchg_string")) { + at_indicator_nobattchg_string = val; + } else if (!strcasecmp(var, "at_indicator_callactive_string")) { + at_indicator_callactive_string = val; + } else if (!strcasecmp(var, "at_indicator_nocallactive_string")) { + at_indicator_nocallactive_string = val; + } else if (!strcasecmp(var, "at_indicator_nocallsetup_string")) { + at_indicator_nocallsetup_string = val; + } else if (!strcasecmp(var, "at_indicator_callsetupincoming_string")) { + at_indicator_callsetupincoming_string = val; + } else if (!strcasecmp(var, "at_indicator_callsetupoutgoing_string")) { + at_indicator_callsetupoutgoing_string = val; + } else if (!strcasecmp(var, "at_indicator_callsetupremoteringing_string")) { + at_indicator_callsetupremoteringing_string = val; + //} else if (!strcasecmp(var, "sms_receiving_program")) { + //sms_receiving_program = val; + } else if (!strcasecmp(var, "alsacname")) { + alsacname = val; + } else if (!strcasecmp(var, "alsapname")) { + alsapname = val; + } else if (!strcasecmp(var, "portaudiocindex")) { + portaudiocindex = val; + } else if (!strcasecmp(var, "portaudiopindex")) { + portaudiopindex = val; + } else if (!strcasecmp(var, "speexecho")) { + speexecho = val; + } else if (!strcasecmp(var, "speexpreprocess")) { + speexpreprocess = val; + } else if (!strcasecmp(var, "at_early_audio")) { + at_early_audio = val; + } else if (!strcasecmp(var, "at_after_preinit_pause")) { + at_after_preinit_pause = val; + } else if (!strcasecmp(var, "at_initial_pause")) { + at_initial_pause = val; + } else if (!strcasecmp(var, "at_has_clcc")) { + at_has_clcc = val; + } else if (!strcasecmp(var, "at_has_ecam")) { + at_has_ecam = val; + } else if (!strcasecmp(var, "alsa_period_size")) { + alsa_period_size = val; + } else if (!strcasecmp(var, "alsa_periods_in_buffer")) { + alsa_periods_in_buffer = val; + } else if (!strcasecmp(var, "gsmopen_sound_rate")) { + gsmopen_sound_rate = val; + } else if (!strcasecmp(var, "alsa_play_is_mono")) { + alsa_play_is_mono = val; + } else if (!strcasecmp(var, "alsa_capture_is_mono")) { + alsa_capture_is_mono = val; + } else if (!strcasecmp(var, "capture_boost")) { + capture_boost = val; + } else if (!strcasecmp(var, "playback_boost")) { + playback_boost = val; + } else if (!strcasecmp(var, "no_sound")) { + no_sound = val; + } else if (!strcasecmp(var, "gsmopen_serial_sync_period")) { + gsmopen_serial_sync_period = val; + } + + + } + + /* BEGIN: Changes here */ + if (reload_type == SOFT_RELOAD) { + char the_interface[256]; + sprintf(the_interface, "#%s", name); + + if (interface_exists(the_interface) == SWITCH_STATUS_SUCCESS) { + continue; + } + } + /* END: Changes here */ + + if (!id) { + ERRORA("interface missing REQUIRED param 'id'\n", GSMOPEN_P_LOG); + continue; + } + + if (switch_is_number(id)) { + interface_id = atoi(id); + } else { + ERRORA("interface param 'id' MUST be a number, now id='%s'\n", GSMOPEN_P_LOG, id); + continue; + } + + if (!switch_is_number(at_early_audio)) { + ERRORA("interface param 'at_early_audio' MUST be a number, now at_early_audio='%s'\n", GSMOPEN_P_LOG, at_early_audio); + continue; + } + if (!switch_is_number(at_after_preinit_pause)) { + ERRORA("interface param 'at_after_preinit_pause' MUST be a number, now at_after_preinit_pause='%s'\n", GSMOPEN_P_LOG, + at_after_preinit_pause); + continue; + } + if (!switch_is_number(at_initial_pause)) { + ERRORA("interface param 'at_initial_pause' MUST be a number, now at_initial_pause='%s'\n", GSMOPEN_P_LOG, at_initial_pause); + continue; + } + if (!switch_is_number(at_has_clcc)) { + ERRORA("interface param 'at_has_clcc' MUST be a number, now at_has_clcc='%s'\n", GSMOPEN_P_LOG, at_has_clcc); + continue; + } + if (!switch_is_number(at_has_ecam)) { + ERRORA("interface param 'at_has_ecam' MUST be a number, now at_has_ecam='%s'\n", GSMOPEN_P_LOG, at_has_ecam); + continue; + } + if (!switch_is_number(alsa_period_size)) { + ERRORA("interface param 'alsa_period_size' MUST be a number, now alsa_period_size='%s'\n", GSMOPEN_P_LOG, alsa_period_size); + continue; + } + if (!switch_is_number(alsa_periods_in_buffer)) { + ERRORA("interface param 'alsa_periods_in_buffer' MUST be a number, now alsa_periods_in_buffer='%s'\n", GSMOPEN_P_LOG, + alsa_periods_in_buffer); + continue; + } + if (!switch_is_number(gsmopen_sound_rate)) { + ERRORA("interface param 'gsmopen_sound_rate' MUST be a number, now gsmopen_sound_rate='%s'\n", GSMOPEN_P_LOG, gsmopen_sound_rate); + continue; + } + if (!switch_is_number(alsa_play_is_mono)) { + ERRORA("interface param 'alsa_play_is_mono' MUST be a number, now alsa_play_is_mono='%s'\n", GSMOPEN_P_LOG, alsa_play_is_mono); + continue; + } + if (!switch_is_number(alsa_capture_is_mono)) { + ERRORA("interface param 'alsa_capture_is_mono' MUST be a number, now alsa_capture_is_mono='%s'\n", GSMOPEN_P_LOG, alsa_capture_is_mono); + continue; + } + if (!switch_is_number(capture_boost)) { + ERRORA("interface param 'capture_boost' MUST be a number, now capture_boost='%s'\n", GSMOPEN_P_LOG, capture_boost); + continue; + } + if (!switch_is_number(playback_boost)) { + ERRORA("interface param 'playback_boost' MUST be a number, now playback_boost='%s'\n", GSMOPEN_P_LOG, playback_boost); + continue; + } + if (!switch_is_number(no_sound)) { + ERRORA("interface param 'no_sound' MUST be a number, now no_sound='%s'\n", GSMOPEN_P_LOG, no_sound); + continue; + } + if (!switch_is_number(gsmopen_serial_sync_period)) { + ERRORA("interface param 'gsmopen_serial_sync_period' MUST be a number, now gsmopen_serial_sync_period='%s'\n", GSMOPEN_P_LOG, gsmopen_serial_sync_period); + continue; + } + + + if (interface_id && interface_id < GSMOPEN_MAX_INTERFACES) { + private_t newconf; + switch_threadattr_t *gsmopen_api_thread_attr = NULL; + int res = 0; + + memset(&newconf, '\0', sizeof(newconf)); + globals.GSMOPEN_INTERFACES[interface_id] = newconf; + + + tech_pvt = &globals.GSMOPEN_INTERFACES[interface_id]; + + switch_mutex_init(&globals.GSMOPEN_INTERFACES[interface_id].controldev_lock, SWITCH_MUTEX_NESTED, gsmopen_module_pool); + + + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].id, id); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].name, name); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].context, context); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].dialplan, dialplan); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].destination, destination); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].controldevice_name, controldevice_name); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].dial_regex, dial_regex); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].hold_music, hold_music); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].fail_dial_regex, fail_dial_regex); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_dial_pre_number, at_dial_pre_number); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_dial_post_number, at_dial_post_number); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_dial_expect, at_dial_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_hangup, at_hangup); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_hangup_expect, at_hangup_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_answer, at_answer); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_answer_expect, at_answer_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_send_dtmf, at_send_dtmf); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_preinit_1, at_preinit_1); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_preinit_1_expect, at_preinit_1_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_preinit_2, at_preinit_2); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_preinit_2_expect, at_preinit_2_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_preinit_3, at_preinit_3); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_preinit_3_expect, at_preinit_3_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_preinit_4, at_preinit_4); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_preinit_4_expect, at_preinit_4_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_preinit_5, at_preinit_5); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_preinit_5_expect, at_preinit_5_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_postinit_1, at_postinit_1); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_postinit_1_expect, at_postinit_1_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_postinit_2, at_postinit_2); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_postinit_2_expect, at_postinit_2_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_postinit_3, at_postinit_3); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_postinit_3_expect, at_postinit_3_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_postinit_4, at_postinit_4); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_postinit_4_expect, at_postinit_4_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_postinit_5, at_postinit_5); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_postinit_5_expect, at_postinit_5_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_query_battchg, at_query_battchg); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_query_battchg_expect, at_query_battchg_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_query_signal, at_query_signal); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_query_signal_expect, at_query_signal_expect); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_call_idle, at_call_idle); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_call_incoming, at_call_incoming); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_call_active, at_call_active); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_call_failed, at_call_failed); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_call_calling, at_call_calling); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_indicator_noservice_string, at_indicator_noservice_string); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_indicator_nosignal_string, at_indicator_nosignal_string); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_indicator_lowsignal_string, at_indicator_lowsignal_string); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_indicator_lowbattchg_string, at_indicator_lowbattchg_string); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_indicator_nobattchg_string, at_indicator_nobattchg_string); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_indicator_callactive_string, at_indicator_callactive_string); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_indicator_nocallactive_string, at_indicator_nocallactive_string); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_indicator_nocallsetup_string, at_indicator_nocallsetup_string); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_indicator_callsetupincoming_string, at_indicator_callsetupincoming_string); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_indicator_callsetupoutgoing_string, at_indicator_callsetupoutgoing_string); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].at_indicator_callsetupremoteringing_string, + at_indicator_callsetupremoteringing_string); + //switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].sms_receiving_program, sms_receiving_program); +#ifdef GSMOPEN_ALSA + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].alsacname, alsacname); + switch_set_string(globals.GSMOPEN_INTERFACES[interface_id].alsapname, alsapname); +#endif// GSMOPEN_ALSA + +#ifdef GSMOPEN_PORTAUDIO + globals.GSMOPEN_INTERFACES[interface_id].portaudiocindex = atoi(portaudiocindex); + globals.GSMOPEN_INTERFACES[interface_id].portaudiopindex = atoi(portaudiopindex); + globals.GSMOPEN_INTERFACES[interface_id].speexecho = atoi(speexecho); + globals.GSMOPEN_INTERFACES[interface_id].speexpreprocess = atoi(speexpreprocess); +#endif// GSMOPEN_PORTAUDIO + globals.GSMOPEN_INTERFACES[interface_id].at_early_audio = atoi(at_early_audio); + globals.GSMOPEN_INTERFACES[interface_id].at_after_preinit_pause = atoi(at_after_preinit_pause); + globals.GSMOPEN_INTERFACES[interface_id].at_initial_pause = atoi(at_initial_pause); + globals.GSMOPEN_INTERFACES[interface_id].at_has_clcc = atoi(at_has_clcc); + globals.GSMOPEN_INTERFACES[interface_id].at_has_ecam = atoi(at_has_ecam); +#ifdef GSMOPEN_ALSA + globals.GSMOPEN_INTERFACES[interface_id].alsa_period_size = atoi(alsa_period_size); + globals.GSMOPEN_INTERFACES[interface_id].alsa_periods_in_buffer = atoi(alsa_periods_in_buffer); + globals.GSMOPEN_INTERFACES[interface_id].gsmopen_sound_rate = atoi(gsmopen_sound_rate); + globals.GSMOPEN_INTERFACES[interface_id].alsa_play_is_mono = atoi(alsa_play_is_mono); + globals.GSMOPEN_INTERFACES[interface_id].alsa_capture_is_mono = atoi(alsa_capture_is_mono); +#endif// GSMOPEN_ALSA + globals.GSMOPEN_INTERFACES[interface_id].capture_boost = atoi(capture_boost); + globals.GSMOPEN_INTERFACES[interface_id].playback_boost = atoi(playback_boost); +#if defined(GSMOPEN_ALSA) || defined(GSMOPEN_PORTAUDIO) + globals.GSMOPEN_INTERFACES[interface_id].no_sound = atoi(no_sound); +#else + globals.GSMOPEN_INTERFACES[interface_id].no_sound = 1; +#endif // defined(GSMOPEN_ALSA) || defined(GSMOPEN_PORTAUDIO) + globals.GSMOPEN_INTERFACES[interface_id].gsmopen_serial_sync_period = atoi(gsmopen_serial_sync_period); + + + + globals.GSMOPEN_INTERFACES[interface_id].controldevice_speed = controldevice_speed; //FIXME + globals.GSMOPEN_INTERFACES[interface_id].controldevprotocol = controldevprotocol; //FIXME + globals.GSMOPEN_INTERFACES[interface_id].running = running; //FIXME + + + + WARNINGA("STARTING interface_id=%d\n", GSMOPEN_P_LOG, interface_id); + DEBUGA_GSMOPEN("id=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].id); + DEBUGA_GSMOPEN("name=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].name); + DEBUGA_GSMOPEN("hold-music=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].hold_music); + DEBUGA_GSMOPEN("context=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].context); + DEBUGA_GSMOPEN("dialplan=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].dialplan); + DEBUGA_GSMOPEN("destination=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].destination); + DEBUGA_GSMOPEN("controldevice_name=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].controldevice_name); +#ifdef GSMOPEN_ALSA + DEBUGA_GSMOPEN("alsacname=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].alsacname); + DEBUGA_GSMOPEN("alsapname=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].alsapname); +#endif// GSMOPEN_ALSA + + +#ifdef GSMOPEN_PORTAUDIO + //FIXME + //globals.GSMOPEN_INTERFACES[interface_id].portaudiocindex = 1; + //globals.GSMOPEN_INTERFACES[interface_id].portaudiopindex = 1; + //globals.GSMOPEN_INTERFACES[interface_id].speexecho = 1; + //globals.GSMOPEN_INTERFACES[interface_id].speexpreprocess = 1; + DEBUGA_GSMOPEN("portaudiocindex=%d\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].portaudiocindex); + DEBUGA_GSMOPEN("portaudiocindex=%d\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].portaudiocindex); + DEBUGA_GSMOPEN("speexecho=%d\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].speexecho); + DEBUGA_GSMOPEN("speexpreprocess=%d\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[interface_id].speexpreprocess); +#endif// GSMOPEN_PORTAUDIO + DEBUGA_GSMOPEN("gsmopen_serial_sync_period=%d\n", GSMOPEN_P_LOG, (int)globals.GSMOPEN_INTERFACES[interface_id].gsmopen_serial_sync_period); + /* init the serial port */ + if (globals.GSMOPEN_INTERFACES[interface_id].controldevprotocol != PROTOCOL_NO_SERIAL) { + globals.GSMOPEN_INTERFACES[interface_id].controldevfd = + gsmopen_serial_init(&globals.GSMOPEN_INTERFACES[interface_id], globals.GSMOPEN_INTERFACES[interface_id].controldevice_speed); + if (globals.GSMOPEN_INTERFACES[interface_id].controldevfd == -1) { + ERRORA("gsmopen_serial_init failed\n", GSMOPEN_P_LOG); + ERRORA("STARTING interface_id=%d FAILED\n", GSMOPEN_P_LOG, interface_id); + //return SWITCH_STATUS_FALSE; + globals.GSMOPEN_INTERFACES[interface_id].running=0; + alarm_event(&globals.GSMOPEN_INTERFACES[interface_id], ALARM_FAILED_INTERFACE, "gsmopen_serial_init failed"); + globals.GSMOPEN_INTERFACES[interface_id].active=0; + globals.GSMOPEN_INTERFACES[interface_id].name[0]='\0'; + continue; + } + } + + /* config the phone/modem on the serial port */ + if (globals.GSMOPEN_INTERFACES[interface_id].controldevprotocol != PROTOCOL_NO_SERIAL) { + res = gsmopen_serial_config(&globals.GSMOPEN_INTERFACES[interface_id]); + if (res) { + ERRORA("gsmopen_serial_config failed\n", GSMOPEN_P_LOG); + ERRORA("STARTING interface_id=%d FAILED\n", GSMOPEN_P_LOG, interface_id); + //return SWITCH_STATUS_FALSE; + globals.GSMOPEN_INTERFACES[interface_id].running=0; + alarm_event(&globals.GSMOPEN_INTERFACES[interface_id], ALARM_FAILED_INTERFACE, "gsmopen_serial_config failed"); + globals.GSMOPEN_INTERFACES[interface_id].active=0; + globals.GSMOPEN_INTERFACES[interface_id].name[0]='\0'; + continue; + } + } + + if(globals.GSMOPEN_INTERFACES[interface_id].no_sound==0){ +#ifdef GSMOPEN_ALSA + if (alsa_init(&globals.GSMOPEN_INTERFACES[interface_id])) { + ERRORA("alsa_init failed\n", GSMOPEN_P_LOG); + ERRORA("STARTING interface_id=%d FAILED\n", GSMOPEN_P_LOG, interface_id); + //return SWITCH_STATUS_FALSE; + globals.GSMOPEN_INTERFACES[interface_id].running=0; + alarm_event(&globals.GSMOPEN_INTERFACES[interface_id], ALARM_FAILED_INTERFACE, "alsa_init failed"); + globals.GSMOPEN_INTERFACES[interface_id].active=0; + globals.GSMOPEN_INTERFACES[interface_id].name[0]='\0'; + continue; + + } + + if (alsa_shutdown(&globals.GSMOPEN_INTERFACES[interface_id])) { + ERRORA("alsa_shutdown failed\n", GSMOPEN_P_LOG); + ERRORA("STARTING interface_id=%d FAILED\n", GSMOPEN_P_LOG, interface_id); + //return SWITCH_STATUS_FALSE; + globals.GSMOPEN_INTERFACES[interface_id].running=0; + alarm_event(&globals.GSMOPEN_INTERFACES[interface_id], ALARM_FAILED_INTERFACE, "alsa_shutdown failed"); + globals.GSMOPEN_INTERFACES[interface_id].active=0; + globals.GSMOPEN_INTERFACES[interface_id].name[0]='\0'; + continue; + + } +#endif// GSMOPEN_ALSA +#ifdef GSMOPEN_PORTAUDIO + if (gsmopen_portaudio_init(&globals.GSMOPEN_INTERFACES[interface_id])) { + ERRORA("gsmopen_portaudio_init failed\n", GSMOPEN_P_LOG); + ERRORA("STARTING interface_id=%d FAILED\n", GSMOPEN_P_LOG, interface_id); + //return SWITCH_STATUS_FALSE; + globals.GSMOPEN_INTERFACES[interface_id].running=0; + alarm_event(&globals.GSMOPEN_INTERFACES[interface_id], ALARM_FAILED_INTERFACE, "gsmopen_portaudio_init failed"); + globals.GSMOPEN_INTERFACES[interface_id].active=0; + globals.GSMOPEN_INTERFACES[interface_id].name[0]='\0'; + continue; + + } + + if (gsmopen_portaudio_shutdown(&globals.GSMOPEN_INTERFACES[interface_id])) { + ERRORA("gsmopen_portaudio_shutdown failed\n", GSMOPEN_P_LOG); + ERRORA("STARTING interface_id=%d FAILED\n", GSMOPEN_P_LOG, interface_id); + //return SWITCH_STATUS_FALSE; + globals.GSMOPEN_INTERFACES[interface_id].running=0; + alarm_event(&globals.GSMOPEN_INTERFACES[interface_id], ALARM_FAILED_INTERFACE, "gsmopen_portaudio_shutdown failed"); + globals.GSMOPEN_INTERFACES[interface_id].active=0; + globals.GSMOPEN_INTERFACES[interface_id].name[0]='\0'; + continue; + + } +#endif// GSMOPEN_PORTAUDIO + } + + globals.GSMOPEN_INTERFACES[interface_id].active=1; + + //gsmopen_store_boost((char *)"5", &globals.GSMOPEN_INTERFACES[interface_id].capture_boost); //FIXME + //gsmopen_store_boost((char *)"10", &globals.GSMOPEN_INTERFACES[interface_id].playback_boost); //FIXME + gsmopen_store_boost((char *) capture_boost, &globals.GSMOPEN_INTERFACES[interface_id].capture_boost); //FIXME + gsmopen_store_boost((char *) playback_boost, &globals.GSMOPEN_INTERFACES[interface_id].playback_boost); //FIXME + + switch_sleep(100000); + switch_threadattr_create(&gsmopen_api_thread_attr, gsmopen_module_pool); + switch_threadattr_stacksize_set(gsmopen_api_thread_attr, SWITCH_THREAD_STACKSIZE); + switch_thread_create(&globals.GSMOPEN_INTERFACES[interface_id].gsmopen_api_thread, gsmopen_api_thread_attr, gsmopen_do_gsmopenapi_thread, + &globals.GSMOPEN_INTERFACES[interface_id], gsmopen_module_pool); + + switch_sleep(100000); + WARNINGA("STARTED interface_id=%d\n", GSMOPEN_P_LOG, interface_id); + + } else { + ERRORA("interface id %d is higher than GSMOPEN_MAX_INTERFACES (%d)\n", GSMOPEN_P_LOG, interface_id, GSMOPEN_MAX_INTERFACES); + alarm_event(&globals.GSMOPEN_INTERFACES[interface_id], ALARM_FAILED_INTERFACE, "interface id is higher than GSMOPEN_MAX_INTERFACES"); + continue; + } + + } + + for (i = 0; i < GSMOPEN_MAX_INTERFACES; i++) { + if (strlen(globals.GSMOPEN_INTERFACES[i].name)) { + /* How many real intterfaces */ + globals.real_interfaces = i + 1; + + tech_pvt = &globals.GSMOPEN_INTERFACES[i]; + + DEBUGA_GSMOPEN("id=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].id); + DEBUGA_GSMOPEN("name=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].name); + DEBUGA_GSMOPEN("context=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].context); + DEBUGA_GSMOPEN("hold-music=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].hold_music); + DEBUGA_GSMOPEN("dialplan=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].dialplan); + DEBUGA_GSMOPEN("destination=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].destination); + DEBUGA_GSMOPEN("controldevice_name=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].controldevice_name); +#ifdef GSMOPEN_ALSA + DEBUGA_GSMOPEN("alsacname=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].alsacname); + DEBUGA_GSMOPEN("alsapname=%s\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].alsapname); +#endif// GSMOPEN_ALSA +#ifdef GSMOPEN_PORTAUDIO + DEBUGA_GSMOPEN("portaudiocindex=%d\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].portaudiocindex); + DEBUGA_GSMOPEN("portaudiopindex=%d\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].portaudiopindex); + DEBUGA_GSMOPEN("speexecho=%d\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].speexecho); + DEBUGA_GSMOPEN("speexpreprocess=%d\n", GSMOPEN_P_LOG, globals.GSMOPEN_INTERFACES[i].speexpreprocess); +#endif// GSMOPEN_PORTAUDIO + DEBUGA_GSMOPEN("gsmopen_serial_sync_period=%d\n", GSMOPEN_P_LOG, (int)globals.GSMOPEN_INTERFACES[i].gsmopen_serial_sync_period); + + } + } + } + + switch_mutex_unlock(globals.mutex); + switch_xml_free(xml); + + return SWITCH_STATUS_SUCCESS; +} + +static switch_status_t chat_send(const char *proto, const char *from, const char *to, const char *subject, const char *body, const char *type, + const char *hint) +{ + char *user, *host, *f_user = NULL, *f_host = NULL, *f_resource = NULL; + private_t *tech_pvt = NULL; + int i = 0, found = 0; + + switch_assert(proto != NULL); + + DEBUGA_GSMOPEN("chat_send(proto=%s, from=%s, to=%s, subject=%s, body=%s, type=%s, hint=%s)\n", GSMOPEN_P_LOG, proto, from, to, subject, body, type, + hint ? hint : "NULL"); + + if (!to || !strlen(to)) { + ERRORA("Missing To: header.\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_SUCCESS; + } + + if ((!from && !hint) || (!strlen(from) && !strlen(hint))) { + ERRORA("Missing From: AND Hint: headers.\n", GSMOPEN_P_LOG); + return SWITCH_STATUS_SUCCESS; + } + + if (from && (f_user = strdup(from))) { + if ((f_host = strchr(f_user, '@'))) { + *f_host++ = '\0'; + if ((f_resource = strchr(f_host, '/'))) { + *f_resource++ = '\0'; + } + } + } + + if (!strlen(hint)) { //FIXME FIXME FIXME + hint = from; + } + if (to && (user = strdup(to))) { + if ((host = strchr(user, '@'))) { + *host++ = '\0'; + } + + DEBUGA_GSMOPEN("chat_send(proto=%s, from=%s, to=%s, subject=%s, body=%s, type=%s, hint=%s)\n", GSMOPEN_P_LOG, proto, from, to, subject, body, type, + hint ? hint : "NULL"); + if (hint && strlen(hint)) { + //in hint we receive the interface name to use + for (i = 0; !found && i < GSMOPEN_MAX_INTERFACES; i++) { + if (strlen(globals.GSMOPEN_INTERFACES[i].name) + && (strncmp(globals.GSMOPEN_INTERFACES[i].name, hint, strlen(hint)) == 0)) { + tech_pvt = &globals.GSMOPEN_INTERFACES[i]; + DEBUGA_GSMOPEN("Using interface: globals.GSMOPEN_INTERFACES[%d].name=|||%s|||\n", GSMOPEN_P_LOG, i, + globals.GSMOPEN_INTERFACES[i].name); + found = 1; + break; + } + } + } /* FIXME add a tech_pvt member for the SIM telephone number //else { + //we have no a predefined interface name to use (hint is NULL), so let's choose an interface from the username (from) + for (i = 0; !found && i < GSMOPEN_MAX_INTERFACES; i++) { + if (strlen(globals.GSMOPEN_INTERFACES[i].name) + && (strncmp(globals.GSMOPEN_INTERFACES[i].skype_user, from, strlen(from)) == 0)) { + tech_pvt = &globals.GSMOPEN_INTERFACES[i]; + DEBUGA_GSMOPEN("Using interface: globals.GSMOPEN_INTERFACES[%d].name=|||%s|||\n", GSMOPEN_P_LOG, i, globals.GSMOPEN_INTERFACES[i].name); + found = 1; + break; + } + } + } + */ + if (!found) { + ERRORA("ERROR: A GSMopen interface with name='%s' or one with SIM_number='%s' was not found\n", GSMOPEN_P_LOG, hint ? hint : "NULL", + from ? from : "NULL"); + goto end; + } else { + gsmopen_sendsms(tech_pvt, (char *) to, (char *) body); + } + } + end: + switch_safe_free(user); + switch_safe_free(f_user); + return SWITCH_STATUS_SUCCESS; +} + + +SWITCH_MODULE_LOAD_FUNCTION(mod_gsmopen_load) +{ + switch_api_interface_t *commands_api_interface; + switch_chat_interface_t *chat_interface; + + gsmopen_module_pool = pool; + memset(&globals, '\0', sizeof(globals)); + + running = 1; + + if (load_config(FULL_RELOAD) != SWITCH_STATUS_SUCCESS) { + running = 0; + return SWITCH_STATUS_FALSE; + } + + if (switch_event_reserve_subclass(MY_EVENT_INCOMING_SMS) != SWITCH_STATUS_SUCCESS) { + switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Couldn't register subclass!\n"); + return SWITCH_STATUS_GENERR; + } + + *module_interface = switch_loadable_module_create_module_interface(pool, modname); + gsmopen_endpoint_interface = (switch_endpoint_interface_t *) switch_loadable_module_create_interface(*module_interface, SWITCH_ENDPOINT_INTERFACE); + gsmopen_endpoint_interface->interface_name = "gsmopen"; + gsmopen_endpoint_interface->io_routines = &gsmopen_io_routines; + gsmopen_endpoint_interface->state_handler = &gsmopen_state_handlers; + + if (running) { + +#if 1 + SWITCH_ADD_API(commands_api_interface, "gsm", "gsm console AT_command", gsm_function, GSM_SYNTAX); + SWITCH_ADD_API(commands_api_interface, "gsmopen", "gsmopen interface AT_command", gsmopen_function, GSMOPEN_SYNTAX); +#endif //0 + SWITCH_ADD_API(commands_api_interface, "gsmopen_boost_audio", "gsmopen_boost_audio interface AT_command", gsmopen_boost_audio_function, GSMOPEN_BOOST_AUDIO_SYNTAX); + SWITCH_ADD_API(commands_api_interface, "gsmopen_dump", "gsmopen_dump interface", gsmopen_dump_function, GSMOPEN_DUMP_SYNTAX); + SWITCH_ADD_API(commands_api_interface, "gsmopen_sendsms", "gsmopen_sendsms interface destination_number SMS_text", sendsms_function, + SENDSMS_SYNTAX); + SWITCH_ADD_CHAT(chat_interface, MDL_CHAT_PROTO, chat_send); + + /* indicate that the module should continue to be loaded */ + return SWITCH_STATUS_SUCCESS; + } else + return SWITCH_STATUS_FALSE; +} + +SWITCH_MODULE_SHUTDOWN_FUNCTION(mod_gsmopen_shutdown) +{ + int x; + private_t *tech_pvt = NULL; + switch_status_t status; + unsigned int howmany = 8; + int interface_id; + int fd; + + running = 0; + + for (interface_id = 0; interface_id < GSMOPEN_MAX_INTERFACES; interface_id++) { + tech_pvt = &globals.GSMOPEN_INTERFACES[interface_id]; + + if (strlen(globals.GSMOPEN_INTERFACES[interface_id].name)) { + WARNINGA("SHUTDOWN interface_id=%d\n", GSMOPEN_P_LOG, interface_id); + globals.GSMOPEN_INTERFACES[interface_id].running = 0; + if (globals.GSMOPEN_INTERFACES[interface_id].gsmopen_signaling_thread) { +#ifdef WIN32 + switch_file_write(tech_pvt->GSMopenHandles.fdesc[1], "sciutati", &howmany); // let's the controldev_thread die +#else /* WIN32 */ + howmany = write(tech_pvt->GSMopenHandles.fdesc[1], "sciutati", howmany); +#endif /* WIN32 */ + } + x = 10; + while (x) { //FIXME 0.5 seconds? + x--; + switch_yield(50000); + } + if (globals.GSMOPEN_INTERFACES[interface_id].gsmopen_signaling_thread) { + switch_thread_join(&status, globals.GSMOPEN_INTERFACES[interface_id].gsmopen_signaling_thread); + } + if (globals.GSMOPEN_INTERFACES[interface_id].gsmopen_api_thread) { + switch_thread_join(&status, globals.GSMOPEN_INTERFACES[interface_id].gsmopen_api_thread); + } + + x = 10; + while (x) { //FIXME 0.5 seconds? + x--; + switch_yield(50000); + } + fd = tech_pvt->controldevfd; + //DEBUGA_GSMOPEN("SHUTDOWN tech_pvt->controldevfd=%d\n", GSMOPEN_P_LOG, tech_pvt->controldevfd); + if (fd) { + //close(fd); + //tech_pvt->controldevfd = -1; + DEBUGA_GSMOPEN("SHUTDOWN tech_pvt->controldevfd=%d\n", GSMOPEN_P_LOG, tech_pvt->controldevfd); + } +#ifndef WIN32 + shutdown(tech_pvt->audiogsmopenpipe[0], 2); + close(tech_pvt->audiogsmopenpipe[0]); + shutdown(tech_pvt->audiogsmopenpipe[1], 2); + close(tech_pvt->audiogsmopenpipe[1]); + shutdown(tech_pvt->audiopipe[0], 2); + close(tech_pvt->audiopipe[0]); + shutdown(tech_pvt->audiopipe[1], 2); + close(tech_pvt->audiopipe[1]); + shutdown(tech_pvt->GSMopenHandles.fdesc[0], 2); + close(tech_pvt->GSMopenHandles.fdesc[0]); + shutdown(tech_pvt->GSMopenHandles.fdesc[1], 2); + close(tech_pvt->GSMopenHandles.fdesc[1]); +#endif /* WIN32 */ + } + + } + + switch_event_free_subclass(MY_EVENT_INCOMING_SMS); + + switch_safe_free(globals.dialplan); + switch_safe_free(globals.context); + switch_safe_free(globals.destination); + switch_safe_free(globals.codec_string); + switch_safe_free(globals.codec_rates_string); + + return SWITCH_STATUS_SUCCESS; +} + + +void *SWITCH_THREAD_FUNC gsmopen_do_gsmopenapi_thread(switch_thread_t * thread, void *obj) +{ + return gsmopen_do_gsmopenapi_thread_func(obj); +} + +int dtmf_received(private_t * tech_pvt, char *value) +{ + switch_core_session_t *session = NULL; + switch_channel_t *channel = NULL; + + session = switch_core_session_locate(tech_pvt->session_uuid_str); + channel = switch_core_session_get_channel(session); + + if (channel) { + + if (!switch_channel_test_flag(channel, CF_BRIDGED)) { + + switch_dtmf_t dtmf = { (char) value[0], switch_core_default_dtmf_duration(0) }; + DEBUGA_GSMOPEN("received DTMF %c on channel %s\n", GSMOPEN_P_LOG, dtmf.digit, switch_channel_get_name(channel)); + switch_mutex_lock(tech_pvt->flag_mutex); + //FIXME: why sometimes DTMFs from here do not seems to be get by FS? + switch_channel_queue_dtmf(channel, &dtmf); + switch_set_flag(tech_pvt, TFLAG_DTMF); + switch_mutex_unlock(tech_pvt->flag_mutex); + } else { + DEBUGA_GSMOPEN + ("received a DTMF on channel %s, but we're BRIDGED, so let's NOT relay it out of band\n", GSMOPEN_P_LOG, switch_channel_get_name(channel)); + } + } else { + WARNINGA("received %c DTMF, but no channel?\n", GSMOPEN_P_LOG, value[0]); + } + switch_core_session_rwunlock(session); + + return 0; +} + +int new_inbound_channel(private_t * tech_pvt) +{ + switch_core_session_t *session = NULL; + switch_channel_t *channel = NULL; + + switch_assert(tech_pvt != NULL); + tech_pvt->ib_calls++; + if ((session = switch_core_session_request(gsmopen_endpoint_interface, SWITCH_CALL_DIRECTION_INBOUND, NULL)) != 0) { + DEBUGA_GSMOPEN("2 SESSION_REQUEST %s\n", GSMOPEN_P_LOG, switch_core_session_get_uuid(session)); + switch_core_session_add_stream(session, NULL); + channel = switch_core_session_get_channel(session); + if (!channel) { + ERRORA("Doh! no channel?\n", GSMOPEN_P_LOG); + switch_core_session_destroy(&session); + return 0; + } + if (gsmopen_tech_init(tech_pvt, session) != SWITCH_STATUS_SUCCESS) { + ERRORA("Doh! no tech_init?\n", GSMOPEN_P_LOG); + switch_core_session_destroy(&session); + return 0; + } + + if ((tech_pvt->caller_profile = + switch_caller_profile_new(switch_core_session_get_pool(session), "gsmopen", + tech_pvt->dialplan, tech_pvt->callid_name, + tech_pvt->callid_number, NULL, NULL, NULL, NULL, "mod_gsmopen", tech_pvt->context, tech_pvt->destination)) != 0) { + char name[128]; + //switch_snprintf(name, sizeof(name), "gsmopen/%s/%s", tech_pvt->name, tech_pvt->caller_profile->destination_number); + switch_snprintf(name, sizeof(name), "gsmopen/%s", tech_pvt->name); + switch_channel_set_name(channel, name); + switch_channel_set_caller_profile(channel, tech_pvt->caller_profile); + } + switch_channel_set_state(channel, CS_INIT); + if (switch_core_session_thread_launch(session) != SWITCH_STATUS_SUCCESS) { + ERRORA("Error spawning thread\n", GSMOPEN_P_LOG); + switch_core_session_destroy(&session); + return 0; + } + } + if (channel) { + //switch_channel_mark_answered(channel); + } + + DEBUGA_GSMOPEN("new_inbound_channel\n", GSMOPEN_P_LOG); + + return 0; +} + +int remote_party_is_ringing(private_t * tech_pvt) +{ + switch_core_session_t *session = NULL; + switch_channel_t *channel = NULL; + + if (!zstr(tech_pvt->session_uuid_str)) { + session = switch_core_session_locate(tech_pvt->session_uuid_str); + } else { + ERRORA("No session???\n", GSMOPEN_P_LOG); + goto done; + } + if (session) { + channel = switch_core_session_get_channel(session); + } else { + ERRORA("No session???\n", GSMOPEN_P_LOG); + goto done; + } + if (channel) { + switch_channel_mark_ring_ready(channel); + DEBUGA_GSMOPEN("gsmopen_call: REMOTE PARTY RINGING\n", GSMOPEN_P_LOG); + } else { + ERRORA("No channel???\n", GSMOPEN_P_LOG); + } + + switch_core_session_rwunlock(session); + + done: + return 0; +} + +int remote_party_is_early_media(private_t * tech_pvt) +{ + switch_core_session_t *session = NULL; + switch_channel_t *channel = NULL; + + if (!zstr(tech_pvt->session_uuid_str)) { + session = switch_core_session_locate(tech_pvt->session_uuid_str); + } else { + ERRORA("No session???\n\n\n", GSMOPEN_P_LOG); + //TODO: kill the bastard + goto done; + } + if (session) { + channel = switch_core_session_get_channel(session); + switch_core_session_add_stream(session, NULL); + } else { + ERRORA("No session???\n", GSMOPEN_P_LOG); + //TODO: kill the bastard + goto done; + } + if (channel) { + switch_channel_mark_pre_answered(channel); + DEBUGA_GSMOPEN("gsmopen_call: REMOTE PARTY EARLY MEDIA\n", GSMOPEN_P_LOG); + } else { + ERRORA("No channel???\n", GSMOPEN_P_LOG); + //TODO: kill the bastard + } + + switch_core_session_rwunlock(session); + + done: + return 0; +} + +int outbound_channel_answered(private_t * tech_pvt) +{ + switch_core_session_t *session = NULL; + switch_channel_t *channel = NULL; + + if (!zstr(tech_pvt->session_uuid_str)) { + session = switch_core_session_locate(tech_pvt->session_uuid_str); + } else { + ERRORA("No session???\n", GSMOPEN_P_LOG); + goto done; + } + if (session) { + channel = switch_core_session_get_channel(session); + } else { + ERRORA("No channel???\n", GSMOPEN_P_LOG); + goto done; + } + if (channel) { + switch_channel_mark_answered(channel); + tech_pvt->phone_callflow = GSMOPEN_STATE_UP; + tech_pvt->interface_state = GSMOPEN_STATE_UP; + //DEBUGA_GSMOPEN("gsmopen_call: %s, answered\n", GSMOPEN_P_LOG, id); + } else { + ERRORA("No channel???\n", GSMOPEN_P_LOG); + } + + switch_core_session_rwunlock(session); + + done: + DEBUGA_GSMOPEN("outbound_channel_answered!\n", GSMOPEN_P_LOG); + + return 0; +} + +private_t *find_available_gsmopen_interface_rr(private_t * tech_pvt_calling) +{ + private_t *tech_pvt = NULL; + int i; + //int num_interfaces = GSMOPEN_MAX_INTERFACES; + //int num_interfaces = globals.real_interfaces; + + switch_mutex_lock(globals.mutex); + + /* Fact is the real interface start from 1 */ + //XXX no, is just a convention, but you can have it start from 0. I do not, for aestetic reasons :-) + //if (globals.next_interface == 0) globals.next_interface = 1; + + for (i = 0; i < GSMOPEN_MAX_INTERFACES; i++) { + int interface_id; + + interface_id = globals.next_interface; + //interface_id = interface_id < GSMOPEN_MAX_INTERFACES ? interface_id : interface_id - GSMOPEN_MAX_INTERFACES + 1; + globals.next_interface = interface_id + 1 < GSMOPEN_MAX_INTERFACES ? interface_id + 1 : 0; + + if (strlen(globals.GSMOPEN_INTERFACES[interface_id].name)) { + int gsmopen_state = 0; + + tech_pvt = &globals.GSMOPEN_INTERFACES[interface_id]; + gsmopen_state = tech_pvt->interface_state; + DEBUGA_GSMOPEN("gsmopen interface: %d, name: %s, state: %d\n", GSMOPEN_P_LOG, interface_id, globals.GSMOPEN_INTERFACES[interface_id].name, + gsmopen_state); + if ((tech_pvt_calling ? strcmp(tech_pvt->gsmopen_user, tech_pvt_calling->gsmopen_user) : 1) + && (GSMOPEN_STATE_DOWN == gsmopen_state || 0 == gsmopen_state) && (tech_pvt->phone_callflow == CALLFLOW_STATUS_FINISHED + || 0 == tech_pvt->phone_callflow)) { + DEBUGA_GSMOPEN("returning as available gsmopen interface name: %s, state: %d callflow: %d\n", GSMOPEN_P_LOG, tech_pvt->name, gsmopen_state, + tech_pvt->phone_callflow); + /*set to Dialing state to avoid other thread fint it, don't know if it is safe */ + //XXX no, it's not safe + if (tech_pvt_calling == NULL) { + tech_pvt->interface_state = GSMOPEN_STATE_SELECTED; + } + + switch_mutex_unlock(globals.mutex); + return tech_pvt; + } + } // else { + //DEBUGA_GSMOPEN("GSM interface: %d blank!! A hole here means we cannot hunt the last interface.\n", GSMOPEN_P_LOG, interface_id); + //} + } + + switch_mutex_unlock(globals.mutex); + return NULL; +} + +#if 1 +SWITCH_STANDARD_API(gsm_function) +{ + char *mycmd = NULL, *argv[10] = { 0 }; + int argc = 0; + + if (globals.gsm_console) + stream->write_function(stream, "gsm console is: |||%s|||\n", globals.gsm_console->name); + else + stream->write_function(stream, "gsm console is NOT yet assigned\n"); + + if (!zstr(cmd) && (mycmd = strdup(cmd))) { + argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0]))); + } + + if (!argc || !argv[0]) { + stream->write_function(stream, "%s", GSM_SYNTAX); + goto end; + } + + if (!strcasecmp(argv[0], "list")) { + int i; + char next_flag_char = ' '; + + stream->write_function(stream, "F ID\t Name \tIB (F/T) OB (F/T)\tState\tCallFlw\t\tUUID\n"); + stream->write_function(stream, "= ====\t ======== \t======= =======\t======\t============\t======\n"); + + for (i = 0; i < GSMOPEN_MAX_INTERFACES; i++) { + next_flag_char = i == globals.next_interface ? '*' : ' '; + + if (strlen(globals.GSMOPEN_INTERFACES[i].name)) { + stream->write_function(stream, + "%c %d\t[%s]\t%3ld/%ld\t%6ld/%ld\t%s\t%s\t%s\n", + next_flag_char, + i, globals.GSMOPEN_INTERFACES[i].name, + globals.GSMOPEN_INTERFACES[i].ib_failed_calls, + globals.GSMOPEN_INTERFACES[i].ib_calls, + globals.GSMOPEN_INTERFACES[i].ob_failed_calls, + globals.GSMOPEN_INTERFACES[i].ob_calls, + interface_status[globals.GSMOPEN_INTERFACES[i].interface_state], + phone_callflow[globals.GSMOPEN_INTERFACES[i].phone_callflow], globals.GSMOPEN_INTERFACES[i].session_uuid_str); + } else if (argc > 1 && !strcasecmp(argv[1], "full")) { + stream->write_function(stream, "%c\t%d\n", next_flag_char, i); + } + + } + stream->write_function(stream, "\nTotal: %d\n", globals.real_interfaces - 1); + + } else if (!strcasecmp(argv[0], "console")) { + int i; + int found = 0; + + if (argc == 2) { + for (i = 0; !found && i < GSMOPEN_MAX_INTERFACES; i++) { + /* we've been asked for a normal interface name, or we have not found idle interfaces to serve as the "ANY" interface */ + if (strlen(globals.GSMOPEN_INTERFACES[i].name) + && (strncmp(globals.GSMOPEN_INTERFACES[i].name, argv[1], strlen(argv[1])) == 0)) { + globals.gsm_console = &globals.GSMOPEN_INTERFACES[i]; + stream->write_function(stream, "gsm console is now: globals.GSMOPEN_INTERFACES[%d].name=|||%s|||\n", i, + globals.GSMOPEN_INTERFACES[i].name); + stream->write_function(stream, "gsm console is: |||%s|||\n", globals.gsm_console->name); + found = 1; + break; + } + + } + if (!found) + stream->write_function(stream, "ERROR: A GSMopen interface with name='%s' was not found\n", argv[1]); + } else { + + stream->write_function(stream, "-ERR Usage: gsm console interface_name\n"); + goto end; + } + + } else if (!strcasecmp(argv[0], "ciapalino")) { + +/* BEGIN: Changes heres */ + } else if (!strcasecmp(argv[0], "reload")) { + if (load_config(SOFT_RELOAD) != SWITCH_STATUS_SUCCESS) { + stream->write_function(stream, "gsm reload failed\n"); + } else { + stream->write_function(stream, "gsm reload success\n"); + } + } else if (!strcasecmp(argv[0], "remove")) { + if (argc == 2) { + if (remove_interface(argv[1]) == SWITCH_STATUS_SUCCESS) { + if (interface_exists(argv[1]) == SWITCH_STATUS_SUCCESS) { + stream->write_function(stream, "gsm remove '%s' failed\n", argv[1]); + } else { + stream->write_function(stream, "gsm remove '%s' success\n", argv[1]); + } + } + } else { + stream->write_function(stream, "-ERR Usage: gsm remove interface_name\n"); + goto end; + } +/* END: Changes heres */ + + } else { + if (globals.gsm_console) + gsmopen_serial_write_AT_noack(globals.gsm_console, (char *) cmd); + else + stream->write_function(stream, "gsm console is NOT yet assigned\n"); + } + end: + switch_safe_free(mycmd); + + return SWITCH_STATUS_SUCCESS; +} + +SWITCH_STANDARD_API(gsmopen_function) +{ + char *mycmd = NULL, *argv[10] = { 0 }; + int argc = 0; + private_t *tech_pvt = NULL; + + if (!zstr(cmd) && (mycmd = strdup(cmd))) { + argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0]))); + } + + if (!argc) { + stream->write_function(stream, "ERROR, usage: %s", GSMOPEN_SYNTAX); + goto end; + } + + if (argc < 2) { + stream->write_function(stream, "ERROR, usage: %s", GSMOPEN_SYNTAX); + goto end; + } + + if (argv[0]) { + int i; + int found = 0; + + for (i = 0; !found && i < GSMOPEN_MAX_INTERFACES; i++) { + /* we've been asked for a normal interface name, or we have not found idle interfaces to serve as the "ANY" interface */ + if (strlen(globals.GSMOPEN_INTERFACES[i].name) + && (strncmp(globals.GSMOPEN_INTERFACES[i].name, argv[0], strlen(argv[0])) == 0)) { + tech_pvt = &globals.GSMOPEN_INTERFACES[i]; + stream->write_function(stream, "Using interface: globals.GSMOPEN_INTERFACES[%d].name=|||%s|||\n", i, globals.GSMOPEN_INTERFACES[i].name); + found = 1; + break; + } + + } + if (!found) { + stream->write_function(stream, "ERROR: A GSMopen interface with name='%s' was not found\n", argv[0]); + switch_safe_free(mycmd); + + return SWITCH_STATUS_SUCCESS; + } else { + gsmopen_serial_write_AT_noack(tech_pvt, (char *) &cmd[strlen(argv[0]) + 1]); + } + } else { + stream->write_function(stream, "ERROR, usage: %s", GSMOPEN_SYNTAX); + } + end: + switch_safe_free(mycmd); + + return SWITCH_STATUS_SUCCESS; +} +#endif //0 +SWITCH_STANDARD_API(gsmopen_dump_function) +{ + char *mycmd = NULL, *argv[10] = { 0 }; + int argc = 0; + private_t *tech_pvt = NULL; + char value[512]; + + if (!zstr(cmd) && (mycmd = strdup(cmd))) { + argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0]))); + } + + if (!argc) { + stream->write_function(stream, "ERROR, usage: %s", GSMOPEN_DUMP_SYNTAX); + goto end; + } + if (argc == 1) { + int i; + int found = 0; + + for (i = 0; !found && i < GSMOPEN_MAX_INTERFACES; i++) { + /* we've been asked for a normal interface name, or we have not found idle interfaces to serve as the "ANY" interface */ + if (strlen(globals.GSMOPEN_INTERFACES[i].name) + && (strncmp(globals.GSMOPEN_INTERFACES[i].name, argv[0], strlen(argv[0])) == 0)) { + tech_pvt = &globals.GSMOPEN_INTERFACES[i]; + //stream->write_function(stream, "Using interface: globals.GSMOPEN_INTERFACES[%d].name=|||%s|||\n", i, globals.GSMOPEN_INTERFACES[i].name); + found = 1; + break; + } + + } + if (!found && (strcmp("list", argv[0]) == 0)) { + int i; + stream->write_function(stream, "gsmopen_dump LIST\n\n"); + for (i = 0; i < GSMOPEN_MAX_INTERFACES; i++) { + if (strlen(globals.GSMOPEN_INTERFACES[i].name)) { + stream->write_function(stream, "dumping interface '%s'\n\n", globals.GSMOPEN_INTERFACES[i].name); + tech_pvt = &globals.GSMOPEN_INTERFACES[i]; + + + stream->write_function(stream, "interface_name = %s\n", tech_pvt->name); + stream->write_function(stream, "interface_id = %s\n", tech_pvt->id); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->active); + stream->write_function(stream, "active = %s\n", value); + if(!tech_pvt->network_creg_not_supported){ + snprintf(value, sizeof(value)-1, "%d", tech_pvt->not_registered); + stream->write_function(stream, "not_registered = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->home_network_registered); + stream->write_function(stream, "home_network_registered = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->roaming_registered); + stream->write_function(stream, "roaming_registered = %s\n", value); + }else{ + stream->write_function(stream, "not_registered = %s\n", "N/A"); + stream->write_function(stream, "home_network_registered = %s\n", "N/A"); + stream->write_function(stream, "roaming_registered = %s\n", "N/A"); + } + snprintf(value, sizeof(value)-1, "%d", tech_pvt->got_signal); + stream->write_function(stream, "got_signal = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->running); + stream->write_function(stream, "running = %s\n", value); + stream->write_function(stream, "imei = %s\n", tech_pvt->imei); + stream->write_function(stream, "imsi = %s\n", tech_pvt->imsi); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->controldev_dead); + stream->write_function(stream, "controldev_dead = %s\n", value); + stream->write_function(stream, "controldevice_name = %s\n", tech_pvt->controldevice_name); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->no_sound); + stream->write_function(stream, "no_sound = %s\n", value); +#ifdef GSMOPEN_ALSA + stream->write_function(stream, "alsacname = %s\n", tech_pvt->alsacname); + stream->write_function(stream, "alsapname = %s\n", tech_pvt->alsapname); +#endif// GSMOPEN_ALSA +#ifdef GSMOPEN_PORTAUDIO + snprintf(value, sizeof(value)-1, "%d", tech_pvt->portaudiocindex); + stream->write_function(stream, "portaudiocindex = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->portaudiopindex); + stream->write_function(stream, "portaudiopindex = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->speexecho); + stream->write_function(stream, "speexecho = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->speexpreprocess); + stream->write_function(stream, "speexpreprocess = %s\n", value); +#endif// GSMOPEN_PORTAUDIO + snprintf(value, sizeof(value)-1, "%f", tech_pvt->playback_boost); + stream->write_function(stream, "playback_boost = %s\n", value); + snprintf(value, sizeof(value)-1, "%f", tech_pvt->capture_boost); + stream->write_function(stream, "capture_boost = %s\n", value); + stream->write_function(stream, "dialplan = %s\n", tech_pvt->dialplan); + stream->write_function(stream, "context = %s\n", tech_pvt->context); + stream->write_function(stream, "destination = %s\n", tech_pvt->destination); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ib_calls); + stream->write_function(stream, "ib_calls = %s\n", value); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ob_calls); + stream->write_function(stream, "ob_calls = %s\n", value); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ib_failed_calls); + stream->write_function(stream, "ib_failed_calls = %s\n", value); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ob_failed_calls); + stream->write_function(stream, "ob_failed_calls = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->interface_state); + stream->write_function(stream, "interface_state = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->phone_callflow); + stream->write_function(stream, "phone_callflow = %s\n", value); + stream->write_function(stream, "session_uuid_str = %s\n", tech_pvt->session_uuid_str); + stream->write_function(stream, "\n"); + + dump_event(tech_pvt); + } + + } + + } else if(found){ + stream->write_function(stream, "dumping interface '%s'\n\n", argv[0]); + tech_pvt = &globals.GSMOPEN_INTERFACES[i]; + + + stream->write_function(stream, "interface_name = %s\n", tech_pvt->name); + stream->write_function(stream, "interface_id = %s\n", tech_pvt->id); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->active); + stream->write_function(stream, "active = %s\n", value); + if(!tech_pvt->network_creg_not_supported){ + snprintf(value, sizeof(value)-1, "%d", tech_pvt->not_registered); + stream->write_function(stream, "not_registered = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->home_network_registered); + stream->write_function(stream, "home_network_registered = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->roaming_registered); + stream->write_function(stream, "roaming_registered = %s\n", value); + }else{ + stream->write_function(stream, "not_registered = %s\n", "N/A"); + stream->write_function(stream, "home_network_registered = %s\n", "N/A"); + stream->write_function(stream, "roaming_registered = %s\n", "N/A"); + } + snprintf(value, sizeof(value)-1, "%d", tech_pvt->got_signal); + stream->write_function(stream, "got_signal = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->running); + stream->write_function(stream, "running = %s\n", value); + stream->write_function(stream, "imei = %s\n", tech_pvt->imei); + stream->write_function(stream, "imsi = %s\n", tech_pvt->imsi); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->controldev_dead); + stream->write_function(stream, "controldev_dead = %s\n", value); + stream->write_function(stream, "controldevice_name = %s\n", tech_pvt->controldevice_name); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->no_sound); + stream->write_function(stream, "no_sound = %s\n", value); +#ifdef GSMOPEN_ALSA + stream->write_function(stream, "alsacname = %s\n", tech_pvt->alsacname); + stream->write_function(stream, "alsapname = %s\n", tech_pvt->alsapname); +#endif// GSMOPEN_ALSA +#ifdef GSMOPEN_PORTAUDIO + snprintf(value, sizeof(value)-1, "%d", tech_pvt->portaudiocindex); + stream->write_function(stream, "portaudiocindex = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->portaudiopindex); + stream->write_function(stream, "portaudiopindex = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->speexecho); + stream->write_function(stream, "speexecho = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->speexpreprocess); + stream->write_function(stream, "speexpreprocess = %s\n", value); +#endif// GSMOPEN_PORTAUDIO + snprintf(value, sizeof(value)-1, "%f", tech_pvt->playback_boost); + stream->write_function(stream, "playback_boost = %s\n", value); + snprintf(value, sizeof(value)-1, "%f", tech_pvt->capture_boost); + stream->write_function(stream, "capture_boost = %s\n", value); + stream->write_function(stream, "dialplan = %s\n", tech_pvt->dialplan); + stream->write_function(stream, "context = %s\n", tech_pvt->context); + stream->write_function(stream, "destination = %s\n", tech_pvt->destination); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ib_calls); + stream->write_function(stream, "ib_calls = %s\n", value); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ob_calls); + stream->write_function(stream, "ob_calls = %s\n", value); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ib_failed_calls); + stream->write_function(stream, "ib_failed_calls = %s\n", value); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ob_failed_calls); + stream->write_function(stream, "ob_failed_calls = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->interface_state); + stream->write_function(stream, "interface_state = %s\n", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->phone_callflow); + stream->write_function(stream, "phone_callflow = %s\n", value); + stream->write_function(stream, "session_uuid_str = %s\n", tech_pvt->session_uuid_str); + stream->write_function(stream, "\n"); + + dump_event(tech_pvt); + } else{ + stream->write_function(stream, "interface '%s' was not found\n", argv[0]); + } + } else { + stream->write_function(stream, "ERROR, usage: %s", GSMOPEN_DUMP_SYNTAX); + } +end: + switch_safe_free(mycmd); + + return SWITCH_STATUS_SUCCESS; +} +SWITCH_STANDARD_API(gsmopen_boost_audio_function) +{ + char *mycmd = NULL, *argv[10] = { 0 }; + int argc = 0; + private_t *tech_pvt = NULL; + + if (!zstr(cmd) && (mycmd = strdup(cmd))) { + argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0]))); + } + + if (argc == 1 || argc==3) { + int i; + int found = 0; + + for (i = 0; !found && i < GSMOPEN_MAX_INTERFACES; i++) { + /* we've been asked for a normal interface name, or we have not found idle interfaces to serve as the "ANY" interface */ + if (strlen(globals.GSMOPEN_INTERFACES[i].name) + && (strncmp(globals.GSMOPEN_INTERFACES[i].name, argv[0], strlen(argv[0])) == 0)) { + tech_pvt = &globals.GSMOPEN_INTERFACES[i]; + stream->write_function(stream, "Using interface: globals.GSMOPEN_INTERFACES[%d].name=|||%s|||\n", i, globals.GSMOPEN_INTERFACES[i].name); + found = 1; + break; + } + + } + if (!found) { + stream->write_function(stream, "ERROR: A GSMopen interface with name='%s' was not found\n", argv[0]); + + } else { + if (argc == 1) { + stream->write_function(stream,"[%s] capture boost is %f\n", globals.GSMOPEN_INTERFACES[i].name, globals.GSMOPEN_INTERFACES[i].capture_boost); + stream->write_function(stream,"[%s] playback boost is %f\n", globals.GSMOPEN_INTERFACES[i].name, globals.GSMOPEN_INTERFACES[i].playback_boost); + stream->write_function(stream, "%s usage: %s", argv[0], GSMOPEN_BOOST_AUDIO_SYNTAX); + goto end; + } else if ((strncmp("play", argv[1], strlen(argv[1])) == 0)) { + if (switch_is_number(argv[2])) { + stream->write_function(stream,"[%s] playback boost was %f\n", globals.GSMOPEN_INTERFACES[i].name, globals.GSMOPEN_INTERFACES[i].playback_boost); + gsmopen_store_boost(argv[2], &globals.GSMOPEN_INTERFACES[i].playback_boost); //FIXME + stream->write_function(stream,"[%s] playback boost is now %f\n", globals.GSMOPEN_INTERFACES[i].name, globals.GSMOPEN_INTERFACES[i].playback_boost); + } + }else if ((strncmp("capt", argv[1], strlen(argv[1])) == 0)) { + if (switch_is_number(argv[2])) { + stream->write_function(stream,"[%s] capture boost was %f\n", globals.GSMOPEN_INTERFACES[i].name, globals.GSMOPEN_INTERFACES[i].capture_boost); + gsmopen_store_boost(argv[2], &globals.GSMOPEN_INTERFACES[i].capture_boost); //FIXME + stream->write_function(stream,"[%s] capture boost is now %f\n", globals.GSMOPEN_INTERFACES[i].name, globals.GSMOPEN_INTERFACES[i].capture_boost); + } + } else { + stream->write_function(stream, "ERROR, usage: %s", GSMOPEN_BOOST_AUDIO_SYNTAX); + } + } + } else { + stream->write_function(stream, "ERROR, usage: %s", GSMOPEN_BOOST_AUDIO_SYNTAX); + } + end: + switch_safe_free(mycmd); + + return SWITCH_STATUS_SUCCESS; +} + + +#if 0 +int gsmopen_transfer(private_t * tech_pvt, char *id, char *value) +{ + char msg_to_gsmopen[1024]; + int i; + int found = 0; + private_t *giovatech; + struct timeval timenow; + + switch_mutex_lock(globals.mutex); + + gettimeofday(&timenow, NULL); + for (i = 0; !found && i < GSMOPEN_MAX_INTERFACES; i++) { + if (strlen(globals.GSMOPEN_INTERFACES[i].name)) { + + giovatech = &globals.GSMOPEN_INTERFACES[i]; + //NOTICA("gsmopen interface: %d, name: %s, state: %d, value=%s, giovatech->callid_number=%s, giovatech->gsmopen_user=%s\n", GSMOPEN_P_LOG, i, giovatech->name, giovatech->interface_state, value, giovatech->callid_number, giovatech->gsmopen_user); + //FIXME check a timestamp here + if (strlen(giovatech->gsmopen_call_id) && (giovatech->interface_state != GSMOPEN_STATE_DOWN) && (!strcmp(giovatech->gsmopen_user, tech_pvt->gsmopen_user)) && (!strcmp(giovatech->callid_number, value)) && ((((timenow.tv_sec - giovatech->answer_time.tv_sec) * 1000000) + (timenow.tv_usec - giovatech->answer_time.tv_usec)) < 500000)) { //0.5sec + found = 1; + DEBUGA_GSMOPEN + ("FOUND (name=%s, giovatech->interface_state=%d != GSMOPEN_STATE_DOWN) && (giovatech->gsmopen_user=%s == tech_pvt->gsmopen_user=%s) && (giovatech->callid_number=%s == value=%s)\n", + GSMOPEN_P_LOG, giovatech->name, giovatech->interface_state, giovatech->gsmopen_user, tech_pvt->gsmopen_user, giovatech->callid_number, + value) + break; + } + } + } + + if (found) { + //tech_pvt->callid_number[0]='\0'; + //sprintf(msg_to_gsmopen, "ALTER CALL %s END HANGUP", id); + //gsmopen_signaling_write(tech_pvt, msg_to_gsmopen); + switch_mutex_unlock(globals.mutex); + return 0; + } + DEBUGA_GSMOPEN("NOT FOUND\n", GSMOPEN_P_LOG); + + if (!tech_pvt || !tech_pvt->gsmopen_call_id || !strlen(tech_pvt->gsmopen_call_id)) { + /* we are not inside an active call */ + DEBUGA_GSMOPEN("We're NO MORE in a call now %s\n", GSMOPEN_P_LOG, (tech_pvt && tech_pvt->gsmopen_call_id) ? tech_pvt->gsmopen_call_id : ""); + switch_mutex_unlock(globals.mutex); + + } else { + + /* we're owned, we're in a call, let's try to transfer */ + /************************** TODO + Checking here if it is possible to transfer this call to Test2 + -> GET CALL 288 CAN_TRANSFER Test2 + <- CALL 288 CAN_TRANSFER test2 TRUE + **********************************/ + + private_t *available_gsmopen_interface = NULL; + + gettimeofday(&timenow, NULL); + for (i = 0; !found && i < GSMOPEN_MAX_INTERFACES; i++) { + if (strlen(globals.GSMOPEN_INTERFACES[i].name)) { + + giovatech = &globals.GSMOPEN_INTERFACES[i]; + //NOTICA("gsmopen interface: %d, name: %s, state: %d, value=%s, giovatech->callid_number=%s, giovatech->gsmopen_user=%s\n", GSMOPEN_P_LOG, i, giovatech->name, giovatech->interface_state, value, giovatech->callid_number, giovatech->gsmopen_user); + //FIXME check a timestamp here + if (strlen(giovatech->gsmopen_transfer_call_id) && (giovatech->interface_state != GSMOPEN_STATE_DOWN) && (!strcmp(giovatech->gsmopen_user, tech_pvt->gsmopen_user)) && (!strcmp(giovatech->transfer_callid_number, value)) && ((((timenow.tv_sec - giovatech->transfer_time.tv_sec) * 1000000) + (timenow.tv_usec - giovatech->transfer_time.tv_usec)) < 1000000)) { //1.0 sec + found = 1; + DEBUGA_GSMOPEN + ("FOUND (name=%s, giovatech->interface_state=%d != GSMOPEN_STATE_DOWN) && (giovatech->gsmopen_user=%s == tech_pvt->gsmopen_user=%s) && (giovatech->transfer_callid_number=%s == value=%s)\n", + GSMOPEN_P_LOG, giovatech->name, giovatech->interface_state, + giovatech->gsmopen_user, tech_pvt->gsmopen_user, giovatech->transfer_callid_number, value) + break; + } + } + } + + if (found) { + //tech_pvt->callid_number[0]='\0'; + //sprintf(msg_to_gsmopen, "ALTER CALL %s END HANGUP", id); + //gsmopen_signaling_write(tech_pvt, msg_to_gsmopen); + switch_mutex_unlock(globals.mutex); + return 0; + } + DEBUGA_GSMOPEN("NOT FOUND\n", GSMOPEN_P_LOG); + + available_gsmopen_interface = find_available_gsmopen_interface_rr(tech_pvt); + if (available_gsmopen_interface) { + /* there is a gsmopen interface idle, let's transfer the call to it */ + + //FIXME write a timestamp here + gettimeofday(&tech_pvt->transfer_time, NULL); + switch_copy_string(tech_pvt->gsmopen_transfer_call_id, id, sizeof(tech_pvt->gsmopen_transfer_call_id) - 1); + + switch_copy_string(tech_pvt->transfer_callid_number, value, sizeof(tech_pvt->transfer_callid_number) - 1); + + DEBUGA_GSMOPEN + ("Let's transfer the gsmopen_call %s to %s interface (with gsmopen_user: %s), because we are already in a gsmopen call(%s)\n", + GSMOPEN_P_LOG, tech_pvt->gsmopen_call_id, available_gsmopen_interface->name, available_gsmopen_interface->gsmopen_user, id); + + //FIXME why this? the inbound call will come, eventually, on that other interface + //available_gsmopen_interface->ib_calls++; + + sprintf(msg_to_gsmopen, "ALTER CALL %s TRANSFER %s", id, available_gsmopen_interface->gsmopen_user); + //gsmopen_signaling_write(tech_pvt, msg_to_gsmopen); + if (tech_pvt->interface_state == GSMOPEN_STATE_SELECTED) { + tech_pvt->interface_state = GSMOPEN_STATE_IDLE; //we marked it GSMOPEN_STATE_SELECTED just in case it has to make an outbound call + } + } else { + /* no gsmopen interfaces idle, do nothing */ + DEBUGA_GSMOPEN + ("Not answering the gsmopen_call %s, because we are already in a gsmopen call(%s) and not transferring, because no other gsmopen interfaces are available\n", + GSMOPEN_P_LOG, id, tech_pvt->gsmopen_call_id); + sprintf(msg_to_gsmopen, "ALTER CALL %s END HANGUP", id); + //gsmopen_signaling_write(tech_pvt, msg_to_gsmopen); + } + switch_sleep(10000); + DEBUGA_GSMOPEN + ("We have NOT answered a GSM RING from gsmopen_call %s, because we are already in a gsmopen call (%s)\n", + GSMOPEN_P_LOG, id, tech_pvt->gsmopen_call_id); + + switch_mutex_unlock(globals.mutex); + } + return 0; +} +#endif //0 + +void *gsmopen_do_gsmopenapi_thread_func(void *obj) +{ + + private_t *tech_pvt = (private_t *) obj; + time_t now_timestamp; + + //if (gsmopen_present(GSMopenHandles)) + while (running && tech_pvt->running) { + int res; + //gsmopen_sleep(1000000); //1 sec + //DEBUGA_GSMOPEN("ciao!\n", GSMOPEN_P_LOG); + res = gsmopen_serial_read(tech_pvt); + if (res == -1) { //manage the graceful interface shutdown + tech_pvt->controldev_dead = 1; + close(tech_pvt->controldevfd); + ERRORA("gsmopen_serial_monitor failed, declaring %s dead\n", GSMOPEN_P_LOG, tech_pvt->controldevice_name); + tech_pvt->running=0; + alarm_event(tech_pvt, ALARM_FAILED_INTERFACE, "gsmopen_serial_monitor failed, declaring interface dead"); + tech_pvt->active=0; + tech_pvt->name[0]='\0'; + switch_sleep(1000000); + } else if (tech_pvt->controldevprotocol != PROTOCOL_NO_SERIAL && tech_pvt->interface_state == GSMOPEN_STATE_RING + && tech_pvt->phone_callflow != CALLFLOW_CALL_HANGUP_REQUESTED) { + //WARNINGA("INCOMING RING\n", GSMOPEN_P_LOG); + + gsmopen_ring(tech_pvt); + + //FIXME gsmopen_answer(tech_pvt); + //new_inbound_channel(tech_pvt); + //FIXME if (!gsmopen_new(p, AST_STATE_RING, tech_pvt->context)) { + //FIXME ERRORA("gsmopen_new failed! BAD BAD BAD\n", GSMOPEN_P_LOG); + //FIXME } + + + } else if (tech_pvt->controldevprotocol != PROTOCOL_NO_SERIAL && tech_pvt->interface_state == GSMOPEN_STATE_DIALING) { + WARNINGA("WE'RE DIALING, let's take the earlymedia\n", GSMOPEN_P_LOG); + tech_pvt->interface_state = CALLFLOW_STATUS_EARLYMEDIA; + remote_party_is_early_media(tech_pvt); + //new_inbound_channel(tech_pvt); + //FIXME if (!gsmopen_new(p, AST_STATE_RING, tech_pvt->context)) { + //FIXME ERRORA("gsmopen_new failed! BAD BAD BAD\n", GSMOPEN_P_LOG); + //FIXME } + + + + + } else if (tech_pvt->interface_state == CALLFLOW_CALL_REMOTEANSWER) { + WARNINGA("REMOTE PARTY ANSWERED\n", GSMOPEN_P_LOG); + outbound_channel_answered(tech_pvt); + //new_inbound_channel(tech_pvt); + //FIXME if (!gsmopen_new(p, AST_STATE_RING, tech_pvt->context)) { + //FIXME ERRORA("gsmopen_new failed! BAD BAD BAD\n", GSMOPEN_P_LOG); + //FIXME } + } + switch_sleep(100); //give other threads a chance + time(&now_timestamp); + + if ((now_timestamp - tech_pvt->gsmopen_serial_synced_timestamp) > tech_pvt->gsmopen_serial_sync_period) { //TODO find a sensible period. 5min? in config? + gsmopen_serial_sync(tech_pvt); + gsmopen_serial_getstatus_AT(tech_pvt); + } + } + DEBUGA_GSMOPEN("EXIT\n", GSMOPEN_P_LOG); + //running = 0; + return NULL; + +} + + +SWITCH_STANDARD_API(sendsms_function) +{ + char *mycmd = NULL, *argv[3] = { 0 }; + int argc = 0; + private_t *tech_pvt = NULL; + + if (!zstr(cmd) && (mycmd = strdup(cmd))) { + argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0]))); + } + + if (!argc) { + stream->write_function(stream, "ERROR, usage: %s", SENDSMS_SYNTAX); + goto end; + } + + if (argc < 3) { + stream->write_function(stream, "ERROR, usage: %s", SENDSMS_SYNTAX); + goto end; + } + + if (argv[0]) { + int i; + int found = 0; + + for (i = 0; !found && i < GSMOPEN_MAX_INTERFACES; i++) { + /* we've been asked for a normal interface name, or we have not found idle interfaces to serve as the "ANY" interface */ + if (strlen(globals.GSMOPEN_INTERFACES[i].name) + && (strncmp(globals.GSMOPEN_INTERFACES[i].name, argv[0], strlen(argv[0])) == 0)) { + tech_pvt = &globals.GSMOPEN_INTERFACES[i]; + stream->write_function(stream, "Trying to send your SMS: interface=%s, dest=%s, text=%s\n", argv[0], argv[1], argv[2]); + found = 1; + break; + } + + } + if (!found) { + stream->write_function(stream, "ERROR: A GSMopen interface with name='%s' was not found\n", argv[0]); + switch_safe_free(mycmd); + + return SWITCH_STATUS_SUCCESS; + } else { + //gsmopen_sendsms(tech_pvt, (char *) argv[1], (char *) argv[2]); + NOTICA("chat_send(proto=%s, from=%s, to=%s, subject=%s, body=%s, type=NULL, hint=%s)\n", GSMOPEN_P_LOG, MDL_CHAT_PROTO, tech_pvt->name, + argv[1], "SIMPLE MESSAGE", switch_str_nil(argv[2]), tech_pvt->name); + + chat_send(MDL_CHAT_PROTO, tech_pvt->name, argv[1], "SIMPLE MESSAGE", switch_str_nil(argv[2]), NULL, tech_pvt->name); + } + } else { + stream->write_function(stream, "ERROR, usage: %s", SENDSMS_SYNTAX); + } + end: + switch_safe_free(mycmd); + + return SWITCH_STATUS_SUCCESS; +} + +int dump_event_full(private_t * tech_pvt, int is_alarm, int alarm_code, const char *alarm_message) +{ + switch_event_t *event; + char value[512]; + switch_core_session_t *session = NULL; + switch_channel_t *channel = NULL; + switch_status_t status; + + session = switch_core_session_locate(tech_pvt->session_uuid_str); + if(session){ + channel = switch_core_session_get_channel(session); + } + + if (is_alarm){ + ERRORA("ALARM on interface %s: \n", GSMOPEN_P_LOG, tech_pvt->name ); + status = switch_event_create_subclass(&event, SWITCH_EVENT_CUSTOM, MY_EVENT_ALARM); + }else{ + DEBUGA_GSMOPEN("DUMP on interface %s: \n", GSMOPEN_P_LOG, tech_pvt->name ); + status = switch_event_create_subclass(&event, SWITCH_EVENT_CUSTOM, MY_EVENT_DUMP); + } + if (status == SWITCH_STATUS_SUCCESS) { + if (is_alarm){ + snprintf(value, sizeof(value)-1, "%d", alarm_code); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "alarm_code", value); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "alarm_message", alarm_message); + } + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "interface_name", tech_pvt->name); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "interface_id", tech_pvt->id); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->active); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "active", value); + if(!tech_pvt->network_creg_not_supported){ + snprintf(value, sizeof(value)-1, "%d", tech_pvt->not_registered); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "not_registered", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->home_network_registered); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "home_network_registered", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->roaming_registered); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "roaming_registered", value); + }else{ + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "not_registered", "N/A"); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "home_network_registered", "N/A"); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "roaming_registered", "N/A"); + } + snprintf(value, sizeof(value)-1, "%d", tech_pvt->got_signal); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "got_signal", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->running); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "running", value); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "imei", tech_pvt->imei); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "imsi", tech_pvt->imsi); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->controldev_dead); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "controldev_dead", value); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "controldevice_name", tech_pvt->controldevice_name); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->no_sound); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "no_sound", value); +#ifdef GSMOPEN_ALSA + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "alsacname", tech_pvt->alsacname); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "alsapname", tech_pvt->alsapname); +#endif// GSMOPEN_ALSA +#ifdef GSMOPEN_PORTAUDIO + snprintf(value, sizeof(value)-1, "%d", tech_pvt->portaudiocindex); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "portaudiocindex", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->portaudiopindex); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "portaudiopindex", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->speexecho); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "speexecho", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->speexpreprocess); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "speexpreprocess", value); +#endif// GSMOPEN_PORTAUDIO + snprintf(value, sizeof(value)-1, "%f", tech_pvt->playback_boost); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "playback_boost", value); + snprintf(value, sizeof(value)-1, "%f", tech_pvt->capture_boost); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "capture_boost", value); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "dialplan", tech_pvt->dialplan); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "context", tech_pvt->context); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "destination", tech_pvt->destination); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ib_calls); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "ib_calls", value); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ob_calls); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "ob_calls", value); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ib_failed_calls); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "ib_failed_calls", value); + snprintf(value, sizeof(value)-1, "%lu", tech_pvt->ob_failed_calls); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "ob_failed_calls", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->interface_state); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "interface_state", value); + snprintf(value, sizeof(value)-1, "%d", tech_pvt->phone_callflow); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "phone_callflow", value); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "session_uuid_str", tech_pvt->session_uuid_str); + if (strlen(tech_pvt->session_uuid_str)) { + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "during-call", "true"); + } else { //no session + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "during-call", "false"); + } + if (channel) { + switch_channel_event_set_data(channel, event); + } + switch_event_fire(&event); + } else { + ERRORA("cannot create event on interface %s. WHY?????\n", GSMOPEN_P_LOG, tech_pvt->name); + } + + if (session) { + switch_core_session_rwunlock(session); + } + return 0; +} + +int dump_event(private_t * tech_pvt) +{ + return dump_event_full(tech_pvt, 0, 0, NULL); +} + + +int alarm_event(private_t * tech_pvt, int alarm_code, const char *alarm_message) +{ + return dump_event_full(tech_pvt, 1, alarm_code, alarm_message); +} + +int sms_incoming(private_t * tech_pvt) +{ + switch_event_t *event; + switch_core_session_t *session = NULL; + int event_sent_to_esl = 0; + + //DEBUGA_GSMOPEN("received SMS on interface %s: %s\n", GSMOPEN_P_LOG, tech_pvt->name, tech_pvt->sms_message); + DEBUGA_GSMOPEN("received SMS on interface %s: DATE=%s, SENDER=%s, BODY=%s|\n", GSMOPEN_P_LOG, tech_pvt->name, tech_pvt->sms_date, tech_pvt->sms_sender, + tech_pvt->sms_body); + + if (!zstr(tech_pvt->session_uuid_str)) { + session = switch_core_session_locate(tech_pvt->session_uuid_str); + } + if (switch_event_create(&event, SWITCH_EVENT_MESSAGE) == SWITCH_STATUS_SUCCESS) { + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "proto", MDL_CHAT_PROTO); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "login", tech_pvt->name); + //switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "hint", tech_pvt->chatmessages[which].from_dispname); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "from", tech_pvt->sms_sender); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "date", tech_pvt->sms_date); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "datacodingscheme", tech_pvt->sms_datacodingscheme); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "servicecentreaddress", tech_pvt->sms_servicecentreaddress); + switch_event_add_header(event, SWITCH_STACK_BOTTOM, "messagetype", "%d", tech_pvt->sms_messagetype); + //switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "chatname", tech_pvt->chatmessages[which].chatname); + //switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "id", tech_pvt->chatmessages[which].id); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "subject", "SIMPLE MESSAGE"); + switch_event_add_body(event, "%s\n", tech_pvt->sms_body); + if (session) { + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "during-call", "true"); + if (switch_core_session_queue_event(session, &event) != SWITCH_STATUS_SUCCESS) { + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "delivery-failure", "true"); + switch_event_fire(&event); + } + } else { //no session + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "during-call", "false"); + switch_event_fire(&event); + event_sent_to_esl = 1; + } + + } else { + ERRORA("cannot create event on interface %s. WHY?????\n", GSMOPEN_P_LOG, tech_pvt->name); + } + + if (!event_sent_to_esl) { + + if (switch_event_create(&event, SWITCH_EVENT_MESSAGE) == SWITCH_STATUS_SUCCESS) { + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "proto", MDL_CHAT_PROTO); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "login", tech_pvt->name); + //switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "hint", tech_pvt->chatmessages[which].from_dispname); + //switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "from", tech_pvt->chatmessages[which].from_handle); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "from", tech_pvt->sms_sender); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "date", tech_pvt->sms_date); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "datacodingscheme", tech_pvt->sms_datacodingscheme); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "servicecentreaddress", tech_pvt->sms_servicecentreaddress); + switch_event_add_header(event, SWITCH_STACK_BOTTOM, "messagetype", "%d", tech_pvt->sms_messagetype); + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "subject", "SIMPLE MESSAGE"); + //switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "chatname", tech_pvt->chatmessages[which].chatname); + //switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "id", tech_pvt->chatmessages[which].id); + switch_event_add_body(event, "%s\n", tech_pvt->sms_body); + if (session) { + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "during-call", "true"); + } else { //no session + switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "during-call", "false"); + } + switch_event_fire(&event); + } else { + ERRORA("cannot create event on interface %s. WHY?????\n", GSMOPEN_P_LOG, tech_pvt->name); + } + } + + if (session) { + switch_core_session_rwunlock(session); + } + //memset(&tech_pvt->chatmessages[which], '\0', sizeof(&tech_pvt->chatmessages[which]) ); + //memset(tech_pvt->sms_message, '\0', sizeof(tech_pvt->sms_message)); + return 0; +} + + +#ifdef NOTDEF +SWITCH_STANDARD_API(gsmopen_chat_function) +{ + char *mycmd = NULL, *argv[10] = { 0 }; + int argc = 0; + private_t *tech_pvt = NULL; + //int tried =0; + int i; + int found = 0; + //char skype_msg[1024]; + + if (!zstr(cmd) && (mycmd = strdup(cmd))) { + argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0]))); + } + + if (!argc) { + stream->write_function(stream, "ERROR, usage: %s", GSMOPEN_CHAT_SYNTAX); + goto end; + } + + if (argc < 3) { + stream->write_function(stream, "ERROR, usage: %s", GSMOPEN_CHAT_SYNTAX); + goto end; + } + + if (argv[0]) { + for (i = 0; !found && i < GSMOPEN_MAX_INTERFACES; i++) { + /* we've been asked for a normal interface name, or we have not found idle interfaces to serve as the "ANY" interface */ + if (strlen(globals.GSMOPEN_INTERFACES[i].name) + && (strncmp(globals.GSMOPEN_INTERFACES[i].name, argv[0], strlen(argv[0])) == 0)) { + tech_pvt = &globals.GSMOPEN_INTERFACES[i]; + stream->write_function(stream, "Using interface: globals.GSMOPEN_INTERFACES[%d].name=|||%s|||\n", i, globals.GSMOPEN_INTERFACES[i].name); + found = 1; + break; + } + + } + if (!found) { + stream->write_function(stream, "ERROR: A GSMopen interface with name='%s' was not found\n", argv[0]); + goto end; + } else { + + //chat_send(const char *proto, const char *from, const char *to, const char *subject, const char *body, const char *type, const char *hint); + //chat_send(p*roto, const char *from, const char *to, const char *subject, const char *body, const char *type, const char *hint); + //chat_send(MDL_CHAT_PROTO, tech_pvt->skype_user, argv[1], "SIMPLE MESSAGE", switch_str_nil((char *) &cmd[strlen(argv[0]) + 1 + strlen(argv[1]) + 1]), NULL, hint); + + NOTICA("chat_send(proto=%s, from=%s, to=%s, subject=%s, body=%s, type=NULL, hint=%s)\n", GSMOPEN_P_LOG, MDL_CHAT_PROTO, tech_pvt->skype_user, + argv[1], "SIMPLE MESSAGE", switch_str_nil((char *) &cmd[strlen(argv[0]) + 1 + strlen(argv[1]) + 1]), tech_pvt->name); + + chat_send(MDL_CHAT_PROTO, tech_pvt->skype_user, argv[1], "SIMPLE MESSAGE", + switch_str_nil((char *) &cmd[strlen(argv[0]) + 1 + strlen(argv[1]) + 1]), NULL, tech_pvt->name); + + //NOTICA("TEXT is: %s\n", GSMOPEN_P_LOG, (char *) &cmd[strlen(argv[0]) + 1 + strlen(argv[1]) + 1] ); + //snprintf(skype_msg, sizeof(skype_msg), "CHAT CREATE %s", argv[1]); + //gsmopen_signaling_write(tech_pvt, skype_msg); + //switch_sleep(100); + } + } else { + stream->write_function(stream, "ERROR, usage: %s", GSMOPEN_CHAT_SYNTAX); + goto end; + } + +#ifdef NOTDEF + + found = 0; + + while (!found) { + for (i = 0; i < MAX_CHATS; i++) { + if (!strcmp(tech_pvt->chats[i].dialog_partner, argv[1])) { + snprintf(skype_msg, sizeof(skype_msg), "CHATMESSAGE %s %s", tech_pvt->chats[i].chatname, + (char *) &cmd[strlen(argv[0]) + 1 + strlen(argv[1]) + 1]); + gsmopen_signaling_write(tech_pvt, skype_msg); + found = 1; + break; + } + } + if (found) { + break; + } + if (tried > 1000) { + stream->write_function(stream, "ERROR: no chat with dialog_partner='%s' was found\n", argv[1]); + break; + } + switch_sleep(1000); + } +#endif //NOTDEF + + end: + switch_safe_free(mycmd); + + return SWITCH_STATUS_SUCCESS; +} +#endif // NOTDEF + + +/* For Emacs: + * Local Variables: + * mode:c + * indent-tabs-mode:t + * tab-width:4 + * c-basic-offset:4 + * End: + * For VIM: + * vim:set softtabstop=4 shiftwidth=4 tabstop=4 expandtab: + */ diff --git a/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/Makefile b/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/Makefile new file mode 100644 index 0000000000..c2cf8be76b --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/Makefile @@ -0,0 +1,6 @@ +MODNAME=mod_gsmopen +SVNDEF := -D'GSMOPEN_SVN_VERSION="$(shell svnversion -n .)"' +LOCAL_CFLAGS += $(SVNDEF) -DNO_ALSA -I../../../../../../libs/spandsp/src -I../../../../../..//libs/tiff-3.8.2/libtiff +LOCAL_LDFLAGS=-lgsmme -L../../../../../../libs/spandsp/src -avoid-version -module -no-undefined -shared -lspandsp +LOCAL_OBJS=gsmopen_protocol.o +include ../../../../../../build/modmake.rules diff --git a/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/gsmopen.h b/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/gsmopen.h new file mode 120000 index 0000000000..663f1cbc4d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/gsmopen.h @@ -0,0 +1 @@ +../../gsmopen.h \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/gsmopen_protocol.cpp b/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/gsmopen_protocol.cpp new file mode 120000 index 0000000000..b03564bdd9 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/gsmopen_protocol.cpp @@ -0,0 +1 @@ +../../gsmopen_protocol.cpp \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/mod_gsmopen.cpp b/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/mod_gsmopen.cpp new file mode 120000 index 0000000000..a0686ea786 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/noaudio_gsmlib_cplusplus/mod_gsmopen/mod_gsmopen.cpp @@ -0,0 +1 @@ +../../mod_gsmopen.cpp \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/Makefile b/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/Makefile new file mode 100644 index 0000000000..3a50b1f227 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/Makefile @@ -0,0 +1,6 @@ +MODNAME=mod_gsmopen +SVNDEF := -D'GSMOPEN_SVN_VERSION="$(shell svnversion -n .)"' +LOCAL_CFLAGS += $(SVNDEF) -DNO_GSMLIB -DNO_ALSA -I../../../../../../libs/spandsp/src -I../../../../../..//libs/tiff-3.8.2/libtiff +LOCAL_LDFLAGS=-L../../../../../../libs/spandsp/src -avoid-version -module -no-undefined -shared -lspandsp +LOCAL_OBJS=gsmopen_protocol.o +include ../../../../../../build/modmake.rules diff --git a/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/gsmopen.h b/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/gsmopen.h new file mode 120000 index 0000000000..663f1cbc4d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/gsmopen.h @@ -0,0 +1 @@ +../../gsmopen.h \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/gsmopen_protocol.c b/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/gsmopen_protocol.c new file mode 120000 index 0000000000..b03564bdd9 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/gsmopen_protocol.c @@ -0,0 +1 @@ +../../gsmopen_protocol.cpp \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/mod_gsmopen.c b/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/mod_gsmopen.c new file mode 120000 index 0000000000..a0686ea786 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/noaudio_nogsmlib_nocplusplus/mod_gsmopen/mod_gsmopen.c @@ -0,0 +1 @@ +../../mod_gsmopen.cpp \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/pa_ringbuffer.c b/src/mod/endpoints/mod_gsmopen/pa_ringbuffer.c new file mode 100644 index 0000000000..b632c06084 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/pa_ringbuffer.c @@ -0,0 +1,275 @@ +/* + * $Id: pa_ringbuffer.c 1164 2006-12-21 15:34:50Z bjornroche $ + * Portable Audio I/O Library + * Ring Buffer utility. + * + * Author: Phil Burk, http://www.softsynth.com + * modified for SMP safety on Mac OS X by Bjorn Roche + * modified for SMP safety on Linux by Leland Lucius + * also, allowed for const where possible + * Note that this is safe only for a single-thread reader and a + * single-thread writer. + * + * This program uses the PortAudio Portable Audio Library. + * For more information see: http://www.portaudio.com + * Copyright (c) 1999-2000 Ross Bencina and Phil Burk + * + * 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 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR + * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF + * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION + * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ + +/* + * The text above constitutes the entire PortAudio license; however, + * the PortAudio community also makes the following non-binding requests: + * + * Any person wishing to distribute modifications to the Software is + * requested to send the modifications to the original developer so that + * they can be incorporated into the canonical version. It is also + * requested that these non-binding requests be included along with the + * license above. + */ + +/** + @file + @ingroup common_src +*/ + +#include +#include +#include +#include "pa_ringbuffer.h" +#include + +/**************** + * First, we'll define some memory barrier primitives based on the system. + * right now only OS X, FreeBSD, and Linux are supported. In addition to providing + * memory barriers, these functions should ensure that data cached in registers + * is written out to cache where it can be snooped by other CPUs. (ie, the volatile + * keyword should not be required) + * + * the primitives that must be defined are: + * + * PaUtil_FullMemoryBarrier() + * PaUtil_ReadMemoryBarrier() + * PaUtil_WriteMemoryBarrier() + * + ****************/ +#define __VIA_HACK__ +#if defined(__VIA_HACK__) +#define NO_BARRIER +#endif + +#if defined(NO_BARRIER) +# define PaUtil_FullMemoryBarrier() +# define PaUtil_ReadMemoryBarrier() +# define PaUtil_WriteMemoryBarrier() +#else + +#if defined(__APPLE__) //|| defined(__FreeBSD__) +# include + /* Here are the memory barrier functions. Mac OS X and FreeBSD only provide + full memory barriers, so the three types of barriers are the same. */ +# define PaUtil_FullMemoryBarrier() OSMemoryBarrier() +# define PaUtil_ReadMemoryBarrier() OSMemoryBarrier() +# define PaUtil_WriteMemoryBarrier() OSMemoryBarrier() +#elif defined(__GNUC__) + + /* GCC understands volatile asm and "memory" to mean it + * should not reorder memory read/writes */ +# if defined( __PPC__ ) +# define PaUtil_FullMemoryBarrier() __asm__ volatile("sync":::"memory") +# define PaUtil_ReadMemoryBarrier() __asm__ volatile("sync":::"memory") +# define PaUtil_WriteMemoryBarrier() __asm__ volatile("sync":::"memory") +# elif defined( __i386__ ) || defined( __i486__ ) || defined( __i586__ ) || defined( __i686__ ) || defined(__x86_64__) +# define PaUtil_FullMemoryBarrier() __asm__ volatile("mfence":::"memory") +# define PaUtil_ReadMemoryBarrier() __asm__ volatile("lfence":::"memory") +# define PaUtil_WriteMemoryBarrier() __asm__ volatile("sfence":::"memory") +# else +# define PaUtil_FullMemoryBarrier() +# define PaUtil_ReadMemoryBarrier() +# define PaUtil_WriteMemoryBarrier() +# endif +#elif defined(_MSC_VER) +# include +# pragma intrinsic(_ReadWriteBarrier) +# pragma intrinsic(_ReadBarrier) +# pragma intrinsic(_WriteBarrier) +# define PaUtil_FullMemoryBarrier() _ReadWriteBarrier() +# define PaUtil_ReadMemoryBarrier() _ReadBarrier() +# define PaUtil_WriteMemoryBarrier() _WriteBarrier() +#else +# define PaUtil_FullMemoryBarrier() +# define PaUtil_ReadMemoryBarrier() +# define PaUtil_WriteMemoryBarrier() +#endif +#endif +/*************************************************************************** + * Initialize FIFO. + * numBytes must be power of 2, returns -1 if not. + */ +long PaUtil_InitializeRingBuffer(PaUtilRingBuffer * rbuf, long numBytes, void *dataPtr) +{ + if (((numBytes - 1) & numBytes) != 0) + return -1; /* Not Power of two. */ + rbuf->bufferSize = numBytes; + rbuf->buffer = (char *) dataPtr; + PaUtil_FlushRingBuffer(rbuf); + rbuf->bigMask = (numBytes * 2) - 1; + rbuf->smallMask = (numBytes) - 1; + return 0; +} + +/*************************************************************************** +** Return number of bytes available for reading. */ +long PaUtil_GetRingBufferReadAvailable(PaUtilRingBuffer * rbuf) +{ + PaUtil_ReadMemoryBarrier(); + return ((rbuf->writeIndex - rbuf->readIndex) & rbuf->bigMask); +} + +/*************************************************************************** +** Return number of bytes available for writing. */ +long PaUtil_GetRingBufferWriteAvailable(PaUtilRingBuffer * rbuf) +{ + /* Since we are calling PaUtil_GetRingBufferReadAvailable, we don't need an aditional MB */ + return (rbuf->bufferSize - PaUtil_GetRingBufferReadAvailable(rbuf)); +} + +/*************************************************************************** +** Clear buffer. Should only be called when buffer is NOT being read. */ +void PaUtil_FlushRingBuffer(PaUtilRingBuffer * rbuf) +{ + rbuf->writeIndex = rbuf->readIndex = 0; +} + +/*************************************************************************** +** Get address of region(s) to which we can write data. +** If the region is contiguous, size2 will be zero. +** If non-contiguous, size2 will be the size of second region. +** Returns room available to be written or numBytes, whichever is smaller. +*/ +long PaUtil_GetRingBufferWriteRegions(PaUtilRingBuffer * rbuf, long numBytes, void **dataPtr1, long *sizePtr1, void **dataPtr2, long *sizePtr2) +{ + long index; + long available = PaUtil_GetRingBufferWriteAvailable(rbuf); + if (numBytes > available) + numBytes = available; + /* Check to see if write is not contiguous. */ + index = rbuf->writeIndex & rbuf->smallMask; + if ((index + numBytes) > rbuf->bufferSize) { + /* Write data in two blocks that wrap the buffer. */ + long firstHalf = rbuf->bufferSize - index; + *dataPtr1 = &rbuf->buffer[index]; + *sizePtr1 = firstHalf; + *dataPtr2 = &rbuf->buffer[0]; + *sizePtr2 = numBytes - firstHalf; + } else { + *dataPtr1 = &rbuf->buffer[index]; + *sizePtr1 = numBytes; + *dataPtr2 = NULL; + *sizePtr2 = 0; + } + return numBytes; +} + + +/*************************************************************************** +*/ +long PaUtil_AdvanceRingBufferWriteIndex(PaUtilRingBuffer * rbuf, long numBytes) +{ + /* we need to ensure that previous writes are seen before we update the write index */ + PaUtil_WriteMemoryBarrier(); + return rbuf->writeIndex = (rbuf->writeIndex + numBytes) & rbuf->bigMask; +} + +/*************************************************************************** +** Get address of region(s) from which we can read data. +** If the region is contiguous, size2 will be zero. +** If non-contiguous, size2 will be the size of second region. +** Returns room available to be written or numBytes, whichever is smaller. +*/ +long PaUtil_GetRingBufferReadRegions(PaUtilRingBuffer * rbuf, long numBytes, void **dataPtr1, long *sizePtr1, void **dataPtr2, long *sizePtr2) +{ + long index; + long available = PaUtil_GetRingBufferReadAvailable(rbuf); + if (numBytes > available) + numBytes = available; + /* Check to see if read is not contiguous. */ + index = rbuf->readIndex & rbuf->smallMask; + if ((index + numBytes) > rbuf->bufferSize) { + /* Write data in two blocks that wrap the buffer. */ + long firstHalf = rbuf->bufferSize - index; + *dataPtr1 = &rbuf->buffer[index]; + *sizePtr1 = firstHalf; + *dataPtr2 = &rbuf->buffer[0]; + *sizePtr2 = numBytes - firstHalf; + } else { + *dataPtr1 = &rbuf->buffer[index]; + *sizePtr1 = numBytes; + *dataPtr2 = NULL; + *sizePtr2 = 0; + } + return numBytes; +} + +/*************************************************************************** +*/ +long PaUtil_AdvanceRingBufferReadIndex(PaUtilRingBuffer * rbuf, long numBytes) +{ + /* we need to ensure that previous writes are always seen before updating the index. */ + PaUtil_WriteMemoryBarrier(); + return rbuf->readIndex = (rbuf->readIndex + numBytes) & rbuf->bigMask; +} + +/*************************************************************************** +** Return bytes written. */ +long PaUtil_WriteRingBuffer(PaUtilRingBuffer * rbuf, const void *data, long numBytes) +{ + long size1, size2, numWritten; + void *data1, *data2; + numWritten = PaUtil_GetRingBufferWriteRegions(rbuf, numBytes, &data1, &size1, &data2, &size2); + if (size2 > 0) { + + memcpy(data1, data, size1); + data = ((char *) data) + size1; + memcpy(data2, data, size2); + } else { + memcpy(data1, data, size1); + } + PaUtil_AdvanceRingBufferWriteIndex(rbuf, numWritten); + return numWritten; +} + +/*************************************************************************** +** Return bytes read. */ +long PaUtil_ReadRingBuffer(PaUtilRingBuffer * rbuf, void *data, long numBytes) +{ + long size1, size2, numRead; + void *data1, *data2; + numRead = PaUtil_GetRingBufferReadRegions(rbuf, numBytes, &data1, &size1, &data2, &size2); + if (size2 > 0) { + memcpy(data, data1, size1); + data = ((char *) data) + size1; + memcpy(data, data2, size2); + } else { + memcpy(data, data1, size1); + } + PaUtil_AdvanceRingBufferReadIndex(rbuf, numRead); + return numRead; +} diff --git a/src/mod/endpoints/mod_gsmopen/pa_ringbuffer.h b/src/mod/endpoints/mod_gsmopen/pa_ringbuffer.h new file mode 100644 index 0000000000..ae026c02dd --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/pa_ringbuffer.h @@ -0,0 +1,192 @@ +#ifndef PA_RINGBUFFER_H +#define PA_RINGBUFFER_H +/* + * $Id: pa_ringbuffer.h 1151 2006-11-29 02:11:16Z leland_lucius $ + * Portable Audio I/O Library + * Ring Buffer utility. + * + * Author: Phil Burk, http://www.softsynth.com + * modified for SMP safety on OS X by Bjorn Roche. + * also allowed for const where possible. + * Note that this is safe only for a single-thread reader + * and a single-thread writer. + * + * This program is distributed with the PortAudio Portable Audio Library. + * For more information see: http://www.portaudio.com + * Copyright (c) 1999-2000 Ross Bencina and Phil Burk + * + * 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 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR + * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF + * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION + * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ + +/* + * The text above constitutes the entire PortAudio license; however, + * the PortAudio community also makes the following non-binding requests: + * + * Any person wishing to distribute modifications to the Software is + * requested to send the modifications to the original developer so that + * they can be incorporated into the canonical version. It is also + * requested that these non-binding requests be included along with the + * license above. + */ + +/** @file + @ingroup common_src +*/ + +#ifdef __cplusplus +extern "C" { +#endif /* __cplusplus */ + + typedef struct PaUtilRingBuffer { + long bufferSize; /* Number of bytes in FIFO. Power of 2. Set by PaUtil_InitRingBuffer. */ + long writeIndex; /* Index of next writable byte. Set by PaUtil_AdvanceRingBufferWriteIndex. */ + long readIndex; /* Index of next readable byte. Set by PaUtil_AdvanceRingBufferReadIndex. */ + long bigMask; /* Used for wrapping indices with extra bit to distinguish full/empty. */ + long smallMask; /* Used for fitting indices to buffer. */ + char *buffer; + } PaUtilRingBuffer; + +/** Initialize Ring Buffer. + + @param rbuf The ring buffer. + + @param numBytes The number of bytes in the buffer and must be power of 2. + + @param dataPtr A pointer to a previously allocated area where the data + will be maintained. It must be numBytes long. + + @return -1 if numBytes is not a power of 2, otherwise 0. +*/ + long PaUtil_InitializeRingBuffer(PaUtilRingBuffer * rbuf, long numBytes, void *dataPtr); + +/** Clear buffer. Should only be called when buffer is NOT being read. + + @param rbuf The ring buffer. +*/ + void PaUtil_FlushRingBuffer(PaUtilRingBuffer * rbuf); + +/** Retrieve the number of bytes available in the ring buffer for writing. + + @param rbuf The ring buffer. + + @return The number of bytes available for writing. +*/ + long PaUtil_GetRingBufferWriteAvailable(PaUtilRingBuffer * rbuf); + +/** Retrieve the number of bytes available in the ring buffer for reading. + + @param rbuf The ring buffer. + + @return The number of bytes available for reading. +*/ + long PaUtil_GetRingBufferReadAvailable(PaUtilRingBuffer * rbuf); + +/** Write data to the ring buffer. + + @param rbuf The ring buffer. + + @param data The address of new data to write to the buffer. + + @param numBytes The number of bytes to be written. + + @return The number of bytes written. +*/ + long PaUtil_WriteRingBuffer(PaUtilRingBuffer * rbuf, const void *data, long numBytes); + +/** Read data from the ring buffer. + + @param rbuf The ring buffer. + + @param data The address where the data should be stored. + + @param numBytes The number of bytes to be read. + + @return The number of bytes read. +*/ + long PaUtil_ReadRingBuffer(PaUtilRingBuffer * rbuf, void *data, long numBytes); + +/** Get address of region(s) to which we can write data. + + @param rbuf The ring buffer. + + @param numBytes The number of bytes desired. + + @param dataPtr1 The address where the first (or only) region pointer will be + stored. + + @param sizePtr1 The address where the first (or only) region length will be + stored. + + @param dataPtr2 The address where the second region pointer will be stored if + the first region is too small to satisfy numBytes. + + @param sizePtr2 The address where the second region length will be stored if + the first region is too small to satisfy numBytes. + + @return The room available to be written or numBytes, whichever is smaller. +*/ + long PaUtil_GetRingBufferWriteRegions(PaUtilRingBuffer * rbuf, long numBytes, void **dataPtr1, long *sizePtr1, void **dataPtr2, long *sizePtr2); + +/** Advance the write index to the next location to be written. + + @param rbuf The ring buffer. + + @param numBytes The number of bytes to advance. + + @return The new position. +*/ + long PaUtil_AdvanceRingBufferWriteIndex(PaUtilRingBuffer * rbuf, long numBytes); + +/** Get address of region(s) from which we can write data. + + @param rbuf The ring buffer. + + @param numBytes The number of bytes desired. + + @param dataPtr1 The address where the first (or only) region pointer will be + stored. + + @param sizePtr1 The address where the first (or only) region length will be + stored. + + @param dataPtr2 The address where the second region pointer will be stored if + the first region is too small to satisfy numBytes. + + @param sizePtr2 The address where the second region length will be stored if + the first region is too small to satisfy numBytes. + + @return The number of bytes available for reading. +*/ + long PaUtil_GetRingBufferReadRegions(PaUtilRingBuffer * rbuf, long numBytes, void **dataPtr1, long *sizePtr1, void **dataPtr2, long *sizePtr2); + +/** Advance the read index to the next location to be read. + + @param rbuf The ring buffer. + + @param numBytes The number of bytes to advance. + + @return The new position. +*/ + long PaUtil_AdvanceRingBufferReadIndex(PaUtilRingBuffer * rbuf, long numBytes); + +#ifdef __cplusplus +} +#endif /* __cplusplus */ +#endif /* PA_RINGBUFFER_H */ diff --git a/src/mod/endpoints/mod_gsmopen/pablio.c b/src/mod/endpoints/mod_gsmopen/pablio.c new file mode 100644 index 0000000000..aa54d7ae15 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/pablio.c @@ -0,0 +1,720 @@ +/* + * $Id: pablio.c 1151 2006-11-29 02:11:16Z leland_lucius $ + * pablio.c + * Portable Audio Blocking Input/Output utility. + * + * Author: Phil Burk, http://www.softsynth.com + * + * This program uses the PortAudio Portable Audio Library. + * For more information see: http://www.portaudio.com + * Copyright (c) 1999-2000 Ross Bencina and Phil Burk + * + * 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 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR + * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF + * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION + * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ + +/* + * The text above constitutes the entire PortAudio license; however, + * the PortAudio community also makes the following non-binding requests: + * + * Any person wishing to distribute modifications to the Software is + * requested to send the modifications to the original developer so that + * they can be incorporated into the canonical version. It is also + * requested that these non-binding requests be included along with the + * license above. + */ +#define WANT_SPEEX +#include +#include +#include +#include +#include "portaudio.h" +#include "pa_ringbuffer.h" +#include "pablio.h" +#include +#include +#ifdef WANT_SPEEX +#include "speex/speex_preprocess.h" +#include "speex/speex_echo.h" + SpeexPreprocessState *preprocess; + SpeexPreprocessState *preprocess2; + SpeexEchoState *echo_state; + + int speexecho=1; + int speexpreprocess=1; +#endif// WANT_SPEEX + +/************************************************************************/ +/******** Prototypes ****************************************************/ +/************************************************************************/ + +static int iblockingIOCallback(const void *inputBuffer, void *outputBuffer, + unsigned long framesPerBuffer, const PaStreamCallbackTimeInfo * timeInfo, PaStreamCallbackFlags statusFlags, void *userData); +static int oblockingIOCallback(const void *inputBuffer, void *outputBuffer, + unsigned long framesPerBuffer, const PaStreamCallbackTimeInfo * timeInfo, PaStreamCallbackFlags statusFlags, void *userData); + +static int ioblockingIOCallback(const void *inputBuffer, void *outputBuffer, + unsigned long framesPerBuffer, const PaStreamCallbackTimeInfo * timeInfo, PaStreamCallbackFlags statusFlags, void *userData); + +static PaError PABLIO_InitFIFO(PaUtilRingBuffer * rbuf, long numFrames, long bytesPerFrame); +static PaError PABLIO_TermFIFO(PaUtilRingBuffer * rbuf); + +/************************************************************************/ +/******** Functions *****************************************************/ +/************************************************************************/ + +/* Called from PortAudio. + * Read and write data + */ +static int iblockingIOCallback(const void *inputBuffer, void *outputBuffer, + unsigned long framesPerBuffer, const PaStreamCallbackTimeInfo * timeInfo, PaStreamCallbackFlags statusFlags, void *userData) +{ + PABLIO_Stream *data = (PABLIO_Stream *) userData; + long numBytes = data->bytesPerFrame * framesPerBuffer; +#ifdef WANT_SPEEX + spx_int16_t *speexptr=NULL; + spx_int16_t pcm2[160]; + int i; +#endif// WANT_SPEEX + + /* This may get called with NULL inputBuffer during initial setup. */ + if (inputBuffer != NULL) { +#ifdef WANT_SPEEX + //FIXME speex_echo_cancellation(echo_state, inputBuffer, outputBuffer, pcm2); + //FIXME speexptr=(spx_int16_t *)inputBuffer; + //FIXME for (i = 0; i < 160; i++) + //FIXME speexptr[i] = pcm2[i]; + //FIXME speex_preprocess_run(preprocess, speexptr); +#if 1 + if (speexecho) { + speexptr = ((spx_int16_t *) inputBuffer); + + /* Perform echo cancellation */ + speex_echo_capture(echo_state, speexptr, pcm2); +#ifndef GIOVA48 + for (i = 0; i < 160; i++) +#else //GIOVA48 + for (i = 0; i < 960; i++) +#endif //GIOVA48 + speexptr[i] = pcm2[i]; + //printf("read\n"); + } + if (speexpreprocess) { + speex_preprocess_run(preprocess, speexptr); + } + /* Apply noise/echo residual suppression */ +#endif +#endif //WANT_SPEEX + + + if (PaUtil_WriteRingBuffer(&data->inFIFO, inputBuffer, numBytes) != numBytes) { + PaUtil_FlushRingBuffer(&data->inFIFO); + PaUtil_WriteRingBuffer(&data->inFIFO, inputBuffer, numBytes); + printf("HEEEEEEEEEEEj\n"); + speex_echo_state_reset(echo_state); + } + } + + return 0; +} + +static int oblockingIOCallback(const void *inputBuffer, void *outputBuffer, + unsigned long framesPerBuffer, const PaStreamCallbackTimeInfo * timeInfo, PaStreamCallbackFlags statusFlags, void *userData) +{ + PABLIO_Stream *data = (PABLIO_Stream *) userData; + long numBytes = data->bytesPerFrame * framesPerBuffer; +#ifdef WANT_SPEEX + spx_int16_t *speexptr=NULL; + //spx_int16_t pcm2[160]; + //int i; +#endif// WANT_SPEEX + + + if (outputBuffer != NULL) { + int i; + int numRead = PaUtil_ReadRingBuffer(&data->outFIFO, outputBuffer, numBytes); + /* Zero out remainder of buffer if we run out of data. */ + for (i = numRead; i < numBytes; i++) { + ((char *) outputBuffer)[i] = 0; + } + + if(numRead == 0){ + //printf("ZERO\n"); + //usleep(60000); + //speex_echo_state_reset(echo_state); + } +#ifdef WANT_SPEEX + //FIXME speexptr = (spx_int16_t *) outputBuffer; + //FIXME speex_preprocess_run(preprocess2, speexptr); +#if 1 + if (speexecho ) { + speexptr = (spx_int16_t *) outputBuffer; + if (speexpreprocess && numRead) { + //speex_preprocess_run(preprocess2, speexptr); + } + + + + /* Put frame into playback buffer */ + speex_echo_playback(echo_state, speexptr); + //printf("write\n"); + } + +#endif +#endif //WANT_SPEEX + + + } + + return 0; +} + +static int ioblockingIOCallback(const void *inputBuffer, void *outputBuffer, + unsigned long framesPerBuffer, const PaStreamCallbackTimeInfo * timeInfo, PaStreamCallbackFlags statusFlags, void *userData) +{ + + +//write + oblockingIOCallback(inputBuffer, outputBuffer, framesPerBuffer, timeInfo, statusFlags, userData); +//read + iblockingIOCallback(inputBuffer, outputBuffer, framesPerBuffer, timeInfo, statusFlags, userData); + + return 0; +} + +/* Allocate buffer. */ +static PaError PABLIO_InitFIFO(PaUtilRingBuffer * rbuf, long numFrames, long bytesPerFrame) +{ + long numBytes = numFrames * bytesPerFrame; + char *buffer = (char *) malloc(numBytes); + if (buffer == NULL) + return paInsufficientMemory; + memset(buffer, 0, numBytes); + return (PaError) PaUtil_InitializeRingBuffer(rbuf, numBytes, buffer); +} + +/* Free buffer. */ +static PaError PABLIO_TermFIFO(PaUtilRingBuffer * rbuf) +{ + if (rbuf->buffer) + free(rbuf->buffer); + rbuf->buffer = NULL; + return paNoError; +} + +/************************************************************ + * Write data to ring buffer. + * Will not return until all the data has been written. + */ +long WriteAudioStream(PABLIO_Stream * aStream, void *data, long numFrames, switch_timer_t *timer) +{ + long bytesWritten; + char *p = (char *) data; + long numBytes = aStream->bytesPerFrame * numFrames; + + switch_core_timer_next(timer); + + bytesWritten = PaUtil_WriteRingBuffer(&aStream->outFIFO, p, numBytes); + numBytes -= bytesWritten; + p += bytesWritten; + + if (numBytes > 0) { + PaUtil_FlushRingBuffer(&aStream->outFIFO); + printf("2HEEEEEEEEEEEj\n"); + speex_echo_state_reset(echo_state); + return 0; + } + return numFrames; +} + +/************************************************************ + * Read data from ring buffer. + * Will not return until all the data has been read. + */ +long ReadAudioStream(PABLIO_Stream * aStream, void *data, long numFrames, switch_timer_t *timer) +{ + long bytesRead = 0; + char *p = (char *) data; + long avail, totalBytes = 0, neededBytes = aStream->bytesPerFrame * numFrames; + int max = 5000; + + switch_core_timer_next(timer); + + while(totalBytes < neededBytes && --max > 0) { + + avail = PaUtil_GetRingBufferReadAvailable(&aStream->inFIFO); + //printf("AVAILABLE BYTES %ld , neededBytes %ld, pass %d\n", avail, neededBytes, 5000 - max); + if (avail >= neededBytes * 6) { + PaUtil_FlushRingBuffer(&aStream->inFIFO); + printf("3HEEEEEEEEEEEj\n"); + speex_echo_state_reset(echo_state); + avail = 0; + } else { + + bytesRead = 0; + + if (totalBytes < neededBytes && avail >= neededBytes) { + bytesRead = PaUtil_ReadRingBuffer(&aStream->inFIFO, p, neededBytes); + totalBytes += bytesRead; + } + + if (bytesRead) { + p += bytesRead; + } else { + switch_cond_next(); + } + } + } + + //printf("return=%ld\n", totalBytes / aStream->bytesPerFrame); + return totalBytes / aStream->bytesPerFrame; +} + +/************************************************************ + * Return the number of frames that could be written to the stream without + * having to wait. + */ +long GetAudioStreamWriteable(PABLIO_Stream * aStream) +{ + int bytesEmpty = PaUtil_GetRingBufferWriteAvailable(&aStream->outFIFO); + return bytesEmpty / aStream->bytesPerFrame; +} + +/************************************************************ + * Return the number of frames that are available to be read from the + * stream without having to wait. + */ +long GetAudioStreamReadable(PABLIO_Stream * aStream) +{ + int bytesFull = PaUtil_GetRingBufferReadAvailable(&aStream->inFIFO); + return bytesFull / aStream->bytesPerFrame; +} + +/***********************************************************/ +static unsigned long RoundUpToNextPowerOf2(unsigned long n) +{ + long numBits = 0; + if (((n - 1) & n) == 0) + return n; + while (n > 0) { + n = n >> 1; + numBits++; + } + return (1 << numBits); +} + + + +/************************************************************ + * Opens a PortAudio stream with default characteristics. + * Allocates PABLIO_Stream structure. + * + */ +PaError OpenAudioStream(PABLIO_Stream ** rwblPtr, + const PaStreamParameters * inputParameters, + const PaStreamParameters * outputParameters, + double sampleRate, PaStreamFlags streamFlags, + long samples_per_packet, + int do_dual) +{ + long bytesPerSample = 2; + PaError err; + PABLIO_Stream *aStream; + long numFrames; + //long numBytes; + int channels = 1; +#ifdef WANT_SPEEX + int ciapa; + float level; + int tmp; +#endif //WANT_SPEEX + + + if (!(inputParameters || outputParameters)) { + return -1; + } + + /* Allocate PABLIO_Stream structure for caller. */ + aStream = (PABLIO_Stream *) malloc(sizeof(PABLIO_Stream)); + switch_assert(aStream); + memset(aStream, 0, sizeof(PABLIO_Stream)); + + if (inputParameters) { + channels = inputParameters->channelCount; + } else if (outputParameters) { + channels = outputParameters->channelCount; + } + + numFrames = RoundUpToNextPowerOf2(samples_per_packet * 5); + aStream->bytesPerFrame = bytesPerSample; + + /* Initialize Ring Buffers */ + + if (inputParameters) { + err = PABLIO_InitFIFO(&aStream->inFIFO, numFrames, aStream->bytesPerFrame); + if (err != paNoError) { + goto error; + } + aStream-> has_in = 1; + } + + if (outputParameters) { + err = PABLIO_InitFIFO(&aStream->outFIFO, numFrames, aStream->bytesPerFrame); + if (err != paNoError) { + goto error; + } + aStream-> has_out = 1; + } +#ifdef WANT_SPEEX + /* Echo canceller with 100 ms tail length */ +#ifndef GIOVA48 + echo_state = speex_echo_state_init(160, 1600); + ciapa = 8000; +#else// GIOVA48 + echo_state = speex_echo_state_init(960, 4800); + ciapa = 48000; +#endif // GIOVA48 + speex_echo_ctl(echo_state, SPEEX_ECHO_SET_SAMPLING_RATE, &ciapa); + +#if 1 //NO MORE + /* Setup preprocessor and associate with echo canceller for residual echo suppression */ +#ifndef GIOVA48 + preprocess = speex_preprocess_state_init(160, 8000); +#else// GIOVA48 + preprocess = speex_preprocess_state_init(960, 48000); +#endif // GIOVA48 + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_ECHO_STATE, + echo_state); + +#if 0 + /* Setup preprocessor various other goodies */ + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_AGC, &tmp); + level=8000.1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_AGC_LEVEL, &level); + + tmp = 8000; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_AGC_TARGET, &tmp); + + //FIXME tmp = 60; + //FIXME speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_AGC_MAX_GAIN, &tmp); + //FIXME fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_MAX_GAIN is: %d\n", tmp); + //FIXME tmp = 40; + //FIXME speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_AGC_INCREMENT, &tmp); + //FIXME fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_INCREMENT is: %d\n", tmp); + //FIXME tmp = -40; + //FIXME speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_AGC_DECREMENT, &tmp); + //FIXME fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_DECREMENT is: %d\n", tmp); + +#if 0 + // Let's turn off all of the 'denoisers' (eg denoise and dereverb, and vad too) because they start automatic gain on mic input on cm108 usb, also if it (the agc on usb) disbled through mixer + tmp = 0; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_DENOISE, &tmp); + tmp = 0; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_DEREVERB, &tmp); + tmp = 0; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_VAD, &tmp); +#endif + + //tmp = 0; + //speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_SET_DENOISE, &tmp); + tmp = 1; +#endif //0 + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_AGC, &tmp); + fprintf(stderr, "AGC is: %d\n", tmp); + level = 1.0; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_AGC_LEVEL, &level); + fprintf(stderr, "AGC_LEVEL is: %f\n", level); + //tmp=1; + //speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_AGC_TARGET, &tmp); + //fprintf( stderr, "AGC_TARGET is: %d\n", tmp ); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_DENOISE, &tmp); + fprintf(stderr, "DENOISE is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_DEREVERB, &tmp); + fprintf(stderr, "DEREVERB is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_VAD, &tmp); + fprintf(stderr, "VAD is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_AGC_MAX_GAIN, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_MAX_GAIN is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_AGC_INCREMENT, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_INCREMENT is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_AGC_DECREMENT, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_DECREMENT is: %d\n", tmp); + +#if 0 + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_NOISE_SUPPRESS, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_NOISE_SUPPRESS is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_ECHO_SUPPRESS, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_ECHO_SUPPRESS is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_ECHO_SUPPRESS_ACTIVE, + &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_ECHO_SUPPRESS_ACTIVE is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_AGC_MAX_GAIN, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_MAX_GAIN is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_AGC_INCREMENT, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_INCREMENT is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_AGC_DECREMENT, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_DECREMENT is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_PROB_START, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_PROB_START is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess, SPEEX_PREPROCESS_GET_PROB_CONTINUE, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_PROB_CONTINUE is: %d\n", tmp); +#endif //0 +#endif// 0 //NO MORE + + + + + + + + + +#if 1 //NO MORE + /* Setup preprocessor and associate with echo canceller for residual echo suppression */ +#ifndef GIOVA48 + preprocess2 = speex_preprocess_state_init(160, 8000); +#else// GIOVA48 + preprocess = speex_preprocess_state_init(960, 48000); +#endif // GIOVA48 + + /* Setup preprocessor various other goodies */ + tmp = 0; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_SET_AGC, &tmp); + + tmp = 24000; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_SET_AGC_TARGET, &tmp); + + //tmp = 60; + //speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_SET_AGC_MAX_GAIN, &tmp); + tmp = 40; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_SET_AGC_INCREMENT, &tmp); + tmp = -40; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_SET_AGC_DECREMENT, &tmp); + +#if 0 + // Let's turn off all of the 'denoisers' (eg denoise and dereverb, and vad too) because they start automatic gain on mic input on cm108 usb, also if it (the agc on usb) disbled through mixer + tmp = 0; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_SET_DENOISE, &tmp); + tmp = 0; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_SET_DEREVERB, &tmp); + tmp = 0; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_SET_VAD, &tmp); +#endif + + //tmp = 0; + //speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_SET_DENOISE, &tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_AGC, &tmp); + fprintf(stderr, "AGC is: %d\n", tmp); + level = 1.0; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_AGC_LEVEL, &level); + fprintf(stderr, "AGC_LEVEL is: %f\n", level); + //tmp=1; + //speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_AGC_TARGET, &tmp); + //fprintf( stderr, "AGC_TARGET is: %d\n", tmp ); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_DENOISE, &tmp); + fprintf(stderr, "DENOISE is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_DEREVERB, &tmp); + fprintf(stderr, "DEREVERB is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_VAD, &tmp); + fprintf(stderr, "VAD is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_AGC_MAX_GAIN, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_MAX_GAIN is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_AGC_INCREMENT, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_INCREMENT is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_AGC_DECREMENT, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_DECREMENT is: %d\n", tmp); + +#if 0 + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_NOISE_SUPPRESS, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_NOISE_SUPPRESS is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_ECHO_SUPPRESS, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_ECHO_SUPPRESS is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_ECHO_SUPPRESS_ACTIVE, + &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_ECHO_SUPPRESS_ACTIVE is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_AGC_MAX_GAIN, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_MAX_GAIN is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_AGC_INCREMENT, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_INCREMENT is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_AGC_DECREMENT, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_AGC_DECREMENT is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_PROB_START, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_PROB_START is: %d\n", tmp); + tmp = 1; + speex_preprocess_ctl(preprocess2, SPEEX_PREPROCESS_GET_PROB_CONTINUE, &tmp); + fprintf(stderr, "SPEEX_PREPROCESS_GET_PROB_CONTINUE is: %d\n", tmp); +#endif //0 +#endif// 0 //NO MORE + + + + +#endif // WANT_SPEEX + + + /* Open a PortAudio stream that we will use to communicate with the underlying + * audio drivers. */ + + aStream->do_dual = do_dual; + + if (aStream->do_dual) { + err = Pa_OpenStream(&aStream->istream, inputParameters, NULL, sampleRate, samples_per_packet, streamFlags, iblockingIOCallback, aStream); + if (err != paNoError) { + goto error; + } + err = Pa_OpenStream(&aStream->ostream, NULL, outputParameters, sampleRate, samples_per_packet, streamFlags, oblockingIOCallback, aStream); + if (err != paNoError) { + goto error; + } + } else { + err = Pa_OpenStream(&aStream->iostream, inputParameters, outputParameters, sampleRate, samples_per_packet, streamFlags, ioblockingIOCallback, aStream); + } + + if (err != paNoError) { + goto error; + } + + if (aStream->do_dual) { + err = Pa_StartStream(aStream->istream); + + if (err != paNoError) { + goto error; + } + + err = Pa_StartStream(aStream->ostream); + + if (err != paNoError) { + goto error; + } + + } else { + err = Pa_StartStream(aStream->iostream); + } + + if (err != paNoError) { + goto error; + } + + *rwblPtr = aStream; + + //switch_yield(500000); + + return paNoError; + + error: + + CloseAudioStream(aStream); + + *rwblPtr = NULL; + return err; +} + +/************************************************************/ +PaError CloseAudioStream(PABLIO_Stream * aStream) +{ + int bytesEmpty; + int byteSize; + + + byteSize = aStream->outFIFO.bufferSize; + + if (aStream->has_out) { + /* If we are writing data, make sure we play everything written. */ + if (byteSize > 0) { + bytesEmpty = PaUtil_GetRingBufferWriteAvailable(&aStream->outFIFO); + while (bytesEmpty < byteSize) { + Pa_Sleep(10); + bytesEmpty = PaUtil_GetRingBufferWriteAvailable(&aStream->outFIFO); + } + } + } + + if (aStream->do_dual) { + if (aStream->has_in && aStream->istream) { + if (Pa_IsStreamActive(aStream->istream)) { + Pa_StopStream(aStream->istream); + } + + Pa_CloseStream(aStream->istream); + aStream->istream = NULL; + } + + if (aStream->has_out && aStream->ostream) { + if (Pa_IsStreamActive(aStream->ostream)) { + Pa_StopStream(aStream->ostream); + } + + Pa_CloseStream(aStream->ostream); + aStream->ostream = NULL; + } + + } else { + if (aStream->iostream) { + if (Pa_IsStreamActive(aStream->iostream)) { + Pa_StopStream(aStream->iostream); + } + + Pa_CloseStream(aStream->iostream); + aStream->iostream = NULL; + } + } + + if (aStream->has_in) { + PABLIO_TermFIFO(&aStream->inFIFO); + } + + if (aStream->has_out) { + PABLIO_TermFIFO(&aStream->outFIFO); + } + + free(aStream); + //switch_yield(500000); + + return paNoError; +} + diff --git a/src/mod/endpoints/mod_gsmopen/pablio.h b/src/mod/endpoints/mod_gsmopen/pablio.h new file mode 100644 index 0000000000..c933a11426 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/pablio.h @@ -0,0 +1,120 @@ +#ifndef _PABLIO_H +#define _PABLIO_H + +#ifdef __cplusplus +extern "C" { +#endif /* __cplusplus */ + +/* + * $Id: pablio.h 1083 2006-08-23 07:30:49Z rossb $ + * PABLIO.h + * Portable Audio Blocking read/write utility. + * + * Author: Phil Burk, http://www.softsynth.com/portaudio/ + * + * Include file for PABLIO, the Portable Audio Blocking I/O Library. + * PABLIO is built on top of PortAudio, the Portable Audio Library. + * For more information see: http://www.portaudio.com + * Copyright (c) 1999-2000 Ross Bencina and Phil Burk + * + * 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 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR + * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF + * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION + * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ + +/* + * The text above constitutes the entire PortAudio license; however, + * the PortAudio community also makes the following non-binding requests: + * + * Any person wishing to distribute modifications to the Software is + * requested to send the modifications to the original developer so that + * they can be incorporated into the canonical version. It is also + * requested that these non-binding requests be included along with the + * license above. + */ + +#include +#include +#include +#include "pa_ringbuffer.h" +#include "portaudio.h" + +#include + + typedef struct { + PaUtilRingBuffer inFIFO; + PaUtilRingBuffer outFIFO; + PaStream *istream; + PaStream *ostream; + PaStream *iostream; + int bytesPerFrame; + int do_dual; + int has_in; + int has_out; + } PABLIO_Stream; + +/* Values for flags for OpenAudioStream(). */ +#define PABLIO_READ (1<<0) +#define PABLIO_WRITE (1<<1) +#define PABLIO_READ_WRITE (PABLIO_READ|PABLIO_WRITE) +#define PABLIO_MONO (1<<2) +#define PABLIO_STEREO (1<<3) + +/************************************************************ + * Write data to ring buffer. + * Will not return until all the data has been written. + */ + long WriteAudioStream(PABLIO_Stream * aStream, void *data, long numFrames, switch_timer_t *timer); + +/************************************************************ + * Read data from ring buffer. + * Will not return until all the data has been read. + */ + long ReadAudioStream(PABLIO_Stream * aStream, void *data, long numFrames, switch_timer_t *timer); + +/************************************************************ + * Return the number of frames that could be written to the stream without + * having to wait. + */ + long GetAudioStreamWriteable(PABLIO_Stream * aStream); + +/************************************************************ + * Return the number of frames that are available to be read from the + * stream without having to wait. + */ + long GetAudioStreamReadable(PABLIO_Stream * aStream); + +/************************************************************ + * Opens a PortAudio stream with default characteristics. + * Allocates PABLIO_Stream structure. + * + * flags parameter can be an ORed combination of: + * PABLIO_READ, PABLIO_WRITE, or PABLIO_READ_WRITE, + * and either PABLIO_MONO or PABLIO_STEREO + */ + PaError OpenAudioStream(PABLIO_Stream ** rwblPtr, + const PaStreamParameters * inputParameters, + const PaStreamParameters * outputParameters, + double sampleRate, PaStreamCallbackFlags statusFlags, long samples_per_packet, int do_dual); + + PaError CloseAudioStream(PABLIO_Stream * aStream); + +#ifdef __cplusplus +} +#endif /* __cplusplus */ +#endif /* _PABLIO_H */ diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_devlist.c b/src/mod/endpoints/mod_gsmopen/portaudio_devlist.c new file mode 100644 index 0000000000..02a8160221 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_devlist.c @@ -0,0 +1,54 @@ +/* + * gcc -Wall portaudio_devlist.c -o portaudio_devlist -lportaudio + */ +#include +#include +#include + +int main(int argc, char **argv) +{ + int i, c, numDevices; + const PaDeviceInfo *deviceInfo; + PaError err; + char name[256]; + + err = Pa_Initialize(); + if (err != paNoError) + return err; + + + numDevices = Pa_GetDeviceCount(); + if (numDevices < 0) { + return 0; + } + if(argc==1){ + printf("usage: %s [input | output]\n", argv[0]); + return 1; + } + for (i = 0; i < numDevices; i++) { + deviceInfo = Pa_GetDeviceInfo(i); + memset(name, '\0', sizeof(name)); + for(c=0; cname); c++){ + if( deviceInfo->name[c] == ' ') + name[c]='_'; + else + name[c]= deviceInfo->name[c]; + } + if( !strcmp(argv[1], "input")&& deviceInfo->maxInputChannels) + { + printf("%d \"%s\" \n", + i, + name); + } + else if( !strcmp(argv[1], "output")&& deviceInfo->maxOutputChannels) + { + printf("%d \"%s\" \n", + i, + name); + } + } + + return numDevices; +} + + diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/Makefile b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/Makefile new file mode 100644 index 0000000000..2ffe125b8f --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/Makefile @@ -0,0 +1,6 @@ +MODNAME=mod_gsmopen +SVNDEF := -D'GSMOPEN_SVN_VERSION="$(shell svnversion -n .)"' +LOCAL_CFLAGS += $(SVNDEF) -DNO_ALSA -DGSMOPEN_PORTAUDIO -I../../../../../../libs/spandsp/src -I../../../../../..//libs/tiff-3.8.2/libtiff +LOCAL_LDFLAGS=-lportaudio -lspeex -lspeexdsp -lgsmme -L../../../../../../libs/spandsp/src -lspandsp +LOCAL_OBJS=gsmopen_protocol.o pablio.o pa_ringbuffer.o +include ../../../../../../build/modmake.rules diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/filtra48down8.c b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/filtra48down8.c new file mode 120000 index 0000000000..95dcddeb47 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/filtra48down8.c @@ -0,0 +1 @@ +../../filtra48down8.c \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/filtra8up48.c b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/filtra8up48.c new file mode 120000 index 0000000000..ab063a3388 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/filtra8up48.c @@ -0,0 +1 @@ +../../filtra8up48.c \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/gsmopen.h b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/gsmopen.h new file mode 120000 index 0000000000..663f1cbc4d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/gsmopen.h @@ -0,0 +1 @@ +../../gsmopen.h \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/gsmopen_protocol.cpp b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/gsmopen_protocol.cpp new file mode 120000 index 0000000000..b03564bdd9 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/gsmopen_protocol.cpp @@ -0,0 +1 @@ +../../gsmopen_protocol.cpp \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/mod_gsmopen.cpp b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/mod_gsmopen.cpp new file mode 120000 index 0000000000..a0686ea786 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/mod_gsmopen.cpp @@ -0,0 +1 @@ +../../mod_gsmopen.cpp \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pa_ringbuffer.c b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pa_ringbuffer.c new file mode 120000 index 0000000000..d0f4a92d6c --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pa_ringbuffer.c @@ -0,0 +1 @@ +../../pa_ringbuffer.c \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pa_ringbuffer.h b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pa_ringbuffer.h new file mode 120000 index 0000000000..695ee41274 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pa_ringbuffer.h @@ -0,0 +1 @@ +../../pa_ringbuffer.h \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pablio.c b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pablio.c new file mode 120000 index 0000000000..76d569934f --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pablio.c @@ -0,0 +1 @@ +../../pablio.c \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pablio.h b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pablio.h new file mode 120000 index 0000000000..865b997b25 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/pablio.h @@ -0,0 +1 @@ +../../pablio.h \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/portaudio_devlist.c b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/portaudio_devlist.c new file mode 120000 index 0000000000..24c8da084a --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/portaudio_devlist.c @@ -0,0 +1 @@ +../../portaudio_devlist.c \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/usb-cm-108-2.txt b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/usb-cm-108-2.txt new file mode 120000 index 0000000000..47c6b46e93 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_gsmlib_cplusplus_noalsa/mod_gsmopen/usb-cm-108-2.txt @@ -0,0 +1 @@ +../../usb-cm-108-2.txt \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/Makefile b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/Makefile new file mode 100644 index 0000000000..eb5c0e9d5f --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/Makefile @@ -0,0 +1,6 @@ +MODNAME=mod_gsmopen +SVNDEF := -D'GSMOPEN_SVN_VERSION="$(shell svnversion -n .)"' +LOCAL_CFLAGS += $(SVNDEF) -DNO_GSMLIB -DNO_ALSA -DGSMOPEN_PORTAUDIO -I../../../../../../libs/spandsp/src -I../../../../../..//libs/tiff-3.8.2/libtiff +LOCAL_LDFLAGS=-lportaudio -lspeex -lspeexdsp -L../../../../../../libs/spandsp/src -lspandsp +LOCAL_OBJS=gsmopen_protocol.o pablio.o pa_ringbuffer.o +include ../../../../../../build/modmake.rules diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/filtra48down8.c b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/filtra48down8.c new file mode 120000 index 0000000000..95dcddeb47 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/filtra48down8.c @@ -0,0 +1 @@ +../../filtra48down8.c \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/filtra8up48.c b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/filtra8up48.c new file mode 120000 index 0000000000..ab063a3388 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/filtra8up48.c @@ -0,0 +1 @@ +../../filtra8up48.c \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/gsmopen.h b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/gsmopen.h new file mode 120000 index 0000000000..663f1cbc4d --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/gsmopen.h @@ -0,0 +1 @@ +../../gsmopen.h \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/gsmopen_protocol.c b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/gsmopen_protocol.c new file mode 120000 index 0000000000..b03564bdd9 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/gsmopen_protocol.c @@ -0,0 +1 @@ +../../gsmopen_protocol.cpp \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/mod_gsmopen.c b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/mod_gsmopen.c new file mode 120000 index 0000000000..a0686ea786 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/mod_gsmopen.c @@ -0,0 +1 @@ +../../mod_gsmopen.cpp \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pa_ringbuffer.c b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pa_ringbuffer.c new file mode 120000 index 0000000000..d0f4a92d6c --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pa_ringbuffer.c @@ -0,0 +1 @@ +../../pa_ringbuffer.c \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pa_ringbuffer.h b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pa_ringbuffer.h new file mode 120000 index 0000000000..695ee41274 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pa_ringbuffer.h @@ -0,0 +1 @@ +../../pa_ringbuffer.h \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pablio.c b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pablio.c new file mode 120000 index 0000000000..76d569934f --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pablio.c @@ -0,0 +1 @@ +../../pablio.c \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pablio.h b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pablio.h new file mode 120000 index 0000000000..865b997b25 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/pablio.h @@ -0,0 +1 @@ +../../pablio.h \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/portaudio_devlist.c b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/portaudio_devlist.c new file mode 120000 index 0000000000..24c8da084a --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/portaudio_devlist.c @@ -0,0 +1 @@ +../../portaudio_devlist.c \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/usb-cm-108-2.txt b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/usb-cm-108-2.txt new file mode 120000 index 0000000000..47c6b46e93 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/portaudio_nogsmlib_nocplusplus_noalsa/mod_gsmopen/usb-cm-108-2.txt @@ -0,0 +1 @@ +../../usb-cm-108-2.txt \ No newline at end of file diff --git a/src/mod/endpoints/mod_gsmopen/setmixers b/src/mod/endpoints/mod_gsmopen/setmixers new file mode 100755 index 0000000000..063904b9cf --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/setmixers @@ -0,0 +1,13 @@ +#!/bin/bash + +# ALSA can manage a max of 8 cards +CARD_LIST="0 1 2 3 4 5 6 7" + +for i in $CARD_LIST; do + +#amixer -c ${i} -q set Mic 0% mute +amixer -c ${i} -q set Speaker 70% unmute >/dev/null 2>&1 +amixer -c ${i} -q set Mic cap mute 70% >/dev/null 2>&1 +amixer -c ${i} -q set "Auto Gain Control" off >/dev/null 2>&1 + +done diff --git a/src/mod/endpoints/mod_gsmopen/test.cc b/src/mod/endpoints/mod_gsmopen/test.cc new file mode 100644 index 0000000000..f59711ef92 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/test.cc @@ -0,0 +1,206 @@ +// ************************************************************************* +// * GSM TA/ME library +// * +// * File: testgsmlib.cc +// * +// * Purpose: Test general gsm functions (without SMS/phonebook) +// * +// * Author: Peter Hofmann (software@pxh.de) +// * +// * Created: 17.5.1999 +// ************************************************************************* +#ifdef HAVE_CONFIG_H +#include +#endif +#ifdef WIN32 +#include +#else +#include +#endif +#include +#include + +using namespace std; +using namespace gsmlib; + +// some time-consuming tests can be switched off by commenting out the +// following macros +#define TEST_OPERATOR_INFO + +void printForwardReason(string s, ForwardInfo &info) +{ + cout << " " << s << ": " + << (info._active ? "active " : "inactive ") + << "number: " << info._number + << " subaddr: " << info._subAddr + << " time: " << info._time << endl; +} + +int main(int argc, char *argv[]) +{ + string ciapa; + int i; + + if(argc<2){ + cout << (string)"You gave no \"device\" argument!" << endl; + return -1; + } + try + { + cout << (string)"Opening device " + argv[1] << endl; +#ifdef WIN32 + Ref port = new Win32SerialPort((string)argv[1], 38400); +#else + //Ref port = new UnixSerialPort((string)argv[1], B38400); + Ref port = new UnixSerialPort((string)argv[1], B115200); +#endif + + + cout << "Creating MeTa object" << endl; + MeTa m(port); + + cout << "Creating GsmAt object" << endl; + Ref gsmat = new GsmAt(m); + + cout << "Using GsmAt object" << endl; + //cout << gsmat->chat("AT", "OK", false, false) << endl; + //cout << gsmat->chat("D3472665618;") << endl; + gsmat->putLine("ATI9", true); + for(i=0; i<9; i++){ + ciapa = gsmat->getLine(); + cout << "PRESO: |||" << ciapa << "|||" << endl; + //usleep(5000); + } + +#ifdef NOTDEF + cout << "Getting ME info" << endl; + MEInfo mei = m.getMEInfo(); + + cout << " Manufacturer: " << mei._manufacturer << endl + << " Model: " << mei._model << endl + << " Revision: " << mei._revision << endl + << " Serial Number: " << mei._serialNumber << endl << endl; + +#ifdef TEST_OPERATOR_INFO + try + { + cout << "Getting operator info" << endl; + vector opis = m.getAvailableOPInfo(); + for (vector::iterator i = opis.begin(); i != opis.end(); ++i) + { + cout << " Status: "; + switch (i->_status) + { + case 0: cout << "unknown"; break; + case 1: cout << "current"; break; + case 2: cout << "available"; break; + case 3: cout << "forbidden"; break; + } + cout << endl + << " Long name: '" << i->_longName << "' " + << " Short name: '" << i->_shortName << "' " + << " Numeric name: " << i->_numericName << endl; + } + } + catch (GsmException &ge) + { + if (ge.getErrorCode() == 0) + cout << "phone failure ignored" << endl; + else + throw; + } + cout << endl; +#endif // TEST_OPERATOR_INFO + + cout << "Current operator info" << endl; + OPInfo opi = m.getCurrentOPInfo(); + cout << " Long name: '" << opi._longName << "' " + << " Short name: '" << opi._shortName << "' " + << " Numeric name: " << opi._numericName << endl + << " Mode: "; + switch (opi._mode) + { + case 0: cout << "automatic"; break; + case 1: cout << "manual"; break; + case 2: cout << "deregister"; break; + case 4: cout << "manual/automatic"; break; + } + cout << endl; + + cout << "Facility lock capabilities" << endl << " "; + vector fclc = m.getFacilityLockCapabilities(); + for (vector::iterator i = fclc.begin(); i != fclc.end(); ++i) + cout << *i << " "; + cout << endl << endl; + + cout << "Facility lock states" << endl; + for (vector::iterator k = fclc.begin(); k != fclc.end(); ++k) + if (*k != "AB" && *k != "AG" && *k != "AC") + { + cout << " " << *k; + if (m.getFacilityLockStatus(*k, VoiceFacility)) + cout << " Voice"; + if (m.getFacilityLockStatus(*k, DataFacility)) + cout << " Data"; + if (m.getFacilityLockStatus(*k, FaxFacility)) + cout << " Fax"; + } + cout << endl; + + cout << "Facilities with password" << endl; + vector pwi = m.getPasswords(); + for (vector::iterator j = pwi.begin(); j != pwi.end(); ++j) + cout << " " << j->_facility << " len " << j->_maxPasswdLen << endl; + cout << endl; + + cout << "Network caller line identification identification: " + << (m.getNetworkCLIP() ? "on" : "off") << endl << endl; + + cout << "Call forwarding information" << endl; + for (int r = 0; r < 4; ++r) + { + switch (r) + { + case 0: cout << "UnconditionalReason" << endl; break; + case 1: cout << "MobileBusyReason" << endl; break; + case 2: cout << "NoReplyReason" << endl; break; + case 3: cout << "NotReachableReason" << endl; break; + } + ForwardInfo voice, fax, data; + m.getCallForwardInfo((ForwardReason)r, voice, fax, data); + printForwardReason("Voice", voice); + printForwardReason("Data", data); + printForwardReason("Fax", fax); + } + cout << endl; + + cout << "Battery charge status" << endl; + int bcs = m.getBatteryChargeStatus(); + switch (bcs) + { + case 0: cout << "ME is powered by the battery" << endl; break; + case 1: cout << "ME has a battery connected, but is not powered by it" + << endl; break; + case 2: cout << "ME does not have a battery connected" << endl; break; + case 3: cout << "Recognized power fault, calls inhibited" << endl; break; + } + cout << endl; + + cout << "Battery charge: " << m.getBatteryCharge() << endl << endl; + + cout << "Signal strength: " << m.getSignalStrength() << endl << endl; + + cout << "Bit error rate: " << m.getBitErrorRate() << endl << endl; +#endif //NOTDEF + } + catch (GsmException &ge) + { + cerr << "GsmException '" << ge.what() << "'" << endl; + return 1; + } + + + return 0; +} + + diff --git a/src/mod/endpoints/mod_gsmopen/usb-cm-108-2.txt b/src/mod/endpoints/mod_gsmopen/usb-cm-108-2.txt new file mode 100644 index 0000000000..551f42bab6 --- /dev/null +++ b/src/mod/endpoints/mod_gsmopen/usb-cm-108-2.txt @@ -0,0 +1,62 @@ +state.default { + control.1 { + comment.access 'read write' + comment.type BOOLEAN + comment.count 1 + iface MIXER + name 'Mic Playback Switch' + value false + } + control.2 { + comment.access 'read write' + comment.type INTEGER + comment.count 1 + comment.range '0 - 32' + iface MIXER + name 'Mic Playback Volume' + value 0 + } + control.3 { + comment.access 'read write' + comment.type BOOLEAN + comment.count 1 + iface MIXER + name 'Speaker Playback Switch' + value true + } + control.4 { + comment.access 'read write' + comment.type INTEGER + comment.count 2 + comment.range '0 - 151' + iface MIXER + name 'Speaker Playback Volume' + value.0 6 + value.1 6 + } + control.5 { + comment.access 'read write' + comment.type BOOLEAN + comment.count 1 + iface MIXER + name 'Mic Capture Switch' + value true + } + control.6 { + comment.access 'read write' + comment.type INTEGER + comment.count 1 + comment.range '0 - 16' + iface MIXER + name 'Mic Capture Volume' + value 5 + } + control.7 { + comment.access 'read write' + comment.type BOOLEAN + comment.count 1 + iface MIXER + name 'Auto Gain Control' + value false + } +}

y?NWl|-xxOBP>;aWs+( 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�tXTZ`Nv+9T#Ymn-Q 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‰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�$k_J@TZ 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 literal 0 HcmV?d00001 diff --git a/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib_1.10-12ubuntu1.diff.gz b/src/mod/endpoints/mod_gsmopen/gsmlib/gsmlib_1.10-12ubuntu1.diff.gz new file mode 100644 index 0000000000000000000000000000000000000000..60524bfec2a220e02990332252c07376a78bc90d GIT binary patch literal 453447 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