[SCM] idjc/master: Imported Upstream version 0.8.15

sramacher at users.alioth.debian.org sramacher at users.alioth.debian.org
Sun Nov 15 11:39:43 UTC 2015


The following commit has been merged in the master branch:
commit 6c6e29b9cacced7d3f4135da70250888a5ea09d6
Author: Sebastian Ramacher <sramacher at debian.org>
Date:   Sun Nov 15 11:56:13 2015 +0100

    Imported Upstream version 0.8.15

diff --git a/ChangeLog b/ChangeLog
index f0f861b..3c1efef 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,59 @@
+* Changes in version 0.8.15 *
+
+Documentation update for VoIP.
+
+Support for more signals by the IDJCMonitor class.
+
+Support for latest version of python-irc.
+
+Added full support for ITU-R BS.1770 / EBU R128 tags.
+
+Fixed saving of announcement text in .xspf playlists.
+
+The announcement text now appears in the playlist allowing the DJ to pre-read the announcements.
+
+Updated copyright year to 2015
+
+Internationalisation mostly of format.py which was missing from POTFILES.
+
+Git commit hash and build date appears in the 'About' page.
+
+Improved song database connectivity. Fixes and enhancements to last DJ played. Patch: B Millham.
+
+Added wrappers to all glib timeout_add, idle_add, and source_remove calls.
+
+Documentation update.
+
+French language translation update.
+
+Song title database credentials now exportable with DBus.
+
+'Last Played' column added to song title database viewer. This includes a scalable cooldown bar.
+
+Fix for IRC metadata so that Stream Info metadata updates are tied to stream connection, not song title changes.
+
+IDJC now reports server connect/disconnect to IRC in a formalised manner and in messages %U can be used for the source URI.
+
+Added an AppData file.
+
+Added support for generating m3u8 playlist files and added support for file URI's in m3u files.
+
+Fixed metadata to icecast servers now sent with latin1 encoding when streaming mpeg formats.
+
+User can now select latin1 encoding for fixed metadata to shoutcast servers.
+
+Fix for stream metadata character encoding: applied to extant metadata also.
+
+Can now read ReplayGain info from ID3 TXXX tags. Has priority over RVAD/RVA2 tags.
+
+Build system now handles problem with a too old libogg breaking Opus support. 
+
+Can now obtain listener stats from Shoutcast 2 servers.
+
+Applied patches for libav 9 and 10 build and build warnings, courtesy: Sebastian Ramacher <sramacher at debian.org>
+
+Build fix for older ffmpeg dependency.
+
 * Changes in version 0.8.14 *
 
 Fix for playlist controls having an overly dark background.
diff --git a/Makefile.am b/Makefile.am
index 3a5dcfc..b5b1373 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -5,9 +5,12 @@ nodist_bin_SCRIPTS=${PACKAGE_NAME}
 dist_noinst_SCRIPTS=idjc.in.in bootstrap
 nodist_doc_DATA=AUTHORS.gz NEWS.gz README.gz ChangeLog.gz
 docdir=${prefix}/share/doc/${PACKAGE_NAME}-${PACKAGE_VERSION}
-dist_noinst_DATA=idjc.desktop.in.in
+dist_noinst_DATA=idjc.desktop.in.in idjc.appdata.xml.in.in
 nodist_appmenu_DATA=${PACKAGE_NAME}.desktop
 appmenudir=${prefix}/share/applications
+nodist_appdata_DATA=${PACKAGE_NAME}.appdata.xml
+appdatadir=${datadir}/appdata
+nodist_pkgdata_DATA=buildinfo
 
 ${PACKAGE_NAME}: idjc.in
 	@sed -e 's|$${prefix}|${prefix}|g' -e 's|$${pkglibdir}|${pkglibdir}|g' $? >$@
@@ -15,6 +18,9 @@ ${PACKAGE_NAME}: idjc.in
 ${PACKAGE_NAME}.desktop: idjc.desktop.in
 	@sed -e 's|$${prefix}|${prefix}|g' -e 's|$${exec_prefix}|${exec_prefix}|g' $? >$@
 
+${PACKAGE_NAME}.appdata.xml: idjc.appdata.xml.in
+	@sed -e 's|$${prefix}|${prefix}|g' -e 's|$${exec_prefix}|${exec_prefix}|g' $? >$@
+
 AUTHORS.gz: AUTHORS
 	@ gzip -c $? >$@
 	 
@@ -27,8 +33,20 @@ README.gz: README
 ChangeLog.gz: ChangeLog
 	@ gzip -c $? >$@
 
+buildinfo:
+if GIT_VERSION_CONTROL
+	echo Commit hash: $$(git log -n1 "--pretty=format:%H") > buildinfo
+	echo Commit date: $$(git log -n1 "--pretty=format:%aD") >> buildinfo
+	echo Repo status: $$(if test -z "$(git status --porcelain) 2>&1" ; then echo "clean" ; else echo "dirty" ; fi) >> buildinfo
+	echo Remote URL: $$(git config --get remote.origin.url) >> buildinfo
+	echo >> buildinfo
+else
+	rm buildinfo
+endif
+	echo Build date: $$(date -R) >> buildinfo
+
 clean-local:
-	rm -f ChangeLog.gz README.gz NEWS.gz AUTHORS.gz ${PACKAGE_NAME}.desktop idjcctrl ${PACKAGE_NAME}
+	rm -f buildinfo ChangeLog.gz README.gz NEWS.gz AUTHORS.gz ${PACKAGE_NAME}.desktop ${PACKAGE_NAME}.appdata.xml ${PACKAGE_NAME}
 
 dtdist:
 	make dist
@@ -38,7 +56,7 @@ sfpublish:
 	make dist
 	curl --retry 3 --connect-timeout 10 -T ${PACKAGE_TARNAME}-${PACKAGE_VERSION}.tar.gz -n sftp://frs.sourceforge.net/home/frs/project/i/id/idjc/idjc/0.8/
 
-.PHONY: dtdist sfpublish ${PACKAGE_NAME} ${PACKAGE_NAME}.desktop
+.PHONY: buildinfo dtdist sfpublish ${PACKAGE_NAME} ${PACKAGE_NAME}.desktop
 
 ACLOCAL_AMFLAGS = -I m4
 
diff --git a/Makefile.in b/Makefile.in
index afa2c4f..6126cf9 100644
--- a/Makefile.in
+++ b/Makefile.in
@@ -85,9 +85,10 @@ DIST_COMMON = INSTALL NEWS README AUTHORS ChangeLog \
 	$(srcdir)/Makefile.in $(srcdir)/Makefile.am \
 	$(top_srcdir)/configure $(am__configure_deps) \
 	$(srcdir)/config.h.in $(srcdir)/idjc.in.in \
-	$(srcdir)/idjc.desktop.in.in ABOUT-NLS $(dist_noinst_SCRIPTS) \
-	$(dist_noinst_DATA) COPYING compile config.guess config.rpath \
-	config.sub depcomp install-sh missing py-compile ltmain.sh
+	$(srcdir)/idjc.desktop.in.in $(srcdir)/idjc.appdata.xml.in.in \
+	ABOUT-NLS $(dist_noinst_SCRIPTS) $(dist_noinst_DATA) COPYING \
+	compile config.guess config.rpath config.sub depcomp \
+	install-sh missing py-compile ltmain.sh
 ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
 am__aclocal_m4_deps = $(top_srcdir)/m4/gettext.m4 \
 	$(top_srcdir)/m4/iconv.m4 $(top_srcdir)/m4/intlmacosx.m4 \
@@ -103,7 +104,7 @@ am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \
  configure.lineno config.status.lineno
 mkinstalldirs = $(install_sh) -d
 CONFIG_HEADER = config.h
-CONFIG_CLEAN_FILES = idjc.in idjc.desktop.in
+CONFIG_CLEAN_FILES = idjc.in idjc.desktop.in idjc.appdata.xml.in
 CONFIG_CLEAN_VPATH_FILES =
 am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
 am__vpath_adj = case $$p in \
@@ -132,8 +133,9 @@ am__uninstall_files_from_dir = { \
     || { echo " ( cd '$$dir' && rm -f" $$files ")"; \
          $(am__cd) "$$dir" && rm -f $$files; }; \
   }
-am__installdirs = "$(DESTDIR)$(bindir)" "$(DESTDIR)$(appmenudir)" \
-	"$(DESTDIR)$(docdir)"
+am__installdirs = "$(DESTDIR)$(bindir)" "$(DESTDIR)$(appdatadir)" \
+	"$(DESTDIR)$(appmenudir)" "$(DESTDIR)$(docdir)" \
+	"$(DESTDIR)$(pkgdatadir)"
 SCRIPTS = $(dist_noinst_SCRIPTS) $(nodist_bin_SCRIPTS)
 AM_V_P = $(am__v_P_ at AM_V@)
 am__v_P_ = $(am__v_P_ at AM_DEFAULT_V@)
@@ -162,7 +164,9 @@ am__can_run_installinfo = \
     n|no|NO) false;; \
     *) (install-info --version) >/dev/null 2>&1;; \
   esac
-DATA = $(dist_noinst_DATA) $(nodist_appmenu_DATA) $(nodist_doc_DATA)
+DATA = $(dist_noinst_DATA) $(nodist_appdata_DATA) \
+	$(nodist_appmenu_DATA) $(nodist_doc_DATA) \
+	$(nodist_pkgdata_DATA)
 RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive	\
   distclean-recursive maintainer-clean-recursive
 am__recursive_targets = \
@@ -268,6 +272,7 @@ EXEEXT = @EXEEXT@
 EXT = @EXT@
 FGREP = @FGREP@
 GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@
+GIT_PROG_EXISTS = @GIT_PROG_EXISTS@
 GLIB_CFLAGS = @GLIB_CFLAGS@
 GLIB_LIBS = @GLIB_LIBS@
 GMSGFMT = @GMSGFMT@
@@ -325,6 +330,7 @@ LN_S = @LN_S@
 LTLIBICONV = @LTLIBICONV@
 LTLIBINTL = @LTLIBINTL@
 LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
 MAKEINFO = @MAKEINFO@
 MANIFEST_TOOL = @MANIFEST_TOOL@
 MKDIR_P = @MKDIR_P@
@@ -442,9 +448,12 @@ EXTRA_SCRIPTS =
 nodist_bin_SCRIPTS = ${PACKAGE_NAME}
 dist_noinst_SCRIPTS = idjc.in.in bootstrap
 nodist_doc_DATA = AUTHORS.gz NEWS.gz README.gz ChangeLog.gz
-dist_noinst_DATA = idjc.desktop.in.in
+dist_noinst_DATA = idjc.desktop.in.in idjc.appdata.xml.in.in
 nodist_appmenu_DATA = ${PACKAGE_NAME}.desktop
 appmenudir = ${prefix}/share/applications
+nodist_appdata_DATA = ${PACKAGE_NAME}.appdata.xml
+appdatadir = ${datadir}/appdata
+nodist_pkgdata_DATA = buildinfo
 ACLOCAL_AMFLAGS = -I m4
 EXTRA_DIST = config.rpath m4/ChangeLog
 all: config.h
@@ -504,6 +513,8 @@ idjc.in: $(top_builddir)/config.status $(srcdir)/idjc.in.in
 	cd $(top_builddir) && $(SHELL) ./config.status $@
 idjc.desktop.in: $(top_builddir)/config.status $(srcdir)/idjc.desktop.in.in
 	cd $(top_builddir) && $(SHELL) ./config.status $@
+idjc.appdata.xml.in: $(top_builddir)/config.status $(srcdir)/idjc.appdata.xml.in.in
+	cd $(top_builddir) && $(SHELL) ./config.status $@
 install-nodist_binSCRIPTS: $(nodist_bin_SCRIPTS)
 	@$(NORMAL_INSTALL)
 	@list='$(nodist_bin_SCRIPTS)'; test -n "$(bindir)" || list=; \
@@ -548,6 +559,27 @@ clean-libtool:
 
 distclean-libtool:
 	-rm -f libtool config.lt
+install-nodist_appdataDATA: $(nodist_appdata_DATA)
+	@$(NORMAL_INSTALL)
+	@list='$(nodist_appdata_DATA)'; test -n "$(appdatadir)" || list=; \
+	if test -n "$$list"; then \
+	  echo " $(MKDIR_P) '$(DESTDIR)$(appdatadir)'"; \
+	  $(MKDIR_P) "$(DESTDIR)$(appdatadir)" || exit 1; \
+	fi; \
+	for p in $$list; do \
+	  if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
+	  echo "$$d$$p"; \
+	done | $(am__base_list) | \
+	while read files; do \
+	  echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(appdatadir)'"; \
+	  $(INSTALL_DATA) $$files "$(DESTDIR)$(appdatadir)" || exit $$?; \
+	done
+
+uninstall-nodist_appdataDATA:
+	@$(NORMAL_UNINSTALL)
+	@list='$(nodist_appdata_DATA)'; test -n "$(appdatadir)" || list=; \
+	files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \
+	dir='$(DESTDIR)$(appdatadir)'; $(am__uninstall_files_from_dir)
 install-nodist_appmenuDATA: $(nodist_appmenu_DATA)
 	@$(NORMAL_INSTALL)
 	@list='$(nodist_appmenu_DATA)'; test -n "$(appmenudir)" || list=; \
@@ -590,6 +622,27 @@ uninstall-nodist_docDATA:
 	@list='$(nodist_doc_DATA)'; test -n "$(docdir)" || list=; \
 	files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \
 	dir='$(DESTDIR)$(docdir)'; $(am__uninstall_files_from_dir)
+install-nodist_pkgdataDATA: $(nodist_pkgdata_DATA)
+	@$(NORMAL_INSTALL)
+	@list='$(nodist_pkgdata_DATA)'; test -n "$(pkgdatadir)" || list=; \
+	if test -n "$$list"; then \
+	  echo " $(MKDIR_P) '$(DESTDIR)$(pkgdatadir)'"; \
+	  $(MKDIR_P) "$(DESTDIR)$(pkgdatadir)" || exit 1; \
+	fi; \
+	for p in $$list; do \
+	  if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
+	  echo "$$d$$p"; \
+	done | $(am__base_list) | \
+	while read files; do \
+	  echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(pkgdatadir)'"; \
+	  $(INSTALL_DATA) $$files "$(DESTDIR)$(pkgdatadir)" || exit $$?; \
+	done
+
+uninstall-nodist_pkgdataDATA:
+	@$(NORMAL_UNINSTALL)
+	@list='$(nodist_pkgdata_DATA)'; test -n "$(pkgdatadir)" || list=; \
+	files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \
+	dir='$(DESTDIR)$(pkgdatadir)'; $(am__uninstall_files_from_dir)
 
 # This directory's subdirectories are mostly independent; you can cd
 # into them and run 'make' without going through this Makefile.
@@ -883,7 +936,7 @@ check: check-recursive
 all-am: Makefile $(SCRIPTS) $(DATA) config.h
 installdirs: installdirs-recursive
 installdirs-am:
-	for dir in "$(DESTDIR)$(bindir)" "$(DESTDIR)$(appmenudir)" "$(DESTDIR)$(docdir)"; do \
+	for dir in "$(DESTDIR)$(bindir)" "$(DESTDIR)$(appdatadir)" "$(DESTDIR)$(appmenudir)" "$(DESTDIR)$(docdir)" "$(DESTDIR)$(pkgdatadir)"; do \
 	  test -z "$$dir" || $(MKDIR_P) "$$dir"; \
 	done
 install: install-recursive
@@ -938,7 +991,8 @@ info: info-recursive
 
 info-am:
 
-install-data-am: install-nodist_appmenuDATA install-nodist_docDATA
+install-data-am: install-nodist_appdataDATA install-nodist_appmenuDATA \
+	install-nodist_docDATA install-nodist_pkgdataDATA
 
 install-dvi: install-dvi-recursive
 
@@ -984,8 +1038,9 @@ ps: ps-recursive
 
 ps-am:
 
-uninstall-am: uninstall-nodist_appmenuDATA uninstall-nodist_binSCRIPTS \
-	uninstall-nodist_docDATA
+uninstall-am: uninstall-nodist_appdataDATA \
+	uninstall-nodist_appmenuDATA uninstall-nodist_binSCRIPTS \
+	uninstall-nodist_docDATA uninstall-nodist_pkgdataDATA
 
 .MAKE: $(am__recursive_targets) all install-am install-strip
 
@@ -1000,14 +1055,16 @@ uninstall-am: uninstall-nodist_appmenuDATA uninstall-nodist_binSCRIPTS \
 	install-data install-data-am install-dvi install-dvi-am \
 	install-exec install-exec-am install-html install-html-am \
 	install-info install-info-am install-man \
-	install-nodist_appmenuDATA install-nodist_binSCRIPTS \
-	install-nodist_docDATA install-pdf install-pdf-am install-ps \
-	install-ps-am install-strip installcheck installcheck-am \
-	installdirs installdirs-am maintainer-clean \
+	install-nodist_appdataDATA install-nodist_appmenuDATA \
+	install-nodist_binSCRIPTS install-nodist_docDATA \
+	install-nodist_pkgdataDATA install-pdf install-pdf-am \
+	install-ps install-ps-am install-strip installcheck \
+	installcheck-am installdirs installdirs-am maintainer-clean \
 	maintainer-clean-generic mostlyclean mostlyclean-generic \
 	mostlyclean-libtool pdf pdf-am ps ps-am tags tags-am uninstall \
-	uninstall-am uninstall-nodist_appmenuDATA \
-	uninstall-nodist_binSCRIPTS uninstall-nodist_docDATA
+	uninstall-am uninstall-nodist_appdataDATA \
+	uninstall-nodist_appmenuDATA uninstall-nodist_binSCRIPTS \
+	uninstall-nodist_docDATA uninstall-nodist_pkgdataDATA
 
 
 ${PACKAGE_NAME}: idjc.in
@@ -1016,6 +1073,9 @@ ${PACKAGE_NAME}: idjc.in
 ${PACKAGE_NAME}.desktop: idjc.desktop.in
 	@sed -e 's|$${prefix}|${prefix}|g' -e 's|$${exec_prefix}|${exec_prefix}|g' $? >$@
 
+${PACKAGE_NAME}.appdata.xml: idjc.appdata.xml.in
+	@sed -e 's|$${prefix}|${prefix}|g' -e 's|$${exec_prefix}|${exec_prefix}|g' $? >$@
+
 AUTHORS.gz: AUTHORS
 	@ gzip -c $? >$@
 
@@ -1028,8 +1088,17 @@ README.gz: README
 ChangeLog.gz: ChangeLog
 	@ gzip -c $? >$@
 
+buildinfo:
+ at GIT_VERSION_CONTROL_TRUE@	echo Commit hash: $$(git log -n1 "--pretty=format:%H") > buildinfo
+ at GIT_VERSION_CONTROL_TRUE@	echo Commit date: $$(git log -n1 "--pretty=format:%aD") >> buildinfo
+ at GIT_VERSION_CONTROL_TRUE@	echo Repo status: $$(if test -z "$(git status --porcelain) 2>&1" ; then echo "clean" ; else echo "dirty" ; fi) >> buildinfo
+ at GIT_VERSION_CONTROL_TRUE@	echo Remote URL: $$(git config --get remote.origin.url) >> buildinfo
+ at GIT_VERSION_CONTROL_TRUE@	echo >> buildinfo
+ at GIT_VERSION_CONTROL_FALSE@	rm buildinfo
+	echo Build date: $$(date -R) >> buildinfo
+
 clean-local:
-	rm -f ChangeLog.gz README.gz NEWS.gz AUTHORS.gz ${PACKAGE_NAME}.desktop idjcctrl ${PACKAGE_NAME}
+	rm -f buildinfo ChangeLog.gz README.gz NEWS.gz AUTHORS.gz ${PACKAGE_NAME}.desktop ${PACKAGE_NAME}.appdata.xml ${PACKAGE_NAME}
 
 dtdist:
 	make dist
@@ -1039,7 +1108,7 @@ sfpublish:
 	make dist
 	curl --retry 3 --connect-timeout 10 -T ${PACKAGE_TARNAME}-${PACKAGE_VERSION}.tar.gz -n sftp://frs.sourceforge.net/home/frs/project/i/id/idjc/idjc/0.8/
 
-.PHONY: dtdist sfpublish ${PACKAGE_NAME} ${PACKAGE_NAME}.desktop
+.PHONY: buildinfo dtdist sfpublish ${PACKAGE_NAME} ${PACKAGE_NAME}.desktop
 
 # 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.
diff --git a/artwork/Makefile.in b/artwork/Makefile.in
index 4e5680a..7c0fadc 100644
--- a/artwork/Makefile.in
+++ b/artwork/Makefile.in
@@ -180,6 +180,7 @@ EXEEXT = @EXEEXT@
 EXT = @EXT@
 FGREP = @FGREP@
 GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@
+GIT_PROG_EXISTS = @GIT_PROG_EXISTS@
 GLIB_CFLAGS = @GLIB_CFLAGS@
 GLIB_LIBS = @GLIB_LIBS@
 GMSGFMT = @GMSGFMT@
@@ -237,6 +238,7 @@ LN_S = @LN_S@
 LTLIBICONV = @LTLIBICONV@
 LTLIBINTL = @LTLIBINTL@
 LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
 MAKEINFO = @MAKEINFO@
 MANIFEST_TOOL = @MANIFEST_TOOL@
 MKDIR_P = @MKDIR_P@
diff --git a/c/Makefile.in b/c/Makefile.in
index dc64779..ab6a5db 100644
--- a/c/Makefile.in
+++ b/c/Makefile.in
@@ -258,6 +258,7 @@ EXEEXT = @EXEEXT@
 EXT = @EXT@
 FGREP = @FGREP@
 GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@
+GIT_PROG_EXISTS = @GIT_PROG_EXISTS@
 GLIB_CFLAGS = @GLIB_CFLAGS@
 GLIB_LIBS = @GLIB_LIBS@
 GMSGFMT = @GMSGFMT@
@@ -315,6 +316,7 @@ LN_S = @LN_S@
 LTLIBICONV = @LTLIBICONV@
 LTLIBINTL = @LTLIBINTL@
 LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
 MAKEINFO = @MAKEINFO@
 MANIFEST_TOOL = @MANIFEST_TOOL@
 MKDIR_P = @MKDIR_P@
diff --git a/c/avcodec_encoder.c b/c/avcodec_encoder.c
index f3d8d0d..1e3fbb9 100644
--- a/c/avcodec_encoder.c
+++ b/c/avcodec_encoder.c
@@ -20,6 +20,7 @@
 #include "../config.h"
 
 #include <stdio.h>
+#include <string.h>
 #include "main.h"
 #include "sourceclient.h"
 
@@ -283,7 +284,7 @@ static AVCodec *aac_codec()
         if ((codec = avcodec_find_encoder_by_name(*name)))
             return codec;
 
-    return avcodec_find_encoder(CODEC_ID_AAC);
+    return avcodec_find_encoder(AV_CODEC_ID_AAC);
 }
 
 static AVCodec *aacplus_codec()
diff --git a/c/avcodecdecode.c b/c/avcodecdecode.c
index e2fbbce..4bc5205 100644
--- a/c/avcodecdecode.c
+++ b/c/avcodecdecode.c
@@ -25,6 +25,10 @@
 #include <stdlib.h>
 #include <pthread.h>
 #include <libavutil/opt.h>
+#ifdef HAVE_LIBAVUTIL_CHANNEL_LAYOUT_H
+#include <libavutil/channel_layout.h>
+#endif
+#include <libavutil/samplefmt.h>
 #include "main.h"
 #include "xlplayer.h"
 #include "avcodecdecode.h"
@@ -80,8 +84,8 @@ static void avcodecdecode_init(struct xlplayer *xlplayer)
         av_seek_frame(self->ic, -1, (int64_t)xlplayer->seek_s * AV_TIME_BASE, 0);
         switch (self->c->codec_id)
             {
-            case CODEC_ID_MUSEPACK7:   /* add formats here that glitch when seeked */
-            case CODEC_ID_MUSEPACK8:
+            case AV_CODEC_ID_MUSEPACK7:   /* add formats here that glitch when seeked */
+            case AV_CODEC_ID_MUSEPACK8:
                 self->drop = 1.6;
                 fprintf(stderr, "dropping %0.2f seconds of audio\n", self->drop);
             default:
@@ -198,7 +202,7 @@ static void avcodecdecode_play(struct xlplayer *xlplayer)
             continue;
             }
 
-#ifdef HAVE_SWRESAMPLE
+#if defined (HAVE_SWRESAMPLE) && defined(USE_SWRESAMPLE)
         if (!self->swr)
             {
             int64_t layout;
@@ -229,8 +233,6 @@ static void avcodecdecode_play(struct xlplayer *xlplayer)
             av_opt_set_int(self->swr, "out_channel_layout", (self->channels == 2) ? AV_CH_LAYOUT_STEREO : AV_CH_LAYOUT_MONO, 0);
             av_opt_set_sample_fmt(self->swr, "in_sample_fmt", self->c->sample_fmt, 0);
             av_opt_set_sample_fmt(self->swr, "out_sample_fmt", AV_SAMPLE_FMT_FLT, 0);
-            //av_opt_set_int(self->swr, "in_sample_rate",     44100,                0);
-            //av_opt_set_int(self->swr, "out_sample_rate",    44100,                0);
 
             if (swr_init(self->swr))
                 {
@@ -385,7 +387,7 @@ static void avcodecdecode_play(struct xlplayer *xlplayer)
                 return;
             }
    
-#endif /* HAVE_SWRESAMPLE */
+#endif /* defined (HAVE_SWRESAMPLE) && defined(USE_SWRESAMPLE) */
 
         if (self->resample)
             {
@@ -474,7 +476,7 @@ int avcodecdecode_reg(struct xlplayer *xlplayer)
     pthread_mutex_unlock(&g.avc_mutex);
 
     self->c = self->ic->streams[self->stream]->codec;
-#ifndef HAVE_SWRESAMPLE
+#ifndef USE_SWRESAMPLE
     self->c->request_sample_fmt = AV_SAMPLE_FMT_FLT;
     self->c->request_channel_layout = AV_CH_LAYOUT_STEREO_DOWNMIX;
 #endif
diff --git a/c/encoder.c b/c/encoder.c
index f5b98b4..0472c5f 100644
--- a/c/encoder.c
+++ b/c/encoder.c
@@ -19,6 +19,7 @@
 
 #include "../config.h"
 #include "gnusource.h"
+#include <math.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
diff --git a/c/mixer.c b/c/mixer.c
index e645f30..ba5e549 100644
--- a/c/mixer.c
+++ b/c/mixer.c
@@ -1076,7 +1076,7 @@ static struct mixer {
     int fadeout_f;
     int flush_left, flush_right, flush_jingles, flush_interlude;
     int new_left_pause, new_right_pause, new_inter_pause;
-    char *artist, *title, *album, *replaygain;
+    char *artist, *title, *album, *replaygain, *rgloudness;
     double length;
     int use_dsp;
     char midi_output[MIDI_QUEUE_SIZE];
@@ -1420,9 +1420,9 @@ int mixer_main()
     
     if (!strcmp(action, "ogginforequest"))
         {
-        if (oggdecode_get_metainfo(oggpathname, &s.artist, &s.title, &s.album, &s.length, &s.replaygain))
+        if (oggdecode_get_metainfo(oggpathname, &s.artist, &s.title, &s.album, &s.length, &s.replaygain, &s.rgloudness))
             {
-            fprintf(g.out, "OIR:ARTIST=%s\nOIR:TITLE=%s\nOIR:ALBUM=%s\nOIR:LENGTH=%f\nOIR:REPLAYGAIN_TRACK_GAIN=%s\nOIR:end\n", s.artist, s.title, s.album, s.length, s.replaygain);
+            fprintf(g.out, "OIR:ARTIST=%s\nOIR:TITLE=%s\nOIR:ALBUM=%s\nOIR:LENGTH=%f\nOIR:REPLAYGAIN_TRACK_GAIN=%s\nOIR:REPLAYGAIN_REFERENCE_LOUDNESS=%s\nOIR:end\n", s.artist, s.title, s.album, s.length, s.replaygain, s.rgloudness);
             fflush(g.out);
             }
         else
diff --git a/c/oggdec.c b/c/oggdec.c
index 1fdb4ff..1c1cfe2 100644
--- a/c/oggdec.c
+++ b/c/oggdec.c
@@ -152,6 +152,8 @@ static unsigned vorbis_get_samplerate(struct oggdec_vars *self)  /* attempt to g
             }
       
         obtain_tag_info("replaygain_track_gain", &self->replaygain[self->ix], FALSE);
+        obtain_tag_info("replaygain_reference_loudness", &self->rgloudness[self->ix], FALSE);
+
         }
     else
         {
@@ -349,6 +351,7 @@ static void oggflac_metadata_callback(const FLAC__StreamDecoder *decoder, const
                 copy_tag("album=", &self->album[self->ix], TRUE);
                 }
             copy_tag("replaygain_track_gain=", &self->replaygain[self->ix], FALSE);
+            copy_tag("replaygain_reference_loudness=", &self->rgloudness[self->ix], FALSE);
             }
         else
             fprintf(stderr, "oggflac_metadata_callback: unhandled FLAC metadata type\n");
@@ -744,6 +747,8 @@ static off_t oggscan_eos(struct oggdec_vars *self, off_t offset, off_t offset_en
             self->album[self->n_streams - 1] = strdup("");
             self->replaygain = realloc(self->replaygain, self->n_streams * sizeof (char *));
             self->replaygain[self->n_streams - 1] = strdup("");
+            self->rgloudness = realloc(self->rgloudness, self->n_streams * sizeof (char *));
+            self->rgloudness[self->n_streams - 1] = strdup("");
             self->streamtype = realloc(self->streamtype, self->n_streams * sizeof (enum streamtype_t));
             self->start_time = realloc(self->start_time, self->n_streams * sizeof (double));
             self->duration = realloc(self->duration, self->n_streams * sizeof (double));
@@ -1210,7 +1215,7 @@ int oggdecode_reg(struct xlplayer *xlplayer)
         }
     }
 
-int oggdecode_get_metainfo(char *pathname, char **artist, char **title, char **album, double *length, char **replaygain)
+int oggdecode_get_metainfo(char *pathname, char **artist, char **title, char **album, double *length, char **replaygain, char **rgloudness)
     {
     struct oggdec_vars *self;
     int has_pbtime;
@@ -1231,7 +1236,8 @@ int oggdecode_get_metainfo(char *pathname, char **artist, char **title, char **a
             *title  = realloc(*title, 1);
             *album  = realloc(*album, 1);
             *replaygain = realloc(*replaygain, 1);
-            *artist[0] = *title[0] = *album[0] = *replaygain[0] = '\0';
+            *rgloudness = realloc(*rgloudness, 1);
+            *artist[0] = *title[0] = *album[0] = *replaygain[0] = *rgloudness[0] = '\0';
             }
         else
             {
@@ -1282,6 +1288,18 @@ int oggdecode_get_metainfo(char *pathname, char **artist, char **title, char **a
                 *replaygain = realloc(*replaygain, 1);
                 *replaygain[0] = '\0';
                 }
+
+            if (self->rgloudness[0])
+                {
+                if (*rgloudness)
+                    free(*rgloudness);
+                *rgloudness = strdup(self->rgloudness[0]);
+                }
+            else
+                {
+                *rgloudness = realloc(*rgloudness, 1);
+                *rgloudness[0] = '\0';
+                }
             }
         }
 
diff --git a/c/oggdec.h b/c/oggdec.h
index d8c875e..2ace495 100644
--- a/c/oggdec.h
+++ b/c/oggdec.h
@@ -53,6 +53,7 @@ struct oggdec_vars
     char  **title;
     char  **album;
     char  **replaygain;      /* specifically replaygain_track_gain */
+    char  **rgloudness;      /* specifically replaygain_reference_loudness */
     enum streamtype_t *streamtype;    /* indicate which type ie vorbis, flac */
     double *start_time;      /* the time when each stream starts */
     double *duration;        /* playback time */
@@ -63,7 +64,7 @@ struct oggdec_vars
     };
 
 int oggdecode_reg(struct xlplayer *xlplayer);
-int oggdecode_get_metainfo(char *pathname, char **artist, char **title, char **album, double *length, char **replaygain);
+int oggdecode_get_metainfo(char *pathname, char **artist, char **title, char **album, double *length, char **replaygain, char **rgloudness);
 int oggdec_get_next_packet(struct oggdec_vars *self);
 void oggdecode_dynamic_dispatcher(struct xlplayer *xlplayer);
 void oggdecode_playnext(struct xlplayer *xlplayer);
diff --git a/config.guess b/config.guess
index 8b26ecf..8a5d3f4 100755
--- a/config.guess
+++ b/config.guess
@@ -1,8 +1,8 @@
 #! /bin/sh
 # Attempt to guess a canonical system name.
-#   Copyright 1992-2013 Free Software Foundation, Inc.
+#   Copyright 1992-2015 Free Software Foundation, Inc.
 
-timestamp='2013-11-29'
+timestamp='2015-03-04'
 
 # 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
@@ -24,12 +24,12 @@ timestamp='2013-11-29'
 # program.  This Exception is an additional permission under section 7
 # of the GNU General Public License, version 3 ("GPLv3").
 #
-# Originally written by Per Bothner.
+# Originally written by Per Bothner; maintained since 2000 by Ben Elliston.
 #
 # You can get the latest version of this script from:
 # http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD
 #
-# Please send patches with a ChangeLog entry to config-patches at gnu.org.
+# Please send patches to <config-patches at gnu.org>.
 
 
 me=`echo "$0" | sed -e 's,.*/,,'`
@@ -50,7 +50,7 @@ version="\
 GNU config.guess ($timestamp)
 
 Originally written by Per Bothner.
-Copyright 1992-2013 Free Software Foundation, Inc.
+Copyright 1992-2015 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."
@@ -149,7 +149,7 @@ Linux|GNU|GNU/*)
 	LIBC=gnu
 	#endif
 	EOF
-	eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^LIBC'`
+	eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^LIBC' | sed 's, ,,g'`
 	;;
 esac
 
@@ -168,20 +168,27 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
 	# 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)`
+	UNAME_MACHINE_ARCH=`(uname -p 2>/dev/null || \
+	    /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 ;;
+	    earmv*)
+		arch=`echo ${UNAME_MACHINE_ARCH} | sed -e 's,^e\(armv[0-9]\).*$,\1,'`
+		endian=`echo ${UNAME_MACHINE_ARCH} | sed -ne 's,^.*\(eb\)$,\1,p'`
+		machine=${arch}${endian}-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)
+	    arm*|earm*|i386|m68k|ns32k|sh3*|sparc|vax)
 		eval $set_cc_for_build
 		if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
 			| grep -q __ELF__
@@ -197,6 +204,13 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
 		os=netbsd
 		;;
 	esac
+	# Determine ABI tags.
+	case "${UNAME_MACHINE_ARCH}" in
+	    earm*)
+		expr='s/^earmv[0-9]/-eabi/;s/eb$//'
+		abi=`echo ${UNAME_MACHINE_ARCH} | sed -e "$expr"`
+		;;
+	esac
 	# The OS release
 	# Debian GNU/NetBSD machines have a different userland, and
 	# thus, need a distinct triplet. However, they do not need
@@ -213,7 +227,7 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
 	# Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
 	# contains redundant information, the shorter form:
 	# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used.
-	echo "${machine}-${os}${release}"
+	echo "${machine}-${os}${release}${abi}"
 	exit ;;
     *:Bitrig:*:*)
 	UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'`
@@ -579,8 +593,9 @@ EOF
 	else
 		IBM_ARCH=powerpc
 	fi
-	if [ -x /usr/bin/oslevel ] ; then
-		IBM_REV=`/usr/bin/oslevel`
+	if [ -x /usr/bin/lslpp ] ; then
+		IBM_REV=`/usr/bin/lslpp -Lqc bos.rte.libc |
+			   awk -F: '{ print $3 }' | sed s/[0-9]*$/0/`
 	else
 		IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
 	fi
@@ -826,7 +841,7 @@ EOF
     *:MINGW*:*)
 	echo ${UNAME_MACHINE}-pc-mingw32
 	exit ;;
-    i*:MSYS*:*)
+    *:MSYS*:*)
 	echo ${UNAME_MACHINE}-pc-msys
 	exit ;;
     i*:windows32*:*)
@@ -932,6 +947,9 @@ EOF
     crisv32:Linux:*:*)
 	echo ${UNAME_MACHINE}-axis-linux-${LIBC}
 	exit ;;
+    e2k:Linux:*:*)
+	echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+	exit ;;
     frv:Linux:*:*)
 	echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
 	exit ;;
@@ -969,10 +987,10 @@ EOF
 	eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^CPU'`
 	test x"${CPU}" != x && { echo "${CPU}-unknown-linux-${LIBC}"; exit; }
 	;;
-    or1k:Linux:*:*)
-	echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+    openrisc*:Linux:*:*)
+	echo or1k-unknown-linux-${LIBC}
 	exit ;;
-    or32:Linux:*:*)
+    or32:Linux:*:* | or1k*:Linux:*:*)
 	echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
 	exit ;;
     padre:Linux:*:*)
@@ -1382,154 +1400,6 @@ EOF
 	exit ;;
 esac
 
-eval $set_cc_for_build
-cat >$dummy.c <<EOF
-#ifdef _SEQUENT_
-# include <sys/types.h>
-# include <sys/utsname.h>
-#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 <sys/param.h>
-  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 <sys/param.h>
-#  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 <<EOF
 $0: unable to guess system type
 
diff --git a/config.h.in b/config.h.in
index 9b171ef..48c0b99 100644
--- a/config.h.in
+++ b/config.h.in
@@ -67,6 +67,9 @@
 /* Define to 1 if you have the <lame/lame.h> header file. */
 #undef HAVE_LAME_LAME_H
 
+/* Define to 1 if you have the <libavutil/channel_layout.h> header file. */
+#undef HAVE_LIBAVUTIL_CHANNEL_LAYOUT_H
+
 /* Define to 1 if your system has a GNU libc compatible `malloc' function, and
    to 0 otherwise. */
 #undef HAVE_MALLOC
@@ -134,8 +137,7 @@
 /* Define to 1 if you have the <unistd.h> header file. */
 #undef HAVE_UNISTD_H
 
-/* Define to the sub-directory in which libtool stores uninstalled libraries.
-   */
+/* Define to the sub-directory where libtool stores uninstalled libraries. */
 #undef LT_OBJDIR
 
 /* Define to 1 if your C compiler doesn't accept -c and -o together. */
@@ -171,6 +173,9 @@
 /* Set if GNU extensions need to be replicated */
 #undef USE_BSD_COMPAT
 
+/* Set if libswresample allows format conversion */
+#undef USE_SWRESAMPLE
+
 /* Version number of package */
 #undef VERSION
 
diff --git a/config.sub b/config.sub
index 4ffb084..430106a 100755
--- a/config.sub
+++ b/config.sub
@@ -1,8 +1,8 @@
 #! /bin/sh
 # Configuration validation subroutine script.
-#   Copyright 1992-2013 Free Software Foundation, Inc.
+#   Copyright 1992-2015 Free Software Foundation, Inc.
 
-timestamp='2013-10-01'
+timestamp='2015-03-08'
 
 # 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
@@ -25,7 +25,7 @@ timestamp='2013-10-01'
 # of the GNU General Public License, version 3 ("GPLv3").
 
 
-# Please send patches with a ChangeLog entry to config-patches at gnu.org.
+# Please send patches to <config-patches at gnu.org>.
 #
 # Configuration subroutine to validate and canonicalize a configuration type.
 # Supply the specified configuration type as an argument.
@@ -68,7 +68,7 @@ Report bugs and patches to <config-patches at gnu.org>."
 version="\
 GNU config.sub ($timestamp)
 
-Copyright 1992-2013 Free Software Foundation, Inc.
+Copyright 1992-2015 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."
@@ -117,7 +117,7 @@ maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
 case $maybe_os in
   nto-qnx* | linux-gnu* | linux-android* | linux-dietlibc | linux-newlib* | \
   linux-musl* | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | \
-  knetbsd*-gnu* | netbsd*-gnu* | \
+  knetbsd*-gnu* | netbsd*-gnu* | netbsd*-eabi* | \
   kopensolaris*-gnu* | \
   storm-chaos* | os2-emx* | rtmk-nova*)
     os=-$maybe_os
@@ -259,8 +259,8 @@ case $basic_machine in
 	| bfin \
 	| c4x | c8051 | clipper \
 	| d10v | d30v | dlx | dsp16xx | dvp \
-	| epiphany \
-	| fido | fr30 | frv \
+	| e2k | epiphany \
+	| fido | fr30 | frv | ft32 \
 	| h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
 	| hexagon \
 	| i370 | i860 | i960 | ia64 \
@@ -283,8 +283,10 @@ case $basic_machine in
 	| mips64vr5900 | mips64vr5900el \
 	| mipsisa32 | mipsisa32el \
 	| mipsisa32r2 | mipsisa32r2el \
+	| mipsisa32r6 | mipsisa32r6el \
 	| mipsisa64 | mipsisa64el \
 	| mipsisa64r2 | mipsisa64r2el \
+	| mipsisa64r6 | mipsisa64r6el \
 	| mipsisa64sb1 | mipsisa64sb1el \
 	| mipsisa64sr71k | mipsisa64sr71kel \
 	| mipsr5900 | mipsr5900el \
@@ -296,11 +298,11 @@ case $basic_machine in
 	| nds32 | nds32le | nds32be \
 	| nios | nios2 | nios2eb | nios2el \
 	| ns16k | ns32k \
-	| open8 \
-	| or1k | or32 \
+	| open8 | or1k | or1knd | or32 \
 	| pdp10 | pdp11 | pj | pjl \
 	| powerpc | powerpc64 | powerpc64le | powerpcle \
 	| pyramid \
+	| riscv32 | riscv64 \
 	| rl78 | rx \
 	| score \
 	| sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[34]eb | sheb | shbe | shle | sh[1234]le | sh3ele \
@@ -311,6 +313,7 @@ case $basic_machine in
 	| tahoe | tic4x | tic54x | tic55x | tic6x | tic80 | tron \
 	| ubicom32 \
 	| v850 | v850e | v850e1 | v850e2 | v850es | v850e2v3 \
+	| visium \
 	| we32k \
 	| x86 | xc16x | xstormy16 | xtensa \
 	| z8k | z80)
@@ -325,6 +328,9 @@ case $basic_machine in
 	c6x)
 		basic_machine=tic6x-unknown
 		;;
+	leon|leon[3-9])
+		basic_machine=sparc-$basic_machine
+		;;
 	m6811 | m68hc11 | m6812 | m68hc12 | m68hcs12x | nvptx | picochip)
 		basic_machine=$basic_machine-unknown
 		os=-none
@@ -375,7 +381,7 @@ case $basic_machine in
 	| c[123]* | c30-* | [cjt]90-* | c4x-* \
 	| c8051-* | clipper-* | craynv-* | cydra-* \
 	| d10v-* | d30v-* | dlx-* \
-	| elxsi-* \
+	| e2k-* | elxsi-* \
 	| f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \
 	| h8300-* | h8500-* \
 	| hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \
@@ -402,8 +408,10 @@ case $basic_machine in
 	| mips64vr5900-* | mips64vr5900el-* \
 	| mipsisa32-* | mipsisa32el-* \
 	| mipsisa32r2-* | mipsisa32r2el-* \
+	| mipsisa32r6-* | mipsisa32r6el-* \
 	| mipsisa64-* | mipsisa64el-* \
 	| mipsisa64r2-* | mipsisa64r2el-* \
+	| mipsisa64r6-* | mipsisa64r6el-* \
 	| mipsisa64sb1-* | mipsisa64sb1el-* \
 	| mipsisa64sr71k-* | mipsisa64sr71kel-* \
 	| mipsr5900-* | mipsr5900el-* \
@@ -415,6 +423,7 @@ case $basic_machine in
 	| nios-* | nios2-* | nios2eb-* | nios2el-* \
 	| none-* | np1-* | ns16k-* | ns32k-* \
 	| open8-* \
+	| or1k*-* \
 	| orion-* \
 	| pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \
 	| powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* \
@@ -432,6 +441,7 @@ case $basic_machine in
 	| ubicom32-* \
 	| v850-* | v850e-* | v850e1-* | v850es-* | v850e2-* | v850e2v3-* \
 	| vax-* \
+	| visium-* \
 	| we32k-* \
 	| x86-* | x86_64-* | xc16x-* | xps100-* \
 	| xstormy16-* | xtensa*-* \
@@ -508,6 +518,9 @@ case $basic_machine in
 		basic_machine=i386-pc
 		os=-aros
 		;;
+        asmjs)
+		basic_machine=asmjs-unknown
+		;;
 	aux)
 		basic_machine=m68k-apple
 		os=-aux
@@ -769,6 +782,9 @@ case $basic_machine in
 		basic_machine=m68k-isi
 		os=-sysv
 		;;
+	leon-*|leon[3-9]-*)
+		basic_machine=sparc-`echo $basic_machine | sed 's/-.*//'`
+		;;
 	m68knommu)
 		basic_machine=m68k-unknown
 		os=-linux
@@ -842,6 +858,10 @@ case $basic_machine in
 		basic_machine=powerpc-unknown
 		os=-morphos
 		;;
+	moxiebox)
+		basic_machine=moxie-unknown
+		os=-moxiebox
+		;;
 	msdos)
 		basic_machine=i386-pc
 		os=-msdos
@@ -1374,7 +1394,7 @@ case $os in
 	      | -hpux* | -unos* | -osf* | -luna* | -dgux* | -auroraux* | -solaris* \
 	      | -sym* | -kopensolaris* | -plan9* \
 	      | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \
-	      | -aos* | -aros* \
+	      | -aos* | -aros* | -cloudabi* \
 	      | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \
 	      | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \
 	      | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \
@@ -1387,14 +1407,14 @@ case $os in
 	      | -cygwin* | -msys* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
 	      | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \
 	      | -linux-newlib* | -linux-musl* | -linux-uclibc* \
-	      | -uxpv* | -beos* | -mpeix* | -udk* \
+	      | -uxpv* | -beos* | -mpeix* | -udk* | -moxiebox* \
 	      | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \
 	      | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
 	      | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* | -irx* \
 	      | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \
 	      | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \
 	      | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \
-	      | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es*)
+	      | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* | -tirtos*)
 	# Remember, each alternative MUST END IN *, to match a version number.
 		;;
 	-qnx*)
@@ -1612,9 +1632,6 @@ case $basic_machine in
 	mips*-*)
 		os=-elf
 		;;
-	or1k-*)
-		os=-elf
-		;;
 	or32-*)
 		os=-coff
 		;;
diff --git a/configure b/configure
index 25f5999..955e0d3 100755
--- a/configure
+++ b/configure
@@ -1,6 +1,6 @@
 #! /bin/sh
 # Guess values for system-dependent variables and create Makefiles.
-# Generated by GNU Autoconf 2.69 for idjc 0.8.14.
+# Generated by GNU Autoconf 2.69 for idjc 0.8.15.
 #
 # Report bugs to <http://idjc.sourceforge.net>.
 #
@@ -590,8 +590,8 @@ MAKEFLAGS=
 # Identity of this package.
 PACKAGE_NAME='idjc'
 PACKAGE_TARNAME='idjc'
-PACKAGE_VERSION='0.8.14'
-PACKAGE_STRING='idjc 0.8.14'
+PACKAGE_VERSION='0.8.15'
+PACKAGE_STRING='idjc 0.8.15'
 PACKAGE_BUGREPORT='http://idjc.sourceforge.net'
 PACKAGE_URL=''
 
@@ -677,6 +677,9 @@ HAVE_AVFORMAT
 LIBAVCODEC_LIBS
 LIBAVCODEC_CFLAGS
 HAVE_AVCODEC
+GIT_VERSION_CONTROL_FALSE
+GIT_VERSION_CONTROL_TRUE
+GIT_PROG_EXISTS
 GLIB_LIBS
 GLIB_CFLAGS
 LIBSNDFILE_LIBS
@@ -710,6 +713,7 @@ MSGFMT
 GETTEXT_MACRO_VERSION
 USE_NLS
 CPP
+LT_SYS_LIBRARY_PATH
 OTOOL64
 OTOOL
 LIPO
@@ -845,6 +849,7 @@ enable_static
 enable_shared
 with_pic
 enable_fast_install
+with_aix_soname
 enable_dependency_tracking
 with_gnu_ld
 with_sysroot
@@ -870,6 +875,7 @@ CFLAGS
 LDFLAGS
 LIBS
 CPPFLAGS
+LT_SYS_LIBRARY_PATH
 CPP
 PKG_CONFIG
 PKG_CONFIG_PATH
@@ -1448,7 +1454,7 @@ 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 idjc 0.8.14 to adapt to many kinds of systems.
+\`configure' configures idjc 0.8.15 to adapt to many kinds of systems.
 
 Usage: $0 [OPTION]... [VAR=VALUE]...
 
@@ -1519,7 +1525,7 @@ fi
 
 if test -n "$ac_init_help"; then
   case $ac_init_help in
-     short | recursive ) echo "Configuration of idjc 0.8.14:";;
+     short | recursive ) echo "Configuration of idjc 0.8.15:";;
    esac
   cat <<\_ACEOF
 
@@ -1553,9 +1559,12 @@ Optional Packages:
   --without-PACKAGE       do not use PACKAGE (same as --with-PACKAGE=no)
   --with-pic[=PKGS]       try to use only PIC/non-PIC objects [default=use
                           both]
+  --with-aix-soname=aix|svr4|both
+                          shared library versioning (aka "SONAME") variant to
+                          provide on AIX, [default=aix].
   --with-gnu-ld           assume the C compiler uses GNU ld [default=no]
-  --with-sysroot=DIR Search for dependent libraries within DIR
-                        (or the compiler's sysroot if not specified).
+  --with-sysroot[=DIR]    Search for dependent libraries within DIR (or the
+                          compiler's sysroot if not specified).
   --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
@@ -1571,6 +1580,8 @@ Some influential environment variables:
   LIBS        libraries to pass to the linker, e.g. -l<library>
   CPPFLAGS    (Objective) C/C++ preprocessor flags, e.g. -I<include dir> if
               you have headers in a nonstandard directory <include dir>
+  LT_SYS_LIBRARY_PATH
+              User-defined run-time library search path.
   CPP         C preprocessor
   PKG_CONFIG  path to pkg-config utility
   PKG_CONFIG_PATH
@@ -1706,7 +1717,7 @@ fi
 test -n "$ac_init_help" && exit $ac_status
 if $ac_init_version; then
   cat <<\_ACEOF
-idjc configure 0.8.14
+idjc configure 0.8.15
 generated by GNU Autoconf 2.69
 
 Copyright (C) 2012 Free Software Foundation, Inc.
@@ -2129,7 +2140,7 @@ cat >config.log <<_ACEOF
 This file contains any messages produced by compilers while
 running configure, to aid debugging if configure makes a mistake.
 
-It was created by idjc $as_me 0.8.14, which was
+It was created by idjc $as_me 0.8.15, which was
 generated by GNU Autoconf 2.69.  Invocation command line was
 
   $ $0 $@
@@ -2478,7 +2489,7 @@ ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $
 ac_compiler_gnu=$ac_cv_c_compiler_gnu
 
 
-COPYRIGHT_YEAR=2013
+COPYRIGHT_YEAR=2015
 
 ac_aux_dir=
 for ac_dir in "$srcdir" "$srcdir/.." "$srcdir/../.."; do
@@ -3107,7 +3118,7 @@ fi
 
 # Define the identity of the package.
  PACKAGE='idjc'
- VERSION='0.8.14'
+ VERSION='0.8.15'
 
 
 cat >>confdefs.h <<_ACEOF
@@ -3437,8 +3448,8 @@ esac
 
 
 
-macro_version='2.4.2'
-macro_revision='1.3337'
+macro_version='2.4.6'
+macro_revision='2.4.6'
 
 
 
@@ -3452,7 +3463,7 @@ macro_revision='1.3337'
 
 
 
-ltmain="$ac_aux_dir/ltmain.sh"
+ltmain=$ac_aux_dir/ltmain.sh
 
 # Backslashify metacharacters that are still active within
 # double-quoted strings.
@@ -3501,7 +3512,7 @@ func_echo_all ()
     $ECHO ""
 }
 
-case "$ECHO" in
+case $ECHO in
   printf*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: printf" >&5
 $as_echo "printf" >&6; } ;;
   print*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: print -r" >&5
@@ -4804,19 +4815,19 @@ test -z "$GREP" && GREP=grep
 
 # Check whether --with-gnu-ld was given.
 if test "${with_gnu_ld+set}" = set; then :
-  withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes
+  withval=$with_gnu_ld; test no = "$withval" || with_gnu_ld=yes
 else
   with_gnu_ld=no
 fi
 
 ac_prog=ld
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
   # Check if gcc -print-prog-name=ld gives a path.
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5
 $as_echo_n "checking for ld used by $CC... " >&6; }
   case $host in
   *-*-mingw*)
-    # gcc leaves a trailing carriage return which upsets 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` ;;
@@ -4830,7 +4841,7 @@ $as_echo_n "checking for ld used by $CC... " >&6; }
       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"
+      test -z "$LD" && LD=$ac_prog
       ;;
   "")
     # If it fails, then pretend we aren't using GCC.
@@ -4841,7 +4852,7 @@ $as_echo_n "checking for ld used by $CC... " >&6; }
     with_gnu_ld=unknown
     ;;
   esac
-elif test "$with_gnu_ld" = yes; then
+elif test yes = "$with_gnu_ld"; then
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5
 $as_echo_n "checking for GNU ld... " >&6; }
 else
@@ -4852,32 +4863,32 @@ if ${lt_cv_path_LD+:} false; then :
   $as_echo_n "(cached) " >&6
 else
   if test -z "$LD"; then
-  lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+  lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
   for ac_dir in $PATH; do
-    IFS="$lt_save_ifs"
+    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"
+      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 </dev/null` in
       *GNU* | *'with BFD'*)
-	test "$with_gnu_ld" != no && break
+	test no != "$with_gnu_ld" && break
 	;;
       *)
-	test "$with_gnu_ld" != yes && break
+	test yes != "$with_gnu_ld" && break
 	;;
       esac
     fi
   done
-  IFS="$lt_save_ifs"
+  IFS=$lt_save_ifs
 else
-  lt_cv_path_LD="$LD" # Let the user override the test with a path.
+  lt_cv_path_LD=$LD # Let the user override the test with a path.
 fi
 fi
 
-LD="$lt_cv_path_LD"
+LD=$lt_cv_path_LD
 if test -n "$LD"; then
   { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LD" >&5
 $as_echo "$LD" >&6; }
@@ -4920,33 +4931,38 @@ if ${lt_cv_path_NM+:} false; then :
 else
   if test -n "$NM"; then
   # Let the user override the test.
-  lt_cv_path_NM="$NM"
+  lt_cv_path_NM=$NM
 else
-  lt_nm_to_check="${ac_tool_prefix}nm"
+  lt_nm_to_check=${ac_tool_prefix}nm
   if test -n "$ac_tool_prefix" && test "$build" = "$host"; then
     lt_nm_to_check="$lt_nm_to_check nm"
   fi
   for lt_tmp_nm in $lt_nm_to_check; do
-    lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+    lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
     for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do
-      IFS="$lt_save_ifs"
+      IFS=$lt_save_ifs
       test -z "$ac_dir" && ac_dir=.
-      tmp_nm="$ac_dir/$lt_tmp_nm"
-      if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then
+      tmp_nm=$ac_dir/$lt_tmp_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:
+	# 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'*)
+	# MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty
+	case $build_os in
+	mingw*) lt_bad_file=conftest.nm/nofile ;;
+	*) lt_bad_file=/dev/null ;;
+	esac
+	case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in
+	*$lt_bad_file* | *'Invalid file or object type'*)
 	  lt_cv_path_NM="$tmp_nm -B"
-	  break
+	  break 2
 	  ;;
 	*)
 	  case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in
 	  */dev/null*)
 	    lt_cv_path_NM="$tmp_nm -p"
-	    break
+	    break 2
 	    ;;
 	  *)
 	    lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but
@@ -4957,15 +4973,15 @@ else
 	esac
       fi
     done
-    IFS="$lt_save_ifs"
+    IFS=$lt_save_ifs
   done
   : ${lt_cv_path_NM=no}
 fi
 fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_NM" >&5
 $as_echo "$lt_cv_path_NM" >&6; }
-if test "$lt_cv_path_NM" != "no"; then
-  NM="$lt_cv_path_NM"
+if test no != "$lt_cv_path_NM"; then
+  NM=$lt_cv_path_NM
 else
   # Didn't find any BSD compatible name lister, look for dumpbin.
   if test -n "$DUMPBIN"; then :
@@ -5071,9 +5087,9 @@ esac
   fi
 fi
 
-    case `$DUMPBIN -symbols /dev/null 2>&1 | sed '1q'` in
+    case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in
     *COFF*)
-      DUMPBIN="$DUMPBIN -symbols"
+      DUMPBIN="$DUMPBIN -symbols -headers"
       ;;
     *)
       DUMPBIN=:
@@ -5081,8 +5097,8 @@ fi
     esac
   fi
 
-  if test "$DUMPBIN" != ":"; then
-    NM="$DUMPBIN"
+  if test : != "$DUMPBIN"; then
+    NM=$DUMPBIN
   fi
 fi
 test -z "$NM" && NM=nm
@@ -5133,7 +5149,7 @@ if ${lt_cv_sys_max_cmd_len+:} false; then :
   $as_echo_n "(cached) " >&6
 else
     i=0
-  teststring="ABCD"
+  teststring=ABCD
 
   case $build_os in
   msdosdjgpp*)
@@ -5173,7 +5189,7 @@ else
     lt_cv_sys_max_cmd_len=8192;
     ;;
 
-  netbsd* | freebsd* | openbsd* | darwin* | dragonfly*)
+  bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*)
     # 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`
@@ -5223,22 +5239,23 @@ else
     ;;
   *)
     lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null`
-    if test -n "$lt_cv_sys_max_cmd_len"; then
+    if test -n "$lt_cv_sys_max_cmd_len" && \
+       test undefined != "$lt_cv_sys_max_cmd_len"; then
       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`
     else
       # Make teststring a little bigger before we do anything with it.
       # a 1K string should be a reasonable start.
-      for i in 1 2 3 4 5 6 7 8 ; do
+      for i in 1 2 3 4 5 6 7 8; do
         teststring=$teststring$teststring
       done
       SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}}
       # 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.
-      while { test "X"`env echo "$teststring$teststring" 2>/dev/null` \
+      while { test X`env echo "$teststring$teststring" 2>/dev/null` \
 	         = "X$teststring$teststring"; } >/dev/null 2>&1 &&
-	      test $i != 17 # 1/2 MB should be enough
+	      test 17 != "$i" # 1/2 MB should be enough
       do
         i=`expr $i + 1`
         teststring=$teststring$teststring
@@ -5256,7 +5273,7 @@ else
 
 fi
 
-if test -n $lt_cv_sys_max_cmd_len ; then
+if test -n "$lt_cv_sys_max_cmd_len"; then
   { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sys_max_cmd_len" >&5
 $as_echo "$lt_cv_sys_max_cmd_len" >&6; }
 else
@@ -5274,30 +5291,6 @@ max_cmd_len=$lt_cv_sys_max_cmd_len
 : ${MV="mv -f"}
 : ${RM="rm -f"}
 
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the shell understands some XSI constructs" >&5
-$as_echo_n "checking whether the shell understands some XSI constructs... " >&6; }
-# Try some XSI features
-xsi_shell=no
-( _lt_dummy="a/b/c"
-  test "${_lt_dummy##*/},${_lt_dummy%/*},${_lt_dummy#??}"${_lt_dummy%"$_lt_dummy"}, \
-      = c,a/b,b/c, \
-    && eval 'test $(( 1 + 1 )) -eq 2 \
-    && test "${#_lt_dummy}" -eq 5' ) >/dev/null 2>&1 \
-  && xsi_shell=yes
-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $xsi_shell" >&5
-$as_echo "$xsi_shell" >&6; }
-
-
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the shell understands \"+=\"" >&5
-$as_echo_n "checking whether the shell understands \"+=\"... " >&6; }
-lt_shell_append=no
-( foo=bar; set foo baz; eval "$1+=\$2" && test "$foo" = barbaz ) \
-    >/dev/null 2>&1 \
-  && lt_shell_append=yes
-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_shell_append" >&5
-$as_echo "$lt_shell_append" >&6; }
-
-
 if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
   lt_unset=unset
 else
@@ -5420,13 +5413,13 @@ esac
 reload_cmds='$LD$reload_flag -o $output$reload_objs'
 case $host_os in
   cygwin* | mingw* | pw32* | cegcc*)
-    if test "$GCC" != yes; then
+    if test yes != "$GCC"; then
       reload_cmds=false
     fi
     ;;
   darwin*)
-    if test "$GCC" = yes; then
-      reload_cmds='$LTCC $LTCFLAGS -nostdlib ${wl}-r -o $output$reload_objs'
+    if test yes = "$GCC"; then
+      reload_cmds='$LTCC $LTCFLAGS -nostdlib $wl-r -o $output$reload_objs'
     else
       reload_cmds='$LD$reload_flag -o $output$reload_objs'
     fi
@@ -5554,13 +5547,13 @@ 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.
+# '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.
+# that 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
 aix[4-9]*)
@@ -5587,8 +5580,7 @@ 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',
   # unless we find 'file', for example because we are cross-compiling.
-  # func_win32_libid assumes BSD nm, so disallow it if using MS dumpbin.
-  if ( test "$lt_cv_nm_interface" = "BSD nm" && file / ) >/dev/null 2>&1; then
+  if ( file / ) >/dev/null 2>&1; then
     lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL'
     lt_cv_file_magic_cmd='func_win32_libid'
   else
@@ -5624,10 +5616,6 @@ freebsd* | dragonfly*)
   fi
   ;;
 
-gnu*)
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-
 haiku*)
   lt_cv_deplibs_check_method=pass_all
   ;;
@@ -5666,7 +5654,7 @@ irix5* | irix6* | nonstopux*)
   ;;
 
 # This must be glibc/ELF.
-linux* | k*bsd*-gnu | kopensolaris*-gnu)
+linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
   lt_cv_deplibs_check_method=pass_all
   ;;
 
@@ -5688,8 +5676,8 @@ newos6*)
   lt_cv_deplibs_check_method=pass_all
   ;;
 
-openbsd*)
-  if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+openbsd* | bitrig*)
+  if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; 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)$'
@@ -5742,6 +5730,9 @@ sysv4 | sysv4.3*)
 tpf*)
   lt_cv_deplibs_check_method=pass_all
   ;;
+os2*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
 esac
 
 fi
@@ -5899,8 +5890,8 @@ else
 
 case $host_os in
 cygwin* | mingw* | pw32* | cegcc*)
-  # two different shell functions defined in ltmain.sh
-  # decide which to use based on capabilities of $DLLTOOL
+  # two different shell functions defined in ltmain.sh;
+  # decide which one to use based on capabilities of $DLLTOOL
   case `$DLLTOOL --help 2>&1` in
   *--identify-strict*)
     lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib
@@ -5912,7 +5903,7 @@ cygwin* | mingw* | pw32* | cegcc*)
   ;;
 *)
   # fallback: assume linklib IS sharedlib
-  lt_cv_sharedlib_from_linklib_cmd="$ECHO"
+  lt_cv_sharedlib_from_linklib_cmd=$ECHO
   ;;
 esac
 
@@ -6067,7 +6058,7 @@ if ac_fn_c_try_compile "$LINENO"; then :
   ac_status=$?
   $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
   test $ac_status = 0; }
-      if test "$ac_status" -eq 0; then
+      if test 0 -eq "$ac_status"; then
 	# Ensure the archiver fails upon bogus file names.
 	rm -f conftest.$ac_objext libconftest.a
 	{ { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5
@@ -6075,7 +6066,7 @@ if ac_fn_c_try_compile "$LINENO"; then :
   ac_status=$?
   $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
   test $ac_status = 0; }
-	if test "$ac_status" -ne 0; then
+	if test 0 -ne "$ac_status"; then
           lt_cv_ar_at_file=@
         fi
       fi
@@ -6088,7 +6079,7 @@ fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ar_at_file" >&5
 $as_echo "$lt_cv_ar_at_file" >&6; }
 
-if test "x$lt_cv_ar_at_file" = xno; then
+if test no = "$lt_cv_ar_at_file"; then
   archiver_list_spec=
 else
   archiver_list_spec=$lt_cv_ar_at_file
@@ -6305,7 +6296,7 @@ old_postuninstall_cmds=
 
 if test -n "$RANLIB"; then
   case $host_os in
-  openbsd*)
+  bitrig* | openbsd*)
     old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib"
     ;;
   *)
@@ -6395,7 +6386,7 @@ cygwin* | mingw* | pw32* | cegcc*)
   symcode='[ABCDGISTW]'
   ;;
 hpux*)
-  if test "$host_cpu" = ia64; then
+  if test ia64 = "$host_cpu"; then
     symcode='[ABCDEGRST]'
   fi
   ;;
@@ -6428,14 +6419,44 @@ case `$NM -V 2>&1` in
   symcode='[ABCDGIRSTW]' ;;
 esac
 
+if test "$lt_cv_nm_interface" = "MS dumpbin"; then
+  # Gets list of data symbols to import.
+  lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'"
+  # Adjust the below global symbol transforms to fixup imported variables.
+  lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'"
+  lt_c_name_hook=" -e 's/^I .* \(.*\)$/  {\"\1\", (void *) 0},/p'"
+  lt_c_name_lib_hook="\
+  -e 's/^I .* \(lib.*\)$/  {\"\1\", (void *) 0},/p'\
+  -e 's/^I .* \(.*\)$/  {\"lib\1\", (void *) 0},/p'"
+else
+  # Disable hooks by default.
+  lt_cv_sys_global_symbol_to_import=
+  lt_cdecl_hook=
+  lt_c_name_hook=
+  lt_c_name_lib_hook=
+fi
+
 # Transform an extracted symbol line into a proper C declaration.
 # Some systems (esp. on ia64) link data and code symbols differently,
 # so use this general approach.
-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_cdecl="sed -n"\
+$lt_cdecl_hook\
+" -e 's/^T .* \(.*\)$/extern int \1();/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/extern char \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\\\", (void *) 0},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/  {\"\2\", (void *) \&\2},/p'"
-lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n -e 's/^: \([^ ]*\)[ ]*$/  {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([^ ]*\) \(lib[^ ]*\)$/  {\"\2\", (void *) \&\2},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/  {\"lib\2\", (void *) \&\2},/p'"
+lt_cv_sys_global_symbol_to_c_name_address="sed -n"\
+$lt_c_name_hook\
+" -e 's/^: \(.*\) .*$/  {\"\1\", (void *) 0},/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/  {\"\1\", (void *) \&\1},/p'"
+
+# Transform an extracted symbol line into symbol name with lib prefix and
+# symbol address.
+lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\
+$lt_c_name_lib_hook\
+" -e 's/^: \(.*\) .*$/  {\"\1\", (void *) 0},/p'"\
+" -e 's/^$symcode$symcode* .* \(lib.*\)$/  {\"\1\", (void *) \&\1},/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/  {\"lib\1\", (void *) \&\1},/p'"
 
 # Handle CRLF in mingw tool chain
 opt_cr=
@@ -6453,21 +6474,24 @@ for ac_symprfx in "" "_"; do
 
   # Write the raw and C identifiers.
   if test "$lt_cv_nm_interface" = "MS dumpbin"; then
-    # Fake it for dumpbin and say T for any non-static function
-    # and D for any global variable.
+    # Fake it for dumpbin and say T for any non-static function,
+    # D for any global variable and I for any imported variable.
     # Also find C++ and __fastcall symbols from MSVC++,
     # which start with @ or ?.
     lt_cv_sys_global_symbol_pipe="$AWK '"\
 "     {last_section=section; section=\$ 3};"\
 "     /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\
 "     /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\
+"     /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\
+"     /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\
+"     /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\
 "     \$ 0!~/External *\|/{next};"\
 "     / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\
 "     {if(hide[section]) next};"\
-"     {f=0}; \$ 0~/\(\).*\|/{f=1}; {printf f ? \"T \" : \"D \"};"\
-"     {split(\$ 0, a, /\||\r/); split(a[2], s)};"\
-"     s[1]~/^[@?]/{print s[1], s[1]; next};"\
-"     s[1]~prfx {split(s[1],t,\"@\"); print t[1], substr(t[1],length(prfx))}"\
+"     {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\
+"     {split(\$ 0,a,/\||\r/); split(a[2],s)};"\
+"     s[1]~/^[@?]/{print f,s[1],s[1]; next};"\
+"     s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\
 "     ' prfx=^$ac_symprfx"
   else
     lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[	 ]\($symcode$symcode*\)[	 ][	 ]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'"
@@ -6515,11 +6539,11 @@ _LT_EOF
 	if $GREP ' nm_test_func$' "$nlist" >/dev/null; then
 	  cat <<_LT_EOF > conftest.$ac_ext
 /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests.  */
-#if defined(_WIN32) || defined(__CYGWIN__) || defined(_WIN32_WCE)
-/* DATA imports from DLLs on WIN32 con't be const, because runtime
+#if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE
+/* DATA imports from DLLs on WIN32 can't be const, because runtime
    relocations are performed -- see ld's documentation on pseudo-relocs.  */
 # define LT_DLSYM_CONST
-#elif defined(__osf__)
+#elif defined __osf__
 /* This system does not cope well with relocations in const data.  */
 # define LT_DLSYM_CONST
 #else
@@ -6545,7 +6569,7 @@ lt__PROGRAM__LTX_preloaded_symbols[] =
 {
   { "@PROGRAM@", (void *) 0 },
 _LT_EOF
-	  $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/  {\"\2\", (void *) \&\2},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext
+	  $SED "s/^$symcode$symcode* .* \(.*\)$/  {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext
 	  cat <<\_LT_EOF >> conftest.$ac_ext
   {0, (void *) 0}
 };
@@ -6565,13 +6589,13 @@ _LT_EOF
 	  mv conftest.$ac_objext conftstm.$ac_objext
 	  lt_globsym_save_LIBS=$LIBS
 	  lt_globsym_save_CFLAGS=$CFLAGS
-	  LIBS="conftstm.$ac_objext"
+	  LIBS=conftstm.$ac_objext
 	  CFLAGS="$CFLAGS$lt_prog_compiler_no_builtin_flag"
 	  if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5
   (eval $ac_link) 2>&5
   ac_status=$?
   $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
-  test $ac_status = 0; } && test -s conftest${ac_exeext}; then
+  test $ac_status = 0; } && test -s conftest$ac_exeext; then
 	    pipe_works=yes
 	  fi
 	  LIBS=$lt_globsym_save_LIBS
@@ -6592,7 +6616,7 @@ _LT_EOF
   rm -rf conftest* conftst*
 
   # Do not use the global_symbol_pipe unless it works.
-  if test "$pipe_works" = yes; then
+  if test yes = "$pipe_works"; then
     break
   else
     lt_cv_sys_global_symbol_pipe=
@@ -6645,6 +6669,16 @@ fi
 
 
 
+
+
+
+
+
+
+
+
+
+
 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for sysroot" >&5
 $as_echo_n "checking for sysroot... " >&6; }
 
@@ -6657,9 +6691,9 @@ fi
 
 
 lt_sysroot=
-case ${with_sysroot} in #(
+case $with_sysroot in #(
  yes)
-   if test "$GCC" = yes; then
+   if test yes = "$GCC"; then
      lt_sysroot=`$CC --print-sysroot 2>/dev/null`
    fi
    ;; #(
@@ -6669,8 +6703,8 @@ case ${with_sysroot} in #(
  no|'')
    ;; #(
  *)
-   { $as_echo "$as_me:${as_lineno-$LINENO}: result: ${with_sysroot}" >&5
-$as_echo "${with_sysroot}" >&6; }
+   { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_sysroot" >&5
+$as_echo "$with_sysroot" >&6; }
    as_fn_error $? "The sysroot must be an absolute path." "$LINENO" 5
    ;;
 esac
@@ -6682,18 +6716,99 @@ $as_echo "${lt_sysroot:-no}" >&6; }
 
 
 
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a working dd" >&5
+$as_echo_n "checking for a working dd... " >&6; }
+if ${ac_cv_path_lt_DD+:} false; then :
+  $as_echo_n "(cached) " >&6
+else
+  printf 0123456789abcdef0123456789abcdef >conftest.i
+cat conftest.i conftest.i >conftest2.i
+: ${lt_DD:=$DD}
+if test -z "$lt_DD"; then
+  ac_path_lt_DD_found=false
+  # Loop through the user's path and test for each of PROGNAME-LIST
+  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_prog in dd; do
+    for ac_exec_ext in '' $ac_executable_extensions; do
+      ac_path_lt_DD="$as_dir/$ac_prog$ac_exec_ext"
+      as_fn_executable_p "$ac_path_lt_DD" || continue
+if "$ac_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then
+  cmp -s conftest.i conftest.out \
+  && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=:
+fi
+      $ac_path_lt_DD_found && break 3
+    done
+  done
+  done
+IFS=$as_save_IFS
+  if test -z "$ac_cv_path_lt_DD"; then
+    :
+  fi
+else
+  ac_cv_path_lt_DD=$lt_DD
+fi
+
+rm -f conftest.i conftest2.i conftest.out
+fi
+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_lt_DD" >&5
+$as_echo "$ac_cv_path_lt_DD" >&6; }
+
+
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to truncate binary pipes" >&5
+$as_echo_n "checking how to truncate binary pipes... " >&6; }
+if ${lt_cv_truncate_bin+:} false; then :
+  $as_echo_n "(cached) " >&6
+else
+  printf 0123456789abcdef0123456789abcdef >conftest.i
+cat conftest.i conftest.i >conftest2.i
+lt_cv_truncate_bin=
+if "$ac_cv_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then
+  cmp -s conftest.i conftest.out \
+  && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1"
+fi
+rm -f conftest.i conftest2.i conftest.out
+test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q"
+fi
+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_truncate_bin" >&5
+$as_echo "$lt_cv_truncate_bin" >&6; }
+
+
+
+
+
+
+
+# Calculate cc_basename.  Skip known compiler wrappers and cross-prefix.
+func_cc_basename ()
+{
+    for cc_temp in $*""; do
+      case $cc_temp in
+        compile | *[\\/]compile | ccache | *[\\/]ccache ) ;;
+        distcc | *[\\/]distcc | purify | *[\\/]purify ) ;;
+        \-*) ;;
+        *) break;;
+      esac
+    done
+    func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"`
+}
+
 # Check whether --enable-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
+test no = "$enable_libtool_lock" || 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.
+  # Find out what ABI is being produced by ac_compile, and set mode
+  # options accordingly.
   echo 'int i;' > conftest.$ac_ext
   if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
   (eval $ac_compile) 2>&5
@@ -6702,24 +6817,25 @@ ia64-*-hpux*)
   test $ac_status = 0; }; then
     case `/usr/bin/file conftest.$ac_objext` in
       *ELF-32*)
-	HPUX_IA64_MODE="32"
+	HPUX_IA64_MODE=32
 	;;
       *ELF-64*)
-	HPUX_IA64_MODE="64"
+	HPUX_IA64_MODE=64
 	;;
     esac
   fi
   rm -rf conftest*
   ;;
 *-*-irix6*)
-  # Find out which ABI we are using.
+  # Find out what ABI is being produced by ac_compile, and set linker
+  # options accordingly.
   echo '#line '$LINENO' "configure"' > conftest.$ac_ext
   if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
   (eval $ac_compile) 2>&5
   ac_status=$?
   $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
   test $ac_status = 0; }; then
-    if test "$lt_cv_prog_gnu_ld" = yes; then
+    if test yes = "$lt_cv_prog_gnu_ld"; then
       case `/usr/bin/file conftest.$ac_objext` in
 	*32-bit*)
 	  LD="${LD-ld} -melf32bsmip"
@@ -6748,9 +6864,50 @@ ia64-*-hpux*)
   rm -rf conftest*
   ;;
 
-x86_64-*kfreebsd*-gnu|x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*| \
+mips64*-*linux*)
+  # Find out what ABI is being produced by ac_compile, and set linker
+  # options accordingly.
+  echo '#line '$LINENO' "configure"' > conftest.$ac_ext
+  if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
+  (eval $ac_compile) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
+  test $ac_status = 0; }; then
+    emul=elf
+    case `/usr/bin/file conftest.$ac_objext` in
+      *32-bit*)
+	emul="${emul}32"
+	;;
+      *64-bit*)
+	emul="${emul}64"
+	;;
+    esac
+    case `/usr/bin/file conftest.$ac_objext` in
+      *MSB*)
+	emul="${emul}btsmip"
+	;;
+      *LSB*)
+	emul="${emul}ltsmip"
+	;;
+    esac
+    case `/usr/bin/file conftest.$ac_objext` in
+      *N32*)
+	emul="${emul}n32"
+	;;
+    esac
+    LD="${LD-ld} -m $emul"
+  fi
+  rm -rf conftest*
+  ;;
+
+x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \
 s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
-  # Find out which ABI we are using.
+  # Find out what ABI is being produced by ac_compile, and set linker
+  # options accordingly.  Note that the listed cases only cover the
+  # situations where additional linker options are needed (such as when
+  # doing 32-bit compilation for a host where ld defaults to 64-bit, or
+  # vice versa); the common cases where no linker options are needed do
+  # not appear in the list.
   echo 'int i;' > conftest.$ac_ext
   if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
   (eval $ac_compile) 2>&5
@@ -6764,9 +6921,19 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
 	    LD="${LD-ld} -m elf_i386_fbsd"
 	    ;;
 	  x86_64-*linux*)
-	    LD="${LD-ld} -m elf_i386"
+	    case `/usr/bin/file conftest.o` in
+	      *x86-64*)
+		LD="${LD-ld} -m elf32_x86_64"
+		;;
+	      *)
+		LD="${LD-ld} -m elf_i386"
+		;;
+	    esac
+	    ;;
+	  powerpc64le-*linux*)
+	    LD="${LD-ld} -m elf32lppclinux"
 	    ;;
-	  ppc64-*linux*|powerpc64-*linux*)
+	  powerpc64-*linux*)
 	    LD="${LD-ld} -m elf32ppclinux"
 	    ;;
 	  s390x-*linux*)
@@ -6785,7 +6952,10 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
 	  x86_64-*linux*)
 	    LD="${LD-ld} -m elf_x86_64"
 	    ;;
-	  ppc*-*linux*|powerpc*-*linux*)
+	  powerpcle-*linux*)
+	    LD="${LD-ld} -m elf64lppc"
+	    ;;
+	  powerpc-*linux*)
 	    LD="${LD-ld} -m elf64ppc"
 	    ;;
 	  s390*-*linux*|s390*-*tpf*)
@@ -6803,7 +6973,7 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
 
 *-*-sco3.2v5*)
   # On SCO OpenServer 5, we need -belf to get full-featured binaries.
-  SAVE_CFLAGS="$CFLAGS"
+  SAVE_CFLAGS=$CFLAGS
   CFLAGS="$CFLAGS -belf"
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler needs -belf" >&5
 $as_echo_n "checking whether the C compiler needs -belf... " >&6; }
@@ -6843,13 +7013,14 @@ ac_compiler_gnu=$ac_cv_c_compiler_gnu
 fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_cc_needs_belf" >&5
 $as_echo "$lt_cv_cc_needs_belf" >&6; }
-  if test x"$lt_cv_cc_needs_belf" != x"yes"; then
+  if test yes != "$lt_cv_cc_needs_belf"; then
     # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf
-    CFLAGS="$SAVE_CFLAGS"
+    CFLAGS=$SAVE_CFLAGS
   fi
   ;;
 *-*solaris*)
-  # Find out which ABI we are using.
+  # Find out what ABI is being produced by ac_compile, and set linker
+  # options accordingly.
   echo 'int i;' > conftest.$ac_ext
   if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
   (eval $ac_compile) 2>&5
@@ -6861,7 +7032,7 @@ $as_echo "$lt_cv_cc_needs_belf" >&6; }
       case $lt_cv_prog_gnu_ld in
       yes*)
         case $host in
-        i?86-*-solaris*)
+        i?86-*-solaris*|x86_64-*-solaris*)
           LD="${LD-ld} -m elf_x86_64"
           ;;
         sparc*-*-solaris*)
@@ -6870,7 +7041,7 @@ $as_echo "$lt_cv_cc_needs_belf" >&6; }
         esac
         # GNU ld 2.21 introduced _sol2 emulations.  Use them if available.
         if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then
-          LD="${LD-ld}_sol2"
+          LD=${LD-ld}_sol2
         fi
         ;;
       *)
@@ -6886,7 +7057,7 @@ $as_echo "$lt_cv_cc_needs_belf" >&6; }
   ;;
 esac
 
-need_locks="$enable_libtool_lock"
+need_locks=$enable_libtool_lock
 
 if test -n "$ac_tool_prefix"; then
   # Extract the first word of "${ac_tool_prefix}mt", so it can be a program name with args.
@@ -6997,7 +7168,7 @@ else
 fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_mainfest_tool" >&5
 $as_echo "$lt_cv_path_mainfest_tool" >&6; }
-if test "x$lt_cv_path_mainfest_tool" != xyes; then
+if test yes != "$lt_cv_path_mainfest_tool"; then
   MANIFEST_TOOL=:
 fi
 
@@ -7500,7 +7671,7 @@ if ${lt_cv_apple_cc_single_mod+:} false; then :
   $as_echo_n "(cached) " >&6
 else
   lt_cv_apple_cc_single_mod=no
-      if test -z "${LT_MULTI_MODULE}"; then
+      if test -z "$LT_MULTI_MODULE"; then
 	# By default we will add the -single_module flag. You can override
 	# by either setting the environment variable LT_MULTI_MODULE
 	# non-empty at configure time, or by adding -multi_module to the
@@ -7518,7 +7689,7 @@ else
 	  cat conftest.err >&5
 	# Otherwise, if the output was created with a 0 exit code from
 	# the compiler, it worked.
-	elif test -f libconftest.dylib && test $_lt_result -eq 0; then
+	elif test -f libconftest.dylib && test 0 = "$_lt_result"; then
 	  lt_cv_apple_cc_single_mod=yes
 	else
 	  cat conftest.err >&5
@@ -7557,7 +7728,7 @@ else
 fi
 rm -f core conftest.err conftest.$ac_objext \
     conftest$ac_exeext conftest.$ac_ext
-	LDFLAGS="$save_LDFLAGS"
+	LDFLAGS=$save_LDFLAGS
 
 fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_exported_symbols_list" >&5
@@ -7586,7 +7757,7 @@ _LT_EOF
       _lt_result=$?
       if test -s conftest.err && $GREP force_load conftest.err; then
 	cat conftest.err >&5
-      elif test -f conftest && test $_lt_result -eq 0 && $GREP forced_load conftest >/dev/null 2>&1 ; then
+      elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then
 	lt_cv_ld_force_load=yes
       else
 	cat conftest.err >&5
@@ -7599,32 +7770,32 @@ fi
 $as_echo "$lt_cv_ld_force_load" >&6; }
     case $host_os in
     rhapsody* | darwin1.[012])
-      _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;;
+      _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;;
     darwin1.*)
-      _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+      _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;;
     darwin*) # darwin 5.x on
       # if running on 10.5 or later, the deployment target defaults
       # to the OS version, if on x86, and 10.4, the deployment
       # target defaults to 10.4. Don't you love it?
       case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in
 	10.0,*86*-darwin8*|10.0,*-darwin[91]*)
-	  _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
-	10.[012]*)
-	  _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+	  _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;;
+	10.[012][,.]*)
+	  _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;;
 	10.*)
-	  _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
+	  _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;;
       esac
     ;;
   esac
-    if test "$lt_cv_apple_cc_single_mod" = "yes"; then
+    if test yes = "$lt_cv_apple_cc_single_mod"; then
       _lt_dar_single_mod='$single_module'
     fi
-    if test "$lt_cv_ld_exported_symbols_list" = "yes"; then
-      _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym'
+    if test yes = "$lt_cv_ld_exported_symbols_list"; then
+      _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym'
     else
-      _lt_dar_export_syms='~$NMEDIT -s $output_objdir/${libname}-symbols.expsym ${lib}'
+      _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib'
     fi
-    if test "$DSYMUTIL" != ":" && test "$lt_cv_ld_force_load" = "no"; then
+    if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then
       _lt_dsymutil='~$DSYMUTIL $lib || :'
     else
       _lt_dsymutil=
@@ -7632,6 +7803,41 @@ $as_echo "$lt_cv_ld_force_load" >&6; }
     ;;
   esac
 
+# func_munge_path_list VARIABLE PATH
+# -----------------------------------
+# VARIABLE is name of variable containing _space_ separated list of
+# directories to be munged by the contents of PATH, which is string
+# having a format:
+# "DIR[:DIR]:"
+#       string "DIR[ DIR]" will be prepended to VARIABLE
+# ":DIR[:DIR]"
+#       string "DIR[ DIR]" will be appended to VARIABLE
+# "DIRP[:DIRP]::[DIRA:]DIRA"
+#       string "DIRP[ DIRP]" will be prepended to VARIABLE and string
+#       "DIRA[ DIRA]" will be appended to VARIABLE
+# "DIR[:DIR]"
+#       VARIABLE will be replaced by "DIR[ DIR]"
+func_munge_path_list ()
+{
+    case x$2 in
+    x)
+        ;;
+    *:)
+        eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\"
+        ;;
+    x:*)
+        eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\"
+        ;;
+    *::*)
+        eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\"
+        eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\"
+        ;;
+    *)
+        eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\"
+        ;;
+    esac
+}
+
 ac_ext=c
 ac_cpp='$CPP $CPPFLAGS'
 ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
@@ -7926,14 +8132,14 @@ if test "${enable_static+set}" = set; then :
     *)
      enable_static=no
       # Look at the argument we got.  We use all the common list separators.
-      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
       for pkg in $enableval; do
-	IFS="$lt_save_ifs"
+	IFS=$lt_save_ifs
 	if test "X$pkg" = "X$p"; then
 	  enable_static=yes
 	fi
       done
-      IFS="$lt_save_ifs"
+      IFS=$lt_save_ifs
       ;;
     esac
 else
@@ -7964,14 +8170,14 @@ if test "${enable_shared+set}" = set; then :
     *)
       enable_shared=no
       # Look at the argument we got.  We use all the common list separators.
-      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
       for pkg in $enableval; do
-	IFS="$lt_save_ifs"
+	IFS=$lt_save_ifs
 	if test "X$pkg" = "X$p"; then
 	  enable_shared=yes
 	fi
       done
-      IFS="$lt_save_ifs"
+      IFS=$lt_save_ifs
       ;;
     esac
 else
@@ -7996,14 +8202,14 @@ if test "${with_pic+set}" = set; then :
     *)
       pic_mode=default
       # Look at the argument we got.  We use all the common list separators.
-      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
       for lt_pkg in $withval; do
-	IFS="$lt_save_ifs"
+	IFS=$lt_save_ifs
 	if test "X$lt_pkg" = "X$lt_p"; then
 	  pic_mode=yes
 	fi
       done
-      IFS="$lt_save_ifs"
+      IFS=$lt_save_ifs
       ;;
     esac
 else
@@ -8011,8 +8217,6 @@ else
 fi
 
 
-test -z "$pic_mode" && pic_mode=default
-
 
 
 
@@ -8028,14 +8232,14 @@ if test "${enable_fast_install+set}" = set; then :
     *)
       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,"
+      lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
       for pkg in $enableval; do
-	IFS="$lt_save_ifs"
+	IFS=$lt_save_ifs
 	if test "X$pkg" = "X$p"; then
 	  enable_fast_install=yes
 	fi
       done
-      IFS="$lt_save_ifs"
+      IFS=$lt_save_ifs
       ;;
     esac
 else
@@ -8049,11 +8253,63 @@ fi
 
 
 
+  shared_archive_member_spec=
+case $host,$enable_shared in
+power*-*-aix[5-9]*,yes)
+  { $as_echo "$as_me:${as_lineno-$LINENO}: checking which variant of shared library versioning to provide" >&5
+$as_echo_n "checking which variant of shared library versioning to provide... " >&6; }
+
+# Check whether --with-aix-soname was given.
+if test "${with_aix_soname+set}" = set; then :
+  withval=$with_aix_soname; case $withval in
+    aix|svr4|both)
+      ;;
+    *)
+      as_fn_error $? "Unknown argument to --with-aix-soname" "$LINENO" 5
+      ;;
+    esac
+    lt_cv_with_aix_soname=$with_aix_soname
+else
+  if ${lt_cv_with_aix_soname+:} false; then :
+  $as_echo_n "(cached) " >&6
+else
+  lt_cv_with_aix_soname=aix
+fi
+
+    with_aix_soname=$lt_cv_with_aix_soname
+fi
+
+  { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_aix_soname" >&5
+$as_echo "$with_aix_soname" >&6; }
+  if test aix != "$with_aix_soname"; then
+    # For the AIX way of multilib, we name the shared archive member
+    # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o',
+    # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File.
+    # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag,
+    # the AIX toolchain works better with OBJECT_MODE set (default 32).
+    if test 64 = "${OBJECT_MODE-32}"; then
+      shared_archive_member_spec=shr_64
+    else
+      shared_archive_member_spec=shr
+    fi
+  fi
+  ;;
+*)
+  with_aix_soname=aix
+  ;;
+esac
+
+
+
+
+
+
+
 
 
 
 # This can be used to rebuild libtool when needed
-LIBTOOL_DEPS="$ltmain"
+LIBTOOL_DEPS=$ltmain
 
 # Always use our own libtool.
 LIBTOOL='$(SHELL) $(top_builddir)/libtool'
@@ -8102,7 +8358,7 @@ test -z "$LN_S" && LN_S="ln -s"
 
 
 
-if test -n "${ZSH_VERSION+set}" ; then
+if test -n "${ZSH_VERSION+set}"; then
    setopt NO_GLOB_SUBST
 fi
 
@@ -8141,7 +8397,7 @@ 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
+  if test set != "${COLLECT_NAMES+set}"; then
     COLLECT_NAMES=
     export COLLECT_NAMES
   fi
@@ -8152,14 +8408,14 @@ esac
 ofile=libtool
 can_build_shared=yes
 
-# All known linkers require a `.a' archive for static linking (except MSVC,
+# All known linkers require a '.a' archive for static linking (except MSVC,
 # which needs '.lib').
 libext=a
 
-with_gnu_ld="$lt_cv_prog_gnu_ld"
+with_gnu_ld=$lt_cv_prog_gnu_ld
 
-old_CC="$CC"
-old_CFLAGS="$CFLAGS"
+old_CC=$CC
+old_CFLAGS=$CFLAGS
 
 # Set sane defaults for various variables
 test -z "$CC" && CC=cc
@@ -8168,15 +8424,8 @@ test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS
 test -z "$LD" && LD=ld
 test -z "$ac_objext" && ac_objext=o
 
-for cc_temp in $compiler""; do
-  case $cc_temp in
-    compile | *[\\/]compile | ccache | *[\\/]ccache ) ;;
-    distcc | *[\\/]distcc | purify | *[\\/]purify ) ;;
-    \-*) ;;
-    *) break;;
-  esac
-done
-cc_basename=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"`
+func_cc_basename $compiler
+cc_basename=$func_cc_basename_result
 
 
 # Only perform the check for file, if the check method requires it
@@ -8191,22 +8440,22 @@ if ${lt_cv_path_MAGIC_CMD+:} false; then :
 else
   case $MAGIC_CMD in
 [\\/*] |  ?:[\\/]*)
-  lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path.
+  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
+  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"
+    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 -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"
+	  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
 	    :
@@ -8229,13 +8478,13 @@ _LT_EOF
       break
     fi
   done
-  IFS="$lt_save_ifs"
-  MAGIC_CMD="$lt_save_MAGIC_CMD"
+  IFS=$lt_save_ifs
+  MAGIC_CMD=$lt_save_MAGIC_CMD
   ;;
 esac
 fi
 
-MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+MAGIC_CMD=$lt_cv_path_MAGIC_CMD
 if test -n "$MAGIC_CMD"; then
   { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5
 $as_echo "$MAGIC_CMD" >&6; }
@@ -8257,22 +8506,22 @@ if ${lt_cv_path_MAGIC_CMD+:} false; then :
 else
   case $MAGIC_CMD in
 [\\/*] |  ?:[\\/]*)
-  lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path.
+  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
+  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"
+    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 -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"
+	  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
 	    :
@@ -8295,13 +8544,13 @@ _LT_EOF
       break
     fi
   done
-  IFS="$lt_save_ifs"
-  MAGIC_CMD="$lt_save_MAGIC_CMD"
+  IFS=$lt_save_ifs
+  MAGIC_CMD=$lt_save_MAGIC_CMD
   ;;
 esac
 fi
 
-MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+MAGIC_CMD=$lt_cv_path_MAGIC_CMD
 if test -n "$MAGIC_CMD"; then
   { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5
 $as_echo "$MAGIC_CMD" >&6; }
@@ -8322,7 +8571,7 @@ esac
 
 # Use C for the default configuration in the libtool script
 
-lt_save_CC="$CC"
+lt_save_CC=$CC
 ac_ext=c
 ac_cpp='$CPP $CPPFLAGS'
 ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
@@ -8384,7 +8633,7 @@ if test -n "$compiler"; then
 
 lt_prog_compiler_no_builtin_flag=
 
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
   case $cc_basename in
   nvcc*)
     lt_prog_compiler_no_builtin_flag=' -Xcompiler -fno-builtin' ;;
@@ -8400,7 +8649,7 @@ else
   lt_cv_prog_compiler_rtti_exceptions=no
    ac_outfile=conftest.$ac_objext
    echo "$lt_simple_compile_test_code" > conftest.$ac_ext
-   lt_compiler_flag="-fno-rtti -fno-exceptions"
+   lt_compiler_flag="-fno-rtti -fno-exceptions"  ## exclude from sc_useless_quotes_in_assignment
    # 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
@@ -8430,7 +8679,7 @@ fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_rtti_exceptions" >&5
 $as_echo "$lt_cv_prog_compiler_rtti_exceptions" >&6; }
 
-if test x"$lt_cv_prog_compiler_rtti_exceptions" = xyes; then
+if test yes = "$lt_cv_prog_compiler_rtti_exceptions"; then
     lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions"
 else
     :
@@ -8448,17 +8697,18 @@ lt_prog_compiler_pic=
 lt_prog_compiler_static=
 
 
-  if test "$GCC" = yes; then
+  if test yes = "$GCC"; 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
+      if test ia64 = "$host_cpu"; then
 	# AIX 5 now supports IA64 processor
 	lt_prog_compiler_static='-Bstatic'
       fi
+      lt_prog_compiler_pic='-fPIC'
       ;;
 
     amigaos*)
@@ -8469,8 +8719,8 @@ lt_prog_compiler_static=
         ;;
       m68k)
             # FIXME: we need at least 68020 code to build shared libraries, but
-            # adding the `-m68020' flag to GCC prevents building anything better,
-            # like `-m68040'.
+            # adding the '-m68020' flag to GCC prevents building anything better,
+            # like '-m68040'.
             lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4'
         ;;
       esac
@@ -8486,6 +8736,11 @@ lt_prog_compiler_static=
       # Although the cygwin gcc ignores -fPIC, still need this for old-style
       # (--disable-auto-import) libraries
       lt_prog_compiler_pic='-DDLL_EXPORT'
+      case $host_os in
+      os2*)
+	lt_prog_compiler_static='$wl-static'
+	;;
+      esac
       ;;
 
     darwin* | rhapsody*)
@@ -8556,7 +8811,7 @@ lt_prog_compiler_static=
     case $host_os in
     aix*)
       lt_prog_compiler_wl='-Wl,'
-      if test "$host_cpu" = ia64; then
+      if test ia64 = "$host_cpu"; then
 	# AIX 5 now supports IA64 processor
 	lt_prog_compiler_static='-Bstatic'
       else
@@ -8564,10 +8819,29 @@ lt_prog_compiler_static=
       fi
       ;;
 
+    darwin* | rhapsody*)
+      # PIC is the default on this platform
+      # Common symbols not allowed in MH_DYLIB files
+      lt_prog_compiler_pic='-fno-common'
+      case $cc_basename in
+      nagfor*)
+        # NAG Fortran compiler
+        lt_prog_compiler_wl='-Wl,-Wl,,'
+        lt_prog_compiler_pic='-PIC'
+        lt_prog_compiler_static='-Bstatic'
+        ;;
+      esac
+      ;;
+
     mingw* | cygwin* | pw32* | os2* | cegcc*)
       # 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'
+      case $host_os in
+      os2*)
+	lt_prog_compiler_static='$wl-static'
+	;;
+      esac
       ;;
 
     hpux9* | hpux10* | hpux11*)
@@ -8583,7 +8857,7 @@ lt_prog_compiler_static=
 	;;
       esac
       # Is there a better lt_prog_compiler_static that works with the bundled CC?
-      lt_prog_compiler_static='${wl}-a ${wl}archive'
+      lt_prog_compiler_static='$wl-a ${wl}archive'
       ;;
 
     irix5* | irix6* | nonstopux*)
@@ -8592,9 +8866,9 @@ lt_prog_compiler_static=
       lt_prog_compiler_static='-non_shared'
       ;;
 
-    linux* | k*bsd*-gnu | kopensolaris*-gnu)
+    linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
       case $cc_basename in
-      # old Intel for x86_64 which still supported -KPIC.
+      # old Intel for x86_64, which still supported -KPIC.
       ecc*)
 	lt_prog_compiler_wl='-Wl,'
 	lt_prog_compiler_pic='-KPIC'
@@ -8619,6 +8893,12 @@ lt_prog_compiler_static=
 	lt_prog_compiler_pic='-PIC'
 	lt_prog_compiler_static='-Bstatic'
 	;;
+      tcc*)
+	# Fabrice Bellard et al's Tiny C Compiler
+	lt_prog_compiler_wl='-Wl,'
+	lt_prog_compiler_pic='-fPIC'
+	lt_prog_compiler_static='-static'
+	;;
       pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*)
         # Portland Group compilers (*not* the Pentium gcc compiler,
 	# which looks to be a dead project)
@@ -8716,7 +8996,7 @@ lt_prog_compiler_static=
       ;;
 
     sysv4*MP*)
-      if test -d /usr/nec ;then
+      if test -d /usr/nec; then
 	lt_prog_compiler_pic='-Kconform_pic'
 	lt_prog_compiler_static='-Bstatic'
       fi
@@ -8745,7 +9025,7 @@ lt_prog_compiler_static=
   fi
 
 case $host_os in
-  # For platforms which do not support PIC, -DPIC is meaningless:
+  # For platforms that do not support PIC, -DPIC is meaningless:
   *djgpp*)
     lt_prog_compiler_pic=
     ;;
@@ -8777,7 +9057,7 @@ else
   lt_cv_prog_compiler_pic_works=no
    ac_outfile=conftest.$ac_objext
    echo "$lt_simple_compile_test_code" > conftest.$ac_ext
-   lt_compiler_flag="$lt_prog_compiler_pic -DPIC"
+   lt_compiler_flag="$lt_prog_compiler_pic -DPIC"  ## exclude from sc_useless_quotes_in_assignment
    # 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
@@ -8807,7 +9087,7 @@ fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works" >&5
 $as_echo "$lt_cv_prog_compiler_pic_works" >&6; }
 
-if test x"$lt_cv_prog_compiler_pic_works" = xyes; then
+if test yes = "$lt_cv_prog_compiler_pic_works"; then
     case $lt_prog_compiler_pic in
      "" | " "*) ;;
      *) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;;
@@ -8839,7 +9119,7 @@ if ${lt_cv_prog_compiler_static_works+:} false; then :
   $as_echo_n "(cached) " >&6
 else
   lt_cv_prog_compiler_static_works=no
-   save_LDFLAGS="$LDFLAGS"
+   save_LDFLAGS=$LDFLAGS
    LDFLAGS="$LDFLAGS $lt_tmp_static_flag"
    echo "$lt_simple_link_test_code" > conftest.$ac_ext
    if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then
@@ -8858,13 +9138,13 @@ else
      fi
    fi
    $RM -r conftest*
-   LDFLAGS="$save_LDFLAGS"
+   LDFLAGS=$save_LDFLAGS
 
 fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works" >&5
 $as_echo "$lt_cv_prog_compiler_static_works" >&6; }
 
-if test x"$lt_cv_prog_compiler_static_works" = xyes; then
+if test yes = "$lt_cv_prog_compiler_static_works"; then
     :
 else
     lt_prog_compiler_static=
@@ -8984,8 +9264,8 @@ $as_echo "$lt_cv_prog_compiler_c_o" >&6; }
 
 
 
-hard_links="nottested"
-if test "$lt_cv_prog_compiler_c_o" = no && test "$need_locks" != no; then
+hard_links=nottested
+if test no = "$lt_cv_prog_compiler_c_o" && test no != "$need_locks"; then
   # do not overwrite the value of need_locks provided by the user
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5
 $as_echo_n "checking if we can lock with hard links... " >&6; }
@@ -8997,9 +9277,9 @@ $as_echo_n "checking if we can lock with hard links... " >&6; }
   ln conftest.a conftest.b 2>/dev/null && hard_links=no
   { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5
 $as_echo "$hard_links" >&6; }
-  if test "$hard_links" = no; then
-    { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5
-$as_echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;}
+  if test no = "$hard_links"; then
+    { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&5
+$as_echo "$as_me: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&2;}
     need_locks=warn
   fi
 else
@@ -9042,9 +9322,9 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
   # 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'.
+  # 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_|_GLOBAL__F[ID]_.*'
   # 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
@@ -9059,7 +9339,7 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
     # 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
+    if test yes != "$GCC"; then
       with_gnu_ld=no
     fi
     ;;
@@ -9067,7 +9347,7 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
     # we just hope/assume this is gcc and not c89 (= MSVC++)
     with_gnu_ld=yes
     ;;
-  openbsd*)
+  openbsd* | bitrig*)
     with_gnu_ld=no
     ;;
   esac
@@ -9077,7 +9357,7 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
   # On some targets, GNU ld is compatible enough with the native linker
   # that we're better off using the native interface for both.
   lt_use_gnu_ld_interface=no
-  if test "$with_gnu_ld" = yes; then
+  if test yes = "$with_gnu_ld"; then
     case $host_os in
       aix*)
 	# The AIX port of GNU ld has always aspired to compatibility
@@ -9099,24 +9379,24 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
     esac
   fi
 
-  if test "$lt_use_gnu_ld_interface" = yes; then
+  if test yes = "$lt_use_gnu_ld_interface"; then
     # If archive_cmds runs LD, not CC, wlarc should be empty
-    wlarc='${wl}'
+    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'
+    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'
+      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>&1` in
+    case `$LD -v | $SED -e 's/(^)\+)\s\+//' 2>&1` in
       *GNU\ gold*) supports_anon_versioning=yes ;;
       *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11
       *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ...
@@ -9129,7 +9409,7 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
     case $host_os in
     aix[3-9]*)
       # On AIX/PPC, the GNU linker is very broken
-      if test "$host_cpu" != ia64; then
+      if test ia64 != "$host_cpu"; then
 	ld_shlibs=no
 	cat <<_LT_EOF 1>&2
 
@@ -9148,7 +9428,7 @@ _LT_EOF
       case $host_cpu in
       powerpc)
             # see comment about AmigaOS4 .so support
-            archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+            archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
             archive_expsym_cmds=''
         ;;
       m68k)
@@ -9164,7 +9444,7 @@ _LT_EOF
 	allow_undefined_flag=unsupported
 	# Joseph Beckenbach <jrb3 at best.com> 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'
+	archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
       else
 	ld_shlibs=no
       fi
@@ -9174,7 +9454,7 @@ _LT_EOF
       # _LT_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless,
       # as there is no search path for DLLs.
       hardcode_libdir_flag_spec='-L$libdir'
-      export_dynamic_flag_spec='${wl}--export-all-symbols'
+      export_dynamic_flag_spec='$wl--export-all-symbols'
       allow_undefined_flag=unsupported
       always_export_symbols=no
       enable_shared_with_static_runtimes=yes
@@ -9182,61 +9462,89 @@ _LT_EOF
       exclude_expsyms='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'
 
       if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then
-        archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $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}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+        archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+	# If the export-symbols file already is a .def file, use it as
+	# is; otherwise, prepend EXPORTS...
+	archive_expsym_cmds='if   test DEF = "`$SED -n     -e '\''s/^[	 ]*//'\''     -e '\''/^\(;.*\)*$/d'\''     -e '\''s/^\(EXPORTS\|LIBRARY\)\([	 ].*\)*$/DEF/p'\''     -e q     $export_symbols`" ; 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--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
       else
 	ld_shlibs=no
       fi
       ;;
 
     haiku*)
-      archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+      archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
       link_all_deplibs=yes
       ;;
 
+    os2*)
+      hardcode_libdir_flag_spec='-L$libdir'
+      hardcode_minus_L=yes
+      allow_undefined_flag=unsupported
+      shrext_cmds=.dll
+      archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+	$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+	$ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+	$ECHO EXPORTS >> $output_objdir/$libname.def~
+	emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~
+	$CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+	emximp -o $lib $output_objdir/$libname.def'
+      archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+	$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+	$ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+	$ECHO EXPORTS >> $output_objdir/$libname.def~
+	prefix_cmds="$SED"~
+	if test EXPORTS = "`$SED 1q $export_symbols`"; then
+	  prefix_cmds="$prefix_cmds -e 1d";
+	fi~
+	prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~
+	cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~
+	$CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+	emximp -o $lib $output_objdir/$libname.def'
+      old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def'
+      enable_shared_with_static_runtimes=yes
+      ;;
+
     interix[3-9]*)
       hardcode_direct=no
       hardcode_shlibpath_var=no
-      hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
-      export_dynamic_flag_spec='${wl}-E'
+      hardcode_libdir_flag_spec='$wl-rpath,$libdir'
+      export_dynamic_flag_spec='$wl-E'
       # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc.
       # Instead, shared libraries are loaded at an image base (0x10000000 by
       # default) and relocated if they conflict, which is a slow very memory
       # consuming and fragmenting process.  To avoid this, we pick a random,
       # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link
       # time.  Moving up from 0x10000000 also allows more sbrk(2) space.
-      archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
-      archive_expsym_cmds='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+      archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+      archive_expsym_cmds='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
       ;;
 
     gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu)
       tmp_diet=no
-      if test "$host_os" = linux-dietlibc; then
+      if test linux-dietlibc = "$host_os"; then
 	case $cc_basename in
 	  diet\ *) tmp_diet=yes;;	# linux-dietlibc with static linking (!diet-dyn)
 	esac
       fi
       if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \
-	 && test "$tmp_diet" = no
+	 && test no = "$tmp_diet"
       then
 	tmp_addflag=' $pic_flag'
 	tmp_sharedflag='-shared'
 	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; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+	  whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
 	  tmp_addflag=' $pic_flag'
 	  ;;
 	pgf77* | pgf90* | pgf95* | pgfortran*)
 					# 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; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+	  whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
 	  tmp_addflag=' $pic_flag -Mnomain' ;;
 	ecc*,ia64* | icc*,ia64*)	# Intel C compiler on ia64
 	  tmp_addflag=' -i_dynamic' ;;
@@ -9247,42 +9555,47 @@ _LT_EOF
 	lf95*)				# Lahey Fortran 8.1
 	  whole_archive_flag_spec=
 	  tmp_sharedflag='--shared' ;;
+        nagfor*)                        # NAGFOR 5.3
+          tmp_sharedflag='-Wl,-shared' ;;
 	xl[cC]* | bgxl[cC]* | mpixl[cC]*) # IBM XL C 8.0 on PPC (deal with xlf below)
 	  tmp_sharedflag='-qmkshrobj'
 	  tmp_addflag= ;;
 	nvcc*)	# Cuda Compiler Driver 2.2
-	  whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+	  whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
 	  compiler_needs_object=yes
 	  ;;
 	esac
 	case `$CC -V 2>&1 | sed 5q` in
 	*Sun\ C*)			# Sun C 5.9
-	  whole_archive_flag_spec='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+	  whole_archive_flag_spec='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
 	  compiler_needs_object=yes
 	  tmp_sharedflag='-G' ;;
 	*Sun\ F*)			# Sun Fortran 8.3
 	  tmp_sharedflag='-G' ;;
 	esac
-	archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+	archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
 
-        if test "x$supports_anon_versioning" = xyes; then
+        if test yes = "$supports_anon_versioning"; 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 '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib'
+            cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+            echo "local: *; };" >> $output_objdir/$libname.ver~
+            $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib'
         fi
 
 	case $cc_basename in
+	tcc*)
+	  export_dynamic_flag_spec='-rdynamic'
+	  ;;
 	xlf* | bgf* | bgxlf* | mpixlf*)
 	  # IBM XL Fortran 10.1 on PPC cannot create shared libs itself
 	  whole_archive_flag_spec='--whole-archive$convenience --no-whole-archive'
-	  hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+	  hardcode_libdir_flag_spec='$wl-rpath $wl$libdir'
 	  archive_cmds='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib'
-	  if test "x$supports_anon_versioning" = xyes; then
+	  if test yes = "$supports_anon_versioning"; 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~
-	      $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib'
+              cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+              echo "local: *; };" >> $output_objdir/$libname.ver~
+              $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib'
 	  fi
 	  ;;
 	esac
@@ -9296,8 +9609,8 @@ _LT_EOF
 	archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib'
 	wlarc=
       else
-	archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+	archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+	archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
       fi
       ;;
 
@@ -9315,8 +9628,8 @@ _LT_EOF
 
 _LT_EOF
       elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
-	archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+	archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+	archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
       else
 	ld_shlibs=no
       fi
@@ -9328,7 +9641,7 @@ _LT_EOF
 	ld_shlibs=no
 	cat <<_LT_EOF 1>&2
 
-*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not
+*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot
 *** reliably create shared libraries on SCO systems.  Therefore, libtool
 *** is disabling shared libraries support.  We urge you to upgrade GNU
 *** binutils to release 2.16.91.0.3 or newer.  Another option is to modify
@@ -9343,9 +9656,9 @@ _LT_EOF
 	  # DT_RUNPATH tag from executables and libraries.  But doing so
 	  # requires that you compile everything twice, which is a pain.
 	  if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
-	    hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
-	    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'
+	    hardcode_libdir_flag_spec='$wl-rpath $wl$libdir'
+	    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
@@ -9362,15 +9675,15 @@ _LT_EOF
 
     *)
       if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
-	archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+	archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+	archive_expsym_cmds='$CC -shared $pic_flag $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
+    if test no = "$ld_shlibs"; then
       runpath_var=
       hardcode_libdir_flag_spec=
       export_dynamic_flag_spec=
@@ -9386,7 +9699,7 @@ _LT_EOF
       # 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 "$lt_prog_compiler_static"; then
+      if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then
 	# Neither direct hardcoding nor static linking is supported with a
 	# broken collect2.
 	hardcode_direct=unsupported
@@ -9394,34 +9707,57 @@ _LT_EOF
       ;;
 
     aix[4-9]*)
-      if test "$host_cpu" = ia64; then
+      if test ia64 = "$host_cpu"; 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=""
+	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
-	# Also, AIX nm treats weak defined symbols like other global
-	# defined symbols, whereas GNU nm marks them as "W".
+	# -C means demangle to GNU nm, but means don't demangle to AIX nm.
+	# Without the "-l" option, or with the "-B" option, AIX nm treats
+	# weak defined symbols like other global defined symbols, whereas
+	# GNU nm marks them as "W".
+	# While the 'weak' keyword is ignored in the Export File, we need
+	# it in the Import File for the 'aix-soname' feature, so we have
+	# to replace the "-B" option with "-P" for AIX 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") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+	  export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { 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'
+	  export_symbols_cmds='`func_echo_all $NM | $SED -e '\''s/B\([^B]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | 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.
+	# have runtime linking enabled, and use it for executables.
+	# For shared libraries, we enable/disable runtime linking
+	# depending on the kind of the shared library created -
+	# when "with_aix_soname,aix_use_runtimelinking" is:
+	# "aix,no"   lib.a(lib.so.V) shared, rtl:no,  for executables
+	# "aix,yes"  lib.so          shared, rtl:yes, for executables
+	#            lib.a           static archive
+	# "both,no"  lib.so.V(shr.o) shared, rtl:yes
+	#            lib.a(lib.so.V) shared, rtl:no,  for executables
+	# "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables
+	#            lib.a(lib.so.V) shared, rtl:no
+	# "svr4,*"   lib.so.V(shr.o) shared, rtl:yes, for executables
+	#            lib.a           static archive
 	case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*)
 	  for ld_flag in $LDFLAGS; do
-	  if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then
+	  if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then
 	    aix_use_runtimelinking=yes
 	    break
 	  fi
 	  done
+	  if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then
+	    # With aix-soname=svr4, we create the lib.so.V shared archives only,
+	    # so we don't have lib.a shared libs to link our executables.
+	    # We have to force runtime linking in this case.
+	    aix_use_runtimelinking=yes
+	    LDFLAGS="$LDFLAGS -Wl,-brtl"
+	  fi
 	  ;;
 	esac
 
@@ -9440,13 +9776,21 @@ _LT_EOF
       hardcode_direct_absolute=yes
       hardcode_libdir_separator=':'
       link_all_deplibs=yes
-      file_list_spec='${wl}-f,'
+      file_list_spec='$wl-f,'
+      case $with_aix_soname,$aix_use_runtimelinking in
+      aix,*) ;; # traditional, no import file
+      svr4,* | *,yes) # use import file
+	# The Import File defines what to hardcode.
+	hardcode_direct=no
+	hardcode_direct_absolute=no
+	;;
+      esac
 
-      if test "$GCC" = yes; then
+      if test yes = "$GCC"; 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`
+	  collect2name=`$CC -print-prog-name=collect2`
 	  if test -f "$collect2name" &&
 	   strings "$collect2name" | $GREP resolve_lib_name >/dev/null
 	  then
@@ -9465,35 +9809,42 @@ _LT_EOF
 	  ;;
 	esac
 	shared_flag='-shared'
-	if test "$aix_use_runtimelinking" = yes; then
-	  shared_flag="$shared_flag "'${wl}-G'
+	if test yes = "$aix_use_runtimelinking"; then
+	  shared_flag="$shared_flag "'$wl-G'
 	fi
+	# Need to ensure runtime linking is disabled for the traditional
+	# shared library, or the linker may eventually find shared libraries
+	# /with/ Import File - we do not want to mix them.
+	shared_flag_aix='-shared'
+	shared_flag_svr4='-shared $wl-G'
       else
 	# not using gcc
-	if test "$host_cpu" = ia64; then
+	if test ia64 = "$host_cpu"; 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'
+	  if test yes = "$aix_use_runtimelinking"; then
+	    shared_flag='$wl-G'
 	  else
-	    shared_flag='${wl}-bM:SRE'
+	    shared_flag='$wl-bM:SRE'
 	  fi
+	  shared_flag_aix='$wl-bM:SRE'
+	  shared_flag_svr4='$wl-G'
 	fi
       fi
 
-      export_dynamic_flag_spec='${wl}-bexpall'
+      export_dynamic_flag_spec='$wl-bexpall'
       # 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
+      if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; 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.
-        if test "${lt_cv_aix_libpath+set}" = set; then
+        if test set = "${lt_cv_aix_libpath+set}"; then
   aix_libpath=$lt_cv_aix_libpath
 else
   if ${lt_cv_aix_libpath_+:} false; then :
@@ -9528,7 +9879,7 @@ fi
 rm -f core conftest.err conftest.$ac_objext \
     conftest$ac_exeext conftest.$ac_ext
   if test -z "$lt_cv_aix_libpath_"; then
-    lt_cv_aix_libpath_="/usr/lib:/lib"
+    lt_cv_aix_libpath_=/usr/lib:/lib
   fi
 
 fi
@@ -9536,17 +9887,17 @@ fi
   aix_libpath=$lt_cv_aix_libpath_
 fi
 
-        hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath"
-        archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag"
+        hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath"
+        archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $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'
+	if test ia64 = "$host_cpu"; 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 '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols"
+	  archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols"
 	else
 	 # Determine the default libpath from the value encoded in an
 	 # empty executable.
-	 if test "${lt_cv_aix_libpath+set}" = set; then
+	 if test set = "${lt_cv_aix_libpath+set}"; then
   aix_libpath=$lt_cv_aix_libpath
 else
   if ${lt_cv_aix_libpath_+:} false; then :
@@ -9581,7 +9932,7 @@ fi
 rm -f core conftest.err conftest.$ac_objext \
     conftest$ac_exeext conftest.$ac_ext
   if test -z "$lt_cv_aix_libpath_"; then
-    lt_cv_aix_libpath_="/usr/lib:/lib"
+    lt_cv_aix_libpath_=/usr/lib:/lib
   fi
 
 fi
@@ -9589,21 +9940,33 @@ fi
   aix_libpath=$lt_cv_aix_libpath_
 fi
 
-	 hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath"
+	 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'
-	  if test "$with_gnu_ld" = yes; then
+	  no_undefined_flag=' $wl-bernotok'
+	  allow_undefined_flag=' $wl-berok'
+	  if test yes = "$with_gnu_ld"; then
 	    # We only use this code for GNU lds that support --whole-archive.
-	    whole_archive_flag_spec='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
+	    whole_archive_flag_spec='$wl--whole-archive$convenience $wl--no-whole-archive'
 	  else
 	    # Exported symbols can be pulled into shared objects from archives
 	    whole_archive_flag_spec='$convenience'
 	  fi
 	  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 ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
+	  archive_expsym_cmds='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d'
+	  # -brtl affects multiple linker settings, -berok does not and is overridden later
+	  compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([, ]\\)%-berok\\1%g"`'
+	  if test svr4 != "$with_aix_soname"; then
+	    # This is similar to how AIX traditionally builds its shared libraries.
+	    archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname'
+	  fi
+	  if test aix != "$with_aix_soname"; then
+	    archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp'
+	  else
+	    # used by -dlpreopen to get the symbols
+	    archive_expsym_cmds="$archive_expsym_cmds"'~$MV  $output_objdir/$realname.d/$soname $output_objdir'
+	  fi
+	  archive_expsym_cmds="$archive_expsym_cmds"'~$RM -r $output_objdir/$realname.d'
 	fi
       fi
       ;;
@@ -9612,7 +9975,7 @@ fi
       case $host_cpu in
       powerpc)
             # see comment about AmigaOS4 .so support
-            archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+            archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
             archive_expsym_cmds=''
         ;;
       m68k)
@@ -9642,16 +10005,17 @@ fi
 	# Tell ltmain to make .lib files, not .a files.
 	libext=lib
 	# Tell ltmain to make .dll files, not .so files.
-	shrext_cmds=".dll"
+	shrext_cmds=.dll
 	# FIXME: Setting linknames here is a bad hack.
-	archive_cmds='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames='
-	archive_expsym_cmds='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
-	    sed -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp;
-	  else
-	    sed -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp;
-	  fi~
-	  $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
-	  linknames='
+	archive_cmds='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames='
+	archive_expsym_cmds='if   test DEF = "`$SED -n     -e '\''s/^[	 ]*//'\''     -e '\''/^\(;.*\)*$/d'\''     -e '\''s/^\(EXPORTS\|LIBRARY\)\([	 ].*\)*$/DEF/p'\''     -e q     $export_symbols`" ; then
+            cp "$export_symbols" "$output_objdir/$soname.def";
+            echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp";
+          else
+            $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp;
+          fi~
+          $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
+          linknames='
 	# The linker will not automatically build a static lib if we build a DLL.
 	# _LT_TAGVAR(old_archive_from_new_cmds, )='true'
 	enable_shared_with_static_runtimes=yes
@@ -9660,18 +10024,18 @@ fi
 	# Don't use ranlib
 	old_postinstall_cmds='chmod 644 $oldlib'
 	postlink_cmds='lt_outputfile="@OUTPUT@"~
-	  lt_tool_outputfile="@TOOL_OUTPUT@"~
-	  case $lt_outputfile in
-	    *.exe|*.EXE) ;;
-	    *)
-	      lt_outputfile="$lt_outputfile.exe"
-	      lt_tool_outputfile="$lt_tool_outputfile.exe"
-	      ;;
-	  esac~
-	  if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then
-	    $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
-	    $RM "$lt_outputfile.manifest";
-	  fi'
+          lt_tool_outputfile="@TOOL_OUTPUT@"~
+          case $lt_outputfile in
+            *.exe|*.EXE) ;;
+            *)
+              lt_outputfile=$lt_outputfile.exe
+              lt_tool_outputfile=$lt_tool_outputfile.exe
+              ;;
+          esac~
+          if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then
+            $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
+            $RM "$lt_outputfile.manifest";
+          fi'
 	;;
       *)
 	# Assume MSVC wrapper
@@ -9680,7 +10044,7 @@ fi
 	# Tell ltmain to make .lib files, not .a files.
 	libext=lib
 	# Tell ltmain to make .dll files, not .so files.
-	shrext_cmds=".dll"
+	shrext_cmds=.dll
 	# FIXME: Setting linknames here is a bad hack.
 	archive_cmds='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames='
 	# The linker will automatically build a .lib file if we build a DLL.
@@ -9699,24 +10063,24 @@ fi
   hardcode_direct=no
   hardcode_automatic=yes
   hardcode_shlibpath_var=unsupported
-  if test "$lt_cv_ld_force_load" = "yes"; then
-    whole_archive_flag_spec='`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience ${wl}-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`'
+  if test yes = "$lt_cv_ld_force_load"; then
+    whole_archive_flag_spec='`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`'
 
   else
     whole_archive_flag_spec=''
   fi
   link_all_deplibs=yes
-  allow_undefined_flag="$_lt_dar_allow_undefined"
+  allow_undefined_flag=$_lt_dar_allow_undefined
   case $cc_basename in
-     ifort*) _lt_dar_can_shared=yes ;;
+     ifort*|nagfor*) _lt_dar_can_shared=yes ;;
      *) _lt_dar_can_shared=$GCC ;;
   esac
-  if test "$_lt_dar_can_shared" = "yes"; then
+  if test yes = "$_lt_dar_can_shared"; then
     output_verbose_link_cmd=func_echo_all
-    archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}"
-    module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}"
-    archive_expsym_cmds="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}"
-    module_expsym_cmds="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}"
+    archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil"
+    module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil"
+    archive_expsym_cmds="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil"
+    module_expsym_cmds="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil"
 
   else
   ld_shlibs=no
@@ -9758,33 +10122,33 @@ fi
       ;;
 
     hpux9*)
-      if test "$GCC" = yes; then
-	archive_cmds='$RM $output_objdir/$soname~$CC -shared $pic_flag ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+      if test yes = "$GCC"; then
+	archive_cmds='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$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'
+	archive_cmds='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
       fi
-      hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+      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'
+      export_dynamic_flag_spec='$wl-E'
       ;;
 
     hpux10*)
-      if test "$GCC" = yes && test "$with_gnu_ld" = no; then
-	archive_cmds='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+      if test yes,no = "$GCC,$with_gnu_ld"; then
+	archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
       else
 	archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'
       fi
-      if test "$with_gnu_ld" = no; then
-	hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+      if test no = "$with_gnu_ld"; then
+	hardcode_libdir_flag_spec='$wl+b $wl$libdir'
 	hardcode_libdir_separator=:
 	hardcode_direct=yes
 	hardcode_direct_absolute=yes
-	export_dynamic_flag_spec='${wl}-E'
+	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
@@ -9792,25 +10156,25 @@ fi
       ;;
 
     hpux11*)
-      if test "$GCC" = yes && test "$with_gnu_ld" = no; then
+      if test yes,no = "$GCC,$with_gnu_ld"; then
 	case $host_cpu in
 	hppa*64*)
-	  archive_cmds='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+	  archive_cmds='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
 	ia64*)
-	  archive_cmds='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+	  archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
 	*)
-	  archive_cmds='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+	  archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
 	esac
       else
 	case $host_cpu in
 	hppa*64*)
-	  archive_cmds='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+	  archive_cmds='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
 	ia64*)
-	  archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+	  archive_cmds='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
 	*)
 
@@ -9822,7 +10186,7 @@ if ${lt_cv_prog_compiler__b+:} false; then :
   $as_echo_n "(cached) " >&6
 else
   lt_cv_prog_compiler__b=no
-   save_LDFLAGS="$LDFLAGS"
+   save_LDFLAGS=$LDFLAGS
    LDFLAGS="$LDFLAGS -b"
    echo "$lt_simple_link_test_code" > conftest.$ac_ext
    if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then
@@ -9841,14 +10205,14 @@ else
      fi
    fi
    $RM -r conftest*
-   LDFLAGS="$save_LDFLAGS"
+   LDFLAGS=$save_LDFLAGS
 
 fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler__b" >&5
 $as_echo "$lt_cv_prog_compiler__b" >&6; }
 
-if test x"$lt_cv_prog_compiler__b" = xyes; then
-    archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+if test yes = "$lt_cv_prog_compiler__b"; then
+    archive_cmds='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
 else
     archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'
 fi
@@ -9856,8 +10220,8 @@ fi
 	  ;;
 	esac
       fi
-      if test "$with_gnu_ld" = no; then
-	hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+      if test no = "$with_gnu_ld"; then
+	hardcode_libdir_flag_spec='$wl+b $wl$libdir'
 	hardcode_libdir_separator=:
 
 	case $host_cpu in
@@ -9868,7 +10232,7 @@ fi
 	*)
 	  hardcode_direct=yes
 	  hardcode_direct_absolute=yes
-	  export_dynamic_flag_spec='${wl}-E'
+	  export_dynamic_flag_spec='$wl-E'
 
 	  # hardcode_minus_L: Not really in the search PATH,
 	  # but as the default location of the library.
@@ -9879,8 +10243,8 @@ fi
       ;;
 
     irix5* | irix6* | nonstopux*)
-      if test "$GCC" = yes; then
-	archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+      if test yes = "$GCC"; then
+	archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
 	# Try to use the -exported_symbol ld option, if it does not
 	# work, assume that -exports_file does not work either and
 	# implicitly export all symbols.
@@ -9890,8 +10254,8 @@ $as_echo_n "checking whether the $host_os linker accepts -exported_symbol... " >
 if ${lt_cv_irix_exported_symbol+:} false; then :
   $as_echo_n "(cached) " >&6
 else
-  save_LDFLAGS="$LDFLAGS"
-	   LDFLAGS="$LDFLAGS -shared ${wl}-exported_symbol ${wl}foo ${wl}-update_registry ${wl}/dev/null"
+  save_LDFLAGS=$LDFLAGS
+	   LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null"
 	   cat confdefs.h - <<_ACEOF >conftest.$ac_ext
 /* end confdefs.h.  */
 int foo (void) { return 0; }
@@ -9903,24 +10267,34 @@ else
 fi
 rm -f core conftest.err conftest.$ac_objext \
     conftest$ac_exeext conftest.$ac_ext
-           LDFLAGS="$save_LDFLAGS"
+           LDFLAGS=$save_LDFLAGS
 fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_irix_exported_symbol" >&5
 $as_echo "$lt_cv_irix_exported_symbol" >&6; }
-	if test "$lt_cv_irix_exported_symbol" = yes; then
-          archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations ${wl}-exports_file ${wl}$export_symbols -o $lib'
+	if test yes = "$lt_cv_irix_exported_symbol"; then
+          archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib'
 	fi
       else
-	archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
-	archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -exports_file $export_symbols -o $lib'
+	archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
+	archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib'
       fi
       archive_cmds_need_lc='no'
-      hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+      hardcode_libdir_flag_spec='$wl-rpath $wl$libdir'
       hardcode_libdir_separator=:
       inherit_rpath=yes
       link_all_deplibs=yes
       ;;
 
+    linux*)
+      case $cc_basename in
+      tcc*)
+	# Fabrice Bellard et al's Tiny C Compiler
+	ld_shlibs=yes
+	archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+	;;
+      esac
+      ;;
+
     netbsd*)
       if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
 	archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'  # a.out
@@ -9935,7 +10309,7 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
     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_flag_spec='$wl-rpath $wl$libdir'
       hardcode_libdir_separator=:
       hardcode_shlibpath_var=no
       ;;
@@ -9943,27 +10317,19 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
     *nto* | *qnx*)
       ;;
 
-    openbsd*)
+    openbsd* | bitrig*)
       if test -f /usr/libexec/ld.so; then
 	hardcode_direct=yes
 	hardcode_shlibpath_var=no
 	hardcode_direct_absolute=yes
-	if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+	if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; 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'
+	  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
+	  archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+	  hardcode_libdir_flag_spec='$wl-rpath,$libdir'
 	fi
       else
 	ld_shlibs=no
@@ -9974,33 +10340,53 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
       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'
+      shrext_cmds=.dll
+      archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+	$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+	$ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+	$ECHO EXPORTS >> $output_objdir/$libname.def~
+	emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~
+	$CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+	emximp -o $lib $output_objdir/$libname.def'
+      archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+	$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+	$ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+	$ECHO EXPORTS >> $output_objdir/$libname.def~
+	prefix_cmds="$SED"~
+	if test EXPORTS = "`$SED 1q $export_symbols`"; then
+	  prefix_cmds="$prefix_cmds -e 1d";
+	fi~
+	prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~
+	cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~
+	$CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+	emximp -o $lib $output_objdir/$libname.def'
+      old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def'
+      enable_shared_with_static_runtimes=yes
       ;;
 
     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" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+      if test yes = "$GCC"; 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" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
       else
 	allow_undefined_flag=' -expect_unresolved \*'
-	archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+	archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
       fi
       archive_cmds_need_lc='no'
-      hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+      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} $pic_flag $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
-	hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+      if test yes = "$GCC"; then
+	allow_undefined_flag=' $wl-expect_unresolved $wl\*'
+	archive_cmds='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$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='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+	archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-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; printf "%s\\n" "-hidden">> $lib.exp~
-	$CC -shared${allow_undefined_flag} ${wl}-input ${wl}$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib~$RM $lib.exp'
+          $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_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'
@@ -10011,24 +10397,24 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
 
     solaris*)
       no_undefined_flag=' -z defs'
-      if test "$GCC" = yes; then
-	wlarc='${wl}'
-	archive_cmds='$CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+      if test yes = "$GCC"; then
+	wlarc='$wl'
+	archive_cmds='$CC -shared $pic_flag $wl-z ${wl}text $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 $pic_flag ${wl}-z ${wl}text ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+          $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
       else
 	case `$CC -V 2>&1` in
 	*"Compilers 5.0"*)
 	  wlarc=''
-	  archive_cmds='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags'
+	  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'
+            $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp'
 	  ;;
 	*)
-	  wlarc='${wl}'
-	  archive_cmds='$CC -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $compiler_flags'
+	  wlarc='$wl'
+	  archive_cmds='$CC -G$allow_undefined_flag -h $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 -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+            $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
 	  ;;
 	esac
       fi
@@ -10038,11 +10424,11 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
       solaris2.[0-5] | solaris2.[0-5].*) ;;
       *)
 	# The compiler driver will combine and reorder linker options,
-	# but understands `-z linker_flag'.  GCC discards it without `$wl',
+	# but understands '-z linker_flag'.  GCC discards it without '$wl',
 	# but is careful enough not to reorder.
 	# Supported since Solaris 2.6 (maybe 2.5.1?)
-	if test "$GCC" = yes; then
-	  whole_archive_flag_spec='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract'
+	if test yes = "$GCC"; then
+	  whole_archive_flag_spec='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract'
 	else
 	  whole_archive_flag_spec='-z allextract$convenience -z defaultextract'
 	fi
@@ -10052,10 +10438,10 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
       ;;
 
     sunos4*)
-      if test "x$host_vendor" = xsequent; then
+      if test sequent = "$host_vendor"; 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'
+	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
@@ -10104,43 +10490,43 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
       ;;
 
     sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*)
-      no_undefined_flag='${wl}-z,text'
+      no_undefined_flag='$wl-z,text'
       archive_cmds_need_lc=no
       hardcode_shlibpath_var=no
       runpath_var='LD_RUN_PATH'
 
-      if test "$GCC" = yes; then
-	archive_cmds='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      if test yes = "$GCC"; then
+	archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
       else
-	archive_cmds='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
       fi
       ;;
 
     sysv5* | sco3.2v5* | sco5v6*)
-      # Note: We can NOT use -z defs as we might desire, because we do not
+      # Note: We CANNOT use -z defs as we might desire, because we do not
       # link with -lc, and that would cause any symbols used from libc to
       # always be unresolved, which means just about no library would
       # ever link correctly.  If we're not using GNU ld we use -z text
       # though, which does catch some bad symbols but isn't as heavy-handed
       # as -z defs.
-      no_undefined_flag='${wl}-z,text'
-      allow_undefined_flag='${wl}-z,nodefs'
+      no_undefined_flag='$wl-z,text'
+      allow_undefined_flag='$wl-z,nodefs'
       archive_cmds_need_lc=no
       hardcode_shlibpath_var=no
-      hardcode_libdir_flag_spec='${wl}-R,$libdir'
+      hardcode_libdir_flag_spec='$wl-R,$libdir'
       hardcode_libdir_separator=':'
       link_all_deplibs=yes
-      export_dynamic_flag_spec='${wl}-Bexport'
+      export_dynamic_flag_spec='$wl-Bexport'
       runpath_var='LD_RUN_PATH'
 
-      if test "$GCC" = yes; then
-	archive_cmds='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      if test yes = "$GCC"; then
+	archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
       else
-	archive_cmds='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
       fi
       ;;
 
@@ -10155,10 +10541,10 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
       ;;
     esac
 
-    if test x$host_vendor = xsni; then
+    if test sni = "$host_vendor"; then
       case $host in
       sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*)
-	export_dynamic_flag_spec='${wl}-Blargedynsym'
+	export_dynamic_flag_spec='$wl-Blargedynsym'
 	;;
       esac
     fi
@@ -10166,7 +10552,7 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
 
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs" >&5
 $as_echo "$ld_shlibs" >&6; }
-test "$ld_shlibs" = no && can_build_shared=no
+test no = "$ld_shlibs" && can_build_shared=no
 
 with_gnu_ld=$with_gnu_ld
 
@@ -10192,7 +10578,7 @@ x|xyes)
   # Assume -lc should be added
   archive_cmds_need_lc=yes
 
-  if test "$enable_shared" = yes && test "$GCC" = yes; then
+  if test yes,yes = "$GCC,$enable_shared"; then
     case $archive_cmds in
     *'~'*)
       # FIXME: we may have to deal with multi-command sequences.
@@ -10407,14 +10793,14 @@ esac
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5
 $as_echo_n "checking dynamic linker characteristics... " >&6; }
 
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
   case $host_os in
-    darwin*) lt_awk_arg="/^libraries:/,/LR/" ;;
-    *) lt_awk_arg="/^libraries:/" ;;
+    darwin*) lt_awk_arg='/^libraries:/,/LR/' ;;
+    *) lt_awk_arg='/^libraries:/' ;;
   esac
   case $host_os in
-    mingw* | cegcc*) lt_sed_strip_eq="s,=\([A-Za-z]:\),\1,g" ;;
-    *) lt_sed_strip_eq="s,=/,/,g" ;;
+    mingw* | cegcc*) lt_sed_strip_eq='s|=\([A-Za-z]:\)|\1|g' ;;
+    *) lt_sed_strip_eq='s|=/|/|g' ;;
   esac
   lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq`
   case $lt_search_path_spec in
@@ -10430,28 +10816,35 @@ if test "$GCC" = yes; then
     ;;
   esac
   # Ok, now we have the path, separated by spaces, we can step through it
-  # and add multilib dir if necessary.
+  # and add multilib dir if necessary...
   lt_tmp_lt_search_path_spec=
-  lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null`
+  lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null`
+  # ...but if some path component already ends with the multilib dir we assume
+  # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer).
+  case "$lt_multi_os_dir; $lt_search_path_spec " in
+  "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*)
+    lt_multi_os_dir=
+    ;;
+  esac
   for lt_sys_path in $lt_search_path_spec; do
-    if test -d "$lt_sys_path/$lt_multi_os_dir"; then
-      lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir"
-    else
+    if test -d "$lt_sys_path$lt_multi_os_dir"; then
+      lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir"
+    elif test -n "$lt_multi_os_dir"; then
       test -d "$lt_sys_path" && \
 	lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path"
     fi
   done
   lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk '
-BEGIN {RS=" "; FS="/|\n";} {
-  lt_foo="";
-  lt_count=0;
+BEGIN {RS = " "; FS = "/|\n";} {
+  lt_foo = "";
+  lt_count = 0;
   for (lt_i = NF; lt_i > 0; lt_i--) {
     if ($lt_i != "" && $lt_i != ".") {
       if ($lt_i == "..") {
         lt_count++;
       } else {
         if (lt_count == 0) {
-          lt_foo="/" $lt_i lt_foo;
+          lt_foo = "/" $lt_i lt_foo;
         } else {
           lt_count--;
         }
@@ -10465,7 +10858,7 @@ BEGIN {RS=" "; FS="/|\n";} {
   # for these hosts.
   case $host_os in
     mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\
-      $SED 's,/\([A-Za-z]:\),\1,g'` ;;
+      $SED 's|/\([A-Za-z]:\)|\1|g'` ;;
   esac
   sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP`
 else
@@ -10474,7 +10867,7 @@ fi
 library_names_spec=
 libname_spec='lib$name'
 soname_spec=
-shrext_cmds=".so"
+shrext_cmds=.so
 postinstall_cmds=
 postuninstall_cmds=
 finish_cmds=
@@ -10491,14 +10884,16 @@ hardcode_into_libs=no
 # flags to be left without arguments
 need_version=unknown
 
+
+
 case $host_os in
 aix3*)
   version_type=linux # correct to gnu/linux during the next big refactor
-  library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a'
+  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'
+  soname_spec='$libname$release$shared_ext$major'
   ;;
 
 aix[4-9]*)
@@ -10506,41 +10901,91 @@ aix[4-9]*)
   need_lib_prefix=no
   need_version=no
   hardcode_into_libs=yes
-  if test "$host_cpu" = ia64; then
+  if test ia64 = "$host_cpu"; then
     # AIX 5 supports IA64
-    library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}'
+    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
+    # 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
+	   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
+    # Using Import Files as archive members, it is possible to support
+    # filename-based versioning of shared library archives on AIX. While
+    # this would work for both with and without runtime linking, it will
+    # prevent static linking of such archives. So we do filename-based
+    # shared library versioning with .so extension only, which is used
+    # when both runtime linking and shared linking is enabled.
+    # Unfortunately, runtime linking may impact performance, so we do
+    # not want this to be the default eventually. Also, we use the
+    # versioned .so libs for executables only if there is the -brtl
+    # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only.
+    # To allow for filename-based versioning support, we need to create
+    # libNAME.so.V as an archive file, containing:
+    # *) an Import File, referring to the versioned filename of the
+    #    archive as well as the shared archive member, telling the
+    #    bitwidth (32 or 64) of that shared object, and providing the
+    #    list of exported symbols of that shared object, eventually
+    #    decorated with the 'weak' keyword
+    # *) the shared object with the F_LOADONLY flag set, to really avoid
+    #    it being seen by the linker.
+    # At run time we better use the real file rather than another symlink,
+    # but for link time we create the symlink libNAME.so -> libNAME.so.V
+
+    case $with_aix_soname,$aix_use_runtimelinking in
+    # AIX (on Power*) has no versioning support, so currently we cannot 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
+    aix,yes) # traditional libtool
+      dynamic_linker='AIX unversionable lib.so'
       # If using run time linking (on AIX 4.2 or later) use lib<name>.so
       # instead of lib<name>.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
+      library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+      ;;
+    aix,no) # traditional AIX only
+      dynamic_linker='AIX lib.a(lib.so.V)'
       # 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
+      library_names_spec='$libname$release.a $libname.a'
+      soname_spec='$libname$release$shared_ext$major'
+      ;;
+    svr4,*) # full svr4 only
+      dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)"
+      library_names_spec='$libname$release$shared_ext$major $libname$shared_ext'
+      # We do not specify a path in Import Files, so LIBPATH fires.
+      shlibpath_overrides_runpath=yes
+      ;;
+    *,yes) # both, prefer svr4
+      dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)"
+      library_names_spec='$libname$release$shared_ext$major $libname$shared_ext'
+      # unpreferred sharedlib libNAME.a needs extra handling
+      postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"'
+      postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"'
+      # We do not specify a path in Import Files, so LIBPATH fires.
+      shlibpath_overrides_runpath=yes
+      ;;
+    *,no) # both, prefer aix
+      dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)"
+      library_names_spec='$libname$release.a $libname.a'
+      soname_spec='$libname$release$shared_ext$major'
+      # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling
+      postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)'
+      postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"'
+      ;;
+    esac
     shlibpath_var=LIBPATH
   fi
   ;;
@@ -10550,18 +10995,18 @@ amigaos*)
   powerpc)
     # Since July 2007 AmigaOS4 officially supports .so libraries.
     # When compiling the executable, add -use-dynld -Lsobjs: to the compileline.
-    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
     ;;
   m68k)
     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=`func_echo_all "$lib" | $SED '\''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'
+    finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; $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'
     ;;
   esac
   ;;
 
 beos*)
-  library_names_spec='${libname}${shared_ext}'
+  library_names_spec='$libname$shared_ext'
   dynamic_linker="$host_os ld.so"
   shlibpath_var=LIBRARY_PATH
   ;;
@@ -10569,8 +11014,8 @@ beos*)
 bsdi[45]*)
   version_type=linux # correct to gnu/linux during the next big refactor
   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'
+  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"
@@ -10582,7 +11027,7 @@ bsdi[45]*)
 
 cygwin* | mingw* | pw32* | cegcc*)
   version_type=windows
-  shrext_cmds=".dll"
+  shrext_cmds=.dll
   need_version=no
   need_lib_prefix=no
 
@@ -10591,8 +11036,8 @@ cygwin* | mingw* | pw32* | cegcc*)
     # gcc
     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'\''`~
+    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~
@@ -10608,17 +11053,17 @@ cygwin* | mingw* | pw32* | cegcc*)
     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}'
+      soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
 
       sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api"
       ;;
     mingw* | cegcc*)
       # MinGW DLLs use traditional 'lib' prefix
-      soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
+      soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
       ;;
     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}'
+      library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
       ;;
     esac
     dynamic_linker='Win32 ld.exe'
@@ -10627,8 +11072,8 @@ cygwin* | mingw* | pw32* | cegcc*)
   *,cl*)
     # Native MSVC
     libname_spec='$name'
-    soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
-    library_names_spec='${libname}.dll.lib'
+    soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
+    library_names_spec='$libname.dll.lib'
 
     case $build_os in
     mingw*)
@@ -10655,7 +11100,7 @@ cygwin* | mingw* | pw32* | cegcc*)
       sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"`
       ;;
     *)
-      sys_lib_search_path_spec="$LIB"
+      sys_lib_search_path_spec=$LIB
       if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then
         # It is most probably a Windows format PATH.
         sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'`
@@ -10668,8 +11113,8 @@ cygwin* | mingw* | pw32* | cegcc*)
     esac
 
     # 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'\''`~
+    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'
@@ -10682,7 +11127,7 @@ cygwin* | mingw* | pw32* | cegcc*)
 
   *)
     # Assume MSVC wrapper
-    library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib'
+    library_names_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext $libname.lib'
     dynamic_linker='Win32 ld.exe'
     ;;
   esac
@@ -10695,8 +11140,8 @@ darwin* | rhapsody*)
   version_type=darwin
   need_lib_prefix=no
   need_version=no
-  library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext'
-  soname_spec='${libname}${release}${major}$shared_ext'
+  library_names_spec='$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`'
@@ -10709,8 +11154,8 @@ dgux*)
   version_type=linux # correct to gnu/linux during the next big refactor
   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'
+  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
   ;;
 
@@ -10735,12 +11180,13 @@ freebsd* | dragonfly*)
 
   case $version_type in
     freebsd-elf*)
-      library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
+      library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+      soname_spec='$libname$release$shared_ext$major'
       need_version=no
       need_lib_prefix=no
       ;;
     freebsd-*)
-      library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix'
+      library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
       need_version=yes
       ;;
     linux)
@@ -10771,26 +11217,15 @@ freebsd* | dragonfly*)
   esac
   ;;
 
-gnu*)
-  version_type=linux # correct to gnu/linux during the next big refactor
-  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
-  ;;
-
 haiku*)
   version_type=linux # correct to gnu/linux during the next big refactor
   need_lib_prefix=no
   need_version=no
   dynamic_linker="$host_os runtime_loader"
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
+  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=LIBRARY_PATH
-  shlibpath_overrides_runpath=yes
+  shlibpath_overrides_runpath=no
   sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib'
   hardcode_into_libs=yes
   ;;
@@ -10808,14 +11243,15 @@ hpux9* | hpux10* | hpux11*)
     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
+    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 32 = "$HPUX_IA64_MODE"; then
       sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib"
+      sys_lib_dlsearch_path_spec=/usr/lib/hpux32
     else
       sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64"
+      sys_lib_dlsearch_path_spec=/usr/lib/hpux64
     fi
-    sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
     ;;
   hppa*64*)
     shrext_cmds='.sl'
@@ -10823,8 +11259,8 @@ hpux9* | hpux10* | hpux11*)
     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'
+    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
     ;;
@@ -10833,8 +11269,8 @@ hpux9* | hpux10* | hpux11*)
     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'
+    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, ...
@@ -10847,8 +11283,8 @@ interix[3-9]*)
   version_type=linux # correct to gnu/linux during the next big refactor
   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'
+  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='Interix 3.x ld.so.1 (PE, like ELF)'
   shlibpath_var=LD_LIBRARY_PATH
   shlibpath_overrides_runpath=no
@@ -10859,7 +11295,7 @@ irix5* | irix6* | nonstopux*)
   case $host_os in
     nonstopux*) version_type=nonstopux ;;
     *)
-	if test "$lt_cv_prog_gnu_ld" = yes; then
+	if test yes = "$lt_cv_prog_gnu_ld"; then
 		version_type=linux # correct to gnu/linux during the next big refactor
 	else
 		version_type=irix
@@ -10867,8 +11303,8 @@ irix5* | irix6* | nonstopux*)
   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}'
+  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=
@@ -10887,8 +11323,8 @@ irix5* | irix6* | nonstopux*)
   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}"
+  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
   ;;
 
@@ -10897,13 +11333,33 @@ linux*oldld* | linux*aout* | linux*coff*)
   dynamic_linker=no
   ;;
 
+linux*android*)
+  version_type=none # Android doesn't support versioned libraries.
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='$libname$release$shared_ext'
+  soname_spec='$libname$release$shared_ext'
+  finish_cmds=
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+
+  # 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
+
+  dynamic_linker='Android linker'
+  # Don't embed -rpath directories since the linker doesn't support them.
+  hardcode_libdir_flag_spec='-L$libdir'
+  ;;
+
 # This must be glibc/ELF.
-linux* | k*bsd*-gnu | kopensolaris*-gnu)
+linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
   version_type=linux # correct to gnu/linux during the next big refactor
   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'
+  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
@@ -10947,7 +11403,12 @@ fi
   # before this can be enabled.
   hardcode_into_libs=yes
 
-  # Append ld.so.conf contents to the search path
+  # Ideally, we could use ldconfig to report *all* directores which are
+  # searched for libraries, however this is still not possible.  Aside from not
+  # being certain /sbin/ldconfig is available, command
+  # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64,
+  # even though it is searched at run-time.  Try to do the best guess by
+  # appending ld.so.conf contents (and includes) to the search path.
   if test -f /etc/ld.so.conf; then
     lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[	 ]*hwcap[	 ]/d;s/[:,	]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '`
     sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra"
@@ -10967,12 +11428,12 @@ netbsd*)
   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'
+    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'
+    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
@@ -10982,7 +11443,7 @@ netbsd*)
 
 newsos6)
   version_type=linux # correct to gnu/linux during the next big refactor
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  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
   ;;
@@ -10991,58 +11452,68 @@ newsos6)
   version_type=qnx
   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'
+  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='ldqnx.so'
   ;;
 
-openbsd*)
+openbsd* | bitrig*)
   version_type=sunos
-  sys_lib_dlsearch_path_spec="/usr/lib"
+  sys_lib_dlsearch_path_spec=/usr/lib
   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
+  if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then
+    need_version=no
   else
-    shlibpath_overrides_runpath=yes
+    need_version=yes
   fi
+  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
+  shlibpath_overrides_runpath=yes
   ;;
 
 os2*)
   libname_spec='$name'
-  shrext_cmds=".dll"
+  version_type=windows
+  shrext_cmds=.dll
+  need_version=no
   need_lib_prefix=no
-  library_names_spec='$libname${shared_ext} $libname.a'
+  # OS/2 can only load a DLL with a base name of 8 characters or less.
+  soname_spec='`test -n "$os2dllname" && libname="$os2dllname";
+    v=$($ECHO $release$versuffix | tr -d .-);
+    n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _);
+    $ECHO $n$v`$shared_ext'
+  library_names_spec='${libname}_dll.$libext'
   dynamic_linker='OS/2 ld.exe'
-  shlibpath_var=LIBPATH
+  shlibpath_var=BEGINLIBPATH
+  sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib"
+  sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
+  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~
+    if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then
+      eval '\''$striplib \$dldir/$dlname'\'' || exit \$?;
+    fi'
+  postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~
+    dlpath=$dir/\$dldll~
+    $RM \$dlpath'
   ;;
 
 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}'
+  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"
+  sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
   ;;
 
 rdos*)
@@ -11053,8 +11524,8 @@ solaris*)
   version_type=linux # correct to gnu/linux during the next big refactor
   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'
+  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
@@ -11064,11 +11535,11 @@ solaris*)
 
 sunos4*)
   version_type=sunos
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+  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
+  if test yes = "$with_gnu_ld"; then
     need_lib_prefix=no
   fi
   need_version=yes
@@ -11076,8 +11547,8 @@ sunos4*)
 
 sysv4 | sysv4.3*)
   version_type=linux # correct to gnu/linux during the next big refactor
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
+  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)
@@ -11098,24 +11569,24 @@ sysv4 | sysv4.3*)
   ;;
 
 sysv4*MP*)
-  if test -d /usr/nec ;then
+  if test -d /usr/nec; then
     version_type=linux # correct to gnu/linux during the next big refactor
-    library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}'
-    soname_spec='$libname${shared_ext}.$major'
+    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
   ;;
 
 sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
-  version_type=freebsd-elf
+  version_type=sco
   need_lib_prefix=no
   need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
+  library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext'
+  soname_spec='$libname$release$shared_ext$major'
   shlibpath_var=LD_LIBRARY_PATH
   shlibpath_overrides_runpath=yes
   hardcode_into_libs=yes
-  if test "$with_gnu_ld" = yes; then
+  if test yes = "$with_gnu_ld"; then
     sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib'
   else
     sys_lib_search_path_spec='/usr/ccs/lib /usr/lib'
@@ -11133,7 +11604,7 @@ tpf*)
   version_type=linux # correct to gnu/linux during the next big refactor
   need_lib_prefix=no
   need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
   shlibpath_var=LD_LIBRARY_PATH
   shlibpath_overrides_runpath=no
   hardcode_into_libs=yes
@@ -11141,8 +11612,8 @@ tpf*)
 
 uts4*)
   version_type=linux # correct to gnu/linux during the next big refactor
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
+  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
   ;;
 
@@ -11152,20 +11623,35 @@ uts4*)
 esac
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5
 $as_echo "$dynamic_linker" >&6; }
-test "$dynamic_linker" = no && can_build_shared=no
+test no = "$dynamic_linker" && can_build_shared=no
 
 variables_saved_for_relink="PATH $shlibpath_var $runpath_var"
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
   variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH"
 fi
 
-if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then
-  sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec"
+if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then
+  sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec
 fi
-if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then
-  sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec"
+
+if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then
+  sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec
 fi
 
+# remember unaugmented sys_lib_dlsearch_path content for libtool script decls...
+configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec
+
+# ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code
+func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH"
+
+# to be used as default LT_SYS_LIBRARY_PATH value in generated libtool
+configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH
+
+
+
+
+
+
 
 
 
@@ -11262,15 +11748,15 @@ $as_echo_n "checking how to hardcode library paths into programs... " >&6; }
 hardcode_action=
 if test -n "$hardcode_libdir_flag_spec" ||
    test -n "$runpath_var" ||
-   test "X$hardcode_automatic" = "Xyes" ; then
+   test yes = "$hardcode_automatic"; then
 
   # We can hardcode non-existent directories.
-  if test "$hardcode_direct" != no &&
+  if test no != "$hardcode_direct" &&
      # 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_TAGVAR(hardcode_shlibpath_var, )" != no &&
-     test "$hardcode_minus_L" != no; then
+     ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, )" &&
+     test no != "$hardcode_minus_L"; then
     # Linking always hardcodes the temporary library directory.
     hardcode_action=relink
   else
@@ -11285,12 +11771,12 @@ fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hardcode_action" >&5
 $as_echo "$hardcode_action" >&6; }
 
-if test "$hardcode_action" = relink ||
-   test "$inherit_rpath" = yes; then
+if test relink = "$hardcode_action" ||
+   test yes = "$inherit_rpath"; then
   # Fast installation is not supported
   enable_fast_install=no
-elif test "$shlibpath_overrides_runpath" = yes ||
-     test "$enable_shared" = no; then
+elif test yes = "$shlibpath_overrides_runpath" ||
+     test no = "$enable_shared"; then
   # Fast installation is not necessary
   enable_fast_install=needless
 fi
@@ -11300,7 +11786,7 @@ fi
 
 
 
-  if test "x$enable_dlopen" != xyes; then
+  if test yes != "$enable_dlopen"; then
   enable_dlopen=unknown
   enable_dlopen_self=unknown
   enable_dlopen_self_static=unknown
@@ -11310,23 +11796,23 @@ else
 
   case $host_os in
   beos*)
-    lt_cv_dlopen="load_add_on"
+    lt_cv_dlopen=load_add_on
     lt_cv_dlopen_libs=
     lt_cv_dlopen_self=yes
     ;;
 
   mingw* | pw32* | cegcc*)
-    lt_cv_dlopen="LoadLibrary"
+    lt_cv_dlopen=LoadLibrary
     lt_cv_dlopen_libs=
     ;;
 
   cygwin*)
-    lt_cv_dlopen="dlopen"
+    lt_cv_dlopen=dlopen
     lt_cv_dlopen_libs=
     ;;
 
   darwin*)
-  # if libdl is installed we need to link against it
+    # if libdl is installed we need to link against it
     { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5
 $as_echo_n "checking for dlopen in -ldl... " >&6; }
 if ${ac_cv_lib_dl_dlopen+:} false; then :
@@ -11364,10 +11850,10 @@ fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5
 $as_echo "$ac_cv_lib_dl_dlopen" >&6; }
 if test "x$ac_cv_lib_dl_dlopen" = xyes; then :
-  lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"
+  lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl
 else
 
-    lt_cv_dlopen="dyld"
+    lt_cv_dlopen=dyld
     lt_cv_dlopen_libs=
     lt_cv_dlopen_self=yes
 
@@ -11375,10 +11861,18 @@ fi
 
     ;;
 
+  tpf*)
+    # Don't try to run any link tests for TPF.  We know it's impossible
+    # because TPF is a cross-compiler, and we know how we open DSOs.
+    lt_cv_dlopen=dlopen
+    lt_cv_dlopen_libs=
+    lt_cv_dlopen_self=no
+    ;;
+
   *)
     ac_fn_c_check_func "$LINENO" "shl_load" "ac_cv_func_shl_load"
 if test "x$ac_cv_func_shl_load" = xyes; then :
-  lt_cv_dlopen="shl_load"
+  lt_cv_dlopen=shl_load
 else
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking for shl_load in -ldld" >&5
 $as_echo_n "checking for shl_load in -ldld... " >&6; }
@@ -11417,11 +11911,11 @@ fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_shl_load" >&5
 $as_echo "$ac_cv_lib_dld_shl_load" >&6; }
 if test "x$ac_cv_lib_dld_shl_load" = xyes; then :
-  lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld"
+  lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld
 else
   ac_fn_c_check_func "$LINENO" "dlopen" "ac_cv_func_dlopen"
 if test "x$ac_cv_func_dlopen" = xyes; then :
-  lt_cv_dlopen="dlopen"
+  lt_cv_dlopen=dlopen
 else
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5
 $as_echo_n "checking for dlopen in -ldl... " >&6; }
@@ -11460,7 +11954,7 @@ fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5
 $as_echo "$ac_cv_lib_dl_dlopen" >&6; }
 if test "x$ac_cv_lib_dl_dlopen" = xyes; then :
-  lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"
+  lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl
 else
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -lsvld" >&5
 $as_echo_n "checking for dlopen in -lsvld... " >&6; }
@@ -11499,7 +11993,7 @@ fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_svld_dlopen" >&5
 $as_echo "$ac_cv_lib_svld_dlopen" >&6; }
 if test "x$ac_cv_lib_svld_dlopen" = xyes; then :
-  lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld"
+  lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld
 else
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dld_link in -ldld" >&5
 $as_echo_n "checking for dld_link in -ldld... " >&6; }
@@ -11538,7 +12032,7 @@ fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_dld_link" >&5
 $as_echo "$ac_cv_lib_dld_dld_link" >&6; }
 if test "x$ac_cv_lib_dld_dld_link" = xyes; then :
-  lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld"
+  lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld
 fi
 
 
@@ -11559,21 +12053,21 @@ fi
     ;;
   esac
 
-  if test "x$lt_cv_dlopen" != xno; then
-    enable_dlopen=yes
-  else
+  if test no = "$lt_cv_dlopen"; then
     enable_dlopen=no
+  else
+    enable_dlopen=yes
   fi
 
   case $lt_cv_dlopen in
   dlopen)
-    save_CPPFLAGS="$CPPFLAGS"
-    test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H"
+    save_CPPFLAGS=$CPPFLAGS
+    test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H"
 
-    save_LDFLAGS="$LDFLAGS"
+    save_LDFLAGS=$LDFLAGS
     wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\"
 
-    save_LIBS="$LIBS"
+    save_LIBS=$LIBS
     LIBS="$lt_cv_dlopen_libs $LIBS"
 
     { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a program can dlopen itself" >&5
@@ -11581,7 +12075,7 @@ $as_echo_n "checking whether a program can dlopen itself... " >&6; }
 if ${lt_cv_dlopen_self+:} false; then :
   $as_echo_n "(cached) " >&6
 else
-  	  if test "$cross_compiling" = yes; then :
+  	  if test yes = "$cross_compiling"; then :
   lt_cv_dlopen_self=cross
 else
   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
@@ -11628,9 +12122,9 @@ else
 #  endif
 #endif
 
-/* When -fvisbility=hidden is used, assume the code has been annotated
+/* When -fvisibility=hidden is used, assume the code has been annotated
    correspondingly for the symbols needed.  */
-#if defined(__GNUC__) && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
+#if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
 int fnord () __attribute__((visibility("default")));
 #endif
 
@@ -11660,7 +12154,7 @@ _LT_EOF
   (eval $ac_link) 2>&5
   ac_status=$?
   $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
-  test $ac_status = 0; } && test -s conftest${ac_exeext} 2>/dev/null; then
+  test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then
     (./conftest; exit; ) >&5 2>/dev/null
     lt_status=$?
     case x$lt_status in
@@ -11680,14 +12174,14 @@ fi
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self" >&5
 $as_echo "$lt_cv_dlopen_self" >&6; }
 
-    if test "x$lt_cv_dlopen_self" = xyes; then
+    if test yes = "$lt_cv_dlopen_self"; then
       wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\"
       { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a statically linked program can dlopen itself" >&5
 $as_echo_n "checking whether a statically linked program can dlopen itself... " >&6; }
 if ${lt_cv_dlopen_self_static+:} false; then :
   $as_echo_n "(cached) " >&6
 else
-  	  if test "$cross_compiling" = yes; then :
+  	  if test yes = "$cross_compiling"; then :
   lt_cv_dlopen_self_static=cross
 else
   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
@@ -11734,9 +12228,9 @@ else
 #  endif
 #endif
 
-/* When -fvisbility=hidden is used, assume the code has been annotated
+/* When -fvisibility=hidden is used, assume the code has been annotated
    correspondingly for the symbols needed.  */
-#if defined(__GNUC__) && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
+#if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
 int fnord () __attribute__((visibility("default")));
 #endif
 
@@ -11766,7 +12260,7 @@ _LT_EOF
   (eval $ac_link) 2>&5
   ac_status=$?
   $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
-  test $ac_status = 0; } && test -s conftest${ac_exeext} 2>/dev/null; then
+  test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then
     (./conftest; exit; ) >&5 2>/dev/null
     lt_status=$?
     case x$lt_status in
@@ -11787,9 +12281,9 @@ fi
 $as_echo "$lt_cv_dlopen_self_static" >&6; }
     fi
 
-    CPPFLAGS="$save_CPPFLAGS"
-    LDFLAGS="$save_LDFLAGS"
-    LIBS="$save_LIBS"
+    CPPFLAGS=$save_CPPFLAGS
+    LDFLAGS=$save_LDFLAGS
+    LIBS=$save_LIBS
     ;;
   esac
 
@@ -11833,7 +12327,7 @@ else
 # FIXME - insert some real tests, host_os isn't really good enough
   case $host_os in
   darwin*)
-    if test -n "$STRIP" ; then
+    if test -n "$STRIP"; then
       striplib="$STRIP -x"
       old_striplib="$STRIP -S"
       { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
@@ -11861,7 +12355,7 @@ fi
 
 
 
-  # Report which library types will actually be built
+  # Report what library types will actually be built
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking if libtool supports shared libraries" >&5
 $as_echo_n "checking if libtool supports shared libraries... " >&6; }
   { $as_echo "$as_me:${as_lineno-$LINENO}: result: $can_build_shared" >&5
@@ -11869,13 +12363,13 @@ $as_echo "$can_build_shared" >&6; }
 
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build shared libraries" >&5
 $as_echo_n "checking whether to build shared libraries... " >&6; }
-  test "$can_build_shared" = "no" && enable_shared=no
+  test no = "$can_build_shared" && 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
+    test yes = "$enable_shared" && enable_static=no
     if test -n "$RANLIB"; then
       archive_cmds="$archive_cmds~\$RANLIB \$lib"
       postinstall_cmds='$RANLIB $lib'
@@ -11883,8 +12377,12 @@ $as_echo_n "checking whether to build shared libraries... " >&6; }
     ;;
 
   aix[4-9]*)
-    if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
-      test "$enable_shared" = yes && enable_static=no
+    if test ia64 != "$host_cpu"; then
+      case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in
+      yes,aix,yes) ;;			# shared object as lib.so file only
+      yes,svr4,*) ;;			# shared object as lib.so archive member only
+      yes,*) enable_static=no ;;	# shared object in lib.a archive as well
+      esac
     fi
     ;;
   esac
@@ -11894,7 +12392,7 @@ $as_echo "$enable_shared" >&6; }
   { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build static libraries" >&5
 $as_echo_n "checking whether to build static libraries... " >&6; }
   # Make sure either enable_shared or enable_static is yes.
-  test "$enable_shared" = yes || enable_static=yes
+  test yes = "$enable_shared" || enable_static=yes
   { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_static" >&5
 $as_echo "$enable_static" >&6; }
 
@@ -11908,7 +12406,7 @@ 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"
+CC=$lt_save_CC
 
 
 
@@ -14760,6 +15258,68 @@ $as_echo "yes" >&6; }
 
 fi
 
+# Determine if git is installed and a repository is present in source root dir.
+# Extract the first word of "git", so it can be a program name with args.
+set dummy git; ac_word=$2
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if ${ac_cv_prog_GIT_PROG_EXISTS+:} false; then :
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$GIT_PROG_EXISTS"; then
+  ac_cv_prog_GIT_PROG_EXISTS="$GIT_PROG_EXISTS" # 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_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
+    ac_cv_prog_GIT_PROG_EXISTS="yes"
+    $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+  done
+IFS=$as_save_IFS
+
+  test -z "$ac_cv_prog_GIT_PROG_EXISTS" && ac_cv_prog_GIT_PROG_EXISTS="no"
+fi
+fi
+GIT_PROG_EXISTS=$ac_cv_prog_GIT_PROG_EXISTS
+if test -n "$GIT_PROG_EXISTS"; then
+  { $as_echo "$as_me:${as_lineno-$LINENO}: result: $GIT_PROG_EXISTS" >&5
+$as_echo "$GIT_PROG_EXISTS" >&6; }
+else
+  { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+if test ${GIT_PROG_EXISTS} = "yes" ; then
+    # Determine if a repository exists right here in the build directory.
+    { $as_echo "$as_me:${as_lineno-$LINENO}: checking for git repository in source tree root" >&5
+$as_echo_n "checking for git repository in source tree root... " >&6; }
+    if test $(git rev-parse --git-dir) = ".git" ; then
+        { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
+$as_echo "yes" >&6; }
+        git_repo = 1
+    else
+        { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+$as_echo "no" >&6; }
+    fi
+fi
+ if test x$git_repo = x; then
+  GIT_VERSION_CONTROL_TRUE=
+  GIT_VERSION_CONTROL_FALSE='#'
+else
+  GIT_VERSION_CONTROL_TRUE='#'
+  GIT_VERSION_CONTROL_FALSE=
+fi
+
+
+
 # Check whether --enable-libav was given.
 if test "${enable_libav+set}" = set; then :
   enableval=$enable_libav; makelibav=$enableval
@@ -15186,6 +15746,49 @@ else
 
 fi
 
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for av_opt_set_sample_fmt in -lavutil" >&5
+$as_echo_n "checking for av_opt_set_sample_fmt in -lavutil... " >&6; }
+if ${ac_cv_lib_avutil_av_opt_set_sample_fmt+:} false; then :
+  $as_echo_n "(cached) " >&6
+else
+  ac_check_lib_save_LIBS=$LIBS
+LIBS="-lavutil  $LIBS"
+cat confdefs.h - <<_ACEOF >conftest.$ac_ext
+/* end confdefs.h.  */
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char av_opt_set_sample_fmt ();
+int
+main ()
+{
+return av_opt_set_sample_fmt ();
+  ;
+  return 0;
+}
+_ACEOF
+if ac_fn_c_try_link "$LINENO"; then :
+  ac_cv_lib_avutil_av_opt_set_sample_fmt=yes
+else
+  ac_cv_lib_avutil_av_opt_set_sample_fmt=no
+fi
+rm -f core conftest.err conftest.$ac_objext \
+    conftest$ac_exeext conftest.$ac_ext
+LIBS=$ac_check_lib_save_LIBS
+fi
+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_avutil_av_opt_set_sample_fmt" >&5
+$as_echo "$ac_cv_lib_avutil_av_opt_set_sample_fmt" >&6; }
+if test "x$ac_cv_lib_avutil_av_opt_set_sample_fmt" = xyes; then :
+
+$as_echo "#define USE_SWRESAMPLE 1" >>confdefs.h
+
+fi
+
+
 # Check whether --enable-speex was given.
 if test "${enable_speex+set}" = set; then :
   enableval=$enable_speex; makespeex=$enableval
@@ -15559,12 +16162,13 @@ else
 
 fi
 
-for ac_header in mpg123.h
+for ac_header in mpg123.h libavutil/channel_layout.h
 do :
-  ac_fn_c_check_header_mongrel "$LINENO" "mpg123.h" "ac_cv_header_mpg123_h" "$ac_includes_default"
-if test "x$ac_cv_header_mpg123_h" = xyes; then :
+  as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
+ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default"
+if eval test \"x\$"$as_ac_Header"\" = x"yes"; then :
   cat >>confdefs.h <<_ACEOF
-#define HAVE_MPG123_H 1
+#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
 _ACEOF
 
 fi
@@ -15880,7 +16484,45 @@ else
 fi
 
 
-if test $makeopus != "no" ; then
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for ogg_stream_flush_fill in -logg" >&5
+$as_echo_n "checking for ogg_stream_flush_fill in -logg... " >&6; }
+if ${ac_cv_lib_ogg_ogg_stream_flush_fill+:} false; then :
+  $as_echo_n "(cached) " >&6
+else
+  ac_check_lib_save_LIBS=$LIBS
+LIBS="-logg  $LIBS"
+cat confdefs.h - <<_ACEOF >conftest.$ac_ext
+/* end confdefs.h.  */
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char ogg_stream_flush_fill ();
+int
+main ()
+{
+return ogg_stream_flush_fill ();
+  ;
+  return 0;
+}
+_ACEOF
+if ac_fn_c_try_link "$LINENO"; then :
+  ac_cv_lib_ogg_ogg_stream_flush_fill=yes
+else
+  ac_cv_lib_ogg_ogg_stream_flush_fill=no
+fi
+rm -f core conftest.err conftest.$ac_objext \
+    conftest$ac_exeext conftest.$ac_ext
+LIBS=$ac_check_lib_save_LIBS
+fi
+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_ogg_ogg_stream_flush_fill" >&5
+$as_echo "$ac_cv_lib_ogg_ogg_stream_flush_fill" >&6; }
+if test "x$ac_cv_lib_ogg_ogg_stream_flush_fill" = xyes; then :
+
+    if test $makeopus != "no" ; then
 
 pkg_failed=no
 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for OPUS" >&5
@@ -15943,24 +16585,24 @@ fi
 	HAVE_OPUS=0
 ,
 
-            if test $makeopus = "yes" ; then
-               as_fn_error $? "libopus not detected but specifically requested in configure options" "$LINENO" 5
-            else
-               { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: IDJC will be built without opus playback or streaming support" >&5
+                if test $makeopus = "yes" ; then
+                   as_fn_error $? "libopus not detected but specifically requested in configure options" "$LINENO" 5
+                else
+                   { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: IDJC will be built without opus playback or streaming support" >&5
 $as_echo "$as_me: WARNING: IDJC will be built without opus playback or streaming support" >&2;}
-            fi
+                fi
 elif test $pkg_failed = untried; then
      	{ $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
 $as_echo "no" >&6; }
 	HAVE_OPUS=0
 ,
 
-            if test $makeopus = "yes" ; then
-               as_fn_error $? "libopus not detected but specifically requested in configure options" "$LINENO" 5
-            else
-               { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: IDJC will be built without opus playback or streaming support" >&5
+                if test $makeopus = "yes" ; then
+                   as_fn_error $? "libopus not detected but specifically requested in configure options" "$LINENO" 5
+                else
+                   { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: IDJC will be built without opus playback or streaming support" >&5
 $as_echo "$as_me: WARNING: IDJC will be built without opus playback or streaming support" >&2;}
-            fi
+                fi
 else
 	OPUS_CFLAGS=$pkg_cv_OPUS_CFLAGS
 	OPUS_LIBS=$pkg_cv_OPUS_LIBS
@@ -15970,14 +16612,27 @@ $as_echo "yes" >&6; }
 
 $as_echo "#define HAVE_OPUS 1" >>confdefs.h
 
-            HAVE_OPUS=1
+                HAVE_OPUS=1
 
 fi
+    else
+       HAVE_OPUS=0
+
+    fi
+
 else
-   HAVE_OPUS=0
+
+    if test $makeopus = "yes" ; then
+        as_fn_error $? "specifically requested opus support requires newer libogg" "$LINENO" 5
+    fi
+    { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: opus streaming requires newer libogg" >&5
+$as_echo "$as_me: WARNING: opus streaming requires newer libogg" >&2;}
+    HAVE_OPUS=0
+
 
 fi
 
+
 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for pthread_create in -lpthread" >&5
 $as_echo_n "checking for pthread_create in -lpthread... " >&6; }
 if ${ac_cv_lib_pthread_pthread_create+:} false; then :
@@ -16017,7 +16672,7 @@ $as_echo "$ac_cv_lib_pthread_pthread_create" >&6; }
 if test "x$ac_cv_lib_pthread_pthread_create" = xyes; then :
   :
 else
-  as_fn_error $? "\"libpthread not detected\"" "$LINENO" 5
+  as_fn_error $? "libpthread not detected" "$LINENO" 5
 fi
 
 
@@ -16072,7 +16727,7 @@ if test "x$ac_cv_lib_m_sqrt__pow" = xyes; then :
   LIBM="-lm"
 
 else
-  as_fn_error $? "\"math library is missing critical function\"" "$LINENO" 5
+  as_fn_error $? "math library is missing critical function" "$LINENO" 5
 fi
 
 fi
@@ -16202,7 +16857,7 @@ if eval test \"x\$"$as_ac_Header"\" = x"yes"; then :
 _ACEOF
  :
 else
-  as_fn_error $? "\"Critical header file missing\"" "$LINENO" 5
+  as_fn_error $? "Critical header file missing" "$LINENO" 5
 fi
 
 done
@@ -16466,7 +17121,7 @@ if eval test \"x\$"$as_ac_var"\" = x"yes"; then :
 _ACEOF
  :
 else
-  as_fn_error $? "\"Critical function missing\"" "$LINENO" 5
+  as_fn_error $? "Critical function missing" "$LINENO" 5
 fi
 done
 
@@ -16667,7 +17322,7 @@ DYLIB_EXT=${ext}
 { $as_echo "$as_me:${as_lineno-$LINENO}: result: ${ext}" >&5
 $as_echo "${ext}" >&6; }
 
-ac_config_files="$ac_config_files Makefile po/Makefile.in c/Makefile python/Makefile python/prelims/Makefile artwork/Makefile man/Makefile man/fr/Makefile doc/Makefile python/__init__.py.in idjc.in idjc.desktop.in"
+ac_config_files="$ac_config_files Makefile po/Makefile.in c/Makefile python/Makefile python/prelims/Makefile artwork/Makefile man/Makefile man/fr/Makefile doc/Makefile python/__init__.py.in idjc.in idjc.desktop.in idjc.appdata.xml.in"
 
 
 cat >confcache <<\_ACEOF
@@ -16802,6 +17457,10 @@ if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then
   as_fn_error $? "conditional \"am__fastdepCC\" was never defined.
 Usually this means the macro was only invoked conditionally." "$LINENO" 5
 fi
+if test -z "${GIT_VERSION_CONTROL_TRUE}" && test -z "${GIT_VERSION_CONTROL_FALSE}"; then
+  as_fn_error $? "conditional \"GIT_VERSION_CONTROL\" was never defined.
+Usually this means the macro was only invoked conditionally." "$LINENO" 5
+fi
 
 : "${CONFIG_STATUS=./config.status}"
 ac_write_fail=0
@@ -17199,7 +17858,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
 # report actual input values of CONFIG_FILES etc. instead of their
 # values after options handling.
 ac_log="
-This file was extended by idjc $as_me 0.8.14, which was
+This file was extended by idjc $as_me 0.8.15, which was
 generated by GNU Autoconf 2.69.  Invocation command line was
 
   CONFIG_FILES    = $CONFIG_FILES
@@ -17265,7 +17924,7 @@ _ACEOF
 cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`"
 ac_cs_version="\\
-idjc config.status 0.8.14
+idjc config.status 0.8.15
 configured by $0, generated by GNU Autoconf 2.69,
   with options \\"\$ac_cs_config\\"
 
@@ -17400,6 +18059,7 @@ enable_static='`$ECHO "$enable_static" | $SED "$delay_single_quote_subst"`'
 enable_shared='`$ECHO "$enable_shared" | $SED "$delay_single_quote_subst"`'
 pic_mode='`$ECHO "$pic_mode" | $SED "$delay_single_quote_subst"`'
 enable_fast_install='`$ECHO "$enable_fast_install" | $SED "$delay_single_quote_subst"`'
+shared_archive_member_spec='`$ECHO "$shared_archive_member_spec" | $SED "$delay_single_quote_subst"`'
 SHELL='`$ECHO "$SHELL" | $SED "$delay_single_quote_subst"`'
 ECHO='`$ECHO "$ECHO" | $SED "$delay_single_quote_subst"`'
 PATH_SEPARATOR='`$ECHO "$PATH_SEPARATOR" | $SED "$delay_single_quote_subst"`'
@@ -17449,10 +18109,13 @@ compiler='`$ECHO "$compiler" | $SED "$delay_single_quote_subst"`'
 GCC='`$ECHO "$GCC" | $SED "$delay_single_quote_subst"`'
 lt_cv_sys_global_symbol_pipe='`$ECHO "$lt_cv_sys_global_symbol_pipe" | $SED "$delay_single_quote_subst"`'
 lt_cv_sys_global_symbol_to_cdecl='`$ECHO "$lt_cv_sys_global_symbol_to_cdecl" | $SED "$delay_single_quote_subst"`'
+lt_cv_sys_global_symbol_to_import='`$ECHO "$lt_cv_sys_global_symbol_to_import" | $SED "$delay_single_quote_subst"`'
 lt_cv_sys_global_symbol_to_c_name_address='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address" | $SED "$delay_single_quote_subst"`'
 lt_cv_sys_global_symbol_to_c_name_address_lib_prefix='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address_lib_prefix" | $SED "$delay_single_quote_subst"`'
+lt_cv_nm_interface='`$ECHO "$lt_cv_nm_interface" | $SED "$delay_single_quote_subst"`'
 nm_file_list_spec='`$ECHO "$nm_file_list_spec" | $SED "$delay_single_quote_subst"`'
 lt_sysroot='`$ECHO "$lt_sysroot" | $SED "$delay_single_quote_subst"`'
+lt_cv_truncate_bin='`$ECHO "$lt_cv_truncate_bin" | $SED "$delay_single_quote_subst"`'
 objdir='`$ECHO "$objdir" | $SED "$delay_single_quote_subst"`'
 MAGIC_CMD='`$ECHO "$MAGIC_CMD" | $SED "$delay_single_quote_subst"`'
 lt_prog_compiler_no_builtin_flag='`$ECHO "$lt_prog_compiler_no_builtin_flag" | $SED "$delay_single_quote_subst"`'
@@ -17517,7 +18180,8 @@ finish_cmds='`$ECHO "$finish_cmds" | $SED "$delay_single_quote_subst"`'
 finish_eval='`$ECHO "$finish_eval" | $SED "$delay_single_quote_subst"`'
 hardcode_into_libs='`$ECHO "$hardcode_into_libs" | $SED "$delay_single_quote_subst"`'
 sys_lib_search_path_spec='`$ECHO "$sys_lib_search_path_spec" | $SED "$delay_single_quote_subst"`'
-sys_lib_dlsearch_path_spec='`$ECHO "$sys_lib_dlsearch_path_spec" | $SED "$delay_single_quote_subst"`'
+configure_time_dlsearch_path='`$ECHO "$configure_time_dlsearch_path" | $SED "$delay_single_quote_subst"`'
+configure_time_lt_sys_library_path='`$ECHO "$configure_time_lt_sys_library_path" | $SED "$delay_single_quote_subst"`'
 hardcode_action='`$ECHO "$hardcode_action" | $SED "$delay_single_quote_subst"`'
 enable_dlopen='`$ECHO "$enable_dlopen" | $SED "$delay_single_quote_subst"`'
 enable_dlopen_self='`$ECHO "$enable_dlopen_self" | $SED "$delay_single_quote_subst"`'
@@ -17568,9 +18232,12 @@ CFLAGS \
 compiler \
 lt_cv_sys_global_symbol_pipe \
 lt_cv_sys_global_symbol_to_cdecl \
+lt_cv_sys_global_symbol_to_import \
 lt_cv_sys_global_symbol_to_c_name_address \
 lt_cv_sys_global_symbol_to_c_name_address_lib_prefix \
+lt_cv_nm_interface \
 nm_file_list_spec \
+lt_cv_truncate_bin \
 lt_prog_compiler_no_builtin_flag \
 lt_prog_compiler_pic \
 lt_prog_compiler_wl \
@@ -17605,7 +18272,7 @@ old_striplib \
 striplib; do
     case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in
     *[\\\\\\\`\\"\\\$]*)
-      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\""
+      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes
       ;;
     *)
       eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
@@ -17632,10 +18299,11 @@ postinstall_cmds \
 postuninstall_cmds \
 finish_cmds \
 sys_lib_search_path_spec \
-sys_lib_dlsearch_path_spec; do
+configure_time_dlsearch_path \
+configure_time_lt_sys_library_path; do
     case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in
     *[\\\\\\\`\\"\\\$]*)
-      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\""
+      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes
       ;;
     *)
       eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
@@ -17644,19 +18312,16 @@ sys_lib_dlsearch_path_spec; do
 done
 
 ac_aux_dir='$ac_aux_dir'
-xsi_shell='$xsi_shell'
-lt_shell_append='$lt_shell_append'
 
-# See if we are running on zsh, and set the options which allow our
+# See if we are running on zsh, and set the options that allow our
 # commands through without removal of \ escapes INIT.
-if test -n "\${ZSH_VERSION+set}" ; then
+if test -n "\${ZSH_VERSION+set}"; then
    setopt NO_GLOB_SUBST
 fi
 
 
     PACKAGE='$PACKAGE'
     VERSION='$VERSION'
-    TIMESTAMP='$TIMESTAMP'
     RM='$RM'
     ofile='$ofile'
 
@@ -17694,6 +18359,7 @@ do
     "python/__init__.py.in") CONFIG_FILES="$CONFIG_FILES python/__init__.py.in" ;;
     "idjc.in") CONFIG_FILES="$CONFIG_FILES idjc.in" ;;
     "idjc.desktop.in") CONFIG_FILES="$CONFIG_FILES idjc.desktop.in" ;;
+    "idjc.appdata.xml.in") CONFIG_FILES="$CONFIG_FILES idjc.appdata.xml.in" ;;
 
   *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;;
   esac
@@ -18384,55 +19050,53 @@ $as_echo X"$file" |
  ;;
     "libtool":C)
 
-    # See if we are running on zsh, and set the options which allow our
+    # See if we are running on zsh, and set the options that allow our
     # commands through without removal of \ escapes.
-    if test -n "${ZSH_VERSION+set}" ; then
+    if test -n "${ZSH_VERSION+set}"; then
       setopt NO_GLOB_SUBST
     fi
 
-    cfgfile="${ofile}T"
+    cfgfile=${ofile}T
     trap "$RM \"$cfgfile\"; exit 1" 1 2 15
     $RM "$cfgfile"
 
     cat <<_LT_EOF >> "$cfgfile"
 #! $SHELL
-
-# `$ECHO "$ofile" | sed 's%^.*/%%'` - Provide generalized library-building support services.
-# Generated automatically by $as_me ($PACKAGE$TIMESTAMP) $VERSION
+# Generated automatically by $as_me ($PACKAGE) $VERSION
 # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`:
 # NOTE: Changes made to this file will be lost: look at ltmain.sh.
+
+# Provide generalized library-building support services.
+# Written by Gordon Matzigkeit, 1996
+
+# Copyright (C) 2014 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.
+
+# GNU Libtool 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 of the License, or
+# (at your option) any later version.
 #
-#   Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,
-#                 2006, 2007, 2008, 2009, 2010, 2011 Free Software
-#                 Foundation, Inc.
-#   Written by Gordon Matzigkeit, 1996
-#
-#   This file is part of GNU Libtool.
-#
-# GNU Libtool 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.
-#
-# As a special exception to the GNU General Public License,
-# if you distribute this file as part of a program or library that
-# is built using GNU Libtool, you may include this file under the
-# same distribution terms that you use for the rest of that program.
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program or library that is built
+# using GNU Libtool, you may include this file under the  same
+# distribution terms that you use for the rest of that program.
 #
-# GNU Libtool is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# GNU Libtool 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 GNU Libtool; see the file COPYING.  If not, a copy
-# can be downloaded from http://www.gnu.org/licenses/gpl.html, or
-# obtained by writing to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
 
 # The names of the tagged configurations supported by this script.
-available_tags=""
+available_tags=''
+
+# Configured defaults for sys_lib_dlsearch_path munging.
+: \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"}
 
 # ### BEGIN LIBTOOL CONFIG
 
@@ -18452,6 +19116,9 @@ pic_mode=$pic_mode
 # Whether or not to optimize for fast installation.
 fast_install=$enable_fast_install
 
+# Shared archive member basename,for filename based shared library versioning on AIX.
+shared_archive_member_spec=$shared_archive_member_spec
+
 # Shell to use when invoking shell scripts.
 SHELL=$lt_SHELL
 
@@ -18569,18 +19236,27 @@ 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 into a list of symbols to manually relocate.
+global_symbol_to_import=$lt_lt_cv_sys_global_symbol_to_import
+
 # 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
 
 # Transform the output of nm in a C name address pair when lib prefix is needed.
 global_symbol_to_c_name_address_lib_prefix=$lt_lt_cv_sys_global_symbol_to_c_name_address_lib_prefix
 
+# The name lister interface.
+nm_interface=$lt_lt_cv_nm_interface
+
 # Specify filename containing input files for \$NM.
 nm_file_list_spec=$lt_nm_file_list_spec
 
-# The root where to search for dependent libraries,and in which our libraries should be installed.
+# The root where to search for dependent libraries,and where our libraries should be installed.
 lt_sysroot=$lt_sysroot
 
+# Command to truncate a binary pipe.
+lt_truncate_bin=$lt_lt_cv_truncate_bin
+
 # The name of the directory that contains temporary libtool files.
 objdir=$objdir
 
@@ -18671,8 +19347,11 @@ hardcode_into_libs=$hardcode_into_libs
 # 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
+# Detected run-time system search path for libraries.
+sys_lib_dlsearch_path_spec=$lt_configure_time_dlsearch_path
+
+# Explicit LT_SYS_LIBRARY_PATH set during ./configure time.
+configure_time_lt_sys_library_path=$lt_configure_time_lt_sys_library_path
 
 # Whether dlopen is supported.
 dlopen_support=$enable_dlopen
@@ -18765,13 +19444,13 @@ hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec
 # 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
+# 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 DIR/libNAME\${shared_ext} during linking hardcodes
+# Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes
 # DIR into the resulting binary and the resulting library dependency is
-# "absolute",i.e impossible to change by setting \${shlibpath_var} if the
+# "absolute",i.e impossible to change by setting \$shlibpath_var if the
 # library is relocated.
 hardcode_direct_absolute=$hardcode_direct_absolute
 
@@ -18823,13 +19502,72 @@ hardcode_action=$hardcode_action
 
 _LT_EOF
 
+    cat <<'_LT_EOF' >> "$cfgfile"
+
+# ### BEGIN FUNCTIONS SHARED WITH CONFIGURE
+
+# func_munge_path_list VARIABLE PATH
+# -----------------------------------
+# VARIABLE is name of variable containing _space_ separated list of
+# directories to be munged by the contents of PATH, which is string
+# having a format:
+# "DIR[:DIR]:"
+#       string "DIR[ DIR]" will be prepended to VARIABLE
+# ":DIR[:DIR]"
+#       string "DIR[ DIR]" will be appended to VARIABLE
+# "DIRP[:DIRP]::[DIRA:]DIRA"
+#       string "DIRP[ DIRP]" will be prepended to VARIABLE and string
+#       "DIRA[ DIRA]" will be appended to VARIABLE
+# "DIR[:DIR]"
+#       VARIABLE will be replaced by "DIR[ DIR]"
+func_munge_path_list ()
+{
+    case x$2 in
+    x)
+        ;;
+    *:)
+        eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\"
+        ;;
+    x:*)
+        eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\"
+        ;;
+    *::*)
+        eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\"
+        eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\"
+        ;;
+    *)
+        eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\"
+        ;;
+    esac
+}
+
+
+# Calculate cc_basename.  Skip known compiler wrappers and cross-prefix.
+func_cc_basename ()
+{
+    for cc_temp in $*""; do
+      case $cc_temp in
+        compile | *[\\/]compile | ccache | *[\\/]ccache ) ;;
+        distcc | *[\\/]distcc | purify | *[\\/]purify ) ;;
+        \-*) ;;
+        *) break;;
+      esac
+    done
+    func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"`
+}
+
+
+# ### END FUNCTIONS SHARED WITH CONFIGURE
+
+_LT_EOF
+
   case $host_os in
   aix3*)
     cat <<\_LT_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
+if test set != "${COLLECT_NAMES+set}"; then
   COLLECT_NAMES=
   export COLLECT_NAMES
 fi
@@ -18838,7 +19576,7 @@ _LT_EOF
   esac
 
 
-ltmain="$ac_aux_dir/ltmain.sh"
+ltmain=$ac_aux_dir/ltmain.sh
 
 
   # We use sed instead of cat because bash on DJGPP gets confused if
@@ -18848,165 +19586,6 @@ ltmain="$ac_aux_dir/ltmain.sh"
   sed '$q' "$ltmain" >> "$cfgfile" \
      || (rm -f "$cfgfile"; exit 1)
 
-  if test x"$xsi_shell" = xyes; then
-  sed -e '/^func_dirname ()$/,/^} # func_dirname /c\
-func_dirname ()\
-{\
-\    case ${1} in\
-\      */*) func_dirname_result="${1%/*}${2}" ;;\
-\      *  ) func_dirname_result="${3}" ;;\
-\    esac\
-} # Extended-shell func_dirname implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
-  sed -e '/^func_basename ()$/,/^} # func_basename /c\
-func_basename ()\
-{\
-\    func_basename_result="${1##*/}"\
-} # Extended-shell func_basename implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
-  sed -e '/^func_dirname_and_basename ()$/,/^} # func_dirname_and_basename /c\
-func_dirname_and_basename ()\
-{\
-\    case ${1} in\
-\      */*) func_dirname_result="${1%/*}${2}" ;;\
-\      *  ) func_dirname_result="${3}" ;;\
-\    esac\
-\    func_basename_result="${1##*/}"\
-} # Extended-shell func_dirname_and_basename implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
-  sed -e '/^func_stripname ()$/,/^} # func_stripname /c\
-func_stripname ()\
-{\
-\    # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are\
-\    # positional parameters, so assign one to ordinary parameter first.\
-\    func_stripname_result=${3}\
-\    func_stripname_result=${func_stripname_result#"${1}"}\
-\    func_stripname_result=${func_stripname_result%"${2}"}\
-} # Extended-shell func_stripname implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
-  sed -e '/^func_split_long_opt ()$/,/^} # func_split_long_opt /c\
-func_split_long_opt ()\
-{\
-\    func_split_long_opt_name=${1%%=*}\
-\    func_split_long_opt_arg=${1#*=}\
-} # Extended-shell func_split_long_opt implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
-  sed -e '/^func_split_short_opt ()$/,/^} # func_split_short_opt /c\
-func_split_short_opt ()\
-{\
-\    func_split_short_opt_arg=${1#??}\
-\    func_split_short_opt_name=${1%"$func_split_short_opt_arg"}\
-} # Extended-shell func_split_short_opt implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
-  sed -e '/^func_lo2o ()$/,/^} # func_lo2o /c\
-func_lo2o ()\
-{\
-\    case ${1} in\
-\      *.lo) func_lo2o_result=${1%.lo}.${objext} ;;\
-\      *)    func_lo2o_result=${1} ;;\
-\    esac\
-} # Extended-shell func_lo2o implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
-  sed -e '/^func_xform ()$/,/^} # func_xform /c\
-func_xform ()\
-{\
-    func_xform_result=${1%.*}.lo\
-} # Extended-shell func_xform implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
-  sed -e '/^func_arith ()$/,/^} # func_arith /c\
-func_arith ()\
-{\
-    func_arith_result=$(( $* ))\
-} # Extended-shell func_arith implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
-  sed -e '/^func_len ()$/,/^} # func_len /c\
-func_len ()\
-{\
-    func_len_result=${#1}\
-} # Extended-shell func_len implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-fi
-
-if test x"$lt_shell_append" = xyes; then
-  sed -e '/^func_append ()$/,/^} # func_append /c\
-func_append ()\
-{\
-    eval "${1}+=\\${2}"\
-} # Extended-shell func_append implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
-  sed -e '/^func_append_quoted ()$/,/^} # func_append_quoted /c\
-func_append_quoted ()\
-{\
-\    func_quote_for_eval "${2}"\
-\    eval "${1}+=\\\\ \\$func_quote_for_eval_result"\
-} # Extended-shell func_append_quoted implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
-  # Save a `func_append' function call where possible by direct use of '+='
-  sed -e 's%func_append \([a-zA-Z_]\{1,\}\) "%\1+="%g' $cfgfile > $cfgfile.tmp \
-    && mv -f "$cfgfile.tmp" "$cfgfile" \
-      || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-  test 0 -eq $? || _lt_function_replace_fail=:
-else
-  # Save a `func_append' function call even when '+=' is not available
-  sed -e 's%func_append \([a-zA-Z_]\{1,\}\) "%\1="$\1%g' $cfgfile > $cfgfile.tmp \
-    && mv -f "$cfgfile.tmp" "$cfgfile" \
-      || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-  test 0 -eq $? || _lt_function_replace_fail=:
-fi
-
-if test x"$_lt_function_replace_fail" = x":"; then
-  { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: Unable to substitute extended shell functions in $ofile" >&5
-$as_echo "$as_me: WARNING: Unable to substitute extended shell functions in $ofile" >&2;}
-fi
-
-
    mv -f "$cfgfile" "$ofile" ||
     (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile")
   chmod +x "$ofile"
diff --git a/configure.ac b/configure.ac
index f5ab546..3002a13 100644
--- a/configure.ac
+++ b/configure.ac
@@ -2,9 +2,9 @@
 # Process this file with autoconf to produce a configure script.
 
 AC_PREREQ(2.59)
-AC_INIT([idjc], [0.8.14], 
+AC_INIT([idjc], [0.8.15], 
                 [http://idjc.sourceforge.net])
-AC_SUBST(COPYRIGHT_YEAR, [2013])
+AC_SUBST(COPYRIGHT_YEAR, [2015])
 AC_CANONICAL_SYSTEM
 AC_CONFIG_SRCDIR([config.h.in])
 AM_INIT_AUTOMAKE
@@ -35,6 +35,21 @@ PKG_CHECK_MODULES([LIBSAMPLERATE], [samplerate])
 PKG_CHECK_MODULES([LIBSNDFILE], [sndfile])
 PKG_CHECK_MODULES([GLIB], [glib-2.0])
 
+# Determine if git is installed and a repository is present in source root dir.
+AC_CHECK_PROG([GIT_PROG_EXISTS], [git], [yes], [no])
+if test ${GIT_PROG_EXISTS} = "yes" ; then
+    # Determine if a repository exists right here in the build directory.
+    AC_MSG_CHECKING([for git repository in source tree root])
+    if test $(git rev-parse --git-dir) = ".git" ; then
+        AC_MSG_RESULT([yes])
+        git_repo = 1
+    else
+        AC_MSG_RESULT([no])
+    fi
+fi
+AM_CONDITIONAL([GIT_VERSION_CONTROL], [test x$git_repo = x])
+
+
 AC_ARG_ENABLE([libav],
    AC_HELP_STRING([--disable-libav],[remove capability to decode m4a/wma/avi files]),[makelibav=$enableval],[makelibav="maybe"])
 
@@ -90,6 +105,8 @@ else
    AC_SUBST(HAVE_SWRESAMPLE, 0)
 fi
 
+AC_CHECK_LIB([avutil], [av_opt_set_sample_fmt], AC_DEFINE(USE_SWRESAMPLE, 1, [Set if libswresample allows format conversion]))
+
 AC_ARG_ENABLE([speex],
    AC_HELP_STRING([--disable-speex],[remove the capability to play/stream speex]),
    [makespeex=$enableval],[makespeex="maybe"])
@@ -150,7 +167,7 @@ else
    AC_SUBST([HAVE_OGGFLAC],[0])
 fi
 
-AC_CHECK_HEADERS([mpg123.h])
+AC_CHECK_HEADERS([mpg123.h libavutil/channel_layout.h])
 
 AC_ARG_ENABLE(mpg123,
    AC_HELP_STRING([--disable-mpg123],[remove capability to play mp3 format]),[makempg123=$enableval],[makempg123="maybe"])
@@ -216,31 +233,40 @@ AC_ARG_ENABLE([opus],
    AC_HELP_STRING([--disable-opus],[remove capability to play/stream in opus format]),
    [makeopus=$enableval],[makeopus="maybe"])
 
-if test $makeopus != "no" ; then
-   PKG_CHECK_MODULES([OPUS], [opus],
-            [
-            AC_DEFINE(HAVE_OPUS, 1, [Set if libopus was found])
-            AC_SUBST(HAVE_OPUS, 1)],
-            [AC_SUBST(HAVE_OPUS, 0),
-
-            if test $makeopus = "yes" ; then
-               AC_MSG_ERROR([libopus not detected but specifically requested in configure options])
-            else
-               AC_MSG_WARN([IDJC will be built without opus playback or streaming support])
-            fi])
-else
-   AC_SUBST([HAVE_OPUS],[0])
-fi
-
-AC_CHECK_LIB([pthread], [pthread_create], :, AC_MSG_ERROR("libpthread not detected"))
+AC_CHECK_LIB([ogg], [ogg_stream_flush_fill],[
+    if test $makeopus != "no" ; then
+       PKG_CHECK_MODULES([OPUS], [opus],
+                [
+                AC_DEFINE(HAVE_OPUS, 1, [Set if libopus was found])
+                AC_SUBST(HAVE_OPUS, 1)],
+                [AC_SUBST(HAVE_OPUS, 0),
+
+                if test $makeopus = "yes" ; then
+                   AC_MSG_ERROR([libopus not detected but specifically requested in configure options])
+                else
+                   AC_MSG_WARN([IDJC will be built without opus playback or streaming support])
+                fi])
+    else
+       AC_SUBST([HAVE_OPUS], 0)
+    fi
+    ],
+    [
+    if test $makeopus = "yes" ; then
+        AC_MSG_ERROR([specifically requested opus support requires newer libogg])
+    fi
+    AC_MSG_WARN([opus streaming requires newer libogg])
+    AC_SUBST([HAVE_OPUS], 0)]
+    )
+
+AC_CHECK_LIB([pthread], [pthread_create], :, AC_MSG_ERROR([libpthread not detected]))
 
 # Conditionally include libm.  Some standard libraries could have inbuilt math stuff.
 AC_CHECK_FUNCS([sqrt pow], :, [AC_CHECK_LIB([m], [sqrt, pow], AC_SUBST(LIBM, "-lm"),
-	AC_MSG_ERROR("math library is missing critical function"))])
+	AC_MSG_ERROR([math library is missing critical function]))])
 
 # Checks for header files.
 AC_HEADER_STDC
-AC_CHECK_HEADERS([fcntl.h jack/jack.h jack/transport.h pthread.h], :, AC_MSG_ERROR("Critical header file missing"))
+AC_CHECK_HEADERS([fcntl.h jack/jack.h jack/transport.h pthread.h], :, AC_MSG_ERROR([Critical header file missing]))
 
 # Checks for typedefs, structures, and compiler characteristics.
 AC_C_CONST
@@ -251,7 +277,7 @@ AC_TYPE_SIZE_T
 # Checks for library functions.
 AC_FUNC_MALLOC
 AC_TYPE_SIGNAL
-AC_CHECK_FUNCS([memset strchr], :, AC_MSG_ERROR("Critical function missing"))
+AC_CHECK_FUNCS([memset strchr], :, AC_MSG_ERROR([Critical function missing]))
 AC_CHECK_FUNCS([getline strndup canonicalize_file_name], :,
       [AC_DEFINE([USE_BSD_COMPAT],[1],
       [Set if GNU extensions need to be replicated])])
@@ -287,6 +313,7 @@ AC_CONFIG_FILES([Makefile
                   doc/Makefile
                   python/__init__.py.in
                   idjc.in
-                  idjc.desktop.in])
+                  idjc.desktop.in
+                  idjc.appdata.xml.in])
 
 AC_OUTPUT
diff --git a/doc/Makefile.in b/doc/Makefile.in
index 0f8ad1f..576d3ce 100644
--- a/doc/Makefile.in
+++ b/doc/Makefile.in
@@ -149,6 +149,7 @@ EXEEXT = @EXEEXT@
 EXT = @EXT@
 FGREP = @FGREP@
 GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@
+GIT_PROG_EXISTS = @GIT_PROG_EXISTS@
 GLIB_CFLAGS = @GLIB_CFLAGS@
 GLIB_LIBS = @GLIB_LIBS@
 GMSGFMT = @GMSGFMT@
@@ -206,6 +207,7 @@ LN_S = @LN_S@
 LTLIBICONV = @LTLIBICONV@
 LTLIBINTL = @LTLIBINTL@
 LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
 MAKEINFO = @MAKEINFO@
 MANIFEST_TOOL = @MANIFEST_TOOL@
 MKDIR_P = @MKDIR_P@
diff --git a/doc/code_idjcmon.html b/doc/code_idjcmon.html
index 2847507..783d27c 100644
--- a/doc/code_idjcmon.html
+++ b/doc/code_idjcmon.html
@@ -130,6 +130,12 @@ def frozen_handler(monitor, profile, pid, frozen):
     print "IDJC '%s' with process ID %d is %s" % (
                     profile, pid, ("no longer frozen", "frozen")[frozen])
 
+def effect_started_handler(monitor, title, pathname, player):
+    print "Effect player %d is playing %s" % (player, title)
+
+def effect_stopped_handler(monitor, player):
+    print "Effect player %d has stopped" % player
+
 try:
     profile = sys.argv[1]
 except IndexError:
@@ -141,6 +147,8 @@ monitor.connect("quit", quit_handler)
 monitor.connect("streamstate-changed", streamstate_handler)
 monitor.connect("metadata-changed", metadata_handler)
 monitor.connect("frozen", frozen_handler)
+monitor.connect("effect-started", effect_started_handler)
+monitor.connect("effect-stopped", effect_stopped_handler)
 
 gobject.MainLoop().run()
 </pre>
diff --git a/doc/install_build.html b/doc/install_build.html
index 1d6dff8..5edab86 100644
--- a/doc/install_build.html
+++ b/doc/install_build.html
@@ -145,25 +145,25 @@ which you typically want the library development packages whose names carry the
       <td><a href="http://www.gtk.org/download.html">GLib2</a></td><td>2.0.0+</td><td>Required</td>
    </tr>
    <tr>
-      <td><a href="http://www.mpg123.de/">mpg123</a></td><td>1.13+</td><td>Required—provides support for mp2/mp3 playback</td>
+      <td><a href="http://www.mpg123.de/">mpg123</a></td><td>1.13+</td><td>Recommended—for mp2/mp3 playback</td>
    </tr>
    <tr>
-      <td><a href="http://www.twolame.org/">TwoLAME</a></td><td>0.3+</td><td>Required—provides support for streaming/recording in the mp2 format</td>
+      <td><a href="http://www.twolame.org/">TwoLAME</a></td><td>0.3+</td><td>Recommended—for streaming/recording in the mp2 format</td>
    </tr>
    <tr>
-      <td><a href="http://lame.sourceforge.net/">Lame</a></td><td>3.97+</td><td>Recommended—provides support for streaming/recording in the mp3 format</td>
+      <td><a href="http://lame.sourceforge.net/">Lame</a></td><td>3.97+</td><td>Recommended—for streaming/recording in the mp3 format</td>
    </tr>
    <tr>
-      <td><a href="http://www.ffmpeg.org/">FFmpeg's libav…</a></td><td>0.10/0.8+</td><td>Recommended—provides support for mp4/m4a, ape, mpc, aac(+)</td>
+      <td><a href="http://www.ffmpeg.org/">FFmpeg's libav…</a></td><td>0.10/0.8+</td><td>Recommended—for mp4/m4a, ape, mpc, aac(+)</td>
    </tr>
    <tr>
-      <td><a href="http://flac.sourceforge.net/">FLAC</a></td><td>1.1.3+</td><td>Recommended—provides support for FLAC playback, recording, and streaming</td>
+      <td><a href="http://flac.sourceforge.net/">FLAC</a></td><td>1.1.3+</td><td>Recommended—for FLAC playback, recording, and streaming</td>
    </tr>
    <tr>
-      <td><a href="http://www.speex.org/">Speex</a></td><td>1.2rc1+</td><td>Recommended—provides support for Speex playback and streaming</td>
+      <td><a href="http://www.speex.org/">Speex</a></td><td>1.2rc1+</td><td>Recommended—for Speex playback and streaming</td>
    </tr>
    <tr>
-      <td><a href="http://www.opus-codec.org/">Opus</a></td><td>1.0+</td><td>Recommended—provides support for Opus playback and streaming</td>
+      <td><a href="http://www.opus-codec.org/">Opus</a></td><td>1.0+</td><td>Recommended—for Opus playback and streaming</td>
    </tr>
 </table>
 <p>For Ubuntu users, this command should be enough to satisfy nearly all of the above.</p>
diff --git a/doc/jingles-window.png b/doc/jingles-window.png
index cf6ab70..367c9d6 100644
Binary files a/doc/jingles-window.png and b/doc/jingles-window.png differ
diff --git a/doc/main-window.png b/doc/main-window.png
index 4d7e0ec..7d5513d 100644
Binary files a/doc/main-window.png and b/doc/main-window.png differ
diff --git a/doc/output-window.png b/doc/output-window.png
index 12c5288..79af685 100644
Binary files a/doc/output-window.png and b/doc/output-window.png differ
diff --git a/doc/prefs-bindings.png b/doc/prefs-bindings.png
index 83f62b0..6e4b387 100644
Binary files a/doc/prefs-bindings.png and b/doc/prefs-bindings.png differ
diff --git a/doc/prefs-channels.png b/doc/prefs-channels.png
index bcf6851..61badec 100644
Binary files a/doc/prefs-channels.png and b/doc/prefs-channels.png differ
diff --git a/doc/prefs-general.png b/doc/prefs-general.png
index 08d4135..7c8543a 100644
Binary files a/doc/prefs-general.png and b/doc/prefs-general.png differ
diff --git a/doc/prefs-jack-ports.png b/doc/prefs-jack-ports.png
index d441f32..4c51118 100644
Binary files a/doc/prefs-jack-ports.png and b/doc/prefs-jack-ports.png differ
diff --git a/doc/tutorials_icecast.html b/doc/tutorials_icecast.html
index ae9a599..61262aa 100644
--- a/doc/tutorials_icecast.html
+++ b/doc/tutorials_icecast.html
@@ -321,9 +321,9 @@ inadequate write permissions and try again. Leave Icecast running for the time b
 
 <h4>Configuring IDJC</h4>
 
-<p>Start the Jack sound server as follows.</p>
+<p>Start the JACK sound server as follows.</p>
 <pre>$ jackd -d dummy -r 44100</pre>
-<p>This is done so that any media player, even one that does not support Jack Audio Connection Kit can be
+<p>This is done so that any media player, even one that does not support JACK Audio Connection Kit can be
 used for playing the stream on this machine.</p>
 
 <p>Run IDJC and click the Output button in the bottom left hand corner. Click Configuration so the
@@ -335,8 +335,7 @@ can be what you like but choose /listen, login name needs to be source and the p
 password, which is <span style="color:red;" title="Obviously a server exposed to the Internet should never 
 be configured to use its default password">hackme</span>. Click Ok to add the server to the list.</p>
 
-<p>Click Format. Select the Sample rate drop down box and choose 44100. Select MP3 and the top drop down box.
-Choose 128, Quality 5, and Joint Stereo. </p>
+<p>Click Format. Select MPEG and click the right arrow repeatedly until all the option boxes appear.</p>
 
 <p>Click Individual Controls so the controls section is visible and click the button that says
 localhost:8000/listen.</p>
@@ -349,7 +348,7 @@ localhost:8000/listen.</p>
 playlist. Click play. Make sure the crossfader is set all the way to the left. Make sure Stream is on and DJ is off.
 You should be able to see the Str Peak meter is active.</p>
 
-<p>If you can't hear anything right now it's because DJ is off and/or you are running a dummy Jack soundcard,
+<p>If you can't hear anything right now it's because DJ is off and/or you are running a dummy JACK soundcard,
 which is what you want for the sake of this test.</p>
 
 <h4>Join the stream as a listener</h4>
diff --git a/doc/tutorials_jack_ports_demystified.html b/doc/tutorials_jack_ports_demystified.html
index 45b339d..bd3d4de 100644
--- a/doc/tutorials_jack_ports_demystified.html
+++ b/doc/tutorials_jack_ports_demystified.html
@@ -152,7 +152,7 @@ The audio routing of IDJC to the soundcard happens via JACK ports.</p>
 <tr>
   <td><p>Misc</p></td>
   <td><p>The MIDI port can be connected to ports of MIDI devices to use them to control IDJC.</p>
-  <p>The DJ alarm port produces and audible tone when playlists are about to end.</p>
+  <p>The DJ alarm port produces an audible tone when playlists are about to end.</p>
   </td>
 </tr>
 </table> 
diff --git a/doc/tutorials_shoutcast.html b/doc/tutorials_shoutcast.html
index 13f64f3..fa8649c 100644
--- a/doc/tutorials_shoutcast.html
+++ b/doc/tutorials_shoutcast.html
@@ -107,46 +107,41 @@ to take that burden, for a price.</p>
 
 <p>Shoutcast may not be available in your Linux distribution. Not really a problem since it's available
 as a presumably statically linked binary from <a href="http://www.shoutcast.com">http://www.shoutcast.com</a>.
-It's important that you avoid version 2 because IDJC does not support it yet.
 </p>
 
 <h4>Setting up Shoutcast</h4>
 
-<p>Okay, so having downloaded the version of Shoutcast that's right for your platform and extracted it from
-the archive there should be two files called sc_serv and sc_serv.conf. The first is the server and the
-second is its configuration file. There is also a README.TXT which contains some recommended reading.</p>
-
-<p>Let's run this and see what success looks like.</p>
-
-<pre>$ ./sc_serv sc_serv.conf
-*******************************************************************************
-** SHOUTcast Distributed Network Audio Server
-** Copyright (C) 1998-2004 Nullsoft, Inc.  All Rights Reserved.
-** Use "sc_serv filename.ini" to specify an ini file.
-*******************************************************************************
-
-Event log:
-<10/05/10 at 07:09:16> [SHOUTcast] DNAS/Linux v1.9.8 (Feb 28 2007) starting up...
-<10/05/10 at 07:09:16> [main] pid: 5755
-<10/05/10 at 07:09:16> [main] loaded config from sc_serv.conf
-<10/05/10 at 07:09:16> [main] initializing (usermax:32 portbase:8000)...
-<10/05/10 at 07:09:16> [main] No ban file found (sc_serv.ban)
-<10/05/10 at 07:09:16> [main] No rip file found (sc_serv.rip)
-<10/05/10 at 07:09:16> [main] opening source socket
-<10/05/10 at 07:09:16> [main] source thread starting
-<10/05/10 at 07:09:16> [main] opening client socket
-<10/05/10 at 07:09:16> [source] listening for connection on port 8001
-<10/05/10 at 07:09:16> [main] Client Stream thread [0] starting
-<10/05/10 at 07:09:16> [main] client main thread starting</pre>
+<p>Having downloaded the version of Shoutcast that's right for your platform and extracted it from
+the archive you should locate the Shoutcast executable called sc_serv. This needs to be run with a suitable
+confirguration file. There are some examples of these in the source tree as well as a configuration builder.
+For the sake of simplicity a minimalist configuration will be used for this demonstration.
+</p>
+
+<p>Let's use a basic configuration file that we shall call sc_serv.conf which allows IDJC and listener clients to
+connect to/from localhost merely for test purposes and contains the following text:</p>
+<pre>
+logfile=logs/sc_serv.log
+w3clog=logs/sc_w3c.log
+banfile=control/sc_serv.ban
+ripfile=control/sc_serv.rip
+password=changeme
+adminpassword=protected
+</pre>
+
+<p>Let's run this with the following command.</p>
+
+<pre>$ ./sc_serv sc_serv.conf</pre>
+
+<p>Assuming you were not dumped back to a console prompt the server is now running.</p>
 
 <h4>Configuring IDJC</h4>
 
-<p>Start the Jack sound server as follows.</p>
+<p>Start the JACK sound server as follows.</p>
 <pre>$ jackd -d dummy -r 44100</pre>
-<p>This is done so that any media player, even one that does not support Jack Audio Connection Kit can be
+<p>This is done so that any media player, even one that does not support JACK Audio Connection Kit can be
 used for playing the stream on this machine.</p>
 
-<p>Run IDJC and click the Output button in the bottom left hand corner. Click Configuration so the
+<p>Run IDJC open the Output window from the View menu. Click Configuration so the
 configuration section is visible.</p>
 
 <p>Click Connection, then New.</p>
@@ -154,8 +149,7 @@ configuration section is visible.</p>
 will be the default password, which is <span style="color:red;" title="Obviously a server exposed to the Internet 
 should never be configured to use its default password">changeme</span>. Click Ok to add the server to the list.</p>
 
-<p>Click Format. Select the Sample rate drop down box and choose 44100. Select MP3 and the top drop down box.
-Choose 128, Quality 5, and Joint Stereo. </p>
+<p>Click Format. Select MPEG and click the right arrow repeatedly until all the option boxes appear.</p>
 
 <p>Click Individual Controls so the controls section is visible and click the button that says
 localhost:8000/listen.</p>
@@ -168,7 +162,7 @@ localhost:8000/listen.</p>
 playlist. Click play. Make sure the crossfader is set all the way to the left. Make sure Stream is on and DJ is off.
 You should be able to see the Str Peak meter is active.</p>
 
-<p>If you can't hear anything right now it's because DJ is off and/or you are running a dummy Jack soundcard,
+<p>If you can't hear anything right now it's because DJ is off and/or you are running a dummy JACK soundcard,
 which is what you want for the sake of this test.</p>
 
 <h4>Join the stream as a listener</h4>
diff --git a/doc/tutorials_voip.html b/doc/tutorials_voip.html
index 174a492..8e51cf6 100644
--- a/doc/tutorials_voip.html
+++ b/doc/tutorials_voip.html
@@ -145,11 +145,9 @@ however after doing so there may still be reason 2 to contend with.</p>
 <a href="http://packages.debian.org/squeeze/libasound2-plugins">binary</a>. This is intended
 as a replacement for the current <i>alsa-plugins</i> package so remove the old version first.</p>
 
-<h4>Skype configuration</h4>
-
-<p>Launch Skype and Hit <i>Ctrl + O</i>. Choose <i>Sound Devices</i> and for each of the
-<i>Sound In</i>, <i>Sound Out</i>, and <i>Ringing</i> options, select <i>idjcvoip</i> then
-click <i>Apply</i>. Leave the configuration window open for the next step.</p>
+<h4>Skype/Pulseaudio configuration</h4>
+<p>Lots of messing about ever since Skype forced the use of Pulseaudio. Official JACK documentation <a href="http://jackaudio.org/faq/pulseaudio_and_jack.html
+">here</a>. Once you have Pulseaudio ports in JACK they will require connection to the IDJC VoIP JACK ports.</p>
 
 <h4>Testing</h4>
 
diff --git a/idjc.appdata.xml.in.in b/idjc.appdata.xml.in.in
new file mode 100644
index 0000000..498f3e2
--- /dev/null
+++ b/idjc.appdata.xml.in.in
@@ -0,0 +1,25 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!-- Copyright @COPYRIGHT_YEAR@ Stephen Fairchild <s-fairchild at users.sourceforge.net> -->
+<application>
+ <id type="desktop">@PACKAGE_NAME at .desktop</id>
+ <metadata_license>CC0-1.0</metadata_license>
+ <project_license>GPL-2.0+ and GFDL-1.3</project_license>
+ <name>Internet DJ Console</name>
+ <summary>Be a DJ on the Internet</summary>
+ <description>
+  <p>
+    A powerful yet easy to use source-client for people interested in streaming
+    live radio shows over the Internet using Shoutcast or Icecast servers.      
+  </p>
+  <p>
+    Up to 9 simultaneous streams. 12 mono or 6 stereo general purpose audio inputs.
+    3 media players. An effects rack. The audio routing flexibility of Jack Audio Connection Kit.
+    IRC announcements. Ampache music database support.
+  </p>
+ </description>
+ <screenshots>
+  <screenshot type="default" width="1088" height="612">http://idjc.sourceforge.net/appdata_screenshot.png</screenshot>
+ </screenshots>
+ <url type="homepage">http://idjc.sourceforge.net</url>
+ <updatecontact>http://sourceforge.net/api/file/index/project-id/135773/mtime/desc/limit/20/rss</updatecontact>
+</application>
diff --git a/ltmain.sh b/ltmain.sh
index 63ae69d..0f0a2da 100644
--- a/ltmain.sh
+++ b/ltmain.sh
@@ -1,9 +1,12 @@
+#! /bin/sh
+## DO NOT EDIT - This file generated from ./build-aux/ltmain.in
+##               by inline-source v2014-01-03.01
 
-# libtool (GNU libtool) 2.4.2
+# libtool (GNU libtool) 2.4.6
+# Provide generalized library-building support services.
 # Written by Gordon Matzigkeit <gord at gnu.ai.mit.edu>, 1996
 
-# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, 2006,
-# 2007, 2008, 2009, 2010, 2011 Free Software Foundation, Inc.
+# Copyright (C) 1996-2015 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.
 
@@ -23,881 +26,2112 @@
 # General Public License for more details.
 #
 # You should have received a copy of the GNU General Public License
-# along with GNU Libtool; see the file COPYING.  If not, a copy
-# can be downloaded from http://www.gnu.org/licenses/gpl.html,
-# or obtained by writing to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
-# Usage: $progname [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
-#       --mode=MODE          use operation mode MODE
-#       --preserve-dup-deps  don't remove duplicate dependency libraries
-#       --quiet, --silent    don't print informational messages
-#       --no-quiet, --no-silent
-#                            print informational messages (default)
-#       --no-warn            don't display warning messages
-#       --tag=TAG            use configuration variables from tag TAG
-#   -v, --verbose            print more informational messages than default
-#       --no-verbose         don't print the extra informational messages
-#       --version            print version information
-#   -h, --help, --help-all   print short, long, or detailed help message
-#
-# 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.  When passed as first option,
-# `--mode=MODE' may be abbreviated as `MODE' or a unique abbreviation of that.
-# Try `$progname --help --mode=MODE' for a more detailed description of MODE.
-#
-# When reporting a bug, please describe a test case to reproduce it and
-# include the following information:
-#
-#         host-triplet:	$host
-#         shell:		$SHELL
-#         compiler:		$LTCC
-#         compiler flags:		$LTCFLAGS
-#         linker:		$LD (gnu? $with_gnu_ld)
-#         $progname:	(GNU libtool) 2.4.2
-#         automake:	$automake_version
-#         autoconf:	$autoconf_version
-#
-# Report bugs to <bug-libtool at gnu.org>.
-# GNU libtool home page: <http://www.gnu.org/software/libtool/>.
-# General help using GNU software: <http://www.gnu.org/gethelp/>.
 
 PROGRAM=libtool
 PACKAGE=libtool
-VERSION=2.4.2
-TIMESTAMP=""
-package_revision=1.3337
+VERSION=2.4.6
+package_revision=2.4.6
 
-# Be Bourne compatible
-if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then
+
+## ------ ##
+## Usage. ##
+## ------ ##
+
+# Run './libtool --help' for help with using this script from the
+# command line.
+
+
+## ------------------------------- ##
+## User overridable command paths. ##
+## ------------------------------- ##
+
+# After configure completes, it has a better idea of some of the
+# shell tools we need than the defaults used by the functions shared
+# with bootstrap, so set those here where they can still be over-
+# ridden by the user, but otherwise take precedence.
+
+: ${AUTOCONF="autoconf"}
+: ${AUTOMAKE="automake"}
+
+
+## -------------------------- ##
+## Source external libraries. ##
+## -------------------------- ##
+
+# Much of our low-level functionality needs to be sourced from external
+# libraries, which are installed to $pkgauxdir.
+
+# Set a version string for this script.
+scriptversion=2015-01-20.17; # UTC
+
+# General shell script boiler plate, and helper functions.
+# Written by Gary V. Vaughan, 2004
+
+# Copyright (C) 2004-2015 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.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+
+# As a special exception to the GNU General Public License, if you distribute
+# this file as part of a program or library that is built using GNU Libtool,
+# you may include this file under the same distribution terms that you use
+# for the rest of that program.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNES FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+# Please report bugs or propose patches to gary at gnu.org.
+
+
+## ------ ##
+## Usage. ##
+## ------ ##
+
+# Evaluate this file near the top of your script to gain access to
+# the functions and variables defined here:
+#
+#   . `echo "$0" | ${SED-sed} 's|[^/]*$||'`/build-aux/funclib.sh
+#
+# If you need to override any of the default environment variable
+# settings, do that before evaluating this file.
+
+
+## -------------------- ##
+## Shell normalisation. ##
+## -------------------- ##
+
+# Some shells need a little help to be as Bourne compatible as possible.
+# Before doing anything else, make sure all that help has been provided!
+
+DUALCASE=1; export DUALCASE # for MKS sh
+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
+  # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which
   # is contrary to our usage.  Disable this feature.
   alias -g '${1+"$@"}'='"$@"'
   setopt NO_GLOB_SUBST
 else
-  case `(set -o) 2>/dev/null` in *posix*) set -o posix;; esac
+  case `(set -o) 2>/dev/null` in *posix*) set -o posix ;; esac
 fi
-BIN_SH=xpg4; export BIN_SH # for Tru64
-DUALCASE=1; export DUALCASE # for MKS sh
-
-# A function that is used when there is no print builtin or printf.
-func_fallback_echo ()
-{
-  eval 'cat <<_LTECHO_EOF
-$1
-_LTECHO_EOF'
-}
 
-# NLS nuisances: We save the old values to restore during execute mode.
-lt_user_locale=
-lt_safe_locale=
-for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
+# NLS nuisances: We save the old values in case they are required later.
+_G_user_locale=
+_G_safe_locale=
+for _G_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
 do
-  eval "if test \"\${$lt_var+set}\" = set; then
-          save_$lt_var=\$$lt_var
-          $lt_var=C
-	  export $lt_var
-	  lt_user_locale=\"$lt_var=\\\$save_\$lt_var; \$lt_user_locale\"
-	  lt_safe_locale=\"$lt_var=C; \$lt_safe_locale\"
+  eval "if test set = \"\${$_G_var+set}\"; then
+          save_$_G_var=\$$_G_var
+          $_G_var=C
+	  export $_G_var
+	  _G_user_locale=\"$_G_var=\\\$save_\$_G_var; \$_G_user_locale\"
+	  _G_safe_locale=\"$_G_var=C; \$_G_safe_locale\"
 	fi"
 done
-LC_ALL=C
-LANGUAGE=C
-export LANGUAGE LC_ALL
 
-$lt_unset CDPATH
+# CDPATH.
+(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
 
+# Make sure IFS has a sensible default
+sp=' '
+nl='
+'
+IFS="$sp	$nl"
+
+# There are apparently some retarded systems that use ';' as a PATH separator!
+if test "${PATH_SEPARATOR+set}" != set; then
+  PATH_SEPARATOR=:
+  (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && {
+    (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 ||
+      PATH_SEPARATOR=';'
+  }
+fi
 
-# 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"
 
 
+## ------------------------- ##
+## Locate command utilities. ##
+## ------------------------- ##
+
+
+# func_executable_p FILE
+# ----------------------
+# Check that FILE is an executable regular file.
+func_executable_p ()
+{
+    test -f "$1" && test -x "$1"
+}
+
+
+# func_path_progs PROGS_LIST CHECK_FUNC [PATH]
+# --------------------------------------------
+# Search for either a program that responds to --version with output
+# containing "GNU", or else returned by CHECK_FUNC otherwise, by
+# trying all the directories in PATH with each of the elements of
+# PROGS_LIST.
+#
+# CHECK_FUNC should accept the path to a candidate program, and
+# set $func_check_prog_result if it truncates its output less than
+# $_G_path_prog_max characters.
+func_path_progs ()
+{
+    _G_progs_list=$1
+    _G_check_func=$2
+    _G_PATH=${3-"$PATH"}
+
+    _G_path_prog_max=0
+    _G_path_prog_found=false
+    _G_save_IFS=$IFS; IFS=${PATH_SEPARATOR-:}
+    for _G_dir in $_G_PATH; do
+      IFS=$_G_save_IFS
+      test -z "$_G_dir" && _G_dir=.
+      for _G_prog_name in $_G_progs_list; do
+        for _exeext in '' .EXE; do
+          _G_path_prog=$_G_dir/$_G_prog_name$_exeext
+          func_executable_p "$_G_path_prog" || continue
+          case `"$_G_path_prog" --version 2>&1` in
+            *GNU*) func_path_progs_result=$_G_path_prog _G_path_prog_found=: ;;
+            *)     $_G_check_func $_G_path_prog
+		   func_path_progs_result=$func_check_prog_result
+		   ;;
+          esac
+          $_G_path_prog_found && break 3
+        done
+      done
+    done
+    IFS=$_G_save_IFS
+    test -z "$func_path_progs_result" && {
+      echo "no acceptable sed could be found in \$PATH" >&2
+      exit 1
+    }
+}
+
+
+# We want to be able to use the functions in this file before configure
+# has figured out where the best binaries are kept, which means we have
+# to search for them ourselves - except when the results are already set
+# where we skip the searches.
+
+# Unless the user overrides by setting SED, search the path for either GNU
+# sed, or the sed that truncates its output the least.
+test -z "$SED" && {
+  _G_sed_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/
+  for _G_i in 1 2 3 4 5 6 7; do
+    _G_sed_script=$_G_sed_script$nl$_G_sed_script
+  done
+  echo "$_G_sed_script" 2>/dev/null | sed 99q >conftest.sed
+  _G_sed_script=
+
+  func_check_prog_sed ()
+  {
+    _G_path_prog=$1
+
+    _G_count=0
+    printf 0123456789 >conftest.in
+    while :
+    do
+      cat conftest.in conftest.in >conftest.tmp
+      mv conftest.tmp conftest.in
+      cp conftest.in conftest.nl
+      echo '' >> conftest.nl
+      "$_G_path_prog" -f conftest.sed <conftest.nl >conftest.out 2>/dev/null || break
+      diff conftest.out conftest.nl >/dev/null 2>&1 || break
+      _G_count=`expr $_G_count + 1`
+      if test "$_G_count" -gt "$_G_path_prog_max"; then
+        # Best one so far, save it but keep looking for a better one
+        func_check_prog_result=$_G_path_prog
+        _G_path_prog_max=$_G_count
+      fi
+      # 10*(2^10) chars as input seems more than enough
+      test 10 -lt "$_G_count" && break
+    done
+    rm -f conftest.in conftest.tmp conftest.nl conftest.out
+  }
+
+  func_path_progs "sed gsed" func_check_prog_sed $PATH:/usr/xpg4/bin
+  rm -f conftest.sed
+  SED=$func_path_progs_result
+}
+
+
+# Unless the user overrides by setting GREP, search the path for either GNU
+# grep, or the grep that truncates its output the least.
+test -z "$GREP" && {
+  func_check_prog_grep ()
+  {
+    _G_path_prog=$1
+
+    _G_count=0
+    _G_path_prog_max=0
+    printf 0123456789 >conftest.in
+    while :
+    do
+      cat conftest.in conftest.in >conftest.tmp
+      mv conftest.tmp conftest.in
+      cp conftest.in conftest.nl
+      echo 'GREP' >> conftest.nl
+      "$_G_path_prog" -e 'GREP$' -e '-(cannot match)-' <conftest.nl >conftest.out 2>/dev/null || break
+      diff conftest.out conftest.nl >/dev/null 2>&1 || break
+      _G_count=`expr $_G_count + 1`
+      if test "$_G_count" -gt "$_G_path_prog_max"; then
+        # Best one so far, save it but keep looking for a better one
+        func_check_prog_result=$_G_path_prog
+        _G_path_prog_max=$_G_count
+      fi
+      # 10*(2^10) chars as input seems more than enough
+      test 10 -lt "$_G_count" && break
+    done
+    rm -f conftest.in conftest.tmp conftest.nl conftest.out
+  }
+
+  func_path_progs "grep ggrep" func_check_prog_grep $PATH:/usr/xpg4/bin
+  GREP=$func_path_progs_result
+}
+
+
+## ------------------------------- ##
+## User overridable command paths. ##
+## ------------------------------- ##
+
+# All uppercase variable names are used for environment variables.  These
+# variables can be overridden by the user before calling a script that
+# uses them if a suitable command of that name is not already available
+# in the command search PATH.
 
 : ${CP="cp -f"}
-test "${ECHO+set}" = set || ECHO=${as_echo-'printf %s\n'}
+: ${ECHO="printf %s\n"}
+: ${EGREP="$GREP -E"}
+: ${FGREP="$GREP -F"}
+: ${LN_S="ln -s"}
 : ${MAKE="make"}
 : ${MKDIR="mkdir"}
 : ${MV="mv -f"}
 : ${RM="rm -f"}
 : ${SHELL="${CONFIG_SHELL-/bin/sh}"}
-: ${Xsed="$SED -e 1s/^X//"}
-
-# Global variables:
-EXIT_SUCCESS=0
-EXIT_FAILURE=1
-EXIT_MISMATCH=63  # $? = 63 is used to indicate version mismatch to missing.
-EXIT_SKIP=77	  # $? = 77 is used to indicate a skipped test to automake.
-
-exit_status=$EXIT_SUCCESS
-
-# Make sure IFS has a sensible default
-lt_nl='
-'
-IFS=" 	$lt_nl"
 
-dirname="s,/[^/]*$,,"
-basename="s,^.*/,,"
 
-# func_dirname file append nondir_replacement
-# Compute the dirname of FILE.  If nonempty, add APPEND to the result,
-# otherwise set result to NONDIR_REPLACEMENT.
-func_dirname ()
-{
-    func_dirname_result=`$ECHO "${1}" | $SED "$dirname"`
-    if test "X$func_dirname_result" = "X${1}"; then
-      func_dirname_result="${3}"
-    else
-      func_dirname_result="$func_dirname_result${2}"
-    fi
-} # func_dirname may be replaced by extended shell implementation
+## -------------------- ##
+## Useful sed snippets. ##
+## -------------------- ##
 
+sed_dirname='s|/[^/]*$||'
+sed_basename='s|^.*/||'
 
-# func_basename file
-func_basename ()
-{
-    func_basename_result=`$ECHO "${1}" | $SED "$basename"`
-} # func_basename may be replaced by extended shell implementation
+# Sed substitution that helps us do robust quoting.  It backslashifies
+# metacharacters that are still active within double-quoted strings.
+sed_quote_subst='s|\([`"$\\]\)|\\\1|g'
 
+# Same as above, but do not quote variable references.
+sed_double_quote_subst='s/\(["`\\]\)/\\\1/g'
 
-# func_dirname_and_basename file append nondir_replacement
-# perform func_basename and func_dirname in a single function
-# call:
-#   dirname:  Compute the dirname of FILE.  If nonempty,
-#             add APPEND to the result, otherwise set result
-#             to NONDIR_REPLACEMENT.
-#             value returned in "$func_dirname_result"
-#   basename: Compute filename of FILE.
-#             value retuned in "$func_basename_result"
-# Implementation must be kept synchronized with func_dirname
-# and func_basename. For efficiency, we do not delegate to
-# those functions but instead duplicate the functionality here.
-func_dirname_and_basename ()
-{
-    # Extract subdirectory from the argument.
-    func_dirname_result=`$ECHO "${1}" | $SED -e "$dirname"`
-    if test "X$func_dirname_result" = "X${1}"; then
-      func_dirname_result="${3}"
-    else
-      func_dirname_result="$func_dirname_result${2}"
-    fi
-    func_basename_result=`$ECHO "${1}" | $SED -e "$basename"`
-} # func_dirname_and_basename may be replaced by extended shell implementation
+# Sed substitution that turns a string into a regex matching for the
+# string literally.
+sed_make_literal_regex='s|[].[^$\\*\/]|\\&|g'
 
+# Sed substitution that converts a w32 file name or path
+# that contains forward slashes, into one that contains
+# (escaped) backslashes.  A very naive implementation.
+sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
+
+# Re-'\' parameter expansions in output of sed_double_quote_subst that
+# were '\'-ed in input to the same.  If an odd number of '\' preceded a
+# '$' in input to sed_double_quote_subst, that '$' was protected from
+# expansion.  Since each input '\' is now two '\'s, look for any number
+# of runs of four '\'s followed by two '\'s and then a '$'.  '\' that '$'.
+_G_bs='\\'
+_G_bs2='\\\\'
+_G_bs4='\\\\\\\\'
+_G_dollar='\$'
+sed_double_backslash="\
+  s/$_G_bs4/&\\
+/g
+  s/^$_G_bs2$_G_dollar/$_G_bs&/
+  s/\\([^$_G_bs]\\)$_G_bs2$_G_dollar/\\1$_G_bs2$_G_bs$_G_dollar/g
+  s/\n//g"
 
-# func_stripname prefix suffix name
-# strip PREFIX and SUFFIX off of NAME.
-# PREFIX and SUFFIX must not contain globbing or regex special
-# characters, hashes, percent signs, but SUFFIX may contain a leading
-# dot (in which case that matches only a dot).
-# func_strip_suffix prefix name
-func_stripname ()
-{
-    case ${2} in
-      .*) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%\\\\${2}\$%%"`;;
-      *)  func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%${2}\$%%"`;;
-    esac
-} # func_stripname may be replaced by extended shell implementation
 
+## ----------------- ##
+## Global variables. ##
+## ----------------- ##
 
-# These SED scripts presuppose an absolute path with a trailing slash.
-pathcar='s,^/\([^/]*\).*$,\1,'
-pathcdr='s,^/[^/]*,,'
-removedotparts=':dotsl
-		s@/\./@/@g
-		t dotsl
-		s,/\.$,/,'
-collapseslashes='s@/\{1,\}@/@g'
-finalslash='s,/*$,/,'
+# Except for the global variables explicitly listed below, the following
+# functions in the '^func_' namespace, and the '^require_' namespace
+# variables initialised in the 'Resource management' section, sourcing
+# this file will not pollute your global namespace with anything
+# else. There's no portable way to scope variables in Bourne shell
+# though, so actually running these functions will sometimes place
+# results into a variable named after the function, and often use
+# temporary variables in the '^_G_' namespace. If you are careful to
+# avoid using those namespaces casually in your sourcing script, things
+# should continue to work as you expect. And, of course, you can freely
+# overwrite any of the functions or variables defined here before
+# calling anything to customize them.
 
-# func_normal_abspath PATH
-# Remove doubled-up and trailing slashes, "." path components,
-# and cancel out any ".." path components in PATH after making
-# it an absolute path.
-#             value returned in "$func_normal_abspath_result"
-func_normal_abspath ()
-{
-  # Start from root dir and reassemble the path.
-  func_normal_abspath_result=
-  func_normal_abspath_tpath=$1
-  func_normal_abspath_altnamespace=
-  case $func_normal_abspath_tpath in
-    "")
-      # Empty path, that just means $cwd.
-      func_stripname '' '/' "`pwd`"
-      func_normal_abspath_result=$func_stripname_result
-      return
-    ;;
-    # The next three entries are used to spot a run of precisely
-    # two leading slashes without using negated character classes;
-    # we take advantage of case's first-match behaviour.
-    ///*)
-      # Unusual form of absolute path, do nothing.
-    ;;
-    //*)
-      # Not necessarily an ordinary path; POSIX reserves leading '//'
-      # and for example Cygwin uses it to access remote file shares
-      # over CIFS/SMB, so we conserve a leading double slash if found.
-      func_normal_abspath_altnamespace=/
-    ;;
-    /*)
-      # Absolute path, do nothing.
-    ;;
-    *)
-      # Relative path, prepend $cwd.
-      func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath
-    ;;
-  esac
-  # Cancel out all the simple stuff to save iterations.  We also want
-  # the path to end with a slash for ease of parsing, so make sure
-  # there is one (and only one) here.
-  func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
-        -e "$removedotparts" -e "$collapseslashes" -e "$finalslash"`
-  while :; do
-    # Processed it all yet?
-    if test "$func_normal_abspath_tpath" = / ; then
-      # If we ascended to the root using ".." the result may be empty now.
-      if test -z "$func_normal_abspath_result" ; then
-        func_normal_abspath_result=/
-      fi
-      break
-    fi
-    func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \
-        -e "$pathcar"`
-    func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
-        -e "$pathcdr"`
-    # Figure out what to do with it
-    case $func_normal_abspath_tcomponent in
-      "")
-        # Trailing empty path component, ignore it.
-      ;;
-      ..)
-        # Parent dir; strip last assembled component from result.
-        func_dirname "$func_normal_abspath_result"
-        func_normal_abspath_result=$func_dirname_result
-      ;;
-      *)
-        # Actual path component, append it.
-        func_normal_abspath_result=$func_normal_abspath_result/$func_normal_abspath_tcomponent
-      ;;
-    esac
-  done
-  # Restore leading double-slash if one was found on entry.
-  func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result
-}
+EXIT_SUCCESS=0
+EXIT_FAILURE=1
+EXIT_MISMATCH=63  # $? = 63 is used to indicate version mismatch to missing.
+EXIT_SKIP=77	  # $? = 77 is used to indicate a skipped test to automake.
 
-# func_relative_path SRCDIR DSTDIR
-# generates a relative path from SRCDIR to DSTDIR, with a trailing
-# slash if non-empty, suitable for immediately appending a filename
-# without needing to append a separator.
-#             value returned in "$func_relative_path_result"
-func_relative_path ()
-{
-  func_relative_path_result=
-  func_normal_abspath "$1"
-  func_relative_path_tlibdir=$func_normal_abspath_result
-  func_normal_abspath "$2"
-  func_relative_path_tbindir=$func_normal_abspath_result
-
-  # Ascend the tree starting from libdir
-  while :; do
-    # check if we have found a prefix of bindir
-    case $func_relative_path_tbindir in
-      $func_relative_path_tlibdir)
-        # found an exact match
-        func_relative_path_tcancelled=
-        break
-        ;;
-      $func_relative_path_tlibdir*)
-        # found a matching prefix
-        func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir"
-        func_relative_path_tcancelled=$func_stripname_result
-        if test -z "$func_relative_path_result"; then
-          func_relative_path_result=.
-        fi
-        break
-        ;;
-      *)
-        func_dirname $func_relative_path_tlibdir
-        func_relative_path_tlibdir=${func_dirname_result}
-        if test "x$func_relative_path_tlibdir" = x ; then
-          # Have to descend all the way to the root!
-          func_relative_path_result=../$func_relative_path_result
-          func_relative_path_tcancelled=$func_relative_path_tbindir
-          break
-        fi
-        func_relative_path_result=../$func_relative_path_result
-        ;;
-    esac
-  done
+# Allow overriding, eg assuming that you follow the convention of
+# putting '$debug_cmd' at the start of all your functions, you can get
+# bash to show function call trace with:
+#
+#    debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
+debug_cmd=${debug_cmd-":"}
+exit_cmd=:
 
-  # Now calculate path; take care to avoid doubling-up slashes.
-  func_stripname '' '/' "$func_relative_path_result"
-  func_relative_path_result=$func_stripname_result
-  func_stripname '/' '/' "$func_relative_path_tcancelled"
-  if test "x$func_stripname_result" != x ; then
-    func_relative_path_result=${func_relative_path_result}/${func_stripname_result}
-  fi
+# By convention, finish your script with:
+#
+#    exit $exit_status
+#
+# so that you can set exit_status to non-zero if you want to indicate
+# something went wrong during execution without actually bailing out at
+# the point of failure.
+exit_status=$EXIT_SUCCESS
 
-  # Normalisation. If bindir is libdir, return empty string,
-  # else relative path ending with a slash; either way, target
-  # file name can be directly appended.
-  if test ! -z "$func_relative_path_result"; then
-    func_stripname './' '' "$func_relative_path_result/"
-    func_relative_path_result=$func_stripname_result
-  fi
-}
+# 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:
-func_dirname_and_basename "$progpath"
-progname=$func_basename_result
+# The name of this program.
+progname=`$ECHO "$progpath" |$SED "$sed_basename"`
 
-# Make sure we have an absolute path for reexecution:
+# Make sure we have an absolute progpath for reexecution:
 case $progpath in
   [\\/]*|[A-Za-z]:\\*) ;;
   *[\\/]*)
-     progdir=$func_dirname_result
+     progdir=`$ECHO "$progpath" |$SED "$sed_dirname"`
      progdir=`cd "$progdir" && pwd`
-     progpath="$progdir/$progname"
+     progpath=$progdir/$progname
      ;;
   *)
-     save_IFS="$IFS"
+     _G_IFS=$IFS
      IFS=${PATH_SEPARATOR-:}
      for progdir in $PATH; do
-       IFS="$save_IFS"
+       IFS=$_G_IFS
        test -x "$progdir/$progname" && break
      done
-     IFS="$save_IFS"
+     IFS=$_G_IFS
      test -n "$progdir" || progdir=`pwd`
-     progpath="$progdir/$progname"
+     progpath=$progdir/$progname
      ;;
 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 that turns a string into a regex matching for the
-# string literally.
-sed_make_literal_regex='s,[].[^$\\*\/],\\&,g'
+## ----------------- ##
+## Standard options. ##
+## ----------------- ##
 
-# Sed substitution that converts a w32 file name or path
-# which contains forward slashes, into one that contains
-# (escaped) backslashes.  A very naive implementation.
-lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
-
-# Re-`\' parameter expansions in output of double_quote_subst that were
-# `\'-ed in input to the same.  If an odd number of `\' preceded a '$'
-# in input to double_quote_subst, that '$' was protected from expansion.
-# Since each input `\' is now two `\'s, look for any number of runs of
-# four `\'s followed by two `\'s and then a '$'.  `\' that '$'.
-bs='\\'
-bs2='\\\\'
-bs4='\\\\\\\\'
-dollar='\$'
-sed_double_backslash="\
-  s/$bs4/&\\
-/g
-  s/^$bs2$dollar/$bs&/
-  s/\\([^$bs]\\)$bs2$dollar/\\1$bs2$bs$dollar/g
-  s/\n//g"
+# The following options affect the operation of the functions defined
+# below, and should be set appropriately depending on run-time para-
+# meters passed on the command line.
 
-# Standard options:
 opt_dry_run=false
-opt_help=false
 opt_quiet=false
 opt_verbose=false
-opt_warning=:
 
-# func_echo arg...
-# Echo program name prefixed message, along with the current mode
-# name if it has been set yet.
-func_echo ()
-{
-    $ECHO "$progname: ${opt_mode+$opt_mode: }$*"
-}
+# Categories 'all' and 'none' are always available.  Append any others
+# you will pass as the first argument to func_warning from your own
+# code.
+warning_categories=
 
-# func_verbose arg...
-# Echo program name prefixed message in verbose mode only.
-func_verbose ()
-{
-    $opt_verbose && func_echo ${1+"$@"}
+# By default, display warnings according to 'opt_warning_types'.  Set
+# 'warning_func'  to ':' to elide all warnings, or func_fatal_error to
+# treat the next displayed warning as a fatal error.
+warning_func=func_warn_and_continue
 
-    # A bug in bash halts the script if the last line of a function
-    # fails when set -e is in force, so we need another command to
-    # work around that:
-    :
-}
+# Set to 'all' to display all warnings, 'none' to suppress all
+# warnings, or a space delimited list of some subset of
+# 'warning_categories' to display only the listed warnings.
+opt_warning_types=all
 
-# func_echo_all arg...
-# Invoke $ECHO with all args, space-separated.
-func_echo_all ()
-{
-    $ECHO "$*"
-}
 
-# func_error arg...
-# Echo program name prefixed message to standard error.
-func_error ()
-{
-    $ECHO "$progname: ${opt_mode+$opt_mode: }"${1+"$@"} 1>&2
-}
+## -------------------- ##
+## Resource management. ##
+## -------------------- ##
 
-# func_warning arg...
-# Echo program name prefixed warning message to standard error.
-func_warning ()
-{
-    $opt_warning && $ECHO "$progname: ${opt_mode+$opt_mode: }warning: "${1+"$@"} 1>&2
+# This section contains definitions for functions that each ensure a
+# particular resource (a file, or a non-empty configuration variable for
+# example) is available, and if appropriate to extract default values
+# from pertinent package files. Call them using their associated
+# 'require_*' variable to ensure that they are executed, at most, once.
+#
+# It's entirely deliberate that calling these functions can set
+# variables that don't obey the namespace limitations obeyed by the rest
+# of this file, in order that that they be as useful as possible to
+# callers.
 
-    # bash bug again:
-    :
-}
 
-# func_fatal_error arg...
-# Echo program name prefixed message to standard error, and exit.
-func_fatal_error ()
+# require_term_colors
+# -------------------
+# Allow display of bold text on terminals that support it.
+require_term_colors=func_require_term_colors
+func_require_term_colors ()
 {
-    func_error ${1+"$@"}
-    exit $EXIT_FAILURE
-}
+    $debug_cmd
+
+    test -t 1 && {
+      # COLORTERM and USE_ANSI_COLORS environment variables take
+      # precedence, because most terminfo databases neglect to describe
+      # whether color sequences are supported.
+      test -n "${COLORTERM+set}" && : ${USE_ANSI_COLORS="1"}
+
+      if test 1 = "$USE_ANSI_COLORS"; then
+        # Standard ANSI escape sequences
+        tc_reset=''
+        tc_bold='';   tc_standout=''
+        tc_red='';   tc_green=''
+        tc_blue='';  tc_cyan=''
+      else
+        # Otherwise trust the terminfo database after all.
+        test -n "`tput sgr0 2>/dev/null`" && {
+          tc_reset=`tput sgr0`
+          test -n "`tput bold 2>/dev/null`" && tc_bold=`tput bold`
+          tc_standout=$tc_bold
+          test -n "`tput smso 2>/dev/null`" && tc_standout=`tput smso`
+          test -n "`tput setaf 1 2>/dev/null`" && tc_red=`tput setaf 1`
+          test -n "`tput setaf 2 2>/dev/null`" && tc_green=`tput setaf 2`
+          test -n "`tput setaf 4 2>/dev/null`" && tc_blue=`tput setaf 4`
+          test -n "`tput setaf 5 2>/dev/null`" && tc_cyan=`tput setaf 5`
+        }
+      fi
+    }
 
-# func_fatal_help arg...
-# Echo program name prefixed message to standard error, followed by
-# a help hint, and exit.
-func_fatal_help ()
-{
-    func_error ${1+"$@"}
-    func_fatal_error "$help"
+    require_term_colors=:
 }
-help="Try \`$progname --help' for more information."  ## default
 
 
-# func_grep expression filename
+## ----------------- ##
+## Function library. ##
+## ----------------- ##
+
+# This section contains a variety of useful functions to call in your
+# scripts. Take note of the portable wrappers for features provided by
+# some modern shells, which will fall back to slower equivalents on
+# less featureful shells.
+
+
+# func_append VAR VALUE
+# ---------------------
+# Append VALUE onto the existing contents of VAR.
+
+  # We should try to minimise forks, especially on Windows where they are
+  # unreasonably slow, so skip the feature probes when bash or zsh are
+  # being used:
+  if test set = "${BASH_VERSION+set}${ZSH_VERSION+set}"; then
+    : ${_G_HAVE_ARITH_OP="yes"}
+    : ${_G_HAVE_XSI_OPS="yes"}
+    # The += operator was introduced in bash 3.1
+    case $BASH_VERSION in
+      [12].* | 3.0 | 3.0*) ;;
+      *)
+        : ${_G_HAVE_PLUSEQ_OP="yes"}
+        ;;
+    esac
+  fi
+
+  # _G_HAVE_PLUSEQ_OP
+  # Can be empty, in which case the shell is probed, "yes" if += is
+  # useable or anything else if it does not work.
+  test -z "$_G_HAVE_PLUSEQ_OP" \
+    && (eval 'x=a; x+=" b"; test "a b" = "$x"') 2>/dev/null \
+    && _G_HAVE_PLUSEQ_OP=yes
+
+if test yes = "$_G_HAVE_PLUSEQ_OP"
+then
+  # This is an XSI compatible shell, allowing a faster implementation...
+  eval 'func_append ()
+  {
+    $debug_cmd
+
+    eval "$1+=\$2"
+  }'
+else
+  # ...otherwise fall back to using expr, which is often a shell builtin.
+  func_append ()
+  {
+    $debug_cmd
+
+    eval "$1=\$$1\$2"
+  }
+fi
+
+
+# func_append_quoted VAR VALUE
+# ----------------------------
+# Quote VALUE and append to the end of shell variable VAR, separated
+# by a space.
+if test yes = "$_G_HAVE_PLUSEQ_OP"; then
+  eval 'func_append_quoted ()
+  {
+    $debug_cmd
+
+    func_quote_for_eval "$2"
+    eval "$1+=\\ \$func_quote_for_eval_result"
+  }'
+else
+  func_append_quoted ()
+  {
+    $debug_cmd
+
+    func_quote_for_eval "$2"
+    eval "$1=\$$1\\ \$func_quote_for_eval_result"
+  }
+fi
+
+
+# func_append_uniq VAR VALUE
+# --------------------------
+# Append unique VALUE onto the existing contents of VAR, assuming
+# entries are delimited by the first character of VALUE.  For example:
+#
+#   func_append_uniq options " --another-option option-argument"
+#
+# will only append to $options if " --another-option option-argument "
+# is not already present somewhere in $options already (note spaces at
+# each end implied by leading space in second argument).
+func_append_uniq ()
+{
+    $debug_cmd
+
+    eval _G_current_value='`$ECHO $'$1'`'
+    _G_delim=`expr "$2" : '\(.\)'`
+
+    case $_G_delim$_G_current_value$_G_delim in
+      *"$2$_G_delim"*) ;;
+      *) func_append "$@" ;;
+    esac
+}
+
+
+# func_arith TERM...
+# ------------------
+# Set func_arith_result to the result of evaluating TERMs.
+  test -z "$_G_HAVE_ARITH_OP" \
+    && (eval 'test 2 = $(( 1 + 1 ))') 2>/dev/null \
+    && _G_HAVE_ARITH_OP=yes
+
+if test yes = "$_G_HAVE_ARITH_OP"; then
+  eval 'func_arith ()
+  {
+    $debug_cmd
+
+    func_arith_result=$(( $* ))
+  }'
+else
+  func_arith ()
+  {
+    $debug_cmd
+
+    func_arith_result=`expr "$@"`
+  }
+fi
+
+
+# func_basename FILE
+# ------------------
+# Set func_basename_result to FILE with everything up to and including
+# the last / stripped.
+if test yes = "$_G_HAVE_XSI_OPS"; then
+  # If this shell supports suffix pattern removal, then use it to avoid
+  # forking. Hide the definitions single quotes in case the shell chokes
+  # on unsupported syntax...
+  _b='func_basename_result=${1##*/}'
+  _d='case $1 in
+        */*) func_dirname_result=${1%/*}$2 ;;
+        *  ) func_dirname_result=$3        ;;
+      esac'
+
+else
+  # ...otherwise fall back to using sed.
+  _b='func_basename_result=`$ECHO "$1" |$SED "$sed_basename"`'
+  _d='func_dirname_result=`$ECHO "$1"  |$SED "$sed_dirname"`
+      if test "X$func_dirname_result" = "X$1"; then
+        func_dirname_result=$3
+      else
+        func_append func_dirname_result "$2"
+      fi'
+fi
+
+eval 'func_basename ()
+{
+    $debug_cmd
+
+    '"$_b"'
+}'
+
+
+# func_dirname FILE APPEND NONDIR_REPLACEMENT
+# -------------------------------------------
+# Compute the dirname of FILE.  If nonempty, add APPEND to the result,
+# otherwise set result to NONDIR_REPLACEMENT.
+eval 'func_dirname ()
+{
+    $debug_cmd
+
+    '"$_d"'
+}'
+
+
+# func_dirname_and_basename FILE APPEND NONDIR_REPLACEMENT
+# --------------------------------------------------------
+# Perform func_basename and func_dirname in a single function
+# call:
+#   dirname:  Compute the dirname of FILE.  If nonempty,
+#             add APPEND to the result, otherwise set result
+#             to NONDIR_REPLACEMENT.
+#             value returned in "$func_dirname_result"
+#   basename: Compute filename of FILE.
+#             value retuned in "$func_basename_result"
+# For efficiency, we do not delegate to the functions above but instead
+# duplicate the functionality here.
+eval 'func_dirname_and_basename ()
+{
+    $debug_cmd
+
+    '"$_b"'
+    '"$_d"'
+}'
+
+
+# func_echo ARG...
+# ----------------
+# Echo program name prefixed message.
+func_echo ()
+{
+    $debug_cmd
+
+    _G_message=$*
+
+    func_echo_IFS=$IFS
+    IFS=$nl
+    for _G_line in $_G_message; do
+      IFS=$func_echo_IFS
+      $ECHO "$progname: $_G_line"
+    done
+    IFS=$func_echo_IFS
+}
+
+
+# func_echo_all ARG...
+# --------------------
+# Invoke $ECHO with all args, space-separated.
+func_echo_all ()
+{
+    $ECHO "$*"
+}
+
+
+# func_echo_infix_1 INFIX ARG...
+# ------------------------------
+# Echo program name, followed by INFIX on the first line, with any
+# additional lines not showing INFIX.
+func_echo_infix_1 ()
+{
+    $debug_cmd
+
+    $require_term_colors
+
+    _G_infix=$1; shift
+    _G_indent=$_G_infix
+    _G_prefix="$progname: $_G_infix: "
+    _G_message=$*
+
+    # Strip color escape sequences before counting printable length
+    for _G_tc in "$tc_reset" "$tc_bold" "$tc_standout" "$tc_red" "$tc_green" "$tc_blue" "$tc_cyan"
+    do
+      test -n "$_G_tc" && {
+        _G_esc_tc=`$ECHO "$_G_tc" | $SED "$sed_make_literal_regex"`
+        _G_indent=`$ECHO "$_G_indent" | $SED "s|$_G_esc_tc||g"`
+      }
+    done
+    _G_indent="$progname: "`echo "$_G_indent" | $SED 's|.| |g'`"  " ## exclude from sc_prohibit_nested_quotes
+
+    func_echo_infix_1_IFS=$IFS
+    IFS=$nl
+    for _G_line in $_G_message; do
+      IFS=$func_echo_infix_1_IFS
+      $ECHO "$_G_prefix$tc_bold$_G_line$tc_reset" >&2
+      _G_prefix=$_G_indent
+    done
+    IFS=$func_echo_infix_1_IFS
+}
+
+
+# func_error ARG...
+# -----------------
+# Echo program name prefixed message to standard error.
+func_error ()
+{
+    $debug_cmd
+
+    $require_term_colors
+
+    func_echo_infix_1 "  $tc_standout${tc_red}error$tc_reset" "$*" >&2
+}
+
+
+# func_fatal_error ARG...
+# -----------------------
+# Echo program name prefixed message to standard error, and exit.
+func_fatal_error ()
+{
+    $debug_cmd
+
+    func_error "$*"
+    exit $EXIT_FAILURE
+}
+
+
+# func_grep EXPRESSION FILENAME
+# -----------------------------
 # Check whether EXPRESSION matches any line of FILENAME, without output.
 func_grep ()
 {
+    $debug_cmd
+
     $GREP "$1" "$2" >/dev/null 2>&1
 }
 
 
-# func_mkdir_p directory-path
+# func_len STRING
+# ---------------
+# Set func_len_result to the length of STRING. STRING may not
+# start with a hyphen.
+  test -z "$_G_HAVE_XSI_OPS" \
+    && (eval 'x=a/b/c;
+      test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \
+    && _G_HAVE_XSI_OPS=yes
+
+if test yes = "$_G_HAVE_XSI_OPS"; then
+  eval 'func_len ()
+  {
+    $debug_cmd
+
+    func_len_result=${#1}
+  }'
+else
+  func_len ()
+  {
+    $debug_cmd
+
+    func_len_result=`expr "$1" : ".*" 2>/dev/null || echo $max_cmd_len`
+  }
+fi
+
+
+# func_mkdir_p DIRECTORY-PATH
+# ---------------------------
 # Make sure the entire path to DIRECTORY-PATH is available.
 func_mkdir_p ()
 {
-    my_directory_path="$1"
-    my_dir_list=
+    $debug_cmd
 
-    if test -n "$my_directory_path" && test "$opt_dry_run" != ":"; then
+    _G_directory_path=$1
+    _G_dir_list=
 
-      # Protect directory names starting with `-'
-      case $my_directory_path in
-        -*) my_directory_path="./$my_directory_path" ;;
+    if test -n "$_G_directory_path" && test : != "$opt_dry_run"; then
+
+      # Protect directory names starting with '-'
+      case $_G_directory_path in
+        -*) _G_directory_path=./$_G_directory_path ;;
       esac
 
       # While some portion of DIR does not yet exist...
-      while test ! -d "$my_directory_path"; do
+      while test ! -d "$_G_directory_path"; do
         # ...make a list in topmost first order.  Use a colon delimited
 	# list incase some portion of path contains whitespace.
-        my_dir_list="$my_directory_path:$my_dir_list"
+        _G_dir_list=$_G_directory_path:$_G_dir_list
 
         # If the last portion added has no slash in it, the list is done
-        case $my_directory_path in */*) ;; *) break ;; esac
+        case $_G_directory_path in */*) ;; *) break ;; esac
 
         # ...otherwise throw away the child directory and loop
-        my_directory_path=`$ECHO "$my_directory_path" | $SED -e "$dirname"`
+        _G_directory_path=`$ECHO "$_G_directory_path" | $SED -e "$sed_dirname"`
       done
-      my_dir_list=`$ECHO "$my_dir_list" | $SED 's,:*$,,'`
+      _G_dir_list=`$ECHO "$_G_dir_list" | $SED 's|:*$||'`
 
-      save_mkdir_p_IFS="$IFS"; IFS=':'
-      for my_dir in $my_dir_list; do
-	IFS="$save_mkdir_p_IFS"
-        # mkdir can fail with a `File exist' error if two processes
+      func_mkdir_p_IFS=$IFS; IFS=:
+      for _G_dir in $_G_dir_list; do
+	IFS=$func_mkdir_p_IFS
+        # mkdir can fail with a 'File exist' error if two processes
         # try to create one of the directories concurrently.  Don't
         # stop in that case!
-        $MKDIR "$my_dir" 2>/dev/null || :
+        $MKDIR "$_G_dir" 2>/dev/null || :
       done
-      IFS="$save_mkdir_p_IFS"
+      IFS=$func_mkdir_p_IFS
 
       # Bail out if we (or some other process) failed to create a directory.
-      test -d "$my_directory_path" || \
-        func_fatal_error "Failed to create \`$1'"
+      test -d "$_G_directory_path" || \
+        func_fatal_error "Failed to create '$1'"
     fi
 }
 
 
-# func_mktempdir [string]
+# func_mktempdir [BASENAME]
+# -------------------------
 # Make a temporary directory that won't clash with other running
 # libtool processes, and avoids race conditions if possible.  If
-# given, STRING is the basename for that directory.
+# given, BASENAME is the basename for that directory.
 func_mktempdir ()
 {
-    my_template="${TMPDIR-/tmp}/${1-$progname}"
+    $debug_cmd
+
+    _G_template=${TMPDIR-/tmp}/${1-$progname}
 
-    if test "$opt_dry_run" = ":"; then
+    if test : = "$opt_dry_run"; then
       # Return a directory name, but don't create it in dry-run mode
-      my_tmpdir="${my_template}-$$"
+      _G_tmpdir=$_G_template-$$
     else
 
       # If mktemp works, use that first and foremost
-      my_tmpdir=`mktemp -d "${my_template}-XXXXXXXX" 2>/dev/null`
+      _G_tmpdir=`mktemp -d "$_G_template-XXXXXXXX" 2>/dev/null`
 
-      if test ! -d "$my_tmpdir"; then
+      if test ! -d "$_G_tmpdir"; then
         # Failing that, at least try and use $RANDOM to avoid a race
-        my_tmpdir="${my_template}-${RANDOM-0}$$"
+        _G_tmpdir=$_G_template-${RANDOM-0}$$
 
-        save_mktempdir_umask=`umask`
+        func_mktempdir_umask=`umask`
         umask 0077
-        $MKDIR "$my_tmpdir"
-        umask $save_mktempdir_umask
+        $MKDIR "$_G_tmpdir"
+        umask $func_mktempdir_umask
       fi
 
       # If we're not in dry-run mode, bomb out on failure
-      test -d "$my_tmpdir" || \
-        func_fatal_error "cannot create temporary directory \`$my_tmpdir'"
+      test -d "$_G_tmpdir" || \
+        func_fatal_error "cannot create temporary directory '$_G_tmpdir'"
+    fi
+
+    $ECHO "$_G_tmpdir"
+}
+
+
+# func_normal_abspath PATH
+# ------------------------
+# Remove doubled-up and trailing slashes, "." path components,
+# and cancel out any ".." path components in PATH after making
+# it an absolute path.
+func_normal_abspath ()
+{
+    $debug_cmd
+
+    # These SED scripts presuppose an absolute path with a trailing slash.
+    _G_pathcar='s|^/\([^/]*\).*$|\1|'
+    _G_pathcdr='s|^/[^/]*||'
+    _G_removedotparts=':dotsl
+		s|/\./|/|g
+		t dotsl
+		s|/\.$|/|'
+    _G_collapseslashes='s|/\{1,\}|/|g'
+    _G_finalslash='s|/*$|/|'
+
+    # Start from root dir and reassemble the path.
+    func_normal_abspath_result=
+    func_normal_abspath_tpath=$1
+    func_normal_abspath_altnamespace=
+    case $func_normal_abspath_tpath in
+      "")
+        # Empty path, that just means $cwd.
+        func_stripname '' '/' "`pwd`"
+        func_normal_abspath_result=$func_stripname_result
+        return
+        ;;
+      # The next three entries are used to spot a run of precisely
+      # two leading slashes without using negated character classes;
+      # we take advantage of case's first-match behaviour.
+      ///*)
+        # Unusual form of absolute path, do nothing.
+        ;;
+      //*)
+        # Not necessarily an ordinary path; POSIX reserves leading '//'
+        # and for example Cygwin uses it to access remote file shares
+        # over CIFS/SMB, so we conserve a leading double slash if found.
+        func_normal_abspath_altnamespace=/
+        ;;
+      /*)
+        # Absolute path, do nothing.
+        ;;
+      *)
+        # Relative path, prepend $cwd.
+        func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath
+        ;;
+    esac
+
+    # Cancel out all the simple stuff to save iterations.  We also want
+    # the path to end with a slash for ease of parsing, so make sure
+    # there is one (and only one) here.
+    func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
+          -e "$_G_removedotparts" -e "$_G_collapseslashes" -e "$_G_finalslash"`
+    while :; do
+      # Processed it all yet?
+      if test / = "$func_normal_abspath_tpath"; then
+        # If we ascended to the root using ".." the result may be empty now.
+        if test -z "$func_normal_abspath_result"; then
+          func_normal_abspath_result=/
+        fi
+        break
+      fi
+      func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \
+          -e "$_G_pathcar"`
+      func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
+          -e "$_G_pathcdr"`
+      # Figure out what to do with it
+      case $func_normal_abspath_tcomponent in
+        "")
+          # Trailing empty path component, ignore it.
+          ;;
+        ..)
+          # Parent dir; strip last assembled component from result.
+          func_dirname "$func_normal_abspath_result"
+          func_normal_abspath_result=$func_dirname_result
+          ;;
+        *)
+          # Actual path component, append it.
+          func_append func_normal_abspath_result "/$func_normal_abspath_tcomponent"
+          ;;
+      esac
+    done
+    # Restore leading double-slash if one was found on entry.
+    func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result
+}
+
+
+# func_notquiet ARG...
+# --------------------
+# Echo program name prefixed message only when not in quiet mode.
+func_notquiet ()
+{
+    $debug_cmd
+
+    $opt_quiet || func_echo ${1+"$@"}
+
+    # A bug in bash halts the script if the last line of a function
+    # fails when set -e is in force, so we need another command to
+    # work around that:
+    :
+}
+
+
+# func_relative_path SRCDIR DSTDIR
+# --------------------------------
+# Set func_relative_path_result to the relative path from SRCDIR to DSTDIR.
+func_relative_path ()
+{
+    $debug_cmd
+
+    func_relative_path_result=
+    func_normal_abspath "$1"
+    func_relative_path_tlibdir=$func_normal_abspath_result
+    func_normal_abspath "$2"
+    func_relative_path_tbindir=$func_normal_abspath_result
+
+    # Ascend the tree starting from libdir
+    while :; do
+      # check if we have found a prefix of bindir
+      case $func_relative_path_tbindir in
+        $func_relative_path_tlibdir)
+          # found an exact match
+          func_relative_path_tcancelled=
+          break
+          ;;
+        $func_relative_path_tlibdir*)
+          # found a matching prefix
+          func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir"
+          func_relative_path_tcancelled=$func_stripname_result
+          if test -z "$func_relative_path_result"; then
+            func_relative_path_result=.
+          fi
+          break
+          ;;
+        *)
+          func_dirname $func_relative_path_tlibdir
+          func_relative_path_tlibdir=$func_dirname_result
+          if test -z "$func_relative_path_tlibdir"; then
+            # Have to descend all the way to the root!
+            func_relative_path_result=../$func_relative_path_result
+            func_relative_path_tcancelled=$func_relative_path_tbindir
+            break
+          fi
+          func_relative_path_result=../$func_relative_path_result
+          ;;
+      esac
+    done
+
+    # Now calculate path; take care to avoid doubling-up slashes.
+    func_stripname '' '/' "$func_relative_path_result"
+    func_relative_path_result=$func_stripname_result
+    func_stripname '/' '/' "$func_relative_path_tcancelled"
+    if test -n "$func_stripname_result"; then
+      func_append func_relative_path_result "/$func_stripname_result"
+    fi
+
+    # Normalisation. If bindir is libdir, return '.' else relative path.
+    if test -n "$func_relative_path_result"; then
+      func_stripname './' '' "$func_relative_path_result"
+      func_relative_path_result=$func_stripname_result
     fi
 
-    $ECHO "$my_tmpdir"
+    test -n "$func_relative_path_result" || func_relative_path_result=.
+
+    :
+}
+
+
+# func_quote_for_eval ARG...
+# --------------------------
+# Aesthetically quote ARGs to be evaled later.
+# This function returns two values:
+#   i) func_quote_for_eval_result
+#      double-quoted, suitable for a subsequent eval
+#  ii) func_quote_for_eval_unquoted_result
+#      has all characters that are still active within double
+#      quotes backslashified.
+func_quote_for_eval ()
+{
+    $debug_cmd
+
+    func_quote_for_eval_unquoted_result=
+    func_quote_for_eval_result=
+    while test 0 -lt $#; do
+      case $1 in
+        *[\\\`\"\$]*)
+	  _G_unquoted_arg=`printf '%s\n' "$1" |$SED "$sed_quote_subst"` ;;
+        *)
+          _G_unquoted_arg=$1 ;;
+      esac
+      if test -n "$func_quote_for_eval_unquoted_result"; then
+	func_append func_quote_for_eval_unquoted_result " $_G_unquoted_arg"
+      else
+        func_append func_quote_for_eval_unquoted_result "$_G_unquoted_arg"
+      fi
+
+      case $_G_unquoted_arg in
+        # Double-quote args containing shell metacharacters to delay
+        # word splitting, command substitution and variable expansion
+        # for a subsequent eval.
+        # Many Bourne shells cannot handle close brackets correctly
+        # in scan sets, so we specify it separately.
+        *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \	]*|*]*|"")
+          _G_quoted_arg=\"$_G_unquoted_arg\"
+          ;;
+        *)
+          _G_quoted_arg=$_G_unquoted_arg
+	  ;;
+      esac
+
+      if test -n "$func_quote_for_eval_result"; then
+	func_append func_quote_for_eval_result " $_G_quoted_arg"
+      else
+        func_append func_quote_for_eval_result "$_G_quoted_arg"
+      fi
+      shift
+    done
+}
+
+
+# func_quote_for_expand ARG
+# -------------------------
+# Aesthetically quote ARG to be evaled later; same as above,
+# but do not quote variable references.
+func_quote_for_expand ()
+{
+    $debug_cmd
+
+    case $1 in
+      *[\\\`\"]*)
+	_G_arg=`$ECHO "$1" | $SED \
+	    -e "$sed_double_quote_subst" -e "$sed_double_backslash"` ;;
+      *)
+        _G_arg=$1 ;;
+    esac
+
+    case $_G_arg in
+      # Double-quote args containing shell metacharacters to delay
+      # word splitting and command substitution for a subsequent eval.
+      # Many Bourne shells cannot handle close brackets correctly
+      # in scan sets, so we specify it separately.
+      *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \	]*|*]*|"")
+        _G_arg=\"$_G_arg\"
+        ;;
+    esac
+
+    func_quote_for_expand_result=$_G_arg
+}
+
+
+# func_stripname PREFIX SUFFIX NAME
+# ---------------------------------
+# strip PREFIX and SUFFIX from NAME, and store in func_stripname_result.
+# PREFIX and SUFFIX must not contain globbing or regex special
+# characters, hashes, percent signs, but SUFFIX may contain a leading
+# dot (in which case that matches only a dot).
+if test yes = "$_G_HAVE_XSI_OPS"; then
+  eval 'func_stripname ()
+  {
+    $debug_cmd
+
+    # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are
+    # positional parameters, so assign one to ordinary variable first.
+    func_stripname_result=$3
+    func_stripname_result=${func_stripname_result#"$1"}
+    func_stripname_result=${func_stripname_result%"$2"}
+  }'
+else
+  func_stripname ()
+  {
+    $debug_cmd
+
+    case $2 in
+      .*) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%\\\\$2\$%%"`;;
+      *)  func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%$2\$%%"`;;
+    esac
+  }
+fi
+
+
+# func_show_eval CMD [FAIL_EXP]
+# -----------------------------
+# Unless opt_quiet is true, then output CMD.  Then, if opt_dryrun is
+# not true, evaluate CMD.  If the evaluation of CMD fails, and FAIL_EXP
+# is given, then evaluate it.
+func_show_eval ()
+{
+    $debug_cmd
+
+    _G_cmd=$1
+    _G_fail_exp=${2-':'}
+
+    func_quote_for_expand "$_G_cmd"
+    eval "func_notquiet $func_quote_for_expand_result"
+
+    $opt_dry_run || {
+      eval "$_G_cmd"
+      _G_status=$?
+      if test 0 -ne "$_G_status"; then
+	eval "(exit $_G_status); $_G_fail_exp"
+      fi
+    }
+}
+
+
+# func_show_eval_locale CMD [FAIL_EXP]
+# ------------------------------------
+# Unless opt_quiet is true, then output CMD.  Then, if opt_dryrun is
+# not true, evaluate CMD.  If the evaluation of CMD fails, and FAIL_EXP
+# is given, then evaluate it.  Use the saved locale for evaluation.
+func_show_eval_locale ()
+{
+    $debug_cmd
+
+    _G_cmd=$1
+    _G_fail_exp=${2-':'}
+
+    $opt_quiet || {
+      func_quote_for_expand "$_G_cmd"
+      eval "func_echo $func_quote_for_expand_result"
+    }
+
+    $opt_dry_run || {
+      eval "$_G_user_locale
+	    $_G_cmd"
+      _G_status=$?
+      eval "$_G_safe_locale"
+      if test 0 -ne "$_G_status"; then
+	eval "(exit $_G_status); $_G_fail_exp"
+      fi
+    }
+}
+
+
+# func_tr_sh
+# ----------
+# Turn $1 into a string suitable for a shell variable name.
+# Result is stored in $func_tr_sh_result.  All characters
+# not in the set a-zA-Z0-9_ are replaced with '_'. Further,
+# if $1 begins with a digit, a '_' is prepended as well.
+func_tr_sh ()
+{
+    $debug_cmd
+
+    case $1 in
+    [0-9]* | *[!a-zA-Z0-9_]*)
+      func_tr_sh_result=`$ECHO "$1" | $SED -e 's/^\([0-9]\)/_\1/' -e 's/[^a-zA-Z0-9_]/_/g'`
+      ;;
+    * )
+      func_tr_sh_result=$1
+      ;;
+    esac
+}
+
+
+# func_verbose ARG...
+# -------------------
+# Echo program name prefixed message in verbose mode only.
+func_verbose ()
+{
+    $debug_cmd
+
+    $opt_verbose && func_echo "$*"
+
+    :
+}
+
+
+# func_warn_and_continue ARG...
+# -----------------------------
+# Echo program name prefixed warning message to standard error.
+func_warn_and_continue ()
+{
+    $debug_cmd
+
+    $require_term_colors
+
+    func_echo_infix_1 "${tc_red}warning$tc_reset" "$*" >&2
+}
+
+
+# func_warning CATEGORY ARG...
+# ----------------------------
+# Echo program name prefixed warning message to standard error. Warning
+# messages can be filtered according to CATEGORY, where this function
+# elides messages where CATEGORY is not listed in the global variable
+# 'opt_warning_types'.
+func_warning ()
+{
+    $debug_cmd
+
+    # CATEGORY must be in the warning_categories list!
+    case " $warning_categories " in
+      *" $1 "*) ;;
+      *) func_internal_error "invalid warning category '$1'" ;;
+    esac
+
+    _G_category=$1
+    shift
+
+    case " $opt_warning_types " in
+      *" $_G_category "*) $warning_func ${1+"$@"} ;;
+    esac
+}
+
+
+# func_sort_ver VER1 VER2
+# -----------------------
+# 'sort -V' is not generally available.
+# Note this deviates from the version comparison in automake
+# in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a
+# but this should suffice as we won't be specifying old
+# version formats or redundant trailing .0 in bootstrap.conf.
+# If we did want full compatibility then we should probably
+# use m4_version_compare from autoconf.
+func_sort_ver ()
+{
+    $debug_cmd
+
+    printf '%s\n%s\n' "$1" "$2" \
+      | sort -t. -k 1,1n -k 2,2n -k 3,3n -k 4,4n -k 5,5n -k 6,6n -k 7,7n -k 8,8n -k 9,9n
+}
+
+# func_lt_ver PREV CURR
+# ---------------------
+# Return true if PREV and CURR are in the correct order according to
+# func_sort_ver, otherwise false.  Use it like this:
+#
+#  func_lt_ver "$prev_ver" "$proposed_ver" || func_fatal_error "..."
+func_lt_ver ()
+{
+    $debug_cmd
+
+    test "x$1" = x`func_sort_ver "$1" "$2" | $SED 1q`
+}
+
+
+# Local variables:
+# mode: shell-script
+# sh-indentation: 2
+# eval: (add-hook 'before-save-hook 'time-stamp)
+# time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC"
+# time-stamp-time-zone: "UTC"
+# End:
+#! /bin/sh
+
+# Set a version string for this script.
+scriptversion=2014-01-07.03; # UTC
+
+# A portable, pluggable option parser for Bourne shell.
+# Written by Gary V. Vaughan, 2010
+
+# Copyright (C) 2010-2015 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.
+
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+# Please report bugs or propose patches to gary at gnu.org.
+
+
+## ------ ##
+## Usage. ##
+## ------ ##
+
+# This file is a library for parsing options in your shell scripts along
+# with assorted other useful supporting features that you can make use
+# of too.
+#
+# For the simplest scripts you might need only:
+#
+#   #!/bin/sh
+#   . relative/path/to/funclib.sh
+#   . relative/path/to/options-parser
+#   scriptversion=1.0
+#   func_options ${1+"$@"}
+#   eval set dummy "$func_options_result"; shift
+#   ...rest of your script...
+#
+# In order for the '--version' option to work, you will need to have a
+# suitably formatted comment like the one at the top of this file
+# starting with '# Written by ' and ending with '# warranty; '.
+#
+# For '-h' and '--help' to work, you will also need a one line
+# description of your script's purpose in a comment directly above the
+# '# Written by ' line, like the one at the top of this file.
+#
+# The default options also support '--debug', which will turn on shell
+# execution tracing (see the comment above debug_cmd below for another
+# use), and '--verbose' and the func_verbose function to allow your script
+# to display verbose messages only when your user has specified
+# '--verbose'.
+#
+# After sourcing this file, you can plug processing for additional
+# options by amending the variables from the 'Configuration' section
+# below, and following the instructions in the 'Option parsing'
+# section further down.
+
+## -------------- ##
+## Configuration. ##
+## -------------- ##
+
+# You should override these variables in your script after sourcing this
+# file so that they reflect the customisations you have added to the
+# option parser.
+
+# The usage line for option parsing errors and the start of '-h' and
+# '--help' output messages. You can embed shell variables for delayed
+# expansion at the time the message is displayed, but you will need to
+# quote other shell meta-characters carefully to prevent them being
+# expanded when the contents are evaled.
+usage='$progpath [OPTION]...'
+
+# Short help message in response to '-h' and '--help'.  Add to this or
+# override it after sourcing this library to reflect the full set of
+# options your script accepts.
+usage_message="\
+       --debug        enable verbose shell tracing
+   -W, --warnings=CATEGORY
+                      report the warnings falling in CATEGORY [all]
+   -v, --verbose      verbosely report processing
+       --version      print version information and exit
+   -h, --help         print short or long help message and exit
+"
+
+# Additional text appended to 'usage_message' in response to '--help'.
+long_help_message="
+Warning categories include:
+       'all'          show all warnings
+       'none'         turn off all the warnings
+       'error'        warnings are treated as fatal errors"
+
+# Help message printed before fatal option parsing errors.
+fatal_help="Try '\$progname --help' for more information."
+
+
+
+## ------------------------- ##
+## Hook function management. ##
+## ------------------------- ##
+
+# This section contains functions for adding, removing, and running hooks
+# to the main code.  A hook is just a named list of of function, that can
+# be run in order later on.
+
+# func_hookable FUNC_NAME
+# -----------------------
+# Declare that FUNC_NAME will run hooks added with
+# 'func_add_hook FUNC_NAME ...'.
+func_hookable ()
+{
+    $debug_cmd
+
+    func_append hookable_fns " $1"
+}
+
+
+# func_add_hook FUNC_NAME HOOK_FUNC
+# ---------------------------------
+# Request that FUNC_NAME call HOOK_FUNC before it returns.  FUNC_NAME must
+# first have been declared "hookable" by a call to 'func_hookable'.
+func_add_hook ()
+{
+    $debug_cmd
+
+    case " $hookable_fns " in
+      *" $1 "*) ;;
+      *) func_fatal_error "'$1' does not accept hook functions." ;;
+    esac
+
+    eval func_append ${1}_hooks '" $2"'
+}
+
+
+# func_remove_hook FUNC_NAME HOOK_FUNC
+# ------------------------------------
+# Remove HOOK_FUNC from the list of functions called by FUNC_NAME.
+func_remove_hook ()
+{
+    $debug_cmd
+
+    eval ${1}_hooks='`$ECHO "\$'$1'_hooks" |$SED "s| '$2'||"`'
+}
+
+
+# func_run_hooks FUNC_NAME [ARG]...
+# ---------------------------------
+# Run all hook functions registered to FUNC_NAME.
+# It is assumed that the list of hook functions contains nothing more
+# than a whitespace-delimited list of legal shell function names, and
+# no effort is wasted trying to catch shell meta-characters or preserve
+# whitespace.
+func_run_hooks ()
+{
+    $debug_cmd
+
+    case " $hookable_fns " in
+      *" $1 "*) ;;
+      *) func_fatal_error "'$1' does not support hook funcions.n" ;;
+    esac
+
+    eval _G_hook_fns=\$$1_hooks; shift
+
+    for _G_hook in $_G_hook_fns; do
+      eval $_G_hook '"$@"'
+
+      # store returned options list back into positional
+      # parameters for next 'cmd' execution.
+      eval _G_hook_result=\$${_G_hook}_result
+      eval set dummy "$_G_hook_result"; shift
+    done
+
+    func_quote_for_eval ${1+"$@"}
+    func_run_hooks_result=$func_quote_for_eval_result
+}
+
+
+
+## --------------- ##
+## Option parsing. ##
+## --------------- ##
+
+# In order to add your own option parsing hooks, you must accept the
+# full positional parameter list in your hook function, remove any
+# options that you action, and then pass back the remaining unprocessed
+# options in '<hooked_function_name>_result', escaped suitably for
+# 'eval'.  Like this:
+#
+#    my_options_prep ()
+#    {
+#        $debug_cmd
+#
+#        # Extend the existing usage message.
+#        usage_message=$usage_message'
+#      -s, --silent       don'\''t print informational messages
+#    '
+#
+#        func_quote_for_eval ${1+"$@"}
+#        my_options_prep_result=$func_quote_for_eval_result
+#    }
+#    func_add_hook func_options_prep my_options_prep
+#
+#
+#    my_silent_option ()
+#    {
+#        $debug_cmd
+#
+#        # Note that for efficiency, we parse as many options as we can
+#        # recognise in a loop before passing the remainder back to the
+#        # caller on the first unrecognised argument we encounter.
+#        while test $# -gt 0; do
+#          opt=$1; shift
+#          case $opt in
+#            --silent|-s) opt_silent=: ;;
+#            # Separate non-argument short options:
+#            -s*)         func_split_short_opt "$_G_opt"
+#                         set dummy "$func_split_short_opt_name" \
+#                             "-$func_split_short_opt_arg" ${1+"$@"}
+#                         shift
+#                         ;;
+#            *)            set dummy "$_G_opt" "$*"; shift; break ;;
+#          esac
+#        done
+#
+#        func_quote_for_eval ${1+"$@"}
+#        my_silent_option_result=$func_quote_for_eval_result
+#    }
+#    func_add_hook func_parse_options my_silent_option
+#
+#
+#    my_option_validation ()
+#    {
+#        $debug_cmd
+#
+#        $opt_silent && $opt_verbose && func_fatal_help "\
+#    '--silent' and '--verbose' options are mutually exclusive."
+#
+#        func_quote_for_eval ${1+"$@"}
+#        my_option_validation_result=$func_quote_for_eval_result
+#    }
+#    func_add_hook func_validate_options my_option_validation
+#
+# You'll alse need to manually amend $usage_message to reflect the extra
+# options you parse.  It's preferable to append if you can, so that
+# multiple option parsing hooks can be added safely.
+
+
+# func_options [ARG]...
+# ---------------------
+# All the functions called inside func_options are hookable. See the
+# individual implementations for details.
+func_hookable func_options
+func_options ()
+{
+    $debug_cmd
+
+    func_options_prep ${1+"$@"}
+    eval func_parse_options \
+        ${func_options_prep_result+"$func_options_prep_result"}
+    eval func_validate_options \
+        ${func_parse_options_result+"$func_parse_options_result"}
+
+    eval func_run_hooks func_options \
+        ${func_validate_options_result+"$func_validate_options_result"}
+
+    # save modified positional parameters for caller
+    func_options_result=$func_run_hooks_result
 }
 
 
-# func_quote_for_eval arg
-# Aesthetically quote ARG to be evaled later.
-# This function returns two values: FUNC_QUOTE_FOR_EVAL_RESULT
-# is double-quoted, suitable for a subsequent eval, whereas
-# FUNC_QUOTE_FOR_EVAL_UNQUOTED_RESULT has merely all characters
-# which are still active within double quotes backslashified.
-func_quote_for_eval ()
+# func_options_prep [ARG]...
+# --------------------------
+# All initialisations required before starting the option parse loop.
+# Note that when calling hook functions, we pass through the list of
+# positional parameters.  If a hook function modifies that list, and
+# needs to propogate that back to rest of this script, then the complete
+# modified list must be put in 'func_run_hooks_result' before
+# returning.
+func_hookable func_options_prep
+func_options_prep ()
 {
-    case $1 in
-      *[\\\`\"\$]*)
-	func_quote_for_eval_unquoted_result=`$ECHO "$1" | $SED "$sed_quote_subst"` ;;
-      *)
-        func_quote_for_eval_unquoted_result="$1" ;;
-    esac
+    $debug_cmd
 
-    case $func_quote_for_eval_unquoted_result in
-      # Double-quote args containing shell metacharacters to delay
-      # word splitting, command substitution and and variable
-      # expansion for a subsequent eval.
-      # Many Bourne shells cannot handle close brackets correctly
-      # in scan sets, so we specify it separately.
-      *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \	]*|*]*|"")
-        func_quote_for_eval_result="\"$func_quote_for_eval_unquoted_result\""
-        ;;
-      *)
-        func_quote_for_eval_result="$func_quote_for_eval_unquoted_result"
-    esac
+    # Option defaults:
+    opt_verbose=false
+    opt_warning_types=
+
+    func_run_hooks func_options_prep ${1+"$@"}
+
+    # save modified positional parameters for caller
+    func_options_prep_result=$func_run_hooks_result
 }
 
 
-# func_quote_for_expand arg
-# Aesthetically quote ARG to be evaled later; same as above,
-# but do not quote variable references.
-func_quote_for_expand ()
+# func_parse_options [ARG]...
+# ---------------------------
+# The main option parsing loop.
+func_hookable func_parse_options
+func_parse_options ()
 {
-    case $1 in
-      *[\\\`\"]*)
-	my_arg=`$ECHO "$1" | $SED \
-	    -e "$double_quote_subst" -e "$sed_double_backslash"` ;;
-      *)
-        my_arg="$1" ;;
-    esac
+    $debug_cmd
 
-    case $my_arg in
-      # Double-quote args containing shell metacharacters to delay
-      # word splitting and command substitution for a subsequent eval.
-      # Many Bourne shells cannot handle close brackets correctly
-      # in scan sets, so we specify it separately.
-      *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \	]*|*]*|"")
-        my_arg="\"$my_arg\""
-        ;;
-    esac
+    func_parse_options_result=
 
-    func_quote_for_expand_result="$my_arg"
-}
+    # this just eases exit handling
+    while test $# -gt 0; do
+      # Defer to hook functions for initial option parsing, so they
+      # get priority in the event of reusing an option name.
+      func_run_hooks func_parse_options ${1+"$@"}
 
+      # Adjust func_parse_options positional parameters to match
+      eval set dummy "$func_run_hooks_result"; shift
 
-# func_show_eval cmd [fail_exp]
-# Unless opt_silent is true, then output CMD.  Then, if opt_dryrun is
-# not true, evaluate CMD.  If the evaluation of CMD fails, and FAIL_EXP
-# is given, then evaluate it.
-func_show_eval ()
-{
-    my_cmd="$1"
-    my_fail_exp="${2-:}"
+      # Break out of the loop if we already parsed every option.
+      test $# -gt 0 || break
 
-    ${opt_silent-false} || {
-      func_quote_for_expand "$my_cmd"
-      eval "func_echo $func_quote_for_expand_result"
-    }
+      _G_opt=$1
+      shift
+      case $_G_opt in
+        --debug|-x)   debug_cmd='set -x'
+                      func_echo "enabling shell trace mode"
+                      $debug_cmd
+                      ;;
+
+        --no-warnings|--no-warning|--no-warn)
+                      set dummy --warnings none ${1+"$@"}
+                      shift
+		      ;;
 
-    if ${opt_dry_run-false}; then :; else
-      eval "$my_cmd"
-      my_status=$?
-      if test "$my_status" -eq 0; then :; else
-	eval "(exit $my_status); $my_fail_exp"
-      fi
-    fi
+        --warnings|--warning|-W)
+                      test $# = 0 && func_missing_arg $_G_opt && break
+                      case " $warning_categories $1" in
+                        *" $1 "*)
+                          # trailing space prevents matching last $1 above
+                          func_append_uniq opt_warning_types " $1"
+                          ;;
+                        *all)
+                          opt_warning_types=$warning_categories
+                          ;;
+                        *none)
+                          opt_warning_types=none
+                          warning_func=:
+                          ;;
+                        *error)
+                          opt_warning_types=$warning_categories
+                          warning_func=func_fatal_error
+                          ;;
+                        *)
+                          func_fatal_error \
+                             "unsupported warning category: '$1'"
+                          ;;
+                      esac
+                      shift
+                      ;;
+
+        --verbose|-v) opt_verbose=: ;;
+        --version)    func_version ;;
+        -\?|-h)       func_usage ;;
+        --help)       func_help ;;
+
+	# Separate optargs to long options (plugins may need this):
+	--*=*)        func_split_equals "$_G_opt"
+	              set dummy "$func_split_equals_lhs" \
+                          "$func_split_equals_rhs" ${1+"$@"}
+                      shift
+                      ;;
+
+       # Separate optargs to short options:
+        -W*)
+                      func_split_short_opt "$_G_opt"
+                      set dummy "$func_split_short_opt_name" \
+                          "$func_split_short_opt_arg" ${1+"$@"}
+                      shift
+                      ;;
+
+        # Separate non-argument short options:
+        -\?*|-h*|-v*|-x*)
+                      func_split_short_opt "$_G_opt"
+                      set dummy "$func_split_short_opt_name" \
+                          "-$func_split_short_opt_arg" ${1+"$@"}
+                      shift
+                      ;;
+
+        --)           break ;;
+        -*)           func_fatal_help "unrecognised option: '$_G_opt'" ;;
+        *)            set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
+      esac
+    done
+
+    # save modified positional parameters for caller
+    func_quote_for_eval ${1+"$@"}
+    func_parse_options_result=$func_quote_for_eval_result
 }
 
 
-# func_show_eval_locale cmd [fail_exp]
-# Unless opt_silent is true, then output CMD.  Then, if opt_dryrun is
-# not true, evaluate CMD.  If the evaluation of CMD fails, and FAIL_EXP
-# is given, then evaluate it.  Use the saved locale for evaluation.
-func_show_eval_locale ()
+# func_validate_options [ARG]...
+# ------------------------------
+# Perform any sanity checks on option settings and/or unconsumed
+# arguments.
+func_hookable func_validate_options
+func_validate_options ()
 {
-    my_cmd="$1"
-    my_fail_exp="${2-:}"
+    $debug_cmd
 
-    ${opt_silent-false} || {
-      func_quote_for_expand "$my_cmd"
-      eval "func_echo $func_quote_for_expand_result"
-    }
+    # Display all warnings if -W was not given.
+    test -n "$opt_warning_types" || opt_warning_types=" $warning_categories"
 
-    if ${opt_dry_run-false}; then :; else
-      eval "$lt_user_locale
-	    $my_cmd"
-      my_status=$?
-      eval "$lt_safe_locale"
-      if test "$my_status" -eq 0; then :; else
-	eval "(exit $my_status); $my_fail_exp"
-      fi
-    fi
-}
+    func_run_hooks func_validate_options ${1+"$@"}
 
-# func_tr_sh
-# Turn $1 into a string suitable for a shell variable name.
-# Result is stored in $func_tr_sh_result.  All characters
-# not in the set a-zA-Z0-9_ are replaced with '_'. Further,
-# if $1 begins with a digit, a '_' is prepended as well.
-func_tr_sh ()
-{
-  case $1 in
-  [0-9]* | *[!a-zA-Z0-9_]*)
-    func_tr_sh_result=`$ECHO "$1" | $SED 's/^\([0-9]\)/_\1/; s/[^a-zA-Z0-9_]/_/g'`
-    ;;
-  * )
-    func_tr_sh_result=$1
-    ;;
-  esac
+    # Bail if the options were screwed!
+    $exit_cmd $EXIT_FAILURE
+
+    # save modified positional parameters for caller
+    func_validate_options_result=$func_run_hooks_result
 }
 
 
-# func_version
-# Echo version message to standard output and exit.
-func_version ()
-{
-    $opt_debug
 
-    $SED -n '/(C)/!b go
-	:more
-	/\./!{
-	  N
-	  s/\n# / /
-	  b more
-	}
-	:go
-	/^# '$PROGRAM' (GNU /,/# warranty; / {
-        s/^# //
-	s/^# *$//
-        s/\((C)\)[ 0-9,-]*\( [1-9][0-9]*\)/\1\2/
-        p
-     }' < "$progpath"
-     exit $?
-}
+## ----------------- ##
+## Helper functions. ##
+## ----------------- ##
 
-# func_usage
-# Echo short help message to standard output and exit.
-func_usage ()
+# This section contains the helper functions used by the rest of the
+# hookable option parser framework in ascii-betical order.
+
+
+# func_fatal_help ARG...
+# ----------------------
+# Echo program name prefixed message to standard error, followed by
+# a help hint, and exit.
+func_fatal_help ()
 {
-    $opt_debug
+    $debug_cmd
 
-    $SED -n '/^# Usage:/,/^#  *.*--help/ {
-        s/^# //
-	s/^# *$//
-	s/\$progname/'$progname'/
-	p
-    }' < "$progpath"
-    echo
-    $ECHO "run \`$progname --help | more' for full usage"
-    exit $?
+    eval \$ECHO \""Usage: $usage"\"
+    eval \$ECHO \""$fatal_help"\"
+    func_error ${1+"$@"}
+    exit $EXIT_FAILURE
 }
 
-# func_help [NOEXIT]
-# Echo long help message to standard output and exit,
-# unless 'noexit' is passed as argument.
+
+# func_help
+# ---------
+# Echo long help message to standard output and exit.
 func_help ()
 {
-    $opt_debug
-
-    $SED -n '/^# Usage:/,/# Report bugs to/ {
-	:print
-        s/^# //
-	s/^# *$//
-	s*\$progname*'$progname'*
-	s*\$host*'"$host"'*
-	s*\$SHELL*'"$SHELL"'*
-	s*\$LTCC*'"$LTCC"'*
-	s*\$LTCFLAGS*'"$LTCFLAGS"'*
-	s*\$LD*'"$LD"'*
-	s/\$with_gnu_ld/'"$with_gnu_ld"'/
-	s/\$automake_version/'"`(${AUTOMAKE-automake} --version) 2>/dev/null |$SED 1q`"'/
-	s/\$autoconf_version/'"`(${AUTOCONF-autoconf} --version) 2>/dev/null |$SED 1q`"'/
-	p
-	d
-     }
-     /^# .* home page:/b print
-     /^# General help using/b print
-     ' < "$progpath"
-    ret=$?
-    if test -z "$1"; then
-      exit $ret
-    fi
+    $debug_cmd
+
+    func_usage_message
+    $ECHO "$long_help_message"
+    exit 0
 }
 
-# func_missing_arg argname
+
+# func_missing_arg ARGNAME
+# ------------------------
 # Echo program name prefixed message to standard error and set global
 # exit_cmd.
 func_missing_arg ()
 {
-    $opt_debug
+    $debug_cmd
 
-    func_error "missing argument for $1."
+    func_error "Missing argument for '$1'."
     exit_cmd=exit
 }
 
 
-# func_split_short_opt shortopt
+# func_split_equals STRING
+# ------------------------
+# Set func_split_equals_lhs and func_split_equals_rhs shell variables after
+# splitting STRING at the '=' sign.
+test -z "$_G_HAVE_XSI_OPS" \
+    && (eval 'x=a/b/c;
+      test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \
+    && _G_HAVE_XSI_OPS=yes
+
+if test yes = "$_G_HAVE_XSI_OPS"
+then
+  # This is an XSI compatible shell, allowing a faster implementation...
+  eval 'func_split_equals ()
+  {
+      $debug_cmd
+
+      func_split_equals_lhs=${1%%=*}
+      func_split_equals_rhs=${1#*=}
+      test "x$func_split_equals_lhs" = "x$1" \
+        && func_split_equals_rhs=
+  }'
+else
+  # ...otherwise fall back to using expr, which is often a shell builtin.
+  func_split_equals ()
+  {
+      $debug_cmd
+
+      func_split_equals_lhs=`expr "x$1" : 'x\([^=]*\)'`
+      func_split_equals_rhs=
+      test "x$func_split_equals_lhs" = "x$1" \
+        || func_split_equals_rhs=`expr "x$1" : 'x[^=]*=\(.*\)$'`
+  }
+fi #func_split_equals
+
+
+# func_split_short_opt SHORTOPT
+# -----------------------------
 # Set func_split_short_opt_name and func_split_short_opt_arg shell
 # variables after splitting SHORTOPT after the 2nd character.
-func_split_short_opt ()
+if test yes = "$_G_HAVE_XSI_OPS"
+then
+  # This is an XSI compatible shell, allowing a faster implementation...
+  eval 'func_split_short_opt ()
+  {
+      $debug_cmd
+
+      func_split_short_opt_arg=${1#??}
+      func_split_short_opt_name=${1%"$func_split_short_opt_arg"}
+  }'
+else
+  # ...otherwise fall back to using expr, which is often a shell builtin.
+  func_split_short_opt ()
+  {
+      $debug_cmd
+
+      func_split_short_opt_name=`expr "x$1" : 'x-\(.\)'`
+      func_split_short_opt_arg=`expr "x$1" : 'x-.\(.*\)$'`
+  }
+fi #func_split_short_opt
+
+
+# func_usage
+# ----------
+# Echo short help message to standard output and exit.
+func_usage ()
 {
-    my_sed_short_opt='1s/^\(..\).*$/\1/;q'
-    my_sed_short_rest='1s/^..\(.*\)$/\1/;q'
+    $debug_cmd
 
-    func_split_short_opt_name=`$ECHO "$1" | $SED "$my_sed_short_opt"`
-    func_split_short_opt_arg=`$ECHO "$1" | $SED "$my_sed_short_rest"`
-} # func_split_short_opt may be replaced by extended shell implementation
+    func_usage_message
+    $ECHO "Run '$progname --help |${PAGER-more}' for full usage"
+    exit 0
+}
 
 
-# func_split_long_opt longopt
-# Set func_split_long_opt_name and func_split_long_opt_arg shell
-# variables after splitting LONGOPT at the `=' sign.
-func_split_long_opt ()
+# func_usage_message
+# ------------------
+# Echo short help message to standard output.
+func_usage_message ()
 {
-    my_sed_long_opt='1s/^\(--[^=]*\)=.*/\1/;q'
-    my_sed_long_arg='1s/^--[^=]*=//'
+    $debug_cmd
 
-    func_split_long_opt_name=`$ECHO "$1" | $SED "$my_sed_long_opt"`
-    func_split_long_opt_arg=`$ECHO "$1" | $SED "$my_sed_long_arg"`
-} # func_split_long_opt may be replaced by extended shell implementation
+    eval \$ECHO \""Usage: $usage"\"
+    echo
+    $SED -n 's|^# ||
+        /^Written by/{
+          x;p;x
+        }
+	h
+	/^Written by/q' < "$progpath"
+    echo
+    eval \$ECHO \""$usage_message"\"
+}
 
-exit_cmd=:
 
+# func_version
+# ------------
+# Echo version message to standard output and exit.
+func_version ()
+{
+    $debug_cmd
 
+    printf '%s\n' "$progname $scriptversion"
+    $SED -n '
+        /(C)/!b go
+        :more
+        /\./!{
+          N
+          s|\n# | |
+          b more
+        }
+        :go
+        /^# Written by /,/# warranty; / {
+          s|^# ||
+          s|^# *$||
+          s|\((C)\)[ 0-9,-]*[ ,-]\([1-9][0-9]* \)|\1 \2|
+          p
+        }
+        /^# Written by / {
+          s|^# ||
+          p
+        }
+        /^warranty; /q' < "$progpath"
 
+    exit $?
+}
 
 
-magic="%%%MAGIC variable%%%"
-magic_exe="%%%MAGIC EXE variable%%%"
+# Local variables:
+# mode: shell-script
+# sh-indentation: 2
+# eval: (add-hook 'before-save-hook 'time-stamp)
+# time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC"
+# time-stamp-time-zone: "UTC"
+# End:
 
-# Global variables.
-nonopt=
-preserve_args=
-lo2o="s/\\.lo\$/.${objext}/"
-o2lo="s/\\.${objext}\$/.lo/"
-extracted_archives=
-extracted_serial=0
+# Set a version string.
+scriptversion='(GNU libtool) 2.4.6'
 
-# 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=
 
-# func_append var value
-# Append VALUE to the end of shell variable VAR.
-func_append ()
+# func_echo ARG...
+# ----------------
+# Libtool also displays the current mode in messages, so override
+# funclib.sh func_echo with this custom definition.
+func_echo ()
 {
-    eval "${1}=\$${1}\${2}"
-} # func_append may be replaced by extended shell implementation
+    $debug_cmd
 
-# func_append_quoted var value
-# Quote VALUE and append to the end of shell variable VAR, separated
-# by a space.
-func_append_quoted ()
-{
-    func_quote_for_eval "${2}"
-    eval "${1}=\$${1}\\ \$func_quote_for_eval_result"
-} # func_append_quoted may be replaced by extended shell implementation
+    _G_message=$*
 
+    func_echo_IFS=$IFS
+    IFS=$nl
+    for _G_line in $_G_message; do
+      IFS=$func_echo_IFS
+      $ECHO "$progname${opt_mode+: $opt_mode}: $_G_line"
+    done
+    IFS=$func_echo_IFS
+}
 
-# func_arith arithmetic-term...
-func_arith ()
+
+# func_warning ARG...
+# -------------------
+# Libtool warnings are not categorized, so override funclib.sh
+# func_warning with this simpler definition.
+func_warning ()
 {
-    func_arith_result=`expr "${@}"`
-} # func_arith may be replaced by extended shell implementation
+    $debug_cmd
 
+    $warning_func ${1+"$@"}
+}
 
-# func_len string
-# STRING may not start with a hyphen.
-func_len ()
-{
-    func_len_result=`expr "${1}" : ".*" 2>/dev/null || echo $max_cmd_len`
-} # func_len may be replaced by extended shell implementation
 
+## ---------------- ##
+## Options parsing. ##
+## ---------------- ##
+
+# Hook in the functions to make sure our own options are parsed during
+# the option parsing loop.
+
+usage='$progpath [OPTION]... [MODE-ARG]...'
+
+# Short help message in response to '-h'.
+usage_message="Options:
+       --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
+       --mode=MODE          use operation mode MODE
+       --no-warnings        equivalent to '-Wnone'
+       --preserve-dup-deps  don't remove duplicate dependency libraries
+       --quiet, --silent    don't print informational messages
+       --tag=TAG            use configuration variables from tag TAG
+   -v, --verbose            print more informational messages than default
+       --version            print version information
+   -W, --warnings=CATEGORY  report the warnings falling in CATEGORY [all]
+   -h, --help, --help-all   print short, long, or detailed help message
+"
 
-# func_lo2o object
-func_lo2o ()
+# Additional text appended to 'usage_message' in response to '--help'.
+func_help ()
 {
-    func_lo2o_result=`$ECHO "${1}" | $SED "$lo2o"`
-} # func_lo2o may be replaced by extended shell implementation
+    $debug_cmd
+
+    func_usage_message
+    $ECHO "$long_help_message
+
+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.  When passed as first option,
+'--mode=MODE' may be abbreviated as 'MODE' or a unique abbreviation of that.
+Try '$progname --help --mode=MODE' for a more detailed description of MODE.
+
+When reporting a bug, please describe a test case to reproduce it and
+include the following information:
+
+       host-triplet:   $host
+       shell:          $SHELL
+       compiler:       $LTCC
+       compiler flags: $LTCFLAGS
+       linker:         $LD (gnu? $with_gnu_ld)
+       version:        $progname (GNU libtool) 2.4.6
+       automake:       `($AUTOMAKE --version) 2>/dev/null |$SED 1q`
+       autoconf:       `($AUTOCONF --version) 2>/dev/null |$SED 1q`
+
+Report bugs to <bug-libtool at gnu.org>.
+GNU libtool home page: <http://www.gnu.org/software/libtool/>.
+General help using GNU software: <http://www.gnu.org/gethelp/>."
+    exit 0
+}
 
 
-# func_xform libobj-or-source
-func_xform ()
-{
-    func_xform_result=`$ECHO "${1}" | $SED 's/\.[^.]*$/.lo/'`
-} # func_xform may be replaced by extended shell implementation
+# func_lo2o OBJECT-NAME
+# ---------------------
+# Transform OBJECT-NAME from a '.lo' suffix to the platform specific
+# object suffix.
+
+lo2o=s/\\.lo\$/.$objext/
+o2lo=s/\\.$objext\$/.lo/
+
+if test yes = "$_G_HAVE_XSI_OPS"; then
+  eval 'func_lo2o ()
+  {
+    case $1 in
+      *.lo) func_lo2o_result=${1%.lo}.$objext ;;
+      *   ) func_lo2o_result=$1               ;;
+    esac
+  }'
+
+  # func_xform LIBOBJ-OR-SOURCE
+  # ---------------------------
+  # Transform LIBOBJ-OR-SOURCE from a '.o' or '.c' (or otherwise)
+  # suffix to a '.lo' libtool-object suffix.
+  eval 'func_xform ()
+  {
+    func_xform_result=${1%.*}.lo
+  }'
+else
+  # ...otherwise fall back to using sed.
+  func_lo2o ()
+  {
+    func_lo2o_result=`$ECHO "$1" | $SED "$lo2o"`
+  }
+
+  func_xform ()
+  {
+    func_xform_result=`$ECHO "$1" | $SED 's|\.[^.]*$|.lo|'`
+  }
+fi
 
 
-# func_fatal_configuration arg...
+# func_fatal_configuration ARG...
+# -------------------------------
 # Echo program name prefixed message to standard error, followed by
 # a configuration failure hint, and exit.
 func_fatal_configuration ()
 {
-    func_error ${1+"$@"}
-    func_error "See the $PACKAGE documentation for more information."
-    func_fatal_error "Fatal configuration error."
+    func__fatal_error ${1+"$@"} \
+      "See the $PACKAGE documentation for more information." \
+      "Fatal configuration error."
 }
 
 
 # func_config
+# -----------
 # Display the configuration for all the tags in this script.
 func_config ()
 {
@@ -915,17 +2149,19 @@ func_config ()
     exit $?
 }
 
+
 # func_features
+# -------------
 # Display the features supported by this script.
 func_features ()
 {
     echo "host: $host"
-    if test "$build_libtool_libs" = yes; then
+    if test yes = "$build_libtool_libs"; then
       echo "enable shared libraries"
     else
       echo "disable shared libraries"
     fi
-    if test "$build_old_libs" = yes; then
+    if test yes = "$build_old_libs"; then
       echo "enable static libraries"
     else
       echo "disable static libraries"
@@ -934,314 +2170,350 @@ func_features ()
     exit $?
 }
 
-# func_enable_tag tagname
+
+# func_enable_tag TAGNAME
+# -----------------------
 # Verify that TAGNAME is valid, and either flag an error and exit, or
 # enable the TAGNAME tag.  We also add TAGNAME to the global $taglist
 # variable here.
 func_enable_tag ()
 {
-  # Global variable:
-  tagname="$1"
+    # Global variable:
+    tagname=$1
 
-  re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$"
-  re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$"
-  sed_extractcf="/$re_begincf/,/$re_endcf/p"
+    re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$"
+    re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$"
+    sed_extractcf=/$re_begincf/,/$re_endcf/p
 
-  # Validate tagname.
-  case $tagname in
-    *[!-_A-Za-z0-9,/]*)
-      func_fatal_error "invalid tag name: $tagname"
-      ;;
-  esac
+    # Validate tagname.
+    case $tagname in
+      *[!-_A-Za-z0-9,/]*)
+        func_fatal_error "invalid tag name: $tagname"
+        ;;
+    esac
 
-  # Don't test for the "default" C tag, as we know it's
-  # there but not specially marked.
-  case $tagname in
-    CC) ;;
+    # Don't test for the "default" C tag, as we know it's
+    # there but not specially marked.
+    case $tagname in
+        CC) ;;
     *)
-      if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then
-	taglist="$taglist $tagname"
-
-	# Evaluate the configuration.  Be careful to quote the path
-	# and the sed script, to avoid splitting on whitespace, but
-	# also don't use non-portable quotes within backquotes within
-	# quotes we have to do it in 2 steps:
-	extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"`
-	eval "$extractedcf"
-      else
-	func_error "ignoring unknown tag $tagname"
-      fi
-      ;;
-  esac
+        if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then
+	  taglist="$taglist $tagname"
+
+	  # Evaluate the configuration.  Be careful to quote the path
+	  # and the sed script, to avoid splitting on whitespace, but
+	  # also don't use non-portable quotes within backquotes within
+	  # quotes we have to do it in 2 steps:
+	  extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"`
+	  eval "$extractedcf"
+        else
+	  func_error "ignoring unknown tag $tagname"
+        fi
+        ;;
+    esac
 }
 
+
 # func_check_version_match
+# ------------------------
 # Ensure that we are using m4 macros, and libtool script from the same
 # release of libtool.
 func_check_version_match ()
 {
-  if test "$package_revision" != "$macro_revision"; then
-    if test "$VERSION" != "$macro_version"; then
-      if test -z "$macro_version"; then
-        cat >&2 <<_LT_EOF
+    if test "$package_revision" != "$macro_revision"; then
+      if test "$VERSION" != "$macro_version"; then
+        if test -z "$macro_version"; then
+          cat >&2 <<_LT_EOF
 $progname: Version mismatch error.  This is $PACKAGE $VERSION, but the
 $progname: definition of this LT_INIT comes from an older release.
 $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
 $progname: and run autoconf again.
 _LT_EOF
-      else
-        cat >&2 <<_LT_EOF
+        else
+          cat >&2 <<_LT_EOF
 $progname: Version mismatch error.  This is $PACKAGE $VERSION, but the
 $progname: definition of this LT_INIT comes from $PACKAGE $macro_version.
 $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
 $progname: and run autoconf again.
 _LT_EOF
-      fi
-    else
-      cat >&2 <<_LT_EOF
+        fi
+      else
+        cat >&2 <<_LT_EOF
 $progname: Version mismatch error.  This is $PACKAGE $VERSION, revision $package_revision,
 $progname: but the definition of this LT_INIT comes from revision $macro_revision.
 $progname: You should recreate aclocal.m4 with macros from revision $package_revision
 $progname: of $PACKAGE $VERSION and run autoconf again.
 _LT_EOF
-    fi
+      fi
 
-    exit $EXIT_MISMATCH
-  fi
+      exit $EXIT_MISMATCH
+    fi
 }
 
 
-# Shorthand for --mode=foo, only valid as the first argument
-case $1 in
-clean|clea|cle|cl)
-  shift; set dummy --mode clean ${1+"$@"}; shift
-  ;;
-compile|compil|compi|comp|com|co|c)
-  shift; set dummy --mode compile ${1+"$@"}; shift
-  ;;
-execute|execut|execu|exec|exe|ex|e)
-  shift; set dummy --mode execute ${1+"$@"}; shift
-  ;;
-finish|finis|fini|fin|fi|f)
-  shift; set dummy --mode finish ${1+"$@"}; shift
-  ;;
-install|instal|insta|inst|ins|in|i)
-  shift; set dummy --mode install ${1+"$@"}; shift
-  ;;
-link|lin|li|l)
-  shift; set dummy --mode link ${1+"$@"}; shift
-  ;;
-uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
-  shift; set dummy --mode uninstall ${1+"$@"}; shift
-  ;;
-esac
+# libtool_options_prep [ARG]...
+# -----------------------------
+# Preparation for options parsed by libtool.
+libtool_options_prep ()
+{
+    $debug_mode
 
+    # Option defaults:
+    opt_config=false
+    opt_dlopen=
+    opt_dry_run=false
+    opt_help=false
+    opt_mode=
+    opt_preserve_dup_deps=false
+    opt_quiet=false
 
+    nonopt=
+    preserve_args=
 
-# Option defaults:
-opt_debug=:
-opt_dry_run=false
-opt_config=false
-opt_preserve_dup_deps=false
-opt_features=false
-opt_finish=false
-opt_help=false
-opt_help_all=false
-opt_silent=:
-opt_warning=:
-opt_verbose=:
-opt_silent=false
-opt_verbose=false
+    # Shorthand for --mode=foo, only valid as the first argument
+    case $1 in
+    clean|clea|cle|cl)
+      shift; set dummy --mode clean ${1+"$@"}; shift
+      ;;
+    compile|compil|compi|comp|com|co|c)
+      shift; set dummy --mode compile ${1+"$@"}; shift
+      ;;
+    execute|execut|execu|exec|exe|ex|e)
+      shift; set dummy --mode execute ${1+"$@"}; shift
+      ;;
+    finish|finis|fini|fin|fi|f)
+      shift; set dummy --mode finish ${1+"$@"}; shift
+      ;;
+    install|instal|insta|inst|ins|in|i)
+      shift; set dummy --mode install ${1+"$@"}; shift
+      ;;
+    link|lin|li|l)
+      shift; set dummy --mode link ${1+"$@"}; shift
+      ;;
+    uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
+      shift; set dummy --mode uninstall ${1+"$@"}; shift
+      ;;
+    esac
+
+    # Pass back the list of options.
+    func_quote_for_eval ${1+"$@"}
+    libtool_options_prep_result=$func_quote_for_eval_result
+}
+func_add_hook func_options_prep libtool_options_prep
 
 
-# Parse options once, thoroughly.  This comes as soon as possible in the
-# script to make things like `--version' happen as quickly as we can.
+# libtool_parse_options [ARG]...
+# ---------------------------------
+# Provide handling for libtool specific options.
+libtool_parse_options ()
 {
-  # this just eases exit handling
-  while test $# -gt 0; do
-    opt="$1"
-    shift
-    case $opt in
-      --debug|-x)	opt_debug='set -x'
-			func_echo "enabling shell trace mode"
-			$opt_debug
-			;;
-      --dry-run|--dryrun|-n)
-			opt_dry_run=:
-			;;
-      --config)
-			opt_config=:
-func_config
-			;;
-      --dlopen|-dlopen)
-			optarg="$1"
-			opt_dlopen="${opt_dlopen+$opt_dlopen
-}$optarg"
-			shift
-			;;
-      --preserve-dup-deps)
-			opt_preserve_dup_deps=:
-			;;
-      --features)
-			opt_features=:
-func_features
-			;;
-      --finish)
-			opt_finish=:
-set dummy --mode finish ${1+"$@"}; shift
-			;;
-      --help)
-			opt_help=:
-			;;
-      --help-all)
-			opt_help_all=:
-opt_help=': help-all'
-			;;
-      --mode)
-			test $# = 0 && func_missing_arg $opt && break
-			optarg="$1"
-			opt_mode="$optarg"
-case $optarg in
-  # Valid mode arguments:
-  clean|compile|execute|finish|install|link|relink|uninstall) ;;
-
-  # Catch anything else as an error
-  *) func_error "invalid argument for $opt"
-     exit_cmd=exit
-     break
-     ;;
-esac
-			shift
-			;;
-      --no-silent|--no-quiet)
-			opt_silent=false
-func_append preserve_args " $opt"
-			;;
-      --no-warning|--no-warn)
-			opt_warning=false
-func_append preserve_args " $opt"
-			;;
-      --no-verbose)
-			opt_verbose=false
-func_append preserve_args " $opt"
-			;;
-      --silent|--quiet)
-			opt_silent=:
-func_append preserve_args " $opt"
-        opt_verbose=false
-			;;
-      --verbose|-v)
-			opt_verbose=:
-func_append preserve_args " $opt"
-opt_silent=false
-			;;
-      --tag)
-			test $# = 0 && func_missing_arg $opt && break
-			optarg="$1"
-			opt_tag="$optarg"
-func_append preserve_args " $opt $optarg"
-func_enable_tag "$optarg"
-			shift
-			;;
-
-      -\?|-h)		func_usage				;;
-      --help)		func_help				;;
-      --version)	func_version				;;
-
-      # Separate optargs to long options:
-      --*=*)
-			func_split_long_opt "$opt"
-			set dummy "$func_split_long_opt_name" "$func_split_long_opt_arg" ${1+"$@"}
-			shift
-			;;
-
-      # Separate non-argument short options:
-      -\?*|-h*|-n*|-v*)
-			func_split_short_opt "$opt"
-			set dummy "$func_split_short_opt_name" "-$func_split_short_opt_arg" ${1+"$@"}
-			shift
-			;;
-
-      --)		break					;;
-      -*)		func_fatal_help "unrecognized option \`$opt'" ;;
-      *)		set dummy "$opt" ${1+"$@"};	shift; break  ;;
-    esac
-  done
+    $debug_cmd
 
-  # Validate options:
+    # Perform our own loop to consume as many options as possible in
+    # each iteration.
+    while test $# -gt 0; do
+      _G_opt=$1
+      shift
+      case $_G_opt in
+        --dry-run|--dryrun|-n)
+                        opt_dry_run=:
+                        ;;
+
+        --config)       func_config ;;
+
+        --dlopen|-dlopen)
+                        opt_dlopen="${opt_dlopen+$opt_dlopen
+}$1"
+                        shift
+                        ;;
+
+        --preserve-dup-deps)
+                        opt_preserve_dup_deps=: ;;
+
+        --features)     func_features ;;
+
+        --finish)       set dummy --mode finish ${1+"$@"}; shift ;;
+
+        --help)         opt_help=: ;;
+
+        --help-all)     opt_help=': help-all' ;;
+
+        --mode)         test $# = 0 && func_missing_arg $_G_opt && break
+                        opt_mode=$1
+                        case $1 in
+                          # Valid mode arguments:
+                          clean|compile|execute|finish|install|link|relink|uninstall) ;;
+
+                          # Catch anything else as an error
+                          *) func_error "invalid argument for $_G_opt"
+                             exit_cmd=exit
+                             break
+                             ;;
+                        esac
+                        shift
+                        ;;
+
+        --no-silent|--no-quiet)
+                        opt_quiet=false
+                        func_append preserve_args " $_G_opt"
+                        ;;
+
+        --no-warnings|--no-warning|--no-warn)
+                        opt_warning=false
+                        func_append preserve_args " $_G_opt"
+                        ;;
+
+        --no-verbose)
+                        opt_verbose=false
+                        func_append preserve_args " $_G_opt"
+                        ;;
+
+        --silent|--quiet)
+                        opt_quiet=:
+                        opt_verbose=false
+                        func_append preserve_args " $_G_opt"
+                        ;;
+
+        --tag)          test $# = 0 && func_missing_arg $_G_opt && break
+                        opt_tag=$1
+                        func_append preserve_args " $_G_opt $1"
+                        func_enable_tag "$1"
+                        shift
+                        ;;
+
+        --verbose|-v)   opt_quiet=false
+                        opt_verbose=:
+                        func_append preserve_args " $_G_opt"
+                        ;;
+
+	# An option not handled by this hook function:
+        *)		set dummy "$_G_opt" ${1+"$@"};	shift; break  ;;
+      esac
+    done
 
-  # save first non-option argument
-  if test "$#" -gt 0; then
-    nonopt="$opt"
-    shift
-  fi
 
-  # preserve --debug
-  test "$opt_debug" = : || func_append preserve_args " --debug"
+    # save modified positional parameters for caller
+    func_quote_for_eval ${1+"$@"}
+    libtool_parse_options_result=$func_quote_for_eval_result
+}
+func_add_hook func_parse_options libtool_parse_options
 
-  case $host in
-    *cygwin* | *mingw* | *pw32* | *cegcc*)
-      # don't eliminate duplications in $postdeps and $predeps
-      opt_duplicate_compiler_generated_deps=:
-      ;;
-    *)
-      opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps
-      ;;
-  esac
 
-  $opt_help || {
-    # Sanity checks first:
-    func_check_version_match
 
-    if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then
-      func_fatal_configuration "not configured to build any kind of library"
+# libtool_validate_options [ARG]...
+# ---------------------------------
+# Perform any sanity checks on option settings and/or unconsumed
+# arguments.
+libtool_validate_options ()
+{
+    # save first non-option argument
+    if test 0 -lt $#; then
+      nonopt=$1
+      shift
     fi
 
-    # Darwin sucks
-    eval std_shrext=\"$shrext_cmds\"
+    # preserve --debug
+    test : = "$debug_cmd" || func_append preserve_args " --debug"
 
-    # Only execute mode is allowed to have -dlopen flags.
-    if test -n "$opt_dlopen" && test "$opt_mode" != execute; then
-      func_error "unrecognized option \`-dlopen'"
-      $ECHO "$help" 1>&2
-      exit $EXIT_FAILURE
-    fi
+    case $host in
+      # Solaris2 added to fix http://debbugs.gnu.org/cgi/bugreport.cgi?bug=16452
+      # see also: http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59788
+      *cygwin* | *mingw* | *pw32* | *cegcc* | *solaris2* | *os2*)
+        # don't eliminate duplications in $postdeps and $predeps
+        opt_duplicate_compiler_generated_deps=:
+        ;;
+      *)
+        opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps
+        ;;
+    esac
 
-    # Change the help message to a mode-specific one.
-    generic_help="$help"
-    help="Try \`$progname --help --mode=$opt_mode' for more information."
-  }
+    $opt_help || {
+      # Sanity checks first:
+      func_check_version_match
+
+      test yes != "$build_libtool_libs" \
+        && test yes != "$build_old_libs" \
+        && func_fatal_configuration "not configured to build any kind of library"
+
+      # Darwin sucks
+      eval std_shrext=\"$shrext_cmds\"
+
+      # Only execute mode is allowed to have -dlopen flags.
+      if test -n "$opt_dlopen" && test execute != "$opt_mode"; then
+        func_error "unrecognized option '-dlopen'"
+        $ECHO "$help" 1>&2
+        exit $EXIT_FAILURE
+      fi
 
+      # Change the help message to a mode-specific one.
+      generic_help=$help
+      help="Try '$progname --help --mode=$opt_mode' for more information."
+    }
 
-  # Bail if the options were screwed
-  $exit_cmd $EXIT_FAILURE
+    # Pass back the unparsed argument list
+    func_quote_for_eval ${1+"$@"}
+    libtool_validate_options_result=$func_quote_for_eval_result
 }
+func_add_hook func_validate_options libtool_validate_options
 
 
+# Process options as early as possible so that --help and --version
+# can return quickly.
+func_options ${1+"$@"}
+eval set dummy "$func_options_result"; shift
+
 
 
 ## ----------- ##
 ##    Main.    ##
 ## ----------- ##
 
+magic='%%%MAGIC variable%%%'
+magic_exe='%%%MAGIC EXE variable%%%'
+
+# Global variables.
+extracted_archives=
+extracted_serial=0
+
+# 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=
+
+
+# A function that is used when there is no print builtin or printf.
+func_fallback_echo ()
+{
+  eval 'cat <<_LTECHO_EOF
+$1
+_LTECHO_EOF'
+}
+
+# func_generated_by_libtool
+# True iff stdin has been generated by Libtool. This function is only
+# a basic sanity check; it will hardly flush out determined imposters.
+func_generated_by_libtool_p ()
+{
+  $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1
+}
+
 # func_lalib_p file
-# True iff FILE is a libtool `.la' library or `.lo' object file.
+# True iff FILE is a libtool '.la' library or '.lo' object file.
 # This function is only a basic sanity check; it will hardly flush out
 # determined imposters.
 func_lalib_p ()
 {
     test -f "$1" &&
-      $SED -e 4q "$1" 2>/dev/null \
-        | $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1
+      $SED -e 4q "$1" 2>/dev/null | func_generated_by_libtool_p
 }
 
 # func_lalib_unsafe_p file
-# True iff FILE is a libtool `.la' library or `.lo' object file.
+# True iff FILE is a libtool '.la' library or '.lo' object file.
 # This function implements the same check as func_lalib_p without
 # resorting to external programs.  To this end, it redirects stdin and
 # closes it afterwards, without saving the original file descriptor.
 # As a safety measure, use it only where a negative result would be
-# fatal anyway.  Works if `file' does not exist.
+# fatal anyway.  Works if 'file' does not exist.
 func_lalib_unsafe_p ()
 {
     lalib_p=no
@@ -1249,13 +2521,13 @@ func_lalib_unsafe_p ()
 	for lalib_p_l in 1 2 3 4
 	do
 	    read lalib_p_line
-	    case "$lalib_p_line" in
+	    case $lalib_p_line in
 		\#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;;
 	    esac
 	done
 	exec 0<&5 5<&-
     fi
-    test "$lalib_p" = yes
+    test yes = "$lalib_p"
 }
 
 # func_ltwrapper_script_p file
@@ -1264,7 +2536,8 @@ func_lalib_unsafe_p ()
 # determined imposters.
 func_ltwrapper_script_p ()
 {
-    func_lalib_p "$1"
+    test -f "$1" &&
+      $lt_truncate_bin < "$1" 2>/dev/null | func_generated_by_libtool_p
 }
 
 # func_ltwrapper_executable_p file
@@ -1289,7 +2562,7 @@ func_ltwrapper_scriptname ()
 {
     func_dirname_and_basename "$1" "" "."
     func_stripname '' '.exe' "$func_basename_result"
-    func_ltwrapper_scriptname_result="$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper"
+    func_ltwrapper_scriptname_result=$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper
 }
 
 # func_ltwrapper_p file
@@ -1308,11 +2581,13 @@ func_ltwrapper_p ()
 # FAIL_CMD may read-access the current command in variable CMD!
 func_execute_cmds ()
 {
-    $opt_debug
+    $debug_cmd
+
     save_ifs=$IFS; IFS='~'
     for cmd in $1; do
-      IFS=$save_ifs
+      IFS=$sp$nl
       eval cmd=\"$cmd\"
+      IFS=$save_ifs
       func_show_eval "$cmd" "${2-:}"
     done
     IFS=$save_ifs
@@ -1324,10 +2599,11 @@ func_execute_cmds ()
 # Note that it is not necessary on cygwin/mingw to append a dot to
 # FILE even if both FILE 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.
+# 'FILE.' does not work on cygwin managed mounts.
 func_source ()
 {
-    $opt_debug
+    $debug_cmd
+
     case $1 in
     */* | *\\*)	. "$1" ;;
     *)		. "./$1" ;;
@@ -1354,10 +2630,10 @@ func_resolve_sysroot ()
 # store the result into func_replace_sysroot_result.
 func_replace_sysroot ()
 {
-  case "$lt_sysroot:$1" in
+  case $lt_sysroot:$1 in
   ?*:"$lt_sysroot"*)
     func_stripname "$lt_sysroot" '' "$1"
-    func_replace_sysroot_result="=$func_stripname_result"
+    func_replace_sysroot_result='='$func_stripname_result
     ;;
   *)
     # Including no sysroot.
@@ -1374,7 +2650,8 @@ func_replace_sysroot ()
 # arg is usually of the form 'gcc ...'
 func_infer_tag ()
 {
-    $opt_debug
+    $debug_cmd
+
     if test -n "$available_tags" && test -z "$tagname"; then
       CC_quoted=
       for arg in $CC; do
@@ -1393,7 +2670,7 @@ func_infer_tag ()
 	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`"
+	    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.
@@ -1418,7 +2695,7 @@ func_infer_tag ()
 	# line option must be used.
 	if test -z "$tagname"; then
 	  func_echo "unable to infer tagged configuration"
-	  func_fatal_error "specify a tag with \`--tag'"
+	  func_fatal_error "specify a tag with '--tag'"
 #	else
 #	  func_verbose "using $tagname tagged configuration"
 	fi
@@ -1434,15 +2711,15 @@ func_infer_tag ()
 # but don't create it if we're doing a dry run.
 func_write_libtool_object ()
 {
-    write_libobj=${1}
-    if test "$build_libtool_libs" = yes; then
-      write_lobj=\'${2}\'
+    write_libobj=$1
+    if test yes = "$build_libtool_libs"; then
+      write_lobj=\'$2\'
     else
       write_lobj=none
     fi
 
-    if test "$build_old_libs" = yes; then
-      write_oldobj=\'${3}\'
+    if test yes = "$build_old_libs"; then
+      write_oldobj=\'$3\'
     else
       write_oldobj=none
     fi
@@ -1450,7 +2727,7 @@ func_write_libtool_object ()
     $opt_dry_run || {
       cat >${write_libobj}T <<EOF
 # $write_libobj - a libtool object file
-# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+# Generated by $PROGRAM (GNU $PACKAGE) $VERSION
 #
 # Please DO NOT delete this file!
 # It is necessary for linking the library.
@@ -1462,7 +2739,7 @@ pic_object=$write_lobj
 non_pic_object=$write_oldobj
 
 EOF
-      $MV "${write_libobj}T" "${write_libobj}"
+      $MV "${write_libobj}T" "$write_libobj"
     }
 }
 
@@ -1482,8 +2759,9 @@ EOF
 # be empty on error (or when ARG is empty)
 func_convert_core_file_wine_to_w32 ()
 {
-  $opt_debug
-  func_convert_core_file_wine_to_w32_result="$1"
+  $debug_cmd
+
+  func_convert_core_file_wine_to_w32_result=$1
   if test -n "$1"; then
     # Unfortunately, winepath does not exit with a non-zero error code, so we
     # are forced to check the contents of stdout. On the other hand, if the
@@ -1491,9 +2769,9 @@ func_convert_core_file_wine_to_w32 ()
     # *an error message* to stdout. So we must check for both error code of
     # zero AND non-empty stdout, which explains the odd construction:
     func_convert_core_file_wine_to_w32_tmp=`winepath -w "$1" 2>/dev/null`
-    if test "$?" -eq 0 && test -n "${func_convert_core_file_wine_to_w32_tmp}"; then
+    if test "$?" -eq 0 && test -n "$func_convert_core_file_wine_to_w32_tmp"; then
       func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_wine_to_w32_tmp" |
-        $SED -e "$lt_sed_naive_backslashify"`
+        $SED -e "$sed_naive_backslashify"`
     else
       func_convert_core_file_wine_to_w32_result=
     fi
@@ -1514,18 +2792,19 @@ func_convert_core_file_wine_to_w32 ()
 # are convertible, then the result may be empty.
 func_convert_core_path_wine_to_w32 ()
 {
-  $opt_debug
+  $debug_cmd
+
   # unfortunately, winepath doesn't convert paths, only file names
-  func_convert_core_path_wine_to_w32_result=""
+  func_convert_core_path_wine_to_w32_result=
   if test -n "$1"; then
     oldIFS=$IFS
     IFS=:
     for func_convert_core_path_wine_to_w32_f in $1; do
       IFS=$oldIFS
       func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f"
-      if test -n "$func_convert_core_file_wine_to_w32_result" ; then
+      if test -n "$func_convert_core_file_wine_to_w32_result"; then
         if test -z "$func_convert_core_path_wine_to_w32_result"; then
-          func_convert_core_path_wine_to_w32_result="$func_convert_core_file_wine_to_w32_result"
+          func_convert_core_path_wine_to_w32_result=$func_convert_core_file_wine_to_w32_result
         else
           func_append func_convert_core_path_wine_to_w32_result ";$func_convert_core_file_wine_to_w32_result"
         fi
@@ -1554,7 +2833,8 @@ func_convert_core_path_wine_to_w32 ()
 # environment variable; do not put it in $PATH.
 func_cygpath ()
 {
-  $opt_debug
+  $debug_cmd
+
   if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then
     func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null`
     if test "$?" -ne 0; then
@@ -1563,7 +2843,7 @@ func_cygpath ()
     fi
   else
     func_cygpath_result=
-    func_error "LT_CYGPATH is empty or specifies non-existent file: \`$LT_CYGPATH'"
+    func_error "LT_CYGPATH is empty or specifies non-existent file: '$LT_CYGPATH'"
   fi
 }
 #end: func_cygpath
@@ -1574,10 +2854,11 @@ func_cygpath ()
 # result in func_convert_core_msys_to_w32_result.
 func_convert_core_msys_to_w32 ()
 {
-  $opt_debug
+  $debug_cmd
+
   # awkward: cmd appends spaces to result
   func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null |
-    $SED -e 's/[ ]*$//' -e "$lt_sed_naive_backslashify"`
+    $SED -e 's/[ ]*$//' -e "$sed_naive_backslashify"`
 }
 #end: func_convert_core_msys_to_w32
 
@@ -1588,13 +2869,14 @@ func_convert_core_msys_to_w32 ()
 # func_to_host_file_result to ARG1).
 func_convert_file_check ()
 {
-  $opt_debug
-  if test -z "$2" && test -n "$1" ; then
+  $debug_cmd
+
+  if test -z "$2" && test -n "$1"; then
     func_error "Could not determine host file name corresponding to"
-    func_error "  \`$1'"
+    func_error "  '$1'"
     func_error "Continuing, but uninstalled executables may not work."
     # Fallback:
-    func_to_host_file_result="$1"
+    func_to_host_file_result=$1
   fi
 }
 # end func_convert_file_check
@@ -1606,10 +2888,11 @@ func_convert_file_check ()
 # func_to_host_file_result to a simplistic fallback value (see below).
 func_convert_path_check ()
 {
-  $opt_debug
+  $debug_cmd
+
   if test -z "$4" && test -n "$3"; then
     func_error "Could not determine the host path corresponding to"
-    func_error "  \`$3'"
+    func_error "  '$3'"
     func_error "Continuing, but uninstalled executables may not work."
     # Fallback.  This is a deliberately simplistic "conversion" and
     # should not be "improved".  See libtool.info.
@@ -1618,7 +2901,7 @@ func_convert_path_check ()
       func_to_host_path_result=`echo "$3" |
         $SED -e "$lt_replace_pathsep_chars"`
     else
-      func_to_host_path_result="$3"
+      func_to_host_path_result=$3
     fi
   fi
 }
@@ -1630,9 +2913,10 @@ func_convert_path_check ()
 # and appending REPL if ORIG matches BACKPAT.
 func_convert_path_front_back_pathsep ()
 {
-  $opt_debug
+  $debug_cmd
+
   case $4 in
-  $1 ) func_to_host_path_result="$3$func_to_host_path_result"
+  $1 ) func_to_host_path_result=$3$func_to_host_path_result
     ;;
   esac
   case $4 in
@@ -1646,7 +2930,7 @@ func_convert_path_front_back_pathsep ()
 ##################################################
 # $build to $host FILE NAME CONVERSION FUNCTIONS #
 ##################################################
-# invoked via `$to_host_file_cmd ARG'
+# invoked via '$to_host_file_cmd ARG'
 #
 # In each case, ARG is the path to be converted from $build to $host format.
 # Result will be available in $func_to_host_file_result.
@@ -1657,7 +2941,8 @@ func_convert_path_front_back_pathsep ()
 # in func_to_host_file_result.
 func_to_host_file ()
 {
-  $opt_debug
+  $debug_cmd
+
   $to_host_file_cmd "$1"
 }
 # end func_to_host_file
@@ -1669,7 +2954,8 @@ func_to_host_file ()
 # in (the comma separated) LAZY, no conversion takes place.
 func_to_tool_file ()
 {
-  $opt_debug
+  $debug_cmd
+
   case ,$2, in
     *,"$to_tool_file_cmd",*)
       func_to_tool_file_result=$1
@@ -1687,7 +2973,7 @@ func_to_tool_file ()
 # Copy ARG to func_to_host_file_result.
 func_convert_file_noop ()
 {
-  func_to_host_file_result="$1"
+  func_to_host_file_result=$1
 }
 # end func_convert_file_noop
 
@@ -1698,11 +2984,12 @@ func_convert_file_noop ()
 # func_to_host_file_result.
 func_convert_file_msys_to_w32 ()
 {
-  $opt_debug
-  func_to_host_file_result="$1"
+  $debug_cmd
+
+  func_to_host_file_result=$1
   if test -n "$1"; then
     func_convert_core_msys_to_w32 "$1"
-    func_to_host_file_result="$func_convert_core_msys_to_w32_result"
+    func_to_host_file_result=$func_convert_core_msys_to_w32_result
   fi
   func_convert_file_check "$1" "$func_to_host_file_result"
 }
@@ -1714,8 +3001,9 @@ func_convert_file_msys_to_w32 ()
 # func_to_host_file_result.
 func_convert_file_cygwin_to_w32 ()
 {
-  $opt_debug
-  func_to_host_file_result="$1"
+  $debug_cmd
+
+  func_to_host_file_result=$1
   if test -n "$1"; then
     # because $build is cygwin, we call "the" cygpath in $PATH; no need to use
     # LT_CYGPATH in this case.
@@ -1731,11 +3019,12 @@ func_convert_file_cygwin_to_w32 ()
 # and a working winepath. Returns result in func_to_host_file_result.
 func_convert_file_nix_to_w32 ()
 {
-  $opt_debug
-  func_to_host_file_result="$1"
+  $debug_cmd
+
+  func_to_host_file_result=$1
   if test -n "$1"; then
     func_convert_core_file_wine_to_w32 "$1"
-    func_to_host_file_result="$func_convert_core_file_wine_to_w32_result"
+    func_to_host_file_result=$func_convert_core_file_wine_to_w32_result
   fi
   func_convert_file_check "$1" "$func_to_host_file_result"
 }
@@ -1747,12 +3036,13 @@ func_convert_file_nix_to_w32 ()
 # Returns result in func_to_host_file_result.
 func_convert_file_msys_to_cygwin ()
 {
-  $opt_debug
-  func_to_host_file_result="$1"
+  $debug_cmd
+
+  func_to_host_file_result=$1
   if test -n "$1"; then
     func_convert_core_msys_to_w32 "$1"
     func_cygpath -u "$func_convert_core_msys_to_w32_result"
-    func_to_host_file_result="$func_cygpath_result"
+    func_to_host_file_result=$func_cygpath_result
   fi
   func_convert_file_check "$1" "$func_to_host_file_result"
 }
@@ -1765,13 +3055,14 @@ func_convert_file_msys_to_cygwin ()
 # in func_to_host_file_result.
 func_convert_file_nix_to_cygwin ()
 {
-  $opt_debug
-  func_to_host_file_result="$1"
+  $debug_cmd
+
+  func_to_host_file_result=$1
   if test -n "$1"; then
     # convert from *nix to w32, then use cygpath to convert from w32 to cygwin.
     func_convert_core_file_wine_to_w32 "$1"
     func_cygpath -u "$func_convert_core_file_wine_to_w32_result"
-    func_to_host_file_result="$func_cygpath_result"
+    func_to_host_file_result=$func_cygpath_result
   fi
   func_convert_file_check "$1" "$func_to_host_file_result"
 }
@@ -1781,7 +3072,7 @@ func_convert_file_nix_to_cygwin ()
 #############################################
 # $build to $host PATH CONVERSION FUNCTIONS #
 #############################################
-# invoked via `$to_host_path_cmd ARG'
+# invoked via '$to_host_path_cmd ARG'
 #
 # In each case, ARG is the path to be converted from $build to $host format.
 # The result will be available in $func_to_host_path_result.
@@ -1805,10 +3096,11 @@ func_convert_file_nix_to_cygwin ()
 to_host_path_cmd=
 func_init_to_host_path_cmd ()
 {
-  $opt_debug
+  $debug_cmd
+
   if test -z "$to_host_path_cmd"; then
     func_stripname 'func_convert_file_' '' "$to_host_file_cmd"
-    to_host_path_cmd="func_convert_path_${func_stripname_result}"
+    to_host_path_cmd=func_convert_path_$func_stripname_result
   fi
 }
 
@@ -1818,7 +3110,8 @@ func_init_to_host_path_cmd ()
 # in func_to_host_path_result.
 func_to_host_path ()
 {
-  $opt_debug
+  $debug_cmd
+
   func_init_to_host_path_cmd
   $to_host_path_cmd "$1"
 }
@@ -1829,7 +3122,7 @@ func_to_host_path ()
 # Copy ARG to func_to_host_path_result.
 func_convert_path_noop ()
 {
-  func_to_host_path_result="$1"
+  func_to_host_path_result=$1
 }
 # end func_convert_path_noop
 
@@ -1840,8 +3133,9 @@ func_convert_path_noop ()
 # func_to_host_path_result.
 func_convert_path_msys_to_w32 ()
 {
-  $opt_debug
-  func_to_host_path_result="$1"
+  $debug_cmd
+
+  func_to_host_path_result=$1
   if test -n "$1"; then
     # Remove leading and trailing path separator characters from ARG.  MSYS
     # behavior is inconsistent here; cygpath turns them into '.;' and ';.';
@@ -1849,7 +3143,7 @@ func_convert_path_msys_to_w32 ()
     func_stripname : : "$1"
     func_to_host_path_tmp1=$func_stripname_result
     func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
-    func_to_host_path_result="$func_convert_core_msys_to_w32_result"
+    func_to_host_path_result=$func_convert_core_msys_to_w32_result
     func_convert_path_check : ";" \
       "$func_to_host_path_tmp1" "$func_to_host_path_result"
     func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
@@ -1863,8 +3157,9 @@ func_convert_path_msys_to_w32 ()
 # func_to_host_file_result.
 func_convert_path_cygwin_to_w32 ()
 {
-  $opt_debug
-  func_to_host_path_result="$1"
+  $debug_cmd
+
+  func_to_host_path_result=$1
   if test -n "$1"; then
     # See func_convert_path_msys_to_w32:
     func_stripname : : "$1"
@@ -1883,14 +3178,15 @@ func_convert_path_cygwin_to_w32 ()
 # a working winepath.  Returns result in func_to_host_file_result.
 func_convert_path_nix_to_w32 ()
 {
-  $opt_debug
-  func_to_host_path_result="$1"
+  $debug_cmd
+
+  func_to_host_path_result=$1
   if test -n "$1"; then
     # See func_convert_path_msys_to_w32:
     func_stripname : : "$1"
     func_to_host_path_tmp1=$func_stripname_result
     func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1"
-    func_to_host_path_result="$func_convert_core_path_wine_to_w32_result"
+    func_to_host_path_result=$func_convert_core_path_wine_to_w32_result
     func_convert_path_check : ";" \
       "$func_to_host_path_tmp1" "$func_to_host_path_result"
     func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
@@ -1904,15 +3200,16 @@ func_convert_path_nix_to_w32 ()
 # Returns result in func_to_host_file_result.
 func_convert_path_msys_to_cygwin ()
 {
-  $opt_debug
-  func_to_host_path_result="$1"
+  $debug_cmd
+
+  func_to_host_path_result=$1
   if test -n "$1"; then
     # See func_convert_path_msys_to_w32:
     func_stripname : : "$1"
     func_to_host_path_tmp1=$func_stripname_result
     func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
     func_cygpath -u -p "$func_convert_core_msys_to_w32_result"
-    func_to_host_path_result="$func_cygpath_result"
+    func_to_host_path_result=$func_cygpath_result
     func_convert_path_check : : \
       "$func_to_host_path_tmp1" "$func_to_host_path_result"
     func_convert_path_front_back_pathsep ":*" "*:" : "$1"
@@ -1927,8 +3224,9 @@ func_convert_path_msys_to_cygwin ()
 # func_to_host_file_result.
 func_convert_path_nix_to_cygwin ()
 {
-  $opt_debug
-  func_to_host_path_result="$1"
+  $debug_cmd
+
+  func_to_host_path_result=$1
   if test -n "$1"; then
     # Remove leading and trailing path separator characters from
     # ARG. msys behavior is inconsistent here, cygpath turns them
@@ -1937,7 +3235,7 @@ func_convert_path_nix_to_cygwin ()
     func_to_host_path_tmp1=$func_stripname_result
     func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1"
     func_cygpath -u -p "$func_convert_core_path_wine_to_w32_result"
-    func_to_host_path_result="$func_cygpath_result"
+    func_to_host_path_result=$func_cygpath_result
     func_convert_path_check : : \
       "$func_to_host_path_tmp1" "$func_to_host_path_result"
     func_convert_path_front_back_pathsep ":*" "*:" : "$1"
@@ -1946,13 +3244,31 @@ func_convert_path_nix_to_cygwin ()
 # end func_convert_path_nix_to_cygwin
 
 
+# func_dll_def_p FILE
+# True iff FILE is a Windows DLL '.def' file.
+# Keep in sync with _LT_DLL_DEF_P in libtool.m4
+func_dll_def_p ()
+{
+  $debug_cmd
+
+  func_dll_def_p_tmp=`$SED -n \
+    -e 's/^[	 ]*//' \
+    -e '/^\(;.*\)*$/d' \
+    -e 's/^\(EXPORTS\|LIBRARY\)\([	 ].*\)*$/DEF/p' \
+    -e q \
+    "$1"`
+  test DEF = "$func_dll_def_p_tmp"
+}
+
+
 # func_mode_compile arg...
 func_mode_compile ()
 {
-    $opt_debug
+    $debug_cmd
+
     # Get the compilation command and the source file.
     base_compile=
-    srcfile="$nonopt"  #  always keep a non-empty value in "srcfile"
+    srcfile=$nonopt  #  always keep a non-empty value in "srcfile"
     suppress_opt=yes
     suppress_output=
     arg_mode=normal
@@ -1965,12 +3281,12 @@ func_mode_compile ()
       case $arg_mode in
       arg  )
 	# do not "continue".  Instead, add this to base_compile
-	lastarg="$arg"
+	lastarg=$arg
 	arg_mode=normal
 	;;
 
       target )
-	libobj="$arg"
+	libobj=$arg
 	arg_mode=normal
 	continue
 	;;
@@ -1980,7 +3296,7 @@ func_mode_compile ()
 	case $arg in
 	-o)
 	  test -n "$libobj" && \
-	    func_fatal_error "you cannot specify \`-o' more than once"
+	    func_fatal_error "you cannot specify '-o' more than once"
 	  arg_mode=target
 	  continue
 	  ;;
@@ -2009,12 +3325,12 @@ func_mode_compile ()
 	  func_stripname '-Wc,' '' "$arg"
 	  args=$func_stripname_result
 	  lastarg=
-	  save_ifs="$IFS"; IFS=','
+	  save_ifs=$IFS; IFS=,
 	  for arg in $args; do
-	    IFS="$save_ifs"
+	    IFS=$save_ifs
 	    func_append_quoted lastarg "$arg"
 	  done
-	  IFS="$save_ifs"
+	  IFS=$save_ifs
 	  func_stripname ' ' '' "$lastarg"
 	  lastarg=$func_stripname_result
 
@@ -2027,8 +3343,8 @@ func_mode_compile ()
 	  # Accept the current argument as the source file.
 	  # The previous "srcfile" becomes the current argument.
 	  #
-	  lastarg="$srcfile"
-	  srcfile="$arg"
+	  lastarg=$srcfile
+	  srcfile=$arg
 	  ;;
 	esac  #  case $arg
 	;;
@@ -2043,13 +3359,13 @@ func_mode_compile ()
       func_fatal_error "you must specify an argument for -Xcompile"
       ;;
     target)
-      func_fatal_error "you must specify a target with \`-o'"
+      func_fatal_error "you must specify a target with '-o'"
       ;;
     *)
       # Get the name of the library object.
       test -z "$libobj" && {
 	func_basename "$srcfile"
-	libobj="$func_basename_result"
+	libobj=$func_basename_result
       }
       ;;
     esac
@@ -2069,7 +3385,7 @@ func_mode_compile ()
     case $libobj in
     *.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;;
     *)
-      func_fatal_error "cannot determine name of library object from \`$libobj'"
+      func_fatal_error "cannot determine name of library object from '$libobj'"
       ;;
     esac
 
@@ -2078,8 +3394,8 @@ func_mode_compile ()
     for arg in $later; do
       case $arg in
       -shared)
-	test "$build_libtool_libs" != yes && \
-	  func_fatal_configuration "can not build a shared library"
+	test yes = "$build_libtool_libs" \
+	  || func_fatal_configuration "cannot build a shared library"
 	build_old_libs=no
 	continue
 	;;
@@ -2105,17 +3421,17 @@ func_mode_compile ()
     func_quote_for_eval "$libobj"
     test "X$libobj" != "X$func_quote_for_eval_result" \
       && $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"'	 &()|`$[]' \
-      && func_warning "libobj name \`$libobj' may not contain shell special characters."
+      && func_warning "libobj name '$libobj' may not contain shell special characters."
     func_dirname_and_basename "$obj" "/" ""
-    objname="$func_basename_result"
-    xdir="$func_dirname_result"
-    lobj=${xdir}$objdir/$objname
+    objname=$func_basename_result
+    xdir=$func_dirname_result
+    lobj=$xdir$objdir/$objname
 
     test -z "$base_compile" && \
       func_fatal_help "you must specify a compilation command"
 
     # Delete any leftover library objects.
-    if test "$build_old_libs" = yes; then
+    if test yes = "$build_old_libs"; then
       removelist="$obj $lobj $libobj ${libobj}T"
     else
       removelist="$lobj $libobj ${libobj}T"
@@ -2127,16 +3443,16 @@ func_mode_compile ()
       pic_mode=default
       ;;
     esac
-    if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then
+    if test no = "$pic_mode" && test pass_all != "$deplibs_check_method"; 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 "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.${objext}
-      lockfile="$output_obj.lock"
+    if test no = "$compiler_c_o"; then
+      output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.$objext
+      lockfile=$output_obj.lock
     else
       output_obj=
       need_locks=no
@@ -2145,12 +3461,12 @@ func_mode_compile ()
 
     # 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
+    if test yes = "$need_locks"; then
       until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do
 	func_echo "Waiting for $lockfile to be removed"
 	sleep 2
       done
-    elif test "$need_locks" = warn; then
+    elif test warn = "$need_locks"; then
       if test -f "$lockfile"; then
 	$ECHO "\
 *** ERROR, $lockfile exists and contains:
@@ -2158,7 +3474,7 @@ func_mode_compile ()
 
 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
+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."
@@ -2180,11 +3496,11 @@ compiler."
     qsrcfile=$func_quote_for_eval_result
 
     # Only build a PIC object if we are building libtool libraries.
-    if test "$build_libtool_libs" = yes; then
+    if test yes = "$build_libtool_libs"; then
       # Without this assignment, base_compile gets emptied.
       fbsd_hideous_sh_bug=$base_compile
 
-      if test "$pic_mode" != no; then
+      if test no != "$pic_mode"; then
 	command="$base_compile $qsrcfile $pic_flag"
       else
 	# Don't build PIC code
@@ -2201,7 +3517,7 @@ compiler."
       func_show_eval_locale "$command"	\
           'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE'
 
-      if test "$need_locks" = warn &&
+      if test warn = "$need_locks" &&
 	 test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
 	$ECHO "\
 *** ERROR, $lockfile contains:
@@ -2212,7 +3528,7 @@ $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
+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."
@@ -2228,20 +3544,20 @@ compiler."
       fi
 
       # Allow error messages only from the first compilation.
-      if test "$suppress_opt" = yes; then
+      if test yes = "$suppress_opt"; then
 	suppress_output=' >/dev/null 2>&1'
       fi
     fi
 
     # Only build a position-dependent object if we build old libraries.
-    if test "$build_old_libs" = yes; then
-      if test "$pic_mode" != yes; then
+    if test yes = "$build_old_libs"; then
+      if test yes != "$pic_mode"; then
 	# Don't build PIC code
 	command="$base_compile $qsrcfile$pie_flag"
       else
 	command="$base_compile $qsrcfile $pic_flag"
       fi
-      if test "$compiler_c_o" = yes; then
+      if test yes = "$compiler_c_o"; then
 	func_append command " -o $obj"
       fi
 
@@ -2250,7 +3566,7 @@ compiler."
       func_show_eval_locale "$command" \
         '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE'
 
-      if test "$need_locks" = warn &&
+      if test warn = "$need_locks" &&
 	 test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
 	$ECHO "\
 *** ERROR, $lockfile contains:
@@ -2261,7 +3577,7 @@ $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
+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."
@@ -2281,7 +3597,7 @@ compiler."
       func_write_libtool_object "$libobj" "$objdir/$objname" "$objname"
 
       # Unlock the critical section if it was locked
-      if test "$need_locks" != no; then
+      if test no != "$need_locks"; then
 	removelist=$lockfile
         $RM "$lockfile"
       fi
@@ -2291,7 +3607,7 @@ compiler."
 }
 
 $opt_help || {
-  test "$opt_mode" = compile && func_mode_compile ${1+"$@"}
+  test compile = "$opt_mode" && func_mode_compile ${1+"$@"}
 }
 
 func_mode_help ()
@@ -2311,7 +3627,7 @@ func_mode_help ()
 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
+(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
@@ -2330,16 +3646,16 @@ This mode accepts the following additional options:
   -no-suppress      do not suppress compiler output for multiple passes
   -prefer-pic       try to build PIC objects only
   -prefer-non-pic   try to build non-PIC objects only
-  -shared           do not build a \`.o' file suitable for static linking
-  -static           only build a \`.o' file suitable for static linking
+  -shared           do not build a '.o' file suitable for static linking
+  -static           only build a '.o' file suitable for static linking
   -Wc,FLAG          pass FLAG directly to the compiler
 
-COMPILE-COMMAND is a command to be used in creating a \`standard' object file
+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'."
+SOURCEFILE, then substituting the C source code suffix '.c' with the
+library object suffix, '.lo'."
         ;;
 
       execute)
@@ -2352,7 +3668,7 @@ 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'
+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
@@ -2371,7 +3687,7 @@ 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."
+the '--dry-run' option if you just want to see what would be executed."
         ;;
 
       install)
@@ -2381,7 +3697,7 @@ the \`--dry-run' option if you just want to see what would be executed."
 Install executables or libraries.
 
 INSTALL-COMMAND is the installation command.  The first component should be
-either the \`install' or \`cp' program.
+either the 'install' or 'cp' program.
 
 The following components of INSTALL-COMMAND are treated specially:
 
@@ -2407,7 +3723,7 @@ The following components of LINK-COMMAND are treated specially:
   -avoid-version    do not add a version suffix if possible
   -bindir BINDIR    specify path to binaries directory (for systems where
                     libraries must be found in the PATH setting at runtime)
-  -dlopen FILE      \`-dlpreopen' FILE if it cannot be dlopened at runtime
+  -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
@@ -2421,7 +3737,8 @@ The following components of LINK-COMMAND are treated specially:
   -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
+  -objectlist FILE  use a list of object files found in FILE to specify objects
+  -os2dllname NAME  force a short DLL name on OS/2 (no effect on other OSes)
   -precious-files-regex REGEX
                     don't remove output files matching REGEX
   -release RELEASE  specify package release information
@@ -2441,20 +3758,20 @@ The following components of LINK-COMMAND are treated specially:
   -Xlinker FLAG     pass linker-specific FLAG directly to the linker
   -XCClinker FLAG   pass link-specific FLAG to the compiler driver (CC)
 
-All other options (arguments beginning with \`-') are ignored.
+All other options (arguments beginning with '-') are ignored.
 
-Every other argument is treated as a filename.  Files ending in \`.la' are
+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
+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 '.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
+If OUTPUT-FILE ends in '.lo' or '.$objext', then a reloadable object file
 is created, otherwise an executable program is created."
         ;;
 
@@ -2465,7 +3782,7 @@ is created, otherwise an executable program is created."
 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
+(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.
@@ -2473,17 +3790,17 @@ Otherwise, only FILE itself is deleted using RM."
         ;;
 
       *)
-        func_fatal_help "invalid operation mode \`$opt_mode'"
+        func_fatal_help "invalid operation mode '$opt_mode'"
         ;;
     esac
 
     echo
-    $ECHO "Try \`$progname --help' for more information about other modes."
+    $ECHO "Try '$progname --help' for more information about other modes."
 }
 
 # Now that we've collected a possible --mode arg, show help if necessary
 if $opt_help; then
-  if test "$opt_help" = :; then
+  if test : = "$opt_help"; then
     func_mode_help
   else
     {
@@ -2491,7 +3808,7 @@ if $opt_help; then
       for opt_mode in compile link execute install finish uninstall clean; do
 	func_mode_help
       done
-    } | sed -n '1p; 2,$s/^Usage:/  or: /p'
+    } | $SED -n '1p; 2,$s/^Usage:/  or: /p'
     {
       func_help noexit
       for opt_mode in compile link execute install finish uninstall clean; do
@@ -2499,7 +3816,7 @@ if $opt_help; then
 	func_mode_help
       done
     } |
-    sed '1d
+    $SED '1d
       /^When reporting/,/^Report/{
 	H
 	d
@@ -2516,16 +3833,17 @@ fi
 # func_mode_execute arg...
 func_mode_execute ()
 {
-    $opt_debug
+    $debug_cmd
+
     # The first argument is the command name.
-    cmd="$nonopt"
+    cmd=$nonopt
     test -z "$cmd" && \
       func_fatal_help "you must specify a COMMAND"
 
     # Handle -dlopen flags immediately.
     for file in $opt_dlopen; do
       test -f "$file" \
-	|| func_fatal_help "\`$file' is not a file"
+	|| func_fatal_help "'$file' is not a file"
 
       dir=
       case $file in
@@ -2535,7 +3853,7 @@ func_mode_execute ()
 
 	# Check to see that this really is a libtool archive.
 	func_lalib_unsafe_p "$file" \
-	  || func_fatal_help "\`$lib' is not a valid libtool archive"
+	  || func_fatal_help "'$lib' is not a valid libtool archive"
 
 	# Read the libtool library.
 	dlname=
@@ -2546,18 +3864,18 @@ func_mode_execute ()
 	if test -z "$dlname"; then
 	  # Warn if it was a shared library.
 	  test -n "$library_names" && \
-	    func_warning "\`$file' was not linked with \`-export-dynamic'"
+	    func_warning "'$file' was not linked with '-export-dynamic'"
 	  continue
 	fi
 
 	func_dirname "$file" "" "."
-	dir="$func_dirname_result"
+	dir=$func_dirname_result
 
 	if test -f "$dir/$objdir/$dlname"; then
 	  func_append dir "/$objdir"
 	else
 	  if test ! -f "$dir/$dlname"; then
-	    func_fatal_error "cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'"
+	    func_fatal_error "cannot find '$dlname' in '$dir' or '$dir/$objdir'"
 	  fi
 	fi
 	;;
@@ -2565,18 +3883,18 @@ func_mode_execute ()
       *.lo)
 	# Just add the directory containing the .lo file.
 	func_dirname "$file" "" "."
-	dir="$func_dirname_result"
+	dir=$func_dirname_result
 	;;
 
       *)
-	func_warning "\`-dlopen' is ignored for non-libtool libraries and objects"
+	func_warning "'-dlopen' is ignored for non-libtool libraries and objects"
 	continue
 	;;
       esac
 
       # Get the absolute pathname.
       absdir=`cd "$dir" && pwd`
-      test -n "$absdir" && dir="$absdir"
+      test -n "$absdir" && dir=$absdir
 
       # Now add the directory to shlibpath_var.
       if eval "test -z \"\$$shlibpath_var\""; then
@@ -2588,7 +3906,7 @@ func_mode_execute ()
 
     # This variable tells wrapper scripts just to set shlibpath_var
     # rather than running their programs.
-    libtool_execute_magic="$magic"
+    libtool_execute_magic=$magic
 
     # Check if any of the arguments is a wrapper script.
     args=
@@ -2601,12 +3919,12 @@ func_mode_execute ()
 	if func_ltwrapper_script_p "$file"; then
 	  func_source "$file"
 	  # Transform arg to wrapped name.
-	  file="$progdir/$program"
+	  file=$progdir/$program
 	elif func_ltwrapper_executable_p "$file"; then
 	  func_ltwrapper_scriptname "$file"
 	  func_source "$func_ltwrapper_scriptname_result"
 	  # Transform arg to wrapped name.
-	  file="$progdir/$program"
+	  file=$progdir/$program
 	fi
 	;;
       esac
@@ -2614,7 +3932,15 @@ func_mode_execute ()
       func_append_quoted args "$file"
     done
 
-    if test "X$opt_dry_run" = Xfalse; then
+    if $opt_dry_run; then
+      # 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
+    else
       if test -n "$shlibpath_var"; then
 	# Export the shlibpath_var.
 	eval "export $shlibpath_var"
@@ -2631,25 +3957,18 @@ func_mode_execute ()
       done
 
       # 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
+      exec_cmd=\$cmd$args
     fi
 }
 
-test "$opt_mode" = execute && func_mode_execute ${1+"$@"}
+test execute = "$opt_mode" && func_mode_execute ${1+"$@"}
 
 
 # func_mode_finish arg...
 func_mode_finish ()
 {
-    $opt_debug
+    $debug_cmd
+
     libs=
     libdirs=
     admincmds=
@@ -2663,11 +3982,11 @@ func_mode_finish ()
 	if func_lalib_unsafe_p "$opt"; then
 	  func_append libs " $opt"
 	else
-	  func_warning "\`$opt' is not a valid libtool archive"
+	  func_warning "'$opt' is not a valid libtool archive"
 	fi
 
       else
-	func_fatal_error "invalid argument \`$opt'"
+	func_fatal_error "invalid argument '$opt'"
       fi
     done
 
@@ -2682,12 +4001,12 @@ func_mode_finish ()
       # Remove sysroot references
       if $opt_dry_run; then
         for lib in $libs; do
-          echo "removing references to $lt_sysroot and \`=' prefixes from $lib"
+          echo "removing references to $lt_sysroot and '=' prefixes from $lib"
         done
       else
         tmpdir=`func_mktempdir`
         for lib in $libs; do
-	  sed -e "${sysroot_cmd} s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \
+	  $SED -e "$sysroot_cmd s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \
 	    > $tmpdir/tmp-la
 	  mv -f $tmpdir/tmp-la $lib
 	done
@@ -2712,7 +4031,7 @@ func_mode_finish ()
     fi
 
     # Exit here if they wanted silent mode.
-    $opt_silent && exit $EXIT_SUCCESS
+    $opt_quiet && exit $EXIT_SUCCESS
 
     if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
       echo "----------------------------------------------------------------------"
@@ -2723,27 +4042,27 @@ func_mode_finish ()
       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 "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 "   - 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 "   - 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"
+	$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'"
+	echo "   - have your system administrator add LIBDIR to '/etc/ld.so.conf'"
       fi
       echo
 
@@ -2762,18 +4081,20 @@ func_mode_finish ()
     exit $EXIT_SUCCESS
 }
 
-test "$opt_mode" = finish && func_mode_finish ${1+"$@"}
+test finish = "$opt_mode" && func_mode_finish ${1+"$@"}
 
 
 # func_mode_install arg...
 func_mode_install ()
 {
-    $opt_debug
+    $debug_cmd
+
     # 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 ||
+    if test "$SHELL" = "$nonopt" || test /bin/sh = "$nonopt" ||
        # Allow the use of GNU shtool's install command.
-       case $nonopt in *shtool*) :;; *) false;; esac; then
+       case $nonopt in *shtool*) :;; *) false;; esac
+    then
       # Aesthetically quote it.
       func_quote_for_eval "$nonopt"
       install_prog="$func_quote_for_eval_result "
@@ -2800,7 +4121,7 @@ func_mode_install ()
     opts=
     prev=
     install_type=
-    isdir=no
+    isdir=false
     stripme=
     no_mode=:
     for arg
@@ -2813,7 +4134,7 @@ func_mode_install ()
       fi
 
       case $arg in
-      -d) isdir=yes ;;
+      -d) isdir=: ;;
       -f)
 	if $install_cp; then :; else
 	  prev=$arg
@@ -2831,7 +4152,7 @@ func_mode_install ()
       *)
 	# If the previous option needed an argument, then skip it.
 	if test -n "$prev"; then
-	  if test "x$prev" = x-m && test -n "$install_override_mode"; then
+	  if test X-m = "X$prev" && test -n "$install_override_mode"; then
 	    arg2=$install_override_mode
 	    no_mode=false
 	  fi
@@ -2856,7 +4177,7 @@ func_mode_install ()
       func_fatal_help "you must specify an install program"
 
     test -n "$prev" && \
-      func_fatal_help "the \`$prev' option requires an argument"
+      func_fatal_help "the '$prev' option requires an argument"
 
     if test -n "$install_override_mode" && $no_mode; then
       if $install_cp; then :; else
@@ -2878,19 +4199,19 @@ func_mode_install ()
     dest=$func_stripname_result
 
     # Check to see that the destination is a directory.
-    test -d "$dest" && isdir=yes
-    if test "$isdir" = yes; then
-      destdir="$dest"
+    test -d "$dest" && isdir=:
+    if $isdir; then
+      destdir=$dest
       destname=
     else
       func_dirname_and_basename "$dest" "" "."
-      destdir="$func_dirname_result"
-      destname="$func_basename_result"
+      destdir=$func_dirname_result
+      destname=$func_basename_result
 
       # Not a directory, so check to see that there is only one file specified.
       set dummy $files; shift
       test "$#" -gt 1 && \
-	func_fatal_help "\`$dest' is not a directory"
+	func_fatal_help "'$dest' is not a directory"
     fi
     case $destdir in
     [\\/]* | [A-Za-z]:[\\/]*) ;;
@@ -2899,7 +4220,7 @@ func_mode_install ()
 	case $file in
 	*.lo) ;;
 	*)
-	  func_fatal_help "\`$destdir' must be an absolute directory name"
+	  func_fatal_help "'$destdir' must be an absolute directory name"
 	  ;;
 	esac
       done
@@ -2908,7 +4229,7 @@ func_mode_install ()
 
     # This variable tells wrapper scripts just to set variables rather
     # than running their programs.
-    libtool_install_magic="$magic"
+    libtool_install_magic=$magic
 
     staticlibs=
     future_libdirs=
@@ -2928,7 +4249,7 @@ func_mode_install ()
 
 	# Check to see that this really is a libtool archive.
 	func_lalib_unsafe_p "$file" \
-	  || func_fatal_help "\`$file' is not a valid libtool archive"
+	  || func_fatal_help "'$file' is not a valid libtool archive"
 
 	library_names=
 	old_library=
@@ -2950,7 +4271,7 @@ func_mode_install ()
 	fi
 
 	func_dirname "$file" "/" ""
-	dir="$func_dirname_result"
+	dir=$func_dirname_result
 	func_append dir "$objdir"
 
 	if test -n "$relink_command"; then
@@ -2964,7 +4285,7 @@ func_mode_install ()
 	  # are installed into $libdir/../bin (currently, that works fine)
 	  # but it's something to keep an eye on.
 	  test "$inst_prefix_dir" = "$destdir" && \
-	    func_fatal_error "error: cannot install \`$file' to a directory not ending in $libdir"
+	    func_fatal_error "error: cannot install '$file' to a directory not ending in $libdir"
 
 	  if test -n "$inst_prefix_dir"; then
 	    # Stick the inst_prefix_dir data into the link command.
@@ -2973,29 +4294,36 @@ func_mode_install ()
 	    relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%%"`
 	  fi
 
-	  func_warning "relinking \`$file'"
+	  func_warning "relinking '$file'"
 	  func_show_eval "$relink_command" \
-	    'func_fatal_error "error: relink \`$file'\'' with the above command before installing it"'
+	    'func_fatal_error "error: relink '\''$file'\'' with the above command before installing it"'
 	fi
 
 	# See the names of the shared library.
 	set dummy $library_names; shift
 	if test -n "$1"; then
-	  realname="$1"
+	  realname=$1
 	  shift
 
-	  srcname="$realname"
-	  test -n "$relink_command" && srcname="$realname"T
+	  srcname=$realname
+	  test -n "$relink_command" && srcname=${realname}T
 
 	  # Install the shared library and build the symlinks.
 	  func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \
 	      'exit $?'
-	  tstripme="$stripme"
+	  tstripme=$stripme
 	  case $host_os in
 	  cygwin* | mingw* | pw32* | cegcc*)
 	    case $realname in
 	    *.dll.a)
-	      tstripme=""
+	      tstripme=
+	      ;;
+	    esac
+	    ;;
+	  os2*)
+	    case $realname in
+	    *_dll.a)
+	      tstripme=
 	      ;;
 	    esac
 	    ;;
@@ -3006,7 +4334,7 @@ func_mode_install ()
 
 	  if test "$#" -gt 0; then
 	    # Delete the old symlinks, and create new ones.
-	    # Try `ln -sf' first, because the `ln' binary might depend on
+	    # 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
@@ -3017,14 +4345,14 @@ func_mode_install ()
 	  fi
 
 	  # Do each command in the postinstall commands.
-	  lib="$destdir/$realname"
+	  lib=$destdir/$realname
 	  func_execute_cmds "$postinstall_cmds" 'exit $?'
 	fi
 
 	# Install the pseudo-library for information purposes.
 	func_basename "$file"
-	name="$func_basename_result"
-	instname="$dir/$name"i
+	name=$func_basename_result
+	instname=$dir/${name}i
 	func_show_eval "$install_prog $instname $destdir/$name" 'exit $?'
 
 	# Maybe install the static library, too.
@@ -3036,11 +4364,11 @@ func_mode_install ()
 
 	# Figure out destination file name, if it wasn't already specified.
 	if test -n "$destname"; then
-	  destfile="$destdir/$destname"
+	  destfile=$destdir/$destname
 	else
 	  func_basename "$file"
-	  destfile="$func_basename_result"
-	  destfile="$destdir/$destfile"
+	  destfile=$func_basename_result
+	  destfile=$destdir/$destfile
 	fi
 
 	# Deduce the name of the destination old-style object file.
@@ -3050,11 +4378,11 @@ func_mode_install ()
 	  staticdest=$func_lo2o_result
 	  ;;
 	*.$objext)
-	  staticdest="$destfile"
+	  staticdest=$destfile
 	  destfile=
 	  ;;
 	*)
-	  func_fatal_help "cannot copy a libtool object to \`$destfile'"
+	  func_fatal_help "cannot copy a libtool object to '$destfile'"
 	  ;;
 	esac
 
@@ -3063,7 +4391,7 @@ func_mode_install ()
 	  func_show_eval "$install_prog $file $destfile" 'exit $?'
 
 	# Install the old object if enabled.
-	if test "$build_old_libs" = yes; then
+	if test yes = "$build_old_libs"; then
 	  # Deduce the name of the old-style object file.
 	  func_lo2o "$file"
 	  staticobj=$func_lo2o_result
@@ -3075,23 +4403,23 @@ func_mode_install ()
       *)
 	# Figure out destination file name, if it wasn't already specified.
 	if test -n "$destname"; then
-	  destfile="$destdir/$destname"
+	  destfile=$destdir/$destname
 	else
 	  func_basename "$file"
-	  destfile="$func_basename_result"
-	  destfile="$destdir/$destfile"
+	  destfile=$func_basename_result
+	  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=""
+	stripped_ext=
 	case $file in
 	  *.exe)
 	    if test ! -f "$file"; then
 	      func_stripname '' '.exe' "$file"
 	      file=$func_stripname_result
-	      stripped_ext=".exe"
+	      stripped_ext=.exe
 	    fi
 	    ;;
 	esac
@@ -3119,19 +4447,19 @@ func_mode_install ()
 
 	  # Check the variables that should have been set.
 	  test -z "$generated_by_libtool_version" && \
-	    func_fatal_error "invalid libtool wrapper script \`$wrapper'"
+	    func_fatal_error "invalid libtool wrapper script '$wrapper'"
 
-	  finalize=yes
+	  finalize=:
 	  for lib in $notinst_deplibs; do
 	    # Check to see that each library is installed.
 	    libdir=
 	    if test -f "$lib"; then
 	      func_source "$lib"
 	    fi
-	    libfile="$libdir/"`$ECHO "$lib" | $SED 's%^.*/%%g'` ### testsuite: skip nested quoting test
+	    libfile=$libdir/`$ECHO "$lib" | $SED 's%^.*/%%g'`
 	    if test -n "$libdir" && test ! -f "$libfile"; then
-	      func_warning "\`$lib' has not been installed in \`$libdir'"
-	      finalize=no
+	      func_warning "'$lib' has not been installed in '$libdir'"
+	      finalize=false
 	    fi
 	  done
 
@@ -3139,29 +4467,29 @@ func_mode_install ()
 	  func_source "$wrapper"
 
 	  outputname=
-	  if test "$fast_install" = no && test -n "$relink_command"; then
+	  if test no = "$fast_install" && test -n "$relink_command"; then
 	    $opt_dry_run || {
-	      if test "$finalize" = yes; then
+	      if $finalize; then
 	        tmpdir=`func_mktempdir`
 		func_basename "$file$stripped_ext"
-		file="$func_basename_result"
-	        outputname="$tmpdir/$file"
+		file=$func_basename_result
+	        outputname=$tmpdir/$file
 	        # Replace the output file specification.
 	        relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$outputname"'%g'`
 
-	        $opt_silent || {
+	        $opt_quiet || {
 	          func_quote_for_expand "$relink_command"
 		  eval "func_echo $func_quote_for_expand_result"
 	        }
 	        if eval "$relink_command"; then :
 	          else
-		  func_error "error: relink \`$file' with the above command before installing it"
+		  func_error "error: relink '$file' with the above command before installing it"
 		  $opt_dry_run || ${RM}r "$tmpdir"
 		  continue
 	        fi
-	        file="$outputname"
+	        file=$outputname
 	      else
-	        func_warning "cannot relink \`$file'"
+	        func_warning "cannot relink '$file'"
 	      fi
 	    }
 	  else
@@ -3198,10 +4526,10 @@ func_mode_install ()
 
     for file in $staticlibs; do
       func_basename "$file"
-      name="$func_basename_result"
+      name=$func_basename_result
 
       # Set up the ranlib parameters.
-      oldlib="$destdir/$name"
+      oldlib=$destdir/$name
       func_to_tool_file "$oldlib" func_convert_file_msys_to_w32
       tool_oldlib=$func_to_tool_file_result
 
@@ -3216,18 +4544,18 @@ func_mode_install ()
     done
 
     test -n "$future_libdirs" && \
-      func_warning "remember to run \`$progname --finish$future_libdirs'"
+      func_warning "remember to run '$progname --finish$future_libdirs'"
 
     if test -n "$current_libdirs"; then
       # Maybe just do a dry run.
       $opt_dry_run && current_libdirs=" -n$current_libdirs"
-      exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs'
+      exec_cmd='$SHELL "$progpath" $preserve_args --finish$current_libdirs'
     else
       exit $EXIT_SUCCESS
     fi
 }
 
-test "$opt_mode" = install && func_mode_install ${1+"$@"}
+test install = "$opt_mode" && func_mode_install ${1+"$@"}
 
 
 # func_generate_dlsyms outputname originator pic_p
@@ -3235,16 +4563,17 @@ test "$opt_mode" = install && func_mode_install ${1+"$@"}
 # a dlpreopen symbol table.
 func_generate_dlsyms ()
 {
-    $opt_debug
-    my_outputname="$1"
-    my_originator="$2"
-    my_pic_p="${3-no}"
-    my_prefix=`$ECHO "$my_originator" | sed 's%[^a-zA-Z0-9]%_%g'`
+    $debug_cmd
+
+    my_outputname=$1
+    my_originator=$2
+    my_pic_p=${3-false}
+    my_prefix=`$ECHO "$my_originator" | $SED 's%[^a-zA-Z0-9]%_%g'`
     my_dlsyms=
 
-    if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
+    if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then
       if test -n "$NM" && test -n "$global_symbol_pipe"; then
-	my_dlsyms="${my_outputname}S.c"
+	my_dlsyms=${my_outputname}S.c
       else
 	func_error "not configured to extract global symbols from dlpreopened files"
       fi
@@ -3255,7 +4584,7 @@ func_generate_dlsyms ()
       "") ;;
       *.c)
 	# Discover the nlist of each of the dlfiles.
-	nlist="$output_objdir/${my_outputname}.nm"
+	nlist=$output_objdir/$my_outputname.nm
 
 	func_show_eval "$RM $nlist ${nlist}S ${nlist}T"
 
@@ -3263,34 +4592,36 @@ func_generate_dlsyms ()
 	func_verbose "creating $output_objdir/$my_dlsyms"
 
 	$opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\
-/* $my_dlsyms - symbol resolution table for \`$my_outputname' dlsym emulation. */
-/* Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION */
+/* $my_dlsyms - symbol resolution table for '$my_outputname' dlsym emulation. */
+/* Generated by $PROGRAM (GNU $PACKAGE) $VERSION */
 
 #ifdef __cplusplus
 extern \"C\" {
 #endif
 
-#if defined(__GNUC__) && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4))
+#if defined __GNUC__ && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4))
 #pragma GCC diagnostic ignored \"-Wstrict-prototypes\"
 #endif
 
 /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests.  */
-#if defined(_WIN32) || defined(__CYGWIN__) || defined(_WIN32_WCE)
-/* DATA imports from DLLs on WIN32 con't be const, because runtime
+#if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE
+/* DATA imports from DLLs on WIN32 can't be const, because runtime
    relocations are performed -- see ld's documentation on pseudo-relocs.  */
 # define LT_DLSYM_CONST
-#elif defined(__osf__)
+#elif defined __osf__
 /* This system does not cope well with relocations in const data.  */
 # define LT_DLSYM_CONST
 #else
 # define LT_DLSYM_CONST const
 #endif
 
+#define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0)
+
 /* External symbol declarations for the compiler. */\
 "
 
-	if test "$dlself" = yes; then
-	  func_verbose "generating symbol list for \`$output'"
+	if test yes = "$dlself"; then
+	  func_verbose "generating symbol list for '$output'"
 
 	  $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist"
 
@@ -3298,7 +4629,7 @@ extern \"C\" {
 	  progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP`
 	  for progfile in $progfiles; do
 	    func_to_tool_file "$progfile" func_convert_file_msys_to_w32
-	    func_verbose "extracting global C symbols from \`$func_to_tool_file_result'"
+	    func_verbose "extracting global C symbols from '$func_to_tool_file_result'"
 	    $opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_pipe >> '$nlist'"
 	  done
 
@@ -3318,10 +4649,10 @@ extern \"C\" {
 
 	  # Prepare the list of exported symbols
 	  if test -z "$export_symbols"; then
-	    export_symbols="$output_objdir/$outputname.exp"
+	    export_symbols=$output_objdir/$outputname.exp
 	    $opt_dry_run || {
 	      $RM $export_symbols
-	      eval "${SED} -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"'
+	      eval "$SED -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"'
 	      case $host in
 	      *cygwin* | *mingw* | *cegcc* )
                 eval "echo EXPORTS "'> "$output_objdir/$outputname.def"'
@@ -3331,7 +4662,7 @@ extern \"C\" {
 	    }
 	  else
 	    $opt_dry_run || {
-	      eval "${SED} -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"'
+	      eval "$SED -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"'
 	      eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T'
 	      eval '$MV "$nlist"T "$nlist"'
 	      case $host in
@@ -3345,22 +4676,22 @@ extern \"C\" {
 	fi
 
 	for dlprefile in $dlprefiles; do
-	  func_verbose "extracting global C symbols from \`$dlprefile'"
+	  func_verbose "extracting global C symbols from '$dlprefile'"
 	  func_basename "$dlprefile"
-	  name="$func_basename_result"
+	  name=$func_basename_result
           case $host in
 	    *cygwin* | *mingw* | *cegcc* )
 	      # if an import library, we need to obtain dlname
 	      if func_win32_import_lib_p "$dlprefile"; then
 	        func_tr_sh "$dlprefile"
 	        eval "curr_lafile=\$libfile_$func_tr_sh_result"
-	        dlprefile_dlbasename=""
+	        dlprefile_dlbasename=
 	        if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then
 	          # Use subshell, to avoid clobbering current variable values
 	          dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"`
-	          if test -n "$dlprefile_dlname" ; then
+	          if test -n "$dlprefile_dlname"; then
 	            func_basename "$dlprefile_dlname"
-	            dlprefile_dlbasename="$func_basename_result"
+	            dlprefile_dlbasename=$func_basename_result
 	          else
 	            # no lafile. user explicitly requested -dlpreopen <import library>.
 	            $sharedlib_from_linklib_cmd "$dlprefile"
@@ -3368,7 +4699,7 @@ extern \"C\" {
 	          fi
 	        fi
 	        $opt_dry_run || {
-	          if test -n "$dlprefile_dlbasename" ; then
+	          if test -n "$dlprefile_dlbasename"; then
 	            eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"'
 	          else
 	            func_warning "Could not compute DLL name from $name"
@@ -3424,6 +4755,11 @@ extern \"C\" {
 	    echo '/* NONE */' >> "$output_objdir/$my_dlsyms"
 	  fi
 
+	  func_show_eval '$RM "${nlist}I"'
+	  if test -n "$global_symbol_to_import"; then
+	    eval "$global_symbol_to_import"' < "$nlist"S > "$nlist"I'
+	  fi
+
 	  echo >> "$output_objdir/$my_dlsyms" "\
 
 /* The mapping between symbol names and symbols.  */
@@ -3432,11 +4768,30 @@ typedef struct {
   void *address;
 } lt_dlsymlist;
 extern LT_DLSYM_CONST lt_dlsymlist
-lt_${my_prefix}_LTX_preloaded_symbols[];
+lt_${my_prefix}_LTX_preloaded_symbols[];\
+"
+
+	  if test -s "$nlist"I; then
+	    echo >> "$output_objdir/$my_dlsyms" "\
+static void lt_syminit(void)
+{
+  LT_DLSYM_CONST lt_dlsymlist *symbol = lt_${my_prefix}_LTX_preloaded_symbols;
+  for (; symbol->name; ++symbol)
+    {"
+	    $SED 's/.*/      if (STREQ (symbol->name, \"&\")) symbol->address = (void *) \&&;/' < "$nlist"I >> "$output_objdir/$my_dlsyms"
+	    echo >> "$output_objdir/$my_dlsyms" "\
+    }
+}"
+	  fi
+	  echo >> "$output_objdir/$my_dlsyms" "\
 LT_DLSYM_CONST lt_dlsymlist
 lt_${my_prefix}_LTX_preloaded_symbols[] =
-{\
-  { \"$my_originator\", (void *) 0 },"
+{ {\"$my_originator\", (void *) 0},"
+
+	  if test -s "$nlist"I; then
+	    echo >> "$output_objdir/$my_dlsyms" "\
+  {\"@INIT@\", (void *) &lt_syminit},"
+	  fi
 
 	  case $need_lib_prefix in
 	  no)
@@ -3478,9 +4833,7 @@ static const void *lt_preloaded_setup() {
 	  *-*-hpux*)
 	    pic_flag_for_symtable=" $pic_flag"  ;;
 	  *)
-	    if test "X$my_pic_p" != Xno; then
-	      pic_flag_for_symtable=" $pic_flag"
-	    fi
+	    $my_pic_p && pic_flag_for_symtable=" $pic_flag"
 	    ;;
 	  esac
 	  ;;
@@ -3497,10 +4850,10 @@ static const void *lt_preloaded_setup() {
 	func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?'
 
 	# Clean up the generated files.
-	func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T"'
+	func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T" "${nlist}I"'
 
 	# Transform the symbol file into the correct name.
-	symfileobj="$output_objdir/${my_outputname}S.$objext"
+	symfileobj=$output_objdir/${my_outputname}S.$objext
 	case $host in
 	*cygwin* | *mingw* | *cegcc* )
 	  if test -f "$output_objdir/$my_outputname.def"; then
@@ -3518,7 +4871,7 @@ static const void *lt_preloaded_setup() {
 	esac
 	;;
       *)
-	func_fatal_error "unknown suffix for \`$my_dlsyms'"
+	func_fatal_error "unknown suffix for '$my_dlsyms'"
 	;;
       esac
     else
@@ -3532,6 +4885,32 @@ static const void *lt_preloaded_setup() {
     fi
 }
 
+# func_cygming_gnu_implib_p ARG
+# This predicate returns with zero status (TRUE) if
+# ARG is a GNU/binutils-style import library. Returns
+# with nonzero status (FALSE) otherwise.
+func_cygming_gnu_implib_p ()
+{
+  $debug_cmd
+
+  func_to_tool_file "$1" func_convert_file_msys_to_w32
+  func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'`
+  test -n "$func_cygming_gnu_implib_tmp"
+}
+
+# func_cygming_ms_implib_p ARG
+# This predicate returns with zero status (TRUE) if
+# ARG is an MS-style import library. Returns
+# with nonzero status (FALSE) otherwise.
+func_cygming_ms_implib_p ()
+{
+  $debug_cmd
+
+  func_to_tool_file "$1" func_convert_file_msys_to_w32
+  func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'`
+  test -n "$func_cygming_ms_implib_tmp"
+}
+
 # func_win32_libid arg
 # return the library type of file 'arg'
 #
@@ -3541,8 +4920,9 @@ static const void *lt_preloaded_setup() {
 # Despite the name, also deal with 64 bit binaries.
 func_win32_libid ()
 {
-  $opt_debug
-  win32_libid_type="unknown"
+  $debug_cmd
+
+  win32_libid_type=unknown
   win32_fileres=`file -L $1 2>/dev/null`
   case $win32_fileres in
   *ar\ archive\ import\ library*) # definitely import
@@ -3552,16 +4932,29 @@ func_win32_libid ()
     # Keep the egrep pattern in sync with the one in _LT_CHECK_MAGIC_METHOD.
     if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null |
        $EGREP 'file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' >/dev/null; then
-      func_to_tool_file "$1" func_convert_file_msys_to_w32
-      win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" |
-	$SED -n -e '
+      case $nm_interface in
+      "MS dumpbin")
+	if func_cygming_ms_implib_p "$1" ||
+	   func_cygming_gnu_implib_p "$1"
+	then
+	  win32_nmres=import
+	else
+	  win32_nmres=
+	fi
+	;;
+      *)
+	func_to_tool_file "$1" func_convert_file_msys_to_w32
+	win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" |
+	  $SED -n -e '
 	    1,100{
 		/ I /{
-		    s,.*,import,
+		    s|.*|import|
 		    p
 		    q
 		}
 	    }'`
+	;;
+      esac
       case $win32_nmres in
       import*)  win32_libid_type="x86 archive import";;
       *)        win32_libid_type="x86 archive static";;
@@ -3593,7 +4986,8 @@ func_win32_libid ()
 #    $sharedlib_from_linklib_result
 func_cygming_dll_for_implib ()
 {
-  $opt_debug
+  $debug_cmd
+
   sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"`
 }
 
@@ -3610,7 +5004,8 @@ func_cygming_dll_for_implib ()
 # specified import library.
 func_cygming_dll_for_implib_fallback_core ()
 {
-  $opt_debug
+  $debug_cmd
+
   match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"`
   $OBJDUMP -s --section "$1" "$2" 2>/dev/null |
     $SED '/^Contents of section '"$match_literal"':/{
@@ -3646,8 +5041,8 @@ func_cygming_dll_for_implib_fallback_core ()
       /./p' |
     # we now have a list, one entry per line, of the stringified
     # contents of the appropriate section of all members of the
-    # archive which possess that section. Heuristic: eliminate
-    # all those which have a first or second character that is
+    # archive that possess that section. Heuristic: eliminate
+    # all those that have a first or second character that is
     # a '.' (that is, objdump's representation of an unprintable
     # character.) This should work for all archives with less than
     # 0x302f exports -- but will fail for DLLs whose name actually
@@ -3658,30 +5053,6 @@ func_cygming_dll_for_implib_fallback_core ()
     $SED -e '/^\./d;/^.\./d;q'
 }
 
-# func_cygming_gnu_implib_p ARG
-# This predicate returns with zero status (TRUE) if
-# ARG is a GNU/binutils-style import library. Returns
-# with nonzero status (FALSE) otherwise.
-func_cygming_gnu_implib_p ()
-{
-  $opt_debug
-  func_to_tool_file "$1" func_convert_file_msys_to_w32
-  func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'`
-  test -n "$func_cygming_gnu_implib_tmp"
-}
-
-# func_cygming_ms_implib_p ARG
-# This predicate returns with zero status (TRUE) if
-# ARG is an MS-style import library. Returns
-# with nonzero status (FALSE) otherwise.
-func_cygming_ms_implib_p ()
-{
-  $opt_debug
-  func_to_tool_file "$1" func_convert_file_msys_to_w32
-  func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'`
-  test -n "$func_cygming_ms_implib_tmp"
-}
-
 # func_cygming_dll_for_implib_fallback ARG
 # Platform-specific function to extract the
 # name of the DLL associated with the specified
@@ -3695,16 +5066,17 @@ func_cygming_ms_implib_p ()
 #    $sharedlib_from_linklib_result
 func_cygming_dll_for_implib_fallback ()
 {
-  $opt_debug
-  if func_cygming_gnu_implib_p "$1" ; then
+  $debug_cmd
+
+  if func_cygming_gnu_implib_p "$1"; then
     # binutils import library
     sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$7' "$1"`
-  elif func_cygming_ms_implib_p "$1" ; then
+  elif func_cygming_ms_implib_p "$1"; then
     # ms-generated import library
     sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$6' "$1"`
   else
     # unknown
-    sharedlib_from_linklib_result=""
+    sharedlib_from_linklib_result=
   fi
 }
 
@@ -3712,10 +5084,11 @@ func_cygming_dll_for_implib_fallback ()
 # func_extract_an_archive dir oldlib
 func_extract_an_archive ()
 {
-    $opt_debug
-    f_ex_an_ar_dir="$1"; shift
-    f_ex_an_ar_oldlib="$1"
-    if test "$lock_old_archive_extraction" = yes; then
+    $debug_cmd
+
+    f_ex_an_ar_dir=$1; shift
+    f_ex_an_ar_oldlib=$1
+    if test yes = "$lock_old_archive_extraction"; then
       lockfile=$f_ex_an_ar_oldlib.lock
       until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do
 	func_echo "Waiting for $lockfile to be removed"
@@ -3724,7 +5097,7 @@ func_extract_an_archive ()
     fi
     func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \
 		   'stat=$?; rm -f "$lockfile"; exit $stat'
-    if test "$lock_old_archive_extraction" = yes; then
+    if test yes = "$lock_old_archive_extraction"; then
       $opt_dry_run || rm -f "$lockfile"
     fi
     if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then
@@ -3738,22 +5111,23 @@ func_extract_an_archive ()
 # func_extract_archives gentop oldlib ...
 func_extract_archives ()
 {
-    $opt_debug
-    my_gentop="$1"; shift
+    $debug_cmd
+
+    my_gentop=$1; shift
     my_oldlibs=${1+"$@"}
-    my_oldobjs=""
-    my_xlib=""
-    my_xabs=""
-    my_xdir=""
+    my_oldobjs=
+    my_xlib=
+    my_xabs=
+    my_xdir=
 
     for my_xlib in $my_oldlibs; do
       # Extract the objects.
       case $my_xlib in
-	[\\/]* | [A-Za-z]:[\\/]*) my_xabs="$my_xlib" ;;
+	[\\/]* | [A-Za-z]:[\\/]*) my_xabs=$my_xlib ;;
 	*) my_xabs=`pwd`"/$my_xlib" ;;
       esac
       func_basename "$my_xlib"
-      my_xlib="$func_basename_result"
+      my_xlib=$func_basename_result
       my_xlib_u=$my_xlib
       while :; do
         case " $extracted_archives " in
@@ -3765,7 +5139,7 @@ func_extract_archives ()
 	esac
       done
       extracted_archives="$extracted_archives $my_xlib_u"
-      my_xdir="$my_gentop/$my_xlib_u"
+      my_xdir=$my_gentop/$my_xlib_u
 
       func_mkdir_p "$my_xdir"
 
@@ -3778,22 +5152,23 @@ func_extract_archives ()
 	  cd $my_xdir || exit $?
 	  darwin_archive=$my_xabs
 	  darwin_curdir=`pwd`
-	  darwin_base_archive=`basename "$darwin_archive"`
+	  func_basename "$darwin_archive"
+	  darwin_base_archive=$func_basename_result
 	  darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true`
 	  if test -n "$darwin_arches"; then
 	    darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'`
 	    darwin_arch=
 	    func_verbose "$darwin_base_archive has multiple architectures $darwin_arches"
-	    for darwin_arch in  $darwin_arches ; do
-	      func_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}"
+	    for darwin_arch in  $darwin_arches; do
+	      func_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}"
+	      $RM "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive"
 	    done # $darwin_arches
             ## Okay now we've a bunch of thin objects, gotta fatten them up :)
-	    darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$basename" | sort -u`
+	    darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$sed_basename" | sort -u`
 	    darwin_file=
 	    darwin_files=
 	    for darwin_file in $darwin_filelist; do
@@ -3815,7 +5190,7 @@ func_extract_archives ()
       my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | sort | $NL2SP`
     done
 
-    func_extract_archives_result="$my_oldobjs"
+    func_extract_archives_result=$my_oldobjs
 }
 
 
@@ -3830,7 +5205,7 @@ func_extract_archives ()
 #
 # ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR
 # variable will take.  If 'yes', then the emitted script
-# will assume that the directory in which it is stored is
+# will assume that the directory where it is stored is
 # the $objdir directory.  This is a cygwin/mingw-specific
 # behavior.
 func_emit_wrapper ()
@@ -3841,7 +5216,7 @@ func_emit_wrapper ()
 #! $SHELL
 
 # $output - temporary wrapper script for $objdir/$outputname
-# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+# Generated by $PROGRAM (GNU $PACKAGE) $VERSION
 #
 # The $output program cannot be directly executed until all the libtool
 # libraries that it depends on are installed.
@@ -3898,9 +5273,9 @@ _LTECHO_EOF'
 
 # Very basic option parsing. These options are (a) specific to
 # the libtool wrapper, (b) are identical between the wrapper
-# /script/ and the wrapper /executable/ which is used only on
+# /script/ and the wrapper /executable/ that is used only on
 # windows platforms, and (c) all begin with the string "--lt-"
-# (application programs are unlikely to have options which match
+# (application programs are unlikely to have options that match
 # this pattern).
 #
 # There are only two supported options: --lt-debug and
@@ -3933,7 +5308,7 @@ func_parse_lt_options ()
 
   # Print the debug banner immediately:
   if test -n \"\$lt_option_debug\"; then
-    echo \"${outputname}:${output}:\${LINENO}: libtool wrapper (GNU $PACKAGE$TIMESTAMP) $VERSION\" 1>&2
+    echo \"$outputname:$output:\$LINENO: libtool wrapper (GNU $PACKAGE) $VERSION\" 1>&2
   fi
 }
 
@@ -3944,7 +5319,7 @@ func_lt_dump_args ()
   lt_dump_args_N=1;
   for lt_arg
   do
-    \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[\$lt_dump_args_N]: \$lt_arg\"
+    \$ECHO \"$outputname:$output:\$LINENO: newargv[\$lt_dump_args_N]: \$lt_arg\"
     lt_dump_args_N=\`expr \$lt_dump_args_N + 1\`
   done
 }
@@ -3958,7 +5333,7 @@ func_exec_program_core ()
   *-*-mingw | *-*-os2* | *-cegcc*)
     $ECHO "\
       if test -n \"\$lt_option_debug\"; then
-        \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[0]: \$progdir\\\\\$program\" 1>&2
+        \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir\\\\\$program\" 1>&2
         func_lt_dump_args \${1+\"\$@\"} 1>&2
       fi
       exec \"\$progdir\\\\\$program\" \${1+\"\$@\"}
@@ -3968,7 +5343,7 @@ func_exec_program_core ()
   *)
     $ECHO "\
       if test -n \"\$lt_option_debug\"; then
-        \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[0]: \$progdir/\$program\" 1>&2
+        \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir/\$program\" 1>&2
         func_lt_dump_args \${1+\"\$@\"} 1>&2
       fi
       exec \"\$progdir/\$program\" \${1+\"\$@\"}
@@ -4043,13 +5418,13 @@ func_exec_program ()
   test -n \"\$absdir\" && thisdir=\"\$absdir\"
 "
 
-	if test "$fast_install" = yes; then
+	if test yes = "$fast_install"; then
 	  $ECHO "\
   program=lt-'$outputname'$exeext
   progdir=\"\$thisdir/$objdir\"
 
   if test ! -f \"\$progdir/\$program\" ||
-     { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | ${SED} 1q\`; \\
+     { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | $SED 1q\`; \\
        test \"X\$file\" != \"X\$progdir/\$program\"; }; then
 
     file=\"\$\$-\$program\"
@@ -4066,7 +5441,7 @@ func_exec_program ()
     if test -n \"\$relink_command\"; then
       if relink_command_output=\`eval \$relink_command 2>&1\`; then :
       else
-	$ECHO \"\$relink_command_output\" >&2
+	\$ECHO \"\$relink_command_output\" >&2
 	$RM \"\$progdir/\$file\"
 	exit 1
       fi
@@ -4101,7 +5476,7 @@ func_exec_program ()
 	fi
 
 	# Export our shlibpath_var if we have one.
-	if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
+	if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
 	  $ECHO "\
     # Add our own library path to $shlibpath_var
     $shlibpath_var=\"$temp_rpath\$$shlibpath_var\"
@@ -4121,7 +5496,7 @@ func_exec_program ()
     fi
   else
     # The program doesn't exist.
-    \$ECHO \"\$0: error: \\\`\$progdir/\$program' does not exist\" 1>&2
+    \$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 1
@@ -4140,7 +5515,7 @@ func_emit_cwrapperexe_src ()
 	cat <<EOF
 
 /* $cwrappersource - temporary wrapper executable for $objdir/$outputname
-   Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+   Generated by $PROGRAM (GNU $PACKAGE) $VERSION
 
    The $output program cannot be directly executed until all the libtool
    libraries that it depends on are installed.
@@ -4175,47 +5550,45 @@ EOF
 #include <fcntl.h>
 #include <sys/stat.h>
 
+#define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0)
+
 /* declarations of non-ANSI functions */
-#if defined(__MINGW32__)
+#if defined __MINGW32__
 # ifdef __STRICT_ANSI__
 int _putenv (const char *);
 # endif
-#elif defined(__CYGWIN__)
+#elif defined __CYGWIN__
 # ifdef __STRICT_ANSI__
 char *realpath (const char *, char *);
 int putenv (char *);
 int setenv (const char *, const char *, int);
 # endif
-/* #elif defined (other platforms) ... */
+/* #elif defined other_platform || defined ... */
 #endif
 
 /* portability defines, excluding path handling macros */
-#if defined(_MSC_VER)
+#if defined _MSC_VER
 # define setmode _setmode
 # define stat    _stat
 # define chmod   _chmod
 # define getcwd  _getcwd
 # define putenv  _putenv
 # define S_IXUSR _S_IEXEC
-# ifndef _INTPTR_T_DEFINED
-#  define _INTPTR_T_DEFINED
-#  define intptr_t int
-# endif
-#elif defined(__MINGW32__)
+#elif defined __MINGW32__
 # define setmode _setmode
 # define stat    _stat
 # define chmod   _chmod
 # define getcwd  _getcwd
 # define putenv  _putenv
-#elif defined(__CYGWIN__)
+#elif defined __CYGWIN__
 # define HAVE_SETENV
 # define FOPEN_WB "wb"
-/* #elif defined (other platforms) ... */
+/* #elif defined other platforms ... */
 #endif
 
-#if defined(PATH_MAX)
+#if defined PATH_MAX
 # define LT_PATHMAX PATH_MAX
-#elif defined(MAXPATHLEN)
+#elif defined MAXPATHLEN
 # define LT_PATHMAX MAXPATHLEN
 #else
 # define LT_PATHMAX 1024
@@ -4234,8 +5607,8 @@ int setenv (const char *, const char *, int);
 # define PATH_SEPARATOR ':'
 #endif
 
-#if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \
-  defined (__OS2__)
+#if defined _WIN32 || defined __MSDOS__ || defined __DJGPP__ || \
+  defined __OS2__
 # define HAVE_DOS_BASED_FILE_SYSTEM
 # define FOPEN_WB "wb"
 # ifndef DIR_SEPARATOR_2
@@ -4268,10 +5641,10 @@ int setenv (const char *, const char *, int);
 
 #define XMALLOC(type, num)      ((type *) xmalloc ((num) * sizeof(type)))
 #define XFREE(stale) do { \
-  if (stale) { free ((void *) stale); stale = 0; } \
+  if (stale) { free (stale); stale = 0; } \
 } while (0)
 
-#if defined(LT_DEBUGWRAPPER)
+#if defined LT_DEBUGWRAPPER
 static int lt_debug = 1;
 #else
 static int lt_debug = 0;
@@ -4300,11 +5673,16 @@ void lt_dump_script (FILE *f);
 EOF
 
 	    cat <<EOF
-volatile const char * MAGIC_EXE = "$magic_exe";
+#if __GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 5)
+# define externally_visible volatile
+#else
+# define externally_visible __attribute__((externally_visible)) volatile
+#endif
+externally_visible const char * MAGIC_EXE = "$magic_exe";
 const char * LIB_PATH_VARNAME = "$shlibpath_var";
 EOF
 
-	    if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
+	    if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
               func_to_host_path "$temp_rpath"
 	      cat <<EOF
 const char * LIB_PATH_VALUE   = "$func_to_host_path_result";
@@ -4328,7 +5706,7 @@ const char * EXE_PATH_VALUE   = "";
 EOF
 	    fi
 
-	    if test "$fast_install" = yes; then
+	    if test yes = "$fast_install"; then
 	      cat <<EOF
 const char * TARGET_PROGRAM_NAME = "lt-$outputname"; /* hopefully, no .exe */
 EOF
@@ -4357,12 +5735,12 @@ main (int argc, char *argv[])
   char *actual_cwrapper_name;
   char *target_name;
   char *lt_argv_zero;
-  intptr_t rval = 127;
+  int rval = 127;
 
   int i;
 
   program_name = (char *) xstrdup (base_name (argv[0]));
-  newargz = XMALLOC (char *, argc + 1);
+  newargz = XMALLOC (char *, (size_t) argc + 1);
 
   /* very simple arg parsing; don't want to rely on getopt
    * also, copy all non cwrapper options to newargz, except
@@ -4371,10 +5749,10 @@ main (int argc, char *argv[])
   newargc=0;
   for (i = 1; i < argc; i++)
     {
-      if (strcmp (argv[i], dumpscript_opt) == 0)
+      if (STREQ (argv[i], dumpscript_opt))
 	{
 EOF
-	    case "$host" in
+	    case $host in
 	      *mingw* | *cygwin* )
 		# make stdout use "unix" line endings
 		echo "          setmode(1,_O_BINARY);"
@@ -4385,12 +5763,12 @@ EOF
 	  lt_dump_script (stdout);
 	  return 0;
 	}
-      if (strcmp (argv[i], debug_opt) == 0)
+      if (STREQ (argv[i], debug_opt))
 	{
           lt_debug = 1;
           continue;
 	}
-      if (strcmp (argv[i], ltwrapper_option_prefix) == 0)
+      if (STREQ (argv[i], ltwrapper_option_prefix))
         {
           /* however, if there is an option in the LTWRAPPER_OPTION_PREFIX
              namespace, but it is not one of the ones we know about and
@@ -4413,7 +5791,7 @@ EOF
 EOF
 	    cat <<EOF
   /* The GNU banner must be the first non-error debug message */
-  lt_debugprintf (__FILE__, __LINE__, "libtool wrapper (GNU $PACKAGE$TIMESTAMP) $VERSION\n");
+  lt_debugprintf (__FILE__, __LINE__, "libtool wrapper (GNU $PACKAGE) $VERSION\n");
 EOF
 	    cat <<"EOF"
   lt_debugprintf (__FILE__, __LINE__, "(main) argv[0]: %s\n", argv[0]);
@@ -4524,7 +5902,7 @@ EOF
 		cat <<"EOF"
   /* execv doesn't actually work on mingw as expected on unix */
   newargz = prepare_spawn (newargz);
-  rval = _spawnv (_P_WAIT, lt_argv_zero, (const char * const *) newargz);
+  rval = (int) _spawnv (_P_WAIT, lt_argv_zero, (const char * const *) newargz);
   if (rval == -1)
     {
       /* failed to start process */
@@ -4569,7 +5947,7 @@ base_name (const char *name)
 {
   const char *base;
 
-#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
+#if defined HAVE_DOS_BASED_FILE_SYSTEM
   /* Skip over the disk name in MSDOS pathnames. */
   if (isalpha ((unsigned char) name[0]) && name[1] == ':')
     name += 2;
@@ -4628,7 +6006,7 @@ find_executable (const char *wrapper)
   const char *p_next;
   /* static buffer for getcwd */
   char tmp[LT_PATHMAX + 1];
-  int tmp_len;
+  size_t tmp_len;
   char *concat_name;
 
   lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n",
@@ -4638,7 +6016,7 @@ find_executable (const char *wrapper)
     return NULL;
 
   /* Absolute path? */
-#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
+#if defined HAVE_DOS_BASED_FILE_SYSTEM
   if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':')
     {
       concat_name = xstrdup (wrapper);
@@ -4656,7 +6034,7 @@ find_executable (const char *wrapper)
 	    return concat_name;
 	  XFREE (concat_name);
 	}
-#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
+#if defined HAVE_DOS_BASED_FILE_SYSTEM
     }
 #endif
 
@@ -4679,7 +6057,7 @@ find_executable (const char *wrapper)
 	      for (q = p; *q; q++)
 		if (IS_PATH_SEPARATOR (*q))
 		  break;
-	      p_len = q - p;
+	      p_len = (size_t) (q - p);
 	      p_next = (*q == '\0' ? q : q + 1);
 	      if (p_len == 0)
 		{
@@ -4798,7 +6176,7 @@ strendzap (char *str, const char *pat)
   if (patlen <= len)
     {
       str += len - patlen;
-      if (strcmp (str, pat) == 0)
+      if (STREQ (str, pat))
 	*str = '\0';
     }
   return str;
@@ -4863,7 +6241,7 @@ lt_setenv (const char *name, const char *value)
     char *str = xstrdup (value);
     setenv (name, str, 1);
 #else
-    int len = strlen (name) + 1 + strlen (value) + 1;
+    size_t len = strlen (name) + 1 + strlen (value) + 1;
     char *str = XMALLOC (char, len);
     sprintf (str, "%s=%s", name, value);
     if (putenv (str) != EXIT_SUCCESS)
@@ -4880,8 +6258,8 @@ lt_extend_str (const char *orig_value, const char *add, int to_end)
   char *new_value;
   if (orig_value && *orig_value)
     {
-      int orig_value_len = strlen (orig_value);
-      int add_len = strlen (add);
+      size_t orig_value_len = strlen (orig_value);
+      size_t add_len = strlen (add);
       new_value = XMALLOC (char, add_len + orig_value_len + 1);
       if (to_end)
         {
@@ -4912,10 +6290,10 @@ lt_update_exe_path (const char *name, const char *value)
     {
       char *new_value = lt_extend_str (getenv (name), value, 0);
       /* some systems can't cope with a ':'-terminated path #' */
-      int len = strlen (new_value);
-      while (((len = strlen (new_value)) > 0) && IS_PATH_SEPARATOR (new_value[len-1]))
+      size_t len = strlen (new_value);
+      while ((len > 0) && IS_PATH_SEPARATOR (new_value[len-1]))
         {
-          new_value[len-1] = '\0';
+          new_value[--len] = '\0';
         }
       lt_setenv (name, new_value);
       XFREE (new_value);
@@ -5082,27 +6460,47 @@ EOF
 # True if ARG is an import lib, as indicated by $file_magic_cmd
 func_win32_import_lib_p ()
 {
-    $opt_debug
+    $debug_cmd
+
     case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in
     *import*) : ;;
     *) false ;;
     esac
 }
 
+# func_suncc_cstd_abi
+# !!ONLY CALL THIS FOR SUN CC AFTER $compile_command IS FULLY EXPANDED!!
+# Several compiler flags select an ABI that is incompatible with the
+# Cstd library. Avoid specifying it if any are in CXXFLAGS.
+func_suncc_cstd_abi ()
+{
+    $debug_cmd
+
+    case " $compile_command " in
+    *" -compat=g "*|*\ -std=c++[0-9][0-9]\ *|*" -library=stdcxx4 "*|*" -library=stlport4 "*)
+      suncc_use_cstd_abi=no
+      ;;
+    *)
+      suncc_use_cstd_abi=yes
+      ;;
+    esac
+}
+
 # func_mode_link arg...
 func_mode_link ()
 {
-    $opt_debug
+    $debug_cmd
+
     case $host in
     *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
       # It is impossible to link a dll without this setting, and
       # we shouldn't force the makefile maintainer to figure out
-      # which system we are compiling for in order to pass an extra
+      # what system we are compiling for in order to pass an extra
       # flag for every libtool invocation.
       # allow_undefined=no
 
       # FIXME: Unfortunately, there are problems with the above when trying
-      # to make a dll which has undefined symbols, in which case not
+      # to make a dll that has undefined symbols, in which case not
       # even a static library is built.  For now, we need to specify
       # -no-undefined on the libtool link line when we can be certain
       # that all symbols are satisfied, otherwise we get a static library.
@@ -5146,10 +6544,11 @@ func_mode_link ()
     module=no
     no_install=no
     objs=
+    os2dllname=
     non_pic_objects=
     precious_files_regex=
     prefer_static_libs=no
-    preload=no
+    preload=false
     prev=
     prevarg=
     release=
@@ -5161,7 +6560,7 @@ func_mode_link ()
     vinfo=
     vinfo_number=no
     weak_libs=
-    single_module="${wl}-single_module"
+    single_module=$wl-single_module
     func_infer_tag $base_compile
 
     # We need to know -static, to get the right output filenames.
@@ -5169,15 +6568,15 @@ func_mode_link ()
     do
       case $arg in
       -shared)
-	test "$build_libtool_libs" != yes && \
-	  func_fatal_configuration "can not build a shared library"
+	test yes != "$build_libtool_libs" \
+	  && func_fatal_configuration "cannot build a shared library"
 	build_old_libs=no
 	break
 	;;
       -all-static | -static | -static-libtool-libs)
 	case $arg in
 	-all-static)
-	  if test "$build_libtool_libs" = yes && test -z "$link_static_flag"; then
+	  if test yes = "$build_libtool_libs" && test -z "$link_static_flag"; then
 	    func_warning "complete static linking is impossible in this configuration"
 	  fi
 	  if test -n "$link_static_flag"; then
@@ -5210,7 +6609,7 @@ func_mode_link ()
 
     # Go through the arguments, transforming them on the way.
     while test "$#" -gt 0; do
-      arg="$1"
+      arg=$1
       shift
       func_quote_for_eval "$arg"
       qarg=$func_quote_for_eval_unquoted_result
@@ -5227,21 +6626,21 @@ func_mode_link ()
 
 	case $prev in
 	bindir)
-	  bindir="$arg"
+	  bindir=$arg
 	  prev=
 	  continue
 	  ;;
 	dlfiles|dlprefiles)
-	  if test "$preload" = no; then
+	  $preload || {
 	    # Add the symbol object into the linking commands.
 	    func_append compile_command " @SYMFILE@"
 	    func_append finalize_command " @SYMFILE@"
-	    preload=yes
-	  fi
+	    preload=:
+	  }
 	  case $arg in
 	  *.la | *.lo) ;;  # We handle these cases below.
 	  force)
-	    if test "$dlself" = no; then
+	    if test no = "$dlself"; then
 	      dlself=needless
 	      export_dynamic=yes
 	    fi
@@ -5249,9 +6648,9 @@ func_mode_link ()
 	    continue
 	    ;;
 	  self)
-	    if test "$prev" = dlprefiles; then
+	    if test dlprefiles = "$prev"; then
 	      dlself=yes
-	    elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then
+	    elif test dlfiles = "$prev" && test yes != "$dlopen_self"; then
 	      dlself=yes
 	    else
 	      dlself=needless
@@ -5261,7 +6660,7 @@ func_mode_link ()
 	    continue
 	    ;;
 	  *)
-	    if test "$prev" = dlfiles; then
+	    if test dlfiles = "$prev"; then
 	      func_append dlfiles " $arg"
 	    else
 	      func_append dlprefiles " $arg"
@@ -5272,14 +6671,14 @@ func_mode_link ()
 	  esac
 	  ;;
 	expsyms)
-	  export_symbols="$arg"
+	  export_symbols=$arg
 	  test -f "$arg" \
-	    || func_fatal_error "symbol file \`$arg' does not exist"
+	    || func_fatal_error "symbol file '$arg' does not exist"
 	  prev=
 	  continue
 	  ;;
 	expsyms_regex)
-	  export_symbols_regex="$arg"
+	  export_symbols_regex=$arg
 	  prev=
 	  continue
 	  ;;
@@ -5297,7 +6696,13 @@ func_mode_link ()
 	  continue
 	  ;;
 	inst_prefix)
-	  inst_prefix_dir="$arg"
+	  inst_prefix_dir=$arg
+	  prev=
+	  continue
+	  ;;
+	mllvm)
+	  # Clang does not use LLVM to link, so we can simply discard any
+	  # '-mllvm $arg' options when doing the link step.
 	  prev=
 	  continue
 	  ;;
@@ -5321,21 +6726,21 @@ func_mode_link ()
 
 		if test -z "$pic_object" ||
 		   test -z "$non_pic_object" ||
-		   test "$pic_object" = none &&
-		   test "$non_pic_object" = none; then
-		  func_fatal_error "cannot find name of object for \`$arg'"
+		   test none = "$pic_object" &&
+		   test none = "$non_pic_object"; then
+		  func_fatal_error "cannot find name of object for '$arg'"
 		fi
 
 		# Extract subdirectory from the argument.
 		func_dirname "$arg" "/" ""
-		xdir="$func_dirname_result"
+		xdir=$func_dirname_result
 
-		if test "$pic_object" != none; then
+		if test none != "$pic_object"; then
 		  # Prepend the subdirectory the object is found in.
-		  pic_object="$xdir$pic_object"
+		  pic_object=$xdir$pic_object
 
-		  if test "$prev" = dlfiles; then
-		    if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
+		  if test dlfiles = "$prev"; then
+		    if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then
 		      func_append dlfiles " $pic_object"
 		      prev=
 		      continue
@@ -5346,7 +6751,7 @@ func_mode_link ()
 		  fi
 
 		  # CHECK ME:  I think I busted this.  -Ossama
-		  if test "$prev" = dlprefiles; then
+		  if test dlprefiles = "$prev"; then
 		    # Preload the old-style object.
 		    func_append dlprefiles " $pic_object"
 		    prev=
@@ -5354,23 +6759,23 @@ func_mode_link ()
 
 		  # A PIC object.
 		  func_append libobjs " $pic_object"
-		  arg="$pic_object"
+		  arg=$pic_object
 		fi
 
 		# Non-PIC object.
-		if test "$non_pic_object" != none; then
+		if test none != "$non_pic_object"; then
 		  # Prepend the subdirectory the object is found in.
-		  non_pic_object="$xdir$non_pic_object"
+		  non_pic_object=$xdir$non_pic_object
 
 		  # A standard non-PIC object
 		  func_append non_pic_objects " $non_pic_object"
-		  if test -z "$pic_object" || test "$pic_object" = none ; then
-		    arg="$non_pic_object"
+		  if test -z "$pic_object" || test none = "$pic_object"; then
+		    arg=$non_pic_object
 		  fi
 		else
 		  # If the PIC object exists, use it instead.
 		  # $xdir was prepended to $pic_object above.
-		  non_pic_object="$pic_object"
+		  non_pic_object=$pic_object
 		  func_append non_pic_objects " $non_pic_object"
 		fi
 	      else
@@ -5378,7 +6783,7 @@ func_mode_link ()
 		if $opt_dry_run; then
 		  # Extract subdirectory from the argument.
 		  func_dirname "$arg" "/" ""
-		  xdir="$func_dirname_result"
+		  xdir=$func_dirname_result
 
 		  func_lo2o "$arg"
 		  pic_object=$xdir$objdir/$func_lo2o_result
@@ -5386,24 +6791,29 @@ func_mode_link ()
 		  func_append libobjs " $pic_object"
 		  func_append non_pic_objects " $non_pic_object"
 	        else
-		  func_fatal_error "\`$arg' is not a valid libtool object"
+		  func_fatal_error "'$arg' is not a valid libtool object"
 		fi
 	      fi
 	    done
 	  else
-	    func_fatal_error "link input file \`$arg' does not exist"
+	    func_fatal_error "link input file '$arg' does not exist"
 	  fi
 	  arg=$save_arg
 	  prev=
 	  continue
 	  ;;
+	os2dllname)
+	  os2dllname=$arg
+	  prev=
+	  continue
+	  ;;
 	precious_regex)
-	  precious_files_regex="$arg"
+	  precious_files_regex=$arg
 	  prev=
 	  continue
 	  ;;
 	release)
-	  release="-$arg"
+	  release=-$arg
 	  prev=
 	  continue
 	  ;;
@@ -5415,7 +6825,7 @@ func_mode_link ()
 	    func_fatal_error "only absolute run-paths are allowed"
 	    ;;
 	  esac
-	  if test "$prev" = rpath; then
+	  if test rpath = "$prev"; then
 	    case "$rpath " in
 	    *" $arg "*) ;;
 	    *) func_append rpath " $arg" ;;
@@ -5430,7 +6840,7 @@ func_mode_link ()
 	  continue
 	  ;;
 	shrext)
-	  shrext_cmds="$arg"
+	  shrext_cmds=$arg
 	  prev=
 	  continue
 	  ;;
@@ -5470,7 +6880,7 @@ func_mode_link ()
 	esac
       fi # test -n "$prev"
 
-      prevarg="$arg"
+      prevarg=$arg
 
       case $arg in
       -all-static)
@@ -5484,7 +6894,7 @@ func_mode_link ()
 
       -allow-undefined)
 	# FIXME: remove this flag sometime in the future.
-	func_fatal_error "\`-allow-undefined' must not be used because it is the default"
+	func_fatal_error "'-allow-undefined' must not be used because it is the default"
 	;;
 
       -avoid-version)
@@ -5516,7 +6926,7 @@ func_mode_link ()
 	if test -n "$export_symbols" || test -n "$export_symbols_regex"; then
 	  func_fatal_error "more than one -exported-symbols argument is not allowed"
 	fi
-	if test "X$arg" = "X-export-symbols"; then
+	if test X-export-symbols = "X$arg"; then
 	  prev=expsyms
 	else
 	  prev=expsyms_regex
@@ -5550,9 +6960,9 @@ func_mode_link ()
 	func_stripname "-L" '' "$arg"
 	if test -z "$func_stripname_result"; then
 	  if test "$#" -gt 0; then
-	    func_fatal_error "require no space between \`-L' and \`$1'"
+	    func_fatal_error "require no space between '-L' and '$1'"
 	  else
-	    func_fatal_error "need path for \`-L' option"
+	    func_fatal_error "need path for '-L' option"
 	  fi
 	fi
 	func_resolve_sysroot "$func_stripname_result"
@@ -5563,8 +6973,8 @@ func_mode_link ()
 	*)
 	  absdir=`cd "$dir" && pwd`
 	  test -z "$absdir" && \
-	    func_fatal_error "cannot determine absolute directory name of \`$dir'"
-	  dir="$absdir"
+	    func_fatal_error "cannot determine absolute directory name of '$dir'"
+	  dir=$absdir
 	  ;;
 	esac
 	case "$deplibs " in
@@ -5599,7 +7009,7 @@ func_mode_link ()
 	;;
 
       -l*)
-	if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then
+	if test X-lc = "X$arg" || test X-lm = "X$arg"; then
 	  case $host in
 	  *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku*)
 	    # These systems don't actually have a C or math library (as such)
@@ -5607,11 +7017,11 @@ func_mode_link ()
 	    ;;
 	  *-*-os2*)
 	    # These systems don't actually have a C library (as such)
-	    test "X$arg" = "X-lc" && continue
+	    test X-lc = "X$arg" && continue
 	    ;;
-	  *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
+	  *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*)
 	    # Do not include libc due to us having libc/libc_r.
-	    test "X$arg" = "X-lc" && continue
+	    test X-lc = "X$arg" && continue
 	    ;;
 	  *-*-rhapsody* | *-*-darwin1.[012])
 	    # Rhapsody C and math libraries are in the System framework
@@ -5620,16 +7030,16 @@ func_mode_link ()
 	    ;;
 	  *-*-sco3.2v5* | *-*-sco5v6*)
 	    # Causes problems with __ctype
-	    test "X$arg" = "X-lc" && continue
+	    test X-lc = "X$arg" && continue
 	    ;;
 	  *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*)
 	    # Compiler inserts libc in the correct place for threads to work
-	    test "X$arg" = "X-lc" && continue
+	    test X-lc = "X$arg" && continue
 	    ;;
 	  esac
-	elif test "X$arg" = "X-lc_r"; then
+	elif test X-lc_r = "X$arg"; then
 	 case $host in
-	 *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
+	 *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*)
 	   # Do not include libc_r directly, use -pthread flag.
 	   continue
 	   ;;
@@ -5639,6 +7049,11 @@ func_mode_link ()
 	continue
 	;;
 
+      -mllvm)
+	prev=mllvm
+	continue
+	;;
+
       -module)
 	module=yes
 	continue
@@ -5668,7 +7083,7 @@ func_mode_link ()
 	;;
 
       -multi_module)
-	single_module="${wl}-multi_module"
+	single_module=$wl-multi_module
 	continue
 	;;
 
@@ -5682,8 +7097,8 @@ func_mode_link ()
 	*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*)
 	  # The PATH hackery in wrapper scripts is required on Windows
 	  # and Darwin in order for the loader to find any dlls it needs.
-	  func_warning "\`-no-install' is ignored for $host"
-	  func_warning "assuming \`-no-fast-install' instead"
+	  func_warning "'-no-install' is ignored for $host"
+	  func_warning "assuming '-no-fast-install' instead"
 	  fast_install=no
 	  ;;
 	*) no_install=yes ;;
@@ -5701,6 +7116,11 @@ func_mode_link ()
 	continue
 	;;
 
+      -os2dllname)
+	prev=os2dllname
+	continue
+	;;
+
       -o) prev=output ;;
 
       -precious-files-regex)
@@ -5788,14 +7208,14 @@ func_mode_link ()
 	func_stripname '-Wc,' '' "$arg"
 	args=$func_stripname_result
 	arg=
-	save_ifs="$IFS"; IFS=','
+	save_ifs=$IFS; IFS=,
 	for flag in $args; do
-	  IFS="$save_ifs"
+	  IFS=$save_ifs
           func_quote_for_eval "$flag"
 	  func_append arg " $func_quote_for_eval_result"
 	  func_append compiler_flags " $func_quote_for_eval_result"
 	done
-	IFS="$save_ifs"
+	IFS=$save_ifs
 	func_stripname ' ' '' "$arg"
 	arg=$func_stripname_result
 	;;
@@ -5804,15 +7224,15 @@ func_mode_link ()
 	func_stripname '-Wl,' '' "$arg"
 	args=$func_stripname_result
 	arg=
-	save_ifs="$IFS"; IFS=','
+	save_ifs=$IFS; IFS=,
 	for flag in $args; do
-	  IFS="$save_ifs"
+	  IFS=$save_ifs
           func_quote_for_eval "$flag"
 	  func_append arg " $wl$func_quote_for_eval_result"
 	  func_append compiler_flags " $wl$func_quote_for_eval_result"
 	  func_append linker_flags " $func_quote_for_eval_result"
 	done
-	IFS="$save_ifs"
+	IFS=$save_ifs
 	func_stripname ' ' '' "$arg"
 	arg=$func_stripname_result
 	;;
@@ -5835,7 +7255,7 @@ func_mode_link ()
       # -msg_* for osf cc
       -msg_*)
 	func_quote_for_eval "$arg"
-	arg="$func_quote_for_eval_result"
+	arg=$func_quote_for_eval_result
 	;;
 
       # Flags to be passed through unchanged, with rationale:
@@ -5847,25 +7267,46 @@ func_mode_link ()
       # -m*, -t[45]*, -txscale* architecture-specific flags for GCC
       # -F/path              path to uninstalled frameworks, gcc on darwin
       # -p, -pg, --coverage, -fprofile-*  profiling flags for GCC
+      # -fstack-protector*   stack protector flags for GCC
       # @file                GCC response files
       # -tp=*                Portland pgcc target processor selection
       # --sysroot=*          for sysroot support
-      # -O*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization
+      # -O*, -g*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization
+      # -stdlib=*            select c++ std lib with clang
       -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \
       -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \
-      -O*|-flto*|-fwhopr*|-fuse-linker-plugin)
+      -O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*)
         func_quote_for_eval "$arg"
-	arg="$func_quote_for_eval_result"
+	arg=$func_quote_for_eval_result
         func_append compile_command " $arg"
         func_append finalize_command " $arg"
         func_append compiler_flags " $arg"
         continue
         ;;
 
+      -Z*)
+        if test os2 = "`expr $host : '.*\(os2\)'`"; then
+          # OS/2 uses -Zxxx to specify OS/2-specific options
+	  compiler_flags="$compiler_flags $arg"
+	  func_append compile_command " $arg"
+	  func_append finalize_command " $arg"
+	  case $arg in
+	  -Zlinker | -Zstack)
+	    prev=xcompiler
+	    ;;
+	  esac
+	  continue
+        else
+	  # Otherwise treat like 'Some other compiler flag' below
+	  func_quote_for_eval "$arg"
+	  arg=$func_quote_for_eval_result
+        fi
+	;;
+
       # Some other compiler flag.
       -* | +*)
         func_quote_for_eval "$arg"
-	arg="$func_quote_for_eval_result"
+	arg=$func_quote_for_eval_result
 	;;
 
       *.$objext)
@@ -5886,21 +7327,21 @@ func_mode_link ()
 
 	  if test -z "$pic_object" ||
 	     test -z "$non_pic_object" ||
-	     test "$pic_object" = none &&
-	     test "$non_pic_object" = none; then
-	    func_fatal_error "cannot find name of object for \`$arg'"
+	     test none = "$pic_object" &&
+	     test none = "$non_pic_object"; then
+	    func_fatal_error "cannot find name of object for '$arg'"
 	  fi
 
 	  # Extract subdirectory from the argument.
 	  func_dirname "$arg" "/" ""
-	  xdir="$func_dirname_result"
+	  xdir=$func_dirname_result
 
-	  if test "$pic_object" != none; then
+	  test none = "$pic_object" || {
 	    # Prepend the subdirectory the object is found in.
-	    pic_object="$xdir$pic_object"
+	    pic_object=$xdir$pic_object
 
-	    if test "$prev" = dlfiles; then
-	      if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
+	    if test dlfiles = "$prev"; then
+	      if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then
 		func_append dlfiles " $pic_object"
 		prev=
 		continue
@@ -5911,7 +7352,7 @@ func_mode_link ()
 	    fi
 
 	    # CHECK ME:  I think I busted this.  -Ossama
-	    if test "$prev" = dlprefiles; then
+	    if test dlprefiles = "$prev"; then
 	      # Preload the old-style object.
 	      func_append dlprefiles " $pic_object"
 	      prev=
@@ -5919,23 +7360,23 @@ func_mode_link ()
 
 	    # A PIC object.
 	    func_append libobjs " $pic_object"
-	    arg="$pic_object"
-	  fi
+	    arg=$pic_object
+	  }
 
 	  # Non-PIC object.
-	  if test "$non_pic_object" != none; then
+	  if test none != "$non_pic_object"; then
 	    # Prepend the subdirectory the object is found in.
-	    non_pic_object="$xdir$non_pic_object"
+	    non_pic_object=$xdir$non_pic_object
 
 	    # A standard non-PIC object
 	    func_append non_pic_objects " $non_pic_object"
-	    if test -z "$pic_object" || test "$pic_object" = none ; then
-	      arg="$non_pic_object"
+	    if test -z "$pic_object" || test none = "$pic_object"; then
+	      arg=$non_pic_object
 	    fi
 	  else
 	    # If the PIC object exists, use it instead.
 	    # $xdir was prepended to $pic_object above.
-	    non_pic_object="$pic_object"
+	    non_pic_object=$pic_object
 	    func_append non_pic_objects " $non_pic_object"
 	  fi
 	else
@@ -5943,7 +7384,7 @@ func_mode_link ()
 	  if $opt_dry_run; then
 	    # Extract subdirectory from the argument.
 	    func_dirname "$arg" "/" ""
-	    xdir="$func_dirname_result"
+	    xdir=$func_dirname_result
 
 	    func_lo2o "$arg"
 	    pic_object=$xdir$objdir/$func_lo2o_result
@@ -5951,7 +7392,7 @@ func_mode_link ()
 	    func_append libobjs " $pic_object"
 	    func_append non_pic_objects " $non_pic_object"
 	  else
-	    func_fatal_error "\`$arg' is not a valid libtool object"
+	    func_fatal_error "'$arg' is not a valid libtool object"
 	  fi
 	fi
 	;;
@@ -5967,11 +7408,11 @@ func_mode_link ()
 	# A libtool-controlled library.
 
 	func_resolve_sysroot "$arg"
-	if test "$prev" = dlfiles; then
+	if test dlfiles = "$prev"; then
 	  # This library was specified with -dlopen.
 	  func_append dlfiles " $func_resolve_sysroot_result"
 	  prev=
-	elif test "$prev" = dlprefiles; then
+	elif test dlprefiles = "$prev"; then
 	  # The library was specified with -dlpreopen.
 	  func_append dlprefiles " $func_resolve_sysroot_result"
 	  prev=
@@ -5986,7 +7427,7 @@ func_mode_link ()
 	# Unknown arguments in both finalize_command and compile_command need
 	# to be aesthetically quoted because they are evaled later.
 	func_quote_for_eval "$arg"
-	arg="$func_quote_for_eval_result"
+	arg=$func_quote_for_eval_result
 	;;
       esac # arg
 
@@ -5998,9 +7439,9 @@ func_mode_link ()
     done # argument parsing loop
 
     test -n "$prev" && \
-      func_fatal_help "the \`$prevarg' option requires an argument"
+      func_fatal_help "the '$prevarg' option requires an argument"
 
-    if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then
+    if test yes = "$export_dynamic" && test -n "$export_dynamic_flag_spec"; then
       eval arg=\"$export_dynamic_flag_spec\"
       func_append compile_command " $arg"
       func_append finalize_command " $arg"
@@ -6009,20 +7450,23 @@ func_mode_link ()
     oldlibs=
     # calculate the name of the file, without its directory
     func_basename "$output"
-    outputname="$func_basename_result"
-    libobjs_save="$libobjs"
+    outputname=$func_basename_result
+    libobjs_save=$libobjs
 
     if test -n "$shlibpath_var"; then
       # get the directories listed in $shlibpath_var
-      eval shlib_search_path=\`\$ECHO \"\${$shlibpath_var}\" \| \$SED \'s/:/ /g\'\`
+      eval shlib_search_path=\`\$ECHO \"\$$shlibpath_var\" \| \$SED \'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\"
 
+    # Definition is injected by LT_CONFIG during libtool generation.
+    func_munge_path_list sys_lib_dlsearch_path "$LT_SYS_LIBRARY_PATH"
+
     func_dirname "$output" "/" ""
-    output_objdir="$func_dirname_result$objdir"
+    output_objdir=$func_dirname_result$objdir
     func_to_tool_file "$output_objdir/"
     tool_output_objdir=$func_to_tool_file_result
     # Create the object directory.
@@ -6045,7 +7489,7 @@ func_mode_link ()
     # 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 $opt_preserve_dup_deps ; then
+      if $opt_preserve_dup_deps; then
 	case "$libs " in
 	*" $deplib "*) func_append specialdeplibs " $deplib" ;;
 	esac
@@ -6053,7 +7497,7 @@ func_mode_link ()
       func_append libs " $deplib"
     done
 
-    if test "$linkmode" = lib; then
+    if test lib = "$linkmode"; then
       libs="$predeps $libs $compiler_lib_search_path $postdeps"
 
       # Compute libraries that are listed more than once in $predeps
@@ -6085,7 +7529,7 @@ func_mode_link ()
 	  case $file in
 	  *.la) ;;
 	  *)
-	    func_fatal_help "libraries can \`-dlopen' only libtool libraries: $file"
+	    func_fatal_help "libraries can '-dlopen' only libtool libraries: $file"
 	    ;;
 	  esac
 	done
@@ -6093,7 +7537,7 @@ func_mode_link ()
     prog)
 	compile_deplibs=
 	finalize_deplibs=
-	alldeplibs=no
+	alldeplibs=false
 	newdlfiles=
 	newdlprefiles=
 	passes="conv scan dlopen dlpreopen link"
@@ -6105,29 +7549,29 @@ func_mode_link ()
     for pass in $passes; do
       # The preopen pass in lib mode reverses $deplibs; put it back here
       # so that -L comes before libs that need it for instance...
-      if test "$linkmode,$pass" = "lib,link"; then
+      if test lib,link = "$linkmode,$pass"; then
 	## FIXME: Find the place where the list is rebuilt in the wrong
 	##        order, and fix it there properly
         tmp_deplibs=
 	for deplib in $deplibs; do
 	  tmp_deplibs="$deplib $tmp_deplibs"
 	done
-	deplibs="$tmp_deplibs"
+	deplibs=$tmp_deplibs
       fi
 
-      if test "$linkmode,$pass" = "lib,link" ||
-	 test "$linkmode,$pass" = "prog,scan"; then
-	libs="$deplibs"
+      if test lib,link = "$linkmode,$pass" ||
+	 test prog,scan = "$linkmode,$pass"; then
+	libs=$deplibs
 	deplibs=
       fi
-      if test "$linkmode" = prog; then
+      if test prog = "$linkmode"; then
 	case $pass in
-	dlopen) libs="$dlfiles" ;;
-	dlpreopen) libs="$dlprefiles" ;;
+	dlopen) libs=$dlfiles ;;
+	dlpreopen) libs=$dlprefiles ;;
 	link) libs="$deplibs %DEPLIBS% $dependency_libs" ;;
 	esac
       fi
-      if test "$linkmode,$pass" = "lib,dlpreopen"; then
+      if test lib,dlpreopen = "$linkmode,$pass"; then
 	# Collect and forward deplibs of preopened libtool libs
 	for lib in $dlprefiles; do
 	  # Ignore non-libtool-libs
@@ -6148,26 +7592,26 @@ func_mode_link ()
 	    esac
 	  done
 	done
-	libs="$dlprefiles"
+	libs=$dlprefiles
       fi
-      if test "$pass" = dlopen; then
+      if test dlopen = "$pass"; then
 	# Collect dlpreopened libraries
-	save_deplibs="$deplibs"
+	save_deplibs=$deplibs
 	deplibs=
       fi
 
       for deplib in $libs; do
 	lib=
-	found=no
+	found=false
 	case $deplib in
 	-mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \
         |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*)
-	  if test "$linkmode,$pass" = "prog,link"; then
+	  if test prog,link = "$linkmode,$pass"; then
 	    compile_deplibs="$deplib $compile_deplibs"
 	    finalize_deplibs="$deplib $finalize_deplibs"
 	  else
 	    func_append compiler_flags " $deplib"
-	    if test "$linkmode" = lib ; then
+	    if test lib = "$linkmode"; then
 		case "$new_inherited_linker_flags " in
 		    *" $deplib "*) ;;
 		    * ) func_append new_inherited_linker_flags " $deplib" ;;
@@ -6177,13 +7621,13 @@ func_mode_link ()
 	  continue
 	  ;;
 	-l*)
-	  if test "$linkmode" != lib && test "$linkmode" != prog; then
-	    func_warning "\`-l' is ignored for archives/objects"
+	  if test lib != "$linkmode" && test prog != "$linkmode"; then
+	    func_warning "'-l' is ignored for archives/objects"
 	    continue
 	  fi
 	  func_stripname '-l' '' "$deplib"
 	  name=$func_stripname_result
-	  if test "$linkmode" = lib; then
+	  if test lib = "$linkmode"; then
 	    searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path"
 	  else
 	    searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path"
@@ -6191,31 +7635,22 @@ func_mode_link ()
 	  for searchdir in $searchdirs; do
 	    for search_ext in .la $std_shrext .so .a; do
 	      # Search the libtool library
-	      lib="$searchdir/lib${name}${search_ext}"
+	      lib=$searchdir/lib$name$search_ext
 	      if test -f "$lib"; then
-		if test "$search_ext" = ".la"; then
-		  found=yes
+		if test .la = "$search_ext"; then
+		  found=:
 		else
-		  found=no
+		  found=false
 		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 $found; then
+	    # 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
+	    if test yes = "$allow_libtool_libs_with_static_runtimes"; then
 	      case " $predeps $postdeps " in
 	      *" $deplib "*)
 		if func_lalib_p "$lib"; then
@@ -6223,19 +7658,19 @@ func_mode_link ()
 		  old_library=
 		  func_source "$lib"
 		  for l in $old_library $library_names; do
-		    ll="$l"
+		    ll=$l
 		  done
-		  if test "X$ll" = "X$old_library" ; then # only static version available
-		    found=no
+		  if test "X$ll" = "X$old_library"; then # only static version available
+		    found=false
 		    func_dirname "$lib" "" "."
-		    ladir="$func_dirname_result"
+		    ladir=$func_dirname_result
 		    lib=$ladir/$old_library
-		    if test "$linkmode,$pass" = "prog,link"; then
+		    if test prog,link = "$linkmode,$pass"; then
 		      compile_deplibs="$deplib $compile_deplibs"
 		      finalize_deplibs="$deplib $finalize_deplibs"
 		    else
 		      deplibs="$deplib $deplibs"
-		      test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
+		      test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs"
 		    fi
 		    continue
 		  fi
@@ -6244,15 +7679,25 @@ func_mode_link ()
 	      *) ;;
 	      esac
 	    fi
+	  else
+	    # deplib doesn't seem to be a libtool library
+	    if test prog,link = "$linkmode,$pass"; then
+	      compile_deplibs="$deplib $compile_deplibs"
+	      finalize_deplibs="$deplib $finalize_deplibs"
+	    else
+	      deplibs="$deplib $deplibs"
+	      test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs"
+	    fi
+	    continue
 	  fi
 	  ;; # -l
 	*.ltframework)
-	  if test "$linkmode,$pass" = "prog,link"; then
+	  if test prog,link = "$linkmode,$pass"; then
 	    compile_deplibs="$deplib $compile_deplibs"
 	    finalize_deplibs="$deplib $finalize_deplibs"
 	  else
 	    deplibs="$deplib $deplibs"
-	    if test "$linkmode" = lib ; then
+	    if test lib = "$linkmode"; then
 		case "$new_inherited_linker_flags " in
 		    *" $deplib "*) ;;
 		    * ) func_append new_inherited_linker_flags " $deplib" ;;
@@ -6265,18 +7710,18 @@ func_mode_link ()
 	  case $linkmode in
 	  lib)
 	    deplibs="$deplib $deplibs"
-	    test "$pass" = conv && continue
+	    test conv = "$pass" && continue
 	    newdependency_libs="$deplib $newdependency_libs"
 	    func_stripname '-L' '' "$deplib"
 	    func_resolve_sysroot "$func_stripname_result"
 	    func_append newlib_search_path " $func_resolve_sysroot_result"
 	    ;;
 	  prog)
-	    if test "$pass" = conv; then
+	    if test conv = "$pass"; then
 	      deplibs="$deplib $deplibs"
 	      continue
 	    fi
-	    if test "$pass" = scan; then
+	    if test scan = "$pass"; then
 	      deplibs="$deplib $deplibs"
 	    else
 	      compile_deplibs="$deplib $compile_deplibs"
@@ -6287,13 +7732,13 @@ func_mode_link ()
 	    func_append newlib_search_path " $func_resolve_sysroot_result"
 	    ;;
 	  *)
-	    func_warning "\`-L' is ignored for archives/objects"
+	    func_warning "'-L' is ignored for archives/objects"
 	    ;;
 	  esac # linkmode
 	  continue
 	  ;; # -L
 	-R*)
-	  if test "$pass" = link; then
+	  if test link = "$pass"; then
 	    func_stripname '-R' '' "$deplib"
 	    func_resolve_sysroot "$func_stripname_result"
 	    dir=$func_resolve_sysroot_result
@@ -6311,7 +7756,7 @@ func_mode_link ()
 	  lib=$func_resolve_sysroot_result
 	  ;;
 	*.$libext)
-	  if test "$pass" = conv; then
+	  if test conv = "$pass"; then
 	    deplibs="$deplib $deplibs"
 	    continue
 	  fi
@@ -6322,21 +7767,26 @@ func_mode_link ()
 	    case " $dlpreconveniencelibs " in
 	    *" $deplib "*) ;;
 	    *)
-	      valid_a_lib=no
+	      valid_a_lib=false
 	      case $deplibs_check_method in
 		match_pattern*)
 		  set dummy $deplibs_check_method; shift
 		  match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"`
 		  if eval "\$ECHO \"$deplib\"" 2>/dev/null | $SED 10q \
 		    | $EGREP "$match_pattern_regex" > /dev/null; then
-		    valid_a_lib=yes
+		    valid_a_lib=:
 		  fi
 		;;
 		pass_all)
-		  valid_a_lib=yes
+		  valid_a_lib=:
 		;;
 	      esac
-	      if test "$valid_a_lib" != yes; then
+	      if $valid_a_lib; then
+		echo
+		$ECHO "*** Warning: Linking the shared library $output against the"
+		$ECHO "*** static library $deplib is not portable!"
+		deplibs="$deplib $deplibs"
+	      else
 		echo
 		$ECHO "*** Warning: Trying to link with static lib archive $deplib."
 		echo "*** I have the capability to make that library automatically link in when"
@@ -6344,18 +7794,13 @@ func_mode_link ()
 		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 use here."
-	      else
-		echo
-		$ECHO "*** Warning: Linking the shared library $output against the"
-		$ECHO "*** static library $deplib is not portable!"
-		deplibs="$deplib $deplibs"
 	      fi
 	      ;;
 	    esac
 	    continue
 	    ;;
 	  prog)
-	    if test "$pass" != link; then
+	    if test link != "$pass"; then
 	      deplibs="$deplib $deplibs"
 	    else
 	      compile_deplibs="$deplib $compile_deplibs"
@@ -6366,10 +7811,10 @@ func_mode_link ()
 	  esac # linkmode
 	  ;; # *.$libext
 	*.lo | *.$objext)
-	  if test "$pass" = conv; then
+	  if test conv = "$pass"; then
 	    deplibs="$deplib $deplibs"
-	  elif test "$linkmode" = prog; then
-	    if test "$pass" = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then
+	  elif test prog = "$linkmode"; then
+	    if test dlpreopen = "$pass" || test yes != "$dlopen_support" || test no = "$build_libtool_libs"; then
 	      # If there is no dlopen support or we're linking statically,
 	      # we need to preload.
 	      func_append newdlprefiles " $deplib"
@@ -6382,22 +7827,20 @@ func_mode_link ()
 	  continue
 	  ;;
 	%DEPLIBS%)
-	  alldeplibs=yes
+	  alldeplibs=:
 	  continue
 	  ;;
 	esac # case $deplib
 
-	if test "$found" = yes || test -f "$lib"; then :
-	else
-	  func_fatal_error "cannot find the library \`$lib' or unhandled argument \`$deplib'"
-	fi
+	$found || test -f "$lib" \
+	  || func_fatal_error "cannot find the library '$lib' or unhandled argument '$deplib'"
 
 	# Check to see that this really is a libtool archive.
 	func_lalib_unsafe_p "$lib" \
-	  || func_fatal_error "\`$lib' is not a valid libtool archive"
+	  || func_fatal_error "'$lib' is not a valid libtool archive"
 
 	func_dirname "$lib" "" "."
-	ladir="$func_dirname_result"
+	ladir=$func_dirname_result
 
 	dlname=
 	dlopen=
@@ -6427,30 +7870,30 @@ func_mode_link ()
 	  done
 	fi
 	dependency_libs=`$ECHO " $dependency_libs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
-	if test "$linkmode,$pass" = "lib,link" ||
-	   test "$linkmode,$pass" = "prog,scan" ||
-	   { test "$linkmode" != prog && test "$linkmode" != lib; }; then
+	if test lib,link = "$linkmode,$pass" ||
+	   test prog,scan = "$linkmode,$pass" ||
+	   { test prog != "$linkmode" && test lib != "$linkmode"; }; then
 	  test -n "$dlopen" && func_append dlfiles " $dlopen"
 	  test -n "$dlpreopen" && func_append dlprefiles " $dlpreopen"
 	fi
 
-	if test "$pass" = conv; then
+	if test conv = "$pass"; then
 	  # Only check for convenience libraries
 	  deplibs="$lib $deplibs"
 	  if test -z "$libdir"; then
 	    if test -z "$old_library"; then
-	      func_fatal_error "cannot find name of link library for \`$lib'"
+	      func_fatal_error "cannot find name of link library for '$lib'"
 	    fi
 	    # It is a libtool convenience library, so add in its objects.
 	    func_append convenience " $ladir/$objdir/$old_library"
 	    func_append old_convenience " $ladir/$objdir/$old_library"
-	  elif test "$linkmode" != prog && test "$linkmode" != lib; then
-	    func_fatal_error "\`$lib' is not a convenience library"
+	  elif test prog != "$linkmode" && test lib != "$linkmode"; then
+	    func_fatal_error "'$lib' is not a convenience library"
 	  fi
 	  tmp_libs=
 	  for deplib in $dependency_libs; do
 	    deplibs="$deplib $deplibs"
-	    if $opt_preserve_dup_deps ; then
+	    if $opt_preserve_dup_deps; then
 	      case "$tmp_libs " in
 	      *" $deplib "*) func_append specialdeplibs " $deplib" ;;
 	      esac
@@ -6464,26 +7907,26 @@ func_mode_link ()
 	# Get the name of the library we link against.
 	linklib=
 	if test -n "$old_library" &&
-	   { test "$prefer_static_libs" = yes ||
-	     test "$prefer_static_libs,$installed" = "built,no"; }; then
+	   { test yes = "$prefer_static_libs" ||
+	     test built,no = "$prefer_static_libs,$installed"; }; then
 	  linklib=$old_library
 	else
 	  for l in $old_library $library_names; do
-	    linklib="$l"
+	    linklib=$l
 	  done
 	fi
 	if test -z "$linklib"; then
-	  func_fatal_error "cannot find name of link library for \`$lib'"
+	  func_fatal_error "cannot find name of link library for '$lib'"
 	fi
 
 	# This library was specified with -dlopen.
-	if test "$pass" = dlopen; then
-	  if test -z "$libdir"; then
-	    func_fatal_error "cannot -dlopen a convenience library: \`$lib'"
-	  fi
+	if test dlopen = "$pass"; then
+	  test -z "$libdir" \
+	    && func_fatal_error "cannot -dlopen a convenience library: '$lib'"
 	  if test -z "$dlname" ||
-	     test "$dlopen_support" != yes ||
-	     test "$build_libtool_libs" = no; then
+	     test yes != "$dlopen_support" ||
+	     test no = "$build_libtool_libs"
+	  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
@@ -6497,40 +7940,40 @@ func_mode_link ()
 
 	# We need an absolute path.
 	case $ladir in
-	[\\/]* | [A-Za-z]:[\\/]*) abs_ladir="$ladir" ;;
+	[\\/]* | [A-Za-z]:[\\/]*) abs_ladir=$ladir ;;
 	*)
 	  abs_ladir=`cd "$ladir" && pwd`
 	  if test -z "$abs_ladir"; then
-	    func_warning "cannot determine absolute directory name of \`$ladir'"
+	    func_warning "cannot determine absolute directory name of '$ladir'"
 	    func_warning "passing it literally to the linker, although it might fail"
-	    abs_ladir="$ladir"
+	    abs_ladir=$ladir
 	  fi
 	  ;;
 	esac
 	func_basename "$lib"
-	laname="$func_basename_result"
+	laname=$func_basename_result
 
 	# Find the relevant object directory and library name.
-	if test "X$installed" = Xyes; then
+	if test yes = "$installed"; then
 	  if test ! -f "$lt_sysroot$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then
-	    func_warning "library \`$lib' was moved."
-	    dir="$ladir"
-	    absdir="$abs_ladir"
-	    libdir="$abs_ladir"
+	    func_warning "library '$lib' was moved."
+	    dir=$ladir
+	    absdir=$abs_ladir
+	    libdir=$abs_ladir
 	  else
-	    dir="$lt_sysroot$libdir"
-	    absdir="$lt_sysroot$libdir"
+	    dir=$lt_sysroot$libdir
+	    absdir=$lt_sysroot$libdir
 	  fi
-	  test "X$hardcode_automatic" = Xyes && avoidtemprpath=yes
+	  test yes = "$hardcode_automatic" && avoidtemprpath=yes
 	else
 	  if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then
-	    dir="$ladir"
-	    absdir="$abs_ladir"
+	    dir=$ladir
+	    absdir=$abs_ladir
 	    # Remove this search path later
 	    func_append notinst_path " $abs_ladir"
 	  else
-	    dir="$ladir/$objdir"
-	    absdir="$abs_ladir/$objdir"
+	    dir=$ladir/$objdir
+	    absdir=$abs_ladir/$objdir
 	    # Remove this search path later
 	    func_append notinst_path " $abs_ladir"
 	  fi
@@ -6539,11 +7982,11 @@ func_mode_link ()
 	name=$func_stripname_result
 
 	# This library was specified with -dlpreopen.
-	if test "$pass" = dlpreopen; then
-	  if test -z "$libdir" && test "$linkmode" = prog; then
-	    func_fatal_error "only libraries may -dlpreopen a convenience library: \`$lib'"
+	if test dlpreopen = "$pass"; then
+	  if test -z "$libdir" && test prog = "$linkmode"; then
+	    func_fatal_error "only libraries may -dlpreopen a convenience library: '$lib'"
 	  fi
-	  case "$host" in
+	  case $host in
 	    # special handling for platforms with PE-DLLs.
 	    *cygwin* | *mingw* | *cegcc* )
 	      # Linker will automatically link against shared library if both
@@ -6587,9 +8030,9 @@ func_mode_link ()
 
 	if test -z "$libdir"; then
 	  # Link the convenience library
-	  if test "$linkmode" = lib; then
+	  if test lib = "$linkmode"; then
 	    deplibs="$dir/$old_library $deplibs"
-	  elif test "$linkmode,$pass" = "prog,link"; then
+	  elif test prog,link = "$linkmode,$pass"; then
 	    compile_deplibs="$dir/$old_library $compile_deplibs"
 	    finalize_deplibs="$dir/$old_library $finalize_deplibs"
 	  else
@@ -6599,14 +8042,14 @@ func_mode_link ()
 	fi
 
 
-	if test "$linkmode" = prog && test "$pass" != link; then
+	if test prog = "$linkmode" && test link != "$pass"; then
 	  func_append 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
+	  linkalldeplibs=false
+	  if test no != "$link_all_deplibs" || test -z "$library_names" ||
+	     test no = "$build_libtool_libs"; then
+	    linkalldeplibs=:
 	  fi
 
 	  tmp_libs=
@@ -6618,14 +8061,14 @@ func_mode_link ()
 		 ;;
 	    esac
 	    # Need to link against all dependency_libs?
-	    if test "$linkalldeplibs" = yes; then
+	    if $linkalldeplibs; then
 	      deplibs="$deplib $deplibs"
 	    else
 	      # Need to hardcode shared library paths
 	      # or/and link against static libraries
 	      newdependency_libs="$deplib $newdependency_libs"
 	    fi
-	    if $opt_preserve_dup_deps ; then
+	    if $opt_preserve_dup_deps; then
 	      case "$tmp_libs " in
 	      *" $deplib "*) func_append specialdeplibs " $deplib" ;;
 	      esac
@@ -6635,15 +8078,15 @@ func_mode_link ()
 	  continue
 	fi # $linkmode = prog...
 
-	if test "$linkmode,$pass" = "prog,link"; then
+	if test prog,link = "$linkmode,$pass"; then
 	  if test -n "$library_names" &&
-	     { { test "$prefer_static_libs" = no ||
-	         test "$prefer_static_libs,$installed" = "built,yes"; } ||
+	     { { test no = "$prefer_static_libs" ||
+	         test built,yes = "$prefer_static_libs,$installed"; } ||
 	       test -z "$old_library"; }; then
 	    # We need to hardcode the library path
-	    if test -n "$shlibpath_var" && test -z "$avoidtemprpath" ; then
+	    if test -n "$shlibpath_var" && test -z "$avoidtemprpath"; then
 	      # Make sure the rpath contains only unique directories.
-	      case "$temp_rpath:" in
+	      case $temp_rpath: in
 	      *"$absdir:"*) ;;
 	      *) func_append temp_rpath "$absdir:" ;;
 	      esac
@@ -6672,9 +8115,9 @@ func_mode_link ()
 	    esac
 	  fi # $linkmode,$pass = prog,link...
 
-	  if test "$alldeplibs" = yes &&
-	     { test "$deplibs_check_method" = pass_all ||
-	       { test "$build_libtool_libs" = yes &&
+	  if $alldeplibs &&
+	     { test pass_all = "$deplibs_check_method" ||
+	       { test yes = "$build_libtool_libs" &&
 		 test -n "$library_names"; }; }; then
 	    # We only need to search for static libraries
 	    continue
@@ -6683,19 +8126,19 @@ func_mode_link ()
 
 	link_static=no # Whether the deplib will be linked statically
 	use_static_libs=$prefer_static_libs
-	if test "$use_static_libs" = built && test "$installed" = yes; then
+	if test built = "$use_static_libs" && test yes = "$installed"; then
 	  use_static_libs=no
 	fi
 	if test -n "$library_names" &&
-	   { test "$use_static_libs" = no || test -z "$old_library"; }; then
+	   { test no = "$use_static_libs" || test -z "$old_library"; }; then
 	  case $host in
-	  *cygwin* | *mingw* | *cegcc*)
+	  *cygwin* | *mingw* | *cegcc* | *os2*)
 	      # No point in relinking DLLs because paths are not encoded
 	      func_append notinst_deplibs " $lib"
 	      need_relink=no
 	    ;;
 	  *)
-	    if test "$installed" = no; then
+	    if test no = "$installed"; then
 	      func_append notinst_deplibs " $lib"
 	      need_relink=yes
 	    fi
@@ -6705,24 +8148,24 @@ func_mode_link ()
 
 	  # Warn about portability, can't link against -module's on some
 	  # systems (darwin).  Don't bleat about dlopened modules though!
-	  dlopenmodule=""
+	  dlopenmodule=
 	  for dlpremoduletest in $dlprefiles; do
 	    if test "X$dlpremoduletest" = "X$lib"; then
-	      dlopenmodule="$dlpremoduletest"
+	      dlopenmodule=$dlpremoduletest
 	      break
 	    fi
 	  done
-	  if test -z "$dlopenmodule" && test "$shouldnotlink" = yes && test "$pass" = link; then
+	  if test -z "$dlopenmodule" && test yes = "$shouldnotlink" && test link = "$pass"; then
 	    echo
-	    if test "$linkmode" = prog; then
+	    if test prog = "$linkmode"; 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
+	  if test lib = "$linkmode" &&
+	     test yes = "$hardcode_into_libs"; then
 	    # Hardcode the library path.
 	    # Skip directories that are in the system default run-time
 	    # search path.
@@ -6750,43 +8193,43 @@ func_mode_link ()
 	    # figure out the soname
 	    set dummy $library_names
 	    shift
-	    realname="$1"
+	    realname=$1
 	    shift
 	    libname=`eval "\\$ECHO \"$libname_spec\""`
 	    # use dlname if we got it. it's perfectly good, no?
 	    if test -n "$dlname"; then
-	      soname="$dlname"
+	      soname=$dlname
 	    elif test -n "$soname_spec"; then
 	      # bleh windows
 	      case $host in
-	      *cygwin* | mingw* | *cegcc*)
+	      *cygwin* | mingw* | *cegcc* | *os2*)
 	        func_arith $current - $age
 		major=$func_arith_result
-		versuffix="-$major"
+		versuffix=-$major
 		;;
 	      esac
 	      eval soname=\"$soname_spec\"
 	    else
-	      soname="$realname"
+	      soname=$realname
 	    fi
 
 	    # Make a new name for the extract_expsyms_cmds to use
-	    soroot="$soname"
+	    soroot=$soname
 	    func_basename "$soroot"
-	    soname="$func_basename_result"
+	    soname=$func_basename_result
 	    func_stripname 'lib' '.dll' "$soname"
 	    newlib=libimp-$func_stripname_result.a
 
 	    # If the library has no export list, then create one now
 	    if test -f "$output_objdir/$soname-def"; then :
 	    else
-	      func_verbose "extracting exported symbol list from \`$soname'"
+	      func_verbose "extracting exported symbol list from '$soname'"
 	      func_execute_cmds "$extract_expsyms_cmds" 'exit $?'
 	    fi
 
 	    # Create $newlib
 	    if test -f "$output_objdir/$newlib"; then :; else
-	      func_verbose "generating import library for \`$soname'"
+	      func_verbose "generating import library for '$soname'"
 	      func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?'
 	    fi
 	    # make sure the library variables are pointing to the new library
@@ -6794,58 +8237,58 @@ func_mode_link ()
 	    linklib=$newlib
 	  fi # test -n "$old_archive_from_expsyms_cmds"
 
-	  if test "$linkmode" = prog || test "$opt_mode" != relink; then
+	  if test prog = "$linkmode" || test relink != "$opt_mode"; then
 	    add_shlibpath=
 	    add_dir=
 	    add=
 	    lib_linked=yes
 	    case $hardcode_action in
 	    immediate | unsupported)
-	      if test "$hardcode_direct" = no; then
-		add="$dir/$linklib"
+	      if test no = "$hardcode_direct"; then
+		add=$dir/$linklib
 		case $host in
-		  *-*-sco3.2v5.0.[024]*) add_dir="-L$dir" ;;
-		  *-*-sysv4*uw2*) add_dir="-L$dir" ;;
+		  *-*-sco3.2v5.0.[024]*) add_dir=-L$dir ;;
+		  *-*-sysv4*uw2*) add_dir=-L$dir ;;
 		  *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \
-		    *-*-unixware7*) add_dir="-L$dir" ;;
+		    *-*-unixware7*) add_dir=-L$dir ;;
 		  *-*-darwin* )
-		    # if the lib is a (non-dlopened) module then we can not
+		    # if the lib is a (non-dlopened) module then we cannot
 		    # link against it, someone is ignoring the earlier warnings
 		    if /usr/bin/file -L $add 2> /dev/null |
-			 $GREP ": [^:]* bundle" >/dev/null ; then
+			 $GREP ": [^:]* bundle" >/dev/null; then
 		      if test "X$dlopenmodule" != "X$lib"; then
 			$ECHO "*** Warning: lib $linklib is a module, not a shared library"
-			if test -z "$old_library" ; then
+			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"
+			  add=$dir/$old_library
 			fi
 		      elif test -n "$old_library"; then
-			add="$dir/$old_library"
+			add=$dir/$old_library
 		      fi
 		    fi
 		esac
-	      elif test "$hardcode_minus_L" = no; then
+	      elif test no = "$hardcode_minus_L"; then
 		case $host in
-		*-*-sunos*) add_shlibpath="$dir" ;;
+		*-*-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"
+		add_dir=-L$dir
+		add=-l$name
+	      elif test no = "$hardcode_shlibpath_var"; then
+		add_shlibpath=$dir
+		add=-l$name
 	      else
 		lib_linked=no
 	      fi
 	      ;;
 	    relink)
-	      if test "$hardcode_direct" = yes &&
-	         test "$hardcode_direct_absolute" = no; then
-		add="$dir/$linklib"
-	      elif test "$hardcode_minus_L" = yes; then
-		add_dir="-L$absdir"
+	      if test yes = "$hardcode_direct" &&
+	         test no = "$hardcode_direct_absolute"; then
+		add=$dir/$linklib
+	      elif test yes = "$hardcode_minus_L"; then
+		add_dir=-L$absdir
 		# Try looking first in the location we're being installed to.
 		if test -n "$inst_prefix_dir"; then
 		  case $libdir in
@@ -6854,10 +8297,10 @@ func_mode_link ()
 		      ;;
 		  esac
 		fi
-		add="-l$name"
-	      elif test "$hardcode_shlibpath_var" = yes; then
-		add_shlibpath="$dir"
-		add="-l$name"
+		add=-l$name
+	      elif test yes = "$hardcode_shlibpath_var"; then
+		add_shlibpath=$dir
+		add=-l$name
 	      else
 		lib_linked=no
 	      fi
@@ -6865,7 +8308,7 @@ func_mode_link ()
 	    *) lib_linked=no ;;
 	    esac
 
-	    if test "$lib_linked" != yes; then
+	    if test yes != "$lib_linked"; then
 	      func_fatal_configuration "unsupported hardcode properties"
 	    fi
 
@@ -6875,15 +8318,15 @@ func_mode_link ()
 	      *) func_append compile_shlibpath "$add_shlibpath:" ;;
 	      esac
 	    fi
-	    if test "$linkmode" = prog; then
+	    if test prog = "$linkmode"; 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
+	      if test yes != "$hardcode_direct" &&
+		 test yes != "$hardcode_minus_L" &&
+		 test yes = "$hardcode_shlibpath_var"; then
 		case :$finalize_shlibpath: in
 		*":$libdir:"*) ;;
 		*) func_append finalize_shlibpath "$libdir:" ;;
@@ -6892,33 +8335,33 @@ func_mode_link ()
 	    fi
 	  fi
 
-	  if test "$linkmode" = prog || test "$opt_mode" = relink; then
+	  if test prog = "$linkmode" || test relink = "$opt_mode"; then
 	    add_shlibpath=
 	    add_dir=
 	    add=
 	    # Finalize command for both is simple: just hardcode it.
-	    if test "$hardcode_direct" = yes &&
-	       test "$hardcode_direct_absolute" = no; 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
+	    if test yes = "$hardcode_direct" &&
+	       test no = "$hardcode_direct_absolute"; then
+	      add=$libdir/$linklib
+	    elif test yes = "$hardcode_minus_L"; then
+	      add_dir=-L$libdir
+	      add=-l$name
+	    elif test yes = "$hardcode_shlibpath_var"; then
 	      case :$finalize_shlibpath: in
 	      *":$libdir:"*) ;;
 	      *) func_append finalize_shlibpath "$libdir:" ;;
 	      esac
-	      add="-l$name"
-	    elif test "$hardcode_automatic" = yes; then
+	      add=-l$name
+	    elif test yes = "$hardcode_automatic"; then
 	      if test -n "$inst_prefix_dir" &&
-		 test -f "$inst_prefix_dir$libdir/$linklib" ; then
-		add="$inst_prefix_dir$libdir/$linklib"
+		 test -f "$inst_prefix_dir$libdir/$linklib"; then
+		add=$inst_prefix_dir$libdir/$linklib
 	      else
-		add="$libdir/$linklib"
+		add=$libdir/$linklib
 	      fi
 	    else
 	      # We cannot seem to hardcode it, guess we'll fake it.
-	      add_dir="-L$libdir"
+	      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
@@ -6927,10 +8370,10 @@ func_mode_link ()
 		    ;;
 		esac
 	      fi
-	      add="-l$name"
+	      add=-l$name
 	    fi
 
-	    if test "$linkmode" = prog; then
+	    if test prog = "$linkmode"; then
 	      test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs"
 	      test -n "$add" && finalize_deplibs="$add $finalize_deplibs"
 	    else
@@ -6938,43 +8381,43 @@ func_mode_link ()
 	      test -n "$add" && deplibs="$add $deplibs"
 	    fi
 	  fi
-	elif test "$linkmode" = prog; then
+	elif test prog = "$linkmode"; 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"
+	  if test unsupported != "$hardcode_direct"; 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
+	elif test yes = "$build_libtool_libs"; then
 	  # Not a shared library
-	  if test "$deplibs_check_method" != pass_all; then
+	  if test pass_all != "$deplibs_check_method"; 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 "*** Warning: This system cannot 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
+	    if test yes = "$module"; 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 "*** 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."
+		echo "*** 'nm' from GNU binutils and a full rebuild may help."
 	      fi
-	      if test "$build_old_libs" = no; then
+	      if test no = "$build_old_libs"; then
 		build_libtool_libs=module
 		build_old_libs=yes
 	      else
@@ -6987,11 +8430,11 @@ func_mode_link ()
 	  fi
 	fi # link shared/static library?
 
-	if test "$linkmode" = lib; then
+	if test lib = "$linkmode"; then
 	  if test -n "$dependency_libs" &&
-	     { test "$hardcode_into_libs" != yes ||
-	       test "$build_old_libs" = yes ||
-	       test "$link_static" = yes; }; then
+	     { test yes != "$hardcode_into_libs" ||
+	       test yes = "$build_old_libs" ||
+	       test yes = "$link_static"; }; then
 	    # Extract -R from dependency_libs
 	    temp_deplibs=
 	    for libdir in $dependency_libs; do
@@ -7005,12 +8448,12 @@ func_mode_link ()
 	      *) func_append temp_deplibs " $libdir";;
 	      esac
 	    done
-	    dependency_libs="$temp_deplibs"
+	    dependency_libs=$temp_deplibs
 	  fi
 
 	  func_append newlib_search_path " $absdir"
 	  # Link against this library
-	  test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs"
+	  test no = "$link_static" && newdependency_libs="$abs_ladir/$laname $newdependency_libs"
 	  # ... and its dependency_libs
 	  tmp_libs=
 	  for deplib in $dependency_libs; do
@@ -7020,7 +8463,7 @@ func_mode_link ()
                    func_resolve_sysroot "$func_stripname_result";;
               *) func_resolve_sysroot "$deplib" ;;
             esac
-	    if $opt_preserve_dup_deps ; then
+	    if $opt_preserve_dup_deps; then
 	      case "$tmp_libs " in
 	      *" $func_resolve_sysroot_result "*)
                 func_append specialdeplibs " $func_resolve_sysroot_result" ;;
@@ -7029,12 +8472,12 @@ func_mode_link ()
 	    func_append tmp_libs " $func_resolve_sysroot_result"
 	  done
 
-	  if test "$link_all_deplibs" != no; then
+	  if test no != "$link_all_deplibs"; then
 	    # Add the search paths of all dependency libraries
 	    for deplib in $dependency_libs; do
 	      path=
 	      case $deplib in
-	      -L*) path="$deplib" ;;
+	      -L*) path=$deplib ;;
 	      *.la)
 	        func_resolve_sysroot "$deplib"
 	        deplib=$func_resolve_sysroot_result
@@ -7042,12 +8485,12 @@ func_mode_link ()
 		dir=$func_dirname_result
 		# We need an absolute path.
 		case $dir in
-		[\\/]* | [A-Za-z]:[\\/]*) absdir="$dir" ;;
+		[\\/]* | [A-Za-z]:[\\/]*) absdir=$dir ;;
 		*)
 		  absdir=`cd "$dir" && pwd`
 		  if test -z "$absdir"; then
-		    func_warning "cannot determine absolute directory name of \`$dir'"
-		    absdir="$dir"
+		    func_warning "cannot determine absolute directory name of '$dir'"
+		    absdir=$dir
 		  fi
 		  ;;
 		esac
@@ -7055,35 +8498,35 @@ func_mode_link ()
 		case $host in
 		*-*-darwin*)
 		  depdepl=
-		  eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib`
-		  if test -n "$deplibrary_names" ; then
-		    for tmp in $deplibrary_names ; do
+		  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 "$absdir/$objdir/$depdepl" ; then
-		      depdepl="$absdir/$objdir/$depdepl"
-		      darwin_install_name=`${OTOOL} -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'`
+		    if test -f "$absdir/$objdir/$depdepl"; then
+		      depdepl=$absdir/$objdir/$depdepl
+		      darwin_install_name=`$OTOOL -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'`
                       if test -z "$darwin_install_name"; then
-                          darwin_install_name=`${OTOOL64} -L $depdepl  | awk '{if (NR == 2) {print $1;exit}}'`
+                          darwin_install_name=`$OTOOL64 -L $depdepl  | awk '{if (NR == 2) {print $1;exit}}'`
                       fi
-		      func_append compiler_flags " ${wl}-dylib_file ${wl}${darwin_install_name}:${depdepl}"
-		      func_append linker_flags " -dylib_file ${darwin_install_name}:${depdepl}"
+		      func_append compiler_flags " $wl-dylib_file $wl$darwin_install_name:$depdepl"
+		      func_append linker_flags " -dylib_file $darwin_install_name:$depdepl"
 		      path=
 		    fi
 		  fi
 		  ;;
 		*)
-		  path="-L$absdir/$objdir"
+		  path=-L$absdir/$objdir
 		  ;;
 		esac
 		else
-		  eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
+		  eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
 		  test -z "$libdir" && \
-		    func_fatal_error "\`$deplib' is not a valid libtool archive"
+		    func_fatal_error "'$deplib' is not a valid libtool archive"
 		  test "$absdir" != "$libdir" && \
-		    func_warning "\`$deplib' seems to be moved"
+		    func_warning "'$deplib' seems to be moved"
 
-		  path="-L$absdir"
+		  path=-L$absdir
 		fi
 		;;
 	      esac
@@ -7095,23 +8538,23 @@ func_mode_link ()
 	  fi # link_all_deplibs != no
 	fi # linkmode = lib
       done # for deplib in $libs
-      if test "$pass" = link; then
-	if test "$linkmode" = "prog"; then
+      if test link = "$pass"; then
+	if test prog = "$linkmode"; then
 	  compile_deplibs="$new_inherited_linker_flags $compile_deplibs"
 	  finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs"
 	else
 	  compiler_flags="$compiler_flags "`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
 	fi
       fi
-      dependency_libs="$newdependency_libs"
-      if test "$pass" = dlpreopen; then
+      dependency_libs=$newdependency_libs
+      if test dlpreopen = "$pass"; 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
+      if test dlopen != "$pass"; then
+	test conv = "$pass" || {
 	  # Make sure lib_search_path contains only unique directories.
 	  lib_search_path=
 	  for dir in $newlib_search_path; do
@@ -7121,12 +8564,12 @@ func_mode_link ()
 	    esac
 	  done
 	  newlib_search_path=
-	fi
+	}
 
-	if test "$linkmode,$pass" != "prog,link"; then
-	  vars="deplibs"
-	else
+	if test prog,link = "$linkmode,$pass"; then
 	  vars="compile_deplibs finalize_deplibs"
+	else
+	  vars=deplibs
 	fi
 	for var in $vars dependency_libs; do
 	  # Add libraries to $var in reverse order
@@ -7184,62 +8627,93 @@ func_mode_link ()
 	  eval $var=\"$tmp_libs\"
 	done # for var
       fi
+
+      # Add Sun CC postdeps if required:
+      test CXX = "$tagname" && {
+        case $host_os in
+        linux*)
+          case `$CC -V 2>&1 | sed 5q` in
+          *Sun\ C*) # Sun C++ 5.9
+            func_suncc_cstd_abi
+
+            if test no != "$suncc_use_cstd_abi"; then
+              func_append postdeps ' -library=Cstd -library=Crun'
+            fi
+            ;;
+          esac
+          ;;
+
+        solaris*)
+          func_cc_basename "$CC"
+          case $func_cc_basename_result in
+          CC* | sunCC*)
+            func_suncc_cstd_abi
+
+            if test no != "$suncc_use_cstd_abi"; then
+              func_append postdeps ' -library=Cstd -library=Crun'
+            fi
+            ;;
+          esac
+          ;;
+        esac
+      }
+
       # Last step: remove runtime libs from dependency_libs
       # (they stay in deplibs)
       tmp_libs=
-      for i in $dependency_libs ; do
+      for i in $dependency_libs; do
 	case " $predeps $postdeps $compiler_lib_search_path " in
 	*" $i "*)
-	  i=""
+	  i=
 	  ;;
 	esac
-	if test -n "$i" ; then
+	if test -n "$i"; then
 	  func_append tmp_libs " $i"
 	fi
       done
       dependency_libs=$tmp_libs
     done # for pass
-    if test "$linkmode" = prog; then
-      dlfiles="$newdlfiles"
+    if test prog = "$linkmode"; then
+      dlfiles=$newdlfiles
     fi
-    if test "$linkmode" = prog || test "$linkmode" = lib; then
-      dlprefiles="$newdlprefiles"
+    if test prog = "$linkmode" || test lib = "$linkmode"; then
+      dlprefiles=$newdlprefiles
     fi
 
     case $linkmode in
     oldlib)
-      if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
-	func_warning "\`-dlopen' is ignored for archives"
+      if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then
+	func_warning "'-dlopen' is ignored for archives"
       fi
 
       case " $deplibs" in
       *\ -l* | *\ -L*)
-	func_warning "\`-l' and \`-L' are ignored for archives" ;;
+	func_warning "'-l' and '-L' are ignored for archives" ;;
       esac
 
       test -n "$rpath" && \
-	func_warning "\`-rpath' is ignored for archives"
+	func_warning "'-rpath' is ignored for archives"
 
       test -n "$xrpath" && \
-	func_warning "\`-R' is ignored for archives"
+	func_warning "'-R' is ignored for archives"
 
       test -n "$vinfo" && \
-	func_warning "\`-version-info/-version-number' is ignored for archives"
+	func_warning "'-version-info/-version-number' is ignored for archives"
 
       test -n "$release" && \
-	func_warning "\`-release' is ignored for archives"
+	func_warning "'-release' is ignored for archives"
 
       test -n "$export_symbols$export_symbols_regex" && \
-	func_warning "\`-export-symbols' is ignored for archives"
+	func_warning "'-export-symbols' is ignored for archives"
 
       # Now set the variables for building old libraries.
       build_libtool_libs=no
-      oldlibs="$output"
+      oldlibs=$output
       func_append objs "$old_deplibs"
       ;;
 
     lib)
-      # Make sure we only generate libraries of the form `libNAME.la'.
+      # Make sure we only generate libraries of the form 'libNAME.la'.
       case $outputname in
       lib*)
 	func_stripname 'lib' '.la' "$outputname"
@@ -7248,10 +8722,10 @@ func_mode_link ()
 	eval libname=\"$libname_spec\"
 	;;
       *)
-	test "$module" = no && \
-	  func_fatal_help "libtool library \`$output' must begin with \`lib'"
+	test no = "$module" \
+	  && func_fatal_help "libtool library '$output' must begin with 'lib'"
 
-	if test "$need_lib_prefix" != no; then
+	if test no != "$need_lib_prefix"; then
 	  # Add the "lib" prefix for modules if required
 	  func_stripname '' '.la' "$outputname"
 	  name=$func_stripname_result
@@ -7265,8 +8739,8 @@ func_mode_link ()
       esac
 
       if test -n "$objs"; then
-	if test "$deplibs_check_method" != pass_all; then
-	  func_fatal_error "cannot build libtool library \`$output' from non-libtool objects on this host:$objs"
+	if test pass_all != "$deplibs_check_method"; then
+	  func_fatal_error "cannot build libtool library '$output' from non-libtool objects on this host:$objs"
 	else
 	  echo
 	  $ECHO "*** Warning: Linking the shared library $output against the non-libtool"
@@ -7275,21 +8749,21 @@ func_mode_link ()
 	fi
       fi
 
-      test "$dlself" != no && \
-	func_warning "\`-dlopen self' is ignored for libtool libraries"
+      test no = "$dlself" \
+	|| func_warning "'-dlopen self' is ignored for libtool libraries"
 
       set dummy $rpath
       shift
-      test "$#" -gt 1 && \
-	func_warning "ignoring multiple \`-rpath's for a libtool library"
+      test 1 -lt "$#" \
+	&& func_warning "ignoring multiple '-rpath's for a libtool library"
 
-      install_libdir="$1"
+      install_libdir=$1
 
       oldlibs=
       if test -z "$rpath"; then
-	if test "$build_libtool_libs" = yes; then
+	if test yes = "$build_libtool_libs"; then
 	  # Building a libtool convenience library.
-	  # Some compilers have problems with a `.al' extension so
+	  # 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"
@@ -7298,20 +8772,20 @@ func_mode_link ()
 	fi
 
 	test -n "$vinfo" && \
-	  func_warning "\`-version-info/-version-number' is ignored for convenience libraries"
+	  func_warning "'-version-info/-version-number' is ignored for convenience libraries"
 
 	test -n "$release" && \
-	  func_warning "\`-release' is ignored for convenience libraries"
+	  func_warning "'-release' is ignored for convenience libraries"
       else
 
 	# Parse the version information argument.
-	save_ifs="$IFS"; IFS=':'
+	save_ifs=$IFS; IFS=:
 	set dummy $vinfo 0 0 0
 	shift
-	IFS="$save_ifs"
+	IFS=$save_ifs
 
 	test -n "$7" && \
-	  func_fatal_help "too many parameters to \`-version-info'"
+	  func_fatal_help "too many parameters to '-version-info'"
 
 	# convert absolute version numbers to libtool ages
 	# this retains compatibility with .la files and attempts
@@ -7319,42 +8793,42 @@ func_mode_link ()
 
 	case $vinfo_number in
 	yes)
-	  number_major="$1"
-	  number_minor="$2"
-	  number_revision="$3"
+	  number_major=$1
+	  number_minor=$2
+	  number_revision=$3
 	  #
 	  # 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
+	  # that has an extra 1 added just for fun
 	  #
 	  case $version_type in
 	  # correct linux to gnu/linux during the next big refactor
-	  darwin|linux|osf|windows|none)
+	  darwin|freebsd-elf|linux|osf|windows|none)
 	    func_arith $number_major + $number_minor
 	    current=$func_arith_result
-	    age="$number_minor"
-	    revision="$number_revision"
+	    age=$number_minor
+	    revision=$number_revision
 	    ;;
-	  freebsd-aout|freebsd-elf|qnx|sunos)
-	    current="$number_major"
-	    revision="$number_minor"
-	    age="0"
+	  freebsd-aout|qnx|sunos)
+	    current=$number_major
+	    revision=$number_minor
+	    age=0
 	    ;;
 	  irix|nonstopux)
 	    func_arith $number_major + $number_minor
 	    current=$func_arith_result
-	    age="$number_minor"
-	    revision="$number_minor"
+	    age=$number_minor
+	    revision=$number_minor
 	    lt_irix_increment=no
 	    ;;
 	  esac
 	  ;;
 	no)
-	  current="$1"
-	  revision="$2"
-	  age="$3"
+	  current=$1
+	  revision=$2
+	  age=$3
 	  ;;
 	esac
 
@@ -7362,30 +8836,30 @@ func_mode_link ()
 	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]) ;;
 	*)
-	  func_error "CURRENT \`$current' must be a nonnegative integer"
-	  func_fatal_error "\`$vinfo' is not valid version information"
+	  func_error "CURRENT '$current' must be a nonnegative integer"
+	  func_fatal_error "'$vinfo' is not valid version information"
 	  ;;
 	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]) ;;
 	*)
-	  func_error "REVISION \`$revision' must be a nonnegative integer"
-	  func_fatal_error "\`$vinfo' is not valid version information"
+	  func_error "REVISION '$revision' must be a nonnegative integer"
+	  func_fatal_error "'$vinfo' is not valid version information"
 	  ;;
 	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]) ;;
 	*)
-	  func_error "AGE \`$age' must be a nonnegative integer"
-	  func_fatal_error "\`$vinfo' is not valid version information"
+	  func_error "AGE '$age' must be a nonnegative integer"
+	  func_fatal_error "'$vinfo' is not valid version information"
 	  ;;
 	esac
 
 	if test "$age" -gt "$current"; then
-	  func_error "AGE \`$age' is greater than the current interface number \`$current'"
-	  func_fatal_error "\`$vinfo' is not valid version information"
+	  func_error "AGE '$age' is greater than the current interface number '$current'"
+	  func_fatal_error "'$vinfo' is not valid version information"
 	fi
 
 	# Calculate the version variables.
@@ -7400,26 +8874,36 @@ func_mode_link ()
 	  # verstring for coding it into the library header
 	  func_arith $current - $age
 	  major=.$func_arith_result
-	  versuffix="$major.$age.$revision"
+	  versuffix=$major.$age.$revision
 	  # Darwin ld doesn't like 0 for these options...
 	  func_arith $current + 1
 	  minor_current=$func_arith_result
-	  xlcverstring="${wl}-compatibility_version ${wl}$minor_current ${wl}-current_version ${wl}$minor_current.$revision"
+	  xlcverstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision"
 	  verstring="-compatibility_version $minor_current -current_version $minor_current.$revision"
+          # On Darwin other compilers
+          case $CC in
+              nagfor*)
+                  verstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision"
+                  ;;
+              *)
+                  verstring="-compatibility_version $minor_current -current_version $minor_current.$revision"
+                  ;;
+          esac
 	  ;;
 
 	freebsd-aout)
-	  major=".$current"
-	  versuffix=".$current.$revision";
+	  major=.$current
+	  versuffix=.$current.$revision
 	  ;;
 
 	freebsd-elf)
-	  major=".$current"
-	  versuffix=".$current"
+	  func_arith $current - $age
+	  major=.$func_arith_result
+	  versuffix=$major.$age.$revision
 	  ;;
 
 	irix | nonstopux)
-	  if test "X$lt_irix_increment" = "Xno"; then
+	  if test no = "$lt_irix_increment"; then
 	    func_arith $current - $age
 	  else
 	    func_arith $current - $age + 1
@@ -7430,69 +8914,74 @@ func_mode_link ()
 	    nonstopux) verstring_prefix=nonstopux ;;
 	    *)         verstring_prefix=sgi ;;
 	  esac
-	  verstring="$verstring_prefix$major.$revision"
+	  verstring=$verstring_prefix$major.$revision
 
 	  # Add in all the interfaces that we are compatible with.
 	  loop=$revision
-	  while test "$loop" -ne 0; do
+	  while test 0 -ne "$loop"; do
 	    func_arith $revision - $loop
 	    iface=$func_arith_result
 	    func_arith $loop - 1
 	    loop=$func_arith_result
-	    verstring="$verstring_prefix$major.$iface:$verstring"
+	    verstring=$verstring_prefix$major.$iface:$verstring
 	  done
 
-	  # Before this point, $major must not contain `.'.
+	  # Before this point, $major must not contain '.'.
 	  major=.$major
-	  versuffix="$major.$revision"
+	  versuffix=$major.$revision
 	  ;;
 
 	linux) # correct to gnu/linux during the next big refactor
 	  func_arith $current - $age
 	  major=.$func_arith_result
-	  versuffix="$major.$age.$revision"
+	  versuffix=$major.$age.$revision
 	  ;;
 
 	osf)
 	  func_arith $current - $age
 	  major=.$func_arith_result
-	  versuffix=".$current.$age.$revision"
-	  verstring="$current.$age.$revision"
+	  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
+	  while test 0 -ne "$loop"; do
 	    func_arith $current - $loop
 	    iface=$func_arith_result
 	    func_arith $loop - 1
 	    loop=$func_arith_result
-	    verstring="$verstring:${iface}.0"
+	    verstring=$verstring:$iface.0
 	  done
 
 	  # Make executables depend on our current version.
-	  func_append verstring ":${current}.0"
+	  func_append verstring ":$current.0"
 	  ;;
 
 	qnx)
-	  major=".$current"
-	  versuffix=".$current"
+	  major=.$current
+	  versuffix=.$current
+	  ;;
+
+	sco)
+	  major=.$current
+	  versuffix=.$current
 	  ;;
 
 	sunos)
-	  major=".$current"
-	  versuffix=".$current.$revision"
+	  major=.$current
+	  versuffix=.$current.$revision
 	  ;;
 
 	windows)
 	  # Use '-' rather than '.', since we only want one
-	  # extension on DOS 8.3 filesystems.
+	  # extension on DOS 8.3 file systems.
 	  func_arith $current - $age
 	  major=$func_arith_result
-	  versuffix="-$major"
+	  versuffix=-$major
 	  ;;
 
 	*)
-	  func_fatal_configuration "unknown library version type \`$version_type'"
+	  func_fatal_configuration "unknown library version type '$version_type'"
 	  ;;
 	esac
 
@@ -7506,42 +8995,45 @@ func_mode_link ()
 	    verstring=
 	    ;;
 	  *)
-	    verstring="0.0"
+	    verstring=0.0
 	    ;;
 	  esac
-	  if test "$need_version" = no; then
+	  if test no = "$need_version"; then
 	    versuffix=
 	  else
-	    versuffix=".0.0"
+	    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
+	if test yes,no = "$avoid_version,$need_version"; then
 	  major=
 	  versuffix=
-	  verstring=""
+	  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
-	    func_warning "undefined symbols not allowed in $host shared libraries"
-	    build_libtool_libs=no
-	    build_old_libs=yes
+	if test yes = "$allow_undefined"; then
+	  if test unsupported = "$allow_undefined_flag"; then
+	    if test yes = "$build_old_libs"; then
+	      func_warning "undefined symbols not allowed in $host shared libraries; building static only"
+	      build_libtool_libs=no
+	    else
+	      func_fatal_error "can't build $host shared library unless -no-undefined is specified"
+	    fi
 	  fi
 	else
 	  # Don't allow undefined symbols.
-	  allow_undefined_flag="$no_undefined_flag"
+	  allow_undefined_flag=$no_undefined_flag
 	fi
 
       fi
 
-      func_generate_dlsyms "$libname" "$libname" "yes"
+      func_generate_dlsyms "$libname" "$libname" :
       func_append libobjs " $symfileobj"
-      test "X$libobjs" = "X " && libobjs=
+      test " " = "$libobjs" && libobjs=
 
-      if test "$opt_mode" != relink; then
+      if test relink != "$opt_mode"; then
 	# Remove our outputs, but don't remove object files since they
 	# may have been created when compiling PIC objects.
 	removelist=
@@ -7550,8 +9042,8 @@ func_mode_link ()
 	  case $p in
 	    *.$objext | *.gcno)
 	       ;;
-	    $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/${libname}${release}.*)
-	       if test "X$precious_files_regex" != "X"; then
+	    $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/$libname$release.*)
+	       if test -n "$precious_files_regex"; then
 		 if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1
 		 then
 		   continue
@@ -7567,11 +9059,11 @@ func_mode_link ()
       fi
 
       # Now set the variables for building old libraries.
-      if test "$build_old_libs" = yes && test "$build_libtool_libs" != convenience ; then
+      if test yes = "$build_old_libs" && test convenience != "$build_libtool_libs"; then
 	func_append oldlibs " $output_objdir/$libname.$libext"
 
 	# Transform .lo files to .o files.
-	oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.${libext}$/d; $lo2o" | $NL2SP`
+	oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; $lo2o" | $NL2SP`
       fi
 
       # Eliminate all temporary directories.
@@ -7592,13 +9084,13 @@ func_mode_link ()
 	  *) func_append finalize_rpath " $libdir" ;;
 	  esac
 	done
-	if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then
+	if test yes != "$hardcode_into_libs" || test yes = "$build_old_libs"; then
 	  dependency_libs="$temp_xrpath $dependency_libs"
 	fi
       fi
 
       # Make sure dlfiles contains only unique files that won't be dlpreopened
-      old_dlfiles="$dlfiles"
+      old_dlfiles=$dlfiles
       dlfiles=
       for lib in $old_dlfiles; do
 	case " $dlprefiles $dlfiles " in
@@ -7608,7 +9100,7 @@ func_mode_link ()
       done
 
       # Make sure dlprefiles contains only unique files
-      old_dlprefiles="$dlprefiles"
+      old_dlprefiles=$dlprefiles
       dlprefiles=
       for lib in $old_dlprefiles; do
 	case "$dlprefiles " in
@@ -7617,7 +9109,7 @@ func_mode_link ()
 	esac
       done
 
-      if test "$build_libtool_libs" = yes; then
+      if test yes = "$build_libtool_libs"; then
 	if test -n "$rpath"; then
 	  case $host in
 	  *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc* | *-*-haiku*)
@@ -7641,7 +9133,7 @@ func_mode_link ()
 	    ;;
 	  *)
 	    # Add libc to deplibs on all other systems if necessary.
-	    if test "$build_libtool_need_lc" = "yes"; then
+	    if test yes = "$build_libtool_need_lc"; then
 	      func_append deplibs " -lc"
 	    fi
 	    ;;
@@ -7657,9 +9149,9 @@ func_mode_link ()
 	# 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=""
+	release=
+	versuffix=
+	major=
 	newdeplibs=
 	droppeddeps=no
 	case $deplibs_check_method in
@@ -7688,20 +9180,20 @@ EOF
 	      -l*)
 		func_stripname -l '' "$i"
 		name=$func_stripname_result
-		if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+		if test yes = "$allow_libtool_libs_with_static_runtimes"; then
 		  case " $predeps $postdeps " in
 		  *" $i "*)
 		    func_append newdeplibs " $i"
-		    i=""
+		    i=
 		    ;;
 		  esac
 		fi
-		if test -n "$i" ; then
+		if test -n "$i"; then
 		  libname=`eval "\\$ECHO \"$libname_spec\""`
 		  deplib_matches=`eval "\\$ECHO \"$library_names_spec\""`
 		  set dummy $deplib_matches; shift
 		  deplib_match=$1
-		  if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
+		  if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0; then
 		    func_append newdeplibs " $i"
 		  else
 		    droppeddeps=yes
@@ -7731,20 +9223,20 @@ EOF
 		$opt_dry_run || $RM conftest
 		if $LTCC $LTCFLAGS -o conftest conftest.c $i; then
 		  ldd_output=`ldd conftest`
-		  if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+		  if test yes = "$allow_libtool_libs_with_static_runtimes"; then
 		    case " $predeps $postdeps " in
 		    *" $i "*)
 		      func_append newdeplibs " $i"
-		      i=""
+		      i=
 		      ;;
 		    esac
 		  fi
-		  if test -n "$i" ; then
+		  if test -n "$i"; then
 		    libname=`eval "\\$ECHO \"$libname_spec\""`
 		    deplib_matches=`eval "\\$ECHO \"$library_names_spec\""`
 		    set dummy $deplib_matches; shift
 		    deplib_match=$1
-		    if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
+		    if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0; then
 		      func_append newdeplibs " $i"
 		    else
 		      droppeddeps=yes
@@ -7781,24 +9273,24 @@ EOF
 	    -l*)
 	      func_stripname -l '' "$a_deplib"
 	      name=$func_stripname_result
-	      if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+	      if test yes = "$allow_libtool_libs_with_static_runtimes"; then
 		case " $predeps $postdeps " in
 		*" $a_deplib "*)
 		  func_append newdeplibs " $a_deplib"
-		  a_deplib=""
+		  a_deplib=
 		  ;;
 		esac
 	      fi
-	      if test -n "$a_deplib" ; then
+	      if test -n "$a_deplib"; then
 		libname=`eval "\\$ECHO \"$libname_spec\""`
 		if test -n "$file_magic_glob"; then
 		  libnameglob=`func_echo_all "$libname" | $SED -e $file_magic_glob`
 		else
 		  libnameglob=$libname
 		fi
-		test "$want_nocaseglob" = yes && nocaseglob=`shopt -p nocaseglob`
+		test yes = "$want_nocaseglob" && nocaseglob=`shopt -p nocaseglob`
 		for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
-		  if test "$want_nocaseglob" = yes; then
+		  if test yes = "$want_nocaseglob"; then
 		    shopt -s nocaseglob
 		    potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null`
 		    $nocaseglob
@@ -7816,25 +9308,25 @@ EOF
 		      # We might still enter an endless loop, since a link
 		      # loop can be closed while we follow links,
 		      # but so what?
-		      potlib="$potent_lib"
+		      potlib=$potent_lib
 		      while test -h "$potlib" 2>/dev/null; do
-			potliblink=`ls -ld $potlib | ${SED} 's/.* -> //'`
+			potliblink=`ls -ld $potlib | $SED 's/.* -> //'`
 			case $potliblink in
-			[\\/]* | [A-Za-z]:[\\/]*) potlib="$potliblink";;
-			*) potlib=`$ECHO "$potlib" | $SED 's,[^/]*$,,'`"$potliblink";;
+			[\\/]* | [A-Za-z]:[\\/]*) potlib=$potliblink;;
+			*) potlib=`$ECHO "$potlib" | $SED 's|[^/]*$||'`"$potliblink";;
 			esac
 		      done
 		      if eval $file_magic_cmd \"\$potlib\" 2>/dev/null |
 			 $SED -e 10q |
 			 $EGREP "$file_magic_regex" > /dev/null; then
 			func_append newdeplibs " $a_deplib"
-			a_deplib=""
+			a_deplib=
 			break 2
 		      fi
 		  done
 		done
 	      fi
-	      if test -n "$a_deplib" ; then
+	      if test -n "$a_deplib"; then
 		droppeddeps=yes
 		echo
 		$ECHO "*** Warning: linker path does not have real file for library $a_deplib."
@@ -7842,7 +9334,7 @@ EOF
 		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
+		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"
@@ -7865,30 +9357,30 @@ EOF
 	    -l*)
 	      func_stripname -l '' "$a_deplib"
 	      name=$func_stripname_result
-	      if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+	      if test yes = "$allow_libtool_libs_with_static_runtimes"; then
 		case " $predeps $postdeps " in
 		*" $a_deplib "*)
 		  func_append newdeplibs " $a_deplib"
-		  a_deplib=""
+		  a_deplib=
 		  ;;
 		esac
 	      fi
-	      if test -n "$a_deplib" ; then
+	      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
+		    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
 		      func_append newdeplibs " $a_deplib"
-		      a_deplib=""
+		      a_deplib=
 		      break 2
 		    fi
 		  done
 		done
 	      fi
-	      if test -n "$a_deplib" ; then
+	      if test -n "$a_deplib"; then
 		droppeddeps=yes
 		echo
 		$ECHO "*** Warning: linker path does not have real file for library $a_deplib."
@@ -7896,7 +9388,7 @@ EOF
 		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
+		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"
@@ -7912,18 +9404,18 @@ EOF
 	  done # Gone through all deplibs.
 	  ;;
 	none | unknown | *)
-	  newdeplibs=""
+	  newdeplibs=
 	  tmp_deplibs=`$ECHO " $deplibs" | $SED 's/ -lc$//; s/ -[LR][^ ]*//g'`
-	  if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
-	    for i in $predeps $postdeps ; do
+	  if test yes = "$allow_libtool_libs_with_static_runtimes"; then
+	    for i in $predeps $postdeps; do
 	      # can't use Xsed below, because $i might contain '/'
-	      tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s,$i,,"`
+	      tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s|$i||"`
 	    done
 	  fi
 	  case $tmp_deplibs in
 	  *[!\	\ ]*)
 	    echo
-	    if test "X$deplibs_check_method" = "Xnone"; then
+	    if test none = "$deplibs_check_method"; then
 	      echo "*** Warning: inter-library dependencies are not supported in this platform."
 	    else
 	      echo "*** Warning: inter-library dependencies are not known to be supported."
@@ -7947,8 +9439,8 @@ EOF
 	  ;;
 	esac
 
-	if test "$droppeddeps" = yes; then
-	  if test "$module" = yes; then
+	if test yes = "$droppeddeps"; then
+	  if test yes = "$module"; then
 	    echo
 	    echo "*** Warning: libtool could not satisfy all declared inter-library"
 	    $ECHO "*** dependencies of module $libname.  Therefore, libtool will create"
@@ -7957,12 +9449,12 @@ EOF
 	    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 "*** 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."
+	      echo "*** 'nm' from GNU binutils and a full rebuild may help."
 	    fi
-	    if test "$build_old_libs" = no; then
-	      oldlibs="$output_objdir/$libname.$libext"
+	    if test no = "$build_old_libs"; then
+	      oldlibs=$output_objdir/$libname.$libext
 	      build_libtool_libs=module
 	      build_old_libs=yes
 	    else
@@ -7973,14 +9465,14 @@ EOF
 	    echo "*** automatically added whenever a program is linked with this library"
 	    echo "*** or is declared to -dlopen it."
 
-	    if test "$allow_undefined" = no; then
+	    if test no = "$allow_undefined"; 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"
+	      if test no = "$build_old_libs"; then
+		oldlibs=$output_objdir/$libname.$libext
 		build_libtool_libs=module
 		build_old_libs=yes
 	      else
@@ -8026,7 +9518,7 @@ EOF
 	*) func_append new_libs " $deplib" ;;
 	esac
       done
-      deplibs="$new_libs"
+      deplibs=$new_libs
 
       # All the library-specific variables (install_libdir is set above).
       library_names=
@@ -8034,25 +9526,25 @@ EOF
       dlname=
 
       # Test again, we may have decided not to build it any more
-      if test "$build_libtool_libs" = yes; then
-	# Remove ${wl} instances when linking with ld.
+      if test yes = "$build_libtool_libs"; then
+	# Remove $wl instances when linking with ld.
 	# FIXME: should test the right _cmds variable.
 	case $archive_cmds in
 	  *\$LD\ *) wl= ;;
         esac
-	if test "$hardcode_into_libs" = yes; then
+	if test yes = "$hardcode_into_libs"; then
 	  # Hardcode the library paths
 	  hardcode_libdirs=
 	  dep_rpath=
-	  rpath="$finalize_rpath"
-	  test "$opt_mode" != relink && rpath="$compile_rpath$rpath"
+	  rpath=$finalize_rpath
+	  test relink = "$opt_mode" || rpath=$compile_rpath$rpath
 	  for libdir in $rpath; do
 	    if test -n "$hardcode_libdir_flag_spec"; then
 	      if test -n "$hardcode_libdir_separator"; then
 		func_replace_sysroot "$libdir"
 		libdir=$func_replace_sysroot_result
 		if test -z "$hardcode_libdirs"; then
-		  hardcode_libdirs="$libdir"
+		  hardcode_libdirs=$libdir
 		else
 		  # Just accumulate the unique libdirs.
 		  case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
@@ -8077,7 +9569,7 @@ EOF
 	  # Substitute the hardcoded libdirs into the rpath.
 	  if test -n "$hardcode_libdir_separator" &&
 	     test -n "$hardcode_libdirs"; then
-	    libdir="$hardcode_libdirs"
+	    libdir=$hardcode_libdirs
 	    eval "dep_rpath=\"$hardcode_libdir_flag_spec\""
 	  fi
 	  if test -n "$runpath_var" && test -n "$perm_rpath"; then
@@ -8091,8 +9583,8 @@ EOF
 	  test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs"
 	fi
 
-	shlibpath="$finalize_shlibpath"
-	test "$opt_mode" != relink && shlibpath="$compile_shlibpath$shlibpath"
+	shlibpath=$finalize_shlibpath
+	test relink = "$opt_mode" || shlibpath=$compile_shlibpath$shlibpath
 	if test -n "$shlibpath"; then
 	  eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var"
 	fi
@@ -8102,19 +9594,19 @@ EOF
 	eval library_names=\"$library_names_spec\"
 	set dummy $library_names
 	shift
-	realname="$1"
+	realname=$1
 	shift
 
 	if test -n "$soname_spec"; then
 	  eval soname=\"$soname_spec\"
 	else
-	  soname="$realname"
+	  soname=$realname
 	fi
 	if test -z "$dlname"; then
 	  dlname=$soname
 	fi
 
-	lib="$output_objdir/$realname"
+	lib=$output_objdir/$realname
 	linknames=
 	for link
 	do
@@ -8128,7 +9620,7 @@ EOF
 	delfiles=
 	if test -n "$export_symbols" && test -n "$include_expsyms"; then
 	  $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp"
-	  export_symbols="$output_objdir/$libname.uexp"
+	  export_symbols=$output_objdir/$libname.uexp
 	  func_append delfiles " $export_symbols"
 	fi
 
@@ -8137,31 +9629,31 @@ EOF
 	cygwin* | mingw* | cegcc*)
 	  if test -n "$export_symbols" && test -z "$export_symbols_regex"; then
 	    # exporting using user supplied symfile
-	    if test "x`$SED 1q $export_symbols`" != xEXPORTS; then
+	    func_dll_def_p "$export_symbols" || {
 	      # and it's NOT already a .def file. Must figure out
 	      # which of the given symbols are data symbols and tag
 	      # them as such. So, trigger use of export_symbols_cmds.
 	      # export_symbols gets reassigned inside the "prepare
 	      # the list of exported symbols" if statement, so the
 	      # include_expsyms logic still works.
-	      orig_export_symbols="$export_symbols"
+	      orig_export_symbols=$export_symbols
 	      export_symbols=
 	      always_export_symbols=yes
-	    fi
+	    }
 	  fi
 	  ;;
 	esac
 
 	# Prepare the list of exported symbols
 	if test -z "$export_symbols"; then
-	  if test "$always_export_symbols" = yes || test -n "$export_symbols_regex"; then
-	    func_verbose "generating symbol list for \`$libname.la'"
-	    export_symbols="$output_objdir/$libname.exp"
+	  if test yes = "$always_export_symbols" || test -n "$export_symbols_regex"; then
+	    func_verbose "generating symbol list for '$libname.la'"
+	    export_symbols=$output_objdir/$libname.exp
 	    $opt_dry_run || $RM $export_symbols
 	    cmds=$export_symbols_cmds
-	    save_ifs="$IFS"; IFS='~'
+	    save_ifs=$IFS; IFS='~'
 	    for cmd1 in $cmds; do
-	      IFS="$save_ifs"
+	      IFS=$save_ifs
 	      # Take the normal branch if the nm_file_list_spec branch
 	      # doesn't work or if tool conversion is not needed.
 	      case $nm_file_list_spec~$to_tool_file_cmd in
@@ -8175,7 +9667,7 @@ EOF
 		  try_normal_branch=no
 		  ;;
 	      esac
-	      if test "$try_normal_branch" = yes \
+	      if test yes = "$try_normal_branch" \
 		 && { test "$len" -lt "$max_cmd_len" \
 		      || test "$max_cmd_len" -le -1; }
 	      then
@@ -8186,7 +9678,7 @@ EOF
 		output_la=$func_basename_result
 		save_libobjs=$libobjs
 		save_output=$output
-		output=${output_objdir}/${output_la}.nm
+		output=$output_objdir/$output_la.nm
 		func_to_tool_file "$output"
 		libobjs=$nm_file_list_spec$func_to_tool_file_result
 		func_append delfiles " $output"
@@ -8209,8 +9701,8 @@ EOF
 		break
 	      fi
 	    done
-	    IFS="$save_ifs"
-	    if test -n "$export_symbols_regex" && test "X$skipped_export" != "X:"; then
+	    IFS=$save_ifs
+	    if test -n "$export_symbols_regex" && test : != "$skipped_export"; then
 	      func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
 	      func_show_eval '$MV "${export_symbols}T" "$export_symbols"'
 	    fi
@@ -8218,16 +9710,16 @@ EOF
 	fi
 
 	if test -n "$export_symbols" && test -n "$include_expsyms"; then
-	  tmp_export_symbols="$export_symbols"
-	  test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols"
+	  tmp_export_symbols=$export_symbols
+	  test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols
 	  $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"'
 	fi
 
-	if test "X$skipped_export" != "X:" && test -n "$orig_export_symbols"; then
+	if test : != "$skipped_export" && test -n "$orig_export_symbols"; then
 	  # The given exports_symbols file has to be filtered, so filter it.
-	  func_verbose "filter symbol list for \`$libname.la' to tag DATA exports"
+	  func_verbose "filter symbol list for '$libname.la' to tag DATA exports"
 	  # FIXME: $output_objdir/$libname.filter potentially contains lots of
-	  # 's' commands which not all seds can handle. GNU sed should be fine
+	  # 's' commands, which not all seds can handle. GNU sed should be fine
 	  # though. Also, the filter scales superlinearly with the number of
 	  # global variables. join(1) would be nice here, but unfortunately
 	  # isn't a blessed tool.
@@ -8246,11 +9738,11 @@ EOF
 	    ;;
 	  esac
 	done
-	deplibs="$tmp_deplibs"
+	deplibs=$tmp_deplibs
 
 	if test -n "$convenience"; then
 	  if test -n "$whole_archive_flag_spec" &&
-	    test "$compiler_needs_object" = yes &&
+	    test yes = "$compiler_needs_object" &&
 	    test -z "$libobjs"; then
 	    # extract the archives, so we have objects to list.
 	    # TODO: could optimize this to just extract one archive.
@@ -8261,7 +9753,7 @@ EOF
 	    eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
 	    test "X$libobjs" = "X " && libobjs=
 	  else
-	    gentop="$output_objdir/${outputname}x"
+	    gentop=$output_objdir/${outputname}x
 	    func_append generated " $gentop"
 
 	    func_extract_archives $gentop $convenience
@@ -8270,18 +9762,18 @@ EOF
 	  fi
 	fi
 
-	if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then
+	if test yes = "$thread_safe" && test -n "$thread_safe_flag_spec"; then
 	  eval flag=\"$thread_safe_flag_spec\"
 	  func_append linker_flags " $flag"
 	fi
 
 	# Make a backup of the uninstalled library when relinking
-	if test "$opt_mode" = relink; then
+	if test relink = "$opt_mode"; then
 	  $opt_dry_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 yes = "$module" && 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
@@ -8299,7 +9791,7 @@ EOF
 	  fi
 	fi
 
-	if test "X$skipped_export" != "X:" &&
+	if test : != "$skipped_export" &&
 	   func_len " $test_cmds" &&
 	   len=$func_len_result &&
 	   test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then
@@ -8332,8 +9824,8 @@ EOF
 	  last_robj=
 	  k=1
 
-	  if test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "$with_gnu_ld" = yes; then
-	    output=${output_objdir}/${output_la}.lnkscript
+	  if test -n "$save_libobjs" && test : != "$skipped_export" && test yes = "$with_gnu_ld"; then
+	    output=$output_objdir/$output_la.lnkscript
 	    func_verbose "creating GNU ld script: $output"
 	    echo 'INPUT (' > $output
 	    for obj in $save_libobjs
@@ -8345,14 +9837,14 @@ EOF
 	    func_append delfiles " $output"
 	    func_to_tool_file "$output"
 	    output=$func_to_tool_file_result
-	  elif test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "X$file_list_spec" != X; then
-	    output=${output_objdir}/${output_la}.lnk
+	  elif test -n "$save_libobjs" && test : != "$skipped_export" && test -n "$file_list_spec"; then
+	    output=$output_objdir/$output_la.lnk
 	    func_verbose "creating linker input file list: $output"
 	    : > $output
 	    set x $save_libobjs
 	    shift
 	    firstobj=
-	    if test "$compiler_needs_object" = yes; then
+	    if test yes = "$compiler_needs_object"; then
 	      firstobj="$1 "
 	      shift
 	    fi
@@ -8367,7 +9859,7 @@ EOF
 	  else
 	    if test -n "$save_libobjs"; then
 	      func_verbose "creating reloadable object files..."
-	      output=$output_objdir/$output_la-${k}.$objext
+	      output=$output_objdir/$output_la-$k.$objext
 	      eval test_cmds=\"$reload_cmds\"
 	      func_len " $test_cmds"
 	      len0=$func_len_result
@@ -8379,13 +9871,13 @@ EOF
 		func_len " $obj"
 		func_arith $len + $func_len_result
 		len=$func_arith_result
-		if test "X$objlist" = X ||
+		if test -z "$objlist" ||
 		   test "$len" -lt "$max_cmd_len"; then
 		  func_append objlist " $obj"
 		else
 		  # The command $test_cmds is almost too long, add a
 		  # command to the queue.
-		  if test "$k" -eq 1 ; then
+		  if test 1 -eq "$k"; then
 		    # The first file doesn't have a previous command to add.
 		    reload_objs=$objlist
 		    eval concat_cmds=\"$reload_cmds\"
@@ -8395,10 +9887,10 @@ EOF
 		    reload_objs="$objlist $last_robj"
 		    eval concat_cmds=\"\$concat_cmds~$reload_cmds~\$RM $last_robj\"
 		  fi
-		  last_robj=$output_objdir/$output_la-${k}.$objext
+		  last_robj=$output_objdir/$output_la-$k.$objext
 		  func_arith $k + 1
 		  k=$func_arith_result
-		  output=$output_objdir/$output_la-${k}.$objext
+		  output=$output_objdir/$output_la-$k.$objext
 		  objlist=" $obj"
 		  func_len " $last_robj"
 		  func_arith $len0 + $func_len_result
@@ -8410,9 +9902,9 @@ EOF
 	      # files will link in the last one created.
 	      test -z "$concat_cmds" || concat_cmds=$concat_cmds~
 	      reload_objs="$objlist $last_robj"
-	      eval concat_cmds=\"\${concat_cmds}$reload_cmds\"
+	      eval concat_cmds=\"\$concat_cmds$reload_cmds\"
 	      if test -n "$last_robj"; then
-	        eval concat_cmds=\"\${concat_cmds}~\$RM $last_robj\"
+	        eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\"
 	      fi
 	      func_append delfiles " $output"
 
@@ -8420,9 +9912,9 @@ EOF
 	      output=
 	    fi
 
-	    if ${skipped_export-false}; then
-	      func_verbose "generating symbol list for \`$libname.la'"
-	      export_symbols="$output_objdir/$libname.exp"
+	    ${skipped_export-false} && {
+	      func_verbose "generating symbol list for '$libname.la'"
+	      export_symbols=$output_objdir/$libname.exp
 	      $opt_dry_run || $RM $export_symbols
 	      libobjs=$output
 	      # Append the command to create the export file.
@@ -8431,16 +9923,16 @@ EOF
 	      if test -n "$last_robj"; then
 		eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\"
 	      fi
-	    fi
+	    }
 
 	    test -n "$save_libobjs" &&
 	      func_verbose "creating a temporary reloadable object file: $output"
 
 	    # Loop through the commands generated above and execute them.
-	    save_ifs="$IFS"; IFS='~'
+	    save_ifs=$IFS; IFS='~'
 	    for cmd in $concat_cmds; do
-	      IFS="$save_ifs"
-	      $opt_silent || {
+	      IFS=$save_ifs
+	      $opt_quiet || {
 		  func_quote_for_expand "$cmd"
 		  eval "func_echo $func_quote_for_expand_result"
 	      }
@@ -8448,7 +9940,7 @@ EOF
 		lt_exit=$?
 
 		# Restore the uninstalled library and exit
-		if test "$opt_mode" = relink; then
+		if test relink = "$opt_mode"; then
 		  ( cd "$output_objdir" && \
 		    $RM "${realname}T" && \
 		    $MV "${realname}U" "$realname" )
@@ -8457,7 +9949,7 @@ EOF
 		exit $lt_exit
 	      }
 	    done
-	    IFS="$save_ifs"
+	    IFS=$save_ifs
 
 	    if test -n "$export_symbols_regex" && ${skipped_export-false}; then
 	      func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
@@ -8465,18 +9957,18 @@ EOF
 	    fi
 	  fi
 
-          if ${skipped_export-false}; then
+          ${skipped_export-false} && {
 	    if test -n "$export_symbols" && test -n "$include_expsyms"; then
-	      tmp_export_symbols="$export_symbols"
-	      test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols"
+	      tmp_export_symbols=$export_symbols
+	      test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols
 	      $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"'
 	    fi
 
 	    if test -n "$orig_export_symbols"; then
 	      # The given exports_symbols file has to be filtered, so filter it.
-	      func_verbose "filter symbol list for \`$libname.la' to tag DATA exports"
+	      func_verbose "filter symbol list for '$libname.la' to tag DATA exports"
 	      # FIXME: $output_objdir/$libname.filter potentially contains lots of
-	      # 's' commands which not all seds can handle. GNU sed should be fine
+	      # 's' commands, which not all seds can handle. GNU sed should be fine
 	      # though. Also, the filter scales superlinearly with the number of
 	      # global variables. join(1) would be nice here, but unfortunately
 	      # isn't a blessed tool.
@@ -8485,7 +9977,7 @@ EOF
 	      export_symbols=$output_objdir/$libname.def
 	      $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols
 	    fi
-	  fi
+	  }
 
 	  libobjs=$output
 	  # Restore the value of output.
@@ -8499,7 +9991,7 @@ EOF
 	  # value of $libobjs for piecewise linking.
 
 	  # Do each of the archive commands.
-	  if test "$module" = yes && test -n "$module_cmds" ; then
+	  if test yes = "$module" && test -n "$module_cmds"; then
 	    if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
 	      cmds=$module_expsym_cmds
 	    else
@@ -8521,7 +10013,7 @@ EOF
 
 	# Add any objects from preloaded convenience libraries
 	if test -n "$dlprefiles"; then
-	  gentop="$output_objdir/${outputname}x"
+	  gentop=$output_objdir/${outputname}x
 	  func_append generated " $gentop"
 
 	  func_extract_archives $gentop $dlprefiles
@@ -8529,11 +10021,12 @@ EOF
 	  test "X$libobjs" = "X " && libobjs=
 	fi
 
-	save_ifs="$IFS"; IFS='~'
+	save_ifs=$IFS; IFS='~'
 	for cmd in $cmds; do
-	  IFS="$save_ifs"
+	  IFS=$sp$nl
 	  eval cmd=\"$cmd\"
-	  $opt_silent || {
+	  IFS=$save_ifs
+	  $opt_quiet || {
 	    func_quote_for_expand "$cmd"
 	    eval "func_echo $func_quote_for_expand_result"
 	  }
@@ -8541,7 +10034,7 @@ EOF
 	    lt_exit=$?
 
 	    # Restore the uninstalled library and exit
-	    if test "$opt_mode" = relink; then
+	    if test relink = "$opt_mode"; then
 	      ( cd "$output_objdir" && \
 	        $RM "${realname}T" && \
 		$MV "${realname}U" "$realname" )
@@ -8550,10 +10043,10 @@ EOF
 	    exit $lt_exit
 	  }
 	done
-	IFS="$save_ifs"
+	IFS=$save_ifs
 
 	# Restore the uninstalled library and exit
-	if test "$opt_mode" = relink; then
+	if test relink = "$opt_mode"; then
 	  $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $?
 
 	  if test -n "$convenience"; then
@@ -8573,39 +10066,39 @@ EOF
 	done
 
 	# If -module or -export-dynamic was specified, set the dlname.
-	if test "$module" = yes || test "$export_dynamic" = yes; then
+	if test yes = "$module" || test yes = "$export_dynamic"; then
 	  # On all known operating systems, these are identical.
-	  dlname="$soname"
+	  dlname=$soname
 	fi
       fi
       ;;
 
     obj)
-      if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
-	func_warning "\`-dlopen' is ignored for objects"
+      if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then
+	func_warning "'-dlopen' is ignored for objects"
       fi
 
       case " $deplibs" in
       *\ -l* | *\ -L*)
-	func_warning "\`-l' and \`-L' are ignored for objects" ;;
+	func_warning "'-l' and '-L' are ignored for objects" ;;
       esac
 
       test -n "$rpath" && \
-	func_warning "\`-rpath' is ignored for objects"
+	func_warning "'-rpath' is ignored for objects"
 
       test -n "$xrpath" && \
-	func_warning "\`-R' is ignored for objects"
+	func_warning "'-R' is ignored for objects"
 
       test -n "$vinfo" && \
-	func_warning "\`-version-info' is ignored for objects"
+	func_warning "'-version-info' is ignored for objects"
 
       test -n "$release" && \
-	func_warning "\`-release' is ignored for objects"
+	func_warning "'-release' is ignored for objects"
 
       case $output in
       *.lo)
 	test -n "$objs$old_deplibs" && \
-	  func_fatal_error "cannot build library object \`$output' from non-libtool objects"
+	  func_fatal_error "cannot build library object '$output' from non-libtool objects"
 
 	libobj=$output
 	func_lo2o "$libobj"
@@ -8613,7 +10106,7 @@ EOF
 	;;
       *)
 	libobj=
-	obj="$output"
+	obj=$output
 	;;
       esac
 
@@ -8626,17 +10119,19 @@ EOF
       # the extraction.
       reload_conv_objs=
       gentop=
-      # reload_cmds runs $LD directly, so let us get rid of
-      # -Wl from whole_archive_flag_spec and hope we can get by with
-      # turning comma into space..
-      wl=
-
+      # if reload_cmds runs $LD directly, get rid of -Wl from
+      # whole_archive_flag_spec and hope we can get by with turning comma
+      # into space.
+      case $reload_cmds in
+        *\$LD[\ \$]*) wl= ;;
+      esac
       if test -n "$convenience"; then
 	if test -n "$whole_archive_flag_spec"; then
 	  eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\"
-	  reload_conv_objs=$reload_objs\ `$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'`
+	  test -n "$wl" || tmp_whole_archive_flags=`$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'`
+	  reload_conv_objs=$reload_objs\ $tmp_whole_archive_flags
 	else
-	  gentop="$output_objdir/${obj}x"
+	  gentop=$output_objdir/${obj}x
 	  func_append generated " $gentop"
 
 	  func_extract_archives $gentop $convenience
@@ -8645,12 +10140,12 @@ EOF
       fi
 
       # If we're not building shared, we need to use non_pic_objs
-      test "$build_libtool_libs" != yes && libobjs="$non_pic_objects"
+      test yes = "$build_libtool_libs" || libobjs=$non_pic_objects
 
       # Create the old-style object.
-      reload_objs="$objs$old_deplibs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.${libext}$/d; /\.lib$/d; $lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test
+      reload_objs=$objs$old_deplibs' '`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; /\.lib$/d; $lo2o" | $NL2SP`' '$reload_conv_objs
 
-      output="$obj"
+      output=$obj
       func_execute_cmds "$reload_cmds" 'exit $?'
 
       # Exit if we aren't doing a library object file.
@@ -8662,7 +10157,7 @@ EOF
 	exit $EXIT_SUCCESS
       fi
 
-      if test "$build_libtool_libs" != yes; then
+      test yes = "$build_libtool_libs" || {
 	if test -n "$gentop"; then
 	  func_show_eval '${RM}r "$gentop"'
 	fi
@@ -8672,12 +10167,12 @@ EOF
 	# $show "echo timestamp > $libobj"
 	# $opt_dry_run || eval "echo timestamp > $libobj" || exit $?
 	exit $EXIT_SUCCESS
-      fi
+      }
 
-      if test -n "$pic_flag" || test "$pic_mode" != default; then
+      if test -n "$pic_flag" || test default != "$pic_mode"; then
 	# Only do commands if we really have different PIC objects.
 	reload_objs="$libobjs $reload_conv_objs"
-	output="$libobj"
+	output=$libobj
 	func_execute_cmds "$reload_cmds" 'exit $?'
       fi
 
@@ -8694,16 +10189,14 @@ EOF
 	          output=$func_stripname_result.exe;;
       esac
       test -n "$vinfo" && \
-	func_warning "\`-version-info' is ignored for programs"
+	func_warning "'-version-info' is ignored for programs"
 
       test -n "$release" && \
-	func_warning "\`-release' is ignored for programs"
+	func_warning "'-release' is ignored for programs"
 
-      test "$preload" = yes \
-        && test "$dlopen_support" = unknown \
-	&& test "$dlopen_self" = unknown \
-	&& test "$dlopen_self_static" = unknown && \
-	  func_warning "\`LT_INIT([dlopen])' not used. Assuming no dlopen support."
+      $preload \
+	&& test unknown,unknown,unknown = "$dlopen_support,$dlopen_self,$dlopen_self_static" \
+	&& func_warning "'LT_INIT([dlopen])' not used. Assuming no dlopen support."
 
       case $host in
       *-*-rhapsody* | *-*-darwin1.[012])
@@ -8717,11 +10210,11 @@ EOF
       *-*-darwin*)
 	# Don't allow lazy linking, it breaks C++ global constructors
 	# But is supposedly fixed on 10.4 or later (yay!).
-	if test "$tagname" = CXX ; then
+	if test CXX = "$tagname"; then
 	  case ${MACOSX_DEPLOYMENT_TARGET-10.0} in
 	    10.[0123])
-	      func_append compile_command " ${wl}-bind_at_load"
-	      func_append finalize_command " ${wl}-bind_at_load"
+	      func_append compile_command " $wl-bind_at_load"
+	      func_append finalize_command " $wl-bind_at_load"
 	    ;;
 	  esac
 	fi
@@ -8757,7 +10250,7 @@ EOF
 	*) func_append new_libs " $deplib" ;;
 	esac
       done
-      compile_deplibs="$new_libs"
+      compile_deplibs=$new_libs
 
 
       func_append compile_command " $compile_deplibs"
@@ -8781,7 +10274,7 @@ EOF
 	if test -n "$hardcode_libdir_flag_spec"; then
 	  if test -n "$hardcode_libdir_separator"; then
 	    if test -z "$hardcode_libdirs"; then
-	      hardcode_libdirs="$libdir"
+	      hardcode_libdirs=$libdir
 	    else
 	      # Just accumulate the unique libdirs.
 	      case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
@@ -8804,7 +10297,7 @@ EOF
 	fi
 	case $host in
 	*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
-	  testbindir=`${ECHO} "$libdir" | ${SED} -e 's*/lib$*/bin*'`
+	  testbindir=`$ECHO "$libdir" | $SED -e 's*/lib$*/bin*'`
 	  case :$dllsearchpath: in
 	  *":$libdir:"*) ;;
 	  ::) dllsearchpath=$libdir;;
@@ -8821,10 +10314,10 @@ EOF
       # Substitute the hardcoded libdirs into the rpath.
       if test -n "$hardcode_libdir_separator" &&
 	 test -n "$hardcode_libdirs"; then
-	libdir="$hardcode_libdirs"
+	libdir=$hardcode_libdirs
 	eval rpath=\" $hardcode_libdir_flag_spec\"
       fi
-      compile_rpath="$rpath"
+      compile_rpath=$rpath
 
       rpath=
       hardcode_libdirs=
@@ -8832,7 +10325,7 @@ EOF
 	if test -n "$hardcode_libdir_flag_spec"; then
 	  if test -n "$hardcode_libdir_separator"; then
 	    if test -z "$hardcode_libdirs"; then
-	      hardcode_libdirs="$libdir"
+	      hardcode_libdirs=$libdir
 	    else
 	      # Just accumulate the unique libdirs.
 	      case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
@@ -8857,45 +10350,43 @@ EOF
       # Substitute the hardcoded libdirs into the rpath.
       if test -n "$hardcode_libdir_separator" &&
 	 test -n "$hardcode_libdirs"; then
-	libdir="$hardcode_libdirs"
+	libdir=$hardcode_libdirs
 	eval rpath=\" $hardcode_libdir_flag_spec\"
       fi
-      finalize_rpath="$rpath"
+      finalize_rpath=$rpath
 
-      if test -n "$libobjs" && test "$build_old_libs" = yes; then
+      if test -n "$libobjs" && test yes = "$build_old_libs"; then
 	# Transform all the library objects into standard objects.
 	compile_command=`$ECHO "$compile_command" | $SP2NL | $SED "$lo2o" | $NL2SP`
 	finalize_command=`$ECHO "$finalize_command" | $SP2NL | $SED "$lo2o" | $NL2SP`
       fi
 
-      func_generate_dlsyms "$outputname" "@PROGRAM@" "no"
+      func_generate_dlsyms "$outputname" "@PROGRAM@" false
 
       # template prelinking step
       if test -n "$prelink_cmds"; then
 	func_execute_cmds "$prelink_cmds" 'exit $?'
       fi
 
-      wrappers_required=yes
+      wrappers_required=:
       case $host in
       *cegcc* | *mingw32ce*)
         # Disable wrappers for cegcc and mingw32ce hosts, we are cross compiling anyway.
-        wrappers_required=no
+        wrappers_required=false
         ;;
       *cygwin* | *mingw* )
-        if test "$build_libtool_libs" != yes; then
-          wrappers_required=no
-        fi
+        test yes = "$build_libtool_libs" || wrappers_required=false
         ;;
       *)
-        if test "$need_relink" = no || test "$build_libtool_libs" != yes; then
-          wrappers_required=no
+        if test no = "$need_relink" || test yes != "$build_libtool_libs"; then
+          wrappers_required=false
         fi
         ;;
       esac
-      if test "$wrappers_required" = no; then
+      $wrappers_required || {
 	# Replace the output file specification.
 	compile_command=`$ECHO "$compile_command" | $SED 's%@OUTPUT@%'"$output"'%g'`
-	link_command="$compile_command$compile_rpath"
+	link_command=$compile_command$compile_rpath
 
 	# We have no uninstalled library dependencies, so finalize right now.
 	exit_status=0
@@ -8908,12 +10399,12 @@ EOF
 	fi
 
 	# Delete the generated files.
-	if test -f "$output_objdir/${outputname}S.${objext}"; then
-	  func_show_eval '$RM "$output_objdir/${outputname}S.${objext}"'
+	if test -f "$output_objdir/${outputname}S.$objext"; then
+	  func_show_eval '$RM "$output_objdir/${outputname}S.$objext"'
 	fi
 
 	exit $exit_status
-      fi
+      }
 
       if test -n "$compile_shlibpath$finalize_shlibpath"; then
 	compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command"
@@ -8943,9 +10434,9 @@ EOF
 	fi
       fi
 
-      if test "$no_install" = yes; then
+      if test yes = "$no_install"; then
 	# We don't need to create a wrapper script.
-	link_command="$compile_var$compile_command$compile_rpath"
+	link_command=$compile_var$compile_command$compile_rpath
 	# Replace the output file specification.
 	link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output"'%g'`
 	# Delete the old output file.
@@ -8962,27 +10453,28 @@ EOF
 	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"
+      case $hardcode_action,$fast_install in
+        relink,*)
+	  # Fast installation is not supported
+	  link_command=$compile_var$compile_command$compile_rpath
+	  relink_command=$finalize_var$finalize_command$finalize_rpath
 
-	func_warning "this platform does not like uninstalled shared libraries"
-	func_warning "\`$output' will be relinked during installation"
-      else
-	if test "$fast_install" != no; then
-	  link_command="$finalize_var$compile_command$finalize_rpath"
-	  if test "$fast_install" = yes; then
-	    relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED '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
+	  func_warning "this platform does not like uninstalled shared libraries"
+	  func_warning "'$output' will be relinked during installation"
+	  ;;
+        *,yes)
+	  link_command=$finalize_var$compile_command$finalize_rpath
+	  relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED 's%@OUTPUT@%\$progdir/\$file%g'`
+          ;;
+	*,no)
+	  link_command=$compile_var$compile_command$compile_rpath
+	  relink_command=$finalize_var$finalize_command$finalize_rpath
+          ;;
+	*,needless)
+	  link_command=$finalize_var$compile_command$finalize_rpath
+	  relink_command=
+          ;;
+      esac
 
       # Replace the output file specification.
       link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'`
@@ -9039,8 +10531,8 @@ EOF
 	    func_dirname_and_basename "$output" "" "."
 	    output_name=$func_basename_result
 	    output_path=$func_dirname_result
-	    cwrappersource="$output_path/$objdir/lt-$output_name.c"
-	    cwrapper="$output_path/$output_name.exe"
+	    cwrappersource=$output_path/$objdir/lt-$output_name.c
+	    cwrapper=$output_path/$output_name.exe
 	    $RM $cwrappersource $cwrapper
 	    trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15
 
@@ -9061,7 +10553,7 @@ EOF
 	    trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15
 	    $opt_dry_run || {
 	      # note: this script will not be executed, so do not chmod.
-	      if test "x$build" = "x$host" ; then
+	      if test "x$build" = "x$host"; then
 		$cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result
 	      else
 		func_emit_wrapper no > $func_ltwrapper_scriptname_result
@@ -9084,25 +10576,27 @@ EOF
     # 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 $symfileobj"
-	addlibs="$convenience"
-	build_libtool_libs=no
-      else
-	if test "$build_libtool_libs" = module; then
-	  oldobjs="$libobjs_save"
+      case $build_libtool_libs in
+        convenience)
+	  oldobjs="$libobjs_save $symfileobj"
+	  addlibs=$convenience
 	  build_libtool_libs=no
-	else
+	  ;;
+	module)
+	  oldobjs=$libobjs_save
+	  addlibs=$old_convenience
+	  build_libtool_libs=no
+          ;;
+	*)
 	  oldobjs="$old_deplibs $non_pic_objects"
-	  if test "$preload" = yes && test -f "$symfileobj"; then
-	    func_append oldobjs " $symfileobj"
-	  fi
-	fi
-	addlibs="$old_convenience"
-      fi
+	  $preload && test -f "$symfileobj" \
+	    && func_append oldobjs " $symfileobj"
+	  addlibs=$old_convenience
+	  ;;
+      esac
 
       if test -n "$addlibs"; then
-	gentop="$output_objdir/${outputname}x"
+	gentop=$output_objdir/${outputname}x
 	func_append generated " $gentop"
 
 	func_extract_archives $gentop $addlibs
@@ -9110,13 +10604,13 @@ EOF
       fi
 
       # Do each command in the archive commands.
-      if test -n "$old_archive_from_new_cmds" && test "$build_libtool_libs" = yes; then
+      if test -n "$old_archive_from_new_cmds" && test yes = "$build_libtool_libs"; then
 	cmds=$old_archive_from_new_cmds
       else
 
 	# Add any objects from preloaded convenience libraries
 	if test -n "$dlprefiles"; then
-	  gentop="$output_objdir/${outputname}x"
+	  gentop=$output_objdir/${outputname}x
 	  func_append generated " $gentop"
 
 	  func_extract_archives $gentop $dlprefiles
@@ -9137,7 +10631,7 @@ EOF
 	  :
 	else
 	  echo "copying selected object files to avoid basename conflicts..."
-	  gentop="$output_objdir/${outputname}x"
+	  gentop=$output_objdir/${outputname}x
 	  func_append generated " $gentop"
 	  func_mkdir_p "$gentop"
 	  save_oldobjs=$oldobjs
@@ -9146,7 +10640,7 @@ EOF
 	  for obj in $save_oldobjs
 	  do
 	    func_basename "$obj"
-	    objbase="$func_basename_result"
+	    objbase=$func_basename_result
 	    case " $oldobjs " in
 	    " ") oldobjs=$obj ;;
 	    *[\ /]"$objbase "*)
@@ -9215,18 +10709,18 @@ EOF
 	    else
 	      # the above command should be used before it gets too long
 	      oldobjs=$objlist
-	      if test "$obj" = "$last_oldobj" ; then
+	      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\"
+	      eval concat_cmds=\"\$concat_cmds$old_archive_cmds\"
 	      objlist=
 	      len=$len0
 	    fi
 	  done
 	  RANLIB=$save_RANLIB
 	  oldobjs=$objlist
-	  if test "X$oldobjs" = "X" ; then
+	  if test -z "$oldobjs"; then
 	    eval cmds=\"\$concat_cmds\"
 	  else
 	    eval cmds=\"\$concat_cmds~\$old_archive_cmds\"
@@ -9243,7 +10737,7 @@ EOF
     case $output in
     *.la)
       old_library=
-      test "$build_old_libs" = yes && old_library="$libname.$libext"
+      test yes = "$build_old_libs" && old_library=$libname.$libext
       func_verbose "creating $output"
 
       # Preserve any variables that may affect compiler behavior
@@ -9258,31 +10752,31 @@ EOF
 	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="(cd `pwd`; $SHELL \"$progpath\" $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)"
       relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"`
-      if test "$hardcode_automatic" = yes ; then
+      if test yes = "$hardcode_automatic"; then
 	relink_command=
       fi
 
       # Only create the output if not a dry run.
       $opt_dry_run || {
 	for installed in no yes; do
-	  if test "$installed" = yes; then
+	  if test yes = "$installed"; then
 	    if test -z "$install_libdir"; then
 	      break
 	    fi
-	    output="$output_objdir/$outputname"i
+	    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)
 		func_basename "$deplib"
-		name="$func_basename_result"
+		name=$func_basename_result
 		func_resolve_sysroot "$deplib"
-		eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result`
+		eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result`
 		test -z "$libdir" && \
-		  func_fatal_error "\`$deplib' is not a valid libtool archive"
+		  func_fatal_error "'$deplib' is not a valid libtool archive"
 		func_append newdependency_libs " ${lt_sysroot:+=}$libdir/$name"
 		;;
 	      -L*)
@@ -9298,23 +10792,23 @@ EOF
 	      *) func_append newdependency_libs " $deplib" ;;
 	      esac
 	    done
-	    dependency_libs="$newdependency_libs"
+	    dependency_libs=$newdependency_libs
 	    newdlfiles=
 
 	    for lib in $dlfiles; do
 	      case $lib in
 	      *.la)
 	        func_basename "$lib"
-		name="$func_basename_result"
-		eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
+		name=$func_basename_result
+		eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
 		test -z "$libdir" && \
-		  func_fatal_error "\`$lib' is not a valid libtool archive"
+		  func_fatal_error "'$lib' is not a valid libtool archive"
 		func_append newdlfiles " ${lt_sysroot:+=}$libdir/$name"
 		;;
 	      *) func_append newdlfiles " $lib" ;;
 	      esac
 	    done
-	    dlfiles="$newdlfiles"
+	    dlfiles=$newdlfiles
 	    newdlprefiles=
 	    for lib in $dlprefiles; do
 	      case $lib in
@@ -9324,34 +10818,34 @@ EOF
 		# didn't already link the preopened objects directly into
 		# the library:
 		func_basename "$lib"
-		name="$func_basename_result"
-		eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
+		name=$func_basename_result
+		eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
 		test -z "$libdir" && \
-		  func_fatal_error "\`$lib' is not a valid libtool archive"
+		  func_fatal_error "'$lib' is not a valid libtool archive"
 		func_append newdlprefiles " ${lt_sysroot:+=}$libdir/$name"
 		;;
 	      esac
 	    done
-	    dlprefiles="$newdlprefiles"
+	    dlprefiles=$newdlprefiles
 	  else
 	    newdlfiles=
 	    for lib in $dlfiles; do
 	      case $lib in
-		[\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
+		[\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;;
 		*) abs=`pwd`"/$lib" ;;
 	      esac
 	      func_append newdlfiles " $abs"
 	    done
-	    dlfiles="$newdlfiles"
+	    dlfiles=$newdlfiles
 	    newdlprefiles=
 	    for lib in $dlprefiles; do
 	      case $lib in
-		[\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
+		[\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;;
 		*) abs=`pwd`"/$lib" ;;
 	      esac
 	      func_append newdlprefiles " $abs"
 	    done
-	    dlprefiles="$newdlprefiles"
+	    dlprefiles=$newdlprefiles
 	  fi
 	  $RM $output
 	  # place dlname in correct position for cygwin
@@ -9367,10 +10861,9 @@ EOF
 	  case $host,$output,$installed,$module,$dlname in
 	    *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll)
 	      # If a -bindir argument was supplied, place the dll there.
-	      if test "x$bindir" != x ;
-	      then
+	      if test -n "$bindir"; then
 		func_relative_path "$install_libdir" "$bindir"
-		tdlname=$func_relative_path_result$dlname
+		tdlname=$func_relative_path_result/$dlname
 	      else
 		# Otherwise fall back on heuristic.
 		tdlname=../bin/$dlname
@@ -9379,7 +10872,7 @@ EOF
 	  esac
 	  $ECHO > $output "\
 # $outputname - a libtool library file
-# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+# Generated by $PROGRAM (GNU $PACKAGE) $VERSION
 #
 # Please DO NOT delete this file!
 # It is necessary for linking the library.
@@ -9393,7 +10886,7 @@ library_names='$library_names'
 # The name of the static archive.
 old_library='$old_library'
 
-# Linker flags that can not go in dependency_libs.
+# Linker flags that cannot go in dependency_libs.
 inherited_linker_flags='$new_inherited_linker_flags'
 
 # Libraries that this one depends upon.
@@ -9419,7 +10912,7 @@ dlpreopen='$dlprefiles'
 
 # Directory that this library needs to be installed in:
 libdir='$install_libdir'"
-	  if test "$installed" = no && test "$need_relink" = yes; then
+	  if test no,yes = "$installed,$need_relink"; then
 	    $ECHO >> $output "\
 relink_command=\"$relink_command\""
 	  fi
@@ -9434,27 +10927,29 @@ relink_command=\"$relink_command\""
     exit $EXIT_SUCCESS
 }
 
-{ test "$opt_mode" = link || test "$opt_mode" = relink; } &&
-    func_mode_link ${1+"$@"}
+if test link = "$opt_mode" || test relink = "$opt_mode"; then
+  func_mode_link ${1+"$@"}
+fi
 
 
 # func_mode_uninstall arg...
 func_mode_uninstall ()
 {
-    $opt_debug
-    RM="$nonopt"
+    $debug_cmd
+
+    RM=$nonopt
     files=
-    rmforce=
+    rmforce=false
     exit_status=0
 
     # This variable tells wrapper scripts just to set variables rather
     # than running their programs.
-    libtool_install_magic="$magic"
+    libtool_install_magic=$magic
 
     for arg
     do
       case $arg in
-      -f) func_append RM " $arg"; rmforce=yes ;;
+      -f) func_append RM " $arg"; rmforce=: ;;
       -*) func_append RM " $arg" ;;
       *) func_append files " $arg" ;;
       esac
@@ -9467,18 +10962,18 @@ func_mode_uninstall ()
 
     for file in $files; do
       func_dirname "$file" "" "."
-      dir="$func_dirname_result"
-      if test "X$dir" = X.; then
-	odir="$objdir"
+      dir=$func_dirname_result
+      if test . = "$dir"; then
+	odir=$objdir
       else
-	odir="$dir/$objdir"
+	odir=$dir/$objdir
       fi
       func_basename "$file"
-      name="$func_basename_result"
-      test "$opt_mode" = uninstall && odir="$dir"
+      name=$func_basename_result
+      test uninstall = "$opt_mode" && odir=$dir
 
       # Remember odir for removal later, being careful to avoid duplicates
-      if test "$opt_mode" = clean; then
+      if test clean = "$opt_mode"; then
 	case " $rmdirs " in
 	  *" $odir "*) ;;
 	  *) func_append rmdirs " $odir" ;;
@@ -9493,11 +10988,11 @@ func_mode_uninstall ()
       elif test -d "$file"; then
 	exit_status=1
 	continue
-      elif test "$rmforce" = yes; then
+      elif $rmforce; then
 	continue
       fi
 
-      rmfiles="$file"
+      rmfiles=$file
 
       case $name in
       *.la)
@@ -9511,7 +11006,7 @@ func_mode_uninstall ()
 	  done
 	  test -n "$old_library" && func_append rmfiles " $odir/$old_library"
 
-	  case "$opt_mode" in
+	  case $opt_mode in
 	  clean)
 	    case " $library_names " in
 	    *" $dlname "*) ;;
@@ -9522,12 +11017,12 @@ func_mode_uninstall ()
 	  uninstall)
 	    if test -n "$library_names"; then
 	      # Do each command in the postuninstall commands.
-	      func_execute_cmds "$postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1'
+	      func_execute_cmds "$postuninstall_cmds" '$rmforce || exit_status=1'
 	    fi
 
 	    if test -n "$old_library"; then
 	      # Do each command in the old_postuninstall commands.
-	      func_execute_cmds "$old_postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1'
+	      func_execute_cmds "$old_postuninstall_cmds" '$rmforce || exit_status=1'
 	    fi
 	    # FIXME: should reinstall the best remaining shared library.
 	    ;;
@@ -9543,21 +11038,19 @@ func_mode_uninstall ()
 	  func_source $dir/$name
 
 	  # Add PIC object to the list of files to remove.
-	  if test -n "$pic_object" &&
-	     test "$pic_object" != none; then
+	  if test -n "$pic_object" && test none != "$pic_object"; then
 	    func_append 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
+	  if test -n "$non_pic_object" && test none != "$non_pic_object"; then
 	    func_append rmfiles " $dir/$non_pic_object"
 	  fi
 	fi
 	;;
 
       *)
-	if test "$opt_mode" = clean ; then
+	if test clean = "$opt_mode"; then
 	  noexename=$name
 	  case $file in
 	  *.exe)
@@ -9584,12 +11077,12 @@ func_mode_uninstall ()
 
 	    # note $name still contains .exe if it was in $file originally
 	    # as does the version of $file that was added into $rmfiles
-	    func_append rmfiles " $odir/$name $odir/${name}S.${objext}"
-	    if test "$fast_install" = yes && test -n "$relink_command"; then
+	    func_append rmfiles " $odir/$name $odir/${name}S.$objext"
+	    if test yes = "$fast_install" && test -n "$relink_command"; then
 	      func_append rmfiles " $odir/lt-$name"
 	    fi
-	    if test "X$noexename" != "X$name" ; then
-	      func_append rmfiles " $odir/lt-${noexename}.c"
+	    if test "X$noexename" != "X$name"; then
+	      func_append rmfiles " $odir/lt-$noexename.c"
 	    fi
 	  fi
 	fi
@@ -9598,7 +11091,7 @@ func_mode_uninstall ()
       func_show_eval "$RM $rmfiles" 'exit_status=1'
     done
 
-    # Try to remove the ${objdir}s in the directories where we deleted files
+    # Try to remove the $objdir's in the directories where we deleted files
     for dir in $rmdirs; do
       if test -d "$dir"; then
 	func_show_eval "rmdir $dir >/dev/null 2>&1"
@@ -9608,16 +11101,17 @@ func_mode_uninstall ()
     exit $exit_status
 }
 
-{ test "$opt_mode" = uninstall || test "$opt_mode" = clean; } &&
-    func_mode_uninstall ${1+"$@"}
+if test uninstall = "$opt_mode" || test clean = "$opt_mode"; then
+  func_mode_uninstall ${1+"$@"}
+fi
 
 test -z "$opt_mode" && {
-  help="$generic_help"
+  help=$generic_help
   func_fatal_help "you must specify a MODE"
 }
 
 test -z "$exec_cmd" && \
-  func_fatal_help "invalid operation mode \`$opt_mode'"
+  func_fatal_help "invalid operation mode '$opt_mode'"
 
 if test -n "$exec_cmd"; then
   eval exec "$exec_cmd"
@@ -9628,7 +11122,7 @@ exit $exit_status
 
 
 # The TAGs below are defined such that we never get into a situation
-# in which we disable both kinds of libraries.  Given conflicting
+# where 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
@@ -9651,5 +11145,3 @@ build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac`
 # mode:shell-script
 # sh-indentation:2
 # End:
-# vi:sw=2
-
diff --git a/m4/libtool.m4 b/m4/libtool.m4
index bc28ccc..da4a4f6 100644
--- a/m4/libtool.m4
+++ b/m4/libtool.m4
@@ -1,8 +1,6 @@
 # libtool.m4 - Configure libtool for the host system. -*-Autoconf-*-
 #
-#   Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,
-#                 2006, 2007, 2008, 2009, 2010, 2011 Free Software
-#                 Foundation, Inc.
+#   Copyright (C) 1996-2001, 2003-2015 Free Software Foundation, Inc.
 #   Written by Gordon Matzigkeit, 1996
 #
 # This file is free software; the Free Software Foundation gives
@@ -10,36 +8,30 @@
 # modifications, as long as this notice is preserved.
 
 m4_define([_LT_COPYING], [dnl
-#   Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,
-#                 2006, 2007, 2008, 2009, 2010, 2011 Free Software
-#                 Foundation, Inc.
-#   Written by Gordon Matzigkeit, 1996
-#
-#   This file is part of GNU Libtool.
-#
-# GNU Libtool 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.
+# Copyright (C) 2014 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.
+
+# GNU Libtool 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 of the License, or
+# (at your option) any later version.
 #
-# As a special exception to the GNU General Public License,
-# if you distribute this file as part of a program or library that
-# is built using GNU Libtool, you may include this file under the
-# same distribution terms that you use for the rest of that program.
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program or library that is built
+# using GNU Libtool, you may include this file under the  same
+# distribution terms that you use for the rest of that program.
 #
-# GNU Libtool is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# GNU Libtool 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 GNU Libtool; see the file COPYING.  If not, a copy
-# can be downloaded from http://www.gnu.org/licenses/gpl.html, or
-# obtained by writing to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
 ])
 
-# serial 57 LT_INIT
+# serial 58 LT_INIT
 
 
 # LT_PREREQ(VERSION)
@@ -67,7 +59,7 @@ esac
 # LT_INIT([OPTIONS])
 # ------------------
 AC_DEFUN([LT_INIT],
-[AC_PREREQ([2.58])dnl We use AC_INCLUDES_DEFAULT
+[AC_PREREQ([2.62])dnl We use AC_PATH_PROGS_FEATURE_CHECK
 AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl
 AC_BEFORE([$0], [LT_LANG])dnl
 AC_BEFORE([$0], [LT_OUTPUT])dnl
@@ -91,7 +83,7 @@ dnl Parse OPTIONS
 _LT_SET_OPTIONS([$0], [$1])
 
 # This can be used to rebuild libtool when needed
-LIBTOOL_DEPS="$ltmain"
+LIBTOOL_DEPS=$ltmain
 
 # Always use our own libtool.
 LIBTOOL='$(SHELL) $(top_builddir)/libtool'
@@ -111,26 +103,43 @@ dnl AC_DEFUN([AC_PROG_LIBTOOL], [])
 dnl AC_DEFUN([AM_PROG_LIBTOOL], [])
 
 
+# _LT_PREPARE_CC_BASENAME
+# -----------------------
+m4_defun([_LT_PREPARE_CC_BASENAME], [
+# Calculate cc_basename.  Skip known compiler wrappers and cross-prefix.
+func_cc_basename ()
+{
+    for cc_temp in @S|@*""; do
+      case $cc_temp in
+        compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;;
+        distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;;
+        \-*) ;;
+        *) break;;
+      esac
+    done
+    func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"`
+}
+])# _LT_PREPARE_CC_BASENAME
+
+
 # _LT_CC_BASENAME(CC)
 # -------------------
-# Calculate cc_basename.  Skip known compiler wrappers and cross-prefix.
+# It would be clearer to call AC_REQUIREs from _LT_PREPARE_CC_BASENAME,
+# but that macro is also expanded into generated libtool script, which
+# arranges for $SED and $ECHO to be set by different means.
 m4_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 "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"`
+[m4_require([_LT_PREPARE_CC_BASENAME])dnl
+AC_REQUIRE([_LT_DECL_SED])dnl
+AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl
+func_cc_basename $1
+cc_basename=$func_cc_basename_result
 ])
 
 
 # _LT_FILEUTILS_DEFAULTS
 # ----------------------
 # It is okay to use these file commands and assume they have been set
-# sensibly after `m4_require([_LT_FILEUTILS_DEFAULTS])'.
+# sensibly after 'm4_require([_LT_FILEUTILS_DEFAULTS])'.
 m4_defun([_LT_FILEUTILS_DEFAULTS],
 [: ${CP="cp -f"}
 : ${MV="mv -f"}
@@ -177,15 +186,16 @@ m4_require([_LT_CHECK_SHAREDLIB_FROM_LINKLIB])dnl
 m4_require([_LT_CMD_OLD_ARCHIVE])dnl
 m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl
 m4_require([_LT_WITH_SYSROOT])dnl
+m4_require([_LT_CMD_TRUNCATE])dnl
 
 _LT_CONFIG_LIBTOOL_INIT([
-# See if we are running on zsh, and set the options which allow our
+# See if we are running on zsh, and set the options that allow our
 # commands through without removal of \ escapes INIT.
-if test -n "\${ZSH_VERSION+set}" ; then
+if test -n "\${ZSH_VERSION+set}"; then
    setopt NO_GLOB_SUBST
 fi
 ])
-if test -n "${ZSH_VERSION+set}" ; then
+if test -n "${ZSH_VERSION+set}"; then
    setopt NO_GLOB_SUBST
 fi
 
@@ -198,7 +208,7 @@ 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
+  if test set != "${COLLECT_NAMES+set}"; then
     COLLECT_NAMES=
     export COLLECT_NAMES
   fi
@@ -209,14 +219,14 @@ esac
 ofile=libtool
 can_build_shared=yes
 
-# All known linkers require a `.a' archive for static linking (except MSVC,
+# All known linkers require a '.a' archive for static linking (except MSVC,
 # which needs '.lib').
 libext=a
 
-with_gnu_ld="$lt_cv_prog_gnu_ld"
+with_gnu_ld=$lt_cv_prog_gnu_ld
 
-old_CC="$CC"
-old_CFLAGS="$CFLAGS"
+old_CC=$CC
+old_CFLAGS=$CFLAGS
 
 # Set sane defaults for various variables
 test -z "$CC" && CC=cc
@@ -269,14 +279,14 @@ no_glob_subst='s/\*/\\\*/g'
 
 # _LT_PROG_LTMAIN
 # ---------------
-# Note that this code is called both from `configure', and `config.status'
+# Note that this code is called both from 'configure', and 'config.status'
 # now that we use AC_CONFIG_COMMANDS to generate libtool.  Notably,
-# `config.status' has no value for ac_aux_dir unless we are using Automake,
+# 'config.status' has no value for ac_aux_dir unless we are using Automake,
 # so we pass a copy along to make sure it has a sensible value anyway.
 m4_defun([_LT_PROG_LTMAIN],
 [m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([ltmain.sh])])dnl
 _LT_CONFIG_LIBTOOL_INIT([ac_aux_dir='$ac_aux_dir'])
-ltmain="$ac_aux_dir/ltmain.sh"
+ltmain=$ac_aux_dir/ltmain.sh
 ])# _LT_PROG_LTMAIN
 
 
@@ -286,7 +296,7 @@ ltmain="$ac_aux_dir/ltmain.sh"
 
 # So that we can recreate a full libtool script including additional
 # tags, we accumulate the chunks of code to send to AC_CONFIG_COMMANDS
-# in macros and then make a single call at the end using the `libtool'
+# in macros and then make a single call at the end using the 'libtool'
 # label.
 
 
@@ -421,8 +431,8 @@ m4_define([_lt_decl_all_varnames],
 
 # _LT_CONFIG_STATUS_DECLARE([VARNAME])
 # ------------------------------------
-# Quote a variable value, and forward it to `config.status' so that its
-# declaration there will have the same value as in `configure'.  VARNAME
+# Quote a variable value, and forward it to 'config.status' so that its
+# declaration there will have the same value as in 'configure'.  VARNAME
 # must have a single quote delimited value for this to work.
 m4_define([_LT_CONFIG_STATUS_DECLARE],
 [$1='`$ECHO "$][$1" | $SED "$delay_single_quote_subst"`'])
@@ -446,7 +456,7 @@ m4_defun([_LT_CONFIG_STATUS_DECLARATIONS],
 # Output comment and list of tags supported by the script
 m4_defun([_LT_LIBTOOL_TAGS],
 [_LT_FORMAT_COMMENT([The names of the tagged configurations supported by this script])dnl
-available_tags="_LT_TAGS"dnl
+available_tags='_LT_TAGS'dnl
 ])
 
 
@@ -474,7 +484,7 @@ m4_ifval([$2], [_$2])[]m4_popdef([_libtool_name])[]dnl
 # _LT_LIBTOOL_CONFIG_VARS
 # -----------------------
 # Produce commented declarations of non-tagged libtool config variables
-# suitable for insertion in the LIBTOOL CONFIG section of the `libtool'
+# suitable for insertion in the LIBTOOL CONFIG section of the 'libtool'
 # script.  Tagged libtool config variables (even for the LIBTOOL CONFIG
 # section) are produced by _LT_LIBTOOL_TAG_VARS.
 m4_defun([_LT_LIBTOOL_CONFIG_VARS],
@@ -500,8 +510,8 @@ m4_define([_LT_TAGVAR], [m4_ifval([$2], [$1_$2], [$1])])
 # Send accumulated output to $CONFIG_STATUS.  Thanks to the lists of
 # variables for single and double quote escaping we saved from calls
 # to _LT_DECL, we can put quote escaped variables declarations
-# into `config.status', and then the shell code to quote escape them in
-# for loops in `config.status'.  Finally, any additional code accumulated
+# into 'config.status', and then the shell code to quote escape them in
+# for loops in 'config.status'.  Finally, any additional code accumulated
 # from calls to _LT_CONFIG_LIBTOOL_INIT is expanded.
 m4_defun([_LT_CONFIG_COMMANDS],
 [AC_PROVIDE_IFELSE([LT_OUTPUT],
@@ -547,7 +557,7 @@ for var in lt_decl_all_varnames([[ \
 ]], lt_decl_quote_varnames); do
     case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in
     *[[\\\\\\\`\\"\\\$]]*)
-      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\""
+      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes
       ;;
     *)
       eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
@@ -560,7 +570,7 @@ for var in lt_decl_all_varnames([[ \
 ]], lt_decl_dquote_varnames); do
     case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in
     *[[\\\\\\\`\\"\\\$]]*)
-      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\""
+      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes
       ;;
     *)
       eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
@@ -576,7 +586,7 @@ _LT_OUTPUT_LIBTOOL_INIT
 # Generate a child script FILE with all initialization necessary to
 # reuse the environment learned by the parent script, and make the
 # file executable.  If COMMENT is supplied, it is inserted after the
-# `#!' sequence but before initialization text begins.  After this
+# '#!' sequence but before initialization text begins.  After this
 # macro, additional text can be appended to FILE to form the body of
 # the child script.  The macro ends with non-zero status if the
 # file could not be fully written (such as if the disk is full).
@@ -598,7 +608,7 @@ AS_SHELL_SANITIZE
 _AS_PREPARE
 exec AS_MESSAGE_FD>&1
 _ASEOF
-test $lt_write_fail = 0 && chmod +x $1[]dnl
+test 0 = "$lt_write_fail" && chmod +x $1[]dnl
 m4_popdef([AS_MESSAGE_LOG_FD])])])# _LT_GENERATED_FILE_INIT
 
 # LT_OUTPUT
@@ -621,7 +631,7 @@ exec AS_MESSAGE_LOG_FD>>config.log
 } >&AS_MESSAGE_LOG_FD
 
 lt_cl_help="\
-\`$as_me' creates a local libtool stub from the current configuration,
+'$as_me' creates a local libtool stub from the current configuration,
 for use in further configure time tests before the real libtool is
 generated.
 
@@ -643,7 +653,7 @@ Copyright (C) 2011 Free Software Foundation, Inc.
 This config.lt script is free software; the Free Software Foundation
 gives unlimited permision to copy, distribute and modify it."
 
-while test $[#] != 0
+while test 0 != $[#]
 do
   case $[1] in
     --version | --v* | -V )
@@ -656,10 +666,10 @@ do
       lt_cl_silent=: ;;
 
     -*) AC_MSG_ERROR([unrecognized option: $[1]
-Try \`$[0] --help' for more information.]) ;;
+Try '$[0] --help' for more information.]) ;;
 
     *) AC_MSG_ERROR([unrecognized argument: $[1]
-Try \`$[0] --help' for more information.]) ;;
+Try '$[0] --help' for more information.]) ;;
   esac
   shift
 done
@@ -685,7 +695,7 @@ chmod +x "$CONFIG_LT"
 # open by configure.  Here we exec the FD to /dev/null, effectively closing
 # config.log, so it can be properly (re)opened and appended to by config.lt.
 lt_cl_success=:
-test "$silent" = yes &&
+test yes = "$silent" &&
   lt_config_lt_args="$lt_config_lt_args --quiet"
 exec AS_MESSAGE_LOG_FD>/dev/null
 $SHELL "$CONFIG_LT" $lt_config_lt_args || lt_cl_success=false
@@ -705,27 +715,31 @@ m4_defun([_LT_CONFIG],
 _LT_CONFIG_SAVE_COMMANDS([
   m4_define([_LT_TAG], m4_if([$1], [], [C], [$1]))dnl
   m4_if(_LT_TAG, [C], [
-    # See if we are running on zsh, and set the options which allow our
+    # See if we are running on zsh, and set the options that allow our
     # commands through without removal of \ escapes.
-    if test -n "${ZSH_VERSION+set}" ; then
+    if test -n "${ZSH_VERSION+set}"; then
       setopt NO_GLOB_SUBST
     fi
 
-    cfgfile="${ofile}T"
+    cfgfile=${ofile}T
     trap "$RM \"$cfgfile\"; exit 1" 1 2 15
     $RM "$cfgfile"
 
     cat <<_LT_EOF >> "$cfgfile"
 #! $SHELL
-
-# `$ECHO "$ofile" | sed 's%^.*/%%'` - Provide generalized library-building support services.
-# Generated automatically by $as_me ($PACKAGE$TIMESTAMP) $VERSION
+# Generated automatically by $as_me ($PACKAGE) $VERSION
 # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`:
 # NOTE: Changes made to this file will be lost: look at ltmain.sh.
-#
+
+# Provide generalized library-building support services.
+# Written by Gordon Matzigkeit, 1996
+
 _LT_COPYING
 _LT_LIBTOOL_TAGS
 
+# Configured defaults for sys_lib_dlsearch_path munging.
+: \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"}
+
 # ### BEGIN LIBTOOL CONFIG
 _LT_LIBTOOL_CONFIG_VARS
 _LT_LIBTOOL_TAG_VARS
@@ -733,13 +747,24 @@ _LT_LIBTOOL_TAG_VARS
 
 _LT_EOF
 
+    cat <<'_LT_EOF' >> "$cfgfile"
+
+# ### BEGIN FUNCTIONS SHARED WITH CONFIGURE
+
+_LT_PREPARE_MUNGE_PATH_LIST
+_LT_PREPARE_CC_BASENAME
+
+# ### END FUNCTIONS SHARED WITH CONFIGURE
+
+_LT_EOF
+
   case $host_os in
   aix3*)
     cat <<\_LT_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
+if test set != "${COLLECT_NAMES+set}"; then
   COLLECT_NAMES=
   export COLLECT_NAMES
 fi
@@ -756,8 +781,6 @@ _LT_EOF
   sed '$q' "$ltmain" >> "$cfgfile" \
      || (rm -f "$cfgfile"; exit 1)
 
-  _LT_PROG_REPLACE_SHELLFNS
-
    mv -f "$cfgfile" "$ofile" ||
     (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile")
   chmod +x "$ofile"
@@ -775,7 +798,6 @@ _LT_EOF
 [m4_if([$1], [], [
     PACKAGE='$PACKAGE'
     VERSION='$VERSION'
-    TIMESTAMP='$TIMESTAMP'
     RM='$RM'
     ofile='$ofile'], [])
 ])dnl /_LT_CONFIG_SAVE_COMMANDS
@@ -974,7 +996,7 @@ m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[
 
     AC_CACHE_CHECK([for -single_module linker flag],[lt_cv_apple_cc_single_mod],
       [lt_cv_apple_cc_single_mod=no
-      if test -z "${LT_MULTI_MODULE}"; then
+      if test -z "$LT_MULTI_MODULE"; then
 	# By default we will add the -single_module flag. You can override
 	# by either setting the environment variable LT_MULTI_MODULE
 	# non-empty at configure time, or by adding -multi_module to the
@@ -992,7 +1014,7 @@ m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[
 	  cat conftest.err >&AS_MESSAGE_LOG_FD
 	# Otherwise, if the output was created with a 0 exit code from
 	# the compiler, it worked.
-	elif test -f libconftest.dylib && test $_lt_result -eq 0; then
+	elif test -f libconftest.dylib && test 0 = "$_lt_result"; then
 	  lt_cv_apple_cc_single_mod=yes
 	else
 	  cat conftest.err >&AS_MESSAGE_LOG_FD
@@ -1010,7 +1032,7 @@ m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[
       AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])],
 	[lt_cv_ld_exported_symbols_list=yes],
 	[lt_cv_ld_exported_symbols_list=no])
-	LDFLAGS="$save_LDFLAGS"
+	LDFLAGS=$save_LDFLAGS
     ])
 
     AC_CACHE_CHECK([for -force_load linker flag],[lt_cv_ld_force_load],
@@ -1032,7 +1054,7 @@ _LT_EOF
       _lt_result=$?
       if test -s conftest.err && $GREP force_load conftest.err; then
 	cat conftest.err >&AS_MESSAGE_LOG_FD
-      elif test -f conftest && test $_lt_result -eq 0 && $GREP forced_load conftest >/dev/null 2>&1 ; then
+      elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then
 	lt_cv_ld_force_load=yes
       else
 	cat conftest.err >&AS_MESSAGE_LOG_FD
@@ -1042,32 +1064,32 @@ _LT_EOF
     ])
     case $host_os in
     rhapsody* | darwin1.[[012]])
-      _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;;
+      _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;;
     darwin1.*)
-      _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+      _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;;
     darwin*) # darwin 5.x on
       # if running on 10.5 or later, the deployment target defaults
       # to the OS version, if on x86, and 10.4, the deployment
       # target defaults to 10.4. Don't you love it?
       case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in
 	10.0,*86*-darwin8*|10.0,*-darwin[[91]]*)
-	  _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
-	10.[[012]]*)
-	  _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+	  _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;;
+	10.[[012]][[,.]]*)
+	  _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;;
 	10.*)
-	  _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
+	  _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;;
       esac
     ;;
   esac
-    if test "$lt_cv_apple_cc_single_mod" = "yes"; then
+    if test yes = "$lt_cv_apple_cc_single_mod"; then
       _lt_dar_single_mod='$single_module'
     fi
-    if test "$lt_cv_ld_exported_symbols_list" = "yes"; then
-      _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym'
+    if test yes = "$lt_cv_ld_exported_symbols_list"; then
+      _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym'
     else
-      _lt_dar_export_syms='~$NMEDIT -s $output_objdir/${libname}-symbols.expsym ${lib}'
+      _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib'
     fi
-    if test "$DSYMUTIL" != ":" && test "$lt_cv_ld_force_load" = "no"; then
+    if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then
       _lt_dsymutil='~$DSYMUTIL $lib || :'
     else
       _lt_dsymutil=
@@ -1087,29 +1109,29 @@ m4_defun([_LT_DARWIN_LINKER_FEATURES],
   _LT_TAGVAR(hardcode_direct, $1)=no
   _LT_TAGVAR(hardcode_automatic, $1)=yes
   _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported
-  if test "$lt_cv_ld_force_load" = "yes"; then
-    _LT_TAGVAR(whole_archive_flag_spec, $1)='`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience ${wl}-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`'
+  if test yes = "$lt_cv_ld_force_load"; then
+    _LT_TAGVAR(whole_archive_flag_spec, $1)='`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`'
     m4_case([$1], [F77], [_LT_TAGVAR(compiler_needs_object, $1)=yes],
                   [FC],  [_LT_TAGVAR(compiler_needs_object, $1)=yes])
   else
     _LT_TAGVAR(whole_archive_flag_spec, $1)=''
   fi
   _LT_TAGVAR(link_all_deplibs, $1)=yes
-  _LT_TAGVAR(allow_undefined_flag, $1)="$_lt_dar_allow_undefined"
+  _LT_TAGVAR(allow_undefined_flag, $1)=$_lt_dar_allow_undefined
   case $cc_basename in
-     ifort*) _lt_dar_can_shared=yes ;;
+     ifort*|nagfor*) _lt_dar_can_shared=yes ;;
      *) _lt_dar_can_shared=$GCC ;;
   esac
-  if test "$_lt_dar_can_shared" = "yes"; then
+  if test yes = "$_lt_dar_can_shared"; then
     output_verbose_link_cmd=func_echo_all
-    _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}"
-    _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}"
-    _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}"
-    _LT_TAGVAR(module_expsym_cmds, $1)="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}"
+    _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil"
+    _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil"
+    _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil"
+    _LT_TAGVAR(module_expsym_cmds, $1)="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil"
     m4_if([$1], [CXX],
-[   if test "$lt_cv_apple_cc_single_mod" != "yes"; then
-      _LT_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${_lt_dsymutil}"
-      _LT_TAGVAR(archive_expsym_cmds, $1)="sed '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${_lt_dar_export_syms}${_lt_dsymutil}"
+[   if test yes != "$lt_cv_apple_cc_single_mod"; then
+      _LT_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$_lt_dsymutil"
+      _LT_TAGVAR(archive_expsym_cmds, $1)="sed '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$_lt_dar_export_syms$_lt_dsymutil"
     fi
 ],[])
   else
@@ -1129,7 +1151,7 @@ m4_defun([_LT_DARWIN_LINKER_FEATURES],
 # Allow to override them for all tags through lt_cv_aix_libpath.
 m4_defun([_LT_SYS_MODULE_PATH_AIX],
 [m4_require([_LT_DECL_SED])dnl
-if test "${lt_cv_aix_libpath+set}" = set; then
+if test set = "${lt_cv_aix_libpath+set}"; then
   aix_libpath=$lt_cv_aix_libpath
 else
   AC_CACHE_VAL([_LT_TAGVAR([lt_cv_aix_libpath_], [$1])],
@@ -1147,7 +1169,7 @@ else
     _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"`
   fi],[])
   if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then
-    _LT_TAGVAR([lt_cv_aix_libpath_], [$1])="/usr/lib:/lib"
+    _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=/usr/lib:/lib
   fi
   ])
   aix_libpath=$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])
@@ -1167,8 +1189,8 @@ m4_define([_LT_SHELL_INIT],
 # -----------------------
 # Find how we can fake an echo command that does not interpret backslash.
 # In particular, with Autoconf 2.60 or later we add some code to the start
-# of the generated configure script which will find a shell with a builtin
-# printf (which we can use as an echo command).
+# of the generated configure script that will find a shell with a builtin
+# printf (that we can use as an echo command).
 m4_defun([_LT_PROG_ECHO_BACKSLASH],
 [ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\'
 ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO
@@ -1196,10 +1218,10 @@ fi
 # Invoke $ECHO with all args, space-separated.
 func_echo_all ()
 {
-    $ECHO "$*" 
+    $ECHO "$*"
 }
 
-case "$ECHO" in
+case $ECHO in
   printf*) AC_MSG_RESULT([printf]) ;;
   print*) AC_MSG_RESULT([print -r]) ;;
   *) AC_MSG_RESULT([cat]) ;;
@@ -1225,16 +1247,17 @@ _LT_DECL([], [ECHO], [1], [An echo program that protects backslashes])
 AC_DEFUN([_LT_WITH_SYSROOT],
 [AC_MSG_CHECKING([for sysroot])
 AC_ARG_WITH([sysroot],
-[  --with-sysroot[=DIR] Search for dependent libraries within DIR
-                        (or the compiler's sysroot if not specified).],
+[AS_HELP_STRING([--with-sysroot@<:@=DIR@:>@],
+  [Search for dependent libraries within DIR (or the compiler's sysroot
+   if not specified).])],
 [], [with_sysroot=no])
 
 dnl lt_sysroot will always be passed unquoted.  We quote it here
 dnl in case the user passed a directory name.
 lt_sysroot=
-case ${with_sysroot} in #(
+case $with_sysroot in #(
  yes)
-   if test "$GCC" = yes; then
+   if test yes = "$GCC"; then
      lt_sysroot=`$CC --print-sysroot 2>/dev/null`
    fi
    ;; #(
@@ -1244,14 +1267,14 @@ case ${with_sysroot} in #(
  no|'')
    ;; #(
  *)
-   AC_MSG_RESULT([${with_sysroot}])
+   AC_MSG_RESULT([$with_sysroot])
    AC_MSG_ERROR([The sysroot must be an absolute path.])
    ;;
 esac
 
  AC_MSG_RESULT([${lt_sysroot:-no}])
 _LT_DECL([], [lt_sysroot], [0], [The root where to search for ]dnl
-[dependent libraries, and in which our libraries should be installed.])])
+[dependent libraries, and where our libraries should be installed.])])
 
 # _LT_ENABLE_LOCK
 # ---------------
@@ -1259,31 +1282,33 @@ m4_defun([_LT_ENABLE_LOCK],
 [AC_ARG_ENABLE([libtool-lock],
   [AS_HELP_STRING([--disable-libtool-lock],
     [avoid locking (might break parallel builds)])])
-test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes
+test no = "$enable_libtool_lock" || 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.
+  # Find out what ABI is being produced by ac_compile, and set mode
+  # options accordingly.
   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"
+	HPUX_IA64_MODE=32
 	;;
       *ELF-64*)
-	HPUX_IA64_MODE="64"
+	HPUX_IA64_MODE=64
 	;;
     esac
   fi
   rm -rf conftest*
   ;;
 *-*-irix6*)
-  # Find out which ABI we are using.
+  # Find out what ABI is being produced by ac_compile, and set linker
+  # options accordingly.
   echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext
   if AC_TRY_EVAL(ac_compile); then
-    if test "$lt_cv_prog_gnu_ld" = yes; then
+    if test yes = "$lt_cv_prog_gnu_ld"; then
       case `/usr/bin/file conftest.$ac_objext` in
 	*32-bit*)
 	  LD="${LD-ld} -melf32bsmip"
@@ -1312,9 +1337,46 @@ ia64-*-hpux*)
   rm -rf conftest*
   ;;
 
-x86_64-*kfreebsd*-gnu|x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*| \
+mips64*-*linux*)
+  # Find out what ABI is being produced by ac_compile, and set linker
+  # options accordingly.
+  echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext
+  if AC_TRY_EVAL(ac_compile); then
+    emul=elf
+    case `/usr/bin/file conftest.$ac_objext` in
+      *32-bit*)
+	emul="${emul}32"
+	;;
+      *64-bit*)
+	emul="${emul}64"
+	;;
+    esac
+    case `/usr/bin/file conftest.$ac_objext` in
+      *MSB*)
+	emul="${emul}btsmip"
+	;;
+      *LSB*)
+	emul="${emul}ltsmip"
+	;;
+    esac
+    case `/usr/bin/file conftest.$ac_objext` in
+      *N32*)
+	emul="${emul}n32"
+	;;
+    esac
+    LD="${LD-ld} -m $emul"
+  fi
+  rm -rf conftest*
+  ;;
+
+x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \
 s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
-  # Find out which ABI we are using.
+  # Find out what ABI is being produced by ac_compile, and set linker
+  # options accordingly.  Note that the listed cases only cover the
+  # situations where additional linker options are needed (such as when
+  # doing 32-bit compilation for a host where ld defaults to 64-bit, or
+  # vice versa); the common cases where no linker options are needed do
+  # not appear in the list.
   echo 'int i;' > conftest.$ac_ext
   if AC_TRY_EVAL(ac_compile); then
     case `/usr/bin/file conftest.o` in
@@ -1324,9 +1386,19 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
 	    LD="${LD-ld} -m elf_i386_fbsd"
 	    ;;
 	  x86_64-*linux*)
-	    LD="${LD-ld} -m elf_i386"
+	    case `/usr/bin/file conftest.o` in
+	      *x86-64*)
+		LD="${LD-ld} -m elf32_x86_64"
+		;;
+	      *)
+		LD="${LD-ld} -m elf_i386"
+		;;
+	    esac
+	    ;;
+	  powerpc64le-*linux*)
+	    LD="${LD-ld} -m elf32lppclinux"
 	    ;;
-	  ppc64-*linux*|powerpc64-*linux*)
+	  powerpc64-*linux*)
 	    LD="${LD-ld} -m elf32ppclinux"
 	    ;;
 	  s390x-*linux*)
@@ -1345,7 +1417,10 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
 	  x86_64-*linux*)
 	    LD="${LD-ld} -m elf_x86_64"
 	    ;;
-	  ppc*-*linux*|powerpc*-*linux*)
+	  powerpcle-*linux*)
+	    LD="${LD-ld} -m elf64lppc"
+	    ;;
+	  powerpc-*linux*)
 	    LD="${LD-ld} -m elf64ppc"
 	    ;;
 	  s390*-*linux*|s390*-*tpf*)
@@ -1363,19 +1438,20 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
 
 *-*-sco3.2v5*)
   # On SCO OpenServer 5, we need -belf to get full-featured binaries.
-  SAVE_CFLAGS="$CFLAGS"
+  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_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],[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
+  if test yes != "$lt_cv_cc_needs_belf"; then
     # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf
-    CFLAGS="$SAVE_CFLAGS"
+    CFLAGS=$SAVE_CFLAGS
   fi
   ;;
 *-*solaris*)
-  # Find out which ABI we are using.
+  # Find out what ABI is being produced by ac_compile, and set linker
+  # options accordingly.
   echo 'int i;' > conftest.$ac_ext
   if AC_TRY_EVAL(ac_compile); then
     case `/usr/bin/file conftest.o` in
@@ -1383,7 +1459,7 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
       case $lt_cv_prog_gnu_ld in
       yes*)
         case $host in
-        i?86-*-solaris*)
+        i?86-*-solaris*|x86_64-*-solaris*)
           LD="${LD-ld} -m elf_x86_64"
           ;;
         sparc*-*-solaris*)
@@ -1392,7 +1468,7 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
         esac
         # GNU ld 2.21 introduced _sol2 emulations.  Use them if available.
         if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then
-          LD="${LD-ld}_sol2"
+          LD=${LD-ld}_sol2
         fi
         ;;
       *)
@@ -1408,7 +1484,7 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
   ;;
 esac
 
-need_locks="$enable_libtool_lock"
+need_locks=$enable_libtool_lock
 ])# _LT_ENABLE_LOCK
 
 
@@ -1427,11 +1503,11 @@ AC_CACHE_CHECK([for archiver @FILE support], [lt_cv_ar_at_file],
      [echo conftest.$ac_objext > conftest.lst
       lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&AS_MESSAGE_LOG_FD'
       AC_TRY_EVAL([lt_ar_try])
-      if test "$ac_status" -eq 0; then
+      if test 0 -eq "$ac_status"; then
 	# Ensure the archiver fails upon bogus file names.
 	rm -f conftest.$ac_objext libconftest.a
 	AC_TRY_EVAL([lt_ar_try])
-	if test "$ac_status" -ne 0; then
+	if test 0 -ne "$ac_status"; then
           lt_cv_ar_at_file=@
         fi
       fi
@@ -1439,7 +1515,7 @@ AC_CACHE_CHECK([for archiver @FILE support], [lt_cv_ar_at_file],
      ])
   ])
 
-if test "x$lt_cv_ar_at_file" = xno; then
+if test no = "$lt_cv_ar_at_file"; then
   archiver_list_spec=
 else
   archiver_list_spec=$lt_cv_ar_at_file
@@ -1470,7 +1546,7 @@ old_postuninstall_cmds=
 
 if test -n "$RANLIB"; then
   case $host_os in
-  openbsd*)
+  bitrig* | openbsd*)
     old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib"
     ;;
   *)
@@ -1506,7 +1582,7 @@ AC_CACHE_CHECK([$1], [$2],
   [$2=no
    m4_if([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4])
    echo "$lt_simple_compile_test_code" > conftest.$ac_ext
-   lt_compiler_flag="$3"
+   lt_compiler_flag="$3"  ## exclude from sc_useless_quotes_in_assignment
    # 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
@@ -1533,7 +1609,7 @@ AC_CACHE_CHECK([$1], [$2],
    $RM conftest*
 ])
 
-if test x"[$]$2" = xyes; then
+if test yes = "[$]$2"; then
     m4_if([$5], , :, [$5])
 else
     m4_if([$6], , :, [$6])
@@ -1555,7 +1631,7 @@ AC_DEFUN([_LT_LINKER_OPTION],
 m4_require([_LT_DECL_SED])dnl
 AC_CACHE_CHECK([$1], [$2],
   [$2=no
-   save_LDFLAGS="$LDFLAGS"
+   save_LDFLAGS=$LDFLAGS
    LDFLAGS="$LDFLAGS $3"
    echo "$lt_simple_link_test_code" > conftest.$ac_ext
    if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then
@@ -1574,10 +1650,10 @@ AC_CACHE_CHECK([$1], [$2],
      fi
    fi
    $RM -r conftest*
-   LDFLAGS="$save_LDFLAGS"
+   LDFLAGS=$save_LDFLAGS
 ])
 
-if test x"[$]$2" = xyes; then
+if test yes = "[$]$2"; then
     m4_if([$4], , :, [$4])
 else
     m4_if([$5], , :, [$5])
@@ -1598,7 +1674,7 @@ AC_DEFUN([LT_CMD_MAX_LEN],
 AC_MSG_CHECKING([the maximum length of command line arguments])
 AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl
   i=0
-  teststring="ABCD"
+  teststring=ABCD
 
   case $build_os in
   msdosdjgpp*)
@@ -1638,7 +1714,7 @@ AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl
     lt_cv_sys_max_cmd_len=8192;
     ;;
 
-  netbsd* | freebsd* | openbsd* | darwin* | dragonfly*)
+  bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*)
     # 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`
@@ -1688,22 +1764,23 @@ AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl
     ;;
   *)
     lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null`
-    if test -n "$lt_cv_sys_max_cmd_len"; then
+    if test -n "$lt_cv_sys_max_cmd_len" && \
+       test undefined != "$lt_cv_sys_max_cmd_len"; then
       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`
     else
       # Make teststring a little bigger before we do anything with it.
       # a 1K string should be a reasonable start.
-      for i in 1 2 3 4 5 6 7 8 ; do
+      for i in 1 2 3 4 5 6 7 8; do
         teststring=$teststring$teststring
       done
       SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}}
       # 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.
-      while { test "X"`env echo "$teststring$teststring" 2>/dev/null` \
+      while { test X`env echo "$teststring$teststring" 2>/dev/null` \
 	         = "X$teststring$teststring"; } >/dev/null 2>&1 &&
-	      test $i != 17 # 1/2 MB should be enough
+	      test 17 != "$i" # 1/2 MB should be enough
       do
         i=`expr $i + 1`
         teststring=$teststring$teststring
@@ -1719,7 +1796,7 @@ AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl
     ;;
   esac
 ])
-if test -n $lt_cv_sys_max_cmd_len ; then
+if test -n "$lt_cv_sys_max_cmd_len"; then
   AC_MSG_RESULT($lt_cv_sys_max_cmd_len)
 else
   AC_MSG_RESULT(none)
@@ -1747,7 +1824,7 @@ m4_defun([_LT_HEADER_DLFCN],
 # ----------------------------------------------------------------
 m4_defun([_LT_TRY_DLOPEN_SELF],
 [m4_require([_LT_HEADER_DLFCN])dnl
-if test "$cross_compiling" = yes; then :
+if test yes = "$cross_compiling"; then :
   [$4]
 else
   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
@@ -1794,9 +1871,9 @@ else
 #  endif
 #endif
 
-/* When -fvisbility=hidden is used, assume the code has been annotated
+/* When -fvisibility=hidden is used, assume the code has been annotated
    correspondingly for the symbols needed.  */
-#if defined(__GNUC__) && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
+#if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
 int fnord () __attribute__((visibility("default")));
 #endif
 
@@ -1822,7 +1899,7 @@ int main ()
   return status;
 }]
 _LT_EOF
-  if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext} 2>/dev/null; then
+  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
@@ -1843,7 +1920,7 @@ rm -fr conftest*
 # ------------------
 AC_DEFUN([LT_SYS_DLOPEN_SELF],
 [m4_require([_LT_HEADER_DLFCN])dnl
-if test "x$enable_dlopen" != xyes; then
+if test yes != "$enable_dlopen"; then
   enable_dlopen=unknown
   enable_dlopen_self=unknown
   enable_dlopen_self_static=unknown
@@ -1853,44 +1930,52 @@ else
 
   case $host_os in
   beos*)
-    lt_cv_dlopen="load_add_on"
+    lt_cv_dlopen=load_add_on
     lt_cv_dlopen_libs=
     lt_cv_dlopen_self=yes
     ;;
 
   mingw* | pw32* | cegcc*)
-    lt_cv_dlopen="LoadLibrary"
+    lt_cv_dlopen=LoadLibrary
     lt_cv_dlopen_libs=
     ;;
 
   cygwin*)
-    lt_cv_dlopen="dlopen"
+    lt_cv_dlopen=dlopen
     lt_cv_dlopen_libs=
     ;;
 
   darwin*)
-  # if libdl is installed we need to link against it
+    # 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=dlopen lt_cv_dlopen_libs=-ldl],[
+    lt_cv_dlopen=dyld
     lt_cv_dlopen_libs=
     lt_cv_dlopen_self=yes
     ])
     ;;
 
+  tpf*)
+    # Don't try to run any link tests for TPF.  We know it's impossible
+    # because TPF is a cross-compiler, and we know how we open DSOs.
+    lt_cv_dlopen=dlopen
+    lt_cv_dlopen_libs=
+    lt_cv_dlopen_self=no
+    ;;
+
   *)
     AC_CHECK_FUNC([shl_load],
-	  [lt_cv_dlopen="shl_load"],
+	  [lt_cv_dlopen=shl_load],
       [AC_CHECK_LIB([dld], [shl_load],
-	    [lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld"],
+	    [lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld],
 	[AC_CHECK_FUNC([dlopen],
-	      [lt_cv_dlopen="dlopen"],
+	      [lt_cv_dlopen=dlopen],
 	  [AC_CHECK_LIB([dl], [dlopen],
-		[lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"],
+		[lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl],
 	    [AC_CHECK_LIB([svld], [dlopen],
-		  [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld"],
+		  [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld],
 	      [AC_CHECK_LIB([dld], [dld_link],
-		    [lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld"])
+		    [lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld])
 	      ])
 	    ])
 	  ])
@@ -1899,21 +1984,21 @@ else
     ;;
   esac
 
-  if test "x$lt_cv_dlopen" != xno; then
-    enable_dlopen=yes
-  else
+  if test no = "$lt_cv_dlopen"; then
     enable_dlopen=no
+  else
+    enable_dlopen=yes
   fi
 
   case $lt_cv_dlopen in
   dlopen)
-    save_CPPFLAGS="$CPPFLAGS"
-    test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H"
+    save_CPPFLAGS=$CPPFLAGS
+    test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H"
 
-    save_LDFLAGS="$LDFLAGS"
+    save_LDFLAGS=$LDFLAGS
     wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\"
 
-    save_LIBS="$LIBS"
+    save_LIBS=$LIBS
     LIBS="$lt_cv_dlopen_libs $LIBS"
 
     AC_CACHE_CHECK([whether a program can dlopen itself],
@@ -1923,7 +2008,7 @@ else
 	    lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross)
     ])
 
-    if test "x$lt_cv_dlopen_self" = xyes; then
+    if test yes = "$lt_cv_dlopen_self"; then
       wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\"
       AC_CACHE_CHECK([whether a statically linked program can dlopen itself],
 	  lt_cv_dlopen_self_static, [dnl
@@ -1933,9 +2018,9 @@ else
       ])
     fi
 
-    CPPFLAGS="$save_CPPFLAGS"
-    LDFLAGS="$save_LDFLAGS"
-    LIBS="$save_LIBS"
+    CPPFLAGS=$save_CPPFLAGS
+    LDFLAGS=$save_LDFLAGS
+    LIBS=$save_LIBS
     ;;
   esac
 
@@ -2027,8 +2112,8 @@ m4_defun([_LT_COMPILER_FILE_LOCKS],
 m4_require([_LT_FILEUTILS_DEFAULTS])dnl
 _LT_COMPILER_C_O([$1])
 
-hard_links="nottested"
-if test "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" = no && test "$need_locks" != no; then
+hard_links=nottested
+if test no = "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" && test no != "$need_locks"; 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
@@ -2038,8 +2123,8 @@ if test "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" = no && test "$need_locks" !=
   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])
+  if test no = "$hard_links"; then
+    AC_MSG_WARN(['$CC' does not support '-c -o', so 'make -j' may be unsafe])
     need_locks=warn
   fi
 else
@@ -2066,8 +2151,8 @@ objdir=$lt_cv_objdir
 _LT_DECL([], [objdir], [0],
          [The name of the directory that contains temporary libtool files])dnl
 m4_pattern_allow([LT_OBJDIR])dnl
-AC_DEFINE_UNQUOTED(LT_OBJDIR, "$lt_cv_objdir/",
-  [Define to the sub-directory in which libtool stores uninstalled libraries.])
+AC_DEFINE_UNQUOTED([LT_OBJDIR], "$lt_cv_objdir/",
+  [Define to the sub-directory where libtool stores uninstalled libraries.])
 ])# _LT_CHECK_OBJDIR
 
 
@@ -2079,15 +2164,15 @@ m4_defun([_LT_LINKER_HARDCODE_LIBPATH],
 _LT_TAGVAR(hardcode_action, $1)=
 if test -n "$_LT_TAGVAR(hardcode_libdir_flag_spec, $1)" ||
    test -n "$_LT_TAGVAR(runpath_var, $1)" ||
-   test "X$_LT_TAGVAR(hardcode_automatic, $1)" = "Xyes" ; then
+   test yes = "$_LT_TAGVAR(hardcode_automatic, $1)"; then
 
   # We can hardcode non-existent directories.
-  if test "$_LT_TAGVAR(hardcode_direct, $1)" != no &&
+  if test no != "$_LT_TAGVAR(hardcode_direct, $1)" &&
      # 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_TAGVAR(hardcode_shlibpath_var, $1)" != no &&
-     test "$_LT_TAGVAR(hardcode_minus_L, $1)" != no; then
+     ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" &&
+     test no != "$_LT_TAGVAR(hardcode_minus_L, $1)"; then
     # Linking always hardcodes the temporary library directory.
     _LT_TAGVAR(hardcode_action, $1)=relink
   else
@@ -2101,12 +2186,12 @@ else
 fi
 AC_MSG_RESULT([$_LT_TAGVAR(hardcode_action, $1)])
 
-if test "$_LT_TAGVAR(hardcode_action, $1)" = relink ||
-   test "$_LT_TAGVAR(inherit_rpath, $1)" = yes; then
+if test relink = "$_LT_TAGVAR(hardcode_action, $1)" ||
+   test yes = "$_LT_TAGVAR(inherit_rpath, $1)"; then
   # Fast installation is not supported
   enable_fast_install=no
-elif test "$shlibpath_overrides_runpath" = yes ||
-     test "$enable_shared" = no; then
+elif test yes = "$shlibpath_overrides_runpath" ||
+     test no = "$enable_shared"; then
   # Fast installation is not necessary
   enable_fast_install=needless
 fi
@@ -2130,7 +2215,7 @@ else
 # FIXME - insert some real tests, host_os isn't really good enough
   case $host_os in
   darwin*)
-    if test -n "$STRIP" ; then
+    if test -n "$STRIP"; then
       striplib="$STRIP -x"
       old_striplib="$STRIP -S"
       AC_MSG_RESULT([yes])
@@ -2148,6 +2233,47 @@ _LT_DECL([], [striplib], [1])
 ])# _LT_CMD_STRIPLIB
 
 
+# _LT_PREPARE_MUNGE_PATH_LIST
+# ---------------------------
+# Make sure func_munge_path_list() is defined correctly.
+m4_defun([_LT_PREPARE_MUNGE_PATH_LIST],
+[[# func_munge_path_list VARIABLE PATH
+# -----------------------------------
+# VARIABLE is name of variable containing _space_ separated list of
+# directories to be munged by the contents of PATH, which is string
+# having a format:
+# "DIR[:DIR]:"
+#       string "DIR[ DIR]" will be prepended to VARIABLE
+# ":DIR[:DIR]"
+#       string "DIR[ DIR]" will be appended to VARIABLE
+# "DIRP[:DIRP]::[DIRA:]DIRA"
+#       string "DIRP[ DIRP]" will be prepended to VARIABLE and string
+#       "DIRA[ DIRA]" will be appended to VARIABLE
+# "DIR[:DIR]"
+#       VARIABLE will be replaced by "DIR[ DIR]"
+func_munge_path_list ()
+{
+    case x at S|@2 in
+    x)
+        ;;
+    *:)
+        eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'` \@S|@@S|@1\"
+        ;;
+    x:*)
+        eval @S|@1=\"\@S|@@S|@1 `$ECHO @S|@2 | $SED 's/:/ /g'`\"
+        ;;
+    *::*)
+        eval @S|@1=\"\@S|@@S|@1\ `$ECHO @S|@2 | $SED -e 's/.*:://' -e 's/:/ /g'`\"
+        eval @S|@1=\"`$ECHO @S|@2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \@S|@@S|@1\"
+        ;;
+    *)
+        eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'`\"
+        ;;
+    esac
+}
+]])# _LT_PREPARE_PATH_LIST
+
+
 # _LT_SYS_DYNAMIC_LINKER([TAG])
 # -----------------------------
 # PORTME Fill in your ld.so characteristics
@@ -2158,17 +2284,18 @@ m4_require([_LT_FILEUTILS_DEFAULTS])dnl
 m4_require([_LT_DECL_OBJDUMP])dnl
 m4_require([_LT_DECL_SED])dnl
 m4_require([_LT_CHECK_SHELL_FEATURES])dnl
+m4_require([_LT_PREPARE_MUNGE_PATH_LIST])dnl
 AC_MSG_CHECKING([dynamic linker characteristics])
 m4_if([$1],
 	[], [
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
   case $host_os in
-    darwin*) lt_awk_arg="/^libraries:/,/LR/" ;;
-    *) lt_awk_arg="/^libraries:/" ;;
+    darwin*) lt_awk_arg='/^libraries:/,/LR/' ;;
+    *) lt_awk_arg='/^libraries:/' ;;
   esac
   case $host_os in
-    mingw* | cegcc*) lt_sed_strip_eq="s,=\([[A-Za-z]]:\),\1,g" ;;
-    *) lt_sed_strip_eq="s,=/,/,g" ;;
+    mingw* | cegcc*) lt_sed_strip_eq='s|=\([[A-Za-z]]:\)|\1|g' ;;
+    *) lt_sed_strip_eq='s|=/|/|g' ;;
   esac
   lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq`
   case $lt_search_path_spec in
@@ -2184,28 +2311,35 @@ if test "$GCC" = yes; then
     ;;
   esac
   # Ok, now we have the path, separated by spaces, we can step through it
-  # and add multilib dir if necessary.
+  # and add multilib dir if necessary...
   lt_tmp_lt_search_path_spec=
-  lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null`
+  lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null`
+  # ...but if some path component already ends with the multilib dir we assume
+  # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer).
+  case "$lt_multi_os_dir; $lt_search_path_spec " in
+  "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*)
+    lt_multi_os_dir=
+    ;;
+  esac
   for lt_sys_path in $lt_search_path_spec; do
-    if test -d "$lt_sys_path/$lt_multi_os_dir"; then
-      lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir"
-    else
+    if test -d "$lt_sys_path$lt_multi_os_dir"; then
+      lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir"
+    elif test -n "$lt_multi_os_dir"; then
       test -d "$lt_sys_path" && \
 	lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path"
     fi
   done
   lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk '
-BEGIN {RS=" "; FS="/|\n";} {
-  lt_foo="";
-  lt_count=0;
+BEGIN {RS = " "; FS = "/|\n";} {
+  lt_foo = "";
+  lt_count = 0;
   for (lt_i = NF; lt_i > 0; lt_i--) {
     if ($lt_i != "" && $lt_i != ".") {
       if ($lt_i == "..") {
         lt_count++;
       } else {
         if (lt_count == 0) {
-          lt_foo="/" $lt_i lt_foo;
+          lt_foo = "/" $lt_i lt_foo;
         } else {
           lt_count--;
         }
@@ -2219,7 +2353,7 @@ BEGIN {RS=" "; FS="/|\n";} {
   # for these hosts.
   case $host_os in
     mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\
-      $SED 's,/\([[A-Za-z]]:\),\1,g'` ;;
+      $SED 's|/\([[A-Za-z]]:\)|\1|g'` ;;
   esac
   sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP`
 else
@@ -2228,7 +2362,7 @@ fi])
 library_names_spec=
 libname_spec='lib$name'
 soname_spec=
-shrext_cmds=".so"
+shrext_cmds=.so
 postinstall_cmds=
 postuninstall_cmds=
 finish_cmds=
@@ -2245,14 +2379,17 @@ hardcode_into_libs=no
 # flags to be left without arguments
 need_version=unknown
 
+AC_ARG_VAR([LT_SYS_LIBRARY_PATH],
+[User-defined run-time library search path.])
+
 case $host_os in
 aix3*)
   version_type=linux # correct to gnu/linux during the next big refactor
-  library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a'
+  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'
+  soname_spec='$libname$release$shared_ext$major'
   ;;
 
 aix[[4-9]]*)
@@ -2260,41 +2397,91 @@ aix[[4-9]]*)
   need_lib_prefix=no
   need_version=no
   hardcode_into_libs=yes
-  if test "$host_cpu" = ia64; then
+  if test ia64 = "$host_cpu"; then
     # AIX 5 supports IA64
-    library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}'
+    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
+    # 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
+	   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
+    # Using Import Files as archive members, it is possible to support
+    # filename-based versioning of shared library archives on AIX. While
+    # this would work for both with and without runtime linking, it will
+    # prevent static linking of such archives. So we do filename-based
+    # shared library versioning with .so extension only, which is used
+    # when both runtime linking and shared linking is enabled.
+    # Unfortunately, runtime linking may impact performance, so we do
+    # not want this to be the default eventually. Also, we use the
+    # versioned .so libs for executables only if there is the -brtl
+    # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only.
+    # To allow for filename-based versioning support, we need to create
+    # libNAME.so.V as an archive file, containing:
+    # *) an Import File, referring to the versioned filename of the
+    #    archive as well as the shared archive member, telling the
+    #    bitwidth (32 or 64) of that shared object, and providing the
+    #    list of exported symbols of that shared object, eventually
+    #    decorated with the 'weak' keyword
+    # *) the shared object with the F_LOADONLY flag set, to really avoid
+    #    it being seen by the linker.
+    # At run time we better use the real file rather than another symlink,
+    # but for link time we create the symlink libNAME.so -> libNAME.so.V
+
+    case $with_aix_soname,$aix_use_runtimelinking in
+    # AIX (on Power*) has no versioning support, so currently we cannot 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
+    aix,yes) # traditional libtool
+      dynamic_linker='AIX unversionable lib.so'
       # If using run time linking (on AIX 4.2 or later) use lib<name>.so
       # instead of lib<name>.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
+      library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+      ;;
+    aix,no) # traditional AIX only
+      dynamic_linker='AIX lib.a[(]lib.so.V[)]'
       # 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
+      library_names_spec='$libname$release.a $libname.a'
+      soname_spec='$libname$release$shared_ext$major'
+      ;;
+    svr4,*) # full svr4 only
+      dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)]"
+      library_names_spec='$libname$release$shared_ext$major $libname$shared_ext'
+      # We do not specify a path in Import Files, so LIBPATH fires.
+      shlibpath_overrides_runpath=yes
+      ;;
+    *,yes) # both, prefer svr4
+      dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)], lib.a[(]lib.so.V[)]"
+      library_names_spec='$libname$release$shared_ext$major $libname$shared_ext'
+      # unpreferred sharedlib libNAME.a needs extra handling
+      postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"'
+      postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"'
+      # We do not specify a path in Import Files, so LIBPATH fires.
+      shlibpath_overrides_runpath=yes
+      ;;
+    *,no) # both, prefer aix
+      dynamic_linker="AIX lib.a[(]lib.so.V[)], lib.so.V[(]$shared_archive_member_spec.o[)]"
+      library_names_spec='$libname$release.a $libname.a'
+      soname_spec='$libname$release$shared_ext$major'
+      # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling
+      postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)'
+      postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"'
+      ;;
+    esac
     shlibpath_var=LIBPATH
   fi
   ;;
@@ -2304,18 +2491,18 @@ amigaos*)
   powerpc)
     # Since July 2007 AmigaOS4 officially supports .so libraries.
     # When compiling the executable, add -use-dynld -Lsobjs: to the compileline.
-    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
     ;;
   m68k)
     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=`func_echo_all "$lib" | $SED '\''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'
+    finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; $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'
     ;;
   esac
   ;;
 
 beos*)
-  library_names_spec='${libname}${shared_ext}'
+  library_names_spec='$libname$shared_ext'
   dynamic_linker="$host_os ld.so"
   shlibpath_var=LIBRARY_PATH
   ;;
@@ -2323,8 +2510,8 @@ beos*)
 bsdi[[45]]*)
   version_type=linux # correct to gnu/linux during the next big refactor
   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'
+  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"
@@ -2336,7 +2523,7 @@ bsdi[[45]]*)
 
 cygwin* | mingw* | pw32* | cegcc*)
   version_type=windows
-  shrext_cmds=".dll"
+  shrext_cmds=.dll
   need_version=no
   need_lib_prefix=no
 
@@ -2345,8 +2532,8 @@ cygwin* | mingw* | pw32* | cegcc*)
     # gcc
     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'\''`~
+    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~
@@ -2362,17 +2549,17 @@ cygwin* | mingw* | pw32* | cegcc*)
     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}'
+      soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext'
 m4_if([$1], [],[
       sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api"])
       ;;
     mingw* | cegcc*)
       # MinGW DLLs use traditional 'lib' prefix
-      soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
+      soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext'
       ;;
     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}'
+      library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext'
       ;;
     esac
     dynamic_linker='Win32 ld.exe'
@@ -2381,8 +2568,8 @@ m4_if([$1], [],[
   *,cl*)
     # Native MSVC
     libname_spec='$name'
-    soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
-    library_names_spec='${libname}.dll.lib'
+    soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext'
+    library_names_spec='$libname.dll.lib'
 
     case $build_os in
     mingw*)
@@ -2409,7 +2596,7 @@ m4_if([$1], [],[
       sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"`
       ;;
     *)
-      sys_lib_search_path_spec="$LIB"
+      sys_lib_search_path_spec=$LIB
       if $ECHO "$sys_lib_search_path_spec" | [$GREP ';[c-zC-Z]:/' >/dev/null]; then
         # It is most probably a Windows format PATH.
         sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'`
@@ -2422,8 +2609,8 @@ m4_if([$1], [],[
     esac
 
     # 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'\''`~
+    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'
@@ -2436,7 +2623,7 @@ m4_if([$1], [],[
 
   *)
     # Assume MSVC wrapper
-    library_names_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext} $libname.lib'
+    library_names_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext $libname.lib'
     dynamic_linker='Win32 ld.exe'
     ;;
   esac
@@ -2449,8 +2636,8 @@ darwin* | rhapsody*)
   version_type=darwin
   need_lib_prefix=no
   need_version=no
-  library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext'
-  soname_spec='${libname}${release}${major}$shared_ext'
+  library_names_spec='$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`'
@@ -2463,8 +2650,8 @@ dgux*)
   version_type=linux # correct to gnu/linux during the next big refactor
   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'
+  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
   ;;
 
@@ -2489,12 +2676,13 @@ freebsd* | dragonfly*)
 
   case $version_type in
     freebsd-elf*)
-      library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
+      library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+      soname_spec='$libname$release$shared_ext$major'
       need_version=no
       need_lib_prefix=no
       ;;
     freebsd-*)
-      library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix'
+      library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
       need_version=yes
       ;;
     linux)
@@ -2525,26 +2713,15 @@ freebsd* | dragonfly*)
   esac
   ;;
 
-gnu*)
-  version_type=linux # correct to gnu/linux during the next big refactor
-  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
-  ;;
-
 haiku*)
   version_type=linux # correct to gnu/linux during the next big refactor
   need_lib_prefix=no
   need_version=no
   dynamic_linker="$host_os runtime_loader"
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
+  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=LIBRARY_PATH
-  shlibpath_overrides_runpath=yes
+  shlibpath_overrides_runpath=no
   sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib'
   hardcode_into_libs=yes
   ;;
@@ -2562,14 +2739,15 @@ hpux9* | hpux10* | hpux11*)
     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
+    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 32 = "$HPUX_IA64_MODE"; then
       sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib"
+      sys_lib_dlsearch_path_spec=/usr/lib/hpux32
     else
       sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64"
+      sys_lib_dlsearch_path_spec=/usr/lib/hpux64
     fi
-    sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
     ;;
   hppa*64*)
     shrext_cmds='.sl'
@@ -2577,8 +2755,8 @@ hpux9* | hpux10* | hpux11*)
     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'
+    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
     ;;
@@ -2587,8 +2765,8 @@ hpux9* | hpux10* | hpux11*)
     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'
+    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, ...
@@ -2601,8 +2779,8 @@ interix[[3-9]]*)
   version_type=linux # correct to gnu/linux during the next big refactor
   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'
+  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='Interix 3.x ld.so.1 (PE, like ELF)'
   shlibpath_var=LD_LIBRARY_PATH
   shlibpath_overrides_runpath=no
@@ -2613,7 +2791,7 @@ irix5* | irix6* | nonstopux*)
   case $host_os in
     nonstopux*) version_type=nonstopux ;;
     *)
-	if test "$lt_cv_prog_gnu_ld" = yes; then
+	if test yes = "$lt_cv_prog_gnu_ld"; then
 		version_type=linux # correct to gnu/linux during the next big refactor
 	else
 		version_type=irix
@@ -2621,8 +2799,8 @@ irix5* | irix6* | nonstopux*)
   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}'
+  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=
@@ -2641,8 +2819,8 @@ irix5* | irix6* | nonstopux*)
   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}"
+  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
   ;;
 
@@ -2651,13 +2829,33 @@ linux*oldld* | linux*aout* | linux*coff*)
   dynamic_linker=no
   ;;
 
+linux*android*)
+  version_type=none # Android doesn't support versioned libraries.
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='$libname$release$shared_ext'
+  soname_spec='$libname$release$shared_ext'
+  finish_cmds=
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+
+  # 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
+
+  dynamic_linker='Android linker'
+  # Don't embed -rpath directories since the linker doesn't support them.
+  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+  ;;
+
 # This must be glibc/ELF.
-linux* | k*bsd*-gnu | kopensolaris*-gnu)
+linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
   version_type=linux # correct to gnu/linux during the next big refactor
   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'
+  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
@@ -2682,7 +2880,12 @@ linux* | k*bsd*-gnu | kopensolaris*-gnu)
   # before this can be enabled.
   hardcode_into_libs=yes
 
-  # Append ld.so.conf contents to the search path
+  # Ideally, we could use ldconfig to report *all* directores which are
+  # searched for libraries, however this is still not possible.  Aside from not
+  # being certain /sbin/ldconfig is available, command
+  # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64,
+  # even though it is searched at run-time.  Try to do the best guess by
+  # appending ld.so.conf contents (and includes) to the search path.
   if test -f /etc/ld.so.conf; then
     lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[	 ]*hwcap[	 ]/d;s/[:,	]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '`
     sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra"
@@ -2702,12 +2905,12 @@ netbsd*)
   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'
+    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'
+    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
@@ -2717,7 +2920,7 @@ netbsd*)
 
 newsos6)
   version_type=linux # correct to gnu/linux during the next big refactor
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  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
   ;;
@@ -2726,58 +2929,68 @@ newsos6)
   version_type=qnx
   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'
+  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='ldqnx.so'
   ;;
 
-openbsd*)
+openbsd* | bitrig*)
   version_type=sunos
-  sys_lib_dlsearch_path_spec="/usr/lib"
+  sys_lib_dlsearch_path_spec=/usr/lib
   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
+  if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then
+    need_version=no
   else
-    shlibpath_overrides_runpath=yes
+    need_version=yes
   fi
+  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
+  shlibpath_overrides_runpath=yes
   ;;
 
 os2*)
   libname_spec='$name'
-  shrext_cmds=".dll"
+  version_type=windows
+  shrext_cmds=.dll
+  need_version=no
   need_lib_prefix=no
-  library_names_spec='$libname${shared_ext} $libname.a'
+  # OS/2 can only load a DLL with a base name of 8 characters or less.
+  soname_spec='`test -n "$os2dllname" && libname="$os2dllname";
+    v=$($ECHO $release$versuffix | tr -d .-);
+    n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _);
+    $ECHO $n$v`$shared_ext'
+  library_names_spec='${libname}_dll.$libext'
   dynamic_linker='OS/2 ld.exe'
-  shlibpath_var=LIBPATH
+  shlibpath_var=BEGINLIBPATH
+  sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib"
+  sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
+  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~
+    if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then
+      eval '\''$striplib \$dldir/$dlname'\'' || exit \$?;
+    fi'
+  postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~
+    dlpath=$dir/\$dldll~
+    $RM \$dlpath'
   ;;
 
 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}'
+  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"
+  sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
   ;;
 
 rdos*)
@@ -2788,8 +3001,8 @@ solaris*)
   version_type=linux # correct to gnu/linux during the next big refactor
   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'
+  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
@@ -2799,11 +3012,11 @@ solaris*)
 
 sunos4*)
   version_type=sunos
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+  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
+  if test yes = "$with_gnu_ld"; then
     need_lib_prefix=no
   fi
   need_version=yes
@@ -2811,8 +3024,8 @@ sunos4*)
 
 sysv4 | sysv4.3*)
   version_type=linux # correct to gnu/linux during the next big refactor
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
+  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)
@@ -2833,24 +3046,24 @@ sysv4 | sysv4.3*)
   ;;
 
 sysv4*MP*)
-  if test -d /usr/nec ;then
+  if test -d /usr/nec; then
     version_type=linux # correct to gnu/linux during the next big refactor
-    library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}'
-    soname_spec='$libname${shared_ext}.$major'
+    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
   ;;
 
 sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
-  version_type=freebsd-elf
+  version_type=sco
   need_lib_prefix=no
   need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
+  library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext'
+  soname_spec='$libname$release$shared_ext$major'
   shlibpath_var=LD_LIBRARY_PATH
   shlibpath_overrides_runpath=yes
   hardcode_into_libs=yes
-  if test "$with_gnu_ld" = yes; then
+  if test yes = "$with_gnu_ld"; then
     sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib'
   else
     sys_lib_search_path_spec='/usr/ccs/lib /usr/lib'
@@ -2868,7 +3081,7 @@ tpf*)
   version_type=linux # correct to gnu/linux during the next big refactor
   need_lib_prefix=no
   need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
   shlibpath_var=LD_LIBRARY_PATH
   shlibpath_overrides_runpath=no
   hardcode_into_libs=yes
@@ -2876,8 +3089,8 @@ tpf*)
 
 uts4*)
   version_type=linux # correct to gnu/linux during the next big refactor
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
+  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
   ;;
 
@@ -2886,20 +3099,30 @@ uts4*)
   ;;
 esac
 AC_MSG_RESULT([$dynamic_linker])
-test "$dynamic_linker" = no && can_build_shared=no
+test no = "$dynamic_linker" && can_build_shared=no
 
 variables_saved_for_relink="PATH $shlibpath_var $runpath_var"
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
   variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH"
 fi
 
-if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then
-  sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec"
+if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then
+  sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec
 fi
-if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then
-  sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec"
+
+if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then
+  sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec
 fi
 
+# remember unaugmented sys_lib_dlsearch_path content for libtool script decls...
+configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec
+
+# ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code
+func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH"
+
+# to be used as default LT_SYS_LIBRARY_PATH value in generated libtool
+configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH
+
 _LT_DECL([], [variables_saved_for_relink], [1],
     [Variables whose values should be saved in libtool wrapper scripts and
     restored at link time])
@@ -2932,39 +3155,41 @@ _LT_DECL([], [hardcode_into_libs], [0],
     [Whether we should hardcode library paths into libraries])
 _LT_DECL([], [sys_lib_search_path_spec], [2],
     [Compile-time system search path for libraries])
-_LT_DECL([], [sys_lib_dlsearch_path_spec], [2],
-    [Run-time system search path for libraries])
+_LT_DECL([sys_lib_dlsearch_path_spec], [configure_time_dlsearch_path], [2],
+    [Detected run-time system search path for libraries])
+_LT_DECL([], [configure_time_lt_sys_library_path], [2],
+    [Explicit LT_SYS_LIBRARY_PATH set during ./configure time])
 ])# _LT_SYS_DYNAMIC_LINKER
 
 
 # _LT_PATH_TOOL_PREFIX(TOOL)
 # --------------------------
-# find a file program which can recognize shared library
+# find a file program that can recognize shared library
 AC_DEFUN([_LT_PATH_TOOL_PREFIX],
 [m4_require([_LT_DECL_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_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
+  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="m4_if([$2], , $PATH, [$2])"
   for ac_dir in $ac_dummy; do
-    IFS="$lt_save_ifs"
+    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 -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"
+	  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
 	    :
@@ -2987,11 +3212,11 @@ _LT_EOF
       break
     fi
   done
-  IFS="$lt_save_ifs"
-  MAGIC_CMD="$lt_save_MAGIC_CMD"
+  IFS=$lt_save_ifs
+  MAGIC_CMD=$lt_save_MAGIC_CMD
   ;;
 esac])
-MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+MAGIC_CMD=$lt_cv_path_MAGIC_CMD
 if test -n "$MAGIC_CMD"; then
   AC_MSG_RESULT($MAGIC_CMD)
 else
@@ -3009,7 +3234,7 @@ dnl AC_DEFUN([AC_PATH_TOOL_PREFIX], [])
 
 # _LT_PATH_MAGIC
 # --------------
-# find a file program which can recognize a shared library
+# find a file program that can recognize a shared library
 m4_defun([_LT_PATH_MAGIC],
 [_LT_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH)
 if test -z "$lt_cv_path_MAGIC_CMD"; then
@@ -3036,16 +3261,16 @@ m4_require([_LT_PROG_ECHO_BACKSLASH])dnl
 AC_ARG_WITH([gnu-ld],
     [AS_HELP_STRING([--with-gnu-ld],
 	[assume the C compiler uses GNU ld @<:@default=no@:>@])],
-    [test "$withval" = no || with_gnu_ld=yes],
+    [test no = "$withval" || with_gnu_ld=yes],
     [with_gnu_ld=no])dnl
 
 ac_prog=ld
-if test "$GCC" = yes; then
+if test yes = "$GCC"; 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
+    # 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` ;;
@@ -3059,7 +3284,7 @@ if test "$GCC" = yes; then
       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"
+      test -z "$LD" && LD=$ac_prog
       ;;
   "")
     # If it fails, then pretend we aren't using GCC.
@@ -3070,37 +3295,37 @@ if test "$GCC" = yes; then
     with_gnu_ld=unknown
     ;;
   esac
-elif test "$with_gnu_ld" = yes; then
+elif test yes = "$with_gnu_ld"; 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
+  lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
   for ac_dir in $PATH; do
-    IFS="$lt_save_ifs"
+    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"
+      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 </dev/null` in
       *GNU* | *'with BFD'*)
-	test "$with_gnu_ld" != no && break
+	test no != "$with_gnu_ld" && break
 	;;
       *)
-	test "$with_gnu_ld" != yes && break
+	test yes != "$with_gnu_ld" && break
 	;;
       esac
     fi
   done
-  IFS="$lt_save_ifs"
+  IFS=$lt_save_ifs
 else
-  lt_cv_path_LD="$LD" # Let the user override the test with a path.
+  lt_cv_path_LD=$LD # Let the user override the test with a path.
 fi])
-LD="$lt_cv_path_LD"
+LD=$lt_cv_path_LD
 if test -n "$LD"; then
   AC_MSG_RESULT($LD)
 else
@@ -3154,13 +3379,13 @@ esac
 reload_cmds='$LD$reload_flag -o $output$reload_objs'
 case $host_os in
   cygwin* | mingw* | pw32* | cegcc*)
-    if test "$GCC" != yes; then
+    if test yes != "$GCC"; then
       reload_cmds=false
     fi
     ;;
   darwin*)
-    if test "$GCC" = yes; then
-      reload_cmds='$LTCC $LTCFLAGS -nostdlib ${wl}-r -o $output$reload_objs'
+    if test yes = "$GCC"; then
+      reload_cmds='$LTCC $LTCFLAGS -nostdlib $wl-r -o $output$reload_objs'
     else
       reload_cmds='$LD$reload_flag -o $output$reload_objs'
     fi
@@ -3171,6 +3396,43 @@ _LT_TAGDECL([], [reload_cmds], [2])dnl
 ])# _LT_CMD_RELOAD
 
 
+# _LT_PATH_DD
+# -----------
+# find a working dd
+m4_defun([_LT_PATH_DD],
+[AC_CACHE_CHECK([for a working dd], [ac_cv_path_lt_DD],
+[printf 0123456789abcdef0123456789abcdef >conftest.i
+cat conftest.i conftest.i >conftest2.i
+: ${lt_DD:=$DD}
+AC_PATH_PROGS_FEATURE_CHECK([lt_DD], [dd],
+[if "$ac_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then
+  cmp -s conftest.i conftest.out \
+  && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=:
+fi])
+rm -f conftest.i conftest2.i conftest.out])
+])# _LT_PATH_DD
+
+
+# _LT_CMD_TRUNCATE
+# ----------------
+# find command to truncate a binary pipe
+m4_defun([_LT_CMD_TRUNCATE],
+[m4_require([_LT_PATH_DD])
+AC_CACHE_CHECK([how to truncate binary pipes], [lt_cv_truncate_bin],
+[printf 0123456789abcdef0123456789abcdef >conftest.i
+cat conftest.i conftest.i >conftest2.i
+lt_cv_truncate_bin=
+if "$ac_cv_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then
+  cmp -s conftest.i conftest.out \
+  && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1"
+fi
+rm -f conftest.i conftest2.i conftest.out
+test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q"])
+_LT_DECL([lt_truncate_bin], [lt_cv_truncate_bin], [1],
+  [Command to truncate a binary pipe])
+])# _LT_CMD_TRUNCATE
+
+
 # _LT_CHECK_MAGIC_METHOD
 # ----------------------
 # how to check for library dependencies
@@ -3186,13 +3448,13 @@ 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.
+# '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.
+# that 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
 aix[[4-9]]*)
@@ -3219,8 +3481,7 @@ 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',
   # unless we find 'file', for example because we are cross-compiling.
-  # func_win32_libid assumes BSD nm, so disallow it if using MS dumpbin.
-  if ( test "$lt_cv_nm_interface" = "BSD nm" && file / ) >/dev/null 2>&1; then
+  if ( file / ) >/dev/null 2>&1; then
     lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL'
     lt_cv_file_magic_cmd='func_win32_libid'
   else
@@ -3256,10 +3517,6 @@ freebsd* | dragonfly*)
   fi
   ;;
 
-gnu*)
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-
 haiku*)
   lt_cv_deplibs_check_method=pass_all
   ;;
@@ -3298,7 +3555,7 @@ irix5* | irix6* | nonstopux*)
   ;;
 
 # This must be glibc/ELF.
-linux* | k*bsd*-gnu | kopensolaris*-gnu)
+linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
   lt_cv_deplibs_check_method=pass_all
   ;;
 
@@ -3320,8 +3577,8 @@ newos6*)
   lt_cv_deplibs_check_method=pass_all
   ;;
 
-openbsd*)
-  if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+openbsd* | bitrig*)
+  if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; 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)$'
@@ -3374,6 +3631,9 @@ sysv4 | sysv4.3*)
 tpf*)
   lt_cv_deplibs_check_method=pass_all
   ;;
+os2*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
 esac
 ])
 
@@ -3414,33 +3674,38 @@ AC_DEFUN([LT_PATH_NM],
 AC_CACHE_CHECK([for BSD- or MS-compatible name lister (nm)], lt_cv_path_NM,
 [if test -n "$NM"; then
   # Let the user override the test.
-  lt_cv_path_NM="$NM"
+  lt_cv_path_NM=$NM
 else
-  lt_nm_to_check="${ac_tool_prefix}nm"
+  lt_nm_to_check=${ac_tool_prefix}nm
   if test -n "$ac_tool_prefix" && test "$build" = "$host"; then
     lt_nm_to_check="$lt_nm_to_check nm"
   fi
   for lt_tmp_nm in $lt_nm_to_check; do
-    lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+    lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
     for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do
-      IFS="$lt_save_ifs"
+      IFS=$lt_save_ifs
       test -z "$ac_dir" && ac_dir=.
-      tmp_nm="$ac_dir/$lt_tmp_nm"
-      if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then
+      tmp_nm=$ac_dir/$lt_tmp_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:
+	# 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'*)
+	# MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty
+	case $build_os in
+	mingw*) lt_bad_file=conftest.nm/nofile ;;
+	*) lt_bad_file=/dev/null ;;
+	esac
+	case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in
+	*$lt_bad_file* | *'Invalid file or object type'*)
 	  lt_cv_path_NM="$tmp_nm -B"
-	  break
+	  break 2
 	  ;;
 	*)
 	  case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in
 	  */dev/null*)
 	    lt_cv_path_NM="$tmp_nm -p"
-	    break
+	    break 2
 	    ;;
 	  *)
 	    lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but
@@ -3451,21 +3716,21 @@ else
 	esac
       fi
     done
-    IFS="$lt_save_ifs"
+    IFS=$lt_save_ifs
   done
   : ${lt_cv_path_NM=no}
 fi])
-if test "$lt_cv_path_NM" != "no"; then
-  NM="$lt_cv_path_NM"
+if test no != "$lt_cv_path_NM"; then
+  NM=$lt_cv_path_NM
 else
   # Didn't find any BSD compatible name lister, look for dumpbin.
   if test -n "$DUMPBIN"; then :
     # Let the user override the test.
   else
     AC_CHECK_TOOLS(DUMPBIN, [dumpbin "link -dump"], :)
-    case `$DUMPBIN -symbols /dev/null 2>&1 | sed '1q'` in
+    case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in
     *COFF*)
-      DUMPBIN="$DUMPBIN -symbols"
+      DUMPBIN="$DUMPBIN -symbols -headers"
       ;;
     *)
       DUMPBIN=:
@@ -3473,8 +3738,8 @@ else
     esac
   fi
   AC_SUBST([DUMPBIN])
-  if test "$DUMPBIN" != ":"; then
-    NM="$DUMPBIN"
+  if test : != "$DUMPBIN"; then
+    NM=$DUMPBIN
   fi
 fi
 test -z "$NM" && NM=nm
@@ -3520,8 +3785,8 @@ lt_cv_sharedlib_from_linklib_cmd,
 
 case $host_os in
 cygwin* | mingw* | pw32* | cegcc*)
-  # two different shell functions defined in ltmain.sh
-  # decide which to use based on capabilities of $DLLTOOL
+  # two different shell functions defined in ltmain.sh;
+  # decide which one to use based on capabilities of $DLLTOOL
   case `$DLLTOOL --help 2>&1` in
   *--identify-strict*)
     lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib
@@ -3533,7 +3798,7 @@ cygwin* | mingw* | pw32* | cegcc*)
   ;;
 *)
   # fallback: assume linklib IS sharedlib
-  lt_cv_sharedlib_from_linklib_cmd="$ECHO"
+  lt_cv_sharedlib_from_linklib_cmd=$ECHO
   ;;
 esac
 ])
@@ -3560,13 +3825,28 @@ AC_CACHE_CHECK([if $MANIFEST_TOOL is a manifest tool], [lt_cv_path_mainfest_tool
     lt_cv_path_mainfest_tool=yes
   fi
   rm -f conftest*])
-if test "x$lt_cv_path_mainfest_tool" != xyes; then
+if test yes != "$lt_cv_path_mainfest_tool"; then
   MANIFEST_TOOL=:
 fi
 _LT_DECL([], [MANIFEST_TOOL], [1], [Manifest tool])dnl
 ])# _LT_PATH_MANIFEST_TOOL
 
 
+# _LT_DLL_DEF_P([FILE])
+# ---------------------
+# True iff FILE is a Windows DLL '.def' file.
+# Keep in sync with func_dll_def_p in the libtool script
+AC_DEFUN([_LT_DLL_DEF_P],
+[dnl
+  test DEF = "`$SED -n dnl
+    -e '\''s/^[[	 ]]*//'\'' dnl Strip leading whitespace
+    -e '\''/^\(;.*\)*$/d'\'' dnl      Delete empty lines and comments
+    -e '\''s/^\(EXPORTS\|LIBRARY\)\([[	 ]].*\)*$/DEF/p'\'' dnl
+    -e q dnl                          Only consider the first "real" line
+    $1`" dnl
+])# _LT_DLL_DEF_P
+
+
 # LT_LIB_M
 # --------
 # check for math library
@@ -3578,11 +3858,11 @@ case $host in
   # These system don't have libm, or don't need it
   ;;
 *-ncr-sysv4.3*)
-  AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM="-lmw")
+  AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM=-lmw)
   AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm")
   ;;
 *)
-  AC_CHECK_LIB(m, cos, LIBM="-lm")
+  AC_CHECK_LIB(m, cos, LIBM=-lm)
   ;;
 esac
 AC_SUBST([LIBM])
@@ -3601,7 +3881,7 @@ m4_defun([_LT_COMPILER_NO_RTTI],
 
 _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=
 
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
   case $cc_basename in
   nvcc*)
     _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -Xcompiler -fno-builtin' ;;
@@ -3653,7 +3933,7 @@ cygwin* | mingw* | pw32* | cegcc*)
   symcode='[[ABCDGISTW]]'
   ;;
 hpux*)
-  if test "$host_cpu" = ia64; then
+  if test ia64 = "$host_cpu"; then
     symcode='[[ABCDEGRST]]'
   fi
   ;;
@@ -3686,14 +3966,44 @@ case `$NM -V 2>&1` in
   symcode='[[ABCDGIRSTW]]' ;;
 esac
 
+if test "$lt_cv_nm_interface" = "MS dumpbin"; then
+  # Gets list of data symbols to import.
+  lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'"
+  # Adjust the below global symbol transforms to fixup imported variables.
+  lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'"
+  lt_c_name_hook=" -e 's/^I .* \(.*\)$/  {\"\1\", (void *) 0},/p'"
+  lt_c_name_lib_hook="\
+  -e 's/^I .* \(lib.*\)$/  {\"\1\", (void *) 0},/p'\
+  -e 's/^I .* \(.*\)$/  {\"lib\1\", (void *) 0},/p'"
+else
+  # Disable hooks by default.
+  lt_cv_sys_global_symbol_to_import=
+  lt_cdecl_hook=
+  lt_c_name_hook=
+  lt_c_name_lib_hook=
+fi
+
 # Transform an extracted symbol line into a proper C declaration.
 # Some systems (esp. on ia64) link data and code symbols differently,
 # so use this general approach.
-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_cdecl="sed -n"\
+$lt_cdecl_hook\
+" -e 's/^T .* \(.*\)$/extern int \1();/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/extern char \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\\\", (void *) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/  {\"\2\", (void *) \&\2},/p'"
-lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n -e 's/^: \([[^ ]]*\)[[ ]]*$/  {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \(lib[[^ ]]*\)$/  {\"\2\", (void *) \&\2},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/  {\"lib\2\", (void *) \&\2},/p'"
+lt_cv_sys_global_symbol_to_c_name_address="sed -n"\
+$lt_c_name_hook\
+" -e 's/^: \(.*\) .*$/  {\"\1\", (void *) 0},/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/  {\"\1\", (void *) \&\1},/p'"
+
+# Transform an extracted symbol line into symbol name with lib prefix and
+# symbol address.
+lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\
+$lt_c_name_lib_hook\
+" -e 's/^: \(.*\) .*$/  {\"\1\", (void *) 0},/p'"\
+" -e 's/^$symcode$symcode* .* \(lib.*\)$/  {\"\1\", (void *) \&\1},/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/  {\"lib\1\", (void *) \&\1},/p'"
 
 # Handle CRLF in mingw tool chain
 opt_cr=
@@ -3711,21 +4021,24 @@ for ac_symprfx in "" "_"; do
 
   # Write the raw and C identifiers.
   if test "$lt_cv_nm_interface" = "MS dumpbin"; then
-    # Fake it for dumpbin and say T for any non-static function
-    # and D for any global variable.
+    # Fake it for dumpbin and say T for any non-static function,
+    # D for any global variable and I for any imported variable.
     # Also find C++ and __fastcall symbols from MSVC++,
     # which start with @ or ?.
     lt_cv_sys_global_symbol_pipe="$AWK ['"\
 "     {last_section=section; section=\$ 3};"\
 "     /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\
 "     /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\
+"     /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\
+"     /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\
+"     /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\
 "     \$ 0!~/External *\|/{next};"\
 "     / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\
 "     {if(hide[section]) next};"\
-"     {f=0}; \$ 0~/\(\).*\|/{f=1}; {printf f ? \"T \" : \"D \"};"\
-"     {split(\$ 0, a, /\||\r/); split(a[2], s)};"\
-"     s[1]~/^[@?]/{print s[1], s[1]; next};"\
-"     s[1]~prfx {split(s[1],t,\"@\"); print t[1], substr(t[1],length(prfx))}"\
+"     {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\
+"     {split(\$ 0,a,/\||\r/); split(a[2],s)};"\
+"     s[1]~/^[@?]/{print f,s[1],s[1]; next};"\
+"     s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\
 "     ' prfx=^$ac_symprfx]"
   else
     lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[	 ]]\($symcode$symcode*\)[[	 ]][[	 ]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'"
@@ -3765,11 +4078,11 @@ _LT_EOF
 	if $GREP ' nm_test_func$' "$nlist" >/dev/null; then
 	  cat <<_LT_EOF > conftest.$ac_ext
 /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests.  */
-#if defined(_WIN32) || defined(__CYGWIN__) || defined(_WIN32_WCE)
-/* DATA imports from DLLs on WIN32 con't be const, because runtime
+#if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE
+/* DATA imports from DLLs on WIN32 can't be const, because runtime
    relocations are performed -- see ld's documentation on pseudo-relocs.  */
 # define LT@&t at _DLSYM_CONST
-#elif defined(__osf__)
+#elif defined __osf__
 /* This system does not cope well with relocations in const data.  */
 # define LT@&t at _DLSYM_CONST
 #else
@@ -3795,7 +4108,7 @@ lt__PROGRAM__LTX_preloaded_symbols[[]] =
 {
   { "@PROGRAM@", (void *) 0 },
 _LT_EOF
-	  $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/  {\"\2\", (void *) \&\2},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext
+	  $SED "s/^$symcode$symcode* .* \(.*\)$/  {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext
 	  cat <<\_LT_EOF >> conftest.$ac_ext
   {0, (void *) 0}
 };
@@ -3815,9 +4128,9 @@ _LT_EOF
 	  mv conftest.$ac_objext conftstm.$ac_objext
 	  lt_globsym_save_LIBS=$LIBS
 	  lt_globsym_save_CFLAGS=$CFLAGS
-	  LIBS="conftstm.$ac_objext"
+	  LIBS=conftstm.$ac_objext
 	  CFLAGS="$CFLAGS$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)"
-	  if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext}; then
+	  if AC_TRY_EVAL(ac_link) && test -s conftest$ac_exeext; then
 	    pipe_works=yes
 	  fi
 	  LIBS=$lt_globsym_save_LIBS
@@ -3838,7 +4151,7 @@ _LT_EOF
   rm -rf conftest* conftst*
 
   # Do not use the global_symbol_pipe unless it works.
-  if test "$pipe_works" = yes; then
+  if test yes = "$pipe_works"; then
     break
   else
     lt_cv_sys_global_symbol_pipe=
@@ -3865,12 +4178,16 @@ _LT_DECL([global_symbol_pipe], [lt_cv_sys_global_symbol_pipe], [1],
     [Take the output of nm and produce a listing of raw symbols and C names])
 _LT_DECL([global_symbol_to_cdecl], [lt_cv_sys_global_symbol_to_cdecl], [1],
     [Transform the output of nm in a proper C declaration])
+_LT_DECL([global_symbol_to_import], [lt_cv_sys_global_symbol_to_import], [1],
+    [Transform the output of nm into a list of symbols to manually relocate])
 _LT_DECL([global_symbol_to_c_name_address],
     [lt_cv_sys_global_symbol_to_c_name_address], [1],
     [Transform the output of nm in a C name address pair])
 _LT_DECL([global_symbol_to_c_name_address_lib_prefix],
     [lt_cv_sys_global_symbol_to_c_name_address_lib_prefix], [1],
     [Transform the output of nm in a C name address pair when lib prefix is needed])
+_LT_DECL([nm_interface], [lt_cv_nm_interface], [1],
+    [The name lister interface])
 _LT_DECL([], [nm_file_list_spec], [1],
     [Specify filename containing input files for $NM])
 ]) # _LT_CMD_GLOBAL_SYMBOLS
@@ -3886,17 +4203,18 @@ _LT_TAGVAR(lt_prog_compiler_static, $1)=
 
 m4_if([$1], [CXX], [
   # C++ specific cases for pic, static, wl, etc.
-  if test "$GXX" = yes; then
+  if test yes = "$GXX"; then
     _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
     _LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
 
     case $host_os in
     aix*)
       # All AIX code is PIC.
-      if test "$host_cpu" = ia64; then
+      if test ia64 = "$host_cpu"; then
 	# AIX 5 now supports IA64 processor
 	_LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
       fi
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
       ;;
 
     amigaos*)
@@ -3907,8 +4225,8 @@ m4_if([$1], [CXX], [
         ;;
       m68k)
             # FIXME: we need at least 68020 code to build shared libraries, but
-            # adding the `-m68020' flag to GCC prevents building anything better,
-            # like `-m68040'.
+            # adding the '-m68020' flag to GCC prevents building anything better,
+            # like '-m68040'.
             _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4'
         ;;
       esac
@@ -3924,6 +4242,11 @@ m4_if([$1], [CXX], [
       # (--disable-auto-import) libraries
       m4_if([$1], [GCJ], [],
 	[_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'])
+      case $host_os in
+      os2*)
+	_LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static'
+	;;
+      esac
       ;;
     darwin* | rhapsody*)
       # PIC is the default on this platform
@@ -3973,7 +4296,7 @@ m4_if([$1], [CXX], [
     case $host_os in
       aix[[4-9]]*)
 	# All AIX code is PIC.
-	if test "$host_cpu" = ia64; then
+	if test ia64 = "$host_cpu"; then
 	  # AIX 5 now supports IA64 processor
 	  _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
 	else
@@ -4014,14 +4337,14 @@ m4_if([$1], [CXX], [
 	case $cc_basename in
 	  CC*)
 	    _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-	    _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive'
-	    if test "$host_cpu" != ia64; then
+	    _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive'
+	    if test ia64 != "$host_cpu"; then
 	      _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z'
 	    fi
 	    ;;
 	  aCC*)
 	    _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-	    _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive'
+	    _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive'
 	    case $host_cpu in
 	    hppa*64*|ia64*)
 	      # +Z the default
@@ -4050,7 +4373,7 @@ m4_if([$1], [CXX], [
 	    ;;
 	esac
 	;;
-      linux* | k*bsd*-gnu | kopensolaris*-gnu)
+      linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
 	case $cc_basename in
 	  KCC*)
 	    # KAI C++ Compiler
@@ -4058,7 +4381,7 @@ m4_if([$1], [CXX], [
 	    _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
 	    ;;
 	  ecpc* )
-	    # old Intel C++ for x86_64 which still supported -KPIC.
+	    # old Intel C++ for x86_64, which still supported -KPIC.
 	    _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
 	    _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
 	    _LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
@@ -4203,17 +4526,18 @@ m4_if([$1], [CXX], [
   fi
 ],
 [
-  if test "$GCC" = yes; then
+  if test yes = "$GCC"; then
     _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
     _LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
 
     case $host_os in
       aix*)
       # All AIX code is PIC.
-      if test "$host_cpu" = ia64; then
+      if test ia64 = "$host_cpu"; then
 	# AIX 5 now supports IA64 processor
 	_LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
       fi
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
       ;;
 
     amigaos*)
@@ -4224,8 +4548,8 @@ m4_if([$1], [CXX], [
         ;;
       m68k)
             # FIXME: we need at least 68020 code to build shared libraries, but
-            # adding the `-m68020' flag to GCC prevents building anything better,
-            # like `-m68040'.
+            # adding the '-m68020' flag to GCC prevents building anything better,
+            # like '-m68040'.
             _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4'
         ;;
       esac
@@ -4242,6 +4566,11 @@ m4_if([$1], [CXX], [
       # (--disable-auto-import) libraries
       m4_if([$1], [GCJ], [],
 	[_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'])
+      case $host_os in
+      os2*)
+	_LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static'
+	;;
+      esac
       ;;
 
     darwin* | rhapsody*)
@@ -4312,7 +4641,7 @@ m4_if([$1], [CXX], [
     case $host_os in
     aix*)
       _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-      if test "$host_cpu" = ia64; then
+      if test ia64 = "$host_cpu"; then
 	# AIX 5 now supports IA64 processor
 	_LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
       else
@@ -4320,11 +4649,30 @@ m4_if([$1], [CXX], [
       fi
       ;;
 
+    darwin* | rhapsody*)
+      # PIC is the default on this platform
+      # Common symbols not allowed in MH_DYLIB files
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common'
+      case $cc_basename in
+      nagfor*)
+        # NAG Fortran compiler
+        _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,'
+        _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC'
+        _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+        ;;
+      esac
+      ;;
+
     mingw* | cygwin* | pw32* | os2* | cegcc*)
       # 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).
       m4_if([$1], [GCJ], [],
 	[_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'])
+      case $host_os in
+      os2*)
+	_LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static'
+	;;
+      esac
       ;;
 
     hpux9* | hpux10* | hpux11*)
@@ -4340,7 +4688,7 @@ m4_if([$1], [CXX], [
 	;;
       esac
       # Is there a better lt_prog_compiler_static that works with the bundled CC?
-      _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive'
+      _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive'
       ;;
 
     irix5* | irix6* | nonstopux*)
@@ -4349,9 +4697,9 @@ m4_if([$1], [CXX], [
       _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
       ;;
 
-    linux* | k*bsd*-gnu | kopensolaris*-gnu)
+    linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
       case $cc_basename in
-      # old Intel for x86_64 which still supported -KPIC.
+      # old Intel for x86_64, which still supported -KPIC.
       ecc*)
 	_LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
 	_LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
@@ -4376,6 +4724,12 @@ m4_if([$1], [CXX], [
 	_LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC'
 	_LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
 	;;
+      tcc*)
+	# Fabrice Bellard et al's Tiny C Compiler
+	_LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+	_LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
+	_LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
+	;;
       pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*)
         # Portland Group compilers (*not* the Pentium gcc compiler,
 	# which looks to be a dead project)
@@ -4473,7 +4827,7 @@ m4_if([$1], [CXX], [
       ;;
 
     sysv4*MP*)
-      if test -d /usr/nec ;then
+      if test -d /usr/nec; then
 	_LT_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic'
 	_LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
       fi
@@ -4502,7 +4856,7 @@ m4_if([$1], [CXX], [
   fi
 ])
 case $host_os in
-  # For platforms which do not support PIC, -DPIC is meaningless:
+  # For platforms that do not support PIC, -DPIC is meaningless:
   *djgpp*)
     _LT_TAGVAR(lt_prog_compiler_pic, $1)=
     ;;
@@ -4568,17 +4922,21 @@ m4_if([$1], [CXX], [
   case $host_os in
   aix[[4-9]]*)
     # 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
-    # Also, AIX nm treats weak defined symbols like other global defined
-    # symbols, whereas GNU nm marks them as "W".
+    # -C means demangle to GNU nm, but means don't demangle to AIX nm.
+    # Without the "-l" option, or with the "-B" option, AIX nm treats
+    # weak defined symbols like other global defined symbols, whereas
+    # GNU nm marks them as "W".
+    # While the 'weak' keyword is ignored in the Export File, we need
+    # it in the Import File for the 'aix-soname' feature, so we have
+    # to replace the "-B" option with "-P" for AIX nm.
     if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then
-      _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+      _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols'
     else
-      _LT_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'
+      _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols'
     fi
     ;;
   pw32*)
-    _LT_TAGVAR(export_symbols_cmds, $1)="$ltdll_cmds"
+    _LT_TAGVAR(export_symbols_cmds, $1)=$ltdll_cmds
     ;;
   cygwin* | mingw* | cegcc*)
     case $cc_basename in
@@ -4624,9 +4982,9 @@ m4_if([$1], [CXX], [
   # included in the symbol list
   _LT_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'.
+  # 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_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*']
   # 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
@@ -4642,7 +5000,7 @@ dnl Note also adjust exclude_expsyms for C++ above.
     # 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
+    if test yes != "$GCC"; then
       with_gnu_ld=no
     fi
     ;;
@@ -4650,7 +5008,7 @@ dnl Note also adjust exclude_expsyms for C++ above.
     # we just hope/assume this is gcc and not c89 (= MSVC++)
     with_gnu_ld=yes
     ;;
-  openbsd*)
+  openbsd* | bitrig*)
     with_gnu_ld=no
     ;;
   esac
@@ -4660,7 +5018,7 @@ dnl Note also adjust exclude_expsyms for C++ above.
   # On some targets, GNU ld is compatible enough with the native linker
   # that we're better off using the native interface for both.
   lt_use_gnu_ld_interface=no
-  if test "$with_gnu_ld" = yes; then
+  if test yes = "$with_gnu_ld"; then
     case $host_os in
       aix*)
 	# The AIX port of GNU ld has always aspired to compatibility
@@ -4682,24 +5040,24 @@ dnl Note also adjust exclude_expsyms for C++ above.
     esac
   fi
 
-  if test "$lt_use_gnu_ld_interface" = yes; then
+  if test yes = "$lt_use_gnu_ld_interface"; then
     # If archive_cmds runs LD, not CC, wlarc should be empty
-    wlarc='${wl}'
+    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_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-    _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
+    _LT_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_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+      _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive'
     else
       _LT_TAGVAR(whole_archive_flag_spec, $1)=
     fi
     supports_anon_versioning=no
-    case `$LD -v 2>&1` in
+    case `$LD -v | $SED -e 's/([^)]\+)\s\+//' 2>&1` in
       *GNU\ gold*) supports_anon_versioning=yes ;;
       *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11
       *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ...
@@ -4712,7 +5070,7 @@ dnl Note also adjust exclude_expsyms for C++ above.
     case $host_os in
     aix[[3-9]]*)
       # On AIX/PPC, the GNU linker is very broken
-      if test "$host_cpu" != ia64; then
+      if test ia64 != "$host_cpu"; then
 	_LT_TAGVAR(ld_shlibs, $1)=no
 	cat <<_LT_EOF 1>&2
 
@@ -4731,7 +5089,7 @@ _LT_EOF
       case $host_cpu in
       powerpc)
             # see comment about AmigaOS4 .so support
-            _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+            _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
             _LT_TAGVAR(archive_expsym_cmds, $1)=''
         ;;
       m68k)
@@ -4747,7 +5105,7 @@ _LT_EOF
 	_LT_TAGVAR(allow_undefined_flag, $1)=unsupported
 	# Joseph Beckenbach <jrb3 at best.com> says some releases of gcc
 	# support --undefined.  This deserves some investigation.  FIXME
-	_LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
       else
 	_LT_TAGVAR(ld_shlibs, $1)=no
       fi
@@ -4757,7 +5115,7 @@ _LT_EOF
       # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless,
       # as there is no search path for DLLs.
       _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-      _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-all-symbols'
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols'
       _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
       _LT_TAGVAR(always_export_symbols, $1)=no
       _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
@@ -4765,61 +5123,89 @@ _LT_EOF
       _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname']
 
       if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then
-        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
-	# If the export-symbols file already is a .def file (1st line
-	# is EXPORTS), use it as is; otherwise, prepend...
-	_LT_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}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+	# If the export-symbols file already is a .def file, use it as
+	# is; otherwise, prepend EXPORTS...
+	_LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); 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--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
       else
 	_LT_TAGVAR(ld_shlibs, $1)=no
       fi
       ;;
 
     haiku*)
-      _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+      _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
       _LT_TAGVAR(link_all_deplibs, $1)=yes
       ;;
 
+    os2*)
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+      _LT_TAGVAR(hardcode_minus_L, $1)=yes
+      _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
+      shrext_cmds=.dll
+      _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+	$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+	$ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+	$ECHO EXPORTS >> $output_objdir/$libname.def~
+	emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~
+	$CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+	emximp -o $lib $output_objdir/$libname.def'
+      _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+	$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+	$ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+	$ECHO EXPORTS >> $output_objdir/$libname.def~
+	prefix_cmds="$SED"~
+	if test EXPORTS = "`$SED 1q $export_symbols`"; then
+	  prefix_cmds="$prefix_cmds -e 1d";
+	fi~
+	prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~
+	cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~
+	$CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+	emximp -o $lib $output_objdir/$libname.def'
+      _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def'
+      _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
+      ;;
+
     interix[[3-9]]*)
       _LT_TAGVAR(hardcode_direct, $1)=no
       _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
-      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-      _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
       # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc.
       # Instead, shared libraries are loaded at an image base (0x10000000 by
       # default) and relocated if they conflict, which is a slow very memory
       # consuming and fragmenting process.  To avoid this, we pick a random,
       # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link
       # time.  Moving up from 0x10000000 also allows more sbrk(2) space.
-      _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
-      _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+      _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+      _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
       ;;
 
     gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu)
       tmp_diet=no
-      if test "$host_os" = linux-dietlibc; then
+      if test linux-dietlibc = "$host_os"; then
 	case $cc_basename in
 	  diet\ *) tmp_diet=yes;;	# linux-dietlibc with static linking (!diet-dyn)
 	esac
       fi
       if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \
-	 && test "$tmp_diet" = no
+	 && test no = "$tmp_diet"
       then
 	tmp_addflag=' $pic_flag'
 	tmp_sharedflag='-shared'
 	case $cc_basename,$host_cpu in
         pgcc*)				# Portland Group C compiler
-	  _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+	  _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
 	  tmp_addflag=' $pic_flag'
 	  ;;
 	pgf77* | pgf90* | pgf95* | pgfortran*)
 					# Portland Group f77 and f90 compilers
-	  _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+	  _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
 	  tmp_addflag=' $pic_flag -Mnomain' ;;
 	ecc*,ia64* | icc*,ia64*)	# Intel C compiler on ia64
 	  tmp_addflag=' -i_dynamic' ;;
@@ -4830,42 +5216,47 @@ _LT_EOF
 	lf95*)				# Lahey Fortran 8.1
 	  _LT_TAGVAR(whole_archive_flag_spec, $1)=
 	  tmp_sharedflag='--shared' ;;
+        nagfor*)                        # NAGFOR 5.3
+          tmp_sharedflag='-Wl,-shared' ;;
 	xl[[cC]]* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL C 8.0 on PPC (deal with xlf below)
 	  tmp_sharedflag='-qmkshrobj'
 	  tmp_addflag= ;;
 	nvcc*)	# Cuda Compiler Driver 2.2
-	  _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+	  _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
 	  _LT_TAGVAR(compiler_needs_object, $1)=yes
 	  ;;
 	esac
 	case `$CC -V 2>&1 | sed 5q` in
 	*Sun\ C*)			# Sun C 5.9
-	  _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+	  _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
 	  _LT_TAGVAR(compiler_needs_object, $1)=yes
 	  tmp_sharedflag='-G' ;;
 	*Sun\ F*)			# Sun Fortran 8.3
 	  tmp_sharedflag='-G' ;;
 	esac
-	_LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+	_LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
 
-        if test "x$supports_anon_versioning" = xyes; then
+        if test yes = "$supports_anon_versioning"; then
           _LT_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 '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib'
+            cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+            echo "local: *; };" >> $output_objdir/$libname.ver~
+            $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib'
         fi
 
 	case $cc_basename in
+	tcc*)
+	  _LT_TAGVAR(export_dynamic_flag_spec, $1)='-rdynamic'
+	  ;;
 	xlf* | bgf* | bgxlf* | mpixlf*)
 	  # IBM XL Fortran 10.1 on PPC cannot create shared libs itself
 	  _LT_TAGVAR(whole_archive_flag_spec, $1)='--whole-archive$convenience --no-whole-archive'
-	  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+	  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
 	  _LT_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib'
-	  if test "x$supports_anon_versioning" = xyes; then
+	  if test yes = "$supports_anon_versioning"; then
 	    _LT_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~
-	      $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib'
+              cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+              echo "local: *; };" >> $output_objdir/$libname.ver~
+              $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib'
 	  fi
 	  ;;
 	esac
@@ -4879,8 +5270,8 @@ _LT_EOF
 	_LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib'
 	wlarc=
       else
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
       fi
       ;;
 
@@ -4898,8 +5289,8 @@ _LT_EOF
 
 _LT_EOF
       elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
       else
 	_LT_TAGVAR(ld_shlibs, $1)=no
       fi
@@ -4911,7 +5302,7 @@ _LT_EOF
 	_LT_TAGVAR(ld_shlibs, $1)=no
 	cat <<_LT_EOF 1>&2
 
-*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not
+*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot
 *** reliably create shared libraries on SCO systems.  Therefore, libtool
 *** is disabling shared libraries support.  We urge you to upgrade GNU
 *** binutils to release 2.16.91.0.3 or newer.  Another option is to modify
@@ -4926,9 +5317,9 @@ _LT_EOF
 	  # DT_RUNPATH tag from executables and libraries.  But doing so
 	  # requires that you compile everything twice, which is a pain.
 	  if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
-	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-	    _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	    _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
+	    _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+	    _LT_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_TAGVAR(ld_shlibs, $1)=no
 	  fi
@@ -4945,15 +5336,15 @@ _LT_EOF
 
     *)
       if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
       else
 	_LT_TAGVAR(ld_shlibs, $1)=no
       fi
       ;;
     esac
 
-    if test "$_LT_TAGVAR(ld_shlibs, $1)" = no; then
+    if test no = "$_LT_TAGVAR(ld_shlibs, $1)"; then
       runpath_var=
       _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=
       _LT_TAGVAR(export_dynamic_flag_spec, $1)=
@@ -4969,7 +5360,7 @@ _LT_EOF
       # Note: this linker hardcodes the directories in LIBPATH if there
       # are no directories specified by -L.
       _LT_TAGVAR(hardcode_minus_L, $1)=yes
-      if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then
+      if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then
 	# Neither direct hardcoding nor static linking is supported with a
 	# broken collect2.
 	_LT_TAGVAR(hardcode_direct, $1)=unsupported
@@ -4977,34 +5368,57 @@ _LT_EOF
       ;;
 
     aix[[4-9]]*)
-      if test "$host_cpu" = ia64; then
+      if test ia64 = "$host_cpu"; 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=""
+	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
-	# Also, AIX nm treats weak defined symbols like other global
-	# defined symbols, whereas GNU nm marks them as "W".
+	# -C means demangle to GNU nm, but means don't demangle to AIX nm.
+	# Without the "-l" option, or with the "-B" option, AIX nm treats
+	# weak defined symbols like other global defined symbols, whereas
+	# GNU nm marks them as "W".
+	# While the 'weak' keyword is ignored in the Export File, we need
+	# it in the Import File for the 'aix-soname' feature, so we have
+	# to replace the "-B" option with "-P" for AIX nm.
 	if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then
-	  _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+	  _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols'
 	else
-	  _LT_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'
+	  _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | 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.
+	# have runtime linking enabled, and use it for executables.
+	# For shared libraries, we enable/disable runtime linking
+	# depending on the kind of the shared library created -
+	# when "with_aix_soname,aix_use_runtimelinking" is:
+	# "aix,no"   lib.a(lib.so.V) shared, rtl:no,  for executables
+	# "aix,yes"  lib.so          shared, rtl:yes, for executables
+	#            lib.a           static archive
+	# "both,no"  lib.so.V(shr.o) shared, rtl:yes
+	#            lib.a(lib.so.V) shared, rtl:no,  for executables
+	# "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables
+	#            lib.a(lib.so.V) shared, rtl:no
+	# "svr4,*"   lib.so.V(shr.o) shared, rtl:yes, for executables
+	#            lib.a           static archive
 	case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*)
 	  for ld_flag in $LDFLAGS; do
-	  if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then
+	  if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then
 	    aix_use_runtimelinking=yes
 	    break
 	  fi
 	  done
+	  if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then
+	    # With aix-soname=svr4, we create the lib.so.V shared archives only,
+	    # so we don't have lib.a shared libs to link our executables.
+	    # We have to force runtime linking in this case.
+	    aix_use_runtimelinking=yes
+	    LDFLAGS="$LDFLAGS -Wl,-brtl"
+	  fi
 	  ;;
 	esac
 
@@ -5023,13 +5437,21 @@ _LT_EOF
       _LT_TAGVAR(hardcode_direct_absolute, $1)=yes
       _LT_TAGVAR(hardcode_libdir_separator, $1)=':'
       _LT_TAGVAR(link_all_deplibs, $1)=yes
-      _LT_TAGVAR(file_list_spec, $1)='${wl}-f,'
+      _LT_TAGVAR(file_list_spec, $1)='$wl-f,'
+      case $with_aix_soname,$aix_use_runtimelinking in
+      aix,*) ;; # traditional, no import file
+      svr4,* | *,yes) # use import file
+	# The Import File defines what to hardcode.
+	_LT_TAGVAR(hardcode_direct, $1)=no
+	_LT_TAGVAR(hardcode_direct_absolute, $1)=no
+	;;
+      esac
 
-      if test "$GCC" = yes; then
+      if test yes = "$GCC"; 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`
+	  collect2name=`$CC -print-prog-name=collect2`
 	  if test -f "$collect2name" &&
 	   strings "$collect2name" | $GREP resolve_lib_name >/dev/null
 	  then
@@ -5048,61 +5470,80 @@ _LT_EOF
 	  ;;
 	esac
 	shared_flag='-shared'
-	if test "$aix_use_runtimelinking" = yes; then
-	  shared_flag="$shared_flag "'${wl}-G'
+	if test yes = "$aix_use_runtimelinking"; then
+	  shared_flag="$shared_flag "'$wl-G'
 	fi
+	# Need to ensure runtime linking is disabled for the traditional
+	# shared library, or the linker may eventually find shared libraries
+	# /with/ Import File - we do not want to mix them.
+	shared_flag_aix='-shared'
+	shared_flag_svr4='-shared $wl-G'
       else
 	# not using gcc
-	if test "$host_cpu" = ia64; then
+	if test ia64 = "$host_cpu"; 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'
+	  if test yes = "$aix_use_runtimelinking"; then
+	    shared_flag='$wl-G'
 	  else
-	    shared_flag='${wl}-bM:SRE'
+	    shared_flag='$wl-bM:SRE'
 	  fi
+	  shared_flag_aix='$wl-bM:SRE'
+	  shared_flag_svr4='$wl-G'
 	fi
       fi
 
-      _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-bexpall'
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall'
       # It seems that -bexpall does not export symbols beginning with
       # underscore (_), so it is better to generate a list of symbols to export.
       _LT_TAGVAR(always_export_symbols, $1)=yes
-      if test "$aix_use_runtimelinking" = yes; then
+      if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then
 	# Warning - without using the other runtime loading flags (-brtl),
 	# -berok will link without error, but may produce a broken library.
 	_LT_TAGVAR(allow_undefined_flag, $1)='-berok'
         # Determine the default libpath from the value encoded in an
         # empty executable.
         _LT_SYS_MODULE_PATH_AIX([$1])
-        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
-        _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag"
+        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath"
+        _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag
       else
-	if test "$host_cpu" = ia64; then
-	  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib'
+	if test ia64 = "$host_cpu"; then
+	  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib'
 	  _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs"
-	  _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols"
+	  _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols"
 	else
 	 # Determine the default libpath from the value encoded in an
 	 # empty executable.
 	 _LT_SYS_MODULE_PATH_AIX([$1])
-	 _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
+	 _LT_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_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok'
-	  _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok'
-	  if test "$with_gnu_ld" = yes; then
+	  _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok'
+	  _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok'
+	  if test yes = "$with_gnu_ld"; then
 	    # We only use this code for GNU lds that support --whole-archive.
-	    _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
+	    _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive'
 	  else
 	    # Exported symbols can be pulled into shared objects from archives
 	    _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience'
 	  fi
 	  _LT_TAGVAR(archive_cmds_need_lc, $1)=yes
-	  # This is similar to how AIX traditionally builds its shared libraries.
-	  _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
+	  _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d'
+	  # -brtl affects multiple linker settings, -berok does not and is overridden later
+	  compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`'
+	  if test svr4 != "$with_aix_soname"; then
+	    # This is similar to how AIX traditionally builds its shared libraries.
+	    _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname'
+	  fi
+	  if test aix != "$with_aix_soname"; then
+	    _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp'
+	  else
+	    # used by -dlpreopen to get the symbols
+	    _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV  $output_objdir/$realname.d/$soname $output_objdir'
+	  fi
+	  _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d'
 	fi
       fi
       ;;
@@ -5111,7 +5552,7 @@ _LT_EOF
       case $host_cpu in
       powerpc)
             # see comment about AmigaOS4 .so support
-            _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+            _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
             _LT_TAGVAR(archive_expsym_cmds, $1)=''
         ;;
       m68k)
@@ -5141,16 +5582,17 @@ _LT_EOF
 	# Tell ltmain to make .lib files, not .a files.
 	libext=lib
 	# Tell ltmain to make .dll files, not .so files.
-	shrext_cmds=".dll"
+	shrext_cmds=.dll
 	# FIXME: Setting linknames here is a bad hack.
-	_LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames='
-	_LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
-	    sed -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp;
-	  else
-	    sed -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp;
-	  fi~
-	  $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
-	  linknames='
+	_LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames='
+	_LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then
+            cp "$export_symbols" "$output_objdir/$soname.def";
+            echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp";
+          else
+            $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp;
+          fi~
+          $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
+          linknames='
 	# The linker will not automatically build a static lib if we build a DLL.
 	# _LT_TAGVAR(old_archive_from_new_cmds, $1)='true'
 	_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
@@ -5159,18 +5601,18 @@ _LT_EOF
 	# Don't use ranlib
 	_LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib'
 	_LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~
-	  lt_tool_outputfile="@TOOL_OUTPUT@"~
-	  case $lt_outputfile in
-	    *.exe|*.EXE) ;;
-	    *)
-	      lt_outputfile="$lt_outputfile.exe"
-	      lt_tool_outputfile="$lt_tool_outputfile.exe"
-	      ;;
-	  esac~
-	  if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then
-	    $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
-	    $RM "$lt_outputfile.manifest";
-	  fi'
+          lt_tool_outputfile="@TOOL_OUTPUT@"~
+          case $lt_outputfile in
+            *.exe|*.EXE) ;;
+            *)
+              lt_outputfile=$lt_outputfile.exe
+              lt_tool_outputfile=$lt_tool_outputfile.exe
+              ;;
+          esac~
+          if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then
+            $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
+            $RM "$lt_outputfile.manifest";
+          fi'
 	;;
       *)
 	# Assume MSVC wrapper
@@ -5179,7 +5621,7 @@ _LT_EOF
 	# Tell ltmain to make .lib files, not .a files.
 	libext=lib
 	# Tell ltmain to make .dll files, not .so files.
-	shrext_cmds=".dll"
+	shrext_cmds=.dll
 	# FIXME: Setting linknames here is a bad hack.
 	_LT_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames='
 	# The linker will automatically build a .lib file if we build a DLL.
@@ -5229,33 +5671,33 @@ _LT_EOF
       ;;
 
     hpux9*)
-      if test "$GCC" = yes; then
-	_LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared $pic_flag ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+      if test yes = "$GCC"; then
+	_LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
       else
-	_LT_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'
+	_LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
       fi
-      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir'
       _LT_TAGVAR(hardcode_libdir_separator, $1)=:
       _LT_TAGVAR(hardcode_direct, $1)=yes
 
       # hardcode_minus_L: Not really in the search PATH,
       # but as the default location of the library.
       _LT_TAGVAR(hardcode_minus_L, $1)=yes
-      _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
       ;;
 
     hpux10*)
-      if test "$GCC" = yes && test "$with_gnu_ld" = no; then
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+      if test yes,no = "$GCC,$with_gnu_ld"; then
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
       else
 	_LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'
       fi
-      if test "$with_gnu_ld" = no; then
-	_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+      if test no = "$with_gnu_ld"; then
+	_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir'
 	_LT_TAGVAR(hardcode_libdir_separator, $1)=:
 	_LT_TAGVAR(hardcode_direct, $1)=yes
 	_LT_TAGVAR(hardcode_direct_absolute, $1)=yes
-	_LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+	_LT_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_TAGVAR(hardcode_minus_L, $1)=yes
@@ -5263,25 +5705,25 @@ _LT_EOF
       ;;
 
     hpux11*)
-      if test "$GCC" = yes && test "$with_gnu_ld" = no; then
+      if test yes,no = "$GCC,$with_gnu_ld"; then
 	case $host_cpu in
 	hppa*64*)
-	  _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+	  _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
 	ia64*)
-	  _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+	  _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
 	*)
-	  _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+	  _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
 	esac
       else
 	case $host_cpu in
 	hppa*64*)
-	  _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+	  _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
 	ia64*)
-	  _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+	  _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
 	*)
 	m4_if($1, [], [
@@ -5289,14 +5731,14 @@ _LT_EOF
 	  # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does)
 	  _LT_LINKER_OPTION([if $CC understands -b],
 	    _LT_TAGVAR(lt_cv_prog_compiler__b, $1), [-b],
-	    [_LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'],
+	    [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'],
 	    [_LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'])],
-	  [_LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'])
+	  [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'])
 	  ;;
 	esac
       fi
-      if test "$with_gnu_ld" = no; then
-	_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+      if test no = "$with_gnu_ld"; then
+	_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir'
 	_LT_TAGVAR(hardcode_libdir_separator, $1)=:
 
 	case $host_cpu in
@@ -5307,7 +5749,7 @@ _LT_EOF
 	*)
 	  _LT_TAGVAR(hardcode_direct, $1)=yes
 	  _LT_TAGVAR(hardcode_direct_absolute, $1)=yes
-	  _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+	  _LT_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.
@@ -5318,16 +5760,16 @@ _LT_EOF
       ;;
 
     irix5* | irix6* | nonstopux*)
-      if test "$GCC" = yes; then
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+      if test yes = "$GCC"; then
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
 	# Try to use the -exported_symbol ld option, if it does not
 	# work, assume that -exports_file does not work either and
 	# implicitly export all symbols.
 	# This should be the same for all languages, so no per-tag cache variable.
 	AC_CACHE_CHECK([whether the $host_os linker accepts -exported_symbol],
 	  [lt_cv_irix_exported_symbol],
-	  [save_LDFLAGS="$LDFLAGS"
-	   LDFLAGS="$LDFLAGS -shared ${wl}-exported_symbol ${wl}foo ${wl}-update_registry ${wl}/dev/null"
+	  [save_LDFLAGS=$LDFLAGS
+	   LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null"
 	   AC_LINK_IFELSE(
 	     [AC_LANG_SOURCE(
 	        [AC_LANG_CASE([C], [[int foo (void) { return 0; }]],
@@ -5340,21 +5782,31 @@ _LT_EOF
       end]])])],
 	      [lt_cv_irix_exported_symbol=yes],
 	      [lt_cv_irix_exported_symbol=no])
-           LDFLAGS="$save_LDFLAGS"])
-	if test "$lt_cv_irix_exported_symbol" = yes; then
-          _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations ${wl}-exports_file ${wl}$export_symbols -o $lib'
+           LDFLAGS=$save_LDFLAGS])
+	if test yes = "$lt_cv_irix_exported_symbol"; then
+          _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib'
 	fi
       else
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
-	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -exports_file $export_symbols -o $lib'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
+	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib'
       fi
       _LT_TAGVAR(archive_cmds_need_lc, $1)='no'
-      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
       _LT_TAGVAR(hardcode_libdir_separator, $1)=:
       _LT_TAGVAR(inherit_rpath, $1)=yes
       _LT_TAGVAR(link_all_deplibs, $1)=yes
       ;;
 
+    linux*)
+      case $cc_basename in
+      tcc*)
+	# Fabrice Bellard et al's Tiny C Compiler
+	_LT_TAGVAR(ld_shlibs, $1)=yes
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+	;;
+      esac
+      ;;
+
     netbsd*)
       if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
 	_LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'  # a.out
@@ -5369,7 +5821,7 @@ _LT_EOF
     newsos6)
       _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
       _LT_TAGVAR(hardcode_direct, $1)=yes
-      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
       _LT_TAGVAR(hardcode_libdir_separator, $1)=:
       _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
       ;;
@@ -5377,27 +5829,19 @@ _LT_EOF
     *nto* | *qnx*)
       ;;
 
-    openbsd*)
+    openbsd* | bitrig*)
       if test -f /usr/libexec/ld.so; then
 	_LT_TAGVAR(hardcode_direct, $1)=yes
 	_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
 	_LT_TAGVAR(hardcode_direct_absolute, $1)=yes
-	if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+	if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then
 	  _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
-	  _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols'
-	  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-	  _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+	  _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols'
+	  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+	  _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
 	else
-	  case $host_os in
-	   openbsd[[01]].* | openbsd2.[[0-7]] | openbsd2.[[0-7]].*)
-	     _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'
-	     _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
-	     ;;
-	   *)
-	     _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
-	     _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-	     ;;
-	  esac
+	  _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+	  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
 	fi
       else
 	_LT_TAGVAR(ld_shlibs, $1)=no
@@ -5408,33 +5852,53 @@ _LT_EOF
       _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
       _LT_TAGVAR(hardcode_minus_L, $1)=yes
       _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
-      _LT_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_TAGVAR(old_archive_from_new_cmds, $1)='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def'
+      shrext_cmds=.dll
+      _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+	$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+	$ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+	$ECHO EXPORTS >> $output_objdir/$libname.def~
+	emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~
+	$CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+	emximp -o $lib $output_objdir/$libname.def'
+      _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+	$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+	$ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+	$ECHO EXPORTS >> $output_objdir/$libname.def~
+	prefix_cmds="$SED"~
+	if test EXPORTS = "`$SED 1q $export_symbols`"; then
+	  prefix_cmds="$prefix_cmds -e 1d";
+	fi~
+	prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~
+	cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~
+	$CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+	emximp -o $lib $output_objdir/$libname.def'
+      _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def'
+      _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
       ;;
 
     osf3*)
-      if test "$GCC" = yes; then
-	_LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+      if test yes = "$GCC"; then
+	_LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
       else
 	_LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
       fi
       _LT_TAGVAR(archive_cmds_need_lc, $1)='no'
-      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
       _LT_TAGVAR(hardcode_libdir_separator, $1)=:
       ;;
 
     osf4* | osf5*)	# as osf3* with the addition of -msym flag
-      if test "$GCC" = yes; then
-	_LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $pic_flag $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
-	_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+      if test yes = "$GCC"; then
+	_LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
+	_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
       else
 	_LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
 	_LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~
-	$CC -shared${allow_undefined_flag} ${wl}-input ${wl}$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib~$RM $lib.exp'
+          $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_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_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
@@ -5445,24 +5909,24 @@ _LT_EOF
 
     solaris*)
       _LT_TAGVAR(no_undefined_flag, $1)=' -z defs'
-      if test "$GCC" = yes; then
-	wlarc='${wl}'
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+      if test yes = "$GCC"; then
+	wlarc='$wl'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags'
 	_LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
-	  $CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+          $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
       else
 	case `$CC -V 2>&1` in
 	*"Compilers 5.0"*)
 	  wlarc=''
-	  _LT_TAGVAR(archive_cmds, $1)='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags'
+	  _LT_TAGVAR(archive_cmds, $1)='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags'
 	  _LT_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'
+            $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp'
 	  ;;
 	*)
-	  wlarc='${wl}'
-	  _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $compiler_flags'
+	  wlarc='$wl'
+	  _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags'
 	  _LT_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} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+            $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
 	  ;;
 	esac
       fi
@@ -5472,11 +5936,11 @@ _LT_EOF
       solaris2.[[0-5]] | solaris2.[[0-5]].*) ;;
       *)
 	# The compiler driver will combine and reorder linker options,
-	# but understands `-z linker_flag'.  GCC discards it without `$wl',
+	# but understands '-z linker_flag'.  GCC discards it without '$wl',
 	# but is careful enough not to reorder.
 	# Supported since Solaris 2.6 (maybe 2.5.1?)
-	if test "$GCC" = yes; then
-	  _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract'
+	if test yes = "$GCC"; then
+	  _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract'
 	else
 	  _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract'
 	fi
@@ -5486,10 +5950,10 @@ _LT_EOF
       ;;
 
     sunos4*)
-      if test "x$host_vendor" = xsequent; then
+      if test sequent = "$host_vendor"; then
 	# Use $CC to link under sequent, because it throws in some extra .o
 	# files that make .init and .fini sections work.
-	_LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags'
       else
 	_LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags'
       fi
@@ -5538,43 +6002,43 @@ _LT_EOF
       ;;
 
     sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*)
-      _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
+      _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text'
       _LT_TAGVAR(archive_cmds_need_lc, $1)=no
       _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
       runpath_var='LD_RUN_PATH'
 
-      if test "$GCC" = yes; then
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      if test yes = "$GCC"; then
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
       else
-	_LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
       fi
       ;;
 
     sysv5* | sco3.2v5* | sco5v6*)
-      # Note: We can NOT use -z defs as we might desire, because we do not
+      # Note: We CANNOT use -z defs as we might desire, because we do not
       # link with -lc, and that would cause any symbols used from libc to
       # always be unresolved, which means just about no library would
       # ever link correctly.  If we're not using GNU ld we use -z text
       # though, which does catch some bad symbols but isn't as heavy-handed
       # as -z defs.
-      _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
-      _LT_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs'
+      _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text'
+      _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs'
       _LT_TAGVAR(archive_cmds_need_lc, $1)=no
       _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
-      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R,$libdir'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir'
       _LT_TAGVAR(hardcode_libdir_separator, $1)=':'
       _LT_TAGVAR(link_all_deplibs, $1)=yes
-      _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport'
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport'
       runpath_var='LD_RUN_PATH'
 
-      if test "$GCC" = yes; then
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      if test yes = "$GCC"; then
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
       else
-	_LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	_LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
       fi
       ;;
 
@@ -5589,17 +6053,17 @@ _LT_EOF
       ;;
     esac
 
-    if test x$host_vendor = xsni; then
+    if test sni = "$host_vendor"; then
       case $host in
       sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*)
-	_LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Blargedynsym'
+	_LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Blargedynsym'
 	;;
       esac
     fi
   fi
 ])
 AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)])
-test "$_LT_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no
+test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no
 
 _LT_TAGVAR(with_gnu_ld, $1)=$with_gnu_ld
 
@@ -5616,7 +6080,7 @@ x|xyes)
   # Assume -lc should be added
   _LT_TAGVAR(archive_cmds_need_lc, $1)=yes
 
-  if test "$enable_shared" = yes && test "$GCC" = yes; then
+  if test yes,yes = "$GCC,$enable_shared"; then
     case $_LT_TAGVAR(archive_cmds, $1) in
     *'~'*)
       # FIXME: we may have to deal with multi-command sequences.
@@ -5696,12 +6160,12 @@ _LT_TAGDECL([], [hardcode_libdir_flag_spec], [1],
 _LT_TAGDECL([], [hardcode_libdir_separator], [1],
     [Whether we need a single "-rpath" flag with a separated argument])
 _LT_TAGDECL([], [hardcode_direct], [0],
-    [Set to "yes" if using DIR/libNAME${shared_ext} during linking hardcodes
+    [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes
     DIR into the resulting binary])
 _LT_TAGDECL([], [hardcode_direct_absolute], [0],
-    [Set to "yes" if using DIR/libNAME${shared_ext} during linking hardcodes
+    [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes
     DIR into the resulting binary and the resulting library dependency is
-    "absolute", i.e impossible to change by setting ${shlibpath_var} if the
+    "absolute", i.e impossible to change by setting $shlibpath_var if the
     library is relocated])
 _LT_TAGDECL([], [hardcode_minus_L], [0],
     [Set to "yes" if using the -LDIR flag during linking hardcodes DIR
@@ -5742,10 +6206,10 @@ dnl    [Compiler flag to generate thread safe objects])
 # ------------------------
 # Ensure that the configuration variables for a C compiler are suitably
 # defined.  These variables are subsequently used by _LT_CONFIG to write
-# the compiler configuration to `libtool'.
+# the compiler configuration to 'libtool'.
 m4_defun([_LT_LANG_C_CONFIG],
 [m4_require([_LT_DECL_EGREP])dnl
-lt_save_CC="$CC"
+lt_save_CC=$CC
 AC_LANG_PUSH(C)
 
 # Source file extension for C test sources.
@@ -5785,18 +6249,18 @@ if test -n "$compiler"; then
   LT_SYS_DLOPEN_SELF
   _LT_CMD_STRIPLIB
 
-  # Report which library types will actually be built
+  # Report what library types will 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
+  test no = "$can_build_shared" && 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
+    test yes = "$enable_shared" && enable_static=no
     if test -n "$RANLIB"; then
       archive_cmds="$archive_cmds~\$RANLIB \$lib"
       postinstall_cmds='$RANLIB $lib'
@@ -5804,8 +6268,12 @@ if test -n "$compiler"; then
     ;;
 
   aix[[4-9]]*)
-    if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
-      test "$enable_shared" = yes && enable_static=no
+    if test ia64 != "$host_cpu"; then
+      case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in
+      yes,aix,yes) ;;			# shared object as lib.so file only
+      yes,svr4,*) ;;			# shared object as lib.so archive member only
+      yes,*) enable_static=no ;;	# shared object in lib.a archive as well
+      esac
     fi
     ;;
   esac
@@ -5813,13 +6281,13 @@ if test -n "$compiler"; then
 
   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
+  test yes = "$enable_shared" || enable_static=yes
   AC_MSG_RESULT([$enable_static])
 
   _LT_CONFIG($1)
 fi
 AC_LANG_POP
-CC="$lt_save_CC"
+CC=$lt_save_CC
 ])# _LT_LANG_C_CONFIG
 
 
@@ -5827,14 +6295,14 @@ CC="$lt_save_CC"
 # --------------------------
 # Ensure that the configuration variables for a C++ compiler are suitably
 # defined.  These variables are subsequently used by _LT_CONFIG to write
-# the compiler configuration to `libtool'.
+# the compiler configuration to 'libtool'.
 m4_defun([_LT_LANG_CXX_CONFIG],
 [m4_require([_LT_FILEUTILS_DEFAULTS])dnl
 m4_require([_LT_DECL_EGREP])dnl
 m4_require([_LT_PATH_MANIFEST_TOOL])dnl
-if test -n "$CXX" && ( test "X$CXX" != "Xno" &&
-    ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) ||
-    (test "X$CXX" != "Xg++"))) ; then
+if test -n "$CXX" && ( test no != "$CXX" &&
+    ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) ||
+    (test g++ != "$CXX"))); then
   AC_PROG_CXXCPP
 else
   _lt_caught_CXX_error=yes
@@ -5876,7 +6344,7 @@ _LT_TAGVAR(objext, $1)=$objext
 # the CXX compiler isn't working.  Some variables (like enable_shared)
 # are currently assumed to apply to all compilers on this platform,
 # and will be corrupted by setting them based on a non-working compiler.
-if test "$_lt_caught_CXX_error" != yes; then
+if test yes != "$_lt_caught_CXX_error"; then
   # Code to be used in simple compile tests
   lt_simple_compile_test_code="int some_variable = 0;"
 
@@ -5918,35 +6386,35 @@ if test "$_lt_caught_CXX_error" != yes; then
   if test -n "$compiler"; then
     # We don't want -fno-exception when compiling C++ code, so set the
     # no_builtin_flag separately
-    if test "$GXX" = yes; then
+    if test yes = "$GXX"; then
       _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin'
     else
       _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=
     fi
 
-    if test "$GXX" = yes; then
+    if test yes = "$GXX"; then
       # Set up default GNU C++ configuration
 
       LT_PATH_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_TAGVAR(archive_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
-        _LT_TAGVAR(archive_expsym_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+      if test yes = "$with_gnu_ld"; then
+        _LT_TAGVAR(archive_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+        _LT_TAGVAR(archive_expsym_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
 
-        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-        _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
+        _LT_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}'
+        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_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+          _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive'
         else
           _LT_TAGVAR(whole_archive_flag_spec, $1)=
         fi
@@ -5982,18 +6450,30 @@ if test "$_lt_caught_CXX_error" != yes; then
         _LT_TAGVAR(ld_shlibs, $1)=no
         ;;
       aix[[4-9]]*)
-        if test "$host_cpu" = ia64; then
+        if test ia64 = "$host_cpu"; 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=""
+          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.
+          # have runtime linking enabled, and use it for executables.
+          # For shared libraries, we enable/disable runtime linking
+          # depending on the kind of the shared library created -
+          # when "with_aix_soname,aix_use_runtimelinking" is:
+          # "aix,no"   lib.a(lib.so.V) shared, rtl:no,  for executables
+          # "aix,yes"  lib.so          shared, rtl:yes, for executables
+          #            lib.a           static archive
+          # "both,no"  lib.so.V(shr.o) shared, rtl:yes
+          #            lib.a(lib.so.V) shared, rtl:no,  for executables
+          # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables
+          #            lib.a(lib.so.V) shared, rtl:no
+          # "svr4,*"   lib.so.V(shr.o) shared, rtl:yes, for executables
+          #            lib.a           static archive
           case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*)
 	    for ld_flag in $LDFLAGS; do
 	      case $ld_flag in
@@ -6003,6 +6483,13 @@ if test "$_lt_caught_CXX_error" != yes; then
 	        ;;
 	      esac
 	    done
+	    if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then
+	      # With aix-soname=svr4, we create the lib.so.V shared archives only,
+	      # so we don't have lib.a shared libs to link our executables.
+	      # We have to force runtime linking in this case.
+	      aix_use_runtimelinking=yes
+	      LDFLAGS="$LDFLAGS -Wl,-brtl"
+	    fi
 	    ;;
           esac
 
@@ -6021,13 +6508,21 @@ if test "$_lt_caught_CXX_error" != yes; then
         _LT_TAGVAR(hardcode_direct_absolute, $1)=yes
         _LT_TAGVAR(hardcode_libdir_separator, $1)=':'
         _LT_TAGVAR(link_all_deplibs, $1)=yes
-        _LT_TAGVAR(file_list_spec, $1)='${wl}-f,'
+        _LT_TAGVAR(file_list_spec, $1)='$wl-f,'
+        case $with_aix_soname,$aix_use_runtimelinking in
+        aix,*) ;;	# no import file
+        svr4,* | *,yes) # use import file
+          # The Import File defines what to hardcode.
+          _LT_TAGVAR(hardcode_direct, $1)=no
+          _LT_TAGVAR(hardcode_direct_absolute, $1)=no
+          ;;
+        esac
 
-        if test "$GXX" = yes; then
+        if test yes = "$GXX"; 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`
+	  collect2name=`$CC -print-prog-name=collect2`
 	  if test -f "$collect2name" &&
 	     strings "$collect2name" | $GREP resolve_lib_name >/dev/null
 	  then
@@ -6045,64 +6540,84 @@ if test "$_lt_caught_CXX_error" != yes; then
 	  fi
           esac
           shared_flag='-shared'
-	  if test "$aix_use_runtimelinking" = yes; then
-	    shared_flag="$shared_flag "'${wl}-G'
+	  if test yes = "$aix_use_runtimelinking"; then
+	    shared_flag=$shared_flag' $wl-G'
 	  fi
+	  # Need to ensure runtime linking is disabled for the traditional
+	  # shared library, or the linker may eventually find shared libraries
+	  # /with/ Import File - we do not want to mix them.
+	  shared_flag_aix='-shared'
+	  shared_flag_svr4='-shared $wl-G'
         else
           # not using gcc
-          if test "$host_cpu" = ia64; then
+          if test ia64 = "$host_cpu"; 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'
+	    if test yes = "$aix_use_runtimelinking"; then
+	      shared_flag='$wl-G'
 	    else
-	      shared_flag='${wl}-bM:SRE'
+	      shared_flag='$wl-bM:SRE'
 	    fi
+	    shared_flag_aix='$wl-bM:SRE'
+	    shared_flag_svr4='$wl-G'
           fi
         fi
 
-        _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-bexpall'
+        _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall'
         # It seems that -bexpall does not export symbols beginning with
         # underscore (_), so it is better to generate a list of symbols to
 	# export.
         _LT_TAGVAR(always_export_symbols, $1)=yes
-        if test "$aix_use_runtimelinking" = yes; then
+	if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then
           # Warning - without using the other runtime loading flags (-brtl),
           # -berok will link without error, but may produce a broken library.
-          _LT_TAGVAR(allow_undefined_flag, $1)='-berok'
+          # The "-G" linker flag allows undefined symbols.
+          _LT_TAGVAR(no_undefined_flag, $1)='-bernotok'
           # Determine the default libpath from the value encoded in an empty
           # executable.
           _LT_SYS_MODULE_PATH_AIX([$1])
-          _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
+          _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath"
 
-          _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag"
+          _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag
         else
-          if test "$host_cpu" = ia64; then
-	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib'
+          if test ia64 = "$host_cpu"; then
+	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib'
 	    _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs"
-	    _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols"
+	    _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols"
           else
 	    # Determine the default libpath from the value encoded in an
 	    # empty executable.
 	    _LT_SYS_MODULE_PATH_AIX([$1])
-	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
+	    _LT_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_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok'
-	    _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok'
-	    if test "$with_gnu_ld" = yes; then
+	    _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok'
+	    _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok'
+	    if test yes = "$with_gnu_ld"; then
 	      # We only use this code for GNU lds that support --whole-archive.
-	      _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
+	      _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive'
 	    else
 	      # Exported symbols can be pulled into shared objects from archives
 	      _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience'
 	    fi
 	    _LT_TAGVAR(archive_cmds_need_lc, $1)=yes
-	    # This is similar to how AIX traditionally builds its shared
-	    # libraries.
-	    _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
+	    _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d'
+	    # -brtl affects multiple linker settings, -berok does not and is overridden later
+	    compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`'
+	    if test svr4 != "$with_aix_soname"; then
+	      # This is similar to how AIX traditionally builds its shared
+	      # libraries. Need -bnortl late, we may have -brtl in LDFLAGS.
+	      _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname'
+	    fi
+	    if test aix != "$with_aix_soname"; then
+	      _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp'
+	    else
+	      # used by -dlpreopen to get the symbols
+	      _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV  $output_objdir/$realname.d/$soname $output_objdir'
+	    fi
+	    _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d'
           fi
         fi
         ;;
@@ -6112,7 +6627,7 @@ if test "$_lt_caught_CXX_error" != yes; then
 	  _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
 	  # Joseph Beckenbach <jrb3 at best.com> says some releases of gcc
 	  # support --undefined.  This deserves some investigation.  FIXME
-	  _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+	  _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
 	else
 	  _LT_TAGVAR(ld_shlibs, $1)=no
 	fi
@@ -6140,57 +6655,58 @@ if test "$_lt_caught_CXX_error" != yes; then
 	  # Tell ltmain to make .lib files, not .a files.
 	  libext=lib
 	  # Tell ltmain to make .dll files, not .so files.
-	  shrext_cmds=".dll"
+	  shrext_cmds=.dll
 	  # FIXME: Setting linknames here is a bad hack.
-	  _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames='
-	  _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
-	      $SED -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp;
-	    else
-	      $SED -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp;
-	    fi~
-	    $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
-	    linknames='
+	  _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames='
+	  _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then
+              cp "$export_symbols" "$output_objdir/$soname.def";
+              echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp";
+            else
+              $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp;
+            fi~
+            $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
+            linknames='
 	  # The linker will not automatically build a static lib if we build a DLL.
 	  # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true'
 	  _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
 	  # Don't use ranlib
 	  _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib'
 	  _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~
-	    lt_tool_outputfile="@TOOL_OUTPUT@"~
-	    case $lt_outputfile in
-	      *.exe|*.EXE) ;;
-	      *)
-		lt_outputfile="$lt_outputfile.exe"
-		lt_tool_outputfile="$lt_tool_outputfile.exe"
-		;;
-	    esac~
-	    func_to_tool_file "$lt_outputfile"~
-	    if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then
-	      $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
-	      $RM "$lt_outputfile.manifest";
-	    fi'
+            lt_tool_outputfile="@TOOL_OUTPUT@"~
+            case $lt_outputfile in
+              *.exe|*.EXE) ;;
+              *)
+                lt_outputfile=$lt_outputfile.exe
+                lt_tool_outputfile=$lt_tool_outputfile.exe
+                ;;
+            esac~
+            func_to_tool_file "$lt_outputfile"~
+            if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then
+              $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
+              $RM "$lt_outputfile.manifest";
+            fi'
 	  ;;
 	*)
 	  # g++
 	  # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless,
 	  # as there is no search path for DLLs.
 	  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-	  _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-all-symbols'
+	  _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols'
 	  _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
 	  _LT_TAGVAR(always_export_symbols, $1)=no
 	  _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
 
 	  if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then
-	    _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
-	    # If the export-symbols file already is a .def file (1st line
-	    # is EXPORTS), use it as is; otherwise, prepend...
-	    _LT_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}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+	    _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+	    # If the export-symbols file already is a .def file, use it as
+	    # is; otherwise, prepend EXPORTS...
+	    _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); 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--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
 	  else
 	    _LT_TAGVAR(ld_shlibs, $1)=no
 	  fi
@@ -6201,6 +6717,34 @@ if test "$_lt_caught_CXX_error" != yes; then
         _LT_DARWIN_LINKER_FEATURES($1)
 	;;
 
+      os2*)
+	_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+	_LT_TAGVAR(hardcode_minus_L, $1)=yes
+	_LT_TAGVAR(allow_undefined_flag, $1)=unsupported
+	shrext_cmds=.dll
+	_LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+	  $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+	  $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+	  $ECHO EXPORTS >> $output_objdir/$libname.def~
+	  emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~
+	  $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+	  emximp -o $lib $output_objdir/$libname.def'
+	_LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+	  $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+	  $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+	  $ECHO EXPORTS >> $output_objdir/$libname.def~
+	  prefix_cmds="$SED"~
+	  if test EXPORTS = "`$SED 1q $export_symbols`"; then
+	    prefix_cmds="$prefix_cmds -e 1d";
+	  fi~
+	  prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~
+	  cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~
+	  $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+	  emximp -o $lib $output_objdir/$libname.def'
+	_LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def'
+	_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
+	;;
+
       dgux*)
         case $cc_basename in
           ec++*)
@@ -6235,18 +6779,15 @@ if test "$_lt_caught_CXX_error" != yes; then
         _LT_TAGVAR(ld_shlibs, $1)=yes
         ;;
 
-      gnu*)
-        ;;
-
       haiku*)
-        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
         _LT_TAGVAR(link_all_deplibs, $1)=yes
         ;;
 
       hpux9*)
-        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir'
         _LT_TAGVAR(hardcode_libdir_separator, $1)=:
-        _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+        _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
         _LT_TAGVAR(hardcode_direct, $1)=yes
         _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH,
 				             # but as the default
@@ -6258,7 +6799,7 @@ if test "$_lt_caught_CXX_error" != yes; then
             _LT_TAGVAR(ld_shlibs, $1)=no
             ;;
           aCC*)
-            _LT_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'
+            _LT_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 "x$output_objdir/$soname" = "x$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.
@@ -6267,11 +6808,11 @@ if test "$_lt_caught_CXX_error" != yes; then
             # 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) | $EGREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
+            output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
             ;;
           *)
-            if test "$GXX" = yes; then
-              _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag ${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'
+            if test yes = "$GXX"; then
+              _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
             else
               # FIXME: insert proper C++ library support
               _LT_TAGVAR(ld_shlibs, $1)=no
@@ -6281,15 +6822,15 @@ if test "$_lt_caught_CXX_error" != yes; then
         ;;
 
       hpux10*|hpux11*)
-        if test $with_gnu_ld = no; then
-	  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+        if test no = "$with_gnu_ld"; then
+	  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir'
 	  _LT_TAGVAR(hardcode_libdir_separator, $1)=:
 
           case $host_cpu in
             hppa*64*|ia64*)
               ;;
             *)
-	      _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+	      _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
               ;;
           esac
         fi
@@ -6315,13 +6856,13 @@ if test "$_lt_caught_CXX_error" != yes; then
           aCC*)
 	    case $host_cpu in
 	      hppa*64*)
-	        _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+	        _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
 	        ;;
 	      ia64*)
-	        _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+	        _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
 	        ;;
 	      *)
-	        _LT_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'
+	        _LT_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
@@ -6332,20 +6873,20 @@ if test "$_lt_caught_CXX_error" != yes; then
 	    # 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; func_echo_all "$list"'
+	    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; func_echo_all "$list"'
 	    ;;
           *)
-	    if test "$GXX" = yes; then
-	      if test $with_gnu_ld = no; then
+	    if test yes = "$GXX"; then
+	      if test no = "$with_gnu_ld"; then
 	        case $host_cpu in
 	          hppa*64*)
-	            _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+	            _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
 	            ;;
 	          ia64*)
-	            _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+	            _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
 	            ;;
 	          *)
-	            _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+	            _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
 	            ;;
 	        esac
 	      fi
@@ -6360,22 +6901,22 @@ if test "$_lt_caught_CXX_error" != yes; then
       interix[[3-9]]*)
 	_LT_TAGVAR(hardcode_direct, $1)=no
 	_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
-	_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-	_LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+	_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+	_LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
 	# Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc.
 	# Instead, shared libraries are loaded at an image base (0x10000000 by
 	# default) and relocated if they conflict, which is a slow very memory
 	# consuming and fragmenting process.  To avoid this, we pick a random,
 	# 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link
 	# time.  Moving up from 0x10000000 also allows more sbrk(2) space.
-	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
-	_LT_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+	_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+	_LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
 	;;
       irix5* | irix6*)
         case $cc_basename in
           CC*)
 	    # SGI C++
-	    _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+	    _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-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
@@ -6384,22 +6925,22 @@ if test "$_lt_caught_CXX_error" != yes; then
 	    _LT_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_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+	    if test yes = "$GXX"; then
+	      if test no = "$with_gnu_ld"; then
+	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
 	      else
-	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` -o $lib'
+	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` -o $lib'
 	      fi
 	    fi
 	    _LT_TAGVAR(link_all_deplibs, $1)=yes
 	    ;;
         esac
-        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
         _LT_TAGVAR(hardcode_libdir_separator, $1)=:
         _LT_TAGVAR(inherit_rpath, $1)=yes
         ;;
 
-      linux* | k*bsd*-gnu | kopensolaris*-gnu)
+      linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
         case $cc_basename in
           KCC*)
 	    # Kuck and Associates, Inc. (KAI) C++ Compiler
@@ -6407,8 +6948,8 @@ if test "$_lt_caught_CXX_error" != yes; then
 	    # 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_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_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'
+	    _LT_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_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.
@@ -6417,10 +6958,10 @@ if test "$_lt_caught_CXX_error" != yes; then
 	    # 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; func_echo_all "$list"'
+	    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; func_echo_all "$list"'
 
-	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-	    _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+	    _LT_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.
@@ -6434,59 +6975,59 @@ if test "$_lt_caught_CXX_error" != yes; then
 	    # earlier do not add the objects themselves.
 	    case `$CC -V 2>&1` in
 	      *"Version 7."*)
-	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
-		_LT_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'
+	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+		_LT_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_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-		_LT_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'
+	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+		_LT_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_TAGVAR(archive_cmds_need_lc, $1)=no
-	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-	    _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
-	    _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
+	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+	    _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic'
+	    _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive'
 	    ;;
           pgCC* | pgcpp*)
             # Portland Group C++ compiler
 	    case `$CC -V` in
 	    *pgCC\ [[1-5]].* | *pgcpp\ [[1-5]].*)
 	      _LT_TAGVAR(prelink_cmds, $1)='tpldir=Template.dir~
-		rm -rf $tpldir~
-		$CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~
-		compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"'
+               rm -rf $tpldir~
+               $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~
+               compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"'
 	      _LT_TAGVAR(old_archive_cmds, $1)='tpldir=Template.dir~
-		rm -rf $tpldir~
-		$CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~
-		$AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~
-		$RANLIB $oldlib'
+                rm -rf $tpldir~
+                $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~
+                $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~
+                $RANLIB $oldlib'
 	      _LT_TAGVAR(archive_cmds, $1)='tpldir=Template.dir~
-		rm -rf $tpldir~
-		$CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
-		$CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib'
+                rm -rf $tpldir~
+                $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
+                $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
 	      _LT_TAGVAR(archive_expsym_cmds, $1)='tpldir=Template.dir~
-		rm -rf $tpldir~
-		$CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
-		$CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib'
+                rm -rf $tpldir~
+                $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
+                $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
 	      ;;
 	    *) # Version 6 and above use weak symbols
-	      _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib'
-	      _LT_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_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+	      _LT_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'
 	      ;;
 	    esac
 
-	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir'
-	    _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
-	    _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl--rpath $wl$libdir'
+	    _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic'
+	    _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
             ;;
 	  cxx*)
 	    # Compaq C++
-	    _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	    _LT_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'
+	    _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+	    _LT_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_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
@@ -6500,18 +7041,18 @@ if test "$_lt_caught_CXX_error" != yes; then
 	    # 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=`func_echo_all "$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; func_echo_all "X$list" | $Xsed'
+	    output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$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; func_echo_all "X$list" | $Xsed'
 	    ;;
 	  xl* | mpixl* | bgxl*)
 	    # IBM XL 8.0 on PPC, with GNU ld
-	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-	    _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
-	    _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	    if test "x$supports_anon_versioning" = xyes; then
+	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
+	    _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic'
+	    _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+	    if test yes = "$supports_anon_versioning"; then
 	      _LT_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 -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib'
+                cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+                echo "local: *; };" >> $output_objdir/$libname.ver~
+                $CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib'
 	    fi
 	    ;;
 	  *)
@@ -6519,10 +7060,10 @@ if test "$_lt_caught_CXX_error" != yes; then
 	    *Sun\ C*)
 	      # Sun C++ 5.9
 	      _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs'
-	      _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
-	      _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file ${wl}$export_symbols'
+	      _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+	      _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file $wl$export_symbols'
 	      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
-	      _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+	      _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
 	      _LT_TAGVAR(compiler_needs_object, $1)=yes
 
 	      # Not sure whether something based on
@@ -6580,22 +7121,17 @@ if test "$_lt_caught_CXX_error" != yes; then
         _LT_TAGVAR(ld_shlibs, $1)=yes
 	;;
 
-      openbsd2*)
-        # C++ shared libraries are fairly broken
-	_LT_TAGVAR(ld_shlibs, $1)=no
-	;;
-
-      openbsd*)
+      openbsd* | bitrig*)
 	if test -f /usr/libexec/ld.so; then
 	  _LT_TAGVAR(hardcode_direct, $1)=yes
 	  _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
 	  _LT_TAGVAR(hardcode_direct_absolute, $1)=yes
 	  _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib'
-	  _LT_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_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_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
-	    _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+	  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+	  if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`"; then
+	    _LT_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_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
+	    _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive'
 	  fi
 	  output_verbose_link_cmd=func_echo_all
 	else
@@ -6611,9 +7147,9 @@ if test "$_lt_caught_CXX_error" != yes; then
 	    # 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_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_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_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
+	    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
 	    _LT_TAGVAR(hardcode_libdir_separator, $1)=:
 
 	    # Archives containing C++ object files must be created using
@@ -6631,17 +7167,17 @@ if test "$_lt_caught_CXX_error" != yes; then
           cxx*)
 	    case $host in
 	      osf3*)
-	        _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
-	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && func_echo_all "${wl}-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
-	        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+	        _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*'
+	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $soname `test -n "$verstring" && func_echo_all "$wl-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
+	        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
 		;;
 	      *)
 	        _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
-	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
 	        _LT_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'
+                  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_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
 		;;
 	    esac
@@ -6656,21 +7192,21 @@ if test "$_lt_caught_CXX_error" != yes; then
 	    # 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=`func_echo_all "$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; func_echo_all "$list"'
+	    output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$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; func_echo_all "$list"'
 	    ;;
 	  *)
-	    if test "$GXX" = yes && test "$with_gnu_ld" = no; then
-	      _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
+	    if test yes,no = "$GXX,$with_gnu_ld"; then
+	      _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*'
 	      case $host in
 	        osf3*)
-	          _LT_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" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+	          _LT_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" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
 		  ;;
 	        *)
-	          _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+	          _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
 		  ;;
 	      esac
 
-	      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+	      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
 	      _LT_TAGVAR(hardcode_libdir_separator, $1)=:
 
 	      # Commands to make compiler produce verbose output that lists
@@ -6716,9 +7252,9 @@ if test "$_lt_caught_CXX_error" != yes; then
 	    # Sun C++ 4.2, 5.x and Centerline C++
             _LT_TAGVAR(archive_cmds_need_lc,$1)=yes
 	    _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs'
-	    _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag}  -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+	    _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
 	    _LT_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'
+              $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_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
 	    _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
@@ -6726,7 +7262,7 @@ if test "$_lt_caught_CXX_error" != yes; then
 	      solaris2.[[0-5]] | solaris2.[[0-5]].*) ;;
 	      *)
 		# The compiler driver will combine and reorder linker options,
-		# but understands `-z linker_flag'.
+		# but understands '-z linker_flag'.
 	        # Supported since Solaris 2.6 (maybe 2.5.1?)
 		_LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract'
 	        ;;
@@ -6743,30 +7279,30 @@ if test "$_lt_caught_CXX_error" != yes; then
 	    ;;
           gcx*)
 	    # Green Hills C++ Compiler
-	    _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+	    _LT_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_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_TAGVAR(no_undefined_flag, $1)=' ${wl}-z ${wl}defs'
+	    if test yes,no = "$GXX,$with_gnu_ld"; then
+	      _LT_TAGVAR(no_undefined_flag, $1)=' $wl-z ${wl}defs'
 	      if $CC --version | $GREP -v '^2\.7' > /dev/null; then
-	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+	        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib'
 	        _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
-		  $CC -shared $pic_flag -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
+                  $CC -shared $pic_flag -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -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 -v "^Configured with:" | $GREP "\-L"'
 	      else
-	        # g++ 2.7 appears to require `-G' NOT `-shared' on this
+	        # g++ 2.7 appears to require '-G' NOT '-shared' on this
 	        # platform.
-	        _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+	        _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib'
 	        _LT_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'
+                  $CC -G -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -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
@@ -6774,11 +7310,11 @@ if test "$_lt_caught_CXX_error" != yes; then
 	        output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
 	      fi
 
-	      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $wl$libdir'
+	      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $wl$libdir'
 	      case $host_os in
 		solaris2.[[0-5]] | solaris2.[[0-5]].*) ;;
 		*)
-		  _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract'
+		  _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract'
 		  ;;
 	      esac
 	    fi
@@ -6787,52 +7323,52 @@ if test "$_lt_caught_CXX_error" != yes; then
         ;;
 
     sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*)
-      _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
+      _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text'
       _LT_TAGVAR(archive_cmds_need_lc, $1)=no
       _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
       runpath_var='LD_RUN_PATH'
 
       case $cc_basename in
         CC*)
-	  _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	  _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	  _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	  _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
 	*)
-	  _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	  _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	  _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	  _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
 	  ;;
       esac
       ;;
 
       sysv5* | sco3.2v5* | sco5v6*)
-	# Note: We can NOT use -z defs as we might desire, because we do not
+	# Note: We CANNOT use -z defs as we might desire, because we do not
 	# link with -lc, and that would cause any symbols used from libc to
 	# always be unresolved, which means just about no library would
 	# ever link correctly.  If we're not using GNU ld we use -z text
 	# though, which does catch some bad symbols but isn't as heavy-handed
 	# as -z defs.
-	_LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
-	_LT_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs'
+	_LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text'
+	_LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs'
 	_LT_TAGVAR(archive_cmds_need_lc, $1)=no
 	_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
-	_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R,$libdir'
+	_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir'
 	_LT_TAGVAR(hardcode_libdir_separator, $1)=':'
 	_LT_TAGVAR(link_all_deplibs, $1)=yes
-	_LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport'
+	_LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport'
 	runpath_var='LD_RUN_PATH'
 
 	case $cc_basename in
           CC*)
-	    _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	    _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	    _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	    _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
 	    _LT_TAGVAR(old_archive_cmds, $1)='$CC -Tprelink_objects $oldobjs~
-	      '"$_LT_TAGVAR(old_archive_cmds, $1)"
+              '"$_LT_TAGVAR(old_archive_cmds, $1)"
 	    _LT_TAGVAR(reload_cmds, $1)='$CC -Tprelink_objects $reload_objs~
-	      '"$_LT_TAGVAR(reload_cmds, $1)"
+              '"$_LT_TAGVAR(reload_cmds, $1)"
 	    ;;
 	  *)
-	    _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
-	    _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	    _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+	    _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
 	    ;;
 	esac
       ;;
@@ -6863,10 +7399,10 @@ if test "$_lt_caught_CXX_error" != yes; then
     esac
 
     AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)])
-    test "$_LT_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no
+    test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no
 
-    _LT_TAGVAR(GCC, $1)="$GXX"
-    _LT_TAGVAR(LD, $1)="$LD"
+    _LT_TAGVAR(GCC, $1)=$GXX
+    _LT_TAGVAR(LD, $1)=$LD
 
     ## CAVEAT EMPTOR:
     ## There is no encapsulation within the following macros, do not change
@@ -6893,7 +7429,7 @@ if test "$_lt_caught_CXX_error" != yes; then
   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
-fi # test "$_lt_caught_CXX_error" != yes
+fi # test yes != "$_lt_caught_CXX_error"
 
 AC_LANG_POP
 ])# _LT_LANG_CXX_CONFIG
@@ -6915,13 +7451,14 @@ AC_REQUIRE([_LT_DECL_SED])
 AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])
 func_stripname_cnf ()
 {
-  case ${2} in
-  .*) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%\\\\${2}\$%%"`;;
-  *)  func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%${2}\$%%"`;;
+  case @S|@2 in
+  .*) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%\\\\@S|@2\$%%"`;;
+  *)  func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%@S|@2\$%%"`;;
   esac
 } # func_stripname_cnf
 ])# _LT_FUNC_STRIPNAME_CNF
 
+
 # _LT_SYS_HIDDEN_LIBDEPS([TAGNAME])
 # ---------------------------------
 # Figure out "hidden" library dependencies from verbose
@@ -7005,13 +7542,13 @@ if AC_TRY_EVAL(ac_compile); then
   pre_test_object_deps_done=no
 
   for p in `eval "$output_verbose_link_cmd"`; do
-    case ${prev}${p} in
+    case $prev$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
+       if test x-L = "$p" ||
+          test x-R = "$p"; then
 	 prev=$p
 	 continue
        fi
@@ -7027,16 +7564,16 @@ if AC_TRY_EVAL(ac_compile); then
        case $p in
        =*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;;
        esac
-       if test "$pre_test_object_deps_done" = no; then
-	 case ${prev} in
+       if test no = "$pre_test_object_deps_done"; then
+	 case $prev 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 "$_LT_TAGVAR(compiler_lib_search_path, $1)"; then
-	     _LT_TAGVAR(compiler_lib_search_path, $1)="${prev}${p}"
+	     _LT_TAGVAR(compiler_lib_search_path, $1)=$prev$p
 	   else
-	     _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} ${prev}${p}"
+	     _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} $prev$p"
 	   fi
 	   ;;
 	 # The "-l" case would never come before the object being
@@ -7044,9 +7581,9 @@ if AC_TRY_EVAL(ac_compile); then
 	 esac
        else
 	 if test -z "$_LT_TAGVAR(postdeps, $1)"; then
-	   _LT_TAGVAR(postdeps, $1)="${prev}${p}"
+	   _LT_TAGVAR(postdeps, $1)=$prev$p
 	 else
-	   _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} ${prev}${p}"
+	   _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} $prev$p"
 	 fi
        fi
        prev=
@@ -7061,15 +7598,15 @@ if AC_TRY_EVAL(ac_compile); then
 	 continue
        fi
 
-       if test "$pre_test_object_deps_done" = no; then
+       if test no = "$pre_test_object_deps_done"; then
 	 if test -z "$_LT_TAGVAR(predep_objects, $1)"; then
-	   _LT_TAGVAR(predep_objects, $1)="$p"
+	   _LT_TAGVAR(predep_objects, $1)=$p
 	 else
 	   _LT_TAGVAR(predep_objects, $1)="$_LT_TAGVAR(predep_objects, $1) $p"
 	 fi
        else
 	 if test -z "$_LT_TAGVAR(postdep_objects, $1)"; then
-	   _LT_TAGVAR(postdep_objects, $1)="$p"
+	   _LT_TAGVAR(postdep_objects, $1)=$p
 	 else
 	   _LT_TAGVAR(postdep_objects, $1)="$_LT_TAGVAR(postdep_objects, $1) $p"
 	 fi
@@ -7100,51 +7637,6 @@ interix[[3-9]]*)
   _LT_TAGVAR(postdep_objects,$1)=
   _LT_TAGVAR(postdeps,$1)=
   ;;
-
-linux*)
-  case `$CC -V 2>&1 | sed 5q` in
-  *Sun\ C*)
-    # Sun C++ 5.9
-
-    # The more standards-conforming stlport4 library is
-    # incompatible with the Cstd library. Avoid specifying
-    # it if it's in CXXFLAGS. Ignore libCrun as
-    # -library=stlport4 depends on it.
-    case " $CXX $CXXFLAGS " in
-    *" -library=stlport4 "*)
-      solaris_use_stlport4=yes
-      ;;
-    esac
-
-    if test "$solaris_use_stlport4" != yes; then
-      _LT_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun'
-    fi
-    ;;
-  esac
-  ;;
-
-solaris*)
-  case $cc_basename in
-  CC* | sunCC*)
-    # The more standards-conforming stlport4 library is
-    # incompatible with the Cstd library. Avoid specifying
-    # it if it's in CXXFLAGS. Ignore libCrun as
-    # -library=stlport4 depends on it.
-    case " $CXX $CXXFLAGS " in
-    *" -library=stlport4 "*)
-      solaris_use_stlport4=yes
-      ;;
-    esac
-
-    # 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.
-    if test "$solaris_use_stlport4" != yes; then
-      _LT_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun'
-    fi
-    ;;
-  esac
-  ;;
 esac
 ])
 
@@ -7153,7 +7645,7 @@ case " $_LT_TAGVAR(postdeps, $1) " in
 esac
  _LT_TAGVAR(compiler_lib_search_dirs, $1)=
 if test -n "${_LT_TAGVAR(compiler_lib_search_path, $1)}"; then
- _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | ${SED} -e 's! -L! !g' -e 's!^ !!'`
+ _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | $SED -e 's! -L! !g' -e 's!^ !!'`
 fi
 _LT_TAGDECL([], [compiler_lib_search_dirs], [1],
     [The directories searched by this compiler when creating a shared library])
@@ -7173,10 +7665,10 @@ _LT_TAGDECL([], [compiler_lib_search_path], [1],
 # --------------------------
 # Ensure that the configuration variables for a Fortran 77 compiler are
 # suitably defined.  These variables are subsequently used by _LT_CONFIG
-# to write the compiler configuration to `libtool'.
+# to write the compiler configuration to 'libtool'.
 m4_defun([_LT_LANG_F77_CONFIG],
 [AC_LANG_PUSH(Fortran 77)
-if test -z "$F77" || test "X$F77" = "Xno"; then
+if test -z "$F77" || test no = "$F77"; then
   _lt_disable_F77=yes
 fi
 
@@ -7213,7 +7705,7 @@ _LT_TAGVAR(objext, $1)=$objext
 # the F77 compiler isn't working.  Some variables (like enable_shared)
 # are currently assumed to apply to all compilers on this platform,
 # and will be corrupted by setting them based on a non-working compiler.
-if test "$_lt_disable_F77" != yes; then
+if test yes != "$_lt_disable_F77"; then
   # Code to be used in simple compile tests
   lt_simple_compile_test_code="\
       subroutine t
@@ -7235,7 +7727,7 @@ if test "$_lt_disable_F77" != yes; then
   _LT_LINKER_BOILERPLATE
 
   # Allow CC to be a program name with arguments.
-  lt_save_CC="$CC"
+  lt_save_CC=$CC
   lt_save_GCC=$GCC
   lt_save_CFLAGS=$CFLAGS
   CC=${F77-"f77"}
@@ -7249,21 +7741,25 @@ if test "$_lt_disable_F77" != yes; then
     AC_MSG_RESULT([$can_build_shared])
 
     AC_MSG_CHECKING([whether to build shared libraries])
-    test "$can_build_shared" = "no" && enable_shared=no
+    test no = "$can_build_shared" && 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
+        test yes = "$enable_shared" && enable_static=no
         if test -n "$RANLIB"; then
           archive_cmds="$archive_cmds~\$RANLIB \$lib"
           postinstall_cmds='$RANLIB $lib'
         fi
         ;;
       aix[[4-9]]*)
-	if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
-	  test "$enable_shared" = yes && enable_static=no
+	if test ia64 != "$host_cpu"; then
+	  case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in
+	  yes,aix,yes) ;;		# shared object as lib.so file only
+	  yes,svr4,*) ;;		# shared object as lib.so archive member only
+	  yes,*) enable_static=no ;;	# shared object in lib.a archive as well
+	  esac
 	fi
         ;;
     esac
@@ -7271,11 +7767,11 @@ if test "$_lt_disable_F77" != yes; then
 
     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
+    test yes = "$enable_shared" || enable_static=yes
     AC_MSG_RESULT([$enable_static])
 
-    _LT_TAGVAR(GCC, $1)="$G77"
-    _LT_TAGVAR(LD, $1)="$LD"
+    _LT_TAGVAR(GCC, $1)=$G77
+    _LT_TAGVAR(LD, $1)=$LD
 
     ## CAVEAT EMPTOR:
     ## There is no encapsulation within the following macros, do not change
@@ -7292,9 +7788,9 @@ if test "$_lt_disable_F77" != yes; then
   fi # test -n "$compiler"
 
   GCC=$lt_save_GCC
-  CC="$lt_save_CC"
-  CFLAGS="$lt_save_CFLAGS"
-fi # test "$_lt_disable_F77" != yes
+  CC=$lt_save_CC
+  CFLAGS=$lt_save_CFLAGS
+fi # test yes != "$_lt_disable_F77"
 
 AC_LANG_POP
 ])# _LT_LANG_F77_CONFIG
@@ -7304,11 +7800,11 @@ AC_LANG_POP
 # -------------------------
 # Ensure that the configuration variables for a Fortran compiler are
 # suitably defined.  These variables are subsequently used by _LT_CONFIG
-# to write the compiler configuration to `libtool'.
+# to write the compiler configuration to 'libtool'.
 m4_defun([_LT_LANG_FC_CONFIG],
 [AC_LANG_PUSH(Fortran)
 
-if test -z "$FC" || test "X$FC" = "Xno"; then
+if test -z "$FC" || test no = "$FC"; then
   _lt_disable_FC=yes
 fi
 
@@ -7345,7 +7841,7 @@ _LT_TAGVAR(objext, $1)=$objext
 # the FC compiler isn't working.  Some variables (like enable_shared)
 # are currently assumed to apply to all compilers on this platform,
 # and will be corrupted by setting them based on a non-working compiler.
-if test "$_lt_disable_FC" != yes; then
+if test yes != "$_lt_disable_FC"; then
   # Code to be used in simple compile tests
   lt_simple_compile_test_code="\
       subroutine t
@@ -7367,7 +7863,7 @@ if test "$_lt_disable_FC" != yes; then
   _LT_LINKER_BOILERPLATE
 
   # Allow CC to be a program name with arguments.
-  lt_save_CC="$CC"
+  lt_save_CC=$CC
   lt_save_GCC=$GCC
   lt_save_CFLAGS=$CFLAGS
   CC=${FC-"f95"}
@@ -7383,21 +7879,25 @@ if test "$_lt_disable_FC" != yes; then
     AC_MSG_RESULT([$can_build_shared])
 
     AC_MSG_CHECKING([whether to build shared libraries])
-    test "$can_build_shared" = "no" && enable_shared=no
+    test no = "$can_build_shared" && 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
+        test yes = "$enable_shared" && enable_static=no
         if test -n "$RANLIB"; then
           archive_cmds="$archive_cmds~\$RANLIB \$lib"
           postinstall_cmds='$RANLIB $lib'
         fi
         ;;
       aix[[4-9]]*)
-	if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
-	  test "$enable_shared" = yes && enable_static=no
+	if test ia64 != "$host_cpu"; then
+	  case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in
+	  yes,aix,yes) ;;		# shared object as lib.so file only
+	  yes,svr4,*) ;;		# shared object as lib.so archive member only
+	  yes,*) enable_static=no ;;	# shared object in lib.a archive as well
+	  esac
 	fi
         ;;
     esac
@@ -7405,11 +7905,11 @@ if test "$_lt_disable_FC" != yes; then
 
     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
+    test yes = "$enable_shared" || enable_static=yes
     AC_MSG_RESULT([$enable_static])
 
-    _LT_TAGVAR(GCC, $1)="$ac_cv_fc_compiler_gnu"
-    _LT_TAGVAR(LD, $1)="$LD"
+    _LT_TAGVAR(GCC, $1)=$ac_cv_fc_compiler_gnu
+    _LT_TAGVAR(LD, $1)=$LD
 
     ## CAVEAT EMPTOR:
     ## There is no encapsulation within the following macros, do not change
@@ -7429,7 +7929,7 @@ if test "$_lt_disable_FC" != yes; then
   GCC=$lt_save_GCC
   CC=$lt_save_CC
   CFLAGS=$lt_save_CFLAGS
-fi # test "$_lt_disable_FC" != yes
+fi # test yes != "$_lt_disable_FC"
 
 AC_LANG_POP
 ])# _LT_LANG_FC_CONFIG
@@ -7439,7 +7939,7 @@ AC_LANG_POP
 # --------------------------
 # Ensure that the configuration variables for the GNU Java Compiler compiler
 # are suitably defined.  These variables are subsequently used by _LT_CONFIG
-# to write the compiler configuration to `libtool'.
+# to write the compiler configuration to 'libtool'.
 m4_defun([_LT_LANG_GCJ_CONFIG],
 [AC_REQUIRE([LT_PROG_GCJ])dnl
 AC_LANG_SAVE
@@ -7473,7 +7973,7 @@ CC=${GCJ-"gcj"}
 CFLAGS=$GCJFLAGS
 compiler=$CC
 _LT_TAGVAR(compiler, $1)=$CC
-_LT_TAGVAR(LD, $1)="$LD"
+_LT_TAGVAR(LD, $1)=$LD
 _LT_CC_BASENAME([$compiler])
 
 # GCJ did not exist at the time GCC didn't implicitly link libc in.
@@ -7510,7 +8010,7 @@ CFLAGS=$lt_save_CFLAGS
 # --------------------------
 # Ensure that the configuration variables for the GNU Go compiler
 # are suitably defined.  These variables are subsequently used by _LT_CONFIG
-# to write the compiler configuration to `libtool'.
+# to write the compiler configuration to 'libtool'.
 m4_defun([_LT_LANG_GO_CONFIG],
 [AC_REQUIRE([LT_PROG_GO])dnl
 AC_LANG_SAVE
@@ -7544,7 +8044,7 @@ CC=${GOC-"gccgo"}
 CFLAGS=$GOFLAGS
 compiler=$CC
 _LT_TAGVAR(compiler, $1)=$CC
-_LT_TAGVAR(LD, $1)="$LD"
+_LT_TAGVAR(LD, $1)=$LD
 _LT_CC_BASENAME([$compiler])
 
 # Go did not exist at the time GCC didn't implicitly link libc in.
@@ -7581,7 +8081,7 @@ CFLAGS=$lt_save_CFLAGS
 # -------------------------
 # Ensure that the configuration variables for the Windows resource compiler
 # are suitably defined.  These variables are subsequently used by _LT_CONFIG
-# to write the compiler configuration to `libtool'.
+# to write the compiler configuration to 'libtool'.
 m4_defun([_LT_LANG_RC_CONFIG],
 [AC_REQUIRE([LT_PROG_RC])dnl
 AC_LANG_SAVE
@@ -7597,7 +8097,7 @@ _LT_TAGVAR(objext, $1)=$objext
 lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }'
 
 # Code to be used in simple link tests
-lt_simple_link_test_code="$lt_simple_compile_test_code"
+lt_simple_link_test_code=$lt_simple_compile_test_code
 
 # ltmain only uses $CC for tagged configurations so make sure $CC is set.
 _LT_TAG_COMPILER
@@ -7607,7 +8107,7 @@ _LT_COMPILER_BOILERPLATE
 _LT_LINKER_BOILERPLATE
 
 # Allow CC to be a program name with arguments.
-lt_save_CC="$CC"
+lt_save_CC=$CC
 lt_save_CFLAGS=$CFLAGS
 lt_save_GCC=$GCC
 GCC=
@@ -7636,7 +8136,7 @@ AC_DEFUN([LT_PROG_GCJ],
 [m4_ifdef([AC_PROG_GCJ], [AC_PROG_GCJ],
   [m4_ifdef([A][M_PROG_GCJ], [A][M_PROG_GCJ],
     [AC_CHECK_TOOL(GCJ, gcj,)
-      test "x${GCJFLAGS+set}" = xset || GCJFLAGS="-g -O2"
+      test set = "${GCJFLAGS+set}" || GCJFLAGS="-g -O2"
       AC_SUBST(GCJFLAGS)])])[]dnl
 ])
 
@@ -7747,7 +8247,7 @@ 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
+  test ! -f "$lt_ac_sed" && continue
   cat /dev/null > conftest.in
   lt_ac_count=0
   echo $ECHO_N "0123456789$ECHO_C" >conftest.in
@@ -7764,9 +8264,9 @@ for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do
     $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
+    test 10 -lt "$lt_ac_count" && break
     lt_ac_count=`expr $lt_ac_count + 1`
-    if test $lt_ac_count -gt $lt_ac_max; then
+    if test "$lt_ac_count" -gt "$lt_ac_max"; then
       lt_ac_max=$lt_ac_count
       lt_cv_path_SED=$lt_ac_sed
     fi
@@ -7790,27 +8290,7 @@ dnl AC_DEFUN([LT_AC_PROG_SED], [])
 # Find out whether the shell is Bourne or XSI compatible,
 # or has some other useful features.
 m4_defun([_LT_CHECK_SHELL_FEATURES],
-[AC_MSG_CHECKING([whether the shell understands some XSI constructs])
-# Try some XSI features
-xsi_shell=no
-( _lt_dummy="a/b/c"
-  test "${_lt_dummy##*/},${_lt_dummy%/*},${_lt_dummy#??}"${_lt_dummy%"$_lt_dummy"}, \
-      = c,a/b,b/c, \
-    && eval 'test $(( 1 + 1 )) -eq 2 \
-    && test "${#_lt_dummy}" -eq 5' ) >/dev/null 2>&1 \
-  && xsi_shell=yes
-AC_MSG_RESULT([$xsi_shell])
-_LT_CONFIG_LIBTOOL_INIT([xsi_shell='$xsi_shell'])
-
-AC_MSG_CHECKING([whether the shell understands "+="])
-lt_shell_append=no
-( foo=bar; set foo baz; eval "$[1]+=\$[2]" && test "$foo" = barbaz ) \
-    >/dev/null 2>&1 \
-  && lt_shell_append=yes
-AC_MSG_RESULT([$lt_shell_append])
-_LT_CONFIG_LIBTOOL_INIT([lt_shell_append='$lt_shell_append'])
-
-if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
+[if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
   lt_unset=unset
 else
   lt_unset=false
@@ -7834,102 +8314,9 @@ _LT_DECL([NL2SP], [lt_NL2SP], [1], [turn newlines into spaces])dnl
 ])# _LT_CHECK_SHELL_FEATURES
 
 
-# _LT_PROG_FUNCTION_REPLACE (FUNCNAME, REPLACEMENT-BODY)
-# ------------------------------------------------------
-# In `$cfgfile', look for function FUNCNAME delimited by `^FUNCNAME ()$' and
-# '^} FUNCNAME ', and replace its body with REPLACEMENT-BODY.
-m4_defun([_LT_PROG_FUNCTION_REPLACE],
-[dnl {
-sed -e '/^$1 ()$/,/^} # $1 /c\
-$1 ()\
-{\
-m4_bpatsubsts([$2], [$], [\\], [^\([	 ]\)], [\\\1])
-} # Extended-shell $1 implementation' "$cfgfile" > $cfgfile.tmp \
-  && mv -f "$cfgfile.tmp" "$cfgfile" \
-    || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-])
-
-
-# _LT_PROG_REPLACE_SHELLFNS
-# -------------------------
-# Replace existing portable implementations of several shell functions with
-# equivalent extended shell implementations where those features are available..
-m4_defun([_LT_PROG_REPLACE_SHELLFNS],
-[if test x"$xsi_shell" = xyes; then
-  _LT_PROG_FUNCTION_REPLACE([func_dirname], [dnl
-    case ${1} in
-      */*) func_dirname_result="${1%/*}${2}" ;;
-      *  ) func_dirname_result="${3}" ;;
-    esac])
-
-  _LT_PROG_FUNCTION_REPLACE([func_basename], [dnl
-    func_basename_result="${1##*/}"])
-
-  _LT_PROG_FUNCTION_REPLACE([func_dirname_and_basename], [dnl
-    case ${1} in
-      */*) func_dirname_result="${1%/*}${2}" ;;
-      *  ) func_dirname_result="${3}" ;;
-    esac
-    func_basename_result="${1##*/}"])
-
-  _LT_PROG_FUNCTION_REPLACE([func_stripname], [dnl
-    # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are
-    # positional parameters, so assign one to ordinary parameter first.
-    func_stripname_result=${3}
-    func_stripname_result=${func_stripname_result#"${1}"}
-    func_stripname_result=${func_stripname_result%"${2}"}])
-
-  _LT_PROG_FUNCTION_REPLACE([func_split_long_opt], [dnl
-    func_split_long_opt_name=${1%%=*}
-    func_split_long_opt_arg=${1#*=}])
-
-  _LT_PROG_FUNCTION_REPLACE([func_split_short_opt], [dnl
-    func_split_short_opt_arg=${1#??}
-    func_split_short_opt_name=${1%"$func_split_short_opt_arg"}])
-
-  _LT_PROG_FUNCTION_REPLACE([func_lo2o], [dnl
-    case ${1} in
-      *.lo) func_lo2o_result=${1%.lo}.${objext} ;;
-      *)    func_lo2o_result=${1} ;;
-    esac])
-
-  _LT_PROG_FUNCTION_REPLACE([func_xform], [    func_xform_result=${1%.*}.lo])
-
-  _LT_PROG_FUNCTION_REPLACE([func_arith], [    func_arith_result=$(( $[*] ))])
-
-  _LT_PROG_FUNCTION_REPLACE([func_len], [    func_len_result=${#1}])
-fi
-
-if test x"$lt_shell_append" = xyes; then
-  _LT_PROG_FUNCTION_REPLACE([func_append], [    eval "${1}+=\\${2}"])
-
-  _LT_PROG_FUNCTION_REPLACE([func_append_quoted], [dnl
-    func_quote_for_eval "${2}"
-dnl m4 expansion turns \\\\ into \\, and then the shell eval turns that into \
-    eval "${1}+=\\\\ \\$func_quote_for_eval_result"])
-
-  # Save a `func_append' function call where possible by direct use of '+='
-  sed -e 's%func_append \([[a-zA-Z_]]\{1,\}\) "%\1+="%g' $cfgfile > $cfgfile.tmp \
-    && mv -f "$cfgfile.tmp" "$cfgfile" \
-      || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-  test 0 -eq $? || _lt_function_replace_fail=:
-else
-  # Save a `func_append' function call even when '+=' is not available
-  sed -e 's%func_append \([[a-zA-Z_]]\{1,\}\) "%\1="$\1%g' $cfgfile > $cfgfile.tmp \
-    && mv -f "$cfgfile.tmp" "$cfgfile" \
-      || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-  test 0 -eq $? || _lt_function_replace_fail=:
-fi
-
-if test x"$_lt_function_replace_fail" = x":"; then
-  AC_MSG_WARN([Unable to substitute extended shell functions in $ofile])
-fi
-])
-
 # _LT_PATH_CONVERSION_FUNCTIONS
 # -----------------------------
-# Determine which file name conversion functions should be used by
+# Determine what file name conversion functions should be used by
 # func_to_host_file (and, implicitly, by func_to_host_path).  These are needed
 # for certain cross-compile configurations and native mingw.
 m4_defun([_LT_PATH_CONVERSION_FUNCTIONS],
diff --git a/m4/ltoptions.m4 b/m4/ltoptions.m4
index 5d9acd8..94b0829 100644
--- a/m4/ltoptions.m4
+++ b/m4/ltoptions.m4
@@ -1,14 +1,14 @@
 # Helper functions for option handling.                    -*- Autoconf -*-
 #
-#   Copyright (C) 2004, 2005, 2007, 2008, 2009 Free Software Foundation,
-#   Inc.
+#   Copyright (C) 2004-2005, 2007-2009, 2011-2015 Free Software
+#   Foundation, Inc.
 #   Written by Gary V. Vaughan, 2004
 #
 # 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 ltoptions.m4
+# serial 8 ltoptions.m4
 
 # This is to help aclocal find these macros, as it can't see m4_define.
 AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])])
@@ -29,7 +29,7 @@ m4_define([_LT_SET_OPTION],
 [m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl
 m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]),
         _LT_MANGLE_DEFUN([$1], [$2]),
-    [m4_warning([Unknown $1 option `$2'])])[]dnl
+    [m4_warning([Unknown $1 option '$2'])])[]dnl
 ])
 
 
@@ -75,13 +75,15 @@ m4_if([$1],[LT_INIT],[
   dnl
   dnl If no reference was made to various pairs of opposing options, then
   dnl we run the default mode handler for the pair.  For example, if neither
-  dnl `shared' nor `disable-shared' was passed, we enable building of shared
+  dnl 'shared' nor 'disable-shared' was passed, we enable building of shared
   dnl archives by default:
   _LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED])
   _LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC])
   _LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC])
   _LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install],
-  		   [_LT_ENABLE_FAST_INSTALL])
+		   [_LT_ENABLE_FAST_INSTALL])
+  _LT_UNLESS_OPTIONS([LT_INIT], [aix-soname=aix aix-soname=both aix-soname=svr4],
+		   [_LT_WITH_AIX_SONAME([aix])])
   ])
 ])# _LT_SET_OPTIONS
 
@@ -112,7 +114,7 @@ AU_DEFUN([AC_LIBTOOL_DLOPEN],
 [_LT_SET_OPTION([LT_INIT], [dlopen])
 AC_DIAGNOSE([obsolete],
 [$0: Remove this warning and the call to _LT_SET_OPTION when you
-put the `dlopen' option into LT_INIT's first parameter.])
+put the 'dlopen' option into LT_INIT's first parameter.])
 ])
 
 dnl aclocal-1.4 backwards compatibility:
@@ -148,7 +150,7 @@ AU_DEFUN([AC_LIBTOOL_WIN32_DLL],
 _LT_SET_OPTION([LT_INIT], [win32-dll])
 AC_DIAGNOSE([obsolete],
 [$0: Remove this warning and the call to _LT_SET_OPTION when you
-put the `win32-dll' option into LT_INIT's first parameter.])
+put the 'win32-dll' option into LT_INIT's first parameter.])
 ])
 
 dnl aclocal-1.4 backwards compatibility:
@@ -157,9 +159,9 @@ dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], [])
 
 # _LT_ENABLE_SHARED([DEFAULT])
 # ----------------------------
-# implement the --enable-shared flag, and supports the `shared' and
-# `disable-shared' LT_INIT options.
-# DEFAULT is either `yes' or `no'.  If omitted, it defaults to `yes'.
+# implement the --enable-shared flag, and supports the 'shared' and
+# 'disable-shared' LT_INIT options.
+# DEFAULT is either 'yes' or 'no'.  If omitted, it defaults to 'yes'.
 m4_define([_LT_ENABLE_SHARED],
 [m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl
 AC_ARG_ENABLE([shared],
@@ -172,14 +174,14 @@ AC_ARG_ENABLE([shared],
     *)
       enable_shared=no
       # Look at the argument we got.  We use all the common list separators.
-      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
       for pkg in $enableval; do
-	IFS="$lt_save_ifs"
+	IFS=$lt_save_ifs
 	if test "X$pkg" = "X$p"; then
 	  enable_shared=yes
 	fi
       done
-      IFS="$lt_save_ifs"
+      IFS=$lt_save_ifs
       ;;
     esac],
     [enable_shared=]_LT_ENABLE_SHARED_DEFAULT)
@@ -211,9 +213,9 @@ dnl AC_DEFUN([AM_DISABLE_SHARED], [])
 
 # _LT_ENABLE_STATIC([DEFAULT])
 # ----------------------------
-# implement the --enable-static flag, and support the `static' and
-# `disable-static' LT_INIT options.
-# DEFAULT is either `yes' or `no'.  If omitted, it defaults to `yes'.
+# implement the --enable-static flag, and support the 'static' and
+# 'disable-static' LT_INIT options.
+# DEFAULT is either 'yes' or 'no'.  If omitted, it defaults to 'yes'.
 m4_define([_LT_ENABLE_STATIC],
 [m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl
 AC_ARG_ENABLE([static],
@@ -226,14 +228,14 @@ AC_ARG_ENABLE([static],
     *)
      enable_static=no
       # Look at the argument we got.  We use all the common list separators.
-      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
       for pkg in $enableval; do
-	IFS="$lt_save_ifs"
+	IFS=$lt_save_ifs
 	if test "X$pkg" = "X$p"; then
 	  enable_static=yes
 	fi
       done
-      IFS="$lt_save_ifs"
+      IFS=$lt_save_ifs
       ;;
     esac],
     [enable_static=]_LT_ENABLE_STATIC_DEFAULT)
@@ -265,9 +267,9 @@ dnl AC_DEFUN([AM_DISABLE_STATIC], [])
 
 # _LT_ENABLE_FAST_INSTALL([DEFAULT])
 # ----------------------------------
-# implement the --enable-fast-install flag, and support the `fast-install'
-# and `disable-fast-install' LT_INIT options.
-# DEFAULT is either `yes' or `no'.  If omitted, it defaults to `yes'.
+# implement the --enable-fast-install flag, and support the 'fast-install'
+# and 'disable-fast-install' LT_INIT options.
+# DEFAULT is either 'yes' or 'no'.  If omitted, it defaults to 'yes'.
 m4_define([_LT_ENABLE_FAST_INSTALL],
 [m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl
 AC_ARG_ENABLE([fast-install],
@@ -280,14 +282,14 @@ AC_ARG_ENABLE([fast-install],
     *)
       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,"
+      lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
       for pkg in $enableval; do
-	IFS="$lt_save_ifs"
+	IFS=$lt_save_ifs
 	if test "X$pkg" = "X$p"; then
 	  enable_fast_install=yes
 	fi
       done
-      IFS="$lt_save_ifs"
+      IFS=$lt_save_ifs
       ;;
     esac],
     [enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT)
@@ -304,14 +306,14 @@ AU_DEFUN([AC_ENABLE_FAST_INSTALL],
 [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install])
 AC_DIAGNOSE([obsolete],
 [$0: Remove this warning and the call to _LT_SET_OPTION when you put
-the `fast-install' option into LT_INIT's first parameter.])
+the 'fast-install' option into LT_INIT's first parameter.])
 ])
 
 AU_DEFUN([AC_DISABLE_FAST_INSTALL],
 [_LT_SET_OPTION([LT_INIT], [disable-fast-install])
 AC_DIAGNOSE([obsolete],
 [$0: Remove this warning and the call to _LT_SET_OPTION when you put
-the `disable-fast-install' option into LT_INIT's first parameter.])
+the 'disable-fast-install' option into LT_INIT's first parameter.])
 ])
 
 dnl aclocal-1.4 backwards compatibility:
@@ -319,11 +321,64 @@ dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], [])
 dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], [])
 
 
+# _LT_WITH_AIX_SONAME([DEFAULT])
+# ----------------------------------
+# implement the --with-aix-soname flag, and support the `aix-soname=aix'
+# and `aix-soname=both' and `aix-soname=svr4' LT_INIT options. DEFAULT
+# is either `aix', `both' or `svr4'.  If omitted, it defaults to `aix'.
+m4_define([_LT_WITH_AIX_SONAME],
+[m4_define([_LT_WITH_AIX_SONAME_DEFAULT], [m4_if($1, svr4, svr4, m4_if($1, both, both, aix))])dnl
+shared_archive_member_spec=
+case $host,$enable_shared in
+power*-*-aix[[5-9]]*,yes)
+  AC_MSG_CHECKING([which variant of shared library versioning to provide])
+  AC_ARG_WITH([aix-soname],
+    [AS_HELP_STRING([--with-aix-soname=aix|svr4|both],
+      [shared library versioning (aka "SONAME") variant to provide on AIX, @<:@default=]_LT_WITH_AIX_SONAME_DEFAULT[@:>@.])],
+    [case $withval in
+    aix|svr4|both)
+      ;;
+    *)
+      AC_MSG_ERROR([Unknown argument to --with-aix-soname])
+      ;;
+    esac
+    lt_cv_with_aix_soname=$with_aix_soname],
+    [AC_CACHE_VAL([lt_cv_with_aix_soname],
+      [lt_cv_with_aix_soname=]_LT_WITH_AIX_SONAME_DEFAULT)
+    with_aix_soname=$lt_cv_with_aix_soname])
+  AC_MSG_RESULT([$with_aix_soname])
+  if test aix != "$with_aix_soname"; then
+    # For the AIX way of multilib, we name the shared archive member
+    # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o',
+    # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File.
+    # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag,
+    # the AIX toolchain works better with OBJECT_MODE set (default 32).
+    if test 64 = "${OBJECT_MODE-32}"; then
+      shared_archive_member_spec=shr_64
+    else
+      shared_archive_member_spec=shr
+    fi
+  fi
+  ;;
+*)
+  with_aix_soname=aix
+  ;;
+esac
+
+_LT_DECL([], [shared_archive_member_spec], [0],
+    [Shared archive member basename, for filename based shared library versioning on AIX])dnl
+])# _LT_WITH_AIX_SONAME
+
+LT_OPTION_DEFINE([LT_INIT], [aix-soname=aix], [_LT_WITH_AIX_SONAME([aix])])
+LT_OPTION_DEFINE([LT_INIT], [aix-soname=both], [_LT_WITH_AIX_SONAME([both])])
+LT_OPTION_DEFINE([LT_INIT], [aix-soname=svr4], [_LT_WITH_AIX_SONAME([svr4])])
+
+
 # _LT_WITH_PIC([MODE])
 # --------------------
-# implement the --with-pic flag, and support the `pic-only' and `no-pic'
+# implement the --with-pic flag, and support the 'pic-only' and 'no-pic'
 # LT_INIT options.
-# MODE is either `yes' or `no'.  If omitted, it defaults to `both'.
+# MODE is either 'yes' or 'no'.  If omitted, it defaults to 'both'.
 m4_define([_LT_WITH_PIC],
 [AC_ARG_WITH([pic],
     [AS_HELP_STRING([--with-pic@<:@=PKGS@:>@],
@@ -334,19 +389,17 @@ m4_define([_LT_WITH_PIC],
     *)
       pic_mode=default
       # Look at the argument we got.  We use all the common list separators.
-      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
       for lt_pkg in $withval; do
-	IFS="$lt_save_ifs"
+	IFS=$lt_save_ifs
 	if test "X$lt_pkg" = "X$lt_p"; then
 	  pic_mode=yes
 	fi
       done
-      IFS="$lt_save_ifs"
+      IFS=$lt_save_ifs
       ;;
     esac],
-    [pic_mode=default])
-
-test -z "$pic_mode" && pic_mode=m4_default([$1], [default])
+    [pic_mode=m4_default([$1], [default])])
 
 _LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl
 ])# _LT_WITH_PIC
@@ -359,7 +412,7 @@ AU_DEFUN([AC_LIBTOOL_PICMODE],
 [_LT_SET_OPTION([LT_INIT], [pic-only])
 AC_DIAGNOSE([obsolete],
 [$0: Remove this warning and the call to _LT_SET_OPTION when you
-put the `pic-only' option into LT_INIT's first parameter.])
+put the 'pic-only' option into LT_INIT's first parameter.])
 ])
 
 dnl aclocal-1.4 backwards compatibility:
diff --git a/m4/ltsugar.m4 b/m4/ltsugar.m4
index 9000a05..48bc934 100644
--- a/m4/ltsugar.m4
+++ b/m4/ltsugar.m4
@@ -1,6 +1,7 @@
 # ltsugar.m4 -- libtool m4 base layer.                         -*-Autoconf-*-
 #
-# Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
+# Copyright (C) 2004-2005, 2007-2008, 2011-2015 Free Software
+# Foundation, Inc.
 # Written by Gary V. Vaughan, 2004
 #
 # This file is free software; the Free Software Foundation gives
@@ -33,7 +34,7 @@ m4_define([_lt_join],
 # ------------
 # Manipulate m4 lists.
 # These macros are necessary as long as will still need to support
-# Autoconf-2.59 which quotes differently.
+# Autoconf-2.59, which quotes differently.
 m4_define([lt_car], [[$1]])
 m4_define([lt_cdr],
 [m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])],
@@ -44,7 +45,7 @@ m4_define([lt_unquote], $1)
 
 # lt_append(MACRO-NAME, STRING, [SEPARATOR])
 # ------------------------------------------
-# Redefine MACRO-NAME to hold its former content plus `SEPARATOR'`STRING'.
+# Redefine MACRO-NAME to hold its former content plus 'SEPARATOR''STRING'.
 # Note that neither SEPARATOR nor STRING are expanded; they are appended
 # to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked).
 # No SEPARATOR is output if MACRO-NAME was previously undefined (different
diff --git a/m4/ltversion.m4 b/m4/ltversion.m4
index 07a8602..fa04b52 100644
--- a/m4/ltversion.m4
+++ b/m4/ltversion.m4
@@ -1,6 +1,6 @@
 # ltversion.m4 -- version numbers			-*- Autoconf -*-
 #
-#   Copyright (C) 2004 Free Software Foundation, Inc.
+#   Copyright (C) 2004, 2011-2015 Free Software Foundation, Inc.
 #   Written by Scott James Remnant, 2004
 #
 # This file is free software; the Free Software Foundation gives
@@ -9,15 +9,15 @@
 
 # @configure_input@
 
-# serial 3337 ltversion.m4
+# serial 4179 ltversion.m4
 # This file is part of GNU Libtool
 
-m4_define([LT_PACKAGE_VERSION], [2.4.2])
-m4_define([LT_PACKAGE_REVISION], [1.3337])
+m4_define([LT_PACKAGE_VERSION], [2.4.6])
+m4_define([LT_PACKAGE_REVISION], [2.4.6])
 
 AC_DEFUN([LTVERSION_VERSION],
-[macro_version='2.4.2'
-macro_revision='1.3337'
+[macro_version='2.4.6'
+macro_revision='2.4.6'
 _LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?])
 _LT_DECL(, macro_revision, 0)
 ])
diff --git a/m4/lt~obsolete.m4 b/m4/lt~obsolete.m4
index c573da9..c6b26f8 100644
--- a/m4/lt~obsolete.m4
+++ b/m4/lt~obsolete.m4
@@ -1,6 +1,7 @@
 # lt~obsolete.m4 -- aclocal satisfying obsolete definitions.    -*-Autoconf-*-
 #
-#   Copyright (C) 2004, 2005, 2007, 2009 Free Software Foundation, Inc.
+#   Copyright (C) 2004-2005, 2007, 2009, 2011-2015 Free Software
+#   Foundation, Inc.
 #   Written by Scott James Remnant, 2004.
 #
 # This file is free software; the Free Software Foundation gives
@@ -11,7 +12,7 @@
 
 # These exist entirely to fool aclocal when bootstrapping libtool.
 #
-# In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN)
+# In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN),
 # which have later been changed to m4_define as they aren't part of the
 # exported API, or moved to Autoconf or Automake where they belong.
 #
@@ -25,7 +26,7 @@
 # included after everything else.  This provides aclocal with the
 # AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything
 # because those macros already exist, or will be overwritten later.
-# We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6. 
+# We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6.
 #
 # Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here.
 # Yes, that means every name once taken will need to remain here until
diff --git a/man/Makefile.in b/man/Makefile.in
index e86c34a..1be27c2 100644
--- a/man/Makefile.in
+++ b/man/Makefile.in
@@ -242,6 +242,7 @@ EXEEXT = @EXEEXT@
 EXT = @EXT@
 FGREP = @FGREP@
 GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@
+GIT_PROG_EXISTS = @GIT_PROG_EXISTS@
 GLIB_CFLAGS = @GLIB_CFLAGS@
 GLIB_LIBS = @GLIB_LIBS@
 GMSGFMT = @GMSGFMT@
@@ -299,6 +300,7 @@ LN_S = @LN_S@
 LTLIBICONV = @LTLIBICONV@
 LTLIBINTL = @LTLIBINTL@
 LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
 MAKEINFO = @MAKEINFO@
 MANIFEST_TOOL = @MANIFEST_TOOL@
 MKDIR_P = @MKDIR_P@
diff --git a/man/fr/Makefile.am b/man/fr/Makefile.am
index f153ac8..8bfac63 100644
--- a/man/fr/Makefile.am
+++ b/man/fr/Makefile.am
@@ -6,7 +6,6 @@ SUFFIXES = .1_ .1
 
 dist_noinst_DATA = $(SOURCES) $(COMMON)
 nodist_man_MANS = $(TARGETS)
-man1dir = ${mandir}/fr/man1
 
 $(TARGETS) : $(COMMON) Makefile.am
 
diff --git a/man/fr/Makefile.in b/man/fr/Makefile.in
index 9c4d5da..f7b0f4c 100644
--- a/man/fr/Makefile.in
+++ b/man/fr/Makefile.in
@@ -142,6 +142,7 @@ am__uninstall_files_from_dir = { \
     || { echo " ( cd '$$dir' && rm -f" $$files ")"; \
          $(am__cd) "$$dir" && rm -f $$files; }; \
   }
+man1dir = $(mandir)/man1
 am__installdirs = "$(DESTDIR)$(man1dir)"
 NROFF = nroff
 MANS = $(nodist_man_MANS)
@@ -199,6 +200,7 @@ EXEEXT = @EXEEXT@
 EXT = @EXT@
 FGREP = @FGREP@
 GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@
+GIT_PROG_EXISTS = @GIT_PROG_EXISTS@
 GLIB_CFLAGS = @GLIB_CFLAGS@
 GLIB_LIBS = @GLIB_LIBS@
 GMSGFMT = @GMSGFMT@
@@ -256,6 +258,7 @@ LN_S = @LN_S@
 LTLIBICONV = @LTLIBICONV@
 LTLIBINTL = @LTLIBINTL@
 LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
 MAKEINFO = @MAKEINFO@
 MANIFEST_TOOL = @MANIFEST_TOOL@
 MKDIR_P = @MKDIR_P@
@@ -374,7 +377,6 @@ COMMON = reporting_bugs.part see_also.part
 SUFFIXES = .1_ .1
 dist_noinst_DATA = $(SOURCES) $(COMMON)
 nodist_man_MANS = $(TARGETS)
-man1dir = ${mandir}/fr/man1
 all: all-am
 
 .SUFFIXES:
diff --git a/man/fr/idjc-auto.1_ b/man/fr/idjc-auto.1_
index c69edf1..ce3f574 100644
--- a/man/fr/idjc-auto.1_
+++ b/man/fr/idjc-auto.1_
@@ -5,7 +5,7 @@ idjc\-auto \- Rendre un profile automatique
 .P
 idjc auto [\-h] nom_de_profile
 .SH DESCRIPTION
-Lorsqu'un profile est rendu automatique, la fenêtre du Gestionnaire de Profiles n'apparait pas au démarrage,  au lieu de ça, le profile est chargé. Un seul et unique profile peut être défini comme automatique.
+Lorsqu'un profile est rendu automatique, la fenêtre du Gestionnaire de Profiles n'apparait pas au démarrage, au lieu de ça, le profile est chargé. Un seul et unique profile peut être défini comme étant automatique.
 .SS Options
 .B \-h, \-\-help
 .RS
diff --git a/man/fr/idjc-new.1_ b/man/fr/idjc-new.1_
index a6a815f..8952b4c 100644
--- a/man/fr/idjc-new.1_
+++ b/man/fr/idjc-new.1_
@@ -23,23 +23,23 @@ PROFILE=un profile existant à dupliquer.
 .PP
 .BR "\-i, \-\-icon\-pathname" =ICONE
 .RS
-ICON=le chemin vers un fichier image ex.: un fichier .png
+ICON=le chemin vers un fichier image ex. : un fichier .png
 .RE
 .PP
 .BR "\-n, \-\-nickname" =PSEUDO
 .RS
-PSEUDO=un nom alternatif pour le profile. Contrairement au profile n'importe quel caractère unicode est autorisé.
+PSEUDO=un nom alternatif pour le profile. Contrairement au profile, n'importe quel caractère unicode est autorisé.
 .RE
 .PP
 .BR "\-d, \-\-description" =DESC
 .RS
-DESC=un texte de description. Un texte pour votre profile décrivant ce pourquoi il est destiné.
+DESC=un texte de description. Un texte pour décrivant votre profile, ce à quoi il est destiné.
 .RE
 .PP
 .SS Obligatoire
 .B nom_de_profile
 .RS
-Le nom du nouveau profile. Limité aux lettres et chiffres du jeu ASCII et '_' le sous-ligné.
+Le nom du nouveau profile. Limité aux lettres et chiffres du jeu ASCII et «_» le sous-ligné.
 .RE
 .SH RAPPORTER DES BOGUESS
 .SH VOIR AUSSI
diff --git a/man/fr/idjc-noauto.1_ b/man/fr/idjc-noauto.1_
index 531e599..5dfd8e0 100644
--- a/man/fr/idjc-noauto.1_
+++ b/man/fr/idjc-noauto.1_
@@ -5,7 +5,7 @@ idjc-noauto \- Pas de profile automatique
 .P
 idjc noauto [\-h]
 .SH DESCRIPTION
-Supprime le profile automatique lors du démarrage
+Supprime le profile automatique lors du démarrage de 
 .B idjc
 si aucun profile n'est choisi sur la ligne de commande, le Gestionnaire de Profiles apparaitra de façon à en choisir un manuellement.
 .SS Options
diff --git a/man/fr/idjc-rm.1_ b/man/fr/idjc-rm.1_
index 1d89aff..6da2382 100644
--- a/man/fr/idjc-rm.1_
+++ b/man/fr/idjc-rm.1_
@@ -1,13 +1,13 @@
 .TH "IDJC-RM" 1 "2012-02-06" "VERSION" "Internet DJ Console"
 .SH NOM
-idjc\-rm \- Remove a profile
+idjc\-rm \- Supprimer des profiles
 .SH SYNOPSIS
 .P
-idjc rm [\-h] nom_de_profile [nom_de_profile...]
+idjc rm [\-h] nom_de_profile [nom_de_profile…]
 .SH DESCRIPTION
-Supprime un ou des profiles 
+Supprime un ou des profiles
 .B idjc
-du dossier de configuration correspondant.
+du dossier de configuration correspondant
 .SS Options
 .B \-h, \-\-help
 .RS
diff --git a/man/fr/idjc-run.1_ b/man/fr/idjc-run.1_
index 6dd0178..11aa21e 100644
--- a/man/fr/idjc-run.1_
+++ b/man/fr/idjc-run.1_
@@ -6,8 +6,8 @@ idjc\-run \- Lance l'application principale de
 .P
 idjc run [\-h] [\-d {true,false}] [\-p profile_choisi] [\-j nom_de_serveur]
          [\-S detaild_de_session] [\-\-no\-jack\-connections] [\-C]
-         [\-c c [c ...]] [\-V {off,private,public}] [\-P p [p ...]]
-         [\-s s [s ...]] [\-x {1,2}]
+         [\-c c [c …]] [\-V {off,private,public}] [\-P p [p …]]
+         [\-s s [s …]] [\-x {1,2}]
 .SH DESCRIPTION
 .SS Options generales
 .B \-h, \-\-help
@@ -17,12 +17,12 @@ Affiche un message d'aide
 .PP
 .BR "\-d, \-\-dialog" "={true,false}"
 .RS
-S'il faut ou pas afficher le dialogue de choix de profile.
+S'il faut ou non afficher le dialogue de sélection de profile.
 .RE
 .PP
 .BR "\-p, \-\-profile" =PROFILE
 .RS
-Quel profile à exécuter. N'importe quel autre que celui par défaut doit exister.
+Quel profile à exécuter. Tout autre que celui par défaut doit déjà exister.
 .RE
 .PP
 .BR "\-j, \-\-jackserver" =SERVER
@@ -37,14 +37,14 @@ Voir la section support de session ci\-dessous pour plus de détails.
 .PP
 .B \-\-no\-jack\-connections
 .RS
-Une option potentiellement utils si vous utilisez un quelconque gestionnaire de sessions. Au démarrage 
+Une option potentiellement utile si vous utilisez un quelconque gestionnaire de sessions. Au démarrage, 
 .B idjc
 ne tentera pas de gérer lui même ses connexions.
 .RE
 .PP
 .B \-\-no\-default\-jack\-connections
 .RS
-Aucun port JACK autre que ceux spécifiés dans la session ne sera connecté. Bien entendu, cela implique que si la session spécifiée n'existe pas, aucune connections ne sera effectuée.
+Aucun port JACK autre que ceux spécifiés dans la session ne sera connecté. Bien entendu, cela implique que, si la session spécifiée n'existe pas, aucune connection ne sera effectuée.
 .RE
 .PP
 .SS Options de l'interface utilisateur
@@ -80,20 +80,21 @@ n'existe pas, à moins qu'il n'ait été configuré autrement grâce à un outil
 .I ladiconf
 ou
 .I QjackCtl
+, 
 .B idjc
-démarrera mais sera configuré avec une vitesse d'échantillonnage de 48000 ce qui est trop pour streamer des CD audio. Il est recommendé de créer ce fichier avec la méthode suivante en console ou en utilisant les outils sus\-nommés qui peuvent nécessiter une installation.
+démarrera mais sera configuré avec une vitesse d'échantillonnage de 48000 ce qui est trop pour streamer des CD audio. Il est recommendé de créer ce fichier avec la méthode suivante, en mode console ou en utilisant les outils sus\-nommés qui peuvent nécessiter une installation spécifique :
 .PP
 .B $
 echo "/usr/bin/jackd \-d alsa \-r 44100 \-p 2048" > ~/.jackdrc
 .PP
-Si vous préférez lancer le serveur audio JACK manuellement vous pouvez le faire de cette manière :
+Si vous préférez lancer le serveur audio JACK manuellement, vous pouvez le faire de cette manière :
 .PP
 .BR $ " jackd \-d alsa \-r 44100 \-p 2048"
 .PP
-.RB Référez\-vous\ à\  jackd (1)\ pour\ plus\ de\ détails.
+.RB Référez\-vous\ à\ jackd (1)\ pour\ plus\ de\ détails.
 .PP
 .B idjc
-possède un support des langues natif et tient compte des variables d'environnement
+possède un support des langues en natif et tient compte des variables d'environnement
 .I LANG
 et
 .I LANGUAGE
@@ -102,7 +103,7 @@ et
 supporte les modes de sessions Ladish [L0] et [L1]. A la demande en ligne de commande vous pouvez spécifier \-\-session=L1, \-\-session=L1:session\-name, ou \-\-session=L1:session\-name:/path/to/savedir. Si un path de sauvegarde est fournis, IDJC opère en mode session plutôt qu'en mode profile.
 Le mode par défaut est L0:default qui effectue des sauvegardes périodiques et à la fermeture. Il est aussi possible de spécifier un nom ou un chemin alternatif pour le mode L0.
 .PP
-Lorsque vous utilisez le mode L1 dans Gladish si vous choisissez "Studio/Save Studio" ou "Project/Save Project" dans le menu principal
+Lorsque vous utilisez le mode L1 dans Gladish si vous choisissez «Studio/Sauvegarder» ou «Project/Sauvegarder» dans le menu principal
 .B idjc
 sauvegardera la configuration des connexions JACK dans le fichier de session.
 .SH RAPPORTER DES BOGUES
diff --git a/man/fr/idjc.1_ b/man/fr/idjc.1_
index 9aa528e..f7a5e08 100644
--- a/man/fr/idjc.1_
+++ b/man/fr/idjc.1_
@@ -5,9 +5,9 @@ idjc \- Devenez dj sur internet
 idjc [\-h] [\-v] {run,new,rm,auto,noauto,ls}
 .SH DESCRIPTION
 .B idjc
-est une puissante et simple application pour les individus intéressés dans le streaming shows radio en direct sur Internet par des serveurs Shoutcast ou Icecast ou par la création dde podcasts.
+est application une puissante et simple pour les personnes intéressées par le streaming de radio en direct sur Internet utilisant des serveurs Shoutcast et Icecast ou par la création de podcasts.
 
-Les fonctionalités incluent deux lecteurs média principaux avec crossfader, un lecteur de jingles, un traitement de signal microphone (limiter, noise gate, etc.), des anonces IRC, le démarrage/arret automatique du stream et la reconnection, le striming  simultané en mp3 et Ogg, jusqu'à 12 canaux d'entrées mono ou 6 stéréo, a DSP interface, une intégration VoIP, le support du contrôle par surfaces MIDI, et des vumètres de niveau audio.
+Les fonctionalités incluent deux lecteurs média principaux avec crossfader, un lecteur de jingles, un traitement de signal microphone (limiteur, noise gate, etc.), des anonces IRC, le démarrage/arret automatique du flux et la reconnection, le streaming simultané en mp3 et Ogg, jusqu'à 12 canaux d'entrées mono ou 6 stéréo, une interface DSP, l'intégration de la VoIP, le support du contrôle par surfaces MIDI et des vumètres de niveaux audio.
 
 Il utilise GTK+ pour son interface et JACK Audio Connection Kit pour faciliter l'inclusion d'applications tierces supportant JACK dans leur chaine audio.
 .SS Options
@@ -21,7 +21,7 @@ Affiche un message d'aide
 Affiche le numéro de version et quite.
 .RE
 .SS
-.BR Sous\-commandes " (chacunes possède sa propre page de manuel)"
+.BR Sous\-commandes " (chacune possède sa propre page de manuel)"
 .B run
 .RS
 Exécute l'application principale
diff --git a/po/POTFILES.in b/po/POTFILES.in
index 79c9e2d..80a55a8 100644
--- a/po/POTFILES.in
+++ b/po/POTFILES.in
@@ -14,3 +14,4 @@ python/songdb.py
 python/playergui.py
 python/preferences.py
 python/sourceclientgui.py
+python/format.py
diff --git a/po/fr.gmo b/po/fr.gmo
index 73405a2..fe64361 100644
Binary files a/po/fr.gmo and b/po/fr.gmo differ
diff --git a/po/fr.po b/po/fr.po
index f597ebd..1c1ec47 100644
--- a/po/fr.po
+++ b/po/fr.po
@@ -8,7 +8,7 @@ msgid ""
 msgstr ""
 "Project-Id-Version: \n"
 "Report-Msgid-Bugs-To: putidjcinthesubjectline at bethere.co.uk\n"
-"POT-Creation-Date: 2014-02-17 19:31+0000\n"
+"POT-Creation-Date: 2015-07-27 07:47+0100\n"
 "PO-Revision-Date: 2013-11-07 16:47+0000\n"
 "Last-Translator: \n"
 "Language-Team: English <team at example.com>\n"
@@ -27,8 +27,8 @@ msgid ""
 "run command"
 msgstr ""
 "Afficher ce message d'aide et quitter -- plus d'aide est disponible pour "
-"chacune des sous-commandes, par exemple : « %(prog)s run --help » "
-"affichel'aide concernant la commande run"
+"chacune des sous-commandes, par exemple : « %(prog)s run --help » affiche "
+"l'aide concernant la commande run"
 
 #. TC: a command line option help string.
 #: python/prelims/__init__.py:108
@@ -130,7 +130,7 @@ msgstr "nom_du_serveur"
 
 #: python/prelims/__init__.py:166
 msgid "the named jack sound-server to connect with"
-msgstr "Nom du serveur Jack auqel se connecter"
+msgstr "Nom du serveur Jack auquel se connecter"
 
 #. TC: command line help placeholder.
 #: python/prelims/__init__.py:170
@@ -181,7 +181,7 @@ msgid ""
 "kick sources on servers -- note that this will be\n"
 "                done before any server connection attempts are made"
 msgstr ""
-"Balancer les soureces sur les serveurs -- notee que ceci sera fait\n"
+"Balancer les sources sur les serveurs -- notez que ceci sera fait\n"
 "                avant que toute tentative de connection ne soit effectuée"
 
 #: python/prelims/__init__.py:203
@@ -284,7 +284,7 @@ msgstr "le profil «%s» n'existe pas"
 #: python/prelims/__init__.py:479
 #, python-format
 msgid "profile %s is already running"
-msgstr "le profil %s est en cours d'utilisation"
+msgstr "le profil «%s» est en cours d'utilisation"
 
 #: python/prelims/__init__.py:492
 #, python-format
@@ -312,6 +312,7 @@ msgstr ""
 
 #. TC: text appears in the title bar when in session mode.
 #: python/prelims/__init__.py:590
+#, python-brace-format
 msgid "session={type}:{name}"
 msgstr "session={type}:{name}"
 
@@ -346,14 +347,17 @@ msgid "Profile %s is active."
 msgstr "Le profil %s est actif."
 
 #: python/prelims/__init__.py:791
+#, python-brace-format
 msgid "Cannot rename profile {0} to {1}, {1} currently exists."
 msgstr "Impossible de renommer le profil {0} en {1}, {1} existe déjà."
 
 #: python/prelims/__init__.py:795
+#, python-brace-format
 msgid "Error during attempt to rename {0} to {1}."
 msgstr "Erreur lors de la tentative de renommage de {0} en {1}."
 
 #: python/prelims/__init__.py:805
+#, python-brace-format
 msgid ""
 "<span weight='bold' size='12000'>Error while editing profile: {0}.</span>\n"
 "\n"
@@ -365,6 +369,7 @@ msgstr ""
 "{1}"
 
 #: python/prelims/__init__.py:824
+#, python-brace-format
 msgid "could not get a lock on profile {0}: {1}"
 msgstr "impossible d'obtenir le vérouillage du profil {0} : {1}"
 
@@ -434,7 +439,7 @@ msgstr "Le modèle de profil «%s» n'existe pas."
 #: python/prelims/__init__.py:933
 #, python-format
 msgid "could not write file %s"
-msgstr "impossible d'écrire le fichier %s"
+msgstr "impossible d'écrire le fichier «%s»"
 
 #: python/prelims/__init__.py:934
 #, python-format
@@ -466,54 +471,54 @@ msgid "The default profile"
 msgstr "Profil par défaut"
 
 #. TC: data entry dialog window title text. %s = profile name
-#: python/prelims/profiledialog.py:97
+#: python/prelims/profiledialog.py:98
 #, python-format
 msgid "Edit profile %s"
 msgstr "Modifier le profil %s"
 
 #. TC: data entry dialog window title text. %s = profile name
-#: python/prelims/profiledialog.py:100
+#: python/prelims/profiledialog.py:101
 #, python-format
 msgid "New profile based upon %s"
-msgstr "Nouveau profil basé sur %s"
+msgstr "Nouveau profil basé sur «%s»"
 
 #. TC: data entry dialog window title text.
-#: python/prelims/profiledialog.py:104
+#: python/prelims/profiledialog.py:105
 msgid "New profile details"
 msgstr "Détails du nouveau profil"
 
 #. TC: profile dialog window title text.
-#: python/prelims/profiledialog.py:242
+#: python/prelims/profiledialog.py:243
 msgid "IDJC Profile Manager"
 msgstr "Gestionaire de profils IDJC"
 
-#: python/prelims/profiledialog.py:276
+#: python/prelims/profiledialog.py:277
 msgid "Profile"
 msgstr "Profil"
 
 #. TC: column heading. The profile nicknames.
 #. TC: IRC nickname data entry label.
-#: python/prelims/profiledialog.py:284 python/irc.py:446
+#: python/prelims/profiledialog.py:285 python/irc.py:452
 msgid "Nickname"
 msgstr "Pseudo"
 
 #. TC: column heading.
 #. TC: Station description.
-#: python/prelims/profiledialog.py:287 python/irc.py:90
-#: python/playergui.py:306 python/sourceclientgui.py:1640
+#: python/prelims/profiledialog.py:288 python/irc.py:96
+#: python/playergui.py:307 python/sourceclientgui.py:1697
 msgid "Description"
 msgstr "Description"
 
 #. TC: column heading. The time a particular profile has been running.
-#: python/prelims/profiledialog.py:291
+#: python/prelims/profiledialog.py:292
 msgid "Up-time"
 msgstr "Durée d'activité"
 
-#: python/prelims/profiledialog.py:305
+#: python/prelims/profiledialog.py:306
 msgid "_Auto"
 msgstr "_Auto"
 
-#: python/prelims/profiledialog.py:364
+#: python/prelims/profiledialog.py:365
 #, python-format
 msgid ""
 "<span weight='bold' size='12000'>Delete the data of profile '%s'?</span>\n"
@@ -525,7 +530,7 @@ msgstr ""
 "\n"
 "Le profil restera disponible avec les paramêtres initiaux."
 
-#: python/prelims/profiledialog.py:368
+#: python/prelims/profiledialog.py:369
 #, python-format
 msgid ""
 "<span weight='bold' size='12000'>Delete profile '%s' and all its data?</"
@@ -540,6 +545,7 @@ msgstr ""
 
 #. TC: The contents of <> and {} must not be changed.
 #: python/dialogs.py:198
+#, python-brace-format
 msgid ""
 "<span weight=\"bold\" size=\"12000\">The connection to the server in tab "
 "{servertab} has failed.</span>\n"
@@ -570,141 +576,152 @@ msgid "Released under the GNU General Public License V2.0+."
 msgstr "Distribué selon les termes de la Licence Publique Générale GNU, V2.0+"
 
 #. TC: IRC message subcategory, triggers on new track announcements.
-#: python/irc.py:78
+#: python/irc.py:82
 msgid "Track announce"
 msgstr "Annonce des pistes"
 
 #. TC: IRC message subcategory, triggered by a timer.
-#: python/irc.py:80
+#: python/irc.py:84
 msgid "Timer"
 msgstr "Timer"
 
 #. TC: IRC message subcategory, triggered once when the stream starts.
-#: python/irc.py:82
+#: python/irc.py:86
 msgid "On stream up"
 msgstr "En début de flux"
 
 #. TC: IRC message subcategory, triggered once at the stream's end.
-#: python/irc.py:84
+#: python/irc.py:88
 msgid "On stream down"
 msgstr "En fin de flux"
 
+#. TC: IRC message subcategory, triggered once at the stream's end.
+#: python/irc.py:90
+#, fuzzy
+msgid "Operations"
+msgstr "Autres options"
+
 #. TC: Track artist.
-#: python/irc.py:89 python/mutagentagger.py:375 python/songdb.py:785
-#: python/songdb.py:1157 python/sourceclientgui.py:92
+#: python/irc.py:95 python/mutagentagger.py:375 python/songdb.py:902
+#: python/songdb.py:1290 python/sourceclientgui.py:94
 msgid "Artist"
 msgstr "Artiste"
 
-#: python/irc.py:89 python/mutagentagger.py:375 python/songdb.py:1161
-#: python/sourceclientgui.py:92
+#: python/irc.py:95 python/mutagentagger.py:375 python/songdb.py:1292
+#: python/sourceclientgui.py:94
 msgid "Title"
 msgstr "Titre"
 
-#: python/irc.py:89 python/mutagentagger.py:376 python/songdb.py:1158
-#: python/sourceclientgui.py:92
+#: python/irc.py:95 python/mutagentagger.py:376 python/songdb.py:1291
+#: python/sourceclientgui.py:94
 msgid "Album"
 msgstr "Album"
 
-#: python/irc.py:89 python/sourceclientgui.py:93
+#: python/irc.py:95 python/sourceclientgui.py:95
 msgid "Song name"
 msgstr "Chanson"
 
 #. TC: The DJ or Stream name.
-#: python/irc.py:90 python/sourceclientgui.py:1637
+#: python/irc.py:96 python/sourceclientgui.py:1694
 msgid "DJ name"
 msgstr "Nom du DJ"
 
-#: python/irc.py:90 python/sourceclientgui.py:1638
+#: python/irc.py:96 python/sourceclientgui.py:1695
 msgid "Listen URL"
 msgstr "URL d'écoute"
 
+#: python/irc.py:96
+#, fuzzy
+msgid "Source URI"
+msgstr "Source"
+
 #. TC: Popup menu item for a GTK text entry widget.
-#: python/irc.py:133
+#: python/irc.py:139
 msgid "Insert Attribute or Colour Code"
 msgstr "Insérer un attribut ou un code couleur"
 
 #. TC: Text formatting style.
-#: python/irc.py:170
+#: python/irc.py:176
 msgid "<b>Bold</b>"
 msgstr "<b>Gras</b>"
 
 #. TC: Text formatting style.
-#: python/irc.py:172
+#: python/irc.py:178
 msgid "<u>Underline</u>"
 msgstr "<u>Sous-ligné</u>"
 
 #. TC: Text formatting style.
-#: python/irc.py:174
+#: python/irc.py:180
 msgid "Normal"
 msgstr "Normal"
 
-#: python/irc.py:180
+#: python/irc.py:186
 msgid "Colours"
 msgstr "Couleurs"
 
-#: python/irc.py:397
+#: python/irc.py:403
 msgid "Optional data entry field for information only."
 msgstr "Champ de donnée optionelle pour information uniquement."
 
 #. TC: Tab heading text.
-#: python/irc.py:400
+#: python/irc.py:406
 msgid "IRC server"
 msgstr "Serveur IRC"
 
-#: python/irc.py:412
+#: python/irc.py:418
 msgid "Manual start"
 msgstr "Départ manuel"
 
-#: python/irc.py:414
+#: python/irc.py:420
 msgid "Off when restarting IDJC and off initially."
 msgstr "Arrêté au redémarrage de IDJC et Arrêté au départ"
 
 #. TC: The IRC network e.g. EFnet.
-#: python/irc.py:438
+#: python/irc.py:444
 msgid "Network"
 msgstr "Réseau"
 
 #. TC: label for hostname entry.
-#: python/irc.py:440 python/sourceclientgui.py:206
+#: python/irc.py:446 python/sourceclientgui.py:208
 msgid "Hostname"
 msgstr "Nom de l'hôte"
 
 #. TC: TCP/IP port number label.
 #. TC: TCP port number.
-#: python/irc.py:442 python/sourceclientgui.py:678
+#: python/irc.py:448 python/sourceclientgui.py:704
 msgid "Port"
 msgstr "Port"
 
-#: python/irc.py:443
+#: python/irc.py:449
 msgid "User name"
 msgstr "Nom utilisateur"
 
-#: python/irc.py:444 python/songdb.py:339 python/sourceclientgui.py:207
+#: python/irc.py:450 python/songdb.py:343 python/sourceclientgui.py:209
 msgid "Password"
 msgstr "Mot de passe"
 
 #. TC: Second choice of IRC nickname.
-#: python/irc.py:448
+#: python/irc.py:454
 msgid "Second choice"
 msgstr "Second choix"
 
 #. TC: Third choice of IRC nickname.
-#: python/irc.py:450
+#: python/irc.py:456
 msgid "Third choice"
 msgstr "Troixième choix"
 
 #. TC: The IRC user's 'real' name.
-#: python/irc.py:452
+#: python/irc.py:458
 msgid "Real name"
 msgstr "Nom réel"
 
 #. TC: The NickServ password.
-#: python/irc.py:454
+#: python/irc.py:460
 msgid "NickServ p/w"
 msgstr "MdP NickServ"
 
 #. TC: Tooltip to IRC 'User name' field.
-#: python/irc.py:459
+#: python/irc.py:465
 msgid ""
 "Ideally set this to something even on servers that allow public anonymous "
 "access."
@@ -713,7 +730,7 @@ msgstr ""
 "anonyme ou public."
 
 #. TC: tooltip to all IRC nicknames entry fields.
-#: python/irc.py:469
+#: python/irc.py:475
 msgid ""
 "When a nickname is in use on the target IRC network, during connection these "
 "IRC nicknames are cycled through, then twice again after appending an "
@@ -725,7 +742,7 @@ msgstr ""
 "ligné jusqu'à ce la fin. Cela donne à IDJC un maximum de neuf pseudos à "
 "tenter."
 
-#: python/irc.py:474
+#: python/irc.py:480
 msgid ""
 "The real name you want to use which will be available regardless of whether "
 "the network connection was made with the primary nickname or not.\n"
@@ -737,7 +754,7 @@ msgstr ""
 "\n"
 "Remplissez le par quelque chose."
 
-#: python/irc.py:477
+#: python/irc.py:483
 msgid ""
 "If this value is set an attempt will be made to acquire your first choice "
 "IRC nickname (if needed) and log in with NickServ at services.\n"
@@ -751,7 +768,7 @@ msgstr ""
 "L'utilisation des services NickServ nécessitent qu'un enregistrement "
 "préalable du pseudo ait été effectué avec un client IRC standard."
 
-#: python/irc.py:505
+#: python/irc.py:511
 msgid ""
 "<span weight='bold' size='12000'>Permanently delete this server?</span>\n"
 "\n"
@@ -763,11 +780,11 @@ msgstr ""
 "Cette action effacera aussi tous les messages associés."
 
 #. TC: An IRC channel #chan or user name entry box label.
-#: python/irc.py:552
+#: python/irc.py:559
 msgid "Channels/Users"
 msgstr "Canaux/Utilisateurs"
 
-#: python/irc.py:556
+#: python/irc.py:563
 msgid ""
 "The comma or space separated list of channels and/or users to whom the "
 "message will be sent.\n"
@@ -782,11 +799,11 @@ msgstr ""
 "#canal:motclef"
 
 #. TC: Message text to send to an IRC channel. Widget label.
-#: python/irc.py:563
+#: python/irc.py:616
 msgid "Message"
 msgstr "Message"
 
-#: python/irc.py:567
+#: python/irc.py:620
 msgid ""
 "The message to send.\n"
 "\n"
@@ -798,23 +815,23 @@ msgstr ""
 "Le message à envoyer.\n"
 "\n"
 "Dans la fenêtre de pop-up (clic droit) se trouvent quelques options utiles "
-"pour les métadonnées et le formataze du texte.\n"
+"pour les métadonnées et le formatage du texte.\n"
 "\n"
 "La fenêtre ci-dessous affiche comment le message apparaitra aux utilisateurs "
 "de XChat XChat2 ou HexChat."
 
 #. TC: Dialog window title text.
-#: python/irc.py:638
+#: python/irc.py:673
 msgid "IRC track announce"
 msgstr "Annonce de pistes IRC"
 
 #. TC: Spinbutton label for a delay value.
-#: python/irc.py:645
+#: python/irc.py:680
 msgid "Delay"
 msgstr "Délais"
 
 #. TC: tooltip on a spinbutton widget.
-#: python/irc.py:647
+#: python/irc.py:682
 msgid ""
 "The delay time of this message.\n"
 "\n"
@@ -836,230 +853,234 @@ msgstr ""
 "message."
 
 #. TC: Dialog window title text.
-#: python/irc.py:675
+#: python/irc.py:710
 msgid "IRC timed message"
 msgstr "Message IRC temporisé"
 
 #. TC: Spinbutton time offset value label.
-#: python/irc.py:684
+#: python/irc.py:719
 msgid "Offset"
 msgstr "Offset"
 
 #. TC: Spinbutton timed interval duration value label.
-#: python/irc.py:686
+#: python/irc.py:721
 msgid "Interval"
 msgstr "Interval"
 
 #. TC: spinbutton tooltip
-#: python/irc.py:689
+#: python/irc.py:724
 msgid ""
 "The time offset within the below specified interval at which the message "
 "will be issued."
 msgstr ""
 "Offset de temps dans l'interval spécifié après lequel le message sera envoyé."
 
-#: python/irc.py:693
+#: python/irc.py:728
 msgid "The interval in seconds of the timed message."
 msgstr "Interval en secondes des messages temporisés."
 
-#: python/irc.py:930
-#, fuzzy
+#: python/irc.py:967
 msgid "This feature requires the installation of python-irc."
 msgstr "Cette fonctionalité nécessite l'installation de python-irclib"
 
 #. TC: Indicator text: We used a password.
-#: python/irc.py:1021
+#: python/irc.py:1058
 msgid "PASSWORD"
 msgstr "MOT DE PASSE"
 
 #. TC: Indicator text: We interact with NickServ.
-#: python/irc.py:1024
+#: python/irc.py:1061
 msgid "NICKSERV"
 msgstr "NICKSERV"
 
 #. TC: Indicator text: Server connection started manually.
-#: python/irc.py:1027
+#: python/irc.py:1064
 msgid "MANUAL"
 msgstr "MANUEL"
 
-#. TC: Expander text encapsulating messages that play when stream goes up.
-#: python/irc.py:1048
+#. TC: Dialog title text.
+#: python/irc.py:1089
 msgid "IRC stream up message"
 msgstr "Messages IRC vers le haut"
 
-#. TC: Expander text encapsulating messages that play when stream goes down.
-#: python/irc.py:1050
+#. TC: Dialog title text.
+#: python/irc.py:1091
 msgid "IRC stream down message"
 msgstr "Messages IRC vers le bas"
 
-#: python/jingles.py:95
+#. TC: Dialog title text.
+#: python/irc.py:1093
+msgid "IRC station operations"
+msgstr ""
+
+#: python/jingles.py:96
 msgid "Stop"
 msgstr "Stopper"
 
 #. TC: Column heading, whether to play.
-#: python/jingles.py:113 python/playergui.py:298
+#: python/jingles.py:114 python/playergui.py:299
 msgid "Play"
 msgstr "Lire"
 
-#: python/jingles.py:122 python/sourceclientgui.py:1025
+#: python/jingles.py:123 python/sourceclientgui.py:1051
 msgid "Repeat"
 msgstr "Répéter"
 
-#: python/jingles.py:135
+#: python/jingles.py:136
 msgid "Configure"
 msgstr "Configurer"
 
-#: python/jingles.py:326 python/playergui.py:4052
+#: python/jingles.py:327 python/playergui.py:4135
 msgid "Supported media"
 msgstr "Média supportaté"
 
-#: python/jingles.py:333
+#: python/jingles.py:334
 #, python-format
 msgid "Effect %d Config"
 msgstr "Config effet %d"
 
-#: python/jingles.py:348
+#: python/jingles.py:349
 msgid "Trigger text"
 msgstr "Texte Trigger"
 
-#: python/jingles.py:349
+#: python/jingles.py:350
 msgid "No Name"
 msgstr "Sans nom"
 
-#: python/jingles.py:356
+#: python/jingles.py:357
 msgid "Level adjustment (dB)"
 msgstr "Ajustement des niveaux (dB)"
 
-#: python/jingles.py:431
+#: python/jingles.py:432
 msgid "Effects volume."
 msgstr "Volume des effets"
 
-#: python/jingles.py:438
+#: python/jingles.py:439
 msgid "Player headroom that is applied when an effect is playing."
 msgstr "Headroom appliqué au lecteur quand un effet est lu."
 
-#: python/jingles.py:501
+#: python/jingles.py:502
 msgid "Alternative"
 msgstr "Alternatif"
 
-#: python/jingles.py:502
+#: python/jingles.py:503
 msgid "Default"
 msgstr "Défaut"
 
-#: python/jingles.py:547
+#: python/jingles.py:548
 msgid "Effects"
 msgstr "Effets"
 
-#: python/jingles.py:590
+#: python/jingles.py:591
 #, python-format
 msgid "Effects %d"
 msgstr "Effet %d"
 
-#: python/jingles.py:598 python/maingui.py:188
+#: python/jingles.py:599 python/maingui.py:189
 msgid "Background Tracks"
 msgstr "Pistes de fond"
 
-#: python/jingles.py:617
+#: python/jingles.py:618
 msgid "Background Tracks volume."
 msgstr "Volume des pistes de fond"
 
-#: python/maingui.py:92
+#: python/maingui.py:93
 msgid "Show a JACK freewheel control on the main panel"
 msgstr "Afficher le contrôle rouelibre de JACK en page principale"
 
-#: python/maingui.py:94
+#: python/maingui.py:95
 msgid "Toggle JACK freewheel mode."
 msgstr "Commutateur du mode rouelibre de JACK"
 
-#: python/maingui.py:167
+#: python/maingui.py:168
 msgid "File"
 msgstr "Fichier"
 
-#: python/maingui.py:167 python/preferences.py:1127
+#: python/maingui.py:168 python/preferences.py:1130
 msgid "View"
 msgstr "Voir"
 
-#: python/maingui.py:168
+#: python/maingui.py:169
 msgid "JACK Ports"
 msgstr "Ports JACK"
 
-#: python/maingui.py:168
+#: python/maingui.py:169
 msgid "Help"
 msgstr "Aide"
 
-#: python/maingui.py:170 python/maingui.py:3653
+#: python/maingui.py:171 python/maingui.py:3689
 msgid "Streams"
 msgstr "Flux"
 
-#: python/maingui.py:171
+#: python/maingui.py:172
 msgid "Recorders"
 msgstr "Enregistreurs"
 
-#: python/maingui.py:184 python/maingui.py:223
+#: python/maingui.py:185 python/maingui.py:224
 msgid "Output"
 msgstr "Sortie"
 
-#: python/maingui.py:184
+#: python/maingui.py:185
 msgid "Preferences"
-msgstr "Preferences"
+msgstr "Préférences"
 
-#: python/maingui.py:184
+#: python/maingui.py:185
 msgid "Profiles"
-msgstr "Profils"
+msgstr "Profiles"
 
-#: python/maingui.py:187 python/songdb.py:405
+#: python/maingui.py:188 python/songdb.py:409
 msgid "Music Database"
 msgstr "Base de donnée musicale"
 
-#: python/maingui.py:187
+#: python/maingui.py:188
 msgid "Channel Meters"
 msgstr "Canal Mêtres"
 
-#: python/maingui.py:187
+#: python/maingui.py:188
 msgid "Output Meters"
 msgstr "Sortie Mêtres"
 
-#: python/maingui.py:188
+#: python/maingui.py:189
 msgid "Tabbed Area"
 msgstr "Zone tabulée"
 
-#: python/maingui.py:188
+#: python/maingui.py:189
 msgid "Button Bar"
 msgstr "Barre de boutons"
 
-#: python/maingui.py:222 python/preferences.py:1482
+#: python/maingui.py:223 python/preferences.py:1485
 msgid "Channels"
 msgstr "Canaux"
 
-#: python/maingui.py:222
+#: python/maingui.py:223
 msgid "Players"
 msgstr "Lecteur"
 
-#: python/maingui.py:223
+#: python/maingui.py:224
 msgid "VoIP"
 msgstr "VoIP"
 
-#: python/maingui.py:223 python/maingui.py:3093
+#: python/maingui.py:224 python/maingui.py:3129
 msgid "DSP"
 msgstr "DSP"
 
-#: python/maingui.py:223
+#: python/maingui.py:224
 msgid "Mix"
 msgstr "Mix"
 
-#: python/maingui.py:223
+#: python/maingui.py:224
 msgid "Misc"
 msgstr "Divers"
 
-#: python/maingui.py:268
+#: python/maingui.py:269
 msgid "Reset"
 msgstr "RàZ"
 
-#: python/maingui.py:271
+#: python/maingui.py:272
 msgid "Reset the JACK port connections to the default settings."
 msgstr "Forcer toutes les connexions aux ports JACK à leur valeurs par défaut."
 
-#: python/maingui.py:276
+#: python/maingui.py:277
 msgid ""
 "<span size=\"12000\" weight=\"bold\">Reset all JACK port connections?</"
 "span>\n"
@@ -1070,35 +1091,37 @@ msgstr ""
 "<span size=\"12000\" weight=\"bold\">RàZ de toutes les connexions aux ports "
 "JACK et remise aux paramêtres par défaut."
 
-#: python/maingui.py:320
+#: python/maingui.py:321
 msgid "No compatible ports available."
 msgstr "Aucun port compatible n'est disponible"
 
-#: python/maingui.py:363
+#: python/maingui.py:364
+#, python-brace-format
 msgid "{0} profile={1}:{2} settings saved."
 msgstr "{0} profil={1}:{2} paramêtres sauvegardés."
 
-#: python/maingui.py:366
+#: python/maingui.py:367
+#, python-brace-format
 msgid "{0} session={1}:{2} settings saved."
 msgstr "{0} session={1}:{2} paramêtres sauvegardés."
 
-#: python/maingui.py:670
+#: python/maingui.py:671
 msgid "Text"
 msgstr "Texte"
 
-#: python/maingui.py:673
+#: python/maingui.py:674
 msgid "The opener button's text."
 msgstr "Texte des boutons d'ouverture"
 
-#: python/maingui.py:681
+#: python/maingui.py:682
 msgid "Icon"
 msgstr "Icône"
 
-#: python/maingui.py:689
+#: python/maingui.py:690
 msgid "The opener button's icon."
 msgstr "L'icône d'ouverture."
 
-#: python/maingui.py:697
+#: python/maingui.py:698
 msgid ""
 "The headroom is the amount by which to reduce player volume when this opener "
 "is active. Note that the actual amount will be the largest value of all the "
@@ -1108,15 +1131,15 @@ msgstr ""
 "quand ce lanceur est activé. Notez que la valeur utilisée sera la plus "
 "élevée parmis celles des bouttons activés."
 
-#: python/maingui.py:702
+#: python/maingui.py:703
 msgid "The amount of headroom required (dB)"
 msgstr "Le taux de headroom nécessaire (dB)"
 
-#: python/maingui.py:711
+#: python/maingui.py:712
 msgid "This button will flash as a reminder to close"
 msgstr "Ce bouton clignottera pour rappeler de le fermer"
 
-#: python/maingui.py:712
+#: python/maingui.py:713
 msgid ""
 "After a number of seconds where a main player is active this button's status "
 "indicator will start to flash and will continue to do so until the button is "
@@ -1126,11 +1149,11 @@ msgstr ""
 "l'indicateur de status de ce bouton commence à clignotter jusqu'à ce que le "
 "bouton soit fermé ou le lecteur arrêté."
 
-#: python/maingui.py:720
+#: python/maingui.py:721
 msgid "This button is to be treated as a microphone opener"
 msgstr "Ce bouton doit être utilisé comme ouvreur de micro"
 
-#: python/maingui.py:722
+#: python/maingui.py:723
 msgid ""
 "The button will be grouped with the other microphone opener buttons. It will "
 "be affected by signals to close microphone buttons. Channels associated with "
@@ -1140,7 +1163,11 @@ msgstr ""
 "par les signaux de fermeture de micro. Les canaux associés à ce bouton "
 "seront mixés différamment lors de l'utilisation des modes VoIP."
 
-#: python/maingui.py:733
+#: python/maingui.py:732
+msgid "This button will automatically cancel JACK freewheel mode"
+msgstr ""
+
+#: python/maingui.py:734
 msgid ""
 "This should be set for all buttons that control input from a live sound "
 "source or device."
@@ -1148,75 +1175,75 @@ msgstr ""
 "Doit être configuré pour chacun des boutons contrôlant l'entrée du son en "
 "direct d'une source ou d'un périphérique."
 
-#: python/maingui.py:736
+#: python/maingui.py:737
 msgid "Button Open Triggers"
 msgstr "Bouton Trieurs"
 
-#: python/maingui.py:743
+#: python/maingui.py:744
 msgid "Playlist advance button"
 msgstr "Bouton d'avance dans la liste de lecture"
 
-#: python/maingui.py:744 python/maingui.py:745
+#: python/maingui.py:745 python/maingui.py:746
 #, python-format
 msgid "'%s' control"
 msgstr "contrôle «%s»"
 
 #. TC: Insert playlist control to stop the player.
-#: python/maingui.py:744 python/playergui.py:4310
+#: python/maingui.py:745 python/playergui.py:4393
 msgid "Player Stop"
 msgstr "Arret lecteur"
 
 #. TC: Insert playlist control to stop the player.
-#: python/maingui.py:745 python/playergui.py:4317
+#: python/maingui.py:746 python/playergui.py:4400
 msgid "Player Stop 2"
 msgstr "Arret Lecteur 2"
 
-#: python/maingui.py:746
+#: python/maingui.py:747
 msgid "Announcements"
 msgstr "Annonces"
 
-#: python/maingui.py:758
+#: python/maingui.py:759
 msgid "When opened close these other buttons"
 msgstr "Quand il est ouvert, ferme les autres boutons"
 
-#: python/maingui.py:769
+#: python/maingui.py:770
 msgid "Shell Command"
 msgstr "Commande Shell"
 
-#: python/maingui.py:770
+#: python/maingui.py:771
 msgid ""
 "Mostly useful issuing 'amixer' commands, in particular for setting capture."
 msgstr ""
 "Pratique principalement avec les commandes de «amixer», en particulier pour "
 "configurer la capture."
 
-#: python/maingui.py:790
+#: python/maingui.py:791
 msgid "On open"
 msgstr "A l'ouverture"
 
-#: python/maingui.py:791
+#: python/maingui.py:792
 msgid "On close"
 msgstr "A la fermeture"
 
-#: python/maingui.py:835
+#: python/maingui.py:836
 msgid "Main Panel Opener Buttons"
 msgstr "Panneau principal des boutons d'ouvreurs"
 
-#: python/maingui.py:847
+#: python/maingui.py:848
 msgid "Indicate button numbers and associated channel numbers"
 msgstr "Indique le numéro de boutton et les numéros de canaux associés"
 
-#: python/maingui.py:849
+#: python/maingui.py:850
 msgid "A useful feature to have switched on while allocating channel openers."
 msgstr ""
 "Une fonctionalité utile à avoir activée lorsque l'on alloue des ouvreurs de "
 "canaux."
 
-#: python/maingui.py:855
+#: python/maingui.py:856
 msgid "Status Indicator Appearance"
 msgstr "Apparence de l'indicateur d'état"
 
-#: python/maingui.py:858
+#: python/maingui.py:859
 msgid ""
 "Each opener button has two vertical bars at the side to make the button "
 "state more apparent. These settings control their appearance."
@@ -1224,28 +1251,28 @@ msgstr ""
 "Chaque bouton d'ouverture possède une barre verticale pour le rendre plus "
 "visible. Ces paramêtre contrôlent cette apparence."
 
-#: python/maingui.py:867
+#: python/maingui.py:868 python/format.py:827
 msgid "Width"
 msgstr "Largeur"
 
-#: python/maingui.py:874
+#: python/maingui.py:875
 msgid "Opened"
 msgstr "Ouvert"
 
-#: python/maingui.py:878 python/preferences.py:500 python/preferences.py:502
+#: python/maingui.py:879 python/preferences.py:503 python/preferences.py:505
 msgid "Closed"
 msgstr "Fermé"
 
-#: python/maingui.py:883
+#: python/maingui.py:884
 msgid "Remind"
 msgstr "Se rappeler"
 
 #. TC: A placeholder text for when there are no opener buttons.
-#: python/maingui.py:1064
+#: python/maingui.py:1065
 msgid "No Channel Opener Buttons"
 msgstr "Aucun bouton d'ouverture de canal"
 
-#: python/maingui.py:1353
+#: python/maingui.py:1354
 msgid ""
 "This indicates the state of the various streams. Flashing means stream "
 "packets are being discarded because of network congestion. Partial red means "
@@ -1255,55 +1282,55 @@ msgstr ""
 "Indique l'état des différents flux. Clignottant indique que des paquets du "
 "flux sont écartés à cause d'une congestion du réseau. Partiellement rouge "
 "signifie que le tampon d'émission est partiellement plein, indiquant des "
-"difficultés de comunication avec le serveur. Vert indque que tout va bien."
+"difficultés de comunication avec le serveur. Vert indique que tout va bien."
 
-#: python/maingui.py:1376
+#: python/maingui.py:1377
 msgid "The combined total number of listeners in all server tabs."
 msgstr "Le nombre total d'auditeurs dans tous les onglets de serveurs."
 
 #. TC: Record as in, to make a recording.
-#: python/maingui.py:1824 python/sourceclientgui.py:2702
+#: python/maingui.py:1825 python/sourceclientgui.py:2784
 msgid "Record"
 msgstr "Enregistrer"
 
-#: python/maingui.py:2620
+#: python/maingui.py:2647
 msgid "Confirmation to quit IDJC is required."
 msgstr "Une confirmation est nécessaire pour quitter IDJC."
 
-#: python/maingui.py:2624
+#: python/maingui.py:2651
 msgid "All active recordings and radio streams will terminate."
 msgstr "Tous les entregistrements et flux radio seront arrêtés."
 
-#: python/maingui.py:2626
+#: python/maingui.py:2653
 msgid "All of the active radio streams will terminate."
 msgstr "Tous les flux radio en cours seront arrêtés."
 
-#: python/maingui.py:2628
+#: python/maingui.py:2655
 msgid "All active recordings will cease."
 msgstr "Tous les enregistrements sen cours seront arrêtés."
 
 #. TC: Popup menu item, wipes away the tracks played history text.
-#: python/maingui.py:2885 python/maingui.py:3317
+#: python/maingui.py:2921 python/maingui.py:3353
 msgid "Remove Contents"
 msgstr "Supprimer le contenu"
 
-#: python/maingui.py:3040
+#: python/maingui.py:3076
 msgid "Renameable Labels"
 msgstr "Labels renommables"
 
-#: python/maingui.py:3064
+#: python/maingui.py:3100
 msgid "Main Players"
 msgstr "Lecteur principal"
 
-#: python/maingui.py:3117
+#: python/maingui.py:3153
 msgid "Mix voice over IP audio to the output stream."
 msgstr "Mixe l'audio VoIP au flux de sortie"
 
-#: python/maingui.py:3130
+#: python/maingui.py:3166
 msgid "Mix voice over IP audio to the DJ only."
 msgstr "Mixe l'audio VoIP uniquement au DJ"
 
-#: python/maingui.py:3157
+#: python/maingui.py:3193
 msgid ""
 "This button steps through the active playlist, pausing between tracks. The "
 "active playlist is defined by the placement of the crossfader."
@@ -1311,44 +1338,45 @@ msgstr ""
 "Ce bouton avance dans la liste de lecture en s'arrêtant entre chaque piste. "
 "La liste de lecture en cours est définie par l'emplacement du crossfader."
 
-#: python/maingui.py:3202 python/preferences.py:870
+#: python/maingui.py:3238 python/preferences.py:873
 msgid "The volume control shared by both music players."
 msgstr "Le contrôle de volume partagé par les deux lecteurs."
 
-#: python/maingui.py:3213
+#: python/maingui.py:3249
 msgid "The volume control for the right music player."
 msgstr "Le Volume du lecteur de droite."
 
-#: python/maingui.py:3241
+#: python/maingui.py:3277
 msgid "VoIP level adjustment. 0dB gain is at the mid point."
 msgstr "Ajustement du niveau VoIP. 0dB est le point milieu."
 
-#: python/maingui.py:3264
+#: python/maingui.py:3300
 msgid "The stream volume level to send to the voice over IP connection."
 msgstr "Le niveau de volume à envoyer à la connexion VoIP."
 
-#: python/maingui.py:3291 python/preferences.py:1410
+#: python/maingui.py:3327 python/preferences.py:1413
 msgid "Tracks Played"
 msgstr "Pistes lues"
 
-#: python/maingui.py:3362 python/maingui.py:3364 python/maingui.py:3388
+#: python/maingui.py:3398 python/maingui.py:3400 python/maingui.py:3424
 msgid "Monitor Mix"
 msgstr "Monitor Mix"
 
-#: python/maingui.py:3371 python/maingui.py:3388 python/playergui.py:4251
+#: python/maingui.py:3407 python/maingui.py:3424 python/playergui.py:4334
 msgid "DJ"
 msgstr "DJ"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/maingui.py:3374 python/maingui.py:3388 python/midicontrols.py:154
-#: python/midicontrols.py:1506 python/playergui.py:4243
-#: python/sourceclientgui.py:2710
+#: python/maingui.py:3410 python/maingui.py:3424 python/midicontrols.py:155
+#: python/midicontrols.py:1507 python/playergui.py:4326
+#: python/sourceclientgui.py:2792
 msgid "Stream"
 msgstr "Flux"
 
 #. TC: Context {0}, {1}, {2} = Monitor Mix, Stream, DJ
 #. TC: Or whatever they become translated to.
-#: python/maingui.py:3384
+#: python/maingui.py:3420
+#, python-brace-format
 msgid ""
 "In IDJC there are are two audio paths and this '{0}' control toggles between "
 "them. When '{1}' is active you can hear what the listeners are hearing "
@@ -1361,82 +1389,82 @@ msgstr ""
 "pour pouvoir utiliser la fonctionalité VoIP"
 
 #. TC: Dropdown box title text widget.
-#: python/maingui.py:3397 python/maingui.py:3399
+#: python/maingui.py:3433 python/maingui.py:3435
 msgid "Metadata Source"
 msgstr "Source de métadonnées"
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3405 python/playergui.py:3961
+#: python/maingui.py:3441 python/playergui.py:4044
 msgid "Playlist 1"
 msgstr "Liste de lecture 1"
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3407 python/playergui.py:3962
+#: python/maingui.py:3443 python/playergui.py:4045
 msgid "Playlist 2"
 msgstr "Liste de lecture 2"
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3409
+#: python/maingui.py:3445 python/songdb.py:909 python/songdb.py:1293
 msgid "Last Played"
 msgstr "Dernière lue"
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3411 python/maingui.py:3448 python/maingui.py:3450
+#: python/maingui.py:3447 python/maingui.py:3484 python/maingui.py:3486
 msgid "Crossfader"
 msgstr "Crossfader"
 
 #. TC: The chosen source of track metadata. In this case no metadata.
 #. TC: Fade time is zero. No fade, none.
-#: python/maingui.py:3413 python/playergui.py:4226
+#: python/maingui.py:3449 python/playergui.py:4309
 msgid "None"
 msgstr "Aucune"
 
 #. TC: The chosen source of track metadata. In this case no metadata.
-#: python/maingui.py:3415
+#: python/maingui.py:3451
 msgid "Playlist 3"
 msgstr "Liste de lecture 3"
 
-#: python/maingui.py:3420
+#: python/maingui.py:3456
 msgid "Select the origin for the playing track metadata on the stream."
 msgstr "Sélectionner l'origine pour la piste de métadonnées"
 
 #. TC: Abbreviation of left.
-#: python/maingui.py:3430 python/maingui.py:3432
+#: python/maingui.py:3466 python/maingui.py:3468
 msgid "L"
 msgstr "G"
 
-#: python/maingui.py:3442
+#: python/maingui.py:3478
 msgid "Move the crossfader fully left."
 msgstr "Déplacer le crossfader totalement à gauche"
 
-#: python/maingui.py:3462
+#: python/maingui.py:3498
 msgid "The crossfader."
 msgstr "Le crossfader"
 
 #. TC: Abbreviation of right.
-#: python/maingui.py:3466 python/maingui.py:3468
+#: python/maingui.py:3502 python/maingui.py:3504
 msgid "R"
 msgstr "D"
 
-#: python/maingui.py:3478
+#: python/maingui.py:3514
 msgid "Move the crossfader fully right."
 msgstr "Déplacer le crossfader totalement à droite"
 
 #. TC: Describes a mid point.
-#: python/maingui.py:3487 python/maingui.py:3489
+#: python/maingui.py:3523 python/maingui.py:3525
 msgid "Middle"
 msgstr "Milieu"
 
-#: python/maingui.py:3506 python/maingui.py:3513
+#: python/maingui.py:3542 python/maingui.py:3549
 msgid "Move the crossfader to the middle of its range of travel."
 msgstr "Déplacer le crossfader au point milieu de son chemin."
 
 #. TC: The attenuation response curve of the crossfader. User selectable.
-#: python/maingui.py:3518 python/maingui.py:3520
+#: python/maingui.py:3554 python/maingui.py:3556
 msgid "Response"
 msgstr "Réponse"
 
-#: python/maingui.py:3542
+#: python/maingui.py:3578
 msgid ""
 "This selects the response curve of the crossfader.\n"
 "\n"
@@ -1446,11 +1474,11 @@ msgstr ""
 "Les atténuations au point milieu sont respectivement -3dB, 0dB et -22dB "
 
 #. TC: Duration in seconds.
-#: python/maingui.py:3556 python/maingui.py:3558
+#: python/maingui.py:3592 python/maingui.py:3594
 msgid "Time"
 msgstr "Durée"
 
-#: python/maingui.py:3575
+#: python/maingui.py:3611
 msgid ""
 "The time in seconds that the crossfader will take to automatically pass "
 "across when the button to the right is clicked."
@@ -1460,11 +1488,11 @@ msgstr ""
 
 #. TC: The crossfader pass-across button text.
 #. TC: The actual button appears as [<-->] with this text above it.
-#: python/maingui.py:3584 python/maingui.py:3586
+#: python/maingui.py:3620 python/maingui.py:3622
 msgid "Pass"
 msgstr "Passer"
 
-#: python/maingui.py:3599
+#: python/maingui.py:3635
 msgid ""
 "This button causes the crossfader to move to the opposite side at a speed "
 "determined by the speed selector to the left."
@@ -1472,30 +1500,30 @@ msgstr ""
 "Ce bouton fait passer le crossfader vers le côté opposé à la vitesse "
 "déterminée par le sélecteur de vitesse à gauche."
 
-#: python/maingui.py:3642
+#: python/maingui.py:3678
 msgid "Peak"
 msgstr "Pick"
 
-#: python/maingui.py:3645
+#: python/maingui.py:3681
 msgid "A peak hold meter indicating the signal strength of the stream audio."
 msgstr ""
 "Un indicateur de pic temporisé montrant la force du signal du flux audio."
 
 #. TC: This text appears above the stream mix VU meter.
-#: python/maingui.py:3667
+#: python/maingui.py:3703
 msgid "VU"
 msgstr "VU"
 
-#: python/maingui.py:3671
+#: python/maingui.py:3707
 msgid "A VU meter for the stream audio."
 msgstr "Un Vumêtre pour le flux audio."
 
 #. TC: Appears above the mic meters as a label followed by a number.
-#: python/maingui.py:3674
+#: python/maingui.py:3710
 msgid "Ch"
 msgstr "Ch"
 
-#: python/maingui.py:3701
+#: python/maingui.py:3737
 msgid ""
 "A peak hold meter indicating the microphone signal strength and a meter "
 "indicating attenuation levels in the microphone signal processing system. "
@@ -1508,470 +1536,469 @@ msgstr ""
 "esseur, Rouge par le limiteur."
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:47
+#: python/midicontrols.py:48
 msgid "Tooltips enable"
 msgstr "Ballons Activer"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:49
+#: python/midicontrols.py:50
 msgid "DJ-mix monitor"
 msgstr "DJ-Mix Monitoring"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:51
+#: python/midicontrols.py:52
 msgid "Panning load from presets"
 msgstr "Placement chargé depuis la présélection"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:53
+#: python/midicontrols.py:54
 msgid "Player play/pause"
 msgstr "Lecteur Lecture/pause"
 
 #. TC: Control method. Please keep it as Target:Action.
 #. TC: Playlist control.
-#: python/midicontrols.py:55 python/playergui.py:3719
+#: python/midicontrols.py:56 python/playergui.py:3798
 msgid "Player stop"
 msgstr "Arret lecteur"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:57
+#: python/midicontrols.py:58
 msgid "Player advance"
 msgstr "Lecteur Avance"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:59
+#: python/midicontrols.py:60
 msgid "Player play previous"
 msgstr "Lecteur Lire précédente"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:61
+#: python/midicontrols.py:62
 msgid "Player play next"
 msgstr "Lecteur Lire suivante"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:63
+#: python/midicontrols.py:64
 msgid "Player play selected from start"
 msgstr "Lecteur Reprendre au début"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:65
+#: python/midicontrols.py:66
 msgid "Player select previous"
 msgstr "Lecteur Sélectionner la précédente"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:67
+#: python/midicontrols.py:68
 msgid "Player select next"
 msgstr "Lecteur Sélectionner la suivante"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:69
+#: python/midicontrols.py:70
 msgid "Player stream output enable"
 msgstr "Lecteur de flux Activer la sortie"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:71
+#: python/midicontrols.py:72
 msgid "Player DJ output enable"
 msgstr "Lecteur DJ Activer la sortie"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:73
+#: python/midicontrols.py:74
 msgid "Player DJ-only switch"
 msgstr "Lecteur Commuter DJ seul"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:75
+#: python/midicontrols.py:76
 msgid "Player set volume"
 msgstr "Lecteur Régler le volume"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:77
+#: python/midicontrols.py:78
 msgid "Player set gain"
 msgstr "Lecteur Régler le gain"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:79
+#: python/midicontrols.py:80
 msgid "Player set balance"
 msgstr "Lecteur Régler la balance"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:81
+#: python/midicontrols.py:82
 msgid "Player set pitchbend"
 msgstr "Lecteur Régler la tonalité"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:84
+#: python/midicontrols.py:85
 msgid "Playlist edit tags"
 msgstr "Liste de lecture Editer les tags"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:86
+#: python/midicontrols.py:87
 msgid "Playlist insert stop"
 msgstr "Liste de lecture Insérer un arret"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:88
+#: python/midicontrols.py:89
 msgid "Playlist insert stop 2"
 msgstr "Liste de lecture Insérer un arret 2"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:90
+#: python/midicontrols.py:91
 msgid "Playlist insert announce"
 msgstr "Liste de lecture Insérer une annonce"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:92
+#: python/midicontrols.py:93
 msgid "Playlist insert transfer"
 msgstr "Liste de lecture Insérer un transfert"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:94
+#: python/midicontrols.py:95
 msgid "Playlist insert crossfade"
 msgstr "Liste de lecture Insérer un crossfader"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:96
+#: python/midicontrols.py:97
 msgid "Playlist insert pitchunbend"
 msgstr "Liste de lecture Revenir à la tonalité originale"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:98
+#: python/midicontrols.py:99
 msgid "Playlist insert jump to top"
 msgstr "Liste de lecture Insérer un saut en haut"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:101
+#: python/midicontrols.py:102
 msgid "Players set crossfade"
 msgstr "Lecteurs Régler le crossfader"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:103
+#: python/midicontrols.py:104
 msgid "Players pass crossfade"
 msgstr "Lecteurs Effectuer un crossfader"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:105
+#: python/midicontrols.py:106
 msgid "Players set focus"
 msgstr "Lecteur Régler le focus"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:107
+#: python/midicontrols.py:108
 msgid "Players show pitchbend"
 msgstr "Lecteurs Afficher la tonalité"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:109
-#, fuzzy
+#: python/midicontrols.py:110
 msgid "Players advance"
 msgstr "Lecteur Avance"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:112
+#: python/midicontrols.py:113
 msgid "Channel output enable"
 msgstr "Canal Activer la sortie"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:114
+#: python/midicontrols.py:115
 msgid "Channel set volume"
 msgstr "Canal Régler le volume"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:116
+#: python/midicontrols.py:117
 msgid "Channel set gain"
 msgstr "Canal Régler le gain"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:118
+#: python/midicontrols.py:119
 msgid "Channel set balance"
 msgstr "Canal Régler la balance"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:121
+#: python/midicontrols.py:122
 msgid "VoIP output enable"
 msgstr "VoIP Activer la sortie"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:123
+#: python/midicontrols.py:124
 msgid "VoIP DJ-only switch"
 msgstr "VoIP DJ-Seul Commuter"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:125
+#: python/midicontrols.py:126
 msgid "VoIP set volume"
 msgstr "VoIP Régler le volume"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:127
+#: python/midicontrols.py:128
 msgid "VoIP set mixback"
 msgstr "VoIP Régler le retour"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:129
+#: python/midicontrols.py:130
 msgid "VoIP set gain"
 msgstr "VoIP Régler le gain"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:131
+#: python/midicontrols.py:132
 msgid "VoIP set balance"
 msgstr "VoIP Régler la balance"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:134
+#: python/midicontrols.py:135
 msgid "Effect play from start"
 msgstr "Effet Lire depuis le début"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:137
+#: python/midicontrols.py:138
 msgid "Effects stop many"
 msgstr "Effets Arrèter plusieurs"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:139
+#: python/midicontrols.py:140
 msgid "Effects set volume"
 msgstr "Effets Régler le volume"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:141
+#: python/midicontrols.py:142
 msgid "Effects set headroom"
 msgstr "Effets Régler le headroom"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:144
+#: python/midicontrols.py:145
 msgid "Stream set connected"
 msgstr "Flux Connecter"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:147
+#: python/midicontrols.py:148
 msgid "Recorder set recording"
 msgstr "Enregistreur Enregistrement"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:151 python/midicontrols.py:1492
+#: python/midicontrols.py:152 python/midicontrols.py:1493
 msgid "Player"
 msgstr "Lecteur"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
 #. TC: The midi channel.
 #. TC: Specifically, the numerical midi channel.
-#: python/midicontrols.py:152 python/midicontrols.py:1498
-#: python/midicontrols.py:1567 python/midicontrols.py:1757
+#: python/midicontrols.py:153 python/midicontrols.py:1499
+#: python/midicontrols.py:1568 python/midicontrols.py:1758
 msgid "Channel"
 msgstr "Canal"
 
-#: python/midicontrols.py:153 python/preferences.py:596
-#: python/preferences.py:606
+#: python/midicontrols.py:154 python/preferences.py:599
+#: python/preferences.py:609
 msgid "Effect"
 msgstr "Effet"
 
-#: python/midicontrols.py:155
+#: python/midicontrols.py:156
 msgid "Recorder"
 msgstr "Enregistreur"
 
-#: python/midicontrols.py:156
+#: python/midicontrols.py:157
 msgid "Setting"
 msgstr "Paramètres"
 
-#: python/midicontrols.py:160
+#: python/midicontrols.py:161
 msgid "Left player"
 msgstr "Lecteur de gauche"
 
-#: python/midicontrols.py:161
+#: python/midicontrols.py:162
 msgid "Right player"
 msgstr "Lecteur de droite"
 
-#: python/midicontrols.py:162
+#: python/midicontrols.py:163
 msgid "Background player"
 msgstr "Lecteur de fond"
 
-#: python/midicontrols.py:163
+#: python/midicontrols.py:164
 msgid "Focused player"
 msgstr "Lecteur actif"
 
-#: python/midicontrols.py:164
+#: python/midicontrols.py:165
 msgid "Fadered player"
 msgstr "Lecteur affaibli"
 
-#: python/midicontrols.py:168
+#: python/midicontrols.py:169
 msgid "Effects bank 1"
 msgstr "Effets Banque 1"
 
-#: python/midicontrols.py:169
+#: python/midicontrols.py:170
 msgid "Effects bank 2"
 msgstr "Effets Banque 2"
 
-#: python/midicontrols.py:170
+#: python/midicontrols.py:171
 msgid "All effects"
 msgstr "Tous les effets"
 
 #. TC: The name of the backspace key.
-#: python/midicontrols.py:404
+#: python/midicontrols.py:405
 msgid "BackSpace"
 msgstr "Retour Arrière"
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1468
+#: python/midicontrols.py:1469
 msgid "Use value"
 msgstr "Utiliser la valeur"
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1470
+#: python/midicontrols.py:1471
 msgid "Act if"
 msgstr "Agir si"
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1472
+#: python/midicontrols.py:1473
 msgid "Set to"
 msgstr "Régler à"
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1474
+#: python/midicontrols.py:1475
 msgid "Adjust by"
 msgstr "Ajuster par"
 
 #. TC: binding editor, input pane, fourth row, heading text.
-#: python/midicontrols.py:1479 python/midicontrols.py:1483
+#: python/midicontrols.py:1480 python/midicontrols.py:1484
 msgid "Control"
 msgstr "Contrôle"
 
 #. TC: binding editor, input pane, fourth row, heading text.
-#: python/midicontrols.py:1481
+#: python/midicontrols.py:1482
 msgid "Note"
 msgstr "Note"
 
 #. TC: binding editor, input pane, fourth row, heading text.
-#: python/midicontrols.py:1485
+#: python/midicontrols.py:1486
 msgid "Key"
 msgstr "Touche"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1490
+#: python/midicontrols.py:1491
 msgid "Miscellaneous"
 msgstr "Divers"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1494
+#: python/midicontrols.py:1495
 msgid "Both players"
 msgstr "Les deux lecteurs"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1496
+#: python/midicontrols.py:1497
 msgid "Quick panning"
 msgstr "Panoramique rapide"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1500
+#: python/midicontrols.py:1501
 msgid "VoIP channel"
 msgstr "Canal VoIP"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1502
+#: python/midicontrols.py:1503
 msgid "Single effect"
 msgstr "Effet unique"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1504
+#: python/midicontrols.py:1505
 msgid "Effects bank"
 msgstr "Banque d'effets"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1508
+#: python/midicontrols.py:1509
 msgid "Stream recorder"
 msgstr "Enregistreur de flux"
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1513
+#: python/midicontrols.py:1514
 msgid "Direct fader/held button"
 msgstr "Bouton fader/premuto"
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1515
+#: python/midicontrols.py:1516
 msgid "One-shot/toggle button"
 msgstr "Bouton One-shot/Commuter"
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1517
+#: python/midicontrols.py:1518
 msgid "Set value"
 msgstr "Régler la valeur"
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1519
+#: python/midicontrols.py:1520
 msgid "Alter value"
 msgstr "Modifier la valeur"
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1524
+#: python/midicontrols.py:1525
 msgid "MIDI control"
 msgstr "Contrôle MIDI"
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1526
+#: python/midicontrols.py:1527
 msgid "MIDI note"
 msgstr "Note MIDI"
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1528
+#: python/midicontrols.py:1529
 msgid "MIDI pitch-wheel"
 msgstr "Tonalité MIDI"
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1530
+#: python/midicontrols.py:1531
 msgid "Keyboard press"
 msgstr "Touché du clavier"
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1532
+#: python/midicontrols.py:1533
 msgid "XChat command"
 msgstr "Commande XChat"
 
 #. TC: Dialog window title text.
 #. TC: User is expected to edit a control binding.
-#: python/midicontrols.py:1541
+#: python/midicontrols.py:1542
 msgid "Edit control binding"
 msgstr "Editer les contrôleurs"
 
 #. TC: After clicking this button the binding editor will be listening
 #. TC: for a key press or midi control surface input.
 #. TC: Button text. If pressed triggers 'Listening for input' mode.
-#: python/midicontrols.py:1556 python/midicontrols.py:1637
-#: python/midicontrols.py:1736
+#: python/midicontrols.py:1557 python/midicontrols.py:1638
+#: python/midicontrols.py:1737
 msgid "Listen for input..."
 msgstr "Ecouter sur l'entrée…"
 
 #. TC: The input source.
-#: python/midicontrols.py:1564
+#: python/midicontrols.py:1565
 msgid "Source"
 msgstr "Source"
 
 #. TC: The manner in which the input is interpreted.
-#: python/midicontrols.py:1583
+#: python/midicontrols.py:1584
 msgid "Interaction"
 msgstr "Interraction"
 
 #. TC: The effect of the control can be directed upon a specific target.
 #. TC: e.g. On target [Left player]
-#: python/midicontrols.py:1589
+#: python/midicontrols.py:1590
 msgid "On target"
 msgstr "Destination"
 
 #. TC: Checkbutton text.
 #. TC: Use reverse scale and invert the meaning of button presses.
-#: python/midicontrols.py:1597
+#: python/midicontrols.py:1598
 msgid "Reversed"
 msgstr "Inversé"
 
-#: python/midicontrols.py:1598
+#: python/midicontrols.py:1599
 msgid "Pressed"
 msgstr "Pressé"
 
-#: python/midicontrols.py:1600
+#: python/midicontrols.py:1601
 msgid "Released"
 msgstr "Relaché"
 
 #. TC: Tree column heading for Inputs e.g. Backspace, F1, S.
-#: python/midicontrols.py:1630 python/midicontrols.py:1991
+#: python/midicontrols.py:1631 python/midicontrols.py:1992
 msgid "Input"
 msgstr "Entrée"
 
-#: python/midicontrols.py:1634
+#: python/midicontrols.py:1635
 #, python-format
 msgid ""
 "The first half of a binding is the input which comes in the form of the "
@@ -1985,33 +2012,33 @@ msgstr ""
 "La sélection peut se faire manuellement ou à l'aide de l'option «%s»."
 
 #. TC: Tree column heading for actions e.g. Player stop.
-#: python/midicontrols.py:1670 python/midicontrols.py:1676
-#: python/midicontrols.py:2005
+#: python/midicontrols.py:1671 python/midicontrols.py:1677
+#: python/midicontrols.py:2006
 msgid "Action"
 msgstr "Action"
 
 #. TC: %s is the translation of 'Action'.
-#: python/midicontrols.py:1675
+#: python/midicontrols.py:1676
 #, python-format
 msgid "The '%s' pane determines how the input is handled, and to what effect."
 msgstr ""
 "Le ventail «%s» détermine comment l'entrée est gérée et quels en sont les "
 "effets."
 
-#: python/midicontrols.py:1732
+#: python/midicontrols.py:1733
 msgid "Listening for input"
 msgstr "Lecture de l'entrée"
 
 #. TC: Refers to key modifiers including Ctrl, Alt, Shift, ....
-#: python/midicontrols.py:1753
+#: python/midicontrols.py:1754
 msgid "Shifting"
 msgstr "Altération"
 
-#: python/midicontrols.py:1952
+#: python/midicontrols.py:1953
 msgid "Singular control"
 msgstr "Contrôle unique"
 
-#: python/midicontrols.py:2014
+#: python/midicontrols.py:2015
 msgid "Target"
 msgstr "Obiettivo"
 
@@ -2065,7 +2092,7 @@ msgid " Additional Text Frames "
 msgstr " Champs texte additionnels "
 
 #. TC: The album track number.
-#: python/mutagentagger.py:376 python/songdb.py:789 python/songdb.py:1160
+#: python/mutagentagger.py:376 python/songdb.py:906 python/songdb.py:1295
 msgid "Track"
 msgstr "Piste"
 
@@ -2091,57 +2118,63 @@ msgstr "Nom du fichier :"
 msgid "Native"
 msgstr "Natif"
 
-#: python/songdb.py:174
+#: python/songdb.py:177
 msgid "Connecting"
 msgstr "Connexion"
 
 # python-format
-#: python/songdb.py:183
+#: python/songdb.py:188
 #, python-format
 msgid "Connection failed (try %d)"
 msgstr "Connexion échouée (essayez %d)"
 
-#: python/songdb.py:195
-msgid "Connected: utf-8 mode failed"
+#: python/songdb.py:199
+#, fuzzy
+msgid "Connected: autocommit mode failed"
 msgstr "Connecté : Echec du mode utf-8"
 
-#: python/songdb.py:197
+#: python/songdb.py:201
+#, fuzzy
+msgid "Connected: autocommit mode set"
+msgstr "Connecté : Echec du mode utf-8"
+
+#: python/songdb.py:202
 msgid "Connected"
 msgstr "Connecté"
 
-#: python/songdb.py:205
+#: python/songdb.py:210
 msgid "Job dropped"
 msgstr "Tâche abandonnée"
 
-#: python/songdb.py:215 python/songdb.py:427
+#: python/songdb.py:220 python/songdb.py:431
 msgid "Disconnected"
 msgstr "Disconnecté"
 
-#: python/songdb.py:229
+#: python/songdb.py:233
 msgid "Problem dropping connection"
 msgstr "Problème lors de l'abandon de la tâche"
 
-#: python/songdb.py:231
+#: python/songdb.py:235
 msgid "Connection dropped"
 msgstr "Connexion abandonnée"
 
-#: python/songdb.py:322
+#: python/songdb.py:326
 msgid "Hostname[:Port]"
 msgstr "Hôte[:Port]"
 
-#: python/songdb.py:327
+#: python/songdb.py:331
 msgid "User Name"
 msgstr "Nom utilisateur"
 
-#: python/songdb.py:330
+#: python/songdb.py:334
 msgid "Database"
 msgstr "Base de données"
 
-#: python/songdb.py:385
+#: python/songdb.py:389
 msgid "Prokyon3 or Ampache (song title) Database"
 msgstr "Base de donnée Prokyon3 ou Ampache (titre de chanson)"
 
-#: python/songdb.py:386
+#: python/songdb.py:390
 msgid ""
 "You can make certain media databases accessible in IDJC for easy drag and "
 "drop into the playlists."
@@ -2149,165 +2182,194 @@ msgstr ""
 "Vous pouvez rendre certaines bases de données accessibles dans IDJC pour "
 "plusde facilités lors des glisser/déposer dans les listes de lectures"
 
-#: python/songdb.py:434
+#: python/songdb.py:438
 msgid "Module mysql-python (MySQLdb) required"
 msgstr "Module mysql-python (MySQLdb) nécessaire"
 
-#: python/songdb.py:675 python/songdb.py:680
+#: python/songdb.py:707 python/songdb.py:723 python/songdb.py:747
+#: python/songdb.py:805
 msgid "<unknown>"
 msgstr "<inconnu>"
 
-#: python/songdb.py:761
+#: python/songdb.py:741
+#, fuzzy
+msgid "Not Played"
+msgstr "Dernière lue"
+
+#: python/songdb.py:878
 msgid "Reload the database."
 msgstr "Recharger la base de données"
 
-#: python/songdb.py:766
+#: python/songdb.py:883
 msgid "Expand entire tree."
 msgstr "Développer l'arborescence."
 
-#: python/songdb.py:767
+#: python/songdb.py:884
 msgid "Collapse tree."
 msgstr "Enrouler l'arborescence."
 
-#: python/songdb.py:774
+#: python/songdb.py:891
 msgid "Browse"
 msgstr "Parcourrir"
 
 #. TC: The disk number of the album track.
-#: python/songdb.py:787 python/songdb.py:1159
+#: python/songdb.py:904 python/songdb.py:1294
 msgid "Disk"
 msgstr "Disque"
 
 #. TC: Track playback time.
 #. TC: Playback time.
-#: python/songdb.py:791 python/songdb.py:1162 python/playergui.py:312
+#: python/songdb.py:908 python/songdb.py:1296 python/playergui.py:313
 msgid "Duration"
 msgstr "Durée"
 
-#: python/songdb.py:792 python/songdb.py:1163
+#: python/songdb.py:910 python/songdb.py:1297 python/format.py:594
+#: python/format.py:615 python/format.py:701 python/format.py:722
+#: python/format.py:857 python/format.py:962 python/format.py:1012
+#: python/format.py:1022
 msgid "Bitrate"
 msgstr "Bitrate"
 
-#: python/songdb.py:793 python/songdb.py:1164
+#: python/songdb.py:911 python/songdb.py:1298
 msgid "Filename"
 msgstr "Nom du fichier"
 
 #. TC: Directory path to a file.
-#: python/songdb.py:795 python/songdb.py:1165
+#: python/songdb.py:913 python/songdb.py:1299
 msgid "Path"
 msgstr "Répertoire"
 
-#: python/songdb.py:800
+#: python/songdb.py:918
 msgid "Artist - Album - Title"
 msgstr "Artiste - Album - Titre"
 
-#: python/songdb.py:801
+#: python/songdb.py:919
 msgid "Album - [Disk] - Title"
 msgstr "Album - [Disque] - Titre"
 
-#: python/songdb.py:821
+#: python/songdb.py:939
 msgid "Fetching"
 msgstr "Découverte"
 
-#: python/songdb.py:953
+#: python/songdb.py:1084
 msgid "Tree fetch failed"
 msgstr "Echec de la découverte de l'arborescence"
 
-#: python/songdb.py:955
+#: python/songdb.py:1085
 msgid "Fetch Failed!"
 msgstr "Echec de la découverte!"
 
-#: python/songdb.py:968
+#: python/songdb.py:1098
 msgid "Populating"
 msgstr "Popularité"
 
-#: python/songdb.py:1094
+#: python/songdb.py:1224
 #, python-format
 msgid "Disk %d"
 msgstr "Disque %d"
 
 #. TC: User specified search filter entry box title text.
-#: python/songdb.py:1113
+#: python/songdb.py:1243
 msgid "Filters"
 msgstr "Filtres"
 
 #. TC: A type of search on any data field matching paritial strings.
-#: python/songdb.py:1125
+#: python/songdb.py:1255
 msgid "Fuzzy Search"
 msgstr "Recherche floue"
 
 #. TC: WHERE is an SQL keyword.
-#: python/songdb.py:1134
+#: python/songdb.py:1264
 msgid "WHERE"
-msgstr "LA_OU"
+msgstr "WHERE"
 
-#: python/songdb.py:1147
+#: python/songdb.py:1277
 msgid "Search"
 msgstr "Recherche"
 
-#: python/songdb.py:1440
-msgid "Catalogs"
+#: python/songdb.py:1514 python/songdb.py:1639
+msgid "Minutes"
 msgstr ""
 
-#: python/songdb.py:1445
+#: python/songdb.py:1514 python/songdb.py:1639
 #, fuzzy
+msgid "Hours"
+msgstr "Couleurs"
+
+#: python/songdb.py:1515 python/songdb.py:1639
+msgid "Days"
+msgstr ""
+
+#: python/songdb.py:1515 python/songdb.py:1639 python/songdb.py:1709
+#: python/songdb.py:1803
+msgid "Weeks"
+msgstr ""
+
+#: python/songdb.py:1609
+msgid "Catalogs"
+msgstr "Catalogues"
+
+#: python/songdb.py:1616
 msgid "Name"
-msgstr "Sans nom"
+msgstr "Nom"
 
-#: python/songdb.py:1446
+#: python/songdb.py:1617
 msgid "Catalog Path"
-msgstr ""
+msgstr "Chemin du Catalogue"
 
-#: python/songdb.py:1447
-#, fuzzy
+#: python/songdb.py:1618
 msgid "Prepend Path"
-msgstr "Avant"
+msgstr "Chemin Préfixe"
 
-#: python/songdb.py:1462
+#: python/songdb.py:1626
 #, fuzzy
+msgid "Last Played Scale"
+msgstr "Dernière lue"
+
+#: python/songdb.py:1658
 msgid "Path Peel"
-msgstr "Répertoire"
+msgstr "Chemin supprimable"
 
-#: python/songdb.py:1528
+#: python/songdb.py:1737
 msgid "N/A"
-msgstr ""
+msgstr "S/O"
 
-#: python/songdb.py:1703
+#: python/songdb.py:1918
 msgid "Failed to create FULLTEXT index"
-msgstr "Echec de la création de l'index PLEIN TEXTE"
+msgstr "Echec de la création de l'index TEXTE"
 
-#: python/songdb.py:1707
+#: python/songdb.py:1922
 msgid "Found existing FULLTEXT index"
-msgstr "Un index PLEIN TEXTE exite déjà"
+msgstr "Un index TEXTE exite déjà"
 
-#: python/songdb.py:1721 python/songdb.py:1734
+#: python/songdb.py:1936 python/songdb.py:1949
 msgid "Unrecognised database"
 msgstr "Base de données non reconnue"
 
-#: python/songdb.py:1729
+#: python/songdb.py:1944
 msgid "Found Prokyon 3 schema"
 msgstr "Schéma Prokyon 3 trouvé"
 
-#: python/playergui.py:235
+#: python/playergui.py:236
 msgid "Cuesheet Playlist"
 msgstr "Liste de lecture cuesheet"
 
 #. TC: Column heading, the track number.
-#: python/playergui.py:301
+#: python/playergui.py:302
 msgid "Trk"
 msgstr "Piste"
 
 #. TC: Column heading, the index number.
-#: python/playergui.py:304
+#: python/playergui.py:305
 msgid "Ind"
 msgstr "Index"
 
-#: python/playergui.py:413
+#: python/playergui.py:414
 msgid "External Playlist"
 msgstr "Liste de lecture externe"
 
 #. TC: Button text to activate an external playlist.
-#: python/playergui.py:424
+#: python/playergui.py:425
 msgid "Active"
 msgstr "Attivée"
 
@@ -2335,242 +2397,252 @@ msgstr "Créer une nouvelle annonce"
 msgid "Modify or Delete this announcement"
 msgstr "Modifier ou supprimer cette annonce"
 
-#. TC: Playlist control.
 #. TC: Embed a DJ announcement text into the playlist.
-#: python/playergui.py:528 python/playergui.py:3709 python/playergui.py:4347
+#: python/playergui.py:528 python/playergui.py:4430
 msgid "Announcement"
 msgstr "Annonce"
 
 #. TC: The time format as minutes and seconds.
-#: python/playergui.py:555
+#: python/playergui.py:556
 msgid "mm:ss"
 msgstr "mm:ss"
 
 #. TC: Alongside the name of the next track.
-#: python/playergui.py:608
+#: python/playergui.py:609
 msgid "Next track"
 msgstr "Piste suivante"
 
-#: python/playergui.py:933
+#: python/playergui.py:934
 msgid "By Extension"
 msgstr "Par extention"
 
-#: python/playergui.py:933
+#: python/playergui.py:934
 msgid "M3U playlist"
 msgstr "Liste de lecture M3U"
 
 #: python/playergui.py:934
+#, fuzzy
+msgid "M3U8 playlist"
+msgstr "Liste de lecture M3U"
+
+#: python/playergui.py:935
 msgid "XSPF playlist"
 msgstr "Liste de lecture XSPF"
 
-#: python/playergui.py:934
+#: python/playergui.py:935
 msgid "PLS playlist"
 msgstr "Liste de lecture PLS"
 
-#: python/playergui.py:1006
+#: python/playergui.py:1007
 #, python-format
 msgid "%d Audio Tracks"
 msgstr "%d pistes audio"
 
 #. TC: Missing metadata text.
-#: python/playergui.py:1016
+#: python/playergui.py:1017
 msgid "Unknown"
 msgstr "Inconnu"
 
-#: python/playergui.py:1020
+#: python/playergui.py:1021
 msgid "(Cue sheet)"
 msgstr "(Cue Sheet)"
 
-#: python/playergui.py:1054
+#: python/playergui.py:1058
 msgid "Bad Tag"
 msgstr "Tag erroné"
 
-#: python/playergui.py:1830 python/playergui.py:4185
+#: python/playergui.py:1888 python/playergui.py:4268
 msgid "Manual"
 msgstr "Manuel"
 
-#: python/playergui.py:1834 python/playergui.py:4182
+#: python/playergui.py:1892 python/playergui.py:4265
 msgid "Play All"
 msgstr "Tout jouer"
 
-#: python/playergui.py:1842 python/playergui.py:1851 python/playergui.py:4183
+#: python/playergui.py:1900 python/playergui.py:1909 python/playergui.py:4266
 msgid "Loop All"
 msgstr "Tout boucler"
 
-#: python/playergui.py:1842 python/playergui.py:4186
+#: python/playergui.py:1900 python/playergui.py:4269
 msgid "Cue Up"
 msgstr "Pré-écoute"
 
-#: python/playergui.py:1843 python/playergui.py:4190
+#: python/playergui.py:1901 python/playergui.py:4273
 msgid "Fade Over"
 msgstr "Fondu dessus"
 
-#: python/playergui.py:1855 python/playergui.py:1926 python/playergui.py:4184
+#: python/playergui.py:1913 python/playergui.py:1984 python/playergui.py:4267
 msgid "Random"
 msgstr "Aléatoire"
 
-#: python/playergui.py:1895 python/playergui.py:4187
+#: python/playergui.py:1953 python/playergui.py:4270
 msgid "External"
 msgstr "Externe"
 
-#: python/playergui.py:1907 python/playergui.py:1923 python/playergui.py:4189
+#: python/playergui.py:1965 python/playergui.py:1981 python/playergui.py:4272
 msgid "Alternate"
 msgstr "Alternatif"
 
-#: python/playergui.py:1907 python/playergui.py:1925 python/playergui.py:4191
+#: python/playergui.py:1965 python/playergui.py:1983 python/playergui.py:4274
 msgid "Random Hop"
 msgstr "Hop aléatoire"
 
 #. TC: The remaining playlist time.
-#: python/playergui.py:2080 python/playergui.py:2086
+#: python/playergui.py:2138 python/playergui.py:2144
 msgid "Remaining"
 msgstr "Restant"
 
 #. TC: The estimated finish time of the playlist.
 #. TC: The estimated finish time of the playlist (ETA).
-#: python/playergui.py:2082 python/playergui.py:2086 python/playergui.py:2100
+#: python/playergui.py:2140 python/playergui.py:2144 python/playergui.py:2158
 msgid "Finish"
 msgstr "Fini"
 
 #. TC: The play duration of the block of audio tracks.
-#: python/playergui.py:2087 python/playergui.py:2098
+#: python/playergui.py:2145 python/playergui.py:2156
 msgid "Block size"
 msgstr "Taille de block"
 
 #. TC: File dialog title text.
-#: python/playergui.py:2485
+#: python/playergui.py:2546
 msgid "Add music to left playlist"
 msgstr "Ajouter de la musique à la liste de gauche"
 
 #. TC: File dialog title text.
-#: python/playergui.py:2488
+#: python/playergui.py:2549
 msgid "Add music to right playlist"
 msgstr "Ajouter de la musique à la liste de droite"
 
-#: python/playergui.py:2490
+#: python/playergui.py:2551
 msgid "Add background music"
 msgstr "ajouter une musique de fond"
 
 #. TC: File filter text.
-#: python/playergui.py:2502
+#: python/playergui.py:2563
 msgid "Supported Media Formats"
 msgstr "Formats de média supportés"
 
 #. TC: Expander text "Select File Type (.pls)" for the pls file type.
-#: python/playergui.py:2564
+#: python/playergui.py:2625
 msgid "Select File Type"
 msgstr "Sélectionner le type de fichier"
 
-#: python/playergui.py:3308
+#: python/playergui.py:3383
 msgid "Save left playlist"
 msgstr "Sauvegarder la liste de lecture de gauche"
 
-#: python/playergui.py:3310
+#: python/playergui.py:3385
 msgid "Save right playlist"
 msgstr "Sauvegarder la liste de lecture de droite"
 
-#: python/playergui.py:3312
+#: python/playergui.py:3387
 msgid "Save background playlist"
 msgstr "Sauvegarder la liste de lecture de fond"
 
-#: python/playergui.py:3330
+#: python/playergui.py:3405
 msgid "File Type"
 msgstr "Type de fichier"
 
-#: python/playergui.py:3335
+#: python/playergui.py:3410
 msgid "Extension"
 msgstr "Extention"
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to do a ten second fade to the next track.
-#: python/playergui.py:3693 python/playergui.py:4358
+#: python/playergui.py:3774 python/playergui.py:4441
 msgid "Fade 10s"
 msgstr "Fondu 10s"
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to do a five second fade to the next track.
-#: python/playergui.py:3699 python/playergui.py:4365
+#: python/playergui.py:3780 python/playergui.py:4448
 msgid "Fade 5s"
 msgstr "Fondu 5s"
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to not do a fade to the next track.
-#: python/playergui.py:3704 python/playergui.py:4372
+#: python/playergui.py:3785 python/playergui.py:4455
 msgid "No Fade"
 msgstr "Aucun Fondu"
 
 #. TC: Playlist control.
-#: python/playergui.py:3714
+#: python/playergui.py:3793
 msgid ">> Normal Speed <<"
 msgstr ">> Vitesse normale <<"
 
 #. TC: Playlist control.
-#: python/playergui.py:3724
+#: python/playergui.py:3803
 msgid "Player stop 2"
 msgstr "Arret Lecteur 2"
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to jump to the top of the playlist.
-#: python/playergui.py:3729 python/playergui.py:4324
+#: python/playergui.py:3808 python/playergui.py:4407
 msgid "Jump To Top"
 msgstr "Retour en haut"
 
 #. TC: Playlist control.
-#: python/playergui.py:3734 python/playergui.py:4384
+#: python/playergui.py:3813 python/playergui.py:4467
 msgid "Stop streaming"
 msgstr "Arret du flux"
 
 #. TC: Playlist control.
-#: python/playergui.py:3739 python/playergui.py:4392
+#: python/playergui.py:3818 python/playergui.py:4475
 msgid "Stop recording"
 msgstr "Arret de l'enregistrement"
 
+#: python/playergui.py:3851
+#, fuzzy
+msgid "Announcement:"
+msgstr "Annonce"
+
 #. TC: Playlist control.
-#: python/playergui.py:3774
+#: python/playergui.py:3857
 msgid ">>> Transfer across >>>"
 msgstr ">>> Transfer en face >>>"
 
 #. TC: Playlist control.
-#: python/playergui.py:3777
+#: python/playergui.py:3860
 msgid "<<< Transfer across <<<"
 msgstr "<<< Transfer en face <<<"
 
 #. TC: Playlist control.
-#: python/playergui.py:3782
+#: python/playergui.py:3865
 msgid ">>> Fade across >>>"
 msgstr ">>> Fondu en face >>>"
 
 #. TC: Playlist control.
-#: python/playergui.py:3785
+#: python/playergui.py:3868
 msgid "<<< Fade across <<<"
 msgstr "<<< Fondu en face <<<"
 
 #. TC: Playlist control.
-#: python/playergui.py:3791
+#: python/playergui.py:3874
 msgid "Ignored playlist control"
 msgstr "Contrôle de liste de lecture ignoré"
 
-#: python/playergui.py:3859
+#: python/playergui.py:3942
+#, python-brace-format
 msgid "Playing track {0} of {1}"
 msgstr "Lecture piste {0} sur {1}"
 
 #. TC: Previous line: Playing track {0} of {1}
-#: python/playergui.py:3872
+#: python/playergui.py:3955
 #, python-format
 msgid "From the album, %s"
 msgstr "De l'album, %s"
 
-#: python/playergui.py:3879
+#: python/playergui.py:3962
 #, python-format
 msgid "Total number of tracks %d"
 msgstr "Nombre de piste total %d"
 
-#: python/playergui.py:3883 python/playergui.py:3885
+#: python/playergui.py:3966 python/playergui.py:3968
 #, python-format
 msgid "Total play duration %s"
 msgstr "Durée totale %s"
 
-#: python/playergui.py:3935
+#: python/playergui.py:4018
 msgid ""
 "Left click toggles between showing the amount of time elapsed or remaining "
 "on the current track being played."
@@ -2578,7 +2650,7 @@ msgstr ""
 "Clic à gauche pour afficher le temps écoulé ou le temps restant pour la "
 "piste en cours de reproduction."
 
-#: python/playergui.py:3953
+#: python/playergui.py:4036
 msgid ""
 "This slider acts as both a play progress indicator and as a means for "
 "seeking within the currently playing track."
@@ -2587,15 +2659,16 @@ msgstr ""
 "positionneur dans la piste en cours de reproduction."
 
 #. TC: File filter text.
-#: python/playergui.py:4042
+#: python/playergui.py:4125
 msgid "All file types"
 msgstr "Tout type de fichier"
 
-#: python/playergui.py:4047
-msgid "Playlist types (*.m3u, *.xspf, *.pls)"
-msgstr "Type de listes de lecture (*.m3u, *.xspf, *.pls)"
+#: python/playergui.py:4130
+#, fuzzy
+msgid "Playlist types"
+msgstr "Liste de lecture 1"
 
-#: python/playergui.py:4062
+#: python/playergui.py:4145
 msgid ""
 "'Block size' indicates the amount of time that it will take to play from the "
 "currently selected track to the next stop.\n"
@@ -2607,43 +2680,43 @@ msgstr ""
 "«Restant» indique le temps restant avant le prochain arret.\n"
 "«Fin» est le temps calculé lorsque la piste aura fini d'être lue."
 
-#: python/playergui.py:4085
+#: python/playergui.py:4168
 msgid "This adjusts the playback speed anywhere from 25% to 400%."
 msgstr "Ajuste la vitesse de reproduction entre 25% et 400%."
 
-#: python/playergui.py:4099
+#: python/playergui.py:4182
 msgid "This sets the playback speed back to normal."
 msgstr "Remet la vitesse de reproduction à sa valeur normale."
 
-#: python/playergui.py:4116
+#: python/playergui.py:4199
 msgid "Previous track."
 msgstr "Piste précédente"
 
-#: python/playergui.py:4128
+#: python/playergui.py:4211
 msgid "Play."
 msgstr "Lecture"
 
-#: python/playergui.py:4138
+#: python/playergui.py:4221
 msgid "Pause."
 msgstr "Pause"
 
-#: python/playergui.py:4148
+#: python/playergui.py:4231
 msgid "Stop."
 msgstr "Arret"
 
-#: python/playergui.py:4158
+#: python/playergui.py:4241
 msgid "Next track."
 msgstr "Piste suivante"
 
-#: python/playergui.py:4170
+#: python/playergui.py:4253
 msgid "Add tracks to the playlist."
 msgstr "Ajouter des pistes à la liste"
 
-#: python/playergui.py:4177 python/preferences.py:70
+#: python/playergui.py:4260 python/preferences.py:71
 msgid "Playlist Mode"
 msgstr "Mode de la liste de lecture"
 
-#: python/playergui.py:4196
+#: python/playergui.py:4279
 msgid ""
 "This sets the playlist mode which defines player behaviour after a track has "
 "finished playing.\n"
@@ -2708,31 +2781,31 @@ msgstr ""
 "opposée."
 
 #. TC: Fade time heading.
-#: python/playergui.py:4220 python/preferences.py:71
+#: python/playergui.py:4303 python/preferences.py:72
 msgid "Fade"
 msgstr "Fondu"
 
-#: python/playergui.py:4232
+#: python/playergui.py:4315
 msgid "This controls the amount of fade between tracks."
 msgstr "Contrôle le taux de fondu entre les pistes."
 
-#: python/playergui.py:4239
+#: python/playergui.py:4322
 msgid "Audio Feed"
 msgstr "Audio Feed"
 
-#: python/playergui.py:4249
+#: python/playergui.py:4332
 msgid "Make output from this player available for streaming."
 msgstr "Rendre la sortie de ce lecteur disponible pour le flux"
 
-#: python/playergui.py:4257
+#: python/playergui.py:4340
 msgid "Make output from this player audible to the DJ."
 msgstr "Rendre la sortie de ce lecteur audible au DJ"
 
-#: python/playergui.py:4259
+#: python/playergui.py:4342
 msgid "Force"
 msgstr "Forcer"
 
-#: python/playergui.py:4265
+#: python/playergui.py:4348
 msgid ""
 "When selected this player will be treated like a main player.\n"
 "It will be affected by microphone ducking and won't mute when a main player "
@@ -2743,142 +2816,142 @@ msgstr ""
 "lecteur principal est en fonction."
 
 #. TC: Insert playlist control.
-#: python/playergui.py:4278
+#: python/playergui.py:4361
 msgid "Insert control"
 msgstr "Insérer un contrôle"
 
 #. TC: The Item submenu.
-#: python/playergui.py:4287
+#: python/playergui.py:4370
 msgid "Item"
 msgstr "Elément"
 
 #. TC: The Playlist submenu.
-#: python/playergui.py:4292
+#: python/playergui.py:4375
 msgid "Playlist"
 msgstr "Liste de lecture"
 
 #. TC: Insert playlist control to set playback speed to normal.
-#: python/playergui.py:4303
+#: python/playergui.py:4386
 msgid "Normal Speed"
 msgstr "Vitesse normale"
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4332 python/playergui.py:4486
+#: python/playergui.py:4415 python/playergui.py:4569
 msgid "Transfer"
 msgstr "Transfer"
 
-#: python/playergui.py:4340
+#: python/playergui.py:4423
 msgid "Crossfade"
 msgstr "Crossfader"
 
 #. TC: Menu item. Opens the metadata tagger on the selected track.
-#: python/playergui.py:4405
+#: python/playergui.py:4488
 msgid "Meta Tag"
 msgstr "Méta Tag"
 
 #. TC: Menu Item. Duplicates the selected track in the playlist.
-#: python/playergui.py:4411
+#: python/playergui.py:4494
 msgid "Duplicate"
 msgstr "Dupliquer"
 
 #. TC: Menu Item. Remove the selected track.
-#: python/playergui.py:4418
+#: python/playergui.py:4501
 msgid "Remove"
 msgstr "Supprimer"
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4429
+#: python/playergui.py:4512
 msgid "This"
 msgstr "Ceci"
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4436 python/preferences.py:1234
+#: python/playergui.py:4519 python/preferences.py:1237
 msgid "All"
 msgstr "Tout"
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4443
+#: python/playergui.py:4526
 msgid "From Here"
 msgstr "Depuis ici"
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4450
+#: python/playergui.py:4533
 msgid "To Here"
 msgstr "Jusqu'ici"
 
 #. TC: Open the file dialog for adding music to the chosen playlist.
-#: python/playergui.py:4463
+#: python/playergui.py:4546
 msgid "Add Music"
 msgstr "Ajouter de la musique"
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4470
+#: python/playergui.py:4553
 msgid "Save"
 msgstr "Sauvegarder"
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4481
+#: python/playergui.py:4564
 msgid "Copy"
 msgstr "Copier"
 
-#: python/playergui.py:4492
+#: python/playergui.py:4575
 msgid "Exchange"
 msgstr "Echanger"
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4499
+#: python/playergui.py:4582
 msgid "Empty"
 msgstr "Vide"
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4513 python/playergui.py:4552
+#: python/playergui.py:4596 python/playergui.py:4635
 msgid "Append"
 msgstr "Après"
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4520 python/playergui.py:4559
+#: python/playergui.py:4603 python/playergui.py:4642
 msgid "Prepend"
 msgstr "Avant"
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
-#: python/playergui.py:4531
+#: python/playergui.py:4614
 msgid "Append Cursor"
 msgstr "Ajouter après le curseur"
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
-#: python/playergui.py:4538
+#: python/playergui.py:4621
 msgid "Prepend Cursor"
 msgstr "Ajouter avant le curseur"
 
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4570
+#: python/playergui.py:4653
 msgid "Append at Cursor"
 msgstr "Ajouter après au curseur"
 
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4577
+#: python/playergui.py:4660
 msgid "Prepend at Cursor"
 msgstr "Ajouter avant au curseur"
 
-#: python/preferences.py:84
+#: python/preferences.py:85
 msgid "Track time elapsed"
 msgstr "Tempo écoulé"
 
-#: python/preferences.py:86
+#: python/preferences.py:87
 msgid "Track time remaining"
 msgstr "Temps restant"
 
-#: python/preferences.py:88
+#: python/preferences.py:89
 msgid "Audio to stream"
 msgstr "Audio vers flux"
 
-#: python/preferences.py:89
+#: python/preferences.py:90
 msgid "Audio to DJ"
 msgstr "Audio vers DJ"
 
-#: python/preferences.py:126
+#: python/preferences.py:127
 #, python-format
 msgid ""
 "Stereo panning is the selection of where an audio source sits from left to "
@@ -2905,11 +2978,11 @@ msgstr ""
 "L'appairage des canaux doit être laissé à 100% gauche/droite à moins que la "
 "réduction du champ stéréo ne soit votre intention."
 
-#: python/preferences.py:157
+#: python/preferences.py:158
 msgid "Presets"
 msgstr "Présélections"
 
-#: python/preferences.py:248
+#: python/preferences.py:249
 msgid ""
 "The pan preset selection buttons.\n"
 "\n"
@@ -2927,40 +3000,40 @@ msgstr ""
 "Note : Une préconfiguration des présélections est nécessaire."
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:273
+#: python/preferences.py:274
 msgid "Deactivated"
 msgstr "Désactivé"
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:275
+#: python/preferences.py:276
 msgid "Basic input"
 msgstr "Entrée de base"
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:277
+#: python/preferences.py:278
 msgid "Processed input"
 msgstr "Ingresso elaborato"
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:279
+#: python/preferences.py:280
 #, python-format
 msgid "Partnered with channel %s"
 msgstr "Associer au canal %s"
 
-#: python/preferences.py:429
+#: python/preferences.py:432
 msgid "A label so you may describe briefly the role of this audio channel."
 msgstr "Un label décrivant brièvement le rôle de ce canal audio."
 
-#: python/preferences.py:461
+#: python/preferences.py:464
 msgid "The signal processing mode."
 msgstr "Mode de traitement du signal"
 
 #. TC: A frame heading. The channel opener is selected within.
-#: python/preferences.py:465
+#: python/preferences.py:468
 msgid "Channel Opener"
 msgstr "Ouvreur de canal"
 
-#: python/preferences.py:468
+#: python/preferences.py:471
 msgid ""
 "This controls the allocation of front panel open/unmute buttons. Having one "
 "button control multiple microphones can save time."
@@ -2969,28 +3042,28 @@ msgstr ""
 "un bouton pour contrôler plusieurs micro peut faire gagner du temps."
 
 #. TC: Spinbutton label text.
-#: python/preferences.py:475
+#: python/preferences.py:478
 msgid "Main Panel Button"
 msgstr "Boutton du paneau principal"
 
-#: python/preferences.py:492
+#: python/preferences.py:495
 msgid "This:"
 msgstr "Ceci :"
 
-#: python/preferences.py:501
+#: python/preferences.py:504
 msgid "Open"
 msgstr "Ouvrir"
 
-#: python/preferences.py:514
+#: python/preferences.py:517
 msgid "Stereo Panning"
 msgstr "Panoramique Stéréo"
 
 #. TC: A set of controls that perform audio signal matching.
-#: python/preferences.py:527
+#: python/preferences.py:530
 msgid "Signal Matching"
 msgstr "Correspondance de signal"
 
-#: python/preferences.py:528
+#: python/preferences.py:531
 msgid ""
 "These controls are provided to obtain a decent match between the two "
 "microphones."
@@ -2998,17 +3071,17 @@ msgstr ""
 "Ces contrôles sont mis à disposition pour obtenir une correction de gain "
 "convenable entre les micros."
 
-#: python/preferences.py:537
+#: python/preferences.py:540
 msgid "Relative Gain (dB)"
 msgstr "Gain relatif (dB)"
 
 #. TC: Mic audio phase inversion control.
-#: python/preferences.py:542 python/preferences.py:547
+#: python/preferences.py:545 python/preferences.py:550
 msgid "Invert Signal"
 msgstr "Invercer le signal"
 
-#: python/preferences.py:548 python/preferences.py:568
-#: python/preferences.py:664
+#: python/preferences.py:551 python/preferences.py:571
+#: python/preferences.py:667
 msgid ""
 "Useful for when microphones are cancelling one another out, producing a "
 "hollow sound."
@@ -3016,41 +3089,41 @@ msgstr ""
 "Utile lorsque les micros s'annulent mutuellement provoquant un son caverneux."
 
 #. TC: Control whether to mix microphone audio to the DJ mix.
-#: python/preferences.py:551
+#: python/preferences.py:554
 msgid "In The DJ's Mix"
 msgstr "Dans le mix du DJ"
 
-#: python/preferences.py:552 python/preferences.py:574
-#: python/preferences.py:674
+#: python/preferences.py:555 python/preferences.py:577
+#: python/preferences.py:677
 msgid ""
 "Make the microphone audio audible in the DJ mix. This may not always be "
 "desirable."
 msgstr ""
 "Rendre le micro audio audible dans le mix DJ. Ce n'est pas toujour désiré."
 
-#: python/preferences.py:560
+#: python/preferences.py:563
 msgid "Basic Controls"
 msgstr "Contrôles de base"
 
-#: python/preferences.py:561 python/preferences.py:616
+#: python/preferences.py:564 python/preferences.py:619
 msgid "Boost/Cut (dB)"
 msgstr "Augmenter/Couper (dB)"
 
-#: python/preferences.py:582
+#: python/preferences.py:585
 msgid "High Pass Filter"
 msgstr "Filtre passe haut"
 
-#: python/preferences.py:583 python/preferences.py:598
-#: python/preferences.py:608
+#: python/preferences.py:586 python/preferences.py:601
+#: python/preferences.py:611
 msgid "Cutoff Frequency"
 msgstr "Fréquence de coupure"
 
 #. TC: User can set the number of filter stages.
-#: python/preferences.py:587
+#: python/preferences.py:590
 msgid "Stages"
 msgstr "Passes"
 
-#: python/preferences.py:590
+#: python/preferences.py:593
 msgid ""
 "Frequency in Hertz above which audio can pass to later stages. Use this "
 "feature to restrict low frequency sounds such as mains hum. Setting too high "
@@ -3062,55 +3135,55 @@ msgstr ""
 "sonnera aiguë."
 
 #. TC: this is the treble control. HF = high frequency.
-#: python/preferences.py:595
+#: python/preferences.py:598
 msgid "HF Detail"
 msgstr "Détails HF"
 
-#: python/preferences.py:602
+#: python/preferences.py:605
 msgid "You can use this to boost the amount of treble in the audio."
 msgstr "Vous pouvez l'utiliser pour augmenter le taux d'aiguës dans l'audio."
 
 #. TC: this is the bass control. LF = low frequency.
-#: python/preferences.py:605
+#: python/preferences.py:608
 msgid "LF Detail"
 msgstr "Détails LF"
 
-#: python/preferences.py:612
+#: python/preferences.py:615
 msgid "You can use this to boost the amount of bass in the audio."
 msgstr "Vous pouvez l'utiliser pour augmenter le taux de basses dans l'audio."
 
 #. TC: lookahead brick wall limiter.
-#: python/preferences.py:615
+#: python/preferences.py:618
 msgid "Limiter"
 msgstr "Limiteur"
 
 #. TC: this is the peak signal limit.
-#: python/preferences.py:620
+#: python/preferences.py:623
 msgid "Upper Limit"
 msgstr "Limite supérieure"
 
-#: python/preferences.py:622
+#: python/preferences.py:625
 msgid ""
 "A look-ahead brick-wall limiter. Audio signals are capped at the upper limit."
 msgstr ""
 "Un limiteur prédictif. Les signaux audio sont bloqués à la limite supérieure."
 
-#: python/preferences.py:625
+#: python/preferences.py:628
 msgid "Noise Gate"
 msgstr "Noise Gate"
 
 #. TC: noise gate triggers at this level.
-#: python/preferences.py:627
+#: python/preferences.py:630
 msgid "Threshold"
 msgstr "Profondeur"
 
 #. TC: negative gain when the noise gate is active.
 #. TC: The de-esser attenuation in ess-detected state.
-#: python/preferences.py:631 python/preferences.py:641
+#: python/preferences.py:634 python/preferences.py:644
 msgid "Gain"
 msgstr "Gain"
 
-#: python/preferences.py:633
+#: python/preferences.py:636
 msgid ""
 "Reduce the unwanted quietest sounds and background noise which you don't "
 "want your listeners to hear with this."
@@ -3118,16 +3191,16 @@ msgstr ""
 "Réduit les sons faibles non désirés et le bruit de fond que vous ne désirez "
 "transmettre aux auditeurs."
 
-#: python/preferences.py:636
+#: python/preferences.py:639
 msgid "De-esser"
 msgstr "De-esser"
 
 #. TC: Bias has a numeric setting.
-#: python/preferences.py:638
+#: python/preferences.py:641
 msgid "Bias"
 msgstr "Bias"
 
-#: python/preferences.py:643
+#: python/preferences.py:646
 msgid ""
 "Reduce the S, T, and P sounds which microphones tend to exaggerate. Ideally "
 "the Bias control will be set low so that the de-esser is off when there is "
@@ -3138,19 +3211,19 @@ msgstr ""
 "esseur soit inopérant lorsqu'il y a du silence mais suffisament haut pour "
 "que les clics de la souris soient détectés et éliminés."
 
-#: python/preferences.py:648
+#: python/preferences.py:651
 msgid "Ducker"
 msgstr "Atténuateur"
 
-#: python/preferences.py:649
+#: python/preferences.py:652
 msgid "Release"
 msgstr "Relâche"
 
-#: python/preferences.py:652
+#: python/preferences.py:655
 msgid "Hold"
 msgstr "Maintenu"
 
-#: python/preferences.py:655
+#: python/preferences.py:658
 msgid ""
 "The ducker automatically reduces the level of player audio when the DJ "
 "speaks. These settings allow you to adjust the timings of that audio "
@@ -3160,15 +3233,15 @@ msgstr ""
 "parle. Ces paramêtres permettent l'ajustement de la durée de "
 "l'affaiblissement audio."
 
-#: python/preferences.py:659
+#: python/preferences.py:662
 msgid "Other options"
 msgstr "Autres options"
 
-#: python/preferences.py:666
+#: python/preferences.py:669
 msgid "Phase Rotator"
 msgstr "Rotacteur de phase"
 
-#: python/preferences.py:669
+#: python/preferences.py:672
 msgid ""
 "This feature processes the microphone audio so that it sounds more even. The "
 "effect is particularly noticable on male voices."
@@ -3176,34 +3249,34 @@ msgstr ""
 "Cette fonctionalité traite le micro pour qu'il paraisse plus présent. Cet "
 "effet est plus audible avec les voix mâles."
 
-#: python/preferences.py:852
+#: python/preferences.py:855
 msgid "The volume control for the left music player."
 msgstr "Contrôle de volume du lecteur de gauche."
 
 #. TC: preferences window title.
-#: python/preferences.py:908
+#: python/preferences.py:911
 msgid "IDJC Preferences"
 msgstr "Préférences de IDJC"
 
 #. TC: The DJ's sound level controller.
-#: python/preferences.py:933
+#: python/preferences.py:936
 msgid "DJ Audio Level"
 msgstr "Niveau audio DJ"
 
-#: python/preferences.py:945
+#: python/preferences.py:948
 msgid "This adjusts the sound level of the DJ audio."
 msgstr "Ajuste le niveau sonore du canal audio DJ."
 
 #. TC: The alarm sound level.
-#: python/preferences.py:950
+#: python/preferences.py:953
 msgid "Alarm Level"
 msgstr "Niveau de l'alarme"
 
-#: python/preferences.py:964
+#: python/preferences.py:967
 msgid "Music Loudness Compensation"
 msgstr "Compensation Loudness"
 
-#: python/preferences.py:962
+#: python/preferences.py:965
 #, python-format
 msgid ""
 "This adjusts the sound level of the DJ alarm. Typically this should be set "
@@ -3214,11 +3287,11 @@ msgstr ""
 "alentours du niveau audio du DJ lorsque la fonction «%s» est utilisée, ou "
 "sinon un petit peu plus fort."
 
-#: python/preferences.py:970
+#: python/preferences.py:973
 msgid "Player Resample Quality"
 msgstr "Qualité de rééchantillonnage du lecteur"
 
-#: python/preferences.py:976
+#: python/preferences.py:979
 msgid ""
 "This adjusts the quality of the audio resampling method used whenever the "
 "sample rate of the music file currently playing does not match the sample "
@@ -3232,52 +3305,52 @@ msgstr ""
 "aussi plus de puissance CPU (non recommendé pour les systèmes d'avant 2006). "
 "Tous ces modes donne une qualité correcte."
 
-#: python/preferences.py:984
+#: python/preferences.py:987
 msgid "Best"
 msgstr "Meilleure"
 
-#: python/preferences.py:993
+#: python/preferences.py:996 python/format.py:512
 msgid "Medium"
 msgstr "Moyenne"
 
-#: python/preferences.py:1002
+#: python/preferences.py:1005
 msgid "Fast"
 msgstr "Rapide"
 
 #. TC: the set of features - section heading.
-#: python/preferences.py:1017
+#: python/preferences.py:1020
 msgid "Feature Set"
 msgstr "Liste de fonctionalités"
 
 #. TC: Start in the full featured user interface mode.
-#: python/preferences.py:1029
+#: python/preferences.py:1032
 msgid "Start Full"
 msgstr "Démarrer avec tout"
 
-#: python/preferences.py:1034 python/preferences.py:1042
+#: python/preferences.py:1037 python/preferences.py:1045
 msgid "Indicates which mode IDJC will be in when launched."
 msgstr "Indique quel sera le mode de IDJC au démarrage."
 
 #. TC: Start in a reduced user interface mode.
-#: python/preferences.py:1037
+#: python/preferences.py:1040
 msgid "Start Mini"
 msgstr "Démarrer avec le minimum"
 
-#: python/preferences.py:1050
+#: python/preferences.py:1053
 msgid "Fully Featured"
 msgstr "Toutes les fonctionalités"
 
-#: python/preferences.py:1055
+#: python/preferences.py:1058
 msgid "Run in full functionality mode which uses more CPU power."
 msgstr ""
 "Exécuter dans le mode toutes fonctionalités qui utilise plus de puissance "
 "CPU."
 
-#: python/preferences.py:1057
+#: python/preferences.py:1060
 msgid "Basic Streamer"
 msgstr "Streamer de base"
 
-#: python/preferences.py:1061
+#: python/preferences.py:1064
 msgid ""
 "Run in a reduced functionality mode that lowers the burden on the CPU and "
 "takes up less screen space."
@@ -3285,43 +3358,43 @@ msgstr ""
 "Exécuter dans le mode fonctionalités réduites qui utilise moins de puissance "
 "CPU et utilise moins d'espace à l'écran."
 
-#: python/preferences.py:1069
+#: python/preferences.py:1072
 msgid "These settings take effect after restarting"
 msgstr "Ces paramêtres ne prennent effet qu'après un redémarrage."
 
-#: python/preferences.py:1090
+#: python/preferences.py:1093
 msgid "Reserve 24 sound effects slots"
 msgstr "Réserver 24 slots d'effets sonores"
 
-#: python/preferences.py:1091
+#: python/preferences.py:1094
 msgid "Only 12"
 msgstr "Seulement 12"
 
-#: python/preferences.py:1103
+#: python/preferences.py:1106
 msgid "Audio input channels"
 msgstr "Canaux audio en entrée"
 
-#: python/preferences.py:1108
+#: python/preferences.py:1111
 msgid "Simultaneous stream(s)"
 msgstr "Transmission(ws) simultanée(s)"
 
-#: python/preferences.py:1114
+#: python/preferences.py:1117
 msgid "Simultaneous recording(s)"
 msgstr "Enregistrement(s) simultané(s)"
 
-#: python/preferences.py:1168
+#: python/preferences.py:1171
 msgid "Fill channel meter void space"
 msgstr "Remplir l'espace libre du vu-mêtre du canal"
 
-#: python/preferences.py:1180
+#: python/preferences.py:1183
 msgid "Player Loudness Normalisation"
 msgstr "Normalisation du Loudness du lecteur"
 
-#: python/preferences.py:1191
+#: python/preferences.py:1194
 msgid "Indicate which tracks have loudness metadata"
 msgstr "Indique quelles pistes ont une métadonnée de Loudness."
 
-#: python/preferences.py:1192
+#: python/preferences.py:1195
 msgid ""
 "Shows a marker in the playlists next to each track. Either a green circle or "
 "a red triangle."
@@ -3329,19 +3402,19 @@ msgstr ""
 "Affiche un marqueur à côté de chaque piste dans les listes de lecture. Soit "
 "un cercle vert, soit un triangle rouge."
 
-#: python/preferences.py:1200
+#: python/preferences.py:1203
 msgid "Adjust playback volume in dB"
 msgstr "Ajuste le volume de rendu en dB"
 
-#: python/preferences.py:1201
+#: python/preferences.py:1204
 msgid "Effective only on newly started tracks."
 msgstr "Effectif uniquement pour les pistes nouvellement jouées."
 
-#: python/preferences.py:1207
+#: python/preferences.py:1210
 msgid "R128"
 msgstr "R128"
 
-#: python/preferences.py:1211
+#: python/preferences.py:1214
 msgid ""
 "It may not be desirable to use the default level since it is rather quiet. "
 "This should be set 4 or 5 dB higher than the ReplayGain setting."
@@ -3350,11 +3423,11 @@ msgstr ""
 "est plutot bas. Il doit se situer 4 ou 5 dB plus haut que le réglage de Gain "
 "Replay."
 
-#: python/preferences.py:1216
+#: python/preferences.py:1219
 msgid "ReplayGain"
 msgstr "Gain Replay"
 
-#: python/preferences.py:1220
+#: python/preferences.py:1223
 msgid ""
 "It may not be desirable to use the default level since it is rather quiet. "
 "This should be set 4 or 5 dB lower than the R128 setting."
@@ -3362,11 +3435,11 @@ msgstr ""
 "Il peut ne pas être souhaitable d'utiliser le volume par défaut puisqu'il "
 "est plutot bas. Il doit se situer 4 ou 5 dB plus bas que le réglage du R128."
 
-#: python/preferences.py:1225
+#: python/preferences.py:1228
 msgid "Untagged"
 msgstr "Non taggé"
 
-#: python/preferences.py:1229
+#: python/preferences.py:1232
 msgid ""
 "Set this so that any unmarked tracks are playing at a roughly similar "
 "loudness level as the marked ones."
@@ -3374,15 +3447,15 @@ msgstr ""
 "Cocher pour que toutes les pistes non taggés soient jouées approximativement "
 "au même volume que celle qui le sont."
 
-#: python/preferences.py:1238
+#: python/preferences.py:1241
 msgid "A master level control for the media players."
 msgstr "Un contrôle maitre pour les Lecteurs."
 
-#: python/preferences.py:1249
+#: python/preferences.py:1252
 msgid "Recorder Filename (excluding the file extension)"
 msgstr "Non du fichier d'enregistrement (sans extention)"
 
-#: python/preferences.py:1250
+#: python/preferences.py:1253
 msgid ""
 "The specifiers are $r for the number of the recorder with the rest being "
 "documented in the strftime man page.\n"
@@ -3394,23 +3467,23 @@ msgstr ""
 "Les utilisateurs peuvent modifier ceci pour rendre les noms de fichiers "
 "compatibles avec certains systèmes de fichiers."
 
-#: python/preferences.py:1267
+#: python/preferences.py:1270
 msgid "Miscellaneous Features"
 msgstr "Fonctionalités diverses"
 
-#: python/preferences.py:1276
+#: python/preferences.py:1279
 msgid "Trim quiet song endings and trailing silence"
 msgstr "Eliminer les silences de début et de fin de pistes"
 
-#: python/preferences.py:1282
+#: python/preferences.py:1285
 msgid "End tracks containing long passages of silence"
 msgstr "Terminer les pistes contenant de long segments muets"
 
-#: python/preferences.py:1288
+#: python/preferences.py:1291
 msgid "Enable the main-player speed/pitch controls"
 msgstr "Activer les contrôles de tonalité/vitesse du lecteur principal"
 
-#: python/preferences.py:1292
+#: python/preferences.py:1295
 msgid ""
 "This option causes some extra widgets to appear below the playlists which "
 "allow the playback speed to be adjusted from 25% to 400% and a normal speed "
@@ -3420,11 +3493,11 @@ msgstr ""
 "pour permettre l'ajustement de la vitesse entre 25 rt 400% ainsi qu'un "
 "bouton vitesse normale."
 
-#: python/preferences.py:1297
+#: python/preferences.py:1300
 msgid "Separate left/right player volume faders"
 msgstr "Séparrer les curseurs de volume gauche et droite"
 
-#: python/preferences.py:1301
+#: python/preferences.py:1304
 msgid ""
 "Select this option to use an independent volume fader for the left and right "
 "music players."
@@ -3432,11 +3505,11 @@ msgstr ""
 "Choisir cette option pour avoir des boutons de fader indépendants pour les "
 "lecteurs de gauche et de droite."
 
-#: python/preferences.py:1305
+#: python/preferences.py:1308
 msgid "Enlarge the time elapsed/remaining windows"
 msgstr "Elargir les fenêtres de temps écoulé/restant"
 
-#: python/preferences.py:1309
+#: python/preferences.py:1312
 msgid ""
 "The time elapsed/remaining windows sometimes don't appear big enough for the "
 "text that appears in them due to unusual DPI settings or the use of a "
@@ -3446,11 +3519,11 @@ msgstr ""
 "pour contenir tout le texte pour cause de DPI inabituel ou d'un moteur de "
 "rendu différent. Cette option peut remédier à ce défaut."
 
-#: python/preferences.py:1315
+#: python/preferences.py:1318
 msgid "Sound an alarm when the music is due to end"
 msgstr "Jouer une alarme lorsque la musique arrive à sa fin"
 
-#: python/preferences.py:1318
+#: python/preferences.py:1321
 msgid ""
 "An alarm tone alerting the DJ that dead-air is just nine seconds away. This "
 "also works when monitoring stream audio but the alarm tone is not sent to "
@@ -3464,11 +3537,11 @@ msgstr ""
 "\n"
 "Le mode freewheel de JACK est également désengagé automatiquement."
 
-#: python/preferences.py:1328
+#: python/preferences.py:1331
 msgid "Apply dither to 16 bit PCM playback"
 msgstr "Appliquer un adoucissement au rendu 16 bits PCM"
 
-#: python/preferences.py:1332
+#: python/preferences.py:1335
 msgid ""
 "This feature maybe improves the sound quality a little when listening on a "
 "24 bit sound card."
@@ -3476,11 +3549,11 @@ msgstr ""
 "Cette fonctionalité peut augmenter légèrement la qualité lors de l'écoute "
 "sur une carte son 24bit"
 
-#: python/preferences.py:1335
+#: python/preferences.py:1338
 msgid "Enable tooltips"
 msgstr "Activer les bulles d'aide"
 
-#: python/preferences.py:1339
+#: python/preferences.py:1342
 msgid ""
 "This, what you are currently reading, is a tooltip. This feature turns them "
 "on or off."
@@ -3488,15 +3561,15 @@ msgstr ""
 "Ce que vous lisez actuellement est une bulle d'aide. Cette fonctionalité les "
 "dés/active. "
 
-#: python/preferences.py:1358
+#: python/preferences.py:1361
 msgid "Player Settings At Startup"
 msgstr "Configuration de démarrage du lecteur"
 
-#: python/preferences.py:1369
+#: python/preferences.py:1372
 msgid "Restore the previous session"
 msgstr "Restaurer la session précédente"
 
-#: python/preferences.py:1374
+#: python/preferences.py:1377
 msgid ""
 "When starting IDJC most of the main window settings will be as they were "
 "left. As an alternative you may specify below how you want the various "
@@ -3506,107 +3579,111 @@ msgstr ""
 "resteront comme vous les aviez laissés. Comme alternative, vous pouvez "
 "spécifier ci-dessous comment ils doivent être initialisés."
 
-#: python/preferences.py:1384
+#: python/preferences.py:1387
 msgid "Player 1"
 msgstr "Lecteur 1"
 
-#: python/preferences.py:1386
+#: python/preferences.py:1389
 msgid "Player 2"
 msgstr "Lecteur 2"
 
 #. TC: DJ hears the stream mix.
-#: python/preferences.py:1414
+#: python/preferences.py:1417
 msgid "Monitor Stream Mix"
 msgstr "Moniteur du stream Mixé"
 
 #. TC: A heading label for miscellaneous settings.
-#: python/preferences.py:1425
+#: python/preferences.py:1428
 msgid "General"
 msgstr "Général"
 
-#: python/preferences.py:1475
+#: python/preferences.py:1478
 msgid "VoIP panning + mono downmix"
 msgstr "Placement VoIP + réduction mono"
 
 #. TC: Keyboard and MIDI bindings configuration.
-#: python/preferences.py:1489
+#: python/preferences.py:1492
 msgid "Bindings"
 msgstr "Scorciatoie"
 
-#: python/preferences.py:1537
+#: python/preferences.py:1540
 msgid "Licence"
 msgstr "Licence"
 
-#: python/preferences.py:1560
+#: python/preferences.py:1563
 msgid "Contributors"
 msgstr "Collaborateurs"
 
-#: python/preferences.py:1567
+#: python/preferences.py:1570
 msgid "Translators"
 msgstr "Traducteurs"
 
-#: python/preferences.py:1573
+#: python/preferences.py:1574
+msgid "Build Info"
+msgstr ""
+
+#: python/preferences.py:1591
 msgid "About"
 msgstr "Concernant…"
 
-#: python/sourceclientgui.py:89
+#: python/sourceclientgui.py:91
 msgid "Insert Attribute"
 msgstr "Insérer un attribut"
 
-#: python/sourceclientgui.py:133
+#: python/sourceclientgui.py:135
 msgid "Icecast 2 Master"
 msgstr "Icecast 2 Maitre"
 
-#: python/sourceclientgui.py:133
+#: python/sourceclientgui.py:135
 msgid "Shoutcast Master"
 msgstr "Shoutcast Maitre"
 
-#: python/sourceclientgui.py:134
+#: python/sourceclientgui.py:136
 msgid "Icecast 2 Stats/Relay"
 msgstr "Icecast 2 Stats/Relais"
 
-#: python/sourceclientgui.py:134
+#: python/sourceclientgui.py:136
 msgid "Shoutcast Stats/Relay"
 msgstr "Icecast 2 Stats/Relais"
 
-#: python/sourceclientgui.py:137
+#: python/sourceclientgui.py:139
 msgid "Enter new server connection details"
 msgstr "Insérer de nouveaux détails concernant la connexion au serveur"
 
-#: python/sourceclientgui.py:156
+#: python/sourceclientgui.py:158
 msgid "Edit existing server connection details"
 msgstr "Editer les détails de la connexion au serveur"
 
-#: python/sourceclientgui.py:193
+#: python/sourceclientgui.py:195
 msgid "This server is to be scanned for audience figures"
 msgstr "Ce serveur doit être scanné pour les stats d'audience"
 
-#: python/sourceclientgui.py:206
+#: python/sourceclientgui.py:208
 msgid "Server type"
 msgstr "Type de serveur"
 
-#: python/sourceclientgui.py:206
+#: python/sourceclientgui.py:208
 msgid "Port number"
 msgstr "Numéro du port"
 
-#: python/sourceclientgui.py:207
+#: python/sourceclientgui.py:209
 msgid "Mount point"
 msgstr "Point de montage"
 
-#: python/sourceclientgui.py:207
+#: python/sourceclientgui.py:209
 msgid "Login name"
 msgstr "Nome utente"
 
-#: python/sourceclientgui.py:449
+#: python/sourceclientgui.py:475
 msgid "Encoder Format Not Set/Compatible"
 msgstr "Format d'encodage non défini/incompatible"
 
 #. TC: Connection button text when no details have been entered.
-#: python/sourceclientgui.py:452
+#: python/sourceclientgui.py:478
 msgid "No Master Server Configured"
 msgstr "Aucun serveur maitre n'es configuré"
 
-#: python/sourceclientgui.py:654
+#: python/sourceclientgui.py:680
 msgid ""
 "A table of servers with which to connect. Only one master server can be "
 "added for the purpose of streaming. All other servers will appear below the "
@@ -3618,41 +3695,41 @@ msgstr ""
 "sous le serveur maitre pour les statistiques, qui peuvent être occultés par "
 "serveurs."
 
-#: python/sourceclientgui.py:670
+#: python/sourceclientgui.py:696
 msgid "Hostname/IP address"
 msgstr "Hôte/Adresse IP"
 
 #. TC: Mount point is a technical term in relation to icecast servers.
-#: python/sourceclientgui.py:683
+#: python/sourceclientgui.py:709
 msgid "Mount point       "
 msgstr "Point de montage  "
 
 #. TC: This is the listener count heading.
-#: python/sourceclientgui.py:692
+#: python/sourceclientgui.py:718
 msgid "Listeners"
 msgstr "Auditeurs"
 
-#: python/sourceclientgui.py:707
+#: python/sourceclientgui.py:733
 msgid "The sum total of listeners in this server tab."
 msgstr "Nombre total d'auditeurs pour cet onglet serveur"
 
-#: python/sourceclientgui.py:734
+#: python/sourceclientgui.py:760
 msgid "Never"
 msgstr "Jamais"
 
-#: python/sourceclientgui.py:737
+#: python/sourceclientgui.py:763
 msgid "Always"
 msgstr "Toujours"
 
-#: python/sourceclientgui.py:739
+#: python/sourceclientgui.py:765
 msgid "If connected"
 msgstr "Si connecté"
 
-#: python/sourceclientgui.py:995
+#: python/sourceclientgui.py:1021
 msgid "Custom user agent string"
 msgstr "User agent personnalisé"
 
-#: python/sourceclientgui.py:1002
+#: python/sourceclientgui.py:1028
 msgid ""
 "Set this on the occasion that the server or its firewall specifically "
 "refuses to allow libshout based clients."
@@ -3660,16 +3737,16 @@ msgstr ""
 "A configurer au cas ou le serveur ou le pare-feux refuse spécialement "
 "d'autoriser les clients basés sur libshout."
 
-#: python/sourceclientgui.py:1007
+#: python/sourceclientgui.py:1033
 msgid "If the connection breaks reconnect to the server"
 msgstr "Si la connexion est interrompue, se reconnecter au sserveur"
 
 #. TC: Label for a comma separated list of delay times.
-#: python/sourceclientgui.py:1017
+#: python/sourceclientgui.py:1043
 msgid "Delay times"
 msgstr "Temps de délais"
 
-#: python/sourceclientgui.py:1021
+#: python/sourceclientgui.py:1047
 msgid ""
 "A comma separated list of delays in seconds between reconnection attempts. "
 "Note that bad values or values less than 5 will be interpreted as 5."
@@ -3678,45 +3755,45 @@ msgstr ""
 "tentatives de reconnexion. Notez que de mauvaises valeurs ou inférieures à 5 "
 "seront interprétées comme 5."
 
-#: python/sourceclientgui.py:1027
+#: python/sourceclientgui.py:1053
 msgid "Repeat the sequence of delays indefinitely."
 msgstr "Répéter la saquence de délais indéfiniment."
 
 #. TC: User specifies no dialog box to be shown.
-#: python/sourceclientgui.py:1030
+#: python/sourceclientgui.py:1056
 msgid "Quiet"
 msgstr "Muet"
 
-#: python/sourceclientgui.py:1032
+#: python/sourceclientgui.py:1058
 msgid "Keep the reconnection dialogue box hidden at all times."
 msgstr "Laisser la boite de reconnexion cachée tout le temps."
 
-#: python/sourceclientgui.py:1037
+#: python/sourceclientgui.py:1063
 msgid "The contingency plan upon the stream buffer becoming full is..."
 msgstr "Le plan d'action lorsque le tampon de streaming est plein est…"
 
-#: python/sourceclientgui.py:1046
+#: python/sourceclientgui.py:1072
 msgid "Discard audio data for as long as needed."
 msgstr "Laisser tomber les données audio pour la durée nécessaire."
 
-#: python/sourceclientgui.py:1048
+#: python/sourceclientgui.py:1074
 msgid "Assume the connection is beyond saving and reconnect."
 msgstr ""
 "Assumer que la connexion est interrompue, se déconnecter et se reconnecter."
 
-#: python/sourceclientgui.py:1300
+#: python/sourceclientgui.py:1357 python/format.py:1140
 msgid "Shoutcast"
 msgstr "Shoucast"
 
-#: python/sourceclientgui.py:1337
+#: python/sourceclientgui.py:1394
 msgid "[Metadata suppressed]"
 msgstr "[Métadonnée supprimmée]"
 
-#: python/sourceclientgui.py:1416
+#: python/sourceclientgui.py:1473
 msgid "Individual Controls"
 msgstr "Contrôles individuels"
 
-#: python/sourceclientgui.py:1430
+#: python/sourceclientgui.py:1487
 msgid ""
 "Connect to or disconnect from the radio server. If the button does not stay "
 "in, the connection failed for some reason.\n"
@@ -3738,11 +3815,11 @@ msgstr ""
 "capable de sélectionner le format du flux."
 
 #. TC: Kick whoever is on the server.
-#: python/sourceclientgui.py:1447
+#: python/sourceclientgui.py:1504
 msgid "Kick Source"
 msgstr "Kick Source"
 
-#: python/sourceclientgui.py:1449
+#: python/sourceclientgui.py:1506
 msgid ""
 "This will disconnect whoever is currently using the server, freeing it up "
 "for personal use."
@@ -3750,61 +3827,58 @@ msgstr ""
 "Déconnectera tous ceux qui utilisent le serveurs, le libérant ainsi pour une "
 "utilisation privée."
 
-#: python/sourceclientgui.py:1459
-#, fuzzy
+#: python/sourceclientgui.py:1516
 msgid "Timer:"
-msgstr "Timer"
+msgstr "Timer :"
 
-#: python/sourceclientgui.py:1463
-#, fuzzy
+#: python/sourceclientgui.py:1520
 msgid "From"
-msgstr "Depuis ici"
+msgstr "Depuis"
 
-#: python/sourceclientgui.py:1464
+#: python/sourceclientgui.py:1521
 msgid ""
 "Automatically connect to the server at a specific time in 24 hour format, "
 "midnight being 00:00"
 msgstr ""
 "Se connecter à une heure spécifique au format 24 heures, minuit étant 00:00"
 
-#: python/sourceclientgui.py:1469
+#: python/sourceclientgui.py:1526
 msgid "Kick"
 msgstr ""
 
-#: python/sourceclientgui.py:1471
+#: python/sourceclientgui.py:1528
 msgid "Disconnect whoever is using the server just before start time."
 msgstr "Déconnecter tous ceux qui utilisent le serveur avant de démarrer."
 
-#: python/sourceclientgui.py:1480
+#: python/sourceclientgui.py:1537
 msgid "To"
 msgstr ""
 
-#: python/sourceclientgui.py:1481
+#: python/sourceclientgui.py:1538
 msgid ""
 "Automatically disconnect from the server at a specific time in 24 hour "
 "format."
 msgstr ""
 "Se déconnecter automatiquement à une heure spécifique au format 24 heures"
 
-#: python/sourceclientgui.py:1484
-#, fuzzy
+#: python/sourceclientgui.py:1541
 msgid "Fade out"
-msgstr "Fondu 5s"
+msgstr "Fondu"
 
-#: python/sourceclientgui.py:1486
+#: python/sourceclientgui.py:1543
 msgid "Fade audio before disconnecting."
-msgstr ""
+msgstr "Fondu audio avant la déconnexion."
 
-#: python/sourceclientgui.py:1500
+#: python/sourceclientgui.py:1557
 msgid "At connect:"
 msgstr "A la connection :"
 
 #. TC: [x] Start player (*) 1 ( ) 2
-#: python/sourceclientgui.py:1504
+#: python/sourceclientgui.py:1561
 msgid "Start player"
 msgstr "Démarrer le lecteur"
 
-#: python/sourceclientgui.py:1509
+#: python/sourceclientgui.py:1566
 msgid ""
 "Have one of the players start automatically when a radio server connection "
 "is successfully made."
@@ -3813,32 +3887,33 @@ msgstr ""
 "connexion au serveur radio a réussie."
 
 #. TC: [x] Start recorder (*) 1 ( ) 2
-#: python/sourceclientgui.py:1517
+#: python/sourceclientgui.py:1574
 msgid "Start recorder"
 msgstr "Démarrer l'enregistreur"
 
-#: python/sourceclientgui.py:1524
+#: python/sourceclientgui.py:1581
 msgid ""
 "Have a recorder start automatically when a radio server connection is "
 "successfully made."
 msgstr ""
-"Pour avoir l'enregistreur qui démarre automatiquement lorsque la connexion "
-"au serveur radio a réussie."
+"Pour démarrer automatiquement un enregistreur lorsqu'une connexion au "
+"serveur radio est établie."
 
-#: python/sourceclientgui.py:1529
+#: python/sourceclientgui.py:1586 python/format.py:521 python/format.py:532
+#: python/format.py:542
 msgid "Metadata"
 msgstr "Métadonnées"
 
-#: python/sourceclientgui.py:1539
+#: python/sourceclientgui.py:1596
 msgid "Format String"
 msgstr "Chaine de format"
 
 #. TC: Label for the metadata fallback value.
-#: python/sourceclientgui.py:1541
+#: python/sourceclientgui.py:1598
 msgid "Fallback"
 msgstr "Fallback"
 
-#: python/sourceclientgui.py:1555
+#: python/sourceclientgui.py:1612
 msgid ""
 "You can enter text to accompany the stream here and can specify placemarkers "
 "%r %t %l %s for the artist, title, album, and songname respectively, or "
@@ -3862,7 +3937,7 @@ msgstr ""
 "Lorsque ce champ est vide, les flux Ogg utiliseront les tags standards "
 "vorbis et les mp3 utiliseront %s."
 
-#: python/sourceclientgui.py:1563
+#: python/sourceclientgui.py:1620
 msgid ""
 "The fallback text to use when %r %t %l metadata is unavailable. See the "
 "format string to the left."
@@ -3870,7 +3945,7 @@ msgstr ""
 "Texte de remplacement lorsque les métadonnées %r %t %l ne sont pas "
 "disponibles. voir Chaine de format à gauche."
 
-#: python/sourceclientgui.py:1565
+#: python/sourceclientgui.py:1622
 msgid ""
 "Metadata normally updates only on song title changes but you can force an "
 "immediate update here."
@@ -3878,28 +3953,28 @@ msgstr ""
 "Les métadonnées se mettent à jour lorsque le titre change mais vous pouvez "
 "aussi forcer leur mise à jour immédiate ici."
 
-#: python/sourceclientgui.py:1584
+#: python/sourceclientgui.py:1641
 msgid "Configuration"
 msgstr "Configuration"
 
-#: python/sourceclientgui.py:1585
+#: python/sourceclientgui.py:1642
 msgid "The controls for configuring a stream."
 msgstr "Les contrôles pour configurer un flux."
 
-#: python/sourceclientgui.py:1593
+#: python/sourceclientgui.py:1650
 msgid "Connection"
 msgstr "Connexion"
 
-#: python/sourceclientgui.py:1598
+#: python/sourceclientgui.py:1655
 msgid "Format"
 msgstr "Format"
 
 #. TC: Tab heading. User can enter information about the stream here.
-#: python/sourceclientgui.py:1607
+#: python/sourceclientgui.py:1664
 msgid "Stream Info"
 msgstr "Informations sur le flux"
 
-#: python/sourceclientgui.py:1612
+#: python/sourceclientgui.py:1669
 msgid ""
 "Enter your DJ name or station name here. Typically this information will be "
 "displayed by listener clients."
@@ -3907,7 +3982,7 @@ msgstr ""
 "Saisissez le nom du DJ ou de la station. Typiquement cette information sera "
 "affichée par les clients des Auditeurs."
 
-#: python/sourceclientgui.py:1615
+#: python/sourceclientgui.py:1672
 msgid ""
 "The URL of your radio station. This and the rest of the information below is "
 "intended for display on a radio station listings website."
@@ -3915,19 +3990,19 @@ msgstr ""
 "L'URL de votre station. Ceci ainsi que les informations suivantes sont "
 "destinées à l'affichage sur un site listant les stations."
 
-#: python/sourceclientgui.py:1620
+#: python/sourceclientgui.py:1677
 msgid "A description of your radio station."
 msgstr "Description de votre station."
 
-#: python/sourceclientgui.py:1625
+#: python/sourceclientgui.py:1682
 msgid "The musical genres you are likely to play."
 msgstr "Genres musicaux offerts."
 
-#: python/sourceclientgui.py:1628
+#: python/sourceclientgui.py:1685
 msgid "Make Public"
 msgstr "Rendre publique"
 
-#: python/sourceclientgui.py:1629
+#: python/sourceclientgui.py:1686
 msgid ""
 "Publish your radio station on a listings website. The website in question "
 "will depend on how the server to which you connect is configured."
@@ -3935,15 +4010,15 @@ msgstr ""
 "Publier votre station sur le site de liste. Le site en question dépends de "
 "la configuration du serveur auquel vous vous connectez."
 
-#: python/sourceclientgui.py:1641
+#: python/sourceclientgui.py:1698
 msgid "Genre(s)"
 msgstr "Genere(s)"
 
-#: python/sourceclientgui.py:1651
+#: python/sourceclientgui.py:1709
 msgid "Master server admin password"
 msgstr "Mot de passe administrateur principal"
 
-#: python/sourceclientgui.py:1656
+#: python/sourceclientgui.py:1714
 msgid ""
 "This is for kick and stats on Shoutcast master servers that have an "
 "administrator password. For those that don't leave this blank (the source "
@@ -3953,47 +4028,55 @@ msgstr ""
 "d'administration. Pour ceux n'en possédant pas, laissez vide (le mot de "
 "passe de la source est suffisant pour eux)"
 
-#: python/sourceclientgui.py:1665
+#: python/sourceclientgui.py:1723
 msgid "Contact Details"
 msgstr "Détails de contact"
 
-#: python/sourceclientgui.py:1670
+#: python/sourceclientgui.py:1727
 msgid "Internet Relay Chat connection info goes here."
 msgstr "Les informations d'IRC viennent ici"
 
-#: python/sourceclientgui.py:1673
+#: python/sourceclientgui.py:1730
 msgid "Connection info for AOL instant messenger goes here."
 msgstr "Informations de connexion au messager AOL viennent ici."
 
-#: python/sourceclientgui.py:1676
+#: python/sourceclientgui.py:1733
 msgid "ICQ instant messenger connection info goes here."
 msgstr "Les informations concernant le messager ICQ viennent ici."
 
-#: python/sourceclientgui.py:1679
+#: python/sourceclientgui.py:1736
 msgid "IRC"
 msgstr "IRC"
 
-#: python/sourceclientgui.py:1680
+#: python/sourceclientgui.py:1737
 msgid "AIM"
 msgstr "AIM"
 
-#: python/sourceclientgui.py:1681
+#: python/sourceclientgui.py:1738
 msgid "ICQ"
 msgstr "ICQ"
 
-#: python/sourceclientgui.py:1690
+#: python/sourceclientgui.py:1748
+msgid "Use ISO-8859-1 encoding for fixed metadata"
+msgstr ""
+
+#: python/sourceclientgui.py:1750
+msgid "Enable this if sending to a Shoutcast V1 server."
+msgstr ""
+
+#: python/sourceclientgui.py:1754
 msgid "Extra Shoutcast"
 msgstr "Extra Shoutcast"
 
-#: python/sourceclientgui.py:1695
+#: python/sourceclientgui.py:1759
 msgid "Troubleshooting"
 msgstr "Résolution des problèmes"
 
-#: python/sourceclientgui.py:1821
+#: python/sourceclientgui.py:1890
 msgid "Stop recording."
 msgstr "Arrêter l'enregistrement"
 
-#: python/sourceclientgui.py:1823
+#: python/sourceclientgui.py:1892
 msgid ""
 "Start recording.\n"
 "\n"
@@ -4006,20 +4089,20 @@ msgstr ""
 "sont pas corrects ou que les permissions d'écriture ne sont pas obtenues "
 "pour le dossier de destination."
 
-#: python/sourceclientgui.py:1828
+#: python/sourceclientgui.py:1897
 msgid "Pause recording."
 msgstr "Enregistrement en pause"
 
-#: python/sourceclientgui.py:1865
+#: python/sourceclientgui.py:1934
 msgid "Recording time elapsed."
 msgstr "Temps d'enregistement écoulé."
 
 #. TC: Dialog title bar text.
-#: python/sourceclientgui.py:1919
+#: python/sourceclientgui.py:1988
 msgid "Select the folder to record to"
 msgstr "Sélection du dossier pour l'enregistrement"
 
-#: python/sourceclientgui.py:1930
+#: python/sourceclientgui.py:1999
 msgid ""
 "Choose which stream to record or the 24 bit FLAC option. If the stream isn't "
 "already running the encoder will be started automatically using whatever "
@@ -4029,7 +4112,7 @@ msgstr ""
 "pas en cours de lecture, l'encodage commencera automatiquement quels que "
 "soient les paramêtres actuellement configurés."
 
-#: python/sourceclientgui.py:1934
+#: python/sourceclientgui.py:2003
 msgid ""
 "Choose which directory you want to save to. All file names will be in a "
 "timestamp format and have either an oga, mp3, or flac file extension. "
@@ -4041,69 +4124,70 @@ msgstr ""
 "Important : vous devez sélectionner un dossier avec les permissions en "
 "écriture adéquates."
 
-#: python/sourceclientgui.py:2038
+#: python/sourceclientgui.py:2110
 msgid "Perform operations on multiple servers in unison."
 msgstr "Effecter des opérations simultanément sur plusieurs serveurs."
 
-#: python/sourceclientgui.py:2050
+#: python/sourceclientgui.py:2122
 msgid "Connect"
 msgstr "Connecter"
 
-#: python/sourceclientgui.py:2067
+#: python/sourceclientgui.py:2139
 msgid "Disconnect"
 msgstr "Déconnecter"
 
-#: python/sourceclientgui.py:2075
+#: python/sourceclientgui.py:2147
 msgid "Kick Sources"
 msgstr "Kick Sources"
 
-#: python/sourceclientgui.py:2084
+#: python/sourceclientgui.py:2156
 msgid "Metadata:"
 msgstr "Metadonnées :"
 
-#: python/sourceclientgui.py:2114
+#: python/sourceclientgui.py:2186
 msgid "Group Controls"
 msgstr "Contrôles de groupe"
 
-#: python/sourceclientgui.py:2610
+#: python/sourceclientgui.py:2692
 msgid "Recording Facility Unavailable"
 msgstr "Fonctionalités d'enregistrement non disponibles"
 
-#: python/sourceclientgui.py:2613
+#: python/sourceclientgui.py:2695
 msgid "No Recorders Are Correctly Configured"
 msgstr "Aucun enregistreur configuré correctement"
 
 #. TC: Recorder menu format string.
-#: python/sourceclientgui.py:2626
+#: python/sourceclientgui.py:2708
+#, python-brace-format
 msgid "{numericid} [{source}] > [{directory}]"
 msgstr "{numericid} [{source}] > [{directory}]"
 
-#: python/sourceclientgui.py:2628
+#: python/sourceclientgui.py:2710
 msgid "Misconfigured"
 msgstr "Mal configuré"
 
-#: python/sourceclientgui.py:2649
+#: python/sourceclientgui.py:2731
 msgid "Streaming Facility Unavailable"
 msgstr "Fonctionalités de flux non disponibles"
 
-#: python/sourceclientgui.py:2651
+#: python/sourceclientgui.py:2733
 msgid "No Streams Are Currently Configured"
 msgstr "Aucun flux actuellement configuré"
 
-#: python/sourceclientgui.py:2654
+#: python/sourceclientgui.py:2736
 msgid "Group Connect"
 msgstr "Connexion de groupe"
 
-#: python/sourceclientgui.py:2660
+#: python/sourceclientgui.py:2742
 msgid "Group Disconnect"
 msgstr "Déconnetion de groupe"
 
 #. TC: Window title bar text.
-#: python/sourceclientgui.py:2691
+#: python/sourceclientgui.py:2773
 msgid "IDJC Output"
 msgstr "Sortie IDJC"
 
-#: python/sourceclientgui.py:2707
+#: python/sourceclientgui.py:2789
 msgid ""
 "Each one of these tabs represents a separate stream recorder. The LED "
 "indicator colours represent the following: Clear=Stopped Yellow=Paused "
@@ -4112,7 +4196,7 @@ msgstr ""
 "Chacun de ces onglets représente un enregistreur de flux. La couleur de la "
 "LED indique : Eteinte=Arret Jaune=Pause Rouge=Enregistrement."
 
-#: python/sourceclientgui.py:2715
+#: python/sourceclientgui.py:2797
 msgid ""
 "Each one of these tabs represents a separate radio streamer. The LED "
 "indicator colours represent the following: Clear=No connection "
@@ -4123,11 +4207,11 @@ msgstr ""
 "indique : Eteinte=Aucune connexion Jaune=En attente d'autentification. "
 "Verte=Connecté. Clignottante=Perte de paquet du à une mauvaise connexion."
 
-#: python/sourceclientgui.py:2733
+#: python/sourceclientgui.py:2815
 msgid " Stream "
 msgstr " Flux "
 
-#: python/sourceclientgui.py:2768
+#: python/sourceclientgui.py:2850
 msgid ""
 "<span weight=\"bold\" size=\"12000\">A connection to a radio server has "
 "failed.</span>\n"
@@ -4139,7 +4223,7 @@ msgstr ""
 "\n"
 "Aucune tentative de reconnexion ne sera faite."
 
-#: python/sourceclientgui.py:2773
+#: python/sourceclientgui.py:2855
 msgid ""
 "<span weight=\"bold\" size=\"12000\">A scheduled stream disconnection has "
 "occurred.</span>"
@@ -4147,6 +4231,519 @@ msgstr ""
 "<span weight=\"bold\" size=\"12000\">Une déconnexion pré-programmée du flux "
 "s'est produite.</span>"
 
+#: python/format.py:419
+msgid "Right click for suggested values."
+msgstr ""
+
+#: python/format.py:438
+#, fuzzy
+msgid "Suggested Values"
+msgstr "Régler la valeur"
+
+#: python/format.py:494
+#, fuzzy
+msgid "Pregain"
+msgstr "Lecteur Régler le gain"
+
+#: python/format.py:495 python/format.py:913
+msgid "0 dB"
+msgstr ""
+
+#: python/format.py:496 python/format.py:914
+msgid "-0.5 dB"
+msgstr ""
+
+#: python/format.py:497 python/format.py:915
+msgid "-1.0 dB"
+msgstr ""
+
+#: python/format.py:498 python/format.py:916
+msgid "-1.5 dB"
+msgstr ""
+
+#: python/format.py:499 python/format.py:917
+msgid "-2.0 dB"
+msgstr ""
+
+#: python/format.py:500 python/format.py:918
+msgid "-2.5 dB"
+msgstr ""
+
+#: python/format.py:501 python/format.py:919
+msgid "-3.0 dB"
+msgstr ""
+
+#: python/format.py:502
+msgid ""
+"A blanket gain reduction to promote audio quality when using long "
+"established lossy audio codecs like mp3 with loud audio material.\n"
+"\n"
+"ReplayGain makes this feature generally unnecessary and the correct setting "
+"in that case is 0 dB."
+msgstr ""
+
+#: python/format.py:510
+#, fuzzy
+msgid "Resample Quality"
+msgstr "Qualité de rééchantillonnage du lecteur"
+
+#: python/format.py:511
+msgid "Highest"
+msgstr "La plus élevée"
+
+#: python/format.py:513
+msgid "Lowest"
+msgstr "La plus basse"
+
+#: python/format.py:514
+msgid ""
+"All of these settings will provide adequate audio quality. The highest "
+"setting will preserve more of the original audio bandwidth at the expense of "
+"many CPU cycles."
+msgstr ""
+
+#: python/format.py:522 python/format.py:533 python/format.py:543
+#, fuzzy
+msgid "Suppressed"
+msgstr "Pressé"
+
+#: python/format.py:523 python/format.py:534
+msgid "UTF-8"
+msgstr ""
+
+#: python/format.py:524
+msgid "Latin1 *"
+msgstr ""
+
+#: python/format.py:525
+msgid ""
+"This affects the stream metadata only. Recordings will use UTF-8 for their "
+"metadata."
+msgstr ""
+
+#: python/format.py:535
+msgid ""
+"Choose whether the stream will carry dynamic metadata. In the case of Ogg "
+"streams this is important as a great many players can't handle chained Ogg "
+"streams which result from the metadata updates."
+msgstr ""
+
+#: python/format.py:544
+msgid "Latin1"
+msgstr ""
+
+#: python/format.py:545
+msgid "Choose whether to send metadata. Recordings will use UTF-8 metadata."
+msgstr ""
+
+#: python/format.py:561 python/format.py:572 python/format.py:583
+#: python/format.py:690 python/format.py:818 python/format.py:888
+#: python/format.py:897 python/format.py:971 python/format.py:994
+#: python/format.py:1003
+msgid "Mode"
+msgstr ""
+
+#: python/format.py:562 python/format.py:573 python/format.py:584
+#: python/format.py:691 python/format.py:819 python/format.py:889
+#: python/format.py:898 python/format.py:972 python/format.py:995
+#: python/format.py:1004
+msgid "Mono"
+msgstr ""
+
+#: python/format.py:563 python/format.py:574 python/format.py:585
+#: python/format.py:692 python/format.py:820 python/format.py:890
+#: python/format.py:899 python/format.py:973 python/format.py:996
+#: python/format.py:1005
+#, fuzzy
+msgid "Stereo"
+msgstr "Panoramique Stéréo"
+
+#: python/format.py:564 python/format.py:575 python/format.py:586
+#: python/format.py:693
+msgid "Joint Stereo"
+msgstr ""
+
+#: python/format.py:565
+msgid "Joint Stereo is a good choice on streams with low bitrates."
+msgstr ""
+
+#: python/format.py:576
+msgid "Due to the high bitrate selected, this codec will only support stereo."
+msgstr ""
+
+#: python/format.py:587
+msgid "Due to the low bitrate selected, this codec will only support mono."
+msgstr ""
+
+#: python/format.py:636 python/format.py:646 python/format.py:743
+#: python/format.py:753 python/format.py:763 python/format.py:869
+#: python/format.py:879 python/format.py:1032 python/format.py:1052
+msgid "Samplerate"
+msgstr ""
+
+#. TC: Abbreviation of the word, standard.
+#: python/format.py:657 python/format.py:774
+msgid "Std."
+msgstr ""
+
+#. TC: v stands for version.
+#: python/format.py:659 python/format.py:776
+msgid "V 1"
+msgstr ""
+
+#. TC: v stands for version.
+#: python/format.py:661 python/format.py:778
+msgid "V 2"
+msgstr ""
+
+#: python/format.py:662
+msgid ""
+"MPEG2 introduced lower samplerate options and corresponding lower bitrates. "
+"Choose 2 if those are required."
+msgstr ""
+
+#: python/format.py:669 python/format.py:797
+msgid "Quality"
+msgstr ""
+
+#: python/format.py:670
+msgid "0 most"
+msgstr ""
+
+#. TC: * means is the recommended setting.
+#: python/format.py:673
+msgid "2 *"
+msgstr ""
+
+#: python/format.py:675
+msgid "Higher quality costs more in terms of CPU cycles."
+msgstr ""
+
+#: python/format.py:694
+msgid "Joint Stereo is a good choice on streams with low bitrates"
+msgstr ""
+
+#. TC: v stands for version.
+#: python/format.py:780
+msgid "V 2.5"
+msgstr ""
+
+#: python/format.py:787
+msgid "Complexity"
+msgstr ""
+
+#: python/format.py:790
+msgid "A quality setting that affects how heavily the CPU is used."
+msgstr ""
+
+#: python/format.py:800
+msgid "The higher this setting, the higher the bitrate."
+msgstr ""
+
+#: python/format.py:807
+msgid "Bandwidth"
+msgstr ""
+
+#: python/format.py:808
+msgid "Ultrawide"
+msgstr ""
+
+#: python/format.py:809
+msgid "Wide"
+msgstr ""
+
+#: python/format.py:810
+msgid "Narrow"
+msgstr ""
+
+#: python/format.py:811
+msgid "Essentially a samplerate setting."
+msgstr ""
+
+#: python/format.py:828
+msgid "24 bit"
+msgstr ""
+
+#: python/format.py:829
+msgid "20 bit"
+msgstr ""
+
+#: python/format.py:830
+msgid "16 bit"
+msgstr ""
+
+#: python/format.py:831
+msgid ""
+"24 bit records with the highest level of detail. If file size is a concern "
+"maybe FLAC is not the right codec."
+msgstr ""
+
+#: python/format.py:838 python/format.py:927
+msgid "Variability"
+msgstr ""
+
+#: python/format.py:839
+msgid "Constant"
+msgstr ""
+
+#: python/format.py:840
+msgid "±10%"
+msgstr ""
+
+#: python/format.py:841
+msgid "±20%"
+msgstr ""
+
+#: python/format.py:842
+msgid "±30%"
+msgstr ""
+
+#: python/format.py:843
+msgid "±40%"
+msgstr ""
+
+#: python/format.py:844
+msgid "±50%"
+msgstr ""
+
+#: python/format.py:845
+#, fuzzy
+msgid "This control is for enabling variable bitrate on Vorbis streams."
+msgstr "Les contrôles pour configurer un flux."
+
+#: python/format.py:906
+#, fuzzy
+msgid "Postgain"
+msgstr "VoIP Régler le gain"
+
+#: python/format.py:907
+msgid "3.0 dB"
+msgstr ""
+
+#: python/format.py:908
+msgid "2.5 dB"
+msgstr ""
+
+#: python/format.py:909
+msgid "2.0 dB"
+msgstr ""
+
+#: python/format.py:910
+msgid "1.5 dB"
+msgstr ""
+
+#: python/format.py:911
+msgid "1.0 dB"
+msgstr ""
+
+#: python/format.py:912
+msgid "0.5 dB"
+msgstr ""
+
+#: python/format.py:920
+msgid "A gain adjustment for the player to apply."
+msgstr ""
+
+#: python/format.py:928
+msgid "CBR *"
+msgstr ""
+
+#: python/format.py:929
+msgid "CVBR"
+msgstr ""
+
+#: python/format.py:930
+msgid "VBR"
+msgstr ""
+
+#: python/format.py:931
+msgid ""
+"Bitrate variability. Actual VBR operation may require a higher frame size."
+msgstr ""
+
+#: python/format.py:938
+msgid "Frame Size"
+msgstr ""
+
+#: python/format.py:939
+msgid "60 ms"
+msgstr ""
+
+#: python/format.py:940
+msgid "40 ms"
+msgstr ""
+
+#: python/format.py:941
+msgid "20 ms"
+msgstr ""
+
+#: python/format.py:942
+msgid "A higher frame size may sound better on very low bitrates."
+msgstr ""
+
+#: python/format.py:949
+msgid "CPU"
+msgstr ""
+
+#: python/format.py:952
+msgid "The encoder complexity setting which affects CPU load."
+msgstr ""
+
+#: python/format.py:980 python/format.py:1083
+msgid "Codec"
+msgstr ""
+
+#: python/format.py:981
+msgid "Vorbis"
+msgstr ""
+
+#: python/format.py:982
+msgid "FLAC"
+msgstr ""
+
+#: python/format.py:983
+msgid "Speex"
+msgstr ""
+
+#: python/format.py:984
+msgid "Opus"
+msgstr ""
+
+#: python/format.py:987
+msgid "Codecs of the Ogg container."
+msgstr ""
+
+#: python/format.py:1033
+msgid "96000 Hz"
+msgstr ""
+
+#: python/format.py:1034
+msgid "88200 Hz"
+msgstr ""
+
+#: python/format.py:1035
+msgid "64000 Hz"
+msgstr ""
+
+#: python/format.py:1036 python/format.py:1053
+msgid "48000 Hz"
+msgstr ""
+
+#: python/format.py:1037 python/format.py:1054
+msgid "44100 Hz"
+msgstr ""
+
+#: python/format.py:1038
+msgid "32000 Hz"
+msgstr ""
+
+#: python/format.py:1039
+msgid "24000 Hz"
+msgstr ""
+
+#: python/format.py:1040
+msgid "22050 Hz"
+msgstr ""
+
+#: python/format.py:1041
+msgid "16000 Hz"
+msgstr ""
+
+#: python/format.py:1042
+msgid "12000 Hz"
+msgstr ""
+
+#: python/format.py:1043
+msgid "11025 Hz"
+msgstr ""
+
+#: python/format.py:1044
+msgid "8000 Hz"
+msgstr ""
+
+#: python/format.py:1045
+msgid "7350 Hz"
+msgstr ""
+
+#: python/format.py:1067
+msgid "The MP2 option requires IDJC be rebuilt against libtwolame."
+msgstr ""
+
+#: python/format.py:1070
+msgid "Enable the MP3 option by installing libmp3lame."
+msgstr ""
+
+#: python/format.py:1073
+msgid "The AAC options require IDJC be rebuilt against libav libraries."
+msgstr ""
+
+#: python/format.py:1076
+msgid ""
+"Specific AAC support not present in libavcodec. More info: idjc.sourceforge."
+"net."
+msgstr ""
+
+#: python/format.py:1078
+msgid ""
+"Specific AAC+ support not present in libavcodec. More info: idjc.sourceforge."
+"net."
+msgstr ""
+
+#: python/format.py:1081
+msgid "Codecs of the MPEG family."
+msgstr ""
+
+#: python/format.py:1084
+msgid "MP2"
+msgstr ""
+
+#: python/format.py:1085
+msgid "MP3"
+msgstr ""
+
+#: python/format.py:1086
+msgid "AAC"
+msgstr ""
+
+#: python/format.py:1087
+msgid "AAC+ v2"
+msgstr ""
+
+#. TC: Codec family e.g. Xiph/Ogg, MPEG etc.
+#: python/format.py:1099
+msgid "Family"
+msgstr ""
+
+#. TC: Xiph.org Ogg container format.
+#: python/format.py:1101
+msgid "Xiph/Ogg"
+msgstr ""
+
+#: python/format.py:1102
+msgid "MPEG"
+msgstr ""
+
+#: python/format.py:1103
+msgid "Codecs have been grouped by standards body and or container format."
+msgstr ""
+
+#: python/format.py:1128
+msgid "Capabilities"
+msgstr ""
+
+#: python/format.py:1140
+#, fuzzy
+msgid "Icecast"
+msgstr "Icecast 2 Maitre"
+
+#: python/format.py:1140
+#, fuzzy
+msgid "Recordable"
+msgstr "Enregistreur"
+
+#~ msgid "Playlist types (*.m3u, *.xspf, *.pls)"
+#~ msgstr "Type de listes de lecture (*.m3u, *.xspf, *.pls)"
+
 #~ msgid "File Path Modify"
 #~ msgstr "Modifier le chemin"
 
@@ -4290,9 +4887,3 @@ msgstr ""
 #~ "Pour les matériaux généralement forts, il est conseillé d'utiliser entre "
 #~ "4 et  8dB, toutefois une valeur trop élevée entraine une perte de "
 #~ "dynamique. Le Picmêtre est utile pour trouver la bonne valeur."
-
-#~ msgid "Highest"
-#~ msgstr "La plus élevée"
-
-#~ msgid "Lowest"
-#~ msgstr "La plus basse"
diff --git a/po/idjc.pot b/po/idjc.pot
index faf553d..a266f64 100644
--- a/po/idjc.pot
+++ b/po/idjc.pot
@@ -6,15 +6,15 @@
 #, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: idjc 0.8.14\n"
+"Project-Id-Version: idjc 0.8.15\n"
 "Report-Msgid-Bugs-To: putidjcinthesubjectline at bethere.co.uk\n"
-"POT-Creation-Date: 2014-02-17 19:31+0000\n"
+"POT-Creation-Date: 2015-07-27 07:47+0100\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
 "Language: \n"
 "MIME-Version: 1.0\n"
-"Content-Type: text/plain; charset=CHARSET\n"
+"Content-Type: text/plain; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #: python/prelims/__init__.py:101
@@ -283,6 +283,7 @@ msgstr ""
 
 #. TC: text appears in the title bar when in session mode.
 #: python/prelims/__init__.py:590
+#, python-brace-format
 msgid "session={type}:{name}"
 msgstr ""
 
@@ -317,14 +318,17 @@ msgid "Profile %s is active."
 msgstr ""
 
 #: python/prelims/__init__.py:791
+#, python-brace-format
 msgid "Cannot rename profile {0} to {1}, {1} currently exists."
 msgstr ""
 
 #: python/prelims/__init__.py:795
+#, python-brace-format
 msgid "Error during attempt to rename {0} to {1}."
 msgstr ""
 
 #: python/prelims/__init__.py:805
+#, python-brace-format
 msgid ""
 "<span weight='bold' size='12000'>Error while editing profile: {0}.</span>\n"
 "\n"
@@ -332,6 +336,7 @@ msgid ""
 msgstr ""
 
 #: python/prelims/__init__.py:824
+#, python-brace-format
 msgid "could not get a lock on profile {0}: {1}"
 msgstr ""
 
@@ -433,54 +438,54 @@ msgid "The default profile"
 msgstr ""
 
 #. TC: data entry dialog window title text. %s = profile name
-#: python/prelims/profiledialog.py:97
+#: python/prelims/profiledialog.py:98
 #, python-format
 msgid "Edit profile %s"
 msgstr ""
 
 #. TC: data entry dialog window title text. %s = profile name
-#: python/prelims/profiledialog.py:100
+#: python/prelims/profiledialog.py:101
 #, python-format
 msgid "New profile based upon %s"
 msgstr ""
 
 #. TC: data entry dialog window title text.
-#: python/prelims/profiledialog.py:104
+#: python/prelims/profiledialog.py:105
 msgid "New profile details"
 msgstr ""
 
 #. TC: profile dialog window title text.
-#: python/prelims/profiledialog.py:242
+#: python/prelims/profiledialog.py:243
 msgid "IDJC Profile Manager"
 msgstr ""
 
-#: python/prelims/profiledialog.py:276
+#: python/prelims/profiledialog.py:277
 msgid "Profile"
 msgstr ""
 
 #. TC: column heading. The profile nicknames.
 #. TC: IRC nickname data entry label.
-#: python/prelims/profiledialog.py:284 python/irc.py:446
+#: python/prelims/profiledialog.py:285 python/irc.py:452
 msgid "Nickname"
 msgstr ""
 
 #. TC: column heading.
 #. TC: Station description.
-#: python/prelims/profiledialog.py:287 python/irc.py:90
-#: python/playergui.py:306 python/sourceclientgui.py:1640
+#: python/prelims/profiledialog.py:288 python/irc.py:96
+#: python/playergui.py:307 python/sourceclientgui.py:1697
 msgid "Description"
 msgstr ""
 
 #. TC: column heading. The time a particular profile has been running.
-#: python/prelims/profiledialog.py:291
+#: python/prelims/profiledialog.py:292
 msgid "Up-time"
 msgstr ""
 
-#: python/prelims/profiledialog.py:305
+#: python/prelims/profiledialog.py:306
 msgid "_Auto"
 msgstr ""
 
-#: python/prelims/profiledialog.py:364
+#: python/prelims/profiledialog.py:365
 #, python-format
 msgid ""
 "<span weight='bold' size='12000'>Delete the data of profile '%s'?</span>\n"
@@ -488,7 +493,7 @@ msgid ""
 "The profile will remain available with initial settings."
 msgstr ""
 
-#: python/prelims/profiledialog.py:368
+#: python/prelims/profiledialog.py:369
 #, python-format
 msgid ""
 "<span weight='bold' size='12000'>Delete profile '%s' and all its data?</"
@@ -499,6 +504,7 @@ msgstr ""
 
 #. TC: The contents of <> and {} must not be changed.
 #: python/dialogs.py:198
+#, python-brace-format
 msgid ""
 "<span weight=\"bold\" size=\"12000\">The connection to the server in tab "
 "{servertab} has failed.</span>\n"
@@ -525,148 +531,157 @@ msgid "Released under the GNU General Public License V2.0+."
 msgstr ""
 
 #. TC: IRC message subcategory, triggers on new track announcements.
-#: python/irc.py:78
+#: python/irc.py:82
 msgid "Track announce"
 msgstr ""
 
 #. TC: IRC message subcategory, triggered by a timer.
-#: python/irc.py:80
+#: python/irc.py:84
 msgid "Timer"
 msgstr ""
 
 #. TC: IRC message subcategory, triggered once when the stream starts.
-#: python/irc.py:82
+#: python/irc.py:86
 msgid "On stream up"
 msgstr ""
 
 #. TC: IRC message subcategory, triggered once at the stream's end.
-#: python/irc.py:84
+#: python/irc.py:88
 msgid "On stream down"
 msgstr ""
 
+#. TC: IRC message subcategory, triggered once at the stream's end.
+#: python/irc.py:90
+msgid "Operations"
+msgstr ""
+
 #. TC: Track artist.
-#: python/irc.py:89 python/mutagentagger.py:375 python/songdb.py:785
-#: python/songdb.py:1157 python/sourceclientgui.py:92
+#: python/irc.py:95 python/mutagentagger.py:375 python/songdb.py:902
+#: python/songdb.py:1290 python/sourceclientgui.py:94
 msgid "Artist"
 msgstr ""
 
-#: python/irc.py:89 python/mutagentagger.py:375 python/songdb.py:1161
-#: python/sourceclientgui.py:92
+#: python/irc.py:95 python/mutagentagger.py:375 python/songdb.py:1292
+#: python/sourceclientgui.py:94
 msgid "Title"
 msgstr ""
 
-#: python/irc.py:89 python/mutagentagger.py:376 python/songdb.py:1158
-#: python/sourceclientgui.py:92
+#: python/irc.py:95 python/mutagentagger.py:376 python/songdb.py:1291
+#: python/sourceclientgui.py:94
 msgid "Album"
 msgstr ""
 
-#: python/irc.py:89 python/sourceclientgui.py:93
+#: python/irc.py:95 python/sourceclientgui.py:95
 msgid "Song name"
 msgstr ""
 
 #. TC: The DJ or Stream name.
-#: python/irc.py:90 python/sourceclientgui.py:1637
+#: python/irc.py:96 python/sourceclientgui.py:1694
 msgid "DJ name"
 msgstr ""
 
-#: python/irc.py:90 python/sourceclientgui.py:1638
+#: python/irc.py:96 python/sourceclientgui.py:1695
 msgid "Listen URL"
 msgstr ""
 
+#: python/irc.py:96
+msgid "Source URI"
+msgstr ""
+
 #. TC: Popup menu item for a GTK text entry widget.
-#: python/irc.py:133
+#: python/irc.py:139
 msgid "Insert Attribute or Colour Code"
 msgstr ""
 
 #. TC: Text formatting style.
-#: python/irc.py:170
+#: python/irc.py:176
 msgid "<b>Bold</b>"
 msgstr ""
 
 #. TC: Text formatting style.
-#: python/irc.py:172
+#: python/irc.py:178
 msgid "<u>Underline</u>"
 msgstr ""
 
 #. TC: Text formatting style.
-#: python/irc.py:174
+#: python/irc.py:180
 msgid "Normal"
 msgstr ""
 
-#: python/irc.py:180
+#: python/irc.py:186
 msgid "Colours"
 msgstr ""
 
-#: python/irc.py:397
+#: python/irc.py:403
 msgid "Optional data entry field for information only."
 msgstr ""
 
 #. TC: Tab heading text.
-#: python/irc.py:400
+#: python/irc.py:406
 msgid "IRC server"
 msgstr ""
 
-#: python/irc.py:412
+#: python/irc.py:418
 msgid "Manual start"
 msgstr ""
 
-#: python/irc.py:414
+#: python/irc.py:420
 msgid "Off when restarting IDJC and off initially."
 msgstr ""
 
 #. TC: The IRC network e.g. EFnet.
-#: python/irc.py:438
+#: python/irc.py:444
 msgid "Network"
 msgstr ""
 
 #. TC: label for hostname entry.
-#: python/irc.py:440 python/sourceclientgui.py:206
+#: python/irc.py:446 python/sourceclientgui.py:208
 msgid "Hostname"
 msgstr ""
 
 #. TC: TCP/IP port number label.
 #. TC: TCP port number.
-#: python/irc.py:442 python/sourceclientgui.py:678
+#: python/irc.py:448 python/sourceclientgui.py:704
 msgid "Port"
 msgstr ""
 
-#: python/irc.py:443
+#: python/irc.py:449
 msgid "User name"
 msgstr ""
 
-#: python/irc.py:444 python/songdb.py:339 python/sourceclientgui.py:207
+#: python/irc.py:450 python/songdb.py:343 python/sourceclientgui.py:209
 msgid "Password"
 msgstr ""
 
 #. TC: Second choice of IRC nickname.
-#: python/irc.py:448
+#: python/irc.py:454
 msgid "Second choice"
 msgstr ""
 
 #. TC: Third choice of IRC nickname.
-#: python/irc.py:450
+#: python/irc.py:456
 msgid "Third choice"
 msgstr ""
 
 #. TC: The IRC user's 'real' name.
-#: python/irc.py:452
+#: python/irc.py:458
 msgid "Real name"
 msgstr ""
 
 #. TC: The NickServ password.
-#: python/irc.py:454
+#: python/irc.py:460
 msgid "NickServ p/w"
 msgstr ""
 
 #. TC: Tooltip to IRC 'User name' field.
-#: python/irc.py:459
+#: python/irc.py:465
 msgid ""
 "Ideally set this to something even on servers that allow public anonymous "
 "access."
 msgstr ""
 
 #. TC: tooltip to all IRC nicknames entry fields.
-#: python/irc.py:469
+#: python/irc.py:475
 msgid ""
 "When a nickname is in use on the target IRC network, during connection these "
 "IRC nicknames are cycled through, then twice again after appending an "
@@ -674,7 +689,7 @@ msgid ""
 "nicknames to try."
 msgstr ""
 
-#: python/irc.py:474
+#: python/irc.py:480
 msgid ""
 "The real name you want to use which will be available regardless of whether "
 "the network connection was made with the primary nickname or not.\n"
@@ -682,7 +697,7 @@ msgid ""
 "Ideally set this to something."
 msgstr ""
 
-#: python/irc.py:477
+#: python/irc.py:483
 msgid ""
 "If this value is set an attempt will be made to acquire your first choice "
 "IRC nickname (if needed) and log in with NickServ at services.\n"
@@ -691,7 +706,7 @@ msgid ""
 "network using a regular chat client."
 msgstr ""
 
-#: python/irc.py:505
+#: python/irc.py:511
 msgid ""
 "<span weight='bold' size='12000'>Permanently delete this server?</span>\n"
 "\n"
@@ -699,11 +714,11 @@ msgid ""
 msgstr ""
 
 #. TC: An IRC channel #chan or user name entry box label.
-#: python/irc.py:552
+#: python/irc.py:559
 msgid "Channels/Users"
 msgstr ""
 
-#: python/irc.py:556
+#: python/irc.py:563
 msgid ""
 "The comma or space separated list of channels and/or users to whom the "
 "message will be sent.\n"
@@ -713,11 +728,11 @@ msgid ""
 msgstr ""
 
 #. TC: Message text to send to an IRC channel. Widget label.
-#: python/irc.py:563
+#: python/irc.py:616
 msgid "Message"
 msgstr ""
 
-#: python/irc.py:567
+#: python/irc.py:620
 msgid ""
 "The message to send.\n"
 "\n"
@@ -728,17 +743,17 @@ msgid ""
 msgstr ""
 
 #. TC: Dialog window title text.
-#: python/irc.py:638
+#: python/irc.py:673
 msgid "IRC track announce"
 msgstr ""
 
 #. TC: Spinbutton label for a delay value.
-#: python/irc.py:645
+#: python/irc.py:680
 msgid "Delay"
 msgstr ""
 
 #. TC: tooltip on a spinbutton widget.
-#: python/irc.py:647
+#: python/irc.py:682
 msgid ""
 "The delay time of this message.\n"
 "\n"
@@ -751,228 +766,233 @@ msgid ""
 msgstr ""
 
 #. TC: Dialog window title text.
-#: python/irc.py:675
+#: python/irc.py:710
 msgid "IRC timed message"
 msgstr ""
 
 #. TC: Spinbutton time offset value label.
-#: python/irc.py:684
+#: python/irc.py:719
 msgid "Offset"
 msgstr ""
 
 #. TC: Spinbutton timed interval duration value label.
-#: python/irc.py:686
+#: python/irc.py:721
 msgid "Interval"
 msgstr ""
 
 #. TC: spinbutton tooltip
-#: python/irc.py:689
+#: python/irc.py:724
 msgid ""
 "The time offset within the below specified interval at which the message "
 "will be issued."
 msgstr ""
 
-#: python/irc.py:693
+#: python/irc.py:728
 msgid "The interval in seconds of the timed message."
 msgstr ""
 
-#: python/irc.py:930
+#: python/irc.py:967
 msgid "This feature requires the installation of python-irc."
 msgstr ""
 
 #. TC: Indicator text: We used a password.
-#: python/irc.py:1021
+#: python/irc.py:1058
 msgid "PASSWORD"
 msgstr ""
 
 #. TC: Indicator text: We interact with NickServ.
-#: python/irc.py:1024
+#: python/irc.py:1061
 msgid "NICKSERV"
 msgstr ""
 
 #. TC: Indicator text: Server connection started manually.
-#: python/irc.py:1027
+#: python/irc.py:1064
 msgid "MANUAL"
 msgstr ""
 
-#. TC: Expander text encapsulating messages that play when stream goes up.
-#: python/irc.py:1048
+#. TC: Dialog title text.
+#: python/irc.py:1089
 msgid "IRC stream up message"
 msgstr ""
 
-#. TC: Expander text encapsulating messages that play when stream goes down.
-#: python/irc.py:1050
+#. TC: Dialog title text.
+#: python/irc.py:1091
 msgid "IRC stream down message"
 msgstr ""
 
-#: python/jingles.py:95
+#. TC: Dialog title text.
+#: python/irc.py:1093
+msgid "IRC station operations"
+msgstr ""
+
+#: python/jingles.py:96
 msgid "Stop"
 msgstr ""
 
 #. TC: Column heading, whether to play.
-#: python/jingles.py:113 python/playergui.py:298
+#: python/jingles.py:114 python/playergui.py:299
 msgid "Play"
 msgstr ""
 
-#: python/jingles.py:122 python/sourceclientgui.py:1025
+#: python/jingles.py:123 python/sourceclientgui.py:1051
 msgid "Repeat"
 msgstr ""
 
-#: python/jingles.py:135
+#: python/jingles.py:136
 msgid "Configure"
 msgstr ""
 
-#: python/jingles.py:326 python/playergui.py:4052
+#: python/jingles.py:327 python/playergui.py:4135
 msgid "Supported media"
 msgstr ""
 
-#: python/jingles.py:333
+#: python/jingles.py:334
 #, python-format
 msgid "Effect %d Config"
 msgstr ""
 
-#: python/jingles.py:348
+#: python/jingles.py:349
 msgid "Trigger text"
 msgstr ""
 
-#: python/jingles.py:349
+#: python/jingles.py:350
 msgid "No Name"
 msgstr ""
 
-#: python/jingles.py:356
+#: python/jingles.py:357
 msgid "Level adjustment (dB)"
 msgstr ""
 
-#: python/jingles.py:431
+#: python/jingles.py:432
 msgid "Effects volume."
 msgstr ""
 
-#: python/jingles.py:438
+#: python/jingles.py:439
 msgid "Player headroom that is applied when an effect is playing."
 msgstr ""
 
-#: python/jingles.py:501
+#: python/jingles.py:502
 msgid "Alternative"
 msgstr ""
 
-#: python/jingles.py:502
+#: python/jingles.py:503
 msgid "Default"
 msgstr ""
 
-#: python/jingles.py:547
+#: python/jingles.py:548
 msgid "Effects"
 msgstr ""
 
-#: python/jingles.py:590
+#: python/jingles.py:591
 #, python-format
 msgid "Effects %d"
 msgstr ""
 
-#: python/jingles.py:598 python/maingui.py:188
+#: python/jingles.py:599 python/maingui.py:189
 msgid "Background Tracks"
 msgstr ""
 
-#: python/jingles.py:617
+#: python/jingles.py:618
 msgid "Background Tracks volume."
 msgstr ""
 
-#: python/maingui.py:92
+#: python/maingui.py:93
 msgid "Show a JACK freewheel control on the main panel"
 msgstr ""
 
-#: python/maingui.py:94
+#: python/maingui.py:95
 msgid "Toggle JACK freewheel mode."
 msgstr ""
 
-#: python/maingui.py:167
+#: python/maingui.py:168
 msgid "File"
 msgstr ""
 
-#: python/maingui.py:167 python/preferences.py:1127
+#: python/maingui.py:168 python/preferences.py:1130
 msgid "View"
 msgstr ""
 
-#: python/maingui.py:168
+#: python/maingui.py:169
 msgid "JACK Ports"
 msgstr ""
 
-#: python/maingui.py:168
+#: python/maingui.py:169
 msgid "Help"
 msgstr ""
 
-#: python/maingui.py:170 python/maingui.py:3653
+#: python/maingui.py:171 python/maingui.py:3689
 msgid "Streams"
 msgstr ""
 
-#: python/maingui.py:171
+#: python/maingui.py:172
 msgid "Recorders"
 msgstr ""
 
-#: python/maingui.py:184 python/maingui.py:223
+#: python/maingui.py:185 python/maingui.py:224
 msgid "Output"
 msgstr ""
 
-#: python/maingui.py:184
+#: python/maingui.py:185
 msgid "Preferences"
 msgstr ""
 
-#: python/maingui.py:184
+#: python/maingui.py:185
 msgid "Profiles"
 msgstr ""
 
-#: python/maingui.py:187 python/songdb.py:405
+#: python/maingui.py:188 python/songdb.py:409
 msgid "Music Database"
 msgstr ""
 
-#: python/maingui.py:187
+#: python/maingui.py:188
 msgid "Channel Meters"
 msgstr ""
 
-#: python/maingui.py:187
+#: python/maingui.py:188
 msgid "Output Meters"
 msgstr ""
 
-#: python/maingui.py:188
+#: python/maingui.py:189
 msgid "Tabbed Area"
 msgstr ""
 
-#: python/maingui.py:188
+#: python/maingui.py:189
 msgid "Button Bar"
 msgstr ""
 
-#: python/maingui.py:222 python/preferences.py:1482
+#: python/maingui.py:223 python/preferences.py:1485
 msgid "Channels"
 msgstr ""
 
-#: python/maingui.py:222
+#: python/maingui.py:223
 msgid "Players"
 msgstr ""
 
-#: python/maingui.py:223
+#: python/maingui.py:224
 msgid "VoIP"
 msgstr ""
 
-#: python/maingui.py:223 python/maingui.py:3093
+#: python/maingui.py:224 python/maingui.py:3129
 msgid "DSP"
 msgstr ""
 
-#: python/maingui.py:223
+#: python/maingui.py:224
 msgid "Mix"
 msgstr ""
 
-#: python/maingui.py:223
+#: python/maingui.py:224
 msgid "Misc"
 msgstr ""
 
-#: python/maingui.py:268
+#: python/maingui.py:269
 msgid "Reset"
 msgstr ""
 
-#: python/maingui.py:271
+#: python/maingui.py:272
 msgid "Reset the JACK port connections to the default settings."
 msgstr ""
 
-#: python/maingui.py:276
+#: python/maingui.py:277
 msgid ""
 "<span size=\"12000\" weight=\"bold\">Reset all JACK port connections?</"
 "span>\n"
@@ -981,165 +1001,171 @@ msgid ""
 "and replaced with defaults."
 msgstr ""
 
-#: python/maingui.py:320
+#: python/maingui.py:321
 msgid "No compatible ports available."
 msgstr ""
 
-#: python/maingui.py:363
+#: python/maingui.py:364
+#, python-brace-format
 msgid "{0} profile={1}:{2} settings saved."
 msgstr ""
 
-#: python/maingui.py:366
+#: python/maingui.py:367
+#, python-brace-format
 msgid "{0} session={1}:{2} settings saved."
 msgstr ""
 
-#: python/maingui.py:670
+#: python/maingui.py:671
 msgid "Text"
 msgstr ""
 
-#: python/maingui.py:673
+#: python/maingui.py:674
 msgid "The opener button's text."
 msgstr ""
 
-#: python/maingui.py:681
+#: python/maingui.py:682
 msgid "Icon"
 msgstr ""
 
-#: python/maingui.py:689
+#: python/maingui.py:690
 msgid "The opener button's icon."
 msgstr ""
 
-#: python/maingui.py:697
+#: python/maingui.py:698
 msgid ""
 "The headroom is the amount by which to reduce player volume when this opener "
 "is active. Note that the actual amount will be the largest value of all the "
 "currently open buttons."
 msgstr ""
 
-#: python/maingui.py:702
+#: python/maingui.py:703
 msgid "The amount of headroom required (dB)"
 msgstr ""
 
-#: python/maingui.py:711
+#: python/maingui.py:712
 msgid "This button will flash as a reminder to close"
 msgstr ""
 
-#: python/maingui.py:712
+#: python/maingui.py:713
 msgid ""
 "After a number of seconds where a main player is active this button's status "
 "indicator will start to flash and will continue to do so until the button is "
 "closed or the player stops."
 msgstr ""
 
-#: python/maingui.py:720
+#: python/maingui.py:721
 msgid "This button is to be treated as a microphone opener"
 msgstr ""
 
-#: python/maingui.py:722
+#: python/maingui.py:723
 msgid ""
 "The button will be grouped with the other microphone opener buttons. It will "
 "be affected by signals to close microphone buttons. Channels associated with "
 "this button will be mixed differently when using the VoIP modes."
 msgstr ""
 
-#: python/maingui.py:733
+#: python/maingui.py:732
+msgid "This button will automatically cancel JACK freewheel mode"
+msgstr ""
+
+#: python/maingui.py:734
 msgid ""
 "This should be set for all buttons that control input from a live sound "
 "source or device."
 msgstr ""
 
-#: python/maingui.py:736
+#: python/maingui.py:737
 msgid "Button Open Triggers"
 msgstr ""
 
-#: python/maingui.py:743
+#: python/maingui.py:744
 msgid "Playlist advance button"
 msgstr ""
 
-#: python/maingui.py:744 python/maingui.py:745
+#: python/maingui.py:745 python/maingui.py:746
 #, python-format
 msgid "'%s' control"
 msgstr ""
 
 #. TC: Insert playlist control to stop the player.
-#: python/maingui.py:744 python/playergui.py:4310
+#: python/maingui.py:745 python/playergui.py:4393
 msgid "Player Stop"
 msgstr ""
 
 #. TC: Insert playlist control to stop the player.
-#: python/maingui.py:745 python/playergui.py:4317
+#: python/maingui.py:746 python/playergui.py:4400
 msgid "Player Stop 2"
 msgstr ""
 
-#: python/maingui.py:746
+#: python/maingui.py:747
 msgid "Announcements"
 msgstr ""
 
-#: python/maingui.py:758
+#: python/maingui.py:759
 msgid "When opened close these other buttons"
 msgstr ""
 
-#: python/maingui.py:769
+#: python/maingui.py:770
 msgid "Shell Command"
 msgstr ""
 
-#: python/maingui.py:770
+#: python/maingui.py:771
 msgid ""
 "Mostly useful issuing 'amixer' commands, in particular for setting capture."
 msgstr ""
 
-#: python/maingui.py:790
+#: python/maingui.py:791
 msgid "On open"
 msgstr ""
 
-#: python/maingui.py:791
+#: python/maingui.py:792
 msgid "On close"
 msgstr ""
 
-#: python/maingui.py:835
+#: python/maingui.py:836
 msgid "Main Panel Opener Buttons"
 msgstr ""
 
-#: python/maingui.py:847
+#: python/maingui.py:848
 msgid "Indicate button numbers and associated channel numbers"
 msgstr ""
 
-#: python/maingui.py:849
+#: python/maingui.py:850
 msgid "A useful feature to have switched on while allocating channel openers."
 msgstr ""
 
-#: python/maingui.py:855
+#: python/maingui.py:856
 msgid "Status Indicator Appearance"
 msgstr ""
 
-#: python/maingui.py:858
+#: python/maingui.py:859
 msgid ""
 "Each opener button has two vertical bars at the side to make the button "
 "state more apparent. These settings control their appearance."
 msgstr ""
 
-#: python/maingui.py:867
+#: python/maingui.py:868 python/format.py:827
 msgid "Width"
 msgstr ""
 
-#: python/maingui.py:874
+#: python/maingui.py:875
 msgid "Opened"
 msgstr ""
 
-#: python/maingui.py:878 python/preferences.py:500 python/preferences.py:502
+#: python/maingui.py:879 python/preferences.py:503 python/preferences.py:505
 msgid "Closed"
 msgstr ""
 
-#: python/maingui.py:883
+#: python/maingui.py:884
 msgid "Remind"
 msgstr ""
 
 #. TC: A placeholder text for when there are no opener buttons.
-#: python/maingui.py:1064
+#: python/maingui.py:1065
 msgid "No Channel Opener Buttons"
 msgstr ""
 
-#: python/maingui.py:1353
+#: python/maingui.py:1354
 msgid ""
 "This indicates the state of the various streams. Flashing means stream "
 "packets are being discarded because of network congestion. Partial red means "
@@ -1147,96 +1173,97 @@ msgid ""
 "the server. Green means everything is okay."
 msgstr ""
 
-#: python/maingui.py:1376
+#: python/maingui.py:1377
 msgid "The combined total number of listeners in all server tabs."
 msgstr ""
 
 #. TC: Record as in, to make a recording.
-#: python/maingui.py:1824 python/sourceclientgui.py:2702
+#: python/maingui.py:1825 python/sourceclientgui.py:2784
 msgid "Record"
 msgstr ""
 
-#: python/maingui.py:2620
+#: python/maingui.py:2647
 msgid "Confirmation to quit IDJC is required."
 msgstr ""
 
-#: python/maingui.py:2624
+#: python/maingui.py:2651
 msgid "All active recordings and radio streams will terminate."
 msgstr ""
 
-#: python/maingui.py:2626
+#: python/maingui.py:2653
 msgid "All of the active radio streams will terminate."
 msgstr ""
 
-#: python/maingui.py:2628
+#: python/maingui.py:2655
 msgid "All active recordings will cease."
 msgstr ""
 
 #. TC: Popup menu item, wipes away the tracks played history text.
-#: python/maingui.py:2885 python/maingui.py:3317
+#: python/maingui.py:2921 python/maingui.py:3353
 msgid "Remove Contents"
 msgstr ""
 
-#: python/maingui.py:3040
+#: python/maingui.py:3076
 msgid "Renameable Labels"
 msgstr ""
 
-#: python/maingui.py:3064
+#: python/maingui.py:3100
 msgid "Main Players"
 msgstr ""
 
-#: python/maingui.py:3117
+#: python/maingui.py:3153
 msgid "Mix voice over IP audio to the output stream."
 msgstr ""
 
-#: python/maingui.py:3130
+#: python/maingui.py:3166
 msgid "Mix voice over IP audio to the DJ only."
 msgstr ""
 
-#: python/maingui.py:3157
+#: python/maingui.py:3193
 msgid ""
 "This button steps through the active playlist, pausing between tracks. The "
 "active playlist is defined by the placement of the crossfader."
 msgstr ""
 
-#: python/maingui.py:3202 python/preferences.py:870
+#: python/maingui.py:3238 python/preferences.py:873
 msgid "The volume control shared by both music players."
 msgstr ""
 
-#: python/maingui.py:3213
+#: python/maingui.py:3249
 msgid "The volume control for the right music player."
 msgstr ""
 
-#: python/maingui.py:3241
+#: python/maingui.py:3277
 msgid "VoIP level adjustment. 0dB gain is at the mid point."
 msgstr ""
 
-#: python/maingui.py:3264
+#: python/maingui.py:3300
 msgid "The stream volume level to send to the voice over IP connection."
 msgstr ""
 
-#: python/maingui.py:3291 python/preferences.py:1410
+#: python/maingui.py:3327 python/preferences.py:1413
 msgid "Tracks Played"
 msgstr ""
 
-#: python/maingui.py:3362 python/maingui.py:3364 python/maingui.py:3388
+#: python/maingui.py:3398 python/maingui.py:3400 python/maingui.py:3424
 msgid "Monitor Mix"
 msgstr ""
 
-#: python/maingui.py:3371 python/maingui.py:3388 python/playergui.py:4251
+#: python/maingui.py:3407 python/maingui.py:3424 python/playergui.py:4334
 msgid "DJ"
 msgstr ""
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/maingui.py:3374 python/maingui.py:3388 python/midicontrols.py:154
-#: python/midicontrols.py:1506 python/playergui.py:4243
-#: python/sourceclientgui.py:2710
+#: python/maingui.py:3410 python/maingui.py:3424 python/midicontrols.py:155
+#: python/midicontrols.py:1507 python/playergui.py:4326
+#: python/sourceclientgui.py:2792
 msgid "Stream"
 msgstr ""
 
 #. TC: Context {0}, {1}, {2} = Monitor Mix, Stream, DJ
 #. TC: Or whatever they become translated to.
-#: python/maingui.py:3384
+#: python/maingui.py:3420
+#, python-brace-format
 msgid ""
 "In IDJC there are are two audio paths and this '{0}' control toggles between "
 "them. When '{1}' is active you can hear what the listeners are hearing "
@@ -1245,82 +1272,82 @@ msgid ""
 msgstr ""
 
 #. TC: Dropdown box title text widget.
-#: python/maingui.py:3397 python/maingui.py:3399
+#: python/maingui.py:3433 python/maingui.py:3435
 msgid "Metadata Source"
 msgstr ""
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3405 python/playergui.py:3961
+#: python/maingui.py:3441 python/playergui.py:4044
 msgid "Playlist 1"
 msgstr ""
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3407 python/playergui.py:3962
+#: python/maingui.py:3443 python/playergui.py:4045
 msgid "Playlist 2"
 msgstr ""
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3409
+#: python/maingui.py:3445 python/songdb.py:909 python/songdb.py:1293
 msgid "Last Played"
 msgstr ""
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3411 python/maingui.py:3448 python/maingui.py:3450
+#: python/maingui.py:3447 python/maingui.py:3484 python/maingui.py:3486
 msgid "Crossfader"
 msgstr ""
 
 #. TC: The chosen source of track metadata. In this case no metadata.
 #. TC: Fade time is zero. No fade, none.
-#: python/maingui.py:3413 python/playergui.py:4226
+#: python/maingui.py:3449 python/playergui.py:4309
 msgid "None"
 msgstr ""
 
 #. TC: The chosen source of track metadata. In this case no metadata.
-#: python/maingui.py:3415
+#: python/maingui.py:3451
 msgid "Playlist 3"
 msgstr ""
 
-#: python/maingui.py:3420
+#: python/maingui.py:3456
 msgid "Select the origin for the playing track metadata on the stream."
 msgstr ""
 
 #. TC: Abbreviation of left.
-#: python/maingui.py:3430 python/maingui.py:3432
+#: python/maingui.py:3466 python/maingui.py:3468
 msgid "L"
 msgstr ""
 
-#: python/maingui.py:3442
+#: python/maingui.py:3478
 msgid "Move the crossfader fully left."
 msgstr ""
 
-#: python/maingui.py:3462
+#: python/maingui.py:3498
 msgid "The crossfader."
 msgstr ""
 
 #. TC: Abbreviation of right.
-#: python/maingui.py:3466 python/maingui.py:3468
+#: python/maingui.py:3502 python/maingui.py:3504
 msgid "R"
 msgstr ""
 
-#: python/maingui.py:3478
+#: python/maingui.py:3514
 msgid "Move the crossfader fully right."
 msgstr ""
 
 #. TC: Describes a mid point.
-#: python/maingui.py:3487 python/maingui.py:3489
+#: python/maingui.py:3523 python/maingui.py:3525
 msgid "Middle"
 msgstr ""
 
-#: python/maingui.py:3506 python/maingui.py:3513
+#: python/maingui.py:3542 python/maingui.py:3549
 msgid "Move the crossfader to the middle of its range of travel."
 msgstr ""
 
 #. TC: The attenuation response curve of the crossfader. User selectable.
-#: python/maingui.py:3518 python/maingui.py:3520
+#: python/maingui.py:3554 python/maingui.py:3556
 msgid "Response"
 msgstr ""
 
-#: python/maingui.py:3542
+#: python/maingui.py:3578
 msgid ""
 "This selects the response curve of the crossfader.\n"
 "\n"
@@ -1328,11 +1355,11 @@ msgid ""
 msgstr ""
 
 #. TC: Duration in seconds.
-#: python/maingui.py:3556 python/maingui.py:3558
+#: python/maingui.py:3592 python/maingui.py:3594
 msgid "Time"
 msgstr ""
 
-#: python/maingui.py:3575
+#: python/maingui.py:3611
 msgid ""
 "The time in seconds that the crossfader will take to automatically pass "
 "across when the button to the right is clicked."
@@ -1340,39 +1367,39 @@ msgstr ""
 
 #. TC: The crossfader pass-across button text.
 #. TC: The actual button appears as [<-->] with this text above it.
-#: python/maingui.py:3584 python/maingui.py:3586
+#: python/maingui.py:3620 python/maingui.py:3622
 msgid "Pass"
 msgstr ""
 
-#: python/maingui.py:3599
+#: python/maingui.py:3635
 msgid ""
 "This button causes the crossfader to move to the opposite side at a speed "
 "determined by the speed selector to the left."
 msgstr ""
 
-#: python/maingui.py:3642
+#: python/maingui.py:3678
 msgid "Peak"
 msgstr ""
 
-#: python/maingui.py:3645
+#: python/maingui.py:3681
 msgid "A peak hold meter indicating the signal strength of the stream audio."
 msgstr ""
 
 #. TC: This text appears above the stream mix VU meter.
-#: python/maingui.py:3667
+#: python/maingui.py:3703
 msgid "VU"
 msgstr ""
 
-#: python/maingui.py:3671
+#: python/maingui.py:3707
 msgid "A VU meter for the stream audio."
 msgstr ""
 
 #. TC: Appears above the mic meters as a label followed by a number.
-#: python/maingui.py:3674
+#: python/maingui.py:3710
 msgid "Ch"
 msgstr ""
 
-#: python/maingui.py:3701
+#: python/maingui.py:3737
 msgid ""
 "A peak hold meter indicating the microphone signal strength and a meter "
 "indicating attenuation levels in the microphone signal processing system. "
@@ -1381,469 +1408,469 @@ msgid ""
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:47
+#: python/midicontrols.py:48
 msgid "Tooltips enable"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:49
+#: python/midicontrols.py:50
 msgid "DJ-mix monitor"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:51
+#: python/midicontrols.py:52
 msgid "Panning load from presets"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:53
+#: python/midicontrols.py:54
 msgid "Player play/pause"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
 #. TC: Playlist control.
-#: python/midicontrols.py:55 python/playergui.py:3719
+#: python/midicontrols.py:56 python/playergui.py:3798
 msgid "Player stop"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:57
+#: python/midicontrols.py:58
 msgid "Player advance"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:59
+#: python/midicontrols.py:60
 msgid "Player play previous"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:61
+#: python/midicontrols.py:62
 msgid "Player play next"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:63
+#: python/midicontrols.py:64
 msgid "Player play selected from start"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:65
+#: python/midicontrols.py:66
 msgid "Player select previous"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:67
+#: python/midicontrols.py:68
 msgid "Player select next"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:69
+#: python/midicontrols.py:70
 msgid "Player stream output enable"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:71
+#: python/midicontrols.py:72
 msgid "Player DJ output enable"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:73
+#: python/midicontrols.py:74
 msgid "Player DJ-only switch"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:75
+#: python/midicontrols.py:76
 msgid "Player set volume"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:77
+#: python/midicontrols.py:78
 msgid "Player set gain"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:79
+#: python/midicontrols.py:80
 msgid "Player set balance"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:81
+#: python/midicontrols.py:82
 msgid "Player set pitchbend"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:84
+#: python/midicontrols.py:85
 msgid "Playlist edit tags"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:86
+#: python/midicontrols.py:87
 msgid "Playlist insert stop"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:88
+#: python/midicontrols.py:89
 msgid "Playlist insert stop 2"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:90
+#: python/midicontrols.py:91
 msgid "Playlist insert announce"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:92
+#: python/midicontrols.py:93
 msgid "Playlist insert transfer"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:94
+#: python/midicontrols.py:95
 msgid "Playlist insert crossfade"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:96
+#: python/midicontrols.py:97
 msgid "Playlist insert pitchunbend"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:98
+#: python/midicontrols.py:99
 msgid "Playlist insert jump to top"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:101
+#: python/midicontrols.py:102
 msgid "Players set crossfade"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:103
+#: python/midicontrols.py:104
 msgid "Players pass crossfade"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:105
+#: python/midicontrols.py:106
 msgid "Players set focus"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:107
+#: python/midicontrols.py:108
 msgid "Players show pitchbend"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:109
+#: python/midicontrols.py:110
 msgid "Players advance"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:112
+#: python/midicontrols.py:113
 msgid "Channel output enable"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:114
+#: python/midicontrols.py:115
 msgid "Channel set volume"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:116
+#: python/midicontrols.py:117
 msgid "Channel set gain"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:118
+#: python/midicontrols.py:119
 msgid "Channel set balance"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:121
+#: python/midicontrols.py:122
 msgid "VoIP output enable"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:123
+#: python/midicontrols.py:124
 msgid "VoIP DJ-only switch"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:125
+#: python/midicontrols.py:126
 msgid "VoIP set volume"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:127
+#: python/midicontrols.py:128
 msgid "VoIP set mixback"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:129
+#: python/midicontrols.py:130
 msgid "VoIP set gain"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:131
+#: python/midicontrols.py:132
 msgid "VoIP set balance"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:134
+#: python/midicontrols.py:135
 msgid "Effect play from start"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:137
+#: python/midicontrols.py:138
 msgid "Effects stop many"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:139
+#: python/midicontrols.py:140
 msgid "Effects set volume"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:141
+#: python/midicontrols.py:142
 msgid "Effects set headroom"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:144
+#: python/midicontrols.py:145
 msgid "Stream set connected"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:147
+#: python/midicontrols.py:148
 msgid "Recorder set recording"
 msgstr ""
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:151 python/midicontrols.py:1492
+#: python/midicontrols.py:152 python/midicontrols.py:1493
 msgid "Player"
 msgstr ""
 
 #. TC: binding editor, action pane, first row, toplevel menu.
 #. TC: The midi channel.
 #. TC: Specifically, the numerical midi channel.
-#: python/midicontrols.py:152 python/midicontrols.py:1498
-#: python/midicontrols.py:1567 python/midicontrols.py:1757
+#: python/midicontrols.py:153 python/midicontrols.py:1499
+#: python/midicontrols.py:1568 python/midicontrols.py:1758
 msgid "Channel"
 msgstr ""
 
-#: python/midicontrols.py:153 python/preferences.py:596
-#: python/preferences.py:606
+#: python/midicontrols.py:154 python/preferences.py:599
+#: python/preferences.py:609
 msgid "Effect"
 msgstr ""
 
-#: python/midicontrols.py:155
+#: python/midicontrols.py:156
 msgid "Recorder"
 msgstr ""
 
-#: python/midicontrols.py:156
+#: python/midicontrols.py:157
 msgid "Setting"
 msgstr ""
 
-#: python/midicontrols.py:160
+#: python/midicontrols.py:161
 msgid "Left player"
 msgstr ""
 
-#: python/midicontrols.py:161
+#: python/midicontrols.py:162
 msgid "Right player"
 msgstr ""
 
-#: python/midicontrols.py:162
+#: python/midicontrols.py:163
 msgid "Background player"
 msgstr ""
 
-#: python/midicontrols.py:163
+#: python/midicontrols.py:164
 msgid "Focused player"
 msgstr ""
 
-#: python/midicontrols.py:164
+#: python/midicontrols.py:165
 msgid "Fadered player"
 msgstr ""
 
-#: python/midicontrols.py:168
+#: python/midicontrols.py:169
 msgid "Effects bank 1"
 msgstr ""
 
-#: python/midicontrols.py:169
+#: python/midicontrols.py:170
 msgid "Effects bank 2"
 msgstr ""
 
-#: python/midicontrols.py:170
+#: python/midicontrols.py:171
 msgid "All effects"
 msgstr ""
 
 #. TC: The name of the backspace key.
-#: python/midicontrols.py:404
+#: python/midicontrols.py:405
 msgid "BackSpace"
 msgstr ""
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1468
+#: python/midicontrols.py:1469
 msgid "Use value"
 msgstr ""
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1470
+#: python/midicontrols.py:1471
 msgid "Act if"
 msgstr ""
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1472
+#: python/midicontrols.py:1473
 msgid "Set to"
 msgstr ""
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1474
+#: python/midicontrols.py:1475
 msgid "Adjust by"
 msgstr ""
 
 #. TC: binding editor, input pane, fourth row, heading text.
-#: python/midicontrols.py:1479 python/midicontrols.py:1483
+#: python/midicontrols.py:1480 python/midicontrols.py:1484
 msgid "Control"
 msgstr ""
 
 #. TC: binding editor, input pane, fourth row, heading text.
-#: python/midicontrols.py:1481
+#: python/midicontrols.py:1482
 msgid "Note"
 msgstr ""
 
 #. TC: binding editor, input pane, fourth row, heading text.
-#: python/midicontrols.py:1485
+#: python/midicontrols.py:1486
 msgid "Key"
 msgstr ""
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1490
+#: python/midicontrols.py:1491
 msgid "Miscellaneous"
 msgstr ""
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1494
+#: python/midicontrols.py:1495
 msgid "Both players"
 msgstr ""
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1496
+#: python/midicontrols.py:1497
 msgid "Quick panning"
 msgstr ""
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1500
+#: python/midicontrols.py:1501
 msgid "VoIP channel"
 msgstr ""
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1502
+#: python/midicontrols.py:1503
 msgid "Single effect"
 msgstr ""
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1504
+#: python/midicontrols.py:1505
 msgid "Effects bank"
 msgstr ""
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1508
+#: python/midicontrols.py:1509
 msgid "Stream recorder"
 msgstr ""
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1513
+#: python/midicontrols.py:1514
 msgid "Direct fader/held button"
 msgstr ""
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1515
+#: python/midicontrols.py:1516
 msgid "One-shot/toggle button"
 msgstr ""
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1517
+#: python/midicontrols.py:1518
 msgid "Set value"
 msgstr ""
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1519
+#: python/midicontrols.py:1520
 msgid "Alter value"
 msgstr ""
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1524
+#: python/midicontrols.py:1525
 msgid "MIDI control"
 msgstr ""
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1526
+#: python/midicontrols.py:1527
 msgid "MIDI note"
 msgstr ""
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1528
+#: python/midicontrols.py:1529
 msgid "MIDI pitch-wheel"
 msgstr ""
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1530
+#: python/midicontrols.py:1531
 msgid "Keyboard press"
 msgstr ""
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1532
+#: python/midicontrols.py:1533
 msgid "XChat command"
 msgstr ""
 
 #. TC: Dialog window title text.
 #. TC: User is expected to edit a control binding.
-#: python/midicontrols.py:1541
+#: python/midicontrols.py:1542
 msgid "Edit control binding"
 msgstr ""
 
 #. TC: After clicking this button the binding editor will be listening
 #. TC: for a key press or midi control surface input.
 #. TC: Button text. If pressed triggers 'Listening for input' mode.
-#: python/midicontrols.py:1556 python/midicontrols.py:1637
-#: python/midicontrols.py:1736
+#: python/midicontrols.py:1557 python/midicontrols.py:1638
+#: python/midicontrols.py:1737
 msgid "Listen for input..."
 msgstr ""
 
 #. TC: The input source.
-#: python/midicontrols.py:1564
+#: python/midicontrols.py:1565
 msgid "Source"
 msgstr ""
 
 #. TC: The manner in which the input is interpreted.
-#: python/midicontrols.py:1583
+#: python/midicontrols.py:1584
 msgid "Interaction"
 msgstr ""
 
 #. TC: The effect of the control can be directed upon a specific target.
 #. TC: e.g. On target [Left player]
-#: python/midicontrols.py:1589
+#: python/midicontrols.py:1590
 msgid "On target"
 msgstr ""
 
 #. TC: Checkbutton text.
 #. TC: Use reverse scale and invert the meaning of button presses.
-#: python/midicontrols.py:1597
+#: python/midicontrols.py:1598
 msgid "Reversed"
 msgstr ""
 
-#: python/midicontrols.py:1598
+#: python/midicontrols.py:1599
 msgid "Pressed"
 msgstr ""
 
-#: python/midicontrols.py:1600
+#: python/midicontrols.py:1601
 msgid "Released"
 msgstr ""
 
 #. TC: Tree column heading for Inputs e.g. Backspace, F1, S.
-#: python/midicontrols.py:1630 python/midicontrols.py:1991
+#: python/midicontrols.py:1631 python/midicontrols.py:1992
 msgid "Input"
 msgstr ""
 
-#: python/midicontrols.py:1634
+#: python/midicontrols.py:1635
 #, python-format
 msgid ""
 "The first half of a binding is the input which comes in the form of the "
@@ -1853,31 +1880,31 @@ msgid ""
 msgstr ""
 
 #. TC: Tree column heading for actions e.g. Player stop.
-#: python/midicontrols.py:1670 python/midicontrols.py:1676
-#: python/midicontrols.py:2005
+#: python/midicontrols.py:1671 python/midicontrols.py:1677
+#: python/midicontrols.py:2006
 msgid "Action"
 msgstr ""
 
 #. TC: %s is the translation of 'Action'.
-#: python/midicontrols.py:1675
+#: python/midicontrols.py:1676
 #, python-format
 msgid "The '%s' pane determines how the input is handled, and to what effect."
 msgstr ""
 
-#: python/midicontrols.py:1732
+#: python/midicontrols.py:1733
 msgid "Listening for input"
 msgstr ""
 
 #. TC: Refers to key modifiers including Ctrl, Alt, Shift, ....
-#: python/midicontrols.py:1753
+#: python/midicontrols.py:1754
 msgid "Shifting"
 msgstr ""
 
-#: python/midicontrols.py:1952
+#: python/midicontrols.py:1953
 msgid "Singular control"
 msgstr ""
 
-#: python/midicontrols.py:2014
+#: python/midicontrols.py:2015
 msgid "Target"
 msgstr ""
 
@@ -1923,7 +1950,7 @@ msgid " Additional Text Frames "
 msgstr ""
 
 #. TC: The album track number.
-#: python/mutagentagger.py:376 python/songdb.py:789 python/songdb.py:1160
+#: python/mutagentagger.py:376 python/songdb.py:906 python/songdb.py:1295
 msgid "Track"
 msgstr ""
 
@@ -1949,217 +1976,250 @@ msgstr ""
 msgid "Native"
 msgstr ""
 
-#: python/songdb.py:174
+#: python/songdb.py:177
 msgid "Connecting"
 msgstr ""
 
-#: python/songdb.py:183
+#: python/songdb.py:188
 #, python-format
 msgid "Connection failed (try %d)"
 msgstr ""
 
-#: python/songdb.py:195
-msgid "Connected: utf-8 mode failed"
+#: python/songdb.py:199
+msgid "Connected: autocommit mode failed"
 msgstr ""
 
-#: python/songdb.py:197
+#: python/songdb.py:201
+msgid "Connected: autocommit mode set"
+msgstr ""
+
+#: python/songdb.py:202
 msgid "Connected"
 msgstr ""
 
-#: python/songdb.py:205
+#: python/songdb.py:210
 msgid "Job dropped"
 msgstr ""
 
-#: python/songdb.py:215 python/songdb.py:427
+#: python/songdb.py:220 python/songdb.py:431
 msgid "Disconnected"
 msgstr ""
 
-#: python/songdb.py:229
+#: python/songdb.py:233
 msgid "Problem dropping connection"
 msgstr ""
 
-#: python/songdb.py:231
+#: python/songdb.py:235
 msgid "Connection dropped"
 msgstr ""
 
-#: python/songdb.py:322
+#: python/songdb.py:326
 msgid "Hostname[:Port]"
 msgstr ""
 
-#: python/songdb.py:327
+#: python/songdb.py:331
 msgid "User Name"
 msgstr ""
 
-#: python/songdb.py:330
+#: python/songdb.py:334
 msgid "Database"
 msgstr ""
 
-#: python/songdb.py:385
+#: python/songdb.py:389
 msgid "Prokyon3 or Ampache (song title) Database"
 msgstr ""
 
-#: python/songdb.py:386
+#: python/songdb.py:390
 msgid ""
 "You can make certain media databases accessible in IDJC for easy drag and "
 "drop into the playlists."
 msgstr ""
 
-#: python/songdb.py:434
+#: python/songdb.py:438
 msgid "Module mysql-python (MySQLdb) required"
 msgstr ""
 
-#: python/songdb.py:675 python/songdb.py:680
+#: python/songdb.py:707 python/songdb.py:723 python/songdb.py:747
+#: python/songdb.py:805
 msgid "<unknown>"
 msgstr ""
 
-#: python/songdb.py:761
+#: python/songdb.py:741
+msgid "Not Played"
+msgstr ""
+
+#: python/songdb.py:878
 msgid "Reload the database."
 msgstr ""
 
-#: python/songdb.py:766
+#: python/songdb.py:883
 msgid "Expand entire tree."
 msgstr ""
 
-#: python/songdb.py:767
+#: python/songdb.py:884
 msgid "Collapse tree."
 msgstr ""
 
-#: python/songdb.py:774
+#: python/songdb.py:891
 msgid "Browse"
 msgstr ""
 
 #. TC: The disk number of the album track.
-#: python/songdb.py:787 python/songdb.py:1159
+#: python/songdb.py:904 python/songdb.py:1294
 msgid "Disk"
 msgstr ""
 
 #. TC: Track playback time.
 #. TC: Playback time.
-#: python/songdb.py:791 python/songdb.py:1162 python/playergui.py:312
+#: python/songdb.py:908 python/songdb.py:1296 python/playergui.py:313
 msgid "Duration"
 msgstr ""
 
-#: python/songdb.py:792 python/songdb.py:1163
+#: python/songdb.py:910 python/songdb.py:1297 python/format.py:594
+#: python/format.py:615 python/format.py:701 python/format.py:722
+#: python/format.py:857 python/format.py:962 python/format.py:1012
+#: python/format.py:1022
 msgid "Bitrate"
 msgstr ""
 
-#: python/songdb.py:793 python/songdb.py:1164
+#: python/songdb.py:911 python/songdb.py:1298
 msgid "Filename"
 msgstr ""
 
 #. TC: Directory path to a file.
-#: python/songdb.py:795 python/songdb.py:1165
+#: python/songdb.py:913 python/songdb.py:1299
 msgid "Path"
 msgstr ""
 
-#: python/songdb.py:800
+#: python/songdb.py:918
 msgid "Artist - Album - Title"
 msgstr ""
 
-#: python/songdb.py:801
+#: python/songdb.py:919
 msgid "Album - [Disk] - Title"
 msgstr ""
 
-#: python/songdb.py:821
+#: python/songdb.py:939
 msgid "Fetching"
 msgstr ""
 
-#: python/songdb.py:953
+#: python/songdb.py:1084
 msgid "Tree fetch failed"
 msgstr ""
 
-#: python/songdb.py:955
+#: python/songdb.py:1085
 msgid "Fetch Failed!"
 msgstr ""
 
-#: python/songdb.py:968
+#: python/songdb.py:1098
 msgid "Populating"
 msgstr ""
 
-#: python/songdb.py:1094
+#: python/songdb.py:1224
 #, python-format
 msgid "Disk %d"
 msgstr ""
 
 #. TC: User specified search filter entry box title text.
-#: python/songdb.py:1113
+#: python/songdb.py:1243
 msgid "Filters"
 msgstr ""
 
 #. TC: A type of search on any data field matching paritial strings.
-#: python/songdb.py:1125
+#: python/songdb.py:1255
 msgid "Fuzzy Search"
 msgstr ""
 
 #. TC: WHERE is an SQL keyword.
-#: python/songdb.py:1134
+#: python/songdb.py:1264
 msgid "WHERE"
 msgstr ""
 
-#: python/songdb.py:1147
+#: python/songdb.py:1277
 msgid "Search"
 msgstr ""
 
-#: python/songdb.py:1440
+#: python/songdb.py:1514 python/songdb.py:1639
+msgid "Minutes"
+msgstr ""
+
+#: python/songdb.py:1514 python/songdb.py:1639
+msgid "Hours"
+msgstr ""
+
+#: python/songdb.py:1515 python/songdb.py:1639
+msgid "Days"
+msgstr ""
+
+#: python/songdb.py:1515 python/songdb.py:1639 python/songdb.py:1709
+#: python/songdb.py:1803
+msgid "Weeks"
+msgstr ""
+
+#: python/songdb.py:1609
 msgid "Catalogs"
 msgstr ""
 
-#: python/songdb.py:1445
+#: python/songdb.py:1616
 msgid "Name"
 msgstr ""
 
-#: python/songdb.py:1446
+#: python/songdb.py:1617
 msgid "Catalog Path"
 msgstr ""
 
-#: python/songdb.py:1447
+#: python/songdb.py:1618
 msgid "Prepend Path"
 msgstr ""
 
-#: python/songdb.py:1462
+#: python/songdb.py:1626
+msgid "Last Played Scale"
+msgstr ""
+
+#: python/songdb.py:1658
 msgid "Path Peel"
 msgstr ""
 
-#: python/songdb.py:1528
+#: python/songdb.py:1737
 msgid "N/A"
 msgstr ""
 
-#: python/songdb.py:1703
+#: python/songdb.py:1918
 msgid "Failed to create FULLTEXT index"
 msgstr ""
 
-#: python/songdb.py:1707
+#: python/songdb.py:1922
 msgid "Found existing FULLTEXT index"
 msgstr ""
 
-#: python/songdb.py:1721 python/songdb.py:1734
+#: python/songdb.py:1936 python/songdb.py:1949
 msgid "Unrecognised database"
 msgstr ""
 
-#: python/songdb.py:1729
+#: python/songdb.py:1944
 msgid "Found Prokyon 3 schema"
 msgstr ""
 
-#: python/playergui.py:235
+#: python/playergui.py:236
 msgid "Cuesheet Playlist"
 msgstr ""
 
 #. TC: Column heading, the track number.
-#: python/playergui.py:301
+#: python/playergui.py:302
 msgid "Trk"
 msgstr ""
 
 #. TC: Column heading, the index number.
-#: python/playergui.py:304
+#: python/playergui.py:305
 msgid "Ind"
 msgstr ""
 
-#: python/playergui.py:413
+#: python/playergui.py:414
 msgid "External Playlist"
 msgstr ""
 
 #. TC: Button text to activate an external playlist.
-#: python/playergui.py:424
+#: python/playergui.py:425
 msgid "Active"
 msgstr ""
 
@@ -2187,263 +2247,271 @@ msgstr ""
 msgid "Modify or Delete this announcement"
 msgstr ""
 
-#. TC: Playlist control.
 #. TC: Embed a DJ announcement text into the playlist.
-#: python/playergui.py:528 python/playergui.py:3709 python/playergui.py:4347
+#: python/playergui.py:528 python/playergui.py:4430
 msgid "Announcement"
 msgstr ""
 
 #. TC: The time format as minutes and seconds.
-#: python/playergui.py:555
+#: python/playergui.py:556
 msgid "mm:ss"
 msgstr ""
 
 #. TC: Alongside the name of the next track.
-#: python/playergui.py:608
+#: python/playergui.py:609
 msgid "Next track"
 msgstr ""
 
-#: python/playergui.py:933
+#: python/playergui.py:934
 msgid "By Extension"
 msgstr ""
 
-#: python/playergui.py:933
+#: python/playergui.py:934
 msgid "M3U playlist"
 msgstr ""
 
 #: python/playergui.py:934
+msgid "M3U8 playlist"
+msgstr ""
+
+#: python/playergui.py:935
 msgid "XSPF playlist"
 msgstr ""
 
-#: python/playergui.py:934
+#: python/playergui.py:935
 msgid "PLS playlist"
 msgstr ""
 
-#: python/playergui.py:1006
+#: python/playergui.py:1007
 #, python-format
 msgid "%d Audio Tracks"
 msgstr ""
 
 #. TC: Missing metadata text.
-#: python/playergui.py:1016
+#: python/playergui.py:1017
 msgid "Unknown"
 msgstr ""
 
-#: python/playergui.py:1020
+#: python/playergui.py:1021
 msgid "(Cue sheet)"
 msgstr ""
 
-#: python/playergui.py:1054
+#: python/playergui.py:1058
 msgid "Bad Tag"
 msgstr ""
 
-#: python/playergui.py:1830 python/playergui.py:4185
+#: python/playergui.py:1888 python/playergui.py:4268
 msgid "Manual"
 msgstr ""
 
-#: python/playergui.py:1834 python/playergui.py:4182
+#: python/playergui.py:1892 python/playergui.py:4265
 msgid "Play All"
 msgstr ""
 
-#: python/playergui.py:1842 python/playergui.py:1851 python/playergui.py:4183
+#: python/playergui.py:1900 python/playergui.py:1909 python/playergui.py:4266
 msgid "Loop All"
 msgstr ""
 
-#: python/playergui.py:1842 python/playergui.py:4186
+#: python/playergui.py:1900 python/playergui.py:4269
 msgid "Cue Up"
 msgstr ""
 
-#: python/playergui.py:1843 python/playergui.py:4190
+#: python/playergui.py:1901 python/playergui.py:4273
 msgid "Fade Over"
 msgstr ""
 
-#: python/playergui.py:1855 python/playergui.py:1926 python/playergui.py:4184
+#: python/playergui.py:1913 python/playergui.py:1984 python/playergui.py:4267
 msgid "Random"
 msgstr ""
 
-#: python/playergui.py:1895 python/playergui.py:4187
+#: python/playergui.py:1953 python/playergui.py:4270
 msgid "External"
 msgstr ""
 
-#: python/playergui.py:1907 python/playergui.py:1923 python/playergui.py:4189
+#: python/playergui.py:1965 python/playergui.py:1981 python/playergui.py:4272
 msgid "Alternate"
 msgstr ""
 
-#: python/playergui.py:1907 python/playergui.py:1925 python/playergui.py:4191
+#: python/playergui.py:1965 python/playergui.py:1983 python/playergui.py:4274
 msgid "Random Hop"
 msgstr ""
 
 #. TC: The remaining playlist time.
-#: python/playergui.py:2080 python/playergui.py:2086
+#: python/playergui.py:2138 python/playergui.py:2144
 msgid "Remaining"
 msgstr ""
 
 #. TC: The estimated finish time of the playlist.
 #. TC: The estimated finish time of the playlist (ETA).
-#: python/playergui.py:2082 python/playergui.py:2086 python/playergui.py:2100
+#: python/playergui.py:2140 python/playergui.py:2144 python/playergui.py:2158
 msgid "Finish"
 msgstr ""
 
 #. TC: The play duration of the block of audio tracks.
-#: python/playergui.py:2087 python/playergui.py:2098
+#: python/playergui.py:2145 python/playergui.py:2156
 msgid "Block size"
 msgstr ""
 
 #. TC: File dialog title text.
-#: python/playergui.py:2485
+#: python/playergui.py:2546
 msgid "Add music to left playlist"
 msgstr ""
 
 #. TC: File dialog title text.
-#: python/playergui.py:2488
+#: python/playergui.py:2549
 msgid "Add music to right playlist"
 msgstr ""
 
-#: python/playergui.py:2490
+#: python/playergui.py:2551
 msgid "Add background music"
 msgstr ""
 
 #. TC: File filter text.
-#: python/playergui.py:2502
+#: python/playergui.py:2563
 msgid "Supported Media Formats"
 msgstr ""
 
 #. TC: Expander text "Select File Type (.pls)" for the pls file type.
-#: python/playergui.py:2564
+#: python/playergui.py:2625
 msgid "Select File Type"
 msgstr ""
 
-#: python/playergui.py:3308
+#: python/playergui.py:3383
 msgid "Save left playlist"
 msgstr ""
 
-#: python/playergui.py:3310
+#: python/playergui.py:3385
 msgid "Save right playlist"
 msgstr ""
 
-#: python/playergui.py:3312
+#: python/playergui.py:3387
 msgid "Save background playlist"
 msgstr ""
 
-#: python/playergui.py:3330
+#: python/playergui.py:3405
 msgid "File Type"
 msgstr ""
 
-#: python/playergui.py:3335
+#: python/playergui.py:3410
 msgid "Extension"
 msgstr ""
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to do a ten second fade to the next track.
-#: python/playergui.py:3693 python/playergui.py:4358
+#: python/playergui.py:3774 python/playergui.py:4441
 msgid "Fade 10s"
 msgstr ""
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to do a five second fade to the next track.
-#: python/playergui.py:3699 python/playergui.py:4365
+#: python/playergui.py:3780 python/playergui.py:4448
 msgid "Fade 5s"
 msgstr ""
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to not do a fade to the next track.
-#: python/playergui.py:3704 python/playergui.py:4372
+#: python/playergui.py:3785 python/playergui.py:4455
 msgid "No Fade"
 msgstr ""
 
 #. TC: Playlist control.
-#: python/playergui.py:3714
+#: python/playergui.py:3793
 msgid ">> Normal Speed <<"
 msgstr ""
 
 #. TC: Playlist control.
-#: python/playergui.py:3724
+#: python/playergui.py:3803
 msgid "Player stop 2"
 msgstr ""
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to jump to the top of the playlist.
-#: python/playergui.py:3729 python/playergui.py:4324
+#: python/playergui.py:3808 python/playergui.py:4407
 msgid "Jump To Top"
 msgstr ""
 
 #. TC: Playlist control.
-#: python/playergui.py:3734 python/playergui.py:4384
+#: python/playergui.py:3813 python/playergui.py:4467
 msgid "Stop streaming"
 msgstr ""
 
 #. TC: Playlist control.
-#: python/playergui.py:3739 python/playergui.py:4392
+#: python/playergui.py:3818 python/playergui.py:4475
 msgid "Stop recording"
 msgstr ""
 
+#: python/playergui.py:3851
+msgid "Announcement:"
+msgstr ""
+
 #. TC: Playlist control.
-#: python/playergui.py:3774
+#: python/playergui.py:3857
 msgid ">>> Transfer across >>>"
 msgstr ""
 
 #. TC: Playlist control.
-#: python/playergui.py:3777
+#: python/playergui.py:3860
 msgid "<<< Transfer across <<<"
 msgstr ""
 
 #. TC: Playlist control.
-#: python/playergui.py:3782
+#: python/playergui.py:3865
 msgid ">>> Fade across >>>"
 msgstr ""
 
 #. TC: Playlist control.
-#: python/playergui.py:3785
+#: python/playergui.py:3868
 msgid "<<< Fade across <<<"
 msgstr ""
 
 #. TC: Playlist control.
-#: python/playergui.py:3791
+#: python/playergui.py:3874
 msgid "Ignored playlist control"
 msgstr ""
 
-#: python/playergui.py:3859
+#: python/playergui.py:3942
+#, python-brace-format
 msgid "Playing track {0} of {1}"
 msgstr ""
 
 #. TC: Previous line: Playing track {0} of {1}
-#: python/playergui.py:3872
+#: python/playergui.py:3955
 #, python-format
 msgid "From the album, %s"
 msgstr ""
 
-#: python/playergui.py:3879
+#: python/playergui.py:3962
 #, python-format
 msgid "Total number of tracks %d"
 msgstr ""
 
-#: python/playergui.py:3883 python/playergui.py:3885
+#: python/playergui.py:3966 python/playergui.py:3968
 #, python-format
 msgid "Total play duration %s"
 msgstr ""
 
-#: python/playergui.py:3935
+#: python/playergui.py:4018
 msgid ""
 "Left click toggles between showing the amount of time elapsed or remaining "
 "on the current track being played."
 msgstr ""
 
-#: python/playergui.py:3953
+#: python/playergui.py:4036
 msgid ""
 "This slider acts as both a play progress indicator and as a means for "
 "seeking within the currently playing track."
 msgstr ""
 
 #. TC: File filter text.
-#: python/playergui.py:4042
+#: python/playergui.py:4125
 msgid "All file types"
 msgstr ""
 
-#: python/playergui.py:4047
-msgid "Playlist types (*.m3u, *.xspf, *.pls)"
+#: python/playergui.py:4130
+msgid "Playlist types"
 msgstr ""
 
-#: python/playergui.py:4062
+#: python/playergui.py:4145
 msgid ""
 "'Block size' indicates the amount of time that it will take to play from the "
 "currently selected track to the next stop.\n"
@@ -2451,43 +2519,43 @@ msgid ""
 "'Finish' Is the computed time when the tracks will have finished playing."
 msgstr ""
 
-#: python/playergui.py:4085
+#: python/playergui.py:4168
 msgid "This adjusts the playback speed anywhere from 25% to 400%."
 msgstr ""
 
-#: python/playergui.py:4099
+#: python/playergui.py:4182
 msgid "This sets the playback speed back to normal."
 msgstr ""
 
-#: python/playergui.py:4116
+#: python/playergui.py:4199
 msgid "Previous track."
 msgstr ""
 
-#: python/playergui.py:4128
+#: python/playergui.py:4211
 msgid "Play."
 msgstr ""
 
-#: python/playergui.py:4138
+#: python/playergui.py:4221
 msgid "Pause."
 msgstr ""
 
-#: python/playergui.py:4148
+#: python/playergui.py:4231
 msgid "Stop."
 msgstr ""
 
-#: python/playergui.py:4158
+#: python/playergui.py:4241
 msgid "Next track."
 msgstr ""
 
-#: python/playergui.py:4170
+#: python/playergui.py:4253
 msgid "Add tracks to the playlist."
 msgstr ""
 
-#: python/playergui.py:4177 python/preferences.py:70
+#: python/playergui.py:4260 python/preferences.py:71
 msgid "Playlist Mode"
 msgstr ""
 
-#: python/playergui.py:4196
+#: python/playergui.py:4279
 msgid ""
 "This sets the playlist mode which defines player behaviour after a track has "
 "finished playing.\n"
@@ -2521,31 +2589,31 @@ msgid ""
 msgstr ""
 
 #. TC: Fade time heading.
-#: python/playergui.py:4220 python/preferences.py:71
+#: python/playergui.py:4303 python/preferences.py:72
 msgid "Fade"
 msgstr ""
 
-#: python/playergui.py:4232
+#: python/playergui.py:4315
 msgid "This controls the amount of fade between tracks."
 msgstr ""
 
-#: python/playergui.py:4239
+#: python/playergui.py:4322
 msgid "Audio Feed"
 msgstr ""
 
-#: python/playergui.py:4249
+#: python/playergui.py:4332
 msgid "Make output from this player available for streaming."
 msgstr ""
 
-#: python/playergui.py:4257
+#: python/playergui.py:4340
 msgid "Make output from this player audible to the DJ."
 msgstr ""
 
-#: python/playergui.py:4259
+#: python/playergui.py:4342
 msgid "Force"
 msgstr ""
 
-#: python/playergui.py:4265
+#: python/playergui.py:4348
 msgid ""
 "When selected this player will be treated like a main player.\n"
 "It will be affected by microphone ducking and won't mute when a main player "
@@ -2553,142 +2621,142 @@ msgid ""
 msgstr ""
 
 #. TC: Insert playlist control.
-#: python/playergui.py:4278
+#: python/playergui.py:4361
 msgid "Insert control"
 msgstr ""
 
 #. TC: The Item submenu.
-#: python/playergui.py:4287
+#: python/playergui.py:4370
 msgid "Item"
 msgstr ""
 
 #. TC: The Playlist submenu.
-#: python/playergui.py:4292
+#: python/playergui.py:4375
 msgid "Playlist"
 msgstr ""
 
 #. TC: Insert playlist control to set playback speed to normal.
-#: python/playergui.py:4303
+#: python/playergui.py:4386
 msgid "Normal Speed"
 msgstr ""
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4332 python/playergui.py:4486
+#: python/playergui.py:4415 python/playergui.py:4569
 msgid "Transfer"
 msgstr ""
 
-#: python/playergui.py:4340
+#: python/playergui.py:4423
 msgid "Crossfade"
 msgstr ""
 
 #. TC: Menu item. Opens the metadata tagger on the selected track.
-#: python/playergui.py:4405
+#: python/playergui.py:4488
 msgid "Meta Tag"
 msgstr ""
 
 #. TC: Menu Item. Duplicates the selected track in the playlist.
-#: python/playergui.py:4411
+#: python/playergui.py:4494
 msgid "Duplicate"
 msgstr ""
 
 #. TC: Menu Item. Remove the selected track.
-#: python/playergui.py:4418
+#: python/playergui.py:4501
 msgid "Remove"
 msgstr ""
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4429
+#: python/playergui.py:4512
 msgid "This"
 msgstr ""
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4436 python/preferences.py:1234
+#: python/playergui.py:4519 python/preferences.py:1237
 msgid "All"
 msgstr ""
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4443
+#: python/playergui.py:4526
 msgid "From Here"
 msgstr ""
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4450
+#: python/playergui.py:4533
 msgid "To Here"
 msgstr ""
 
 #. TC: Open the file dialog for adding music to the chosen playlist.
-#: python/playergui.py:4463
+#: python/playergui.py:4546
 msgid "Add Music"
 msgstr ""
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4470
+#: python/playergui.py:4553
 msgid "Save"
 msgstr ""
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4481
+#: python/playergui.py:4564
 msgid "Copy"
 msgstr ""
 
-#: python/playergui.py:4492
+#: python/playergui.py:4575
 msgid "Exchange"
 msgstr ""
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4499
+#: python/playergui.py:4582
 msgid "Empty"
 msgstr ""
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4513 python/playergui.py:4552
+#: python/playergui.py:4596 python/playergui.py:4635
 msgid "Append"
 msgstr ""
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4520 python/playergui.py:4559
+#: python/playergui.py:4603 python/playergui.py:4642
 msgid "Prepend"
 msgstr ""
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
-#: python/playergui.py:4531
+#: python/playergui.py:4614
 msgid "Append Cursor"
 msgstr ""
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
-#: python/playergui.py:4538
+#: python/playergui.py:4621
 msgid "Prepend Cursor"
 msgstr ""
 
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4570
+#: python/playergui.py:4653
 msgid "Append at Cursor"
 msgstr ""
 
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4577
+#: python/playergui.py:4660
 msgid "Prepend at Cursor"
 msgstr ""
 
-#: python/preferences.py:84
+#: python/preferences.py:85
 msgid "Track time elapsed"
 msgstr ""
 
-#: python/preferences.py:86
+#: python/preferences.py:87
 msgid "Track time remaining"
 msgstr ""
 
-#: python/preferences.py:88
+#: python/preferences.py:89
 msgid "Audio to stream"
 msgstr ""
 
-#: python/preferences.py:89
+#: python/preferences.py:90
 msgid "Audio to DJ"
 msgstr ""
 
-#: python/preferences.py:126
+#: python/preferences.py:127
 #, python-format
 msgid ""
 "Stereo panning is the selection of where an audio source sits from left to "
@@ -2704,11 +2772,11 @@ msgid ""
 "stereo field is the intention."
 msgstr ""
 
-#: python/preferences.py:157
+#: python/preferences.py:158
 msgid "Presets"
 msgstr ""
 
-#: python/preferences.py:248
+#: python/preferences.py:249
 msgid ""
 "The pan preset selection buttons.\n"
 "\n"
@@ -2719,124 +2787,124 @@ msgid ""
 msgstr ""
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:273
+#: python/preferences.py:274
 msgid "Deactivated"
 msgstr ""
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:275
+#: python/preferences.py:276
 msgid "Basic input"
 msgstr ""
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:277
+#: python/preferences.py:278
 msgid "Processed input"
 msgstr ""
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:279
+#: python/preferences.py:280
 #, python-format
 msgid "Partnered with channel %s"
 msgstr ""
 
-#: python/preferences.py:429
+#: python/preferences.py:432
 msgid "A label so you may describe briefly the role of this audio channel."
 msgstr ""
 
-#: python/preferences.py:461
+#: python/preferences.py:464
 msgid "The signal processing mode."
 msgstr ""
 
 #. TC: A frame heading. The channel opener is selected within.
-#: python/preferences.py:465
+#: python/preferences.py:468
 msgid "Channel Opener"
 msgstr ""
 
-#: python/preferences.py:468
+#: python/preferences.py:471
 msgid ""
 "This controls the allocation of front panel open/unmute buttons. Having one "
 "button control multiple microphones can save time."
 msgstr ""
 
 #. TC: Spinbutton label text.
-#: python/preferences.py:475
+#: python/preferences.py:478
 msgid "Main Panel Button"
 msgstr ""
 
-#: python/preferences.py:492
+#: python/preferences.py:495
 msgid "This:"
 msgstr ""
 
-#: python/preferences.py:501
+#: python/preferences.py:504
 msgid "Open"
 msgstr ""
 
-#: python/preferences.py:514
+#: python/preferences.py:517
 msgid "Stereo Panning"
 msgstr ""
 
 #. TC: A set of controls that perform audio signal matching.
-#: python/preferences.py:527
+#: python/preferences.py:530
 msgid "Signal Matching"
 msgstr ""
 
-#: python/preferences.py:528
+#: python/preferences.py:531
 msgid ""
 "These controls are provided to obtain a decent match between the two "
 "microphones."
 msgstr ""
 
-#: python/preferences.py:537
+#: python/preferences.py:540
 msgid "Relative Gain (dB)"
 msgstr ""
 
 #. TC: Mic audio phase inversion control.
-#: python/preferences.py:542 python/preferences.py:547
+#: python/preferences.py:545 python/preferences.py:550
 msgid "Invert Signal"
 msgstr ""
 
-#: python/preferences.py:548 python/preferences.py:568
-#: python/preferences.py:664
+#: python/preferences.py:551 python/preferences.py:571
+#: python/preferences.py:667
 msgid ""
 "Useful for when microphones are cancelling one another out, producing a "
 "hollow sound."
 msgstr ""
 
 #. TC: Control whether to mix microphone audio to the DJ mix.
-#: python/preferences.py:551
+#: python/preferences.py:554
 msgid "In The DJ's Mix"
 msgstr ""
 
-#: python/preferences.py:552 python/preferences.py:574
-#: python/preferences.py:674
+#: python/preferences.py:555 python/preferences.py:577
+#: python/preferences.py:677
 msgid ""
 "Make the microphone audio audible in the DJ mix. This may not always be "
 "desirable."
 msgstr ""
 
-#: python/preferences.py:560
+#: python/preferences.py:563
 msgid "Basic Controls"
 msgstr ""
 
-#: python/preferences.py:561 python/preferences.py:616
+#: python/preferences.py:564 python/preferences.py:619
 msgid "Boost/Cut (dB)"
 msgstr ""
 
-#: python/preferences.py:582
+#: python/preferences.py:585
 msgid "High Pass Filter"
 msgstr ""
 
-#: python/preferences.py:583 python/preferences.py:598
-#: python/preferences.py:608
+#: python/preferences.py:586 python/preferences.py:601
+#: python/preferences.py:611
 msgid "Cutoff Frequency"
 msgstr ""
 
 #. TC: User can set the number of filter stages.
-#: python/preferences.py:587
+#: python/preferences.py:590
 msgid "Stages"
 msgstr ""
 
-#: python/preferences.py:590
+#: python/preferences.py:593
 msgid ""
 "Frequency in Hertz above which audio can pass to later stages. Use this "
 "feature to restrict low frequency sounds such as mains hum. Setting too high "
@@ -2844,136 +2912,136 @@ msgid ""
 msgstr ""
 
 #. TC: this is the treble control. HF = high frequency.
-#: python/preferences.py:595
+#: python/preferences.py:598
 msgid "HF Detail"
 msgstr ""
 
-#: python/preferences.py:602
+#: python/preferences.py:605
 msgid "You can use this to boost the amount of treble in the audio."
 msgstr ""
 
 #. TC: this is the bass control. LF = low frequency.
-#: python/preferences.py:605
+#: python/preferences.py:608
 msgid "LF Detail"
 msgstr ""
 
-#: python/preferences.py:612
+#: python/preferences.py:615
 msgid "You can use this to boost the amount of bass in the audio."
 msgstr ""
 
 #. TC: lookahead brick wall limiter.
-#: python/preferences.py:615
+#: python/preferences.py:618
 msgid "Limiter"
 msgstr ""
 
 #. TC: this is the peak signal limit.
-#: python/preferences.py:620
+#: python/preferences.py:623
 msgid "Upper Limit"
 msgstr ""
 
-#: python/preferences.py:622
+#: python/preferences.py:625
 msgid ""
 "A look-ahead brick-wall limiter. Audio signals are capped at the upper limit."
 msgstr ""
 
-#: python/preferences.py:625
+#: python/preferences.py:628
 msgid "Noise Gate"
 msgstr ""
 
 #. TC: noise gate triggers at this level.
-#: python/preferences.py:627
+#: python/preferences.py:630
 msgid "Threshold"
 msgstr ""
 
 #. TC: negative gain when the noise gate is active.
 #. TC: The de-esser attenuation in ess-detected state.
-#: python/preferences.py:631 python/preferences.py:641
+#: python/preferences.py:634 python/preferences.py:644
 msgid "Gain"
 msgstr ""
 
-#: python/preferences.py:633
+#: python/preferences.py:636
 msgid ""
 "Reduce the unwanted quietest sounds and background noise which you don't "
 "want your listeners to hear with this."
 msgstr ""
 
-#: python/preferences.py:636
+#: python/preferences.py:639
 msgid "De-esser"
 msgstr ""
 
 #. TC: Bias has a numeric setting.
-#: python/preferences.py:638
+#: python/preferences.py:641
 msgid "Bias"
 msgstr ""
 
-#: python/preferences.py:643
+#: python/preferences.py:646
 msgid ""
 "Reduce the S, T, and P sounds which microphones tend to exaggerate. Ideally "
 "the Bias control will be set low so that the de-esser is off when there is "
 "silence but is set high enough that mouse clicks are detected and suppressed."
 msgstr ""
 
-#: python/preferences.py:648
+#: python/preferences.py:651
 msgid "Ducker"
 msgstr ""
 
-#: python/preferences.py:649
+#: python/preferences.py:652
 msgid "Release"
 msgstr ""
 
-#: python/preferences.py:652
+#: python/preferences.py:655
 msgid "Hold"
 msgstr ""
 
-#: python/preferences.py:655
+#: python/preferences.py:658
 msgid ""
 "The ducker automatically reduces the level of player audio when the DJ "
 "speaks. These settings allow you to adjust the timings of that audio "
 "reduction."
 msgstr ""
 
-#: python/preferences.py:659
+#: python/preferences.py:662
 msgid "Other options"
 msgstr ""
 
-#: python/preferences.py:666
+#: python/preferences.py:669
 msgid "Phase Rotator"
 msgstr ""
 
-#: python/preferences.py:669
+#: python/preferences.py:672
 msgid ""
 "This feature processes the microphone audio so that it sounds more even. The "
 "effect is particularly noticable on male voices."
 msgstr ""
 
-#: python/preferences.py:852
+#: python/preferences.py:855
 msgid "The volume control for the left music player."
 msgstr ""
 
 #. TC: preferences window title.
-#: python/preferences.py:908
+#: python/preferences.py:911
 msgid "IDJC Preferences"
 msgstr ""
 
 #. TC: The DJ's sound level controller.
-#: python/preferences.py:933
+#: python/preferences.py:936
 msgid "DJ Audio Level"
 msgstr ""
 
-#: python/preferences.py:945
+#: python/preferences.py:948
 msgid "This adjusts the sound level of the DJ audio."
 msgstr ""
 
 #. TC: The alarm sound level.
-#: python/preferences.py:950
+#: python/preferences.py:953
 msgid "Alarm Level"
 msgstr ""
 
-#: python/preferences.py:964
+#: python/preferences.py:967
 msgid "Music Loudness Compensation"
 msgstr ""
 
-#: python/preferences.py:962
+#: python/preferences.py:965
 #, python-format
 msgid ""
 "This adjusts the sound level of the DJ alarm. Typically this should be set "
@@ -2981,11 +3049,11 @@ msgid ""
 "louder."
 msgstr ""
 
-#: python/preferences.py:970
+#: python/preferences.py:973
 msgid "Player Resample Quality"
 msgstr ""
 
-#: python/preferences.py:976
+#: python/preferences.py:979
 msgid ""
 "This adjusts the quality of the audio resampling method used whenever the "
 "sample rate of the music file currently playing does not match the sample "
@@ -2994,144 +3062,144 @@ msgid ""
 "these modes provide adequate sound quality."
 msgstr ""
 
-#: python/preferences.py:984
+#: python/preferences.py:987
 msgid "Best"
 msgstr ""
 
-#: python/preferences.py:993
+#: python/preferences.py:996 python/format.py:512
 msgid "Medium"
 msgstr ""
 
-#: python/preferences.py:1002
+#: python/preferences.py:1005
 msgid "Fast"
 msgstr ""
 
 #. TC: the set of features - section heading.
-#: python/preferences.py:1017
+#: python/preferences.py:1020
 msgid "Feature Set"
 msgstr ""
 
 #. TC: Start in the full featured user interface mode.
-#: python/preferences.py:1029
+#: python/preferences.py:1032
 msgid "Start Full"
 msgstr ""
 
-#: python/preferences.py:1034 python/preferences.py:1042
+#: python/preferences.py:1037 python/preferences.py:1045
 msgid "Indicates which mode IDJC will be in when launched."
 msgstr ""
 
 #. TC: Start in a reduced user interface mode.
-#: python/preferences.py:1037
+#: python/preferences.py:1040
 msgid "Start Mini"
 msgstr ""
 
-#: python/preferences.py:1050
+#: python/preferences.py:1053
 msgid "Fully Featured"
 msgstr ""
 
-#: python/preferences.py:1055
+#: python/preferences.py:1058
 msgid "Run in full functionality mode which uses more CPU power."
 msgstr ""
 
-#: python/preferences.py:1057
+#: python/preferences.py:1060
 msgid "Basic Streamer"
 msgstr ""
 
-#: python/preferences.py:1061
+#: python/preferences.py:1064
 msgid ""
 "Run in a reduced functionality mode that lowers the burden on the CPU and "
 "takes up less screen space."
 msgstr ""
 
-#: python/preferences.py:1069
+#: python/preferences.py:1072
 msgid "These settings take effect after restarting"
 msgstr ""
 
-#: python/preferences.py:1090
+#: python/preferences.py:1093
 msgid "Reserve 24 sound effects slots"
 msgstr ""
 
-#: python/preferences.py:1091
+#: python/preferences.py:1094
 msgid "Only 12"
 msgstr ""
 
-#: python/preferences.py:1103
+#: python/preferences.py:1106
 msgid "Audio input channels"
 msgstr ""
 
-#: python/preferences.py:1108
+#: python/preferences.py:1111
 msgid "Simultaneous stream(s)"
 msgstr ""
 
-#: python/preferences.py:1114
+#: python/preferences.py:1117
 msgid "Simultaneous recording(s)"
 msgstr ""
 
-#: python/preferences.py:1168
+#: python/preferences.py:1171
 msgid "Fill channel meter void space"
 msgstr ""
 
-#: python/preferences.py:1180
+#: python/preferences.py:1183
 msgid "Player Loudness Normalisation"
 msgstr ""
 
-#: python/preferences.py:1191
+#: python/preferences.py:1194
 msgid "Indicate which tracks have loudness metadata"
 msgstr ""
 
-#: python/preferences.py:1192
+#: python/preferences.py:1195
 msgid ""
 "Shows a marker in the playlists next to each track. Either a green circle or "
 "a red triangle."
 msgstr ""
 
-#: python/preferences.py:1200
+#: python/preferences.py:1203
 msgid "Adjust playback volume in dB"
 msgstr ""
 
-#: python/preferences.py:1201
+#: python/preferences.py:1204
 msgid "Effective only on newly started tracks."
 msgstr ""
 
-#: python/preferences.py:1207
+#: python/preferences.py:1210
 msgid "R128"
 msgstr ""
 
-#: python/preferences.py:1211
+#: python/preferences.py:1214
 msgid ""
 "It may not be desirable to use the default level since it is rather quiet. "
 "This should be set 4 or 5 dB higher than the ReplayGain setting."
 msgstr ""
 
-#: python/preferences.py:1216
+#: python/preferences.py:1219
 msgid "ReplayGain"
 msgstr ""
 
-#: python/preferences.py:1220
+#: python/preferences.py:1223
 msgid ""
 "It may not be desirable to use the default level since it is rather quiet. "
 "This should be set 4 or 5 dB lower than the R128 setting."
 msgstr ""
 
-#: python/preferences.py:1225
+#: python/preferences.py:1228
 msgid "Untagged"
 msgstr ""
 
-#: python/preferences.py:1229
+#: python/preferences.py:1232
 msgid ""
 "Set this so that any unmarked tracks are playing at a roughly similar "
 "loudness level as the marked ones."
 msgstr ""
 
-#: python/preferences.py:1238
+#: python/preferences.py:1241
 msgid "A master level control for the media players."
 msgstr ""
 
-#: python/preferences.py:1249
+#: python/preferences.py:1252
 msgid "Recorder Filename (excluding the file extension)"
 msgstr ""
 
-#: python/preferences.py:1250
+#: python/preferences.py:1253
 msgid ""
 "The specifiers are $r for the number of the recorder with the rest being "
 "documented in the strftime man page.\n"
@@ -3139,55 +3207,55 @@ msgid ""
 "particular filesystems."
 msgstr ""
 
-#: python/preferences.py:1267
+#: python/preferences.py:1270
 msgid "Miscellaneous Features"
 msgstr ""
 
-#: python/preferences.py:1276
+#: python/preferences.py:1279
 msgid "Trim quiet song endings and trailing silence"
 msgstr ""
 
-#: python/preferences.py:1282
+#: python/preferences.py:1285
 msgid "End tracks containing long passages of silence"
 msgstr ""
 
-#: python/preferences.py:1288
+#: python/preferences.py:1291
 msgid "Enable the main-player speed/pitch controls"
 msgstr ""
 
-#: python/preferences.py:1292
+#: python/preferences.py:1295
 msgid ""
 "This option causes some extra widgets to appear below the playlists which "
 "allow the playback speed to be adjusted from 25% to 400% and a normal speed "
 "button."
 msgstr ""
 
-#: python/preferences.py:1297
+#: python/preferences.py:1300
 msgid "Separate left/right player volume faders"
 msgstr ""
 
-#: python/preferences.py:1301
+#: python/preferences.py:1304
 msgid ""
 "Select this option to use an independent volume fader for the left and right "
 "music players."
 msgstr ""
 
-#: python/preferences.py:1305
+#: python/preferences.py:1308
 msgid "Enlarge the time elapsed/remaining windows"
 msgstr ""
 
-#: python/preferences.py:1309
+#: python/preferences.py:1312
 msgid ""
 "The time elapsed/remaining windows sometimes don't appear big enough for the "
 "text that appears in them due to unusual DPI settings or the use of a "
 "different rendering engine. This option serves to fix that."
 msgstr ""
 
-#: python/preferences.py:1315
+#: python/preferences.py:1318
 msgid "Sound an alarm when the music is due to end"
 msgstr ""
 
-#: python/preferences.py:1318
+#: python/preferences.py:1321
 msgid ""
 "An alarm tone alerting the DJ that dead-air is just nine seconds away. This "
 "also works when monitoring stream audio but the alarm tone is not sent to "
@@ -3196,142 +3264,146 @@ msgid ""
 "JACK freewheel mode will also be automatically disengaged."
 msgstr ""
 
-#: python/preferences.py:1328
+#: python/preferences.py:1331
 msgid "Apply dither to 16 bit PCM playback"
 msgstr ""
 
-#: python/preferences.py:1332
+#: python/preferences.py:1335
 msgid ""
 "This feature maybe improves the sound quality a little when listening on a "
 "24 bit sound card."
 msgstr ""
 
-#: python/preferences.py:1335
+#: python/preferences.py:1338
 msgid "Enable tooltips"
 msgstr ""
 
-#: python/preferences.py:1339
+#: python/preferences.py:1342
 msgid ""
 "This, what you are currently reading, is a tooltip. This feature turns them "
 "on or off."
 msgstr ""
 
-#: python/preferences.py:1358
+#: python/preferences.py:1361
 msgid "Player Settings At Startup"
 msgstr ""
 
-#: python/preferences.py:1369
+#: python/preferences.py:1372
 msgid "Restore the previous session"
 msgstr ""
 
-#: python/preferences.py:1374
+#: python/preferences.py:1377
 msgid ""
 "When starting IDJC most of the main window settings will be as they were "
 "left. As an alternative you may specify below how you want the various "
 "settings to be when IDJC starts."
 msgstr ""
 
-#: python/preferences.py:1384
+#: python/preferences.py:1387
 msgid "Player 1"
 msgstr ""
 
-#: python/preferences.py:1386
+#: python/preferences.py:1389
 msgid "Player 2"
 msgstr ""
 
 #. TC: DJ hears the stream mix.
-#: python/preferences.py:1414
+#: python/preferences.py:1417
 msgid "Monitor Stream Mix"
 msgstr ""
 
 #. TC: A heading label for miscellaneous settings.
-#: python/preferences.py:1425
+#: python/preferences.py:1428
 msgid "General"
 msgstr ""
 
-#: python/preferences.py:1475
+#: python/preferences.py:1478
 msgid "VoIP panning + mono downmix"
 msgstr ""
 
 #. TC: Keyboard and MIDI bindings configuration.
-#: python/preferences.py:1489
+#: python/preferences.py:1492
 msgid "Bindings"
 msgstr ""
 
-#: python/preferences.py:1537
+#: python/preferences.py:1540
 msgid "Licence"
 msgstr ""
 
-#: python/preferences.py:1560
+#: python/preferences.py:1563
 msgid "Contributors"
 msgstr ""
 
-#: python/preferences.py:1567
+#: python/preferences.py:1570
 msgid "Translators"
 msgstr ""
 
-#: python/preferences.py:1573
+#: python/preferences.py:1574
+msgid "Build Info"
+msgstr ""
+
+#: python/preferences.py:1591
 msgid "About"
 msgstr ""
 
-#: python/sourceclientgui.py:89
+#: python/sourceclientgui.py:91
 msgid "Insert Attribute"
 msgstr ""
 
-#: python/sourceclientgui.py:133
+#: python/sourceclientgui.py:135
 msgid "Icecast 2 Master"
 msgstr ""
 
-#: python/sourceclientgui.py:133
+#: python/sourceclientgui.py:135
 msgid "Shoutcast Master"
 msgstr ""
 
-#: python/sourceclientgui.py:134
+#: python/sourceclientgui.py:136
 msgid "Icecast 2 Stats/Relay"
 msgstr ""
 
-#: python/sourceclientgui.py:134
+#: python/sourceclientgui.py:136
 msgid "Shoutcast Stats/Relay"
 msgstr ""
 
-#: python/sourceclientgui.py:137
+#: python/sourceclientgui.py:139
 msgid "Enter new server connection details"
 msgstr ""
 
-#: python/sourceclientgui.py:156
+#: python/sourceclientgui.py:158
 msgid "Edit existing server connection details"
 msgstr ""
 
-#: python/sourceclientgui.py:193
+#: python/sourceclientgui.py:195
 msgid "This server is to be scanned for audience figures"
 msgstr ""
 
-#: python/sourceclientgui.py:206
+#: python/sourceclientgui.py:208
 msgid "Server type"
 msgstr ""
 
-#: python/sourceclientgui.py:206
+#: python/sourceclientgui.py:208
 msgid "Port number"
 msgstr ""
 
-#: python/sourceclientgui.py:207
+#: python/sourceclientgui.py:209
 msgid "Mount point"
 msgstr ""
 
-#: python/sourceclientgui.py:207
+#: python/sourceclientgui.py:209
 msgid "Login name"
 msgstr ""
 
-#: python/sourceclientgui.py:449
+#: python/sourceclientgui.py:475
 msgid "Encoder Format Not Set/Compatible"
 msgstr ""
 
 #. TC: Connection button text when no details have been entered.
-#: python/sourceclientgui.py:452
+#: python/sourceclientgui.py:478
 msgid "No Master Server Configured"
 msgstr ""
 
-#: python/sourceclientgui.py:654
+#: python/sourceclientgui.py:680
 msgid ""
 "A table of servers with which to connect. Only one master server can be "
 "added for the purpose of streaming. All other servers will appear below the "
@@ -3339,99 +3411,99 @@ msgid ""
 "toggled on a per server basis."
 msgstr ""
 
-#: python/sourceclientgui.py:670
+#: python/sourceclientgui.py:696
 msgid "Hostname/IP address"
 msgstr ""
 
 #. TC: Mount point is a technical term in relation to icecast servers.
-#: python/sourceclientgui.py:683
+#: python/sourceclientgui.py:709
 msgid "Mount point       "
 msgstr ""
 
 #. TC: This is the listener count heading.
-#: python/sourceclientgui.py:692
+#: python/sourceclientgui.py:718
 msgid "Listeners"
 msgstr ""
 
-#: python/sourceclientgui.py:707
+#: python/sourceclientgui.py:733
 msgid "The sum total of listeners in this server tab."
 msgstr ""
 
-#: python/sourceclientgui.py:734
+#: python/sourceclientgui.py:760
 msgid "Never"
 msgstr ""
 
-#: python/sourceclientgui.py:737
+#: python/sourceclientgui.py:763
 msgid "Always"
 msgstr ""
 
-#: python/sourceclientgui.py:739
+#: python/sourceclientgui.py:765
 msgid "If connected"
 msgstr ""
 
-#: python/sourceclientgui.py:995
+#: python/sourceclientgui.py:1021
 msgid "Custom user agent string"
 msgstr ""
 
-#: python/sourceclientgui.py:1002
+#: python/sourceclientgui.py:1028
 msgid ""
 "Set this on the occasion that the server or its firewall specifically "
 "refuses to allow libshout based clients."
 msgstr ""
 
-#: python/sourceclientgui.py:1007
+#: python/sourceclientgui.py:1033
 msgid "If the connection breaks reconnect to the server"
 msgstr ""
 
 #. TC: Label for a comma separated list of delay times.
-#: python/sourceclientgui.py:1017
+#: python/sourceclientgui.py:1043
 msgid "Delay times"
 msgstr ""
 
-#: python/sourceclientgui.py:1021
+#: python/sourceclientgui.py:1047
 msgid ""
 "A comma separated list of delays in seconds between reconnection attempts. "
 "Note that bad values or values less than 5 will be interpreted as 5."
 msgstr ""
 
-#: python/sourceclientgui.py:1027
+#: python/sourceclientgui.py:1053
 msgid "Repeat the sequence of delays indefinitely."
 msgstr ""
 
 #. TC: User specifies no dialog box to be shown.
-#: python/sourceclientgui.py:1030
+#: python/sourceclientgui.py:1056
 msgid "Quiet"
 msgstr ""
 
-#: python/sourceclientgui.py:1032
+#: python/sourceclientgui.py:1058
 msgid "Keep the reconnection dialogue box hidden at all times."
 msgstr ""
 
-#: python/sourceclientgui.py:1037
+#: python/sourceclientgui.py:1063
 msgid "The contingency plan upon the stream buffer becoming full is..."
 msgstr ""
 
-#: python/sourceclientgui.py:1046
+#: python/sourceclientgui.py:1072
 msgid "Discard audio data for as long as needed."
 msgstr ""
 
-#: python/sourceclientgui.py:1048
+#: python/sourceclientgui.py:1074
 msgid "Assume the connection is beyond saving and reconnect."
 msgstr ""
 
-#: python/sourceclientgui.py:1300
+#: python/sourceclientgui.py:1357 python/format.py:1140
 msgid "Shoutcast"
 msgstr ""
 
-#: python/sourceclientgui.py:1337
+#: python/sourceclientgui.py:1394
 msgid "[Metadata suppressed]"
 msgstr ""
 
-#: python/sourceclientgui.py:1416
+#: python/sourceclientgui.py:1473
 msgid "Individual Controls"
 msgstr ""
 
-#: python/sourceclientgui.py:1430
+#: python/sourceclientgui.py:1487
 msgid ""
 "Connect to or disconnect from the radio server. If the button does not stay "
 "in, the connection failed for some reason.\n"
@@ -3446,96 +3518,97 @@ msgid ""
 msgstr ""
 
 #. TC: Kick whoever is on the server.
-#: python/sourceclientgui.py:1447
+#: python/sourceclientgui.py:1504
 msgid "Kick Source"
 msgstr ""
 
-#: python/sourceclientgui.py:1449
+#: python/sourceclientgui.py:1506
 msgid ""
 "This will disconnect whoever is currently using the server, freeing it up "
 "for personal use."
 msgstr ""
 
-#: python/sourceclientgui.py:1459
+#: python/sourceclientgui.py:1516
 msgid "Timer:"
 msgstr ""
 
-#: python/sourceclientgui.py:1463
+#: python/sourceclientgui.py:1520
 msgid "From"
 msgstr ""
 
-#: python/sourceclientgui.py:1464
+#: python/sourceclientgui.py:1521
 msgid ""
 "Automatically connect to the server at a specific time in 24 hour format, "
 "midnight being 00:00"
 msgstr ""
 
-#: python/sourceclientgui.py:1469
+#: python/sourceclientgui.py:1526
 msgid "Kick"
 msgstr ""
 
-#: python/sourceclientgui.py:1471
+#: python/sourceclientgui.py:1528
 msgid "Disconnect whoever is using the server just before start time."
 msgstr ""
 
-#: python/sourceclientgui.py:1480
+#: python/sourceclientgui.py:1537
 msgid "To"
 msgstr ""
 
-#: python/sourceclientgui.py:1481
+#: python/sourceclientgui.py:1538
 msgid ""
 "Automatically disconnect from the server at a specific time in 24 hour "
 "format."
 msgstr ""
 
-#: python/sourceclientgui.py:1484
+#: python/sourceclientgui.py:1541
 msgid "Fade out"
 msgstr ""
 
-#: python/sourceclientgui.py:1486
+#: python/sourceclientgui.py:1543
 msgid "Fade audio before disconnecting."
 msgstr ""
 
-#: python/sourceclientgui.py:1500
+#: python/sourceclientgui.py:1557
 msgid "At connect:"
 msgstr ""
 
 #. TC: [x] Start player (*) 1 ( ) 2
-#: python/sourceclientgui.py:1504
+#: python/sourceclientgui.py:1561
 msgid "Start player"
 msgstr ""
 
-#: python/sourceclientgui.py:1509
+#: python/sourceclientgui.py:1566
 msgid ""
 "Have one of the players start automatically when a radio server connection "
 "is successfully made."
 msgstr ""
 
 #. TC: [x] Start recorder (*) 1 ( ) 2
-#: python/sourceclientgui.py:1517
+#: python/sourceclientgui.py:1574
 msgid "Start recorder"
 msgstr ""
 
-#: python/sourceclientgui.py:1524
+#: python/sourceclientgui.py:1581
 msgid ""
 "Have a recorder start automatically when a radio server connection is "
 "successfully made."
 msgstr ""
 
-#: python/sourceclientgui.py:1529
+#: python/sourceclientgui.py:1586 python/format.py:521 python/format.py:532
+#: python/format.py:542
 msgid "Metadata"
 msgstr ""
 
-#: python/sourceclientgui.py:1539
+#: python/sourceclientgui.py:1596
 msgid "Format String"
 msgstr ""
 
 #. TC: Label for the metadata fallback value.
-#: python/sourceclientgui.py:1541
+#: python/sourceclientgui.py:1598
 msgid "Fallback"
 msgstr ""
 
-#: python/sourceclientgui.py:1555
+#: python/sourceclientgui.py:1612
 msgid ""
 "You can enter text to accompany the stream here and can specify placemarkers "
 "%r %t %l %s for the artist, title, album, and songname respectively, or "
@@ -3549,125 +3622,133 @@ msgid ""
 "%s."
 msgstr ""
 
-#: python/sourceclientgui.py:1563
+#: python/sourceclientgui.py:1620
 msgid ""
 "The fallback text to use when %r %t %l metadata is unavailable. See the "
 "format string to the left."
 msgstr ""
 
-#: python/sourceclientgui.py:1565
+#: python/sourceclientgui.py:1622
 msgid ""
 "Metadata normally updates only on song title changes but you can force an "
 "immediate update here."
 msgstr ""
 
-#: python/sourceclientgui.py:1584
+#: python/sourceclientgui.py:1641
 msgid "Configuration"
 msgstr ""
 
-#: python/sourceclientgui.py:1585
+#: python/sourceclientgui.py:1642
 msgid "The controls for configuring a stream."
 msgstr ""
 
-#: python/sourceclientgui.py:1593
+#: python/sourceclientgui.py:1650
 msgid "Connection"
 msgstr ""
 
-#: python/sourceclientgui.py:1598
+#: python/sourceclientgui.py:1655
 msgid "Format"
 msgstr ""
 
 #. TC: Tab heading. User can enter information about the stream here.
-#: python/sourceclientgui.py:1607
+#: python/sourceclientgui.py:1664
 msgid "Stream Info"
 msgstr ""
 
-#: python/sourceclientgui.py:1612
+#: python/sourceclientgui.py:1669
 msgid ""
 "Enter your DJ name or station name here. Typically this information will be "
 "displayed by listener clients."
 msgstr ""
 
-#: python/sourceclientgui.py:1615
+#: python/sourceclientgui.py:1672
 msgid ""
 "The URL of your radio station. This and the rest of the information below is "
 "intended for display on a radio station listings website."
 msgstr ""
 
-#: python/sourceclientgui.py:1620
+#: python/sourceclientgui.py:1677
 msgid "A description of your radio station."
 msgstr ""
 
-#: python/sourceclientgui.py:1625
+#: python/sourceclientgui.py:1682
 msgid "The musical genres you are likely to play."
 msgstr ""
 
-#: python/sourceclientgui.py:1628
+#: python/sourceclientgui.py:1685
 msgid "Make Public"
 msgstr ""
 
-#: python/sourceclientgui.py:1629
+#: python/sourceclientgui.py:1686
 msgid ""
 "Publish your radio station on a listings website. The website in question "
 "will depend on how the server to which you connect is configured."
 msgstr ""
 
-#: python/sourceclientgui.py:1641
+#: python/sourceclientgui.py:1698
 msgid "Genre(s)"
 msgstr ""
 
-#: python/sourceclientgui.py:1651
+#: python/sourceclientgui.py:1709
 msgid "Master server admin password"
 msgstr ""
 
-#: python/sourceclientgui.py:1656
+#: python/sourceclientgui.py:1714
 msgid ""
 "This is for kick and stats on Shoutcast master servers that have an "
 "administrator password. For those that don't leave this blank (the source "
 "password is sufficient for those)."
 msgstr ""
 
-#: python/sourceclientgui.py:1665
+#: python/sourceclientgui.py:1723
 msgid "Contact Details"
 msgstr ""
 
-#: python/sourceclientgui.py:1670
+#: python/sourceclientgui.py:1727
 msgid "Internet Relay Chat connection info goes here."
 msgstr ""
 
-#: python/sourceclientgui.py:1673
+#: python/sourceclientgui.py:1730
 msgid "Connection info for AOL instant messenger goes here."
 msgstr ""
 
-#: python/sourceclientgui.py:1676
+#: python/sourceclientgui.py:1733
 msgid "ICQ instant messenger connection info goes here."
 msgstr ""
 
-#: python/sourceclientgui.py:1679
+#: python/sourceclientgui.py:1736
 msgid "IRC"
 msgstr ""
 
-#: python/sourceclientgui.py:1680
+#: python/sourceclientgui.py:1737
 msgid "AIM"
 msgstr ""
 
-#: python/sourceclientgui.py:1681
+#: python/sourceclientgui.py:1738
 msgid "ICQ"
 msgstr ""
 
-#: python/sourceclientgui.py:1690
+#: python/sourceclientgui.py:1748
+msgid "Use ISO-8859-1 encoding for fixed metadata"
+msgstr ""
+
+#: python/sourceclientgui.py:1750
+msgid "Enable this if sending to a Shoutcast V1 server."
+msgstr ""
+
+#: python/sourceclientgui.py:1754
 msgid "Extra Shoutcast"
 msgstr ""
 
-#: python/sourceclientgui.py:1695
+#: python/sourceclientgui.py:1759
 msgid "Troubleshooting"
 msgstr ""
 
-#: python/sourceclientgui.py:1821
+#: python/sourceclientgui.py:1890
 msgid "Stop recording."
 msgstr ""
 
-#: python/sourceclientgui.py:1823
+#: python/sourceclientgui.py:1892
 msgid ""
 "Start recording.\n"
 "\n"
@@ -3675,27 +3756,27 @@ msgid ""
 "not valid or write permission is not granted on the selected folder."
 msgstr ""
 
-#: python/sourceclientgui.py:1828
+#: python/sourceclientgui.py:1897
 msgid "Pause recording."
 msgstr ""
 
-#: python/sourceclientgui.py:1865
+#: python/sourceclientgui.py:1934
 msgid "Recording time elapsed."
 msgstr ""
 
 #. TC: Dialog title bar text.
-#: python/sourceclientgui.py:1919
+#: python/sourceclientgui.py:1988
 msgid "Select the folder to record to"
 msgstr ""
 
-#: python/sourceclientgui.py:1930
+#: python/sourceclientgui.py:1999
 msgid ""
 "Choose which stream to record or the 24 bit FLAC option. If the stream isn't "
 "already running the encoder will be started automatically using whatever "
 "settings are currently configured."
 msgstr ""
 
-#: python/sourceclientgui.py:1934
+#: python/sourceclientgui.py:2003
 msgid ""
 "Choose which directory you want to save to. All file names will be in a "
 "timestamp format and have either an oga, mp3, or flac file extension. "
@@ -3703,76 +3784,77 @@ msgid ""
 "permission."
 msgstr ""
 
-#: python/sourceclientgui.py:2038
+#: python/sourceclientgui.py:2110
 msgid "Perform operations on multiple servers in unison."
 msgstr ""
 
-#: python/sourceclientgui.py:2050
+#: python/sourceclientgui.py:2122
 msgid "Connect"
 msgstr ""
 
-#: python/sourceclientgui.py:2067
+#: python/sourceclientgui.py:2139
 msgid "Disconnect"
 msgstr ""
 
-#: python/sourceclientgui.py:2075
+#: python/sourceclientgui.py:2147
 msgid "Kick Sources"
 msgstr ""
 
-#: python/sourceclientgui.py:2084
+#: python/sourceclientgui.py:2156
 msgid "Metadata:"
 msgstr ""
 
-#: python/sourceclientgui.py:2114
+#: python/sourceclientgui.py:2186
 msgid "Group Controls"
 msgstr ""
 
-#: python/sourceclientgui.py:2610
+#: python/sourceclientgui.py:2692
 msgid "Recording Facility Unavailable"
 msgstr ""
 
-#: python/sourceclientgui.py:2613
+#: python/sourceclientgui.py:2695
 msgid "No Recorders Are Correctly Configured"
 msgstr ""
 
 #. TC: Recorder menu format string.
-#: python/sourceclientgui.py:2626
+#: python/sourceclientgui.py:2708
+#, python-brace-format
 msgid "{numericid} [{source}] > [{directory}]"
 msgstr ""
 
-#: python/sourceclientgui.py:2628
+#: python/sourceclientgui.py:2710
 msgid "Misconfigured"
 msgstr ""
 
-#: python/sourceclientgui.py:2649
+#: python/sourceclientgui.py:2731
 msgid "Streaming Facility Unavailable"
 msgstr ""
 
-#: python/sourceclientgui.py:2651
+#: python/sourceclientgui.py:2733
 msgid "No Streams Are Currently Configured"
 msgstr ""
 
-#: python/sourceclientgui.py:2654
+#: python/sourceclientgui.py:2736
 msgid "Group Connect"
 msgstr ""
 
-#: python/sourceclientgui.py:2660
+#: python/sourceclientgui.py:2742
 msgid "Group Disconnect"
 msgstr ""
 
 #. TC: Window title bar text.
-#: python/sourceclientgui.py:2691
+#: python/sourceclientgui.py:2773
 msgid "IDJC Output"
 msgstr ""
 
-#: python/sourceclientgui.py:2707
+#: python/sourceclientgui.py:2789
 msgid ""
 "Each one of these tabs represents a separate stream recorder. The LED "
 "indicator colours represent the following: Clear=Stopped Yellow=Paused "
 "Red=Recording."
 msgstr ""
 
-#: python/sourceclientgui.py:2715
+#: python/sourceclientgui.py:2797
 msgid ""
 "Each one of these tabs represents a separate radio streamer. The LED "
 "indicator colours represent the following: Clear=No connection "
@@ -3780,11 +3862,11 @@ msgid ""
 "a bad connection."
 msgstr ""
 
-#: python/sourceclientgui.py:2733
+#: python/sourceclientgui.py:2815
 msgid " Stream "
 msgstr ""
 
-#: python/sourceclientgui.py:2768
+#: python/sourceclientgui.py:2850
 msgid ""
 "<span weight=\"bold\" size=\"12000\">A connection to a radio server has "
 "failed.</span>\n"
@@ -3792,8 +3874,509 @@ msgid ""
 "Reconnection will not be attempted."
 msgstr ""
 
-#: python/sourceclientgui.py:2773
+#: python/sourceclientgui.py:2855
 msgid ""
 "<span weight=\"bold\" size=\"12000\">A scheduled stream disconnection has "
 "occurred.</span>"
 msgstr ""
+
+#: python/format.py:419
+msgid "Right click for suggested values."
+msgstr ""
+
+#: python/format.py:438
+msgid "Suggested Values"
+msgstr ""
+
+#: python/format.py:494
+msgid "Pregain"
+msgstr ""
+
+#: python/format.py:495 python/format.py:913
+msgid "0 dB"
+msgstr ""
+
+#: python/format.py:496 python/format.py:914
+msgid "-0.5 dB"
+msgstr ""
+
+#: python/format.py:497 python/format.py:915
+msgid "-1.0 dB"
+msgstr ""
+
+#: python/format.py:498 python/format.py:916
+msgid "-1.5 dB"
+msgstr ""
+
+#: python/format.py:499 python/format.py:917
+msgid "-2.0 dB"
+msgstr ""
+
+#: python/format.py:500 python/format.py:918
+msgid "-2.5 dB"
+msgstr ""
+
+#: python/format.py:501 python/format.py:919
+msgid "-3.0 dB"
+msgstr ""
+
+#: python/format.py:502
+msgid ""
+"A blanket gain reduction to promote audio quality when using long "
+"established lossy audio codecs like mp3 with loud audio material.\n"
+"\n"
+"ReplayGain makes this feature generally unnecessary and the correct setting "
+"in that case is 0 dB."
+msgstr ""
+
+#: python/format.py:510
+msgid "Resample Quality"
+msgstr ""
+
+#: python/format.py:511
+msgid "Highest"
+msgstr ""
+
+#: python/format.py:513
+msgid "Lowest"
+msgstr ""
+
+#: python/format.py:514
+msgid ""
+"All of these settings will provide adequate audio quality. The highest "
+"setting will preserve more of the original audio bandwidth at the expense of "
+"many CPU cycles."
+msgstr ""
+
+#: python/format.py:522 python/format.py:533 python/format.py:543
+msgid "Suppressed"
+msgstr ""
+
+#: python/format.py:523 python/format.py:534
+msgid "UTF-8"
+msgstr ""
+
+#: python/format.py:524
+msgid "Latin1 *"
+msgstr ""
+
+#: python/format.py:525
+msgid ""
+"This affects the stream metadata only. Recordings will use UTF-8 for their "
+"metadata."
+msgstr ""
+
+#: python/format.py:535
+msgid ""
+"Choose whether the stream will carry dynamic metadata. In the case of Ogg "
+"streams this is important as a great many players can't handle chained Ogg "
+"streams which result from the metadata updates."
+msgstr ""
+
+#: python/format.py:544
+msgid "Latin1"
+msgstr ""
+
+#: python/format.py:545
+msgid "Choose whether to send metadata. Recordings will use UTF-8 metadata."
+msgstr ""
+
+#: python/format.py:561 python/format.py:572 python/format.py:583
+#: python/format.py:690 python/format.py:818 python/format.py:888
+#: python/format.py:897 python/format.py:971 python/format.py:994
+#: python/format.py:1003
+msgid "Mode"
+msgstr ""
+
+#: python/format.py:562 python/format.py:573 python/format.py:584
+#: python/format.py:691 python/format.py:819 python/format.py:889
+#: python/format.py:898 python/format.py:972 python/format.py:995
+#: python/format.py:1004
+msgid "Mono"
+msgstr ""
+
+#: python/format.py:563 python/format.py:574 python/format.py:585
+#: python/format.py:692 python/format.py:820 python/format.py:890
+#: python/format.py:899 python/format.py:973 python/format.py:996
+#: python/format.py:1005
+msgid "Stereo"
+msgstr ""
+
+#: python/format.py:564 python/format.py:575 python/format.py:586
+#: python/format.py:693
+msgid "Joint Stereo"
+msgstr ""
+
+#: python/format.py:565
+msgid "Joint Stereo is a good choice on streams with low bitrates."
+msgstr ""
+
+#: python/format.py:576
+msgid "Due to the high bitrate selected, this codec will only support stereo."
+msgstr ""
+
+#: python/format.py:587
+msgid "Due to the low bitrate selected, this codec will only support mono."
+msgstr ""
+
+#: python/format.py:636 python/format.py:646 python/format.py:743
+#: python/format.py:753 python/format.py:763 python/format.py:869
+#: python/format.py:879 python/format.py:1032 python/format.py:1052
+msgid "Samplerate"
+msgstr ""
+
+#. TC: Abbreviation of the word, standard.
+#: python/format.py:657 python/format.py:774
+msgid "Std."
+msgstr ""
+
+#. TC: v stands for version.
+#: python/format.py:659 python/format.py:776
+msgid "V 1"
+msgstr ""
+
+#. TC: v stands for version.
+#: python/format.py:661 python/format.py:778
+msgid "V 2"
+msgstr ""
+
+#: python/format.py:662
+msgid ""
+"MPEG2 introduced lower samplerate options and corresponding lower bitrates. "
+"Choose 2 if those are required."
+msgstr ""
+
+#: python/format.py:669 python/format.py:797
+msgid "Quality"
+msgstr ""
+
+#: python/format.py:670
+msgid "0 most"
+msgstr ""
+
+#. TC: * means is the recommended setting.
+#: python/format.py:673
+msgid "2 *"
+msgstr ""
+
+#: python/format.py:675
+msgid "Higher quality costs more in terms of CPU cycles."
+msgstr ""
+
+#: python/format.py:694
+msgid "Joint Stereo is a good choice on streams with low bitrates"
+msgstr ""
+
+#. TC: v stands for version.
+#: python/format.py:780
+msgid "V 2.5"
+msgstr ""
+
+#: python/format.py:787
+msgid "Complexity"
+msgstr ""
+
+#: python/format.py:790
+msgid "A quality setting that affects how heavily the CPU is used."
+msgstr ""
+
+#: python/format.py:800
+msgid "The higher this setting, the higher the bitrate."
+msgstr ""
+
+#: python/format.py:807
+msgid "Bandwidth"
+msgstr ""
+
+#: python/format.py:808
+msgid "Ultrawide"
+msgstr ""
+
+#: python/format.py:809
+msgid "Wide"
+msgstr ""
+
+#: python/format.py:810
+msgid "Narrow"
+msgstr ""
+
+#: python/format.py:811
+msgid "Essentially a samplerate setting."
+msgstr ""
+
+#: python/format.py:828
+msgid "24 bit"
+msgstr ""
+
+#: python/format.py:829
+msgid "20 bit"
+msgstr ""
+
+#: python/format.py:830
+msgid "16 bit"
+msgstr ""
+
+#: python/format.py:831
+msgid ""
+"24 bit records with the highest level of detail. If file size is a concern "
+"maybe FLAC is not the right codec."
+msgstr ""
+
+#: python/format.py:838 python/format.py:927
+msgid "Variability"
+msgstr ""
+
+#: python/format.py:839
+msgid "Constant"
+msgstr ""
+
+#: python/format.py:840
+msgid "±10%"
+msgstr ""
+
+#: python/format.py:841
+msgid "±20%"
+msgstr ""
+
+#: python/format.py:842
+msgid "±30%"
+msgstr ""
+
+#: python/format.py:843
+msgid "±40%"
+msgstr ""
+
+#: python/format.py:844
+msgid "±50%"
+msgstr ""
+
+#: python/format.py:845
+msgid "This control is for enabling variable bitrate on Vorbis streams."
+msgstr ""
+
+#: python/format.py:906
+msgid "Postgain"
+msgstr ""
+
+#: python/format.py:907
+msgid "3.0 dB"
+msgstr ""
+
+#: python/format.py:908
+msgid "2.5 dB"
+msgstr ""
+
+#: python/format.py:909
+msgid "2.0 dB"
+msgstr ""
+
+#: python/format.py:910
+msgid "1.5 dB"
+msgstr ""
+
+#: python/format.py:911
+msgid "1.0 dB"
+msgstr ""
+
+#: python/format.py:912
+msgid "0.5 dB"
+msgstr ""
+
+#: python/format.py:920
+msgid "A gain adjustment for the player to apply."
+msgstr ""
+
+#: python/format.py:928
+msgid "CBR *"
+msgstr ""
+
+#: python/format.py:929
+msgid "CVBR"
+msgstr ""
+
+#: python/format.py:930
+msgid "VBR"
+msgstr ""
+
+#: python/format.py:931
+msgid ""
+"Bitrate variability. Actual VBR operation may require a higher frame size."
+msgstr ""
+
+#: python/format.py:938
+msgid "Frame Size"
+msgstr ""
+
+#: python/format.py:939
+msgid "60 ms"
+msgstr ""
+
+#: python/format.py:940
+msgid "40 ms"
+msgstr ""
+
+#: python/format.py:941
+msgid "20 ms"
+msgstr ""
+
+#: python/format.py:942
+msgid "A higher frame size may sound better on very low bitrates."
+msgstr ""
+
+#: python/format.py:949
+msgid "CPU"
+msgstr ""
+
+#: python/format.py:952
+msgid "The encoder complexity setting which affects CPU load."
+msgstr ""
+
+#: python/format.py:980 python/format.py:1083
+msgid "Codec"
+msgstr ""
+
+#: python/format.py:981
+msgid "Vorbis"
+msgstr ""
+
+#: python/format.py:982
+msgid "FLAC"
+msgstr ""
+
+#: python/format.py:983
+msgid "Speex"
+msgstr ""
+
+#: python/format.py:984
+msgid "Opus"
+msgstr ""
+
+#: python/format.py:987
+msgid "Codecs of the Ogg container."
+msgstr ""
+
+#: python/format.py:1033
+msgid "96000 Hz"
+msgstr ""
+
+#: python/format.py:1034
+msgid "88200 Hz"
+msgstr ""
+
+#: python/format.py:1035
+msgid "64000 Hz"
+msgstr ""
+
+#: python/format.py:1036 python/format.py:1053
+msgid "48000 Hz"
+msgstr ""
+
+#: python/format.py:1037 python/format.py:1054
+msgid "44100 Hz"
+msgstr ""
+
+#: python/format.py:1038
+msgid "32000 Hz"
+msgstr ""
+
+#: python/format.py:1039
+msgid "24000 Hz"
+msgstr ""
+
+#: python/format.py:1040
+msgid "22050 Hz"
+msgstr ""
+
+#: python/format.py:1041
+msgid "16000 Hz"
+msgstr ""
+
+#: python/format.py:1042
+msgid "12000 Hz"
+msgstr ""
+
+#: python/format.py:1043
+msgid "11025 Hz"
+msgstr ""
+
+#: python/format.py:1044
+msgid "8000 Hz"
+msgstr ""
+
+#: python/format.py:1045
+msgid "7350 Hz"
+msgstr ""
+
+#: python/format.py:1067
+msgid "The MP2 option requires IDJC be rebuilt against libtwolame."
+msgstr ""
+
+#: python/format.py:1070
+msgid "Enable the MP3 option by installing libmp3lame."
+msgstr ""
+
+#: python/format.py:1073
+msgid "The AAC options require IDJC be rebuilt against libav libraries."
+msgstr ""
+
+#: python/format.py:1076
+msgid ""
+"Specific AAC support not present in libavcodec. More info: idjc.sourceforge."
+"net."
+msgstr ""
+
+#: python/format.py:1078
+msgid ""
+"Specific AAC+ support not present in libavcodec. More info: idjc.sourceforge."
+"net."
+msgstr ""
+
+#: python/format.py:1081
+msgid "Codecs of the MPEG family."
+msgstr ""
+
+#: python/format.py:1084
+msgid "MP2"
+msgstr ""
+
+#: python/format.py:1085
+msgid "MP3"
+msgstr ""
+
+#: python/format.py:1086
+msgid "AAC"
+msgstr ""
+
+#: python/format.py:1087
+msgid "AAC+ v2"
+msgstr ""
+
+#. TC: Codec family e.g. Xiph/Ogg, MPEG etc.
+#: python/format.py:1099
+msgid "Family"
+msgstr ""
+
+#. TC: Xiph.org Ogg container format.
+#: python/format.py:1101
+msgid "Xiph/Ogg"
+msgstr ""
+
+#: python/format.py:1102
+msgid "MPEG"
+msgstr ""
+
+#: python/format.py:1103
+msgid "Codecs have been grouped by standards body and or container format."
+msgstr ""
+
+#: python/format.py:1128
+msgid "Capabilities"
+msgstr ""
+
+#: python/format.py:1140
+msgid "Icecast"
+msgstr ""
+
+#: python/format.py:1140
+msgid "Recordable"
+msgstr ""
diff --git a/po/it.gmo b/po/it.gmo
index f39ddef..df66149 100644
Binary files a/po/it.gmo and b/po/it.gmo differ
diff --git a/po/it.po b/po/it.po
index 8efd561..b1a5c6f 100644
--- a/po/it.po
+++ b/po/it.po
@@ -8,7 +8,7 @@ msgid ""
 msgstr ""
 "Project-Id-Version: \n"
 "Report-Msgid-Bugs-To: putidjcinthesubjectline at bethere.co.uk\n"
-"POT-Creation-Date: 2014-02-17 19:31+0000\n"
+"POT-Creation-Date: 2015-07-27 07:47+0100\n"
 "PO-Revision-Date: 2013-11-07 16:48+0000\n"
 "Last-Translator: \n"
 "Language-Team: English <team at example.com>\n"
@@ -308,6 +308,7 @@ msgstr ""
 
 #. TC: text appears in the title bar when in session mode.
 #: python/prelims/__init__.py:590
+#, python-brace-format
 msgid "session={type}:{name}"
 msgstr ""
 
@@ -342,14 +343,17 @@ msgid "Profile %s is active."
 msgstr "Il profilo %s è attivo."
 
 #: python/prelims/__init__.py:791
+#, python-brace-format
 msgid "Cannot rename profile {0} to {1}, {1} currently exists."
 msgstr "Non posso rinominare il profilo {0} in {1}, {1} è già presente."
 
 #: python/prelims/__init__.py:795
+#, python-brace-format
 msgid "Error during attempt to rename {0} to {1}."
 msgstr "Errore nel tentativo di rinominare {0} in {1}."
 
 #: python/prelims/__init__.py:805
+#, python-brace-format
 msgid ""
 "<span weight='bold' size='12000'>Error while editing profile: {0}.</span>\n"
 "\n"
@@ -361,6 +365,7 @@ msgstr ""
 "{1}"
 
 #: python/prelims/__init__.py:824
+#, python-brace-format
 msgid "could not get a lock on profile {0}: {1}"
 msgstr ""
 
@@ -463,54 +468,54 @@ msgid "The default profile"
 msgstr "Il profilo base"
 
 #. TC: data entry dialog window title text. %s = profile name
-#: python/prelims/profiledialog.py:97
+#: python/prelims/profiledialog.py:98
 #, python-format
 msgid "Edit profile %s"
 msgstr "Modifica il profilo %s"
 
 #. TC: data entry dialog window title text. %s = profile name
-#: python/prelims/profiledialog.py:100
+#: python/prelims/profiledialog.py:101
 #, python-format
 msgid "New profile based upon %s"
 msgstr "Nuovo profilo basato su %s"
 
 #. TC: data entry dialog window title text.
-#: python/prelims/profiledialog.py:104
+#: python/prelims/profiledialog.py:105
 msgid "New profile details"
 msgstr "Dettagli del nuovo profilo"
 
 #. TC: profile dialog window title text.
-#: python/prelims/profiledialog.py:242
+#: python/prelims/profiledialog.py:243
 msgid "IDJC Profile Manager"
 msgstr "Gestore dei profili IDJC"
 
-#: python/prelims/profiledialog.py:276
+#: python/prelims/profiledialog.py:277
 msgid "Profile"
 msgstr "Profilo"
 
 #. TC: column heading. The profile nicknames.
 #. TC: IRC nickname data entry label.
-#: python/prelims/profiledialog.py:284 python/irc.py:446
+#: python/prelims/profiledialog.py:285 python/irc.py:452
 msgid "Nickname"
 msgstr "Nickname"
 
 #. TC: column heading.
 #. TC: Station description.
-#: python/prelims/profiledialog.py:287 python/irc.py:90
-#: python/playergui.py:306 python/sourceclientgui.py:1640
+#: python/prelims/profiledialog.py:288 python/irc.py:96
+#: python/playergui.py:307 python/sourceclientgui.py:1697
 msgid "Description"
 msgstr "Descrizione"
 
 #. TC: column heading. The time a particular profile has been running.
-#: python/prelims/profiledialog.py:291
+#: python/prelims/profiledialog.py:292
 msgid "Up-time"
 msgstr "Avviato da"
 
-#: python/prelims/profiledialog.py:305
+#: python/prelims/profiledialog.py:306
 msgid "_Auto"
 msgstr "_Auto"
 
-#: python/prelims/profiledialog.py:364
+#: python/prelims/profiledialog.py:365
 #, python-format
 msgid ""
 "<span weight='bold' size='12000'>Delete the data of profile '%s'?</span>\n"
@@ -521,7 +526,7 @@ msgstr ""
 "\n"
 "Il profilo resterà disponibile con le impostazioni iniziali"
 
-#: python/prelims/profiledialog.py:368
+#: python/prelims/profiledialog.py:369
 #, python-format
 msgid ""
 "<span weight='bold' size='12000'>Delete profile '%s' and all its data?</"
@@ -536,6 +541,7 @@ msgstr ""
 
 #. TC: The contents of <> and {} must not be changed.
 #: python/dialogs.py:198
+#, python-brace-format
 msgid ""
 "<span weight=\"bold\" size=\"12000\">The connection to the server in tab "
 "{servertab} has failed.</span>\n"
@@ -566,142 +572,153 @@ msgid "Released under the GNU General Public License V2.0+."
 msgstr "Rilasciato sotto la Licenza Pubblica Generica GNU, V2.0+"
 
 #. TC: IRC message subcategory, triggers on new track announcements.
-#: python/irc.py:78
+#: python/irc.py:82
 msgid "Track announce"
 msgstr "Annuncio traccia"
 
 #. TC: IRC message subcategory, triggered by a timer.
-#: python/irc.py:80
+#: python/irc.py:84
 msgid "Timer"
 msgstr "Cronometro"
 
 #. TC: IRC message subcategory, triggered once when the stream starts.
-#: python/irc.py:82
+#: python/irc.py:86
 msgid "On stream up"
 msgstr "Se il flusso è attivo"
 
 #. TC: IRC message subcategory, triggered once at the stream's end.
-#: python/irc.py:84
+#: python/irc.py:88
 msgid "On stream down"
 msgstr "Se il flusso non è attivo"
 
+#. TC: IRC message subcategory, triggered once at the stream's end.
+#: python/irc.py:90
+#, fuzzy
+msgid "Operations"
+msgstr "Altre opzioni"
+
 #. TC: Track artist.
-#: python/irc.py:89 python/mutagentagger.py:375 python/songdb.py:785
-#: python/songdb.py:1157 python/sourceclientgui.py:92
+#: python/irc.py:95 python/mutagentagger.py:375 python/songdb.py:902
+#: python/songdb.py:1290 python/sourceclientgui.py:94
 msgid "Artist"
 msgstr "Artista"
 
-#: python/irc.py:89 python/mutagentagger.py:375 python/songdb.py:1161
-#: python/sourceclientgui.py:92
+#: python/irc.py:95 python/mutagentagger.py:375 python/songdb.py:1292
+#: python/sourceclientgui.py:94
 msgid "Title"
 msgstr "Titolo"
 
-#: python/irc.py:89 python/mutagentagger.py:376 python/songdb.py:1158
-#: python/sourceclientgui.py:92
+#: python/irc.py:95 python/mutagentagger.py:376 python/songdb.py:1291
+#: python/sourceclientgui.py:94
 msgid "Album"
 msgstr "Album"
 
-#: python/irc.py:89 python/sourceclientgui.py:93
+#: python/irc.py:95 python/sourceclientgui.py:95
 msgid "Song name"
 msgstr "Canzone"
 
 #. TC: The DJ or Stream name.
-#: python/irc.py:90 python/sourceclientgui.py:1637
+#: python/irc.py:96 python/sourceclientgui.py:1694
 msgid "DJ name"
 msgstr "Nome DJ"
 
-#: python/irc.py:90 python/sourceclientgui.py:1638
+#: python/irc.py:96 python/sourceclientgui.py:1695
 msgid "Listen URL"
 msgstr "Indirizzo di ascolto (URL)"
 
+#: python/irc.py:96
+#, fuzzy
+msgid "Source URI"
+msgstr "Fonte"
+
 #. TC: Popup menu item for a GTK text entry widget.
-#: python/irc.py:133
+#: python/irc.py:139
 msgid "Insert Attribute or Colour Code"
 msgstr "Inserisci un attributo o un codice colore"
 
 #. TC: Text formatting style.
-#: python/irc.py:170
+#: python/irc.py:176
 msgid "<b>Bold</b>"
 msgstr "<b>Grassetto</b>"
 
 #. TC: Text formatting style.
-#: python/irc.py:172
+#: python/irc.py:178
 msgid "<u>Underline</u>"
 msgstr "<u>Sottolineato</u>"
 
 #. TC: Text formatting style.
-#: python/irc.py:174
+#: python/irc.py:180
 msgid "Normal"
 msgstr "Normale"
 
-#: python/irc.py:180
+#: python/irc.py:186
 msgid "Colours"
 msgstr "Colori"
 
-#: python/irc.py:397
+#: python/irc.py:403
 msgid "Optional data entry field for information only."
 msgstr "Campo opzionale a scopo informativo."
 
 #. TC: Tab heading text.
-#: python/irc.py:400
+#: python/irc.py:406
 msgid "IRC server"
 msgstr "Server IRC"
 
-#: python/irc.py:412
+#: python/irc.py:418
 #, fuzzy
 msgid "Manual start"
 msgstr "Manuale"
 
-#: python/irc.py:414
+#: python/irc.py:420
 msgid "Off when restarting IDJC and off initially."
 msgstr ""
 
 #. TC: The IRC network e.g. EFnet.
-#: python/irc.py:438
+#: python/irc.py:444
 msgid "Network"
 msgstr "Rete"
 
 #. TC: label for hostname entry.
-#: python/irc.py:440 python/sourceclientgui.py:206
+#: python/irc.py:446 python/sourceclientgui.py:208
 msgid "Hostname"
 msgstr "Nome host"
 
 #. TC: TCP/IP port number label.
 #. TC: TCP port number.
-#: python/irc.py:442 python/sourceclientgui.py:678
+#: python/irc.py:448 python/sourceclientgui.py:704
 msgid "Port"
 msgstr "Porta"
 
-#: python/irc.py:443
+#: python/irc.py:449
 msgid "User name"
 msgstr "Nome utente"
 
-#: python/irc.py:444 python/songdb.py:339 python/sourceclientgui.py:207
+#: python/irc.py:450 python/songdb.py:343 python/sourceclientgui.py:209
 msgid "Password"
 msgstr "Password"
 
 #. TC: Second choice of IRC nickname.
-#: python/irc.py:448
+#: python/irc.py:454
 msgid "Second choice"
 msgstr "Seconda scelta"
 
 #. TC: Third choice of IRC nickname.
-#: python/irc.py:450
+#: python/irc.py:456
 msgid "Third choice"
 msgstr "Terza scelta"
 
 #. TC: The IRC user's 'real' name.
-#: python/irc.py:452
+#: python/irc.py:458
 msgid "Real name"
 msgstr "Nome reale"
 
 #. TC: The NickServ password.
-#: python/irc.py:454
+#: python/irc.py:460
 msgid "NickServ p/w"
 msgstr "NickServ p/w"
 
 #. TC: Tooltip to IRC 'User name' field.
-#: python/irc.py:459
+#: python/irc.py:465
 msgid ""
 "Ideally set this to something even on servers that allow public anonymous "
 "access."
@@ -710,7 +727,7 @@ msgstr ""
 "anonimo."
 
 #. TC: tooltip to all IRC nicknames entry fields.
-#: python/irc.py:469
+#: python/irc.py:475
 msgid ""
 "When a nickname is in use on the target IRC network, during connection these "
 "IRC nicknames are cycled through, then twice again after appending an "
@@ -722,7 +739,7 @@ msgstr ""
 "trattino basso in coda fino a smettere. Questo fornisce a IDJC un massimo di "
 "nove nickname IRC da provare."
 
-#: python/irc.py:474
+#: python/irc.py:480
 msgid ""
 "The real name you want to use which will be available regardless of whether "
 "the network connection was made with the primary nickname or not.\n"
@@ -734,7 +751,7 @@ msgstr ""
 "\n"
 "Dovreste impostarlo."
 
-#: python/irc.py:477
+#: python/irc.py:483
 msgid ""
 "If this value is set an attempt will be made to acquire your first choice "
 "IRC nickname (if needed) and log in with NickServ at services.\n"
@@ -748,7 +765,7 @@ msgstr ""
 "L'utilizzo del servizio NickServ necessista la preventiva registrazione del "
 "nickname sulla rete utilizzando un client regolare."
 
-#: python/irc.py:505
+#: python/irc.py:511
 msgid ""
 "<span weight='bold' size='12000'>Permanently delete this server?</span>\n"
 "\n"
@@ -760,11 +777,11 @@ msgstr ""
 "Questa azione eliminerà anche tutti i messaggi associati"
 
 #. TC: An IRC channel #chan or user name entry box label.
-#: python/irc.py:552
+#: python/irc.py:559
 msgid "Channels/Users"
 msgstr "Canali/Utenti"
 
-#: python/irc.py:556
+#: python/irc.py:563
 msgid ""
 "The comma or space separated list of channels and/or users to whom the "
 "message will be sent.\n"
@@ -779,11 +796,11 @@ msgstr ""
 "#canale:parolachiave"
 
 #. TC: Message text to send to an IRC channel. Widget label.
-#: python/irc.py:563
+#: python/irc.py:616
 msgid "Message"
 msgstr "Messaggio"
 
-#: python/irc.py:567
+#: python/irc.py:620
 msgid ""
 "The message to send.\n"
 "\n"
@@ -801,17 +818,17 @@ msgstr ""
 "XChat."
 
 #. TC: Dialog window title text.
-#: python/irc.py:638
+#: python/irc.py:673
 msgid "IRC track announce"
 msgstr "Annuncio traccia IRC"
 
 #. TC: Spinbutton label for a delay value.
-#: python/irc.py:645
+#: python/irc.py:680
 msgid "Delay"
 msgstr "Ritardo"
 
 #. TC: tooltip on a spinbutton widget.
-#: python/irc.py:647
+#: python/irc.py:682
 msgid ""
 "The delay time of this message.\n"
 "\n"
@@ -833,22 +850,22 @@ msgstr ""
 "messaggio."
 
 #. TC: Dialog window title text.
-#: python/irc.py:675
+#: python/irc.py:710
 msgid "IRC timed message"
 msgstr "Messaggio a tempo IRC"
 
 #. TC: Spinbutton time offset value label.
-#: python/irc.py:684
+#: python/irc.py:719
 msgid "Offset"
 msgstr "Sfasamento"
 
 #. TC: Spinbutton timed interval duration value label.
-#: python/irc.py:686
+#: python/irc.py:721
 msgid "Interval"
 msgstr "Intervallo"
 
 #. TC: spinbutton tooltip
-#: python/irc.py:689
+#: python/irc.py:724
 msgid ""
 "The time offset within the below specified interval at which the message "
 "will be issued."
@@ -856,220 +873,225 @@ msgstr ""
 "Lo sfasamento con l'intervallo specificato qui sotto con cui il messaggio "
 "verrà recapitato."
 
-#: python/irc.py:693
+#: python/irc.py:728
 msgid "The interval in seconds of the timed message."
 msgstr "L'intervallo in secondi del messaggio temporizzato"
 
-#: python/irc.py:930
+#: python/irc.py:967
 #, fuzzy
 msgid "This feature requires the installation of python-irc."
 msgstr "Questa funzionalità necessita dell'installazione di python-irclib"
 
 #. TC: Indicator text: We used a password.
-#: python/irc.py:1021
+#: python/irc.py:1058
 msgid "PASSWORD"
 msgstr ""
 
 #. TC: Indicator text: We interact with NickServ.
-#: python/irc.py:1024
+#: python/irc.py:1061
 msgid "NICKSERV"
 msgstr ""
 
 #. TC: Indicator text: Server connection started manually.
-#: python/irc.py:1027
+#: python/irc.py:1064
 msgid "MANUAL"
 msgstr ""
 
-#. TC: Expander text encapsulating messages that play when stream goes up.
-#: python/irc.py:1048
+#. TC: Dialog title text.
+#: python/irc.py:1089
 msgid "IRC stream up message"
 msgstr "Messaggio di in onda di IRC"
 
-#. TC: Expander text encapsulating messages that play when stream goes down.
-#: python/irc.py:1050
+#. TC: Dialog title text.
+#: python/irc.py:1091
 msgid "IRC stream down message"
 msgstr "Messaggio di fuori onda IRC"
 
-#: python/jingles.py:95
+#. TC: Dialog title text.
+#: python/irc.py:1093
+msgid "IRC station operations"
+msgstr ""
+
+#: python/jingles.py:96
 #, fuzzy
 msgid "Stop"
 msgstr "Ferma"
 
 #. TC: Column heading, whether to play.
-#: python/jingles.py:113 python/playergui.py:298
+#: python/jingles.py:114 python/playergui.py:299
 msgid "Play"
 msgstr "Riproduci"
 
-#: python/jingles.py:122 python/sourceclientgui.py:1025
+#: python/jingles.py:123 python/sourceclientgui.py:1051
 msgid "Repeat"
 msgstr "Ripeti"
 
-#: python/jingles.py:135
+#: python/jingles.py:136
 #, fuzzy
 msgid "Configure"
 msgstr "Configurazione"
 
-#: python/jingles.py:326 python/playergui.py:4052
+#: python/jingles.py:327 python/playergui.py:4135
 msgid "Supported media"
 msgstr "Media supportati"
 
-#: python/jingles.py:333
+#: python/jingles.py:334
 #, python-format
 msgid "Effect %d Config"
 msgstr ""
 
-#: python/jingles.py:348
+#: python/jingles.py:349
 msgid "Trigger text"
 msgstr ""
 
-#: python/jingles.py:349
+#: python/jingles.py:350
 msgid "No Name"
 msgstr ""
 
-#: python/jingles.py:356
+#: python/jingles.py:357
 msgid "Level adjustment (dB)"
 msgstr ""
 
-#: python/jingles.py:431
+#: python/jingles.py:432
 #, fuzzy
 msgid "Effects volume."
 msgstr "VoIP imposta volume"
 
-#: python/jingles.py:438
+#: python/jingles.py:439
 msgid "Player headroom that is applied when an effect is playing."
 msgstr ""
 
-#: python/jingles.py:501
+#: python/jingles.py:502
 #, fuzzy
 msgid "Alternative"
 msgstr "Alterna"
 
-#: python/jingles.py:502
+#: python/jingles.py:503
 #, fuzzy
 msgid "Default"
 msgstr "Base"
 
-#: python/jingles.py:547
+#: python/jingles.py:548
 #, fuzzy
 msgid "Effects"
 msgstr "Effetto"
 
-#: python/jingles.py:590
+#: python/jingles.py:591
 #, fuzzy, python-format
 msgid "Effects %d"
 msgstr "Effetto"
 
-#: python/jingles.py:598 python/maingui.py:188
+#: python/jingles.py:599 python/maingui.py:189
 msgid "Background Tracks"
 msgstr ""
 
-#: python/jingles.py:617
+#: python/jingles.py:618
 msgid "Background Tracks volume."
 msgstr ""
 
-#: python/maingui.py:92
+#: python/maingui.py:93
 msgid "Show a JACK freewheel control on the main panel"
 msgstr ""
 
-#: python/maingui.py:94
+#: python/maingui.py:95
 msgid "Toggle JACK freewheel mode."
 msgstr ""
 
-#: python/maingui.py:167
+#: python/maingui.py:168
 #, fuzzy
 msgid "File"
 msgstr "Nome file"
 
-#: python/maingui.py:167 python/preferences.py:1127
+#: python/maingui.py:168 python/preferences.py:1130
 msgid "View"
 msgstr "Vista"
 
-#: python/maingui.py:168
+#: python/maingui.py:169
 msgid "JACK Ports"
 msgstr "Porte JACK"
 
-#: python/maingui.py:168
+#: python/maingui.py:169
 msgid "Help"
 msgstr ""
 
-#: python/maingui.py:170 python/maingui.py:3653
+#: python/maingui.py:171 python/maingui.py:3689
 msgid "Streams"
 msgstr "Flussi"
 
-#: python/maingui.py:171
+#: python/maingui.py:172
 #, fuzzy
 msgid "Recorders"
 msgstr "Registratore"
 
-#: python/maingui.py:184 python/maingui.py:223
+#: python/maingui.py:185 python/maingui.py:224
 msgid "Output"
 msgstr "Uscita"
 
-#: python/maingui.py:184
+#: python/maingui.py:185
 msgid "Preferences"
 msgstr "Preferenze"
 
-#: python/maingui.py:184
+#: python/maingui.py:185
 msgid "Profiles"
 msgstr "Profili"
 
-#: python/maingui.py:187 python/songdb.py:405
+#: python/maingui.py:188 python/songdb.py:409
 #, fuzzy
 msgid "Music Database"
 msgstr "Database"
 
-#: python/maingui.py:187
+#: python/maingui.py:188
 #, fuzzy
 msgid "Channel Meters"
 msgstr "Gestore canale"
 
-#: python/maingui.py:187
+#: python/maingui.py:188
 #, fuzzy
 msgid "Output Meters"
 msgstr "Uscita"
 
-#: python/maingui.py:188
+#: python/maingui.py:189
 msgid "Tabbed Area"
 msgstr ""
 
-#: python/maingui.py:188
+#: python/maingui.py:189
 msgid "Button Bar"
 msgstr ""
 
-#: python/maingui.py:222 python/preferences.py:1482
+#: python/maingui.py:223 python/preferences.py:1485
 msgid "Channels"
 msgstr "Canali"
 
-#: python/maingui.py:222
+#: python/maingui.py:223
 #, fuzzy
 msgid "Players"
 msgstr "Lettore"
 
-#: python/maingui.py:223
+#: python/maingui.py:224
 msgid "VoIP"
 msgstr ""
 
-#: python/maingui.py:223 python/maingui.py:3093
+#: python/maingui.py:224 python/maingui.py:3129
 msgid "DSP"
 msgstr ""
 
-#: python/maingui.py:223
+#: python/maingui.py:224
 msgid "Mix"
 msgstr ""
 
-#: python/maingui.py:223
+#: python/maingui.py:224
 msgid "Misc"
 msgstr ""
 
-#: python/maingui.py:268
+#: python/maingui.py:269
 msgid "Reset"
 msgstr ""
 
-#: python/maingui.py:271
+#: python/maingui.py:272
 msgid "Reset the JACK port connections to the default settings."
 msgstr ""
 
-#: python/maingui.py:276
+#: python/maingui.py:277
 msgid ""
 "<span size=\"12000\" weight=\"bold\">Reset all JACK port connections?</"
 "span>\n"
@@ -1078,35 +1100,37 @@ msgid ""
 "and replaced with defaults."
 msgstr ""
 
-#: python/maingui.py:320
+#: python/maingui.py:321
 msgid "No compatible ports available."
 msgstr ""
 
-#: python/maingui.py:363
+#: python/maingui.py:364
+#, python-brace-format
 msgid "{0} profile={1}:{2} settings saved."
 msgstr ""
 
-#: python/maingui.py:366
+#: python/maingui.py:367
+#, python-brace-format
 msgid "{0} session={1}:{2} settings saved."
 msgstr ""
 
-#: python/maingui.py:670
+#: python/maingui.py:671
 msgid "Text"
 msgstr "Testo"
 
-#: python/maingui.py:673
+#: python/maingui.py:674
 msgid "The opener button's text."
 msgstr "Il testo del pulsante di apertura"
 
-#: python/maingui.py:681
+#: python/maingui.py:682
 msgid "Icon"
 msgstr "Icona"
 
-#: python/maingui.py:689
+#: python/maingui.py:690
 msgid "The opener button's icon."
 msgstr "L'iconda del pulsante di apertura."
 
-#: python/maingui.py:697
+#: python/maingui.py:698
 msgid ""
 "The headroom is the amount by which to reduce player volume when this opener "
 "is active. Note that the actual amount will be the largest value of all the "
@@ -1116,15 +1140,15 @@ msgstr ""
 "questo opener è attivo. Notare che la riduzione attuale sarà relativa al "
 "valore più alto tra tutti i pulsanti aperti."
 
-#: python/maingui.py:702
+#: python/maingui.py:703
 msgid "The amount of headroom required (dB)"
 msgstr "La quantità di headroom richiesta (dB)"
 
-#: python/maingui.py:711
+#: python/maingui.py:712
 msgid "This button will flash as a reminder to close"
 msgstr "Questo pulsante lampeggerà per ricordarvi di chiuderlo"
 
-#: python/maingui.py:712
+#: python/maingui.py:713
 msgid ""
 "After a number of seconds where a main player is active this button's status "
 "indicator will start to flash and will continue to do so until the button is "
@@ -1135,11 +1159,11 @@ msgstr ""
 "a farlo finché il pulsante non sarà rilasciato o finché non verrò fermata la "
 "riproduzione."
 
-#: python/maingui.py:720
+#: python/maingui.py:721
 msgid "This button is to be treated as a microphone opener"
 msgstr "Questo apre il microfono"
 
-#: python/maingui.py:722
+#: python/maingui.py:723
 msgid ""
 "The button will be grouped with the other microphone opener buttons. It will "
 "be affected by signals to close microphone buttons. Channels associated with "
@@ -1150,79 +1174,83 @@ msgstr ""
 "questo pulsante saranno missati in modo diverso quando vengono usate le "
 "modalità VoIP."
 
-#: python/maingui.py:733
+#: python/maingui.py:732
+msgid "This button will automatically cancel JACK freewheel mode"
+msgstr ""
+
+#: python/maingui.py:734
 msgid ""
 "This should be set for all buttons that control input from a live sound "
 "source or device."
 msgstr ""
 
-#: python/maingui.py:736
+#: python/maingui.py:737
 msgid "Button Open Triggers"
 msgstr "Inneschi apertura pulsante"
 
-#: python/maingui.py:743
+#: python/maingui.py:744
 msgid "Playlist advance button"
 msgstr "Pulsante di avanzamento playlist"
 
-#: python/maingui.py:744 python/maingui.py:745
+#: python/maingui.py:745 python/maingui.py:746
 #, python-format
 msgid "'%s' control"
 msgstr "controllo '%s'"
 
 #. TC: Insert playlist control to stop the player.
-#: python/maingui.py:744 python/playergui.py:4310
+#: python/maingui.py:745 python/playergui.py:4393
 msgid "Player Stop"
 msgstr "Ferma lettore"
 
 #. TC: Insert playlist control to stop the player.
-#: python/maingui.py:745 python/playergui.py:4317
+#: python/maingui.py:746 python/playergui.py:4400
 msgid "Player Stop 2"
 msgstr "Ferma lettore 2"
 
-#: python/maingui.py:746
+#: python/maingui.py:747
 msgid "Announcements"
 msgstr "Annunci"
 
-#: python/maingui.py:758
+#: python/maingui.py:759
 msgid "When opened close these other buttons"
 msgstr "Chiude questi altri pulsanti se aperto"
 
-#: python/maingui.py:769
+#: python/maingui.py:770
 msgid "Shell Command"
 msgstr "Comando Shell"
 
-#: python/maingui.py:770
+#: python/maingui.py:771
 msgid ""
 "Mostly useful issuing 'amixer' commands, in particular for setting capture."
 msgstr ""
 "Più utile se si lancia il comando 'amixer', in particolare per impostare la "
 "registrazione."
 
-#: python/maingui.py:790
+#: python/maingui.py:791
 msgid "On open"
 msgstr "All'avvio"
 
-#: python/maingui.py:791
+#: python/maingui.py:792
 msgid "On close"
 msgstr "In chiusura"
 
-#: python/maingui.py:835
+#: python/maingui.py:836
 msgid "Main Panel Opener Buttons"
 msgstr "Pulsanti di apertura del pannello principale"
 
-#: python/maingui.py:847
+#: python/maingui.py:848
 msgid "Indicate button numbers and associated channel numbers"
 msgstr "Indica il numero dei pulsanti e dei numeri di canale associati"
 
-#: python/maingui.py:849
+#: python/maingui.py:850
 msgid "A useful feature to have switched on while allocating channel openers."
 msgstr "Una funzionalità utile da attivare mentre si allocano i canali"
 
-#: python/maingui.py:855
+#: python/maingui.py:856
 msgid "Status Indicator Appearance"
 msgstr "Aspetto dell'indicatore di stato"
 
-#: python/maingui.py:858
+#: python/maingui.py:859
 msgid ""
 "Each opener button has two vertical bars at the side to make the button "
 "state more apparent. These settings control their appearance."
@@ -1230,28 +1258,28 @@ msgstr ""
 "Ogni pulsante ha due barre verticali ai lati per renderne chiaro lo stato. "
 "Queste impostazioni ne controllano la grafica."
 
-#: python/maingui.py:867
+#: python/maingui.py:868 python/format.py:827
 msgid "Width"
 msgstr "Larghezza"
 
-#: python/maingui.py:874
+#: python/maingui.py:875
 msgid "Opened"
 msgstr "Aperto"
 
-#: python/maingui.py:878 python/preferences.py:500 python/preferences.py:502
+#: python/maingui.py:879 python/preferences.py:503 python/preferences.py:505
 msgid "Closed"
 msgstr "Chiuso"
 
-#: python/maingui.py:883
+#: python/maingui.py:884
 msgid "Remind"
 msgstr "Ricorda"
 
 #. TC: A placeholder text for when there are no opener buttons.
-#: python/maingui.py:1064
+#: python/maingui.py:1065
 msgid "No Channel Opener Buttons"
 msgstr "Nessun canale da abilitare"
 
-#: python/maingui.py:1353
+#: python/maingui.py:1354
 msgid ""
 "This indicates the state of the various streams. Flashing means stream "
 "packets are being discarded because of network congestion. Partial red means "
@@ -1263,54 +1291,54 @@ msgstr ""
 "indica che il buffer di invio è parzialmente pieno, ovvero difficoltà di "
 "comunicazione con il server. Verde indica che tutto è a posto."
 
-#: python/maingui.py:1376
+#: python/maingui.py:1377
 msgid "The combined total number of listeners in all server tabs."
 msgstr "Il numero cumulato di ascoltatori per tutti i server."
 
 #. TC: Record as in, to make a recording.
-#: python/maingui.py:1824 python/sourceclientgui.py:2702
+#: python/maingui.py:1825 python/sourceclientgui.py:2784
 msgid "Record"
 msgstr "Registra"
 
-#: python/maingui.py:2620
+#: python/maingui.py:2647
 msgid "Confirmation to quit IDJC is required."
 msgstr "Viene chiesta una conferma per chiudere IDJC."
 
-#: python/maingui.py:2624
+#: python/maingui.py:2651
 msgid "All active recordings and radio streams will terminate."
 msgstr "Tutte le registrazioni ed i flussi radio verranno interrotti."
 
-#: python/maingui.py:2626
+#: python/maingui.py:2653
 msgid "All of the active radio streams will terminate."
 msgstr "Tutti flussi radio verranno interrotti."
 
-#: python/maingui.py:2628
+#: python/maingui.py:2655
 msgid "All active recordings will cease."
 msgstr "Tutte le registrazioni verranno interrotte."
 
 #. TC: Popup menu item, wipes away the tracks played history text.
-#: python/maingui.py:2885 python/maingui.py:3317
+#: python/maingui.py:2921 python/maingui.py:3353
 msgid "Remove Contents"
 msgstr "Rimuove i contenuti"
 
-#: python/maingui.py:3040
+#: python/maingui.py:3076
 msgid "Renameable Labels"
 msgstr ""
 
-#: python/maingui.py:3064
+#: python/maingui.py:3100
 #, fuzzy
 msgid "Main Players"
 msgstr "Lettore destro"
 
-#: python/maingui.py:3117
+#: python/maingui.py:3153
 msgid "Mix voice over IP audio to the output stream."
 msgstr "Manda in onda l'audio del VoIP"
 
-#: python/maingui.py:3130
+#: python/maingui.py:3166
 msgid "Mix voice over IP audio to the DJ only."
 msgstr "Missa l'audio del VoIP solo al DJ"
 
-#: python/maingui.py:3157
+#: python/maingui.py:3193
 msgid ""
 "This button steps through the active playlist, pausing between tracks. The "
 "active playlist is defined by the placement of the crossfader."
@@ -1318,44 +1346,45 @@ msgstr ""
 "Questo pulsante scorre la playlist attiva facendo una pausa tra le tracce. "
 "La playlist attiva viene dedotta dal posizionamento del crossfader"
 
-#: python/maingui.py:3202 python/preferences.py:870
+#: python/maingui.py:3238 python/preferences.py:873
 msgid "The volume control shared by both music players."
 msgstr "Il controllo del volume per entrambi i lettori"
 
-#: python/maingui.py:3213
+#: python/maingui.py:3249
 msgid "The volume control for the right music player."
 msgstr "Il volume del lettore di destra."
 
-#: python/maingui.py:3241
+#: python/maingui.py:3277
 msgid "VoIP level adjustment. 0dB gain is at the mid point."
 msgstr ""
 
-#: python/maingui.py:3264
+#: python/maingui.py:3300
 msgid "The stream volume level to send to the voice over IP connection."
 msgstr "Il volume del flusso da inviare alla connessione VoIP"
 
-#: python/maingui.py:3291 python/preferences.py:1410
+#: python/maingui.py:3327 python/preferences.py:1413
 msgid "Tracks Played"
 msgstr "Tracce eseguite"
 
-#: python/maingui.py:3362 python/maingui.py:3364 python/maingui.py:3388
+#: python/maingui.py:3398 python/maingui.py:3400 python/maingui.py:3424
 msgid "Monitor Mix"
 msgstr "Monitoraggio Mix"
 
-#: python/maingui.py:3371 python/maingui.py:3388 python/playergui.py:4251
+#: python/maingui.py:3407 python/maingui.py:3424 python/playergui.py:4334
 msgid "DJ"
 msgstr "DJ"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/maingui.py:3374 python/maingui.py:3388 python/midicontrols.py:154
-#: python/midicontrols.py:1506 python/playergui.py:4243
-#: python/sourceclientgui.py:2710
+#: python/maingui.py:3410 python/maingui.py:3424 python/midicontrols.py:155
+#: python/midicontrols.py:1507 python/playergui.py:4326
+#: python/sourceclientgui.py:2792
 msgid "Stream"
 msgstr "Flusso"
 
 #. TC: Context {0}, {1}, {2} = Monitor Mix, Stream, DJ
 #. TC: Or whatever they become translated to.
-#: python/maingui.py:3384
+#: python/maingui.py:3420
+#, python-brace-format
 msgid ""
 "In IDJC there are are two audio paths and this '{0}' control toggles between "
 "them. When '{1}' is active you can hear what the listeners are hearing "
@@ -1368,83 +1397,83 @@ msgstr ""
 "impostato su '{2}' per utilizzare al meglio le funzionalità VoIP"
 
 #. TC: Dropdown box title text widget.
-#: python/maingui.py:3397 python/maingui.py:3399
+#: python/maingui.py:3433 python/maingui.py:3435
 msgid "Metadata Source"
 msgstr "Sorgente dei metadati"
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3405 python/playergui.py:3961
+#: python/maingui.py:3441 python/playergui.py:4044
 msgid "Playlist 1"
 msgstr "Playlist 1"
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3407 python/playergui.py:3962
+#: python/maingui.py:3443 python/playergui.py:4045
 msgid "Playlist 2"
 msgstr "Playlist 2"
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3409
+#: python/maingui.py:3445 python/songdb.py:909 python/songdb.py:1293
 msgid "Last Played"
 msgstr "Ultima eseguita"
 
 #. TC: The chosen source of track metadata.
-#: python/maingui.py:3411 python/maingui.py:3448 python/maingui.py:3450
+#: python/maingui.py:3447 python/maingui.py:3484 python/maingui.py:3486
 msgid "Crossfader"
 msgstr "Crossfader"
 
 #. TC: The chosen source of track metadata. In this case no metadata.
 #. TC: Fade time is zero. No fade, none.
-#: python/maingui.py:3413 python/playergui.py:4226
+#: python/maingui.py:3449 python/playergui.py:4309
 msgid "None"
 msgstr "Nessuna"
 
 #. TC: The chosen source of track metadata. In this case no metadata.
-#: python/maingui.py:3415
+#: python/maingui.py:3451
 msgid "Playlist 3"
 msgstr "Playlist 3"
 
-#: python/maingui.py:3420
+#: python/maingui.py:3456
 #, fuzzy
 msgid "Select the origin for the playing track metadata on the stream."
 msgstr "Seleziona quale Deck è responsabile dei metadati del flusso"
 
 #. TC: Abbreviation of left.
-#: python/maingui.py:3430 python/maingui.py:3432
+#: python/maingui.py:3466 python/maingui.py:3468
 msgid "L"
 msgstr "L"
 
-#: python/maingui.py:3442
+#: python/maingui.py:3478
 msgid "Move the crossfader fully left."
 msgstr "Sposta il crossfader a sinistra"
 
-#: python/maingui.py:3462
+#: python/maingui.py:3498
 msgid "The crossfader."
 msgstr "Il crossfader"
 
 #. TC: Abbreviation of right.
-#: python/maingui.py:3466 python/maingui.py:3468
+#: python/maingui.py:3502 python/maingui.py:3504
 msgid "R"
 msgstr "R"
 
-#: python/maingui.py:3478
+#: python/maingui.py:3514
 msgid "Move the crossfader fully right."
 msgstr "Sposta il crossfader a destra"
 
 #. TC: Describes a mid point.
-#: python/maingui.py:3487 python/maingui.py:3489
+#: python/maingui.py:3523 python/maingui.py:3525
 msgid "Middle"
 msgstr "Mezzo/Metà"
 
-#: python/maingui.py:3506 python/maingui.py:3513
+#: python/maingui.py:3542 python/maingui.py:3549
 msgid "Move the crossfader to the middle of its range of travel."
 msgstr "Sposta il crossfader a metà della corsa"
 
 #. TC: The attenuation response curve of the crossfader. User selectable.
-#: python/maingui.py:3518 python/maingui.py:3520
+#: python/maingui.py:3554 python/maingui.py:3556
 msgid "Response"
 msgstr "Risposta"
 
-#: python/maingui.py:3542
+#: python/maingui.py:3578
 msgid ""
 "This selects the response curve of the crossfader.\n"
 "\n"
@@ -1454,11 +1483,11 @@ msgstr ""
 "Le attenuzioni nel punto di mezzo sono -3dB, 0dB e -22dB rispettivamente."
 
 #. TC: Duration in seconds.
-#: python/maingui.py:3556 python/maingui.py:3558
+#: python/maingui.py:3592 python/maingui.py:3594
 msgid "Time"
 msgstr "Tempo"
 
-#: python/maingui.py:3575
+#: python/maingui.py:3611
 msgid ""
 "The time in seconds that the crossfader will take to automatically pass "
 "across when the button to the right is clicked."
@@ -1468,11 +1497,11 @@ msgstr ""
 
 #. TC: The crossfader pass-across button text.
 #. TC: The actual button appears as [<-->] with this text above it.
-#: python/maingui.py:3584 python/maingui.py:3586
+#: python/maingui.py:3620 python/maingui.py:3622
 msgid "Pass"
 msgstr "Avvia"
 
-#: python/maingui.py:3599
+#: python/maingui.py:3635
 msgid ""
 "This button causes the crossfader to move to the opposite side at a speed "
 "determined by the speed selector to the left."
@@ -1480,32 +1509,32 @@ msgstr ""
 "Questo pulsante muove il crossfader fino alla parte opposta nel lasso di "
 "tempo specificato qui a sinistra"
 
-#: python/maingui.py:3642
+#: python/maingui.py:3678
 #, fuzzy
 msgid "Peak"
 msgstr "Str Peak"
 
-#: python/maingui.py:3645
+#: python/maingui.py:3681
 msgid "A peak hold meter indicating the signal strength of the stream audio."
 msgstr ""
 "Un indicatore a tenuta di picco che indica la potenza del segnale audio "
 "trasmesso."
 
 #. TC: This text appears above the stream mix VU meter.
-#: python/maingui.py:3667
+#: python/maingui.py:3703
 msgid "VU"
 msgstr ""
 
-#: python/maingui.py:3671
+#: python/maingui.py:3707
 msgid "A VU meter for the stream audio."
 msgstr "Indicatore VU per il flusso audio"
 
 #. TC: Appears above the mic meters as a label followed by a number.
-#: python/maingui.py:3674
+#: python/maingui.py:3710
 msgid "Ch"
 msgstr "Ch"
 
-#: python/maingui.py:3701
+#: python/maingui.py:3737
 msgid ""
 "A peak hold meter indicating the microphone signal strength and a meter "
 "indicating attenuation levels in the microphone signal processing system. "
@@ -1518,484 +1547,484 @@ msgstr ""
 "esser. Il rosso del limiter."
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:47
+#: python/midicontrols.py:48
 #, fuzzy
 msgid "Tooltips enable"
 msgstr "VoIP abilita l'uscita"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:49
+#: python/midicontrols.py:50
 msgid "DJ-mix monitor"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:51
+#: python/midicontrols.py:52
 msgid "Panning load from presets"
 msgstr ""
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:53
+#: python/midicontrols.py:54
 msgid "Player play/pause"
 msgstr "Lettore riproduci/pausa"
 
 #. TC: Control method. Please keep it as Target:Action.
 #. TC: Playlist control.
-#: python/midicontrols.py:55 python/playergui.py:3719
+#: python/midicontrols.py:56 python/playergui.py:3798
 msgid "Player stop"
 msgstr "Lettore ferma"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:57
+#: python/midicontrols.py:58
 msgid "Player advance"
 msgstr "Lettore avanza"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:59
+#: python/midicontrols.py:60
 msgid "Player play previous"
 msgstr "Lettore suona la precedente"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:61
+#: python/midicontrols.py:62
 msgid "Player play next"
 msgstr "Lettore suona la prossima"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:63
+#: python/midicontrols.py:64
 msgid "Player play selected from start"
 msgstr "Lettore suona la selezione dall'inizio"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:65
+#: python/midicontrols.py:66
 msgid "Player select previous"
 msgstr "Lettore seleziona la precedente"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:67
+#: python/midicontrols.py:68
 msgid "Player select next"
 msgstr "Lettore seleziona la successiva"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:69
+#: python/midicontrols.py:70
 msgid "Player stream output enable"
 msgstr "Lettore abilita il flusso"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:71
+#: python/midicontrols.py:72
 msgid "Player DJ output enable"
 msgstr "Lettore abilita l'uscita DJ"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:73
+#: python/midicontrols.py:74
 msgid "Player DJ-only switch"
 msgstr "Lettore solo al DJ "
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:75
+#: python/midicontrols.py:76
 msgid "Player set volume"
 msgstr "Lettore Imposta il volume"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:77
+#: python/midicontrols.py:78
 msgid "Player set gain"
 msgstr "Lettore imposta il gain"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:79
+#: python/midicontrols.py:80
 msgid "Player set balance"
 msgstr "Lettore imposta il bilanciamento"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:81
+#: python/midicontrols.py:82
 msgid "Player set pitchbend"
 msgstr "Lettore imposta variazione tono"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:84
+#: python/midicontrols.py:85
 msgid "Playlist edit tags"
 msgstr "Playlist modifica i tag"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:86
+#: python/midicontrols.py:87
 msgid "Playlist insert stop"
 msgstr "Playlist inserisci stop"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:88
+#: python/midicontrols.py:89
 msgid "Playlist insert stop 2"
 msgstr "Playlist inserisci stop 2"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:90
+#: python/midicontrols.py:91
 msgid "Playlist insert announce"
 msgstr "Lettore inserisci annuncio"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:92
+#: python/midicontrols.py:93
 msgid "Playlist insert transfer"
 msgstr "Lettore inserisci trasferimento"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:94
+#: python/midicontrols.py:95
 msgid "Playlist insert crossfade"
 msgstr "Playlist inserisci dissolvenza"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:96
+#: python/midicontrols.py:97
 msgid "Playlist insert pitchunbend"
 msgstr "Playlist inserisci abbassamento tono"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:98
+#: python/midicontrols.py:99
 msgid "Playlist insert jump to top"
 msgstr "Playlist inserisci salto all'inizio"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:101
+#: python/midicontrols.py:102
 msgid "Players set crossfade"
 msgstr "Lettori imposta dissolvenza"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:103
+#: python/midicontrols.py:104
 msgid "Players pass crossfade"
 msgstr "Lettori supera dissolvenza"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:105
+#: python/midicontrols.py:106
 msgid "Players set focus"
 msgstr "Lettori imposta focus"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:107
+#: python/midicontrols.py:108
 msgid "Players show pitchbend"
 msgstr "Lettori mostra alzamento tono"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:109
+#: python/midicontrols.py:110
 #, fuzzy
 msgid "Players advance"
 msgstr "Lettore avanza"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:112
+#: python/midicontrols.py:113
 msgid "Channel output enable"
 msgstr "Canale abilita l'uscita"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:114
+#: python/midicontrols.py:115
 msgid "Channel set volume"
 msgstr "Canale imposta volume"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:116
+#: python/midicontrols.py:117
 msgid "Channel set gain"
 msgstr "Canale imposta guadagno"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:118
+#: python/midicontrols.py:119
 msgid "Channel set balance"
 msgstr "Canale imposta bilanciameno"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:121
+#: python/midicontrols.py:122
 msgid "VoIP output enable"
 msgstr "VoIP abilita l'uscita"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:123
+#: python/midicontrols.py:124
 msgid "VoIP DJ-only switch"
 msgstr "VoIP solo al DJ"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:125
+#: python/midicontrols.py:126
 msgid "VoIP set volume"
 msgstr "VoIP imposta volume"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:127
+#: python/midicontrols.py:128
 #, fuzzy
 msgid "VoIP set mixback"
 msgstr "VoIP imposta il bilanciamento"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:129
+#: python/midicontrols.py:130
 msgid "VoIP set gain"
 msgstr "VoIP imposta guadagno"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:131
+#: python/midicontrols.py:132
 msgid "VoIP set balance"
 msgstr "VoIP imposta il bilanciamento"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:134
+#: python/midicontrols.py:135
 #, fuzzy
 msgid "Effect play from start"
 msgstr "Stacchetto suona dall'inizio"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:137
+#: python/midicontrols.py:138
 #, fuzzy
 msgid "Effects stop many"
 msgstr "VoIP imposta volume"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:139
+#: python/midicontrols.py:140
 #, fuzzy
 msgid "Effects set volume"
 msgstr "VoIP imposta volume"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:141
+#: python/midicontrols.py:142
 #, fuzzy
 msgid "Effects set headroom"
 msgstr "Stacchetti seleziona il successivo"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:144
+#: python/midicontrols.py:145
 msgid "Stream set connected"
 msgstr "Flusso imposta connessione"
 
 #. TC: Control method. Please keep it as Target:Action.
-#: python/midicontrols.py:147
+#: python/midicontrols.py:148
 msgid "Recorder set recording"
 msgstr "Registratore imposta registrazione"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:151 python/midicontrols.py:1492
+#: python/midicontrols.py:152 python/midicontrols.py:1493
 msgid "Player"
 msgstr "Lettore"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
 #. TC: The midi channel.
 #. TC: Specifically, the numerical midi channel.
-#: python/midicontrols.py:152 python/midicontrols.py:1498
-#: python/midicontrols.py:1567 python/midicontrols.py:1757
+#: python/midicontrols.py:153 python/midicontrols.py:1499
+#: python/midicontrols.py:1568 python/midicontrols.py:1758
 msgid "Channel"
 msgstr "Canale"
 
-#: python/midicontrols.py:153 python/preferences.py:596
-#: python/preferences.py:606
+#: python/midicontrols.py:154 python/preferences.py:599
+#: python/preferences.py:609
 msgid "Effect"
 msgstr "Effetto"
 
-#: python/midicontrols.py:155
+#: python/midicontrols.py:156
 msgid "Recorder"
 msgstr "Registratore"
 
-#: python/midicontrols.py:156
+#: python/midicontrols.py:157
 #, fuzzy
 msgid "Setting"
 msgstr "Modificatori"
 
-#: python/midicontrols.py:160
+#: python/midicontrols.py:161
 msgid "Left player"
 msgstr "Lettore sinistro"
 
-#: python/midicontrols.py:161
+#: python/midicontrols.py:162
 msgid "Right player"
 msgstr "Lettore destro"
 
-#: python/midicontrols.py:162
+#: python/midicontrols.py:163
 #, fuzzy
 msgid "Background player"
 msgstr "Lettore attivo"
 
-#: python/midicontrols.py:163
+#: python/midicontrols.py:164
 msgid "Focused player"
 msgstr "Lettore attivo"
 
-#: python/midicontrols.py:164
+#: python/midicontrols.py:165
 msgid "Fadered player"
 msgstr "Lettore inattivo"
 
-#: python/midicontrols.py:168
+#: python/midicontrols.py:169
 #, fuzzy
 msgid "Effects bank 1"
 msgstr "Effetto"
 
-#: python/midicontrols.py:169
+#: python/midicontrols.py:170
 #, fuzzy
 msgid "Effects bank 2"
 msgstr "Effetto"
 
-#: python/midicontrols.py:170
+#: python/midicontrols.py:171
 #, fuzzy
 msgid "All effects"
 msgstr "Stacchetti seleziona il successivo"
 
 #. TC: The name of the backspace key.
-#: python/midicontrols.py:404
+#: python/midicontrols.py:405
 msgid "BackSpace"
 msgstr "BackSpace"
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1468
+#: python/midicontrols.py:1469
 msgid "Use value"
 msgstr "Usa valore"
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1470
+#: python/midicontrols.py:1471
 msgid "Act if"
 msgstr "Agisci se"
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1472
+#: python/midicontrols.py:1473
 msgid "Set to"
 msgstr "Imposta a"
 
 #. TC: binding editor, action pane, third row, heading text.
-#: python/midicontrols.py:1474
+#: python/midicontrols.py:1475
 msgid "Adjust by"
 msgstr "Regola di"
 
 #. TC: binding editor, input pane, fourth row, heading text.
-#: python/midicontrols.py:1479 python/midicontrols.py:1483
+#: python/midicontrols.py:1480 python/midicontrols.py:1484
 msgid "Control"
 msgstr "Controllo"
 
 #. TC: binding editor, input pane, fourth row, heading text.
-#: python/midicontrols.py:1481
+#: python/midicontrols.py:1482
 msgid "Note"
 msgstr "Nota"
 
 #. TC: binding editor, input pane, fourth row, heading text.
-#: python/midicontrols.py:1485
+#: python/midicontrols.py:1486
 msgid "Key"
 msgstr "Tasto"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1490
+#: python/midicontrols.py:1491
 #, fuzzy
 msgid "Miscellaneous"
 msgstr "Impostazioni varie"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1494
+#: python/midicontrols.py:1495
 msgid "Both players"
 msgstr "Entrambi i lettori"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1496
+#: python/midicontrols.py:1497
 msgid "Quick panning"
 msgstr ""
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1500
+#: python/midicontrols.py:1501
 msgid "VoIP channel"
 msgstr "Canale VoIP"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1502
+#: python/midicontrols.py:1503
 #, fuzzy
 msgid "Single effect"
 msgstr "Stacchetti seleziona il successivo"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1504
+#: python/midicontrols.py:1505
 #, fuzzy
 msgid "Effects bank"
 msgstr "Effetto"
 
 #. TC: binding editor, action pane, first row, toplevel menu.
-#: python/midicontrols.py:1508
+#: python/midicontrols.py:1509
 msgid "Stream recorder"
 msgstr "Flusso registratore "
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1513
+#: python/midicontrols.py:1514
 msgid "Direct fader/held button"
 msgstr "Pulsante cursore/premuto"
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1515
+#: python/midicontrols.py:1516
 msgid "One-shot/toggle button"
 msgstr "Pulsante a singolo colpo"
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1517
+#: python/midicontrols.py:1518
 msgid "Set value"
 msgstr "Imposta valore"
 
 #. TC: binding editor, action pane, second row, dropdown text.
-#: python/midicontrols.py:1519
+#: python/midicontrols.py:1520
 msgid "Alter value"
 msgstr "Altera valore"
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1524
+#: python/midicontrols.py:1525
 msgid "MIDI control"
 msgstr "MIDI controllo"
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1526
+#: python/midicontrols.py:1527
 msgid "MIDI note"
 msgstr "MIDI nota"
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1528
+#: python/midicontrols.py:1529
 msgid "MIDI pitch-wheel"
 msgstr "MIDI controllo della tonalità "
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1530
+#: python/midicontrols.py:1531
 msgid "Keyboard press"
 msgstr "Azione da tastiera"
 
 #. TC: binding editor, input pane, second row, dropdown text.
-#: python/midicontrols.py:1532
+#: python/midicontrols.py:1533
 msgid "XChat command"
 msgstr "XChat comando"
 
 #. TC: Dialog window title text.
 #. TC: User is expected to edit a control binding.
-#: python/midicontrols.py:1541
+#: python/midicontrols.py:1542
 msgid "Edit control binding"
 msgstr "Modifica le scorciatoie per i controlli"
 
 #. TC: After clicking this button the binding editor will be listening
 #. TC: for a key press or midi control surface input.
 #. TC: Button text. If pressed triggers 'Listening for input' mode.
-#: python/midicontrols.py:1556 python/midicontrols.py:1637
-#: python/midicontrols.py:1736
+#: python/midicontrols.py:1557 python/midicontrols.py:1638
+#: python/midicontrols.py:1737
 msgid "Listen for input..."
 msgstr "In attesa di input..."
 
 #. TC: The input source.
-#: python/midicontrols.py:1564
+#: python/midicontrols.py:1565
 msgid "Source"
 msgstr "Fonte"
 
 #. TC: The manner in which the input is interpreted.
-#: python/midicontrols.py:1583
+#: python/midicontrols.py:1584
 msgid "Interaction"
 msgstr "Interazione"
 
 #. TC: The effect of the control can be directed upon a specific target.
 #. TC: e.g. On target [Left player]
-#: python/midicontrols.py:1589
+#: python/midicontrols.py:1590
 msgid "On target"
 msgstr "Obiettivo"
 
 #. TC: Checkbutton text.
 #. TC: Use reverse scale and invert the meaning of button presses.
-#: python/midicontrols.py:1597
+#: python/midicontrols.py:1598
 msgid "Reversed"
 msgstr "Invertito"
 
-#: python/midicontrols.py:1598
+#: python/midicontrols.py:1599
 msgid "Pressed"
 msgstr "Premuto"
 
-#: python/midicontrols.py:1600
+#: python/midicontrols.py:1601
 msgid "Released"
 msgstr "Rilasciato"
 
 #. TC: Tree column heading for Inputs e.g. Backspace, F1, S.
-#: python/midicontrols.py:1630 python/midicontrols.py:1991
+#: python/midicontrols.py:1631 python/midicontrols.py:1992
 msgid "Input"
 msgstr "Ingresso"
 
-#: python/midicontrols.py:1634
+#: python/midicontrols.py:1635
 #, python-format
 msgid ""
 "The first half of a binding is the input which comes in the form of the "
@@ -2010,32 +2039,32 @@ msgstr ""
 "dell'opzione '%s'."
 
 #. TC: Tree column heading for actions e.g. Player stop.
-#: python/midicontrols.py:1670 python/midicontrols.py:1676
-#: python/midicontrols.py:2005
+#: python/midicontrols.py:1671 python/midicontrols.py:1677
+#: python/midicontrols.py:2006
 msgid "Action"
 msgstr "Azione"
 
 #. TC: %s is the translation of 'Action'.
-#: python/midicontrols.py:1675
+#: python/midicontrols.py:1676
 #, python-format
 msgid "The '%s' pane determines how the input is handled, and to what effect."
 msgstr ""
 "Il pannello '%s' determina come viene gestito l'ingresso e con quale effetto."
 
-#: python/midicontrols.py:1732
+#: python/midicontrols.py:1733
 msgid "Listening for input"
 msgstr "In attesta di input"
 
 #. TC: Refers to key modifiers including Ctrl, Alt, Shift, ....
-#: python/midicontrols.py:1753
+#: python/midicontrols.py:1754
 msgid "Shifting"
 msgstr "Modificatori"
 
-#: python/midicontrols.py:1952
+#: python/midicontrols.py:1953
 msgid "Singular control"
 msgstr "Controllo unico"
 
-#: python/midicontrols.py:2014
+#: python/midicontrols.py:2015
 msgid "Target"
 msgstr "Obiettivo"
 
@@ -2089,7 +2118,7 @@ msgid " Additional Text Frames "
 msgstr " Riquadri di testo aggiuntivi "
 
 #. TC: The album track number.
-#: python/mutagentagger.py:376 python/songdb.py:789 python/songdb.py:1160
+#: python/mutagentagger.py:376 python/songdb.py:906 python/songdb.py:1295
 msgid "Track"
 msgstr "Traccia"
 
@@ -2115,232 +2144,268 @@ msgstr "Nome file:"
 msgid "Native"
 msgstr "Nativo"
 
-#: python/songdb.py:174
+#: python/songdb.py:177
 #, fuzzy
 msgid "Connecting"
 msgstr "Connessione"
 
-#: python/songdb.py:183
+#: python/songdb.py:188
 #, fuzzy, python-format
 msgid "Connection failed (try %d)"
 msgstr "Timer di connessione:"
 
-#: python/songdb.py:195
-msgid "Connected: utf-8 mode failed"
+#: python/songdb.py:199
+msgid "Connected: autocommit mode failed"
+msgstr ""
+
+#: python/songdb.py:201
+msgid "Connected: autocommit mode set"
 msgstr ""
 
-#: python/songdb.py:197
+#: python/songdb.py:202
 #, fuzzy
 msgid "Connected"
 msgstr "Connetti"
 
-#: python/songdb.py:205
+#: python/songdb.py:210
 msgid "Job dropped"
 msgstr ""
 
-#: python/songdb.py:215 python/songdb.py:427
+#: python/songdb.py:220 python/songdb.py:431
 #, fuzzy
 msgid "Disconnected"
 msgstr "Disconnetti"
 
-#: python/songdb.py:229
+#: python/songdb.py:233
 msgid "Problem dropping connection"
 msgstr ""
 
-#: python/songdb.py:231
+#: python/songdb.py:235
 #, fuzzy
 msgid "Connection dropped"
 msgstr "Connessione"
 
-#: python/songdb.py:322
+#: python/songdb.py:326
 #, fuzzy
 msgid "Hostname[:Port]"
 msgstr "Nome host"
 
-#: python/songdb.py:327
+#: python/songdb.py:331
 #, fuzzy
 msgid "User Name"
 msgstr "Nome utente"
 
-#: python/songdb.py:330
+#: python/songdb.py:334
 msgid "Database"
 msgstr "Database"
 
-#: python/songdb.py:385
+#: python/songdb.py:389
 #, fuzzy
 msgid "Prokyon3 or Ampache (song title) Database"
 msgstr "Prokyon3 (titolo canzone) Database"
 
-#: python/songdb.py:386
+#: python/songdb.py:390
 msgid ""
 "You can make certain media databases accessible in IDJC for easy drag and "
 "drop into the playlists."
 msgstr ""
 
-#: python/songdb.py:434
+#: python/songdb.py:438
 #, fuzzy
 msgid "Module mysql-python (MySQLdb) required"
 msgstr "E' necessario il modulo Python MySQLdb"
 
-#: python/songdb.py:675 python/songdb.py:680
+#: python/songdb.py:707 python/songdb.py:723 python/songdb.py:747
+#: python/songdb.py:805
 msgid "<unknown>"
 msgstr "<sconosciuto>"
 
-#: python/songdb.py:761
+#: python/songdb.py:741
+#, fuzzy
+msgid "Not Played"
+msgstr "Ultima eseguita"
+
+#: python/songdb.py:878
 msgid "Reload the database."
 msgstr ""
 
-#: python/songdb.py:766
+#: python/songdb.py:883
 msgid "Expand entire tree."
 msgstr ""
 
-#: python/songdb.py:767
+#: python/songdb.py:884
 #, fuzzy
 msgid "Collapse tree."
 msgstr "_Collassa"
 
-#: python/songdb.py:774
+#: python/songdb.py:891
 msgid "Browse"
 msgstr ""
 
 #. TC: The disk number of the album track.
-#: python/songdb.py:787 python/songdb.py:1159
+#: python/songdb.py:904 python/songdb.py:1294
 msgid "Disk"
 msgstr ""
 
 #. TC: Track playback time.
 #. TC: Playback time.
-#: python/songdb.py:791 python/songdb.py:1162 python/playergui.py:312
+#: python/songdb.py:908 python/songdb.py:1296 python/playergui.py:313
 msgid "Duration"
 msgstr "Durata"
 
-#: python/songdb.py:792 python/songdb.py:1163
+#: python/songdb.py:910 python/songdb.py:1297 python/format.py:594
+#: python/format.py:615 python/format.py:701 python/format.py:722
+#: python/format.py:857 python/format.py:962 python/format.py:1012
+#: python/format.py:1022
 msgid "Bitrate"
 msgstr "Bitrate"
 
-#: python/songdb.py:793 python/songdb.py:1164
+#: python/songdb.py:911 python/songdb.py:1298
 msgid "Filename"
 msgstr "Nome file"
 
 #. TC: Directory path to a file.
-#: python/songdb.py:795 python/songdb.py:1165
+#: python/songdb.py:913 python/songdb.py:1299
 msgid "Path"
 msgstr "Percorso"
 
-#: python/songdb.py:800
+#: python/songdb.py:918
 msgid "Artist - Album - Title"
 msgstr ""
 
-#: python/songdb.py:801
+#: python/songdb.py:919
 msgid "Album - [Disk] - Title"
 msgstr ""
 
-#: python/songdb.py:821
+#: python/songdb.py:939
 msgid "Fetching"
 msgstr ""
 
-#: python/songdb.py:953
+#: python/songdb.py:1084
 msgid "Tree fetch failed"
 msgstr ""
 
-#: python/songdb.py:955
+#: python/songdb.py:1085
 msgid "Fetch Failed!"
 msgstr ""
 
-#: python/songdb.py:968
+#: python/songdb.py:1098
 msgid "Populating"
 msgstr "Sto popolando"
 
-#: python/songdb.py:1094
+#: python/songdb.py:1224
 #, python-format
 msgid "Disk %d"
 msgstr ""
 
 #. TC: User specified search filter entry box title text.
-#: python/songdb.py:1113
+#: python/songdb.py:1243
 msgid "Filters"
 msgstr "Filtri"
 
 #. TC: A type of search on any data field matching paritial strings.
-#: python/songdb.py:1125
+#: python/songdb.py:1255
 msgid "Fuzzy Search"
 msgstr "Ricerca approssimativa"
 
 #. TC: WHERE is an SQL keyword.
-#: python/songdb.py:1134
+#: python/songdb.py:1264
 msgid "WHERE"
 msgstr "WHERE"
 
-#: python/songdb.py:1147
+#: python/songdb.py:1277
 #, fuzzy
 msgid "Search"
 msgstr "Ricerca approssimativa"
 
-#: python/songdb.py:1440
+#: python/songdb.py:1514 python/songdb.py:1639
+msgid "Minutes"
+msgstr ""
+
+#: python/songdb.py:1514 python/songdb.py:1639
+#, fuzzy
+msgid "Hours"
+msgstr "Colori"
+
+#: python/songdb.py:1515 python/songdb.py:1639
+msgid "Days"
+msgstr ""
+
+#: python/songdb.py:1515 python/songdb.py:1639 python/songdb.py:1709
+#: python/songdb.py:1803
+msgid "Weeks"
+msgstr ""
+
+#: python/songdb.py:1609
 msgid "Catalogs"
 msgstr ""
 
-#: python/songdb.py:1445
+#: python/songdb.py:1616
 #, fuzzy
 msgid "Name"
 msgstr "Nome utente"
 
-#: python/songdb.py:1446
+#: python/songdb.py:1617
 msgid "Catalog Path"
 msgstr ""
 
-#: python/songdb.py:1447
+#: python/songdb.py:1618
 #, fuzzy
 msgid "Prepend Path"
 msgstr "Prependi"
 
-#: python/songdb.py:1462
+#: python/songdb.py:1626
+#, fuzzy
+msgid "Last Played Scale"
+msgstr "Ultima eseguita"
+
+#: python/songdb.py:1658
 #, fuzzy
 msgid "Path Peel"
 msgstr "Percorso"
 
-#: python/songdb.py:1528
+#: python/songdb.py:1737
 msgid "N/A"
 msgstr ""
 
-#: python/songdb.py:1703
+#: python/songdb.py:1918
 #, fuzzy
 msgid "Failed to create FULLTEXT index"
 msgstr "errore nella creazione del profilo: %s"
 
-#: python/songdb.py:1707
+#: python/songdb.py:1922
 msgid "Found existing FULLTEXT index"
 msgstr ""
 
-#: python/songdb.py:1721 python/songdb.py:1734
+#: python/songdb.py:1936 python/songdb.py:1949
 #, fuzzy
 msgid "Unrecognised database"
 msgstr "data di registrazione"
 
-#: python/songdb.py:1729
+#: python/songdb.py:1944
 msgid "Found Prokyon 3 schema"
 msgstr ""
 
-#: python/playergui.py:235
+#: python/playergui.py:236
 msgid "Cuesheet Playlist"
 msgstr "Playlist da file cue"
 
 #. TC: Column heading, the track number.
-#: python/playergui.py:301
+#: python/playergui.py:302
 msgid "Trk"
 msgstr "Trk"
 
 #. TC: Column heading, the index number.
-#: python/playergui.py:304
+#: python/playergui.py:305
 msgid "Ind"
 msgstr "Ind"
 
-#: python/playergui.py:413
+#: python/playergui.py:414
 msgid "External Playlist"
 msgstr "Playlist esterna"
 
 #. TC: Button text to activate an external playlist.
-#: python/playergui.py:424
+#: python/playergui.py:425
 msgid "Active"
 msgstr "Attivo"
 
@@ -2368,243 +2433,253 @@ msgstr "Crea un nuovo annuncio"
 msgid "Modify or Delete this announcement"
 msgstr "Modifica o elimina questo annuncio"
 
-#. TC: Playlist control.
 #. TC: Embed a DJ announcement text into the playlist.
-#: python/playergui.py:528 python/playergui.py:3709 python/playergui.py:4347
+#: python/playergui.py:528 python/playergui.py:4430
 msgid "Announcement"
 msgstr "Avviso"
 
 #. TC: The time format as minutes and seconds.
-#: python/playergui.py:555
+#: python/playergui.py:556
 msgid "mm:ss"
 msgstr "mm:ss"
 
 #. TC: Alongside the name of the next track.
-#: python/playergui.py:608
+#: python/playergui.py:609
 msgid "Next track"
 msgstr "Traccia successiva"
 
-#: python/playergui.py:933
+#: python/playergui.py:934
 msgid "By Extension"
 msgstr "Per estensione"
 
-#: python/playergui.py:933
+#: python/playergui.py:934
 msgid "M3U playlist"
 msgstr "Playlist M3U"
 
 #: python/playergui.py:934
+#, fuzzy
+msgid "M3U8 playlist"
+msgstr "Playlist M3U"
+
+#: python/playergui.py:935
 msgid "XSPF playlist"
 msgstr "XSPF playlist"
 
-#: python/playergui.py:934
+#: python/playergui.py:935
 msgid "PLS playlist"
 msgstr "PLS playlist"
 
-#: python/playergui.py:1006
+#: python/playergui.py:1007
 #, python-format
 msgid "%d Audio Tracks"
 msgstr ""
 
 #. TC: Missing metadata text.
-#: python/playergui.py:1016
+#: python/playergui.py:1017
 msgid "Unknown"
 msgstr "Sconosciuto"
 
-#: python/playergui.py:1020
+#: python/playergui.py:1021
 msgid "(Cue sheet)"
 msgstr "(Elementi del file cue)"
 
-#: python/playergui.py:1054
+#: python/playergui.py:1058
 msgid "Bad Tag"
 msgstr "Tag errato"
 
-#: python/playergui.py:1830 python/playergui.py:4185
+#: python/playergui.py:1888 python/playergui.py:4268
 msgid "Manual"
 msgstr "Manuale"
 
-#: python/playergui.py:1834 python/playergui.py:4182
+#: python/playergui.py:1892 python/playergui.py:4265
 msgid "Play All"
 msgstr "Riproduci tutto"
 
-#: python/playergui.py:1842 python/playergui.py:1851 python/playergui.py:4183
+#: python/playergui.py:1900 python/playergui.py:1909 python/playergui.py:4266
 msgid "Loop All"
 msgstr "Riproduci in ciclo"
 
-#: python/playergui.py:1842 python/playergui.py:4186
+#: python/playergui.py:1900 python/playergui.py:4269
 msgid "Cue Up"
 msgstr "Accoda"
 
-#: python/playergui.py:1843 python/playergui.py:4190
+#: python/playergui.py:1901 python/playergui.py:4273
 msgid "Fade Over"
 msgstr "Dissolvenza in uscita"
 
-#: python/playergui.py:1855 python/playergui.py:1926 python/playergui.py:4184
+#: python/playergui.py:1913 python/playergui.py:1984 python/playergui.py:4267
 msgid "Random"
 msgstr "Casuale"
 
-#: python/playergui.py:1895 python/playergui.py:4187
+#: python/playergui.py:1953 python/playergui.py:4270
 msgid "External"
 msgstr "Esterna"
 
-#: python/playergui.py:1907 python/playergui.py:1923 python/playergui.py:4189
+#: python/playergui.py:1965 python/playergui.py:1981 python/playergui.py:4272
 msgid "Alternate"
 msgstr "Alterna"
 
-#: python/playergui.py:1907 python/playergui.py:1925 python/playergui.py:4191
+#: python/playergui.py:1965 python/playergui.py:1983 python/playergui.py:4274
 msgid "Random Hop"
 msgstr "Salto casuale"
 
 #. TC: The remaining playlist time.
-#: python/playergui.py:2080 python/playergui.py:2086
+#: python/playergui.py:2138 python/playergui.py:2144
 msgid "Remaining"
 msgstr "Restante"
 
 #. TC: The estimated finish time of the playlist.
 #. TC: The estimated finish time of the playlist (ETA).
-#: python/playergui.py:2082 python/playergui.py:2086 python/playergui.py:2100
+#: python/playergui.py:2140 python/playergui.py:2144 python/playergui.py:2158
 msgid "Finish"
 msgstr "Fine"
 
 #. TC: The play duration of the block of audio tracks.
-#: python/playergui.py:2087 python/playergui.py:2098
+#: python/playergui.py:2145 python/playergui.py:2156
 msgid "Block size"
 msgstr "Dimensione blocco"
 
 #. TC: File dialog title text.
-#: python/playergui.py:2485
+#: python/playergui.py:2546
 msgid "Add music to left playlist"
 msgstr "Aggiungi musica alla playlist di sinistra"
 
 #. TC: File dialog title text.
-#: python/playergui.py:2488
+#: python/playergui.py:2549
 msgid "Add music to right playlist"
 msgstr "Aggiungi musica alla playlist di destra"
 
-#: python/playergui.py:2490
+#: python/playergui.py:2551
 msgid "Add background music"
 msgstr ""
 
 #. TC: File filter text.
-#: python/playergui.py:2502
+#: python/playergui.py:2563
 msgid "Supported Media Formats"
 msgstr "Formati di media supportati"
 
 #. TC: Expander text "Select File Type (.pls)" for the pls file type.
-#: python/playergui.py:2564
+#: python/playergui.py:2625
 msgid "Select File Type"
 msgstr "Seleziona il tipo di file"
 
-#: python/playergui.py:3308
+#: python/playergui.py:3383
 msgid "Save left playlist"
 msgstr "Salva la playlist di sinistra"
 
-#: python/playergui.py:3310
+#: python/playergui.py:3385
 msgid "Save right playlist"
 msgstr "Salva la playlist di destra"
 
-#: python/playergui.py:3312
+#: python/playergui.py:3387
 #, fuzzy
 msgid "Save background playlist"
 msgstr "Salva la playlist di destra"
 
-#: python/playergui.py:3330
+#: python/playergui.py:3405
 msgid "File Type"
 msgstr "Tipo file"
 
-#: python/playergui.py:3335
+#: python/playergui.py:3410
 msgid "Extension"
 msgstr "Estensione"
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to do a ten second fade to the next track.
-#: python/playergui.py:3693 python/playergui.py:4358
+#: python/playergui.py:3774 python/playergui.py:4441
 msgid "Fade 10s"
 msgstr "Dissolvi 10sec"
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to do a five second fade to the next track.
-#: python/playergui.py:3699 python/playergui.py:4365
+#: python/playergui.py:3780 python/playergui.py:4448
 msgid "Fade 5s"
 msgstr "Dissolvi 5sec"
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to not do a fade to the next track.
-#: python/playergui.py:3704 python/playergui.py:4372
+#: python/playergui.py:3785 python/playergui.py:4455
 msgid "No Fade"
 msgstr "Nessun dissolvenza"
 
 #. TC: Playlist control.
-#: python/playergui.py:3714
+#: python/playergui.py:3793
 msgid ">> Normal Speed <<"
 msgstr ">> Velocità normale <<"
 
 #. TC: Playlist control.
-#: python/playergui.py:3724
+#: python/playergui.py:3803
 msgid "Player stop 2"
 msgstr "Lettore ferma 2"
 
 #. TC: Playlist control.
 #. TC: Insert playlist control to jump to the top of the playlist.
-#: python/playergui.py:3729 python/playergui.py:4324
+#: python/playergui.py:3808 python/playergui.py:4407
 msgid "Jump To Top"
 msgstr "Passa all'inizio"
 
 #. TC: Playlist control.
-#: python/playergui.py:3734 python/playergui.py:4384
+#: python/playergui.py:3813 python/playergui.py:4467
 msgid "Stop streaming"
 msgstr "Interrompi il flusso"
 
 #. TC: Playlist control.
-#: python/playergui.py:3739 python/playergui.py:4392
+#: python/playergui.py:3818 python/playergui.py:4475
 msgid "Stop recording"
 msgstr "Interrompi la registrazione"
 
+#: python/playergui.py:3851
+#, fuzzy
+msgid "Announcement:"
+msgstr "Avviso"
+
 #. TC: Playlist control.
-#: python/playergui.py:3774
+#: python/playergui.py:3857
 msgid ">>> Transfer across >>>"
 msgstr ">>> Trasferisci tra >>>"
 
 #. TC: Playlist control.
-#: python/playergui.py:3777
+#: python/playergui.py:3860
 msgid "<<< Transfer across <<<"
 msgstr "<<< Trasferisci tra <<<"
 
 #. TC: Playlist control.
-#: python/playergui.py:3782
+#: python/playergui.py:3865
 msgid ">>> Fade across >>>"
 msgstr ">>> Dissolvi tra >>>"
 
 #. TC: Playlist control.
-#: python/playergui.py:3785
+#: python/playergui.py:3868
 msgid "<<< Fade across <<<"
 msgstr "<<< Dissolvi tra <<<"
 
 #. TC: Playlist control.
-#: python/playergui.py:3791
+#: python/playergui.py:3874
 msgid "Ignored playlist control"
 msgstr "Controlli playlist ignorati"
 
-#: python/playergui.py:3859
+#: python/playergui.py:3942
+#, python-brace-format
 msgid "Playing track {0} of {1}"
 msgstr "Riproduzione traccia {0} di {1}"
 
 #. TC: Previous line: Playing track {0} of {1}
-#: python/playergui.py:3872
+#: python/playergui.py:3955
 #, python-format
 msgid "From the album, %s"
 msgstr "Dall'album, %s"
 
-#: python/playergui.py:3879
+#: python/playergui.py:3962
 #, python-format
 msgid "Total number of tracks %d"
 msgstr "Numero totale di tracce %d"
 
-#: python/playergui.py:3883 python/playergui.py:3885
+#: python/playergui.py:3966 python/playergui.py:3968
 #, python-format
 msgid "Total play duration %s"
 msgstr "Durata totale %s"
 
-#: python/playergui.py:3935
+#: python/playergui.py:4018
 msgid ""
 "Left click toggles between showing the amount of time elapsed or remaining "
 "on the current track being played."
@@ -2612,7 +2687,7 @@ msgstr ""
 "Il click sinistro cambia dal mostrare il tempo trascorso o restante della "
 "traccia in esecuzione."
 
-#: python/playergui.py:3953
+#: python/playergui.py:4036
 msgid ""
 "This slider acts as both a play progress indicator and as a means for "
 "seeking within the currently playing track."
@@ -2621,15 +2696,16 @@ msgstr ""
 "strumento per spostarsi nella traccia attualmente in esecuzione."
 
 #. TC: File filter text.
-#: python/playergui.py:4042
+#: python/playergui.py:4125
 msgid "All file types"
 msgstr "Tutti i tipi di file"
 
-#: python/playergui.py:4047
-msgid "Playlist types (*.m3u, *.xspf, *.pls)"
-msgstr "Tipi di playlist (*.m3u, *.xspf, *.pls)"
+#: python/playergui.py:4130
+#, fuzzy
+msgid "Playlist types"
+msgstr "Playlist 1"
 
-#: python/playergui.py:4062
+#: python/playergui.py:4145
 msgid ""
 "'Block size' indicates the amount of time that it will take to play from the "
 "currently selected track to the next stop.\n"
@@ -2641,43 +2717,43 @@ msgstr ""
 "'Restante' è il tempo fino al prossimo stop.\n"
 "'Fine' è il tempo calcolato quando finirà la riproduzione delle tracce."
 
-#: python/playergui.py:4085
+#: python/playergui.py:4168
 msgid "This adjusts the playback speed anywhere from 25% to 400%."
 msgstr "Regola la velocità di riproduzione tra il 25% ed il 400%."
 
-#: python/playergui.py:4099
+#: python/playergui.py:4182
 msgid "This sets the playback speed back to normal."
 msgstr "Reimposta la normale velocità di riproduzione "
 
-#: python/playergui.py:4116
+#: python/playergui.py:4199
 msgid "Previous track."
 msgstr "Traccia precedente"
 
-#: python/playergui.py:4128
+#: python/playergui.py:4211
 msgid "Play."
 msgstr "Riproduci"
 
-#: python/playergui.py:4138
+#: python/playergui.py:4221
 msgid "Pause."
 msgstr "Pausa"
 
-#: python/playergui.py:4148
+#: python/playergui.py:4231
 msgid "Stop."
 msgstr "Ferma"
 
-#: python/playergui.py:4158
+#: python/playergui.py:4241
 msgid "Next track."
 msgstr "Traccia successiva"
 
-#: python/playergui.py:4170
+#: python/playergui.py:4253
 msgid "Add tracks to the playlist."
 msgstr "Aggiungi tracce alla playlist"
 
-#: python/playergui.py:4177 python/preferences.py:70
+#: python/playergui.py:4260 python/preferences.py:71
 msgid "Playlist Mode"
 msgstr "Modalità playlist"
 
-#: python/playergui.py:4196
+#: python/playergui.py:4279
 msgid ""
 "This sets the playlist mode which defines player behaviour after a track has "
 "finished playing.\n"
@@ -2739,31 +2815,31 @@ msgstr ""
 "'Salto casuale' sceglierà una traccia a caso dall'altra playlist."
 
 #. TC: Fade time heading.
-#: python/playergui.py:4220 python/preferences.py:71
+#: python/playergui.py:4303 python/preferences.py:72
 msgid "Fade"
 msgstr "Dissolvenza"
 
-#: python/playergui.py:4232
+#: python/playergui.py:4315
 msgid "This controls the amount of fade between tracks."
 msgstr "Controlla il tempo di dissolvenza tra tracce"
 
-#: python/playergui.py:4239
+#: python/playergui.py:4322
 msgid "Audio Feed"
 msgstr "Audio Feed"
 
-#: python/playergui.py:4249
+#: python/playergui.py:4332
 msgid "Make output from this player available for streaming."
 msgstr "Manda in onda l'audio di questo lettore"
 
-#: python/playergui.py:4257
+#: python/playergui.py:4340
 msgid "Make output from this player audible to the DJ."
 msgstr "Rende l'uscita di questo lettore udibile dal DJ"
 
-#: python/playergui.py:4259
+#: python/playergui.py:4342
 msgid "Force"
 msgstr ""
 
-#: python/playergui.py:4265
+#: python/playergui.py:4348
 msgid ""
 "When selected this player will be treated like a main player.\n"
 "It will be affected by microphone ducking and won't mute when a main player "
@@ -2771,142 +2847,142 @@ msgid ""
 msgstr ""
 
 #. TC: Insert playlist control.
-#: python/playergui.py:4278
+#: python/playergui.py:4361
 msgid "Insert control"
 msgstr "Inserisci controllo"
 
 #. TC: The Item submenu.
-#: python/playergui.py:4287
+#: python/playergui.py:4370
 msgid "Item"
 msgstr "Elemento"
 
 #. TC: The Playlist submenu.
-#: python/playergui.py:4292
+#: python/playergui.py:4375
 msgid "Playlist"
 msgstr "Playlist"
 
 #. TC: Insert playlist control to set playback speed to normal.
-#: python/playergui.py:4303
+#: python/playergui.py:4386
 msgid "Normal Speed"
 msgstr "Velocità normale"
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4332 python/playergui.py:4486
+#: python/playergui.py:4415 python/playergui.py:4569
 msgid "Transfer"
 msgstr "Trasferisci"
 
-#: python/playergui.py:4340
+#: python/playergui.py:4423
 msgid "Crossfade"
 msgstr "Dissolvi"
 
 #. TC: Menu item. Opens the metadata tagger on the selected track.
-#: python/playergui.py:4405
+#: python/playergui.py:4488
 msgid "Meta Tag"
 msgstr "Meta Tag"
 
 #. TC: Menu Item. Duplicates the selected track in the playlist.
-#: python/playergui.py:4411
+#: python/playergui.py:4494
 msgid "Duplicate"
 msgstr "Duplica"
 
 #. TC: Menu Item. Remove the selected track.
-#: python/playergui.py:4418
+#: python/playergui.py:4501
 msgid "Remove"
 msgstr "Rimuovi"
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4429
+#: python/playergui.py:4512
 msgid "This"
 msgstr "Questo"
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4436 python/preferences.py:1234
+#: python/playergui.py:4519 python/preferences.py:1237
 msgid "All"
 msgstr "Tutto"
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4443
+#: python/playergui.py:4526
 msgid "From Here"
 msgstr "Da qui"
 
 #. TC: Submenu Item. Parent menu item is Remove.
-#: python/playergui.py:4450
+#: python/playergui.py:4533
 msgid "To Here"
 msgstr "Fino a qui"
 
 #. TC: Open the file dialog for adding music to the chosen playlist.
-#: python/playergui.py:4463
+#: python/playergui.py:4546
 msgid "Add Music"
 msgstr "Aggiungi musica"
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4470
+#: python/playergui.py:4553
 msgid "Save"
 msgstr "Salva"
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4481
+#: python/playergui.py:4564
 msgid "Copy"
 msgstr "Copia"
 
-#: python/playergui.py:4492
+#: python/playergui.py:4575
 msgid "Exchange"
 msgstr "Scambia"
 
 #. TC: Submenu Item. Parent menu is Playlist.
-#: python/playergui.py:4499
+#: python/playergui.py:4582
 msgid "Empty"
 msgstr "Vuoto"
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4513 python/playergui.py:4552
+#: python/playergui.py:4596 python/playergui.py:4635
 msgid "Append"
 msgstr "Appendi"
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4520 python/playergui.py:4559
+#: python/playergui.py:4603 python/playergui.py:4642
 msgid "Prepend"
 msgstr "Prependi"
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
-#: python/playergui.py:4531
+#: python/playergui.py:4614
 msgid "Append Cursor"
 msgstr "Accoda dal cursore"
 
 #. TC: Submenu Item. Parent menus are Playlist->Copy.
-#: python/playergui.py:4538
+#: python/playergui.py:4621
 msgid "Prepend Cursor"
 msgstr "Prependi dal cursore"
 
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4570
+#: python/playergui.py:4653
 msgid "Append at Cursor"
 msgstr "Accoda dal cursore"
 
 #. TC: Submenu Item. Parent menus are Playlist->Transfer.
-#: python/playergui.py:4577
+#: python/playergui.py:4660
 msgid "Prepend at Cursor"
 msgstr "Prependi dal cursore"
 
-#: python/preferences.py:84
+#: python/preferences.py:85
 msgid "Track time elapsed"
 msgstr "Tempo trascorso"
 
-#: python/preferences.py:86
+#: python/preferences.py:87
 msgid "Track time remaining"
 msgstr "Tempo restante"
 
-#: python/preferences.py:88
+#: python/preferences.py:89
 msgid "Audio to stream"
 msgstr "Audio al flusso"
 
-#: python/preferences.py:89
+#: python/preferences.py:90
 msgid "Audio to DJ"
 msgstr "Audio al DJ"
 
-#: python/preferences.py:126
+#: python/preferences.py:127
 #, fuzzy, python-format
 msgid ""
 "Stereo panning is the selection of where an audio source sits from left to "
@@ -2930,12 +3006,12 @@ msgstr ""
 "Se volete i 0dB di potenza anche nel punto di mezzo allora dovrete "
 "disattivare questa opzione."
 
-#: python/preferences.py:157
+#: python/preferences.py:158
 #, fuzzy
 msgid "Presets"
 msgstr "Premuto"
 
-#: python/preferences.py:248
+#: python/preferences.py:249
 msgid ""
 "The pan preset selection buttons.\n"
 "\n"
@@ -2946,42 +3022,42 @@ msgid ""
 msgstr ""
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:273
+#: python/preferences.py:274
 msgid "Deactivated"
 msgstr "Disattivato"
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:275
+#: python/preferences.py:276
 msgid "Basic input"
 msgstr "Ingresso semplice"
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:277
+#: python/preferences.py:278
 msgid "Processed input"
 msgstr "Ingresso elaborato"
 
 #. TC: Microphone mode combobox text.
-#: python/preferences.py:279
+#: python/preferences.py:280
 #, python-format
 msgid "Partnered with channel %s"
 msgstr "Abbinato al canale %s"
 
-#: python/preferences.py:429
+#: python/preferences.py:432
 msgid "A label so you may describe briefly the role of this audio channel."
 msgstr ""
 "Un'etichetta per descrivere in modo sintetico il ruolo di questo canale "
 "audio."
 
-#: python/preferences.py:461
+#: python/preferences.py:464
 msgid "The signal processing mode."
 msgstr "La modalità di elaborazione del segnale"
 
 #. TC: A frame heading. The channel opener is selected within.
-#: python/preferences.py:465
+#: python/preferences.py:468
 msgid "Channel Opener"
 msgstr "Gestore canale"
 
-#: python/preferences.py:468
+#: python/preferences.py:471
 msgid ""
 "This controls the allocation of front panel open/unmute buttons. Having one "
 "button control multiple microphones can save time."
@@ -2990,28 +3066,28 @@ msgstr ""
 "pulsante che controlla più microfoni può far risparmiare del tempo."
 
 #. TC: Spinbutton label text.
-#: python/preferences.py:475
+#: python/preferences.py:478
 msgid "Main Panel Button"
 msgstr "Pulsante del pannello principale"
 
-#: python/preferences.py:492
+#: python/preferences.py:495
 msgid "This:"
 msgstr "Questo:"
 
-#: python/preferences.py:501
+#: python/preferences.py:504
 msgid "Open"
 msgstr "Apri"
 
-#: python/preferences.py:514
+#: python/preferences.py:517
 msgid "Stereo Panning"
 msgstr "Panorama Stereo"
 
 #. TC: A set of controls that perform audio signal matching.
-#: python/preferences.py:527
+#: python/preferences.py:530
 msgid "Signal Matching"
 msgstr "Corrispondenza segnale"
 
-#: python/preferences.py:528
+#: python/preferences.py:531
 msgid ""
 "These controls are provided to obtain a decent match between the two "
 "microphones."
@@ -3019,17 +3095,17 @@ msgstr ""
 "Questi controlli servono per ottenere una corrispondenza decente tra "
 "microfoni."
 
-#: python/preferences.py:537
+#: python/preferences.py:540
 msgid "Relative Gain (dB)"
 msgstr "Guadagno relativo (dB)"
 
 #. TC: Mic audio phase inversion control.
-#: python/preferences.py:542 python/preferences.py:547
+#: python/preferences.py:545 python/preferences.py:550
 msgid "Invert Signal"
 msgstr "Inverti il segnale"
 
-#: python/preferences.py:548 python/preferences.py:568
-#: python/preferences.py:664
+#: python/preferences.py:551 python/preferences.py:571
+#: python/preferences.py:667
 msgid ""
 "Useful for when microphones are cancelling one another out, producing a "
 "hollow sound."
@@ -3038,12 +3114,12 @@ msgstr ""
 "ovattato."
 
 #. TC: Control whether to mix microphone audio to the DJ mix.
-#: python/preferences.py:551
+#: python/preferences.py:554
 msgid "In The DJ's Mix"
 msgstr "Invia al mix del DJ"
 
-#: python/preferences.py:552 python/preferences.py:574
-#: python/preferences.py:674
+#: python/preferences.py:555 python/preferences.py:577
+#: python/preferences.py:677
 msgid ""
 "Make the microphone audio audible in the DJ mix. This may not always be "
 "desirable."
@@ -3051,29 +3127,29 @@ msgstr ""
 "Fa in modo che l'audio del microfono sia udibile nel mix del DJ. Non sempre "
 "è desiderabile."
 
-#: python/preferences.py:560
+#: python/preferences.py:563
 msgid "Basic Controls"
 msgstr "Controlli base"
 
-#: python/preferences.py:561 python/preferences.py:616
+#: python/preferences.py:564 python/preferences.py:619
 msgid "Boost/Cut (dB)"
 msgstr "Aumenta/Taglia (dB)"
 
-#: python/preferences.py:582
+#: python/preferences.py:585
 msgid "High Pass Filter"
 msgstr "Filtro passa alto"
 
-#: python/preferences.py:583 python/preferences.py:598
-#: python/preferences.py:608
+#: python/preferences.py:586 python/preferences.py:601
+#: python/preferences.py:611
 msgid "Cutoff Frequency"
 msgstr "Frequenza di taglio"
 
 #. TC: User can set the number of filter stages.
-#: python/preferences.py:587
+#: python/preferences.py:590
 msgid "Stages"
 msgstr "Livelli"
 
-#: python/preferences.py:590
+#: python/preferences.py:593
 msgid ""
 "Frequency in Hertz above which audio can pass to later stages. Use this "
 "feature to restrict low frequency sounds such as mains hum. Setting too high "
@@ -3085,55 +3161,55 @@ msgstr ""
 "suono della voce 'sottile'"
 
 #. TC: this is the treble control. HF = high frequency.
-#: python/preferences.py:595
+#: python/preferences.py:598
 msgid "HF Detail"
 msgstr "Dettaglio HF"
 
-#: python/preferences.py:602
+#: python/preferences.py:605
 msgid "You can use this to boost the amount of treble in the audio."
 msgstr "Potete usarlo per aumentare la quantità di alte frequenze nell'audio."
 
 #. TC: this is the bass control. LF = low frequency.
-#: python/preferences.py:605
+#: python/preferences.py:608
 msgid "LF Detail"
 msgstr "Dettagli LF"
 
-#: python/preferences.py:612
+#: python/preferences.py:615
 msgid "You can use this to boost the amount of bass in the audio."
 msgstr "Potete usarlo per aumentare la quantità di basse frequenze nell'audio."
 
 #. TC: lookahead brick wall limiter.
-#: python/preferences.py:615
+#: python/preferences.py:618
 msgid "Limiter"
 msgstr "Limiter"
 
 #. TC: this is the peak signal limit.
-#: python/preferences.py:620
+#: python/preferences.py:623
 msgid "Upper Limit"
 msgstr "Limite superiore"
 
-#: python/preferences.py:622
+#: python/preferences.py:625
 msgid ""
 "A look-ahead brick-wall limiter. Audio signals are capped at the upper limit."
 msgstr ""
 "Un limiter predittivo. I segnali audio vengono bloccati al limite superiore"
 
-#: python/preferences.py:625
+#: python/preferences.py:628
 msgid "Noise Gate"
 msgstr "Noise Gate"
 
 #. TC: noise gate triggers at this level.
-#: python/preferences.py:627
+#: python/preferences.py:630
 msgid "Threshold"
 msgstr "Soglia"
 
 #. TC: negative gain when the noise gate is active.
 #. TC: The de-esser attenuation in ess-detected state.
-#: python/preferences.py:631 python/preferences.py:641
+#: python/preferences.py:634 python/preferences.py:644
 msgid "Gain"
 msgstr "Guadagno"
 
-#: python/preferences.py:633
+#: python/preferences.py:636
 msgid ""
 "Reduce the unwanted quietest sounds and background noise which you don't "
 "want your listeners to hear with this."
@@ -3141,16 +3217,16 @@ msgstr ""
 "Riduce i suoni sommessi indesiderati ed il rumore di fondo che non volete "
 "venga udito dagli ascoltatori."
 
-#: python/preferences.py:636
+#: python/preferences.py:639
 msgid "De-esser"
 msgstr "De-esser"
 
 #. TC: Bias has a numeric setting.
-#: python/preferences.py:638
+#: python/preferences.py:641
 msgid "Bias"
 msgstr "Bias"
 
-#: python/preferences.py:643
+#: python/preferences.py:646
 msgid ""
 "Reduce the S, T, and P sounds which microphones tend to exaggerate. Ideally "
 "the Bias control will be set low so that the de-esser is off when there is "
@@ -3161,19 +3237,19 @@ msgstr ""
 "spento nei momenti di silenzio ma sia sufficentemente alto da non rendere "
 "udibili i click del mouse."
 
-#: python/preferences.py:648
+#: python/preferences.py:651
 msgid "Ducker"
 msgstr "Ducker"
 
-#: python/preferences.py:649
+#: python/preferences.py:652
 msgid "Release"
 msgstr "Rilascio"
 
-#: python/preferences.py:652
+#: python/preferences.py:655
 msgid "Hold"
 msgstr "Tenuta"
 
-#: python/preferences.py:655
+#: python/preferences.py:658
 msgid ""
 "The ducker automatically reduces the level of player audio when the DJ "
 "speaks. These settings allow you to adjust the timings of that audio "
@@ -3183,15 +3259,15 @@ msgstr ""
 "Queste impostazioni ti consentono di regolare la tempistica della riduzione "
 "dell'audio."
 
-#: python/preferences.py:659
+#: python/preferences.py:662
 msgid "Other options"
 msgstr "Altre opzioni"
 
-#: python/preferences.py:666
+#: python/preferences.py:669
 msgid "Phase Rotator"
 msgstr "Rotatore di fase"
 
-#: python/preferences.py:669
+#: python/preferences.py:672
 msgid ""
 "This feature processes the microphone audio so that it sounds more even. The "
 "effect is particularly noticable on male voices."
@@ -3199,34 +3275,34 @@ msgstr ""
 "Questa funzionalità elabora l'audio del microfono in modo di renderlo più "
 "costante. L'effetto è particolarmente distinguibile sulle voci maschili."
 
-#: python/preferences.py:852
+#: python/preferences.py:855
 msgid "The volume control for the left music player."
 msgstr "Il controllo del volume per il lettore di sinistra"
 
 #. TC: preferences window title.
-#: python/preferences.py:908
+#: python/preferences.py:911
 msgid "IDJC Preferences"
 msgstr "Preferenze IDJC"
 
 #. TC: The DJ's sound level controller.
-#: python/preferences.py:933
+#: python/preferences.py:936
 msgid "DJ Audio Level"
 msgstr "Livello audio DJ"
 
-#: python/preferences.py:945
+#: python/preferences.py:948
 msgid "This adjusts the sound level of the DJ audio."
 msgstr "Regola il livello dell'audio del DJ"
 
 #. TC: The alarm sound level.
-#: python/preferences.py:950
+#: python/preferences.py:953
 msgid "Alarm Level"
 msgstr ""
 
-#: python/preferences.py:964
+#: python/preferences.py:967
 msgid "Music Loudness Compensation"
 msgstr ""
 
-#: python/preferences.py:962
+#: python/preferences.py:965
 #, python-format
 msgid ""
 "This adjusts the sound level of the DJ alarm. Typically this should be set "
@@ -3234,11 +3310,11 @@ msgid ""
 "louder."
 msgstr ""
 
-#: python/preferences.py:970
+#: python/preferences.py:973
 msgid "Player Resample Quality"
 msgstr "Qualità di ricampionamento del lettore"
 
-#: python/preferences.py:976
+#: python/preferences.py:979
 #, fuzzy
 msgid ""
 "This adjusts the quality of the audio resampling method used whenever the "
@@ -3253,50 +3329,50 @@ msgstr ""
 "più CPU (non consigliato per sistemi antecedenti al 2006). Benché utilizzi "
 "meno CPU la modalità 'Più veloce' dovrebbe essere evitata del tutto."
 
-#: python/preferences.py:984
+#: python/preferences.py:987
 msgid "Best"
 msgstr ""
 
-#: python/preferences.py:993
+#: python/preferences.py:996 python/format.py:512
 msgid "Medium"
 msgstr ""
 
-#: python/preferences.py:1002
+#: python/preferences.py:1005
 msgid "Fast"
 msgstr "Veloce"
 
 #. TC: the set of features - section heading.
-#: python/preferences.py:1017
+#: python/preferences.py:1020
 msgid "Feature Set"
 msgstr "Impostazioni funzionalità"
 
 #. TC: Start in the full featured user interface mode.
-#: python/preferences.py:1029
+#: python/preferences.py:1032
 msgid "Start Full"
 msgstr "Avvia completo"
 
-#: python/preferences.py:1034 python/preferences.py:1042
+#: python/preferences.py:1037 python/preferences.py:1045
 msgid "Indicates which mode IDJC will be in when launched."
 msgstr "Indica con quale modalità verrà avviato IDJC"
 
 #. TC: Start in a reduced user interface mode.
-#: python/preferences.py:1037
+#: python/preferences.py:1040
 msgid "Start Mini"
 msgstr "Avvia minimale"
 
-#: python/preferences.py:1050
+#: python/preferences.py:1053
 msgid "Fully Featured"
 msgstr "Tutte le funzionalità"
 
-#: python/preferences.py:1055
+#: python/preferences.py:1058
 msgid "Run in full functionality mode which uses more CPU power."
 msgstr "Avvia con tutte le funzionalità, consuma più CPU"
 
-#: python/preferences.py:1057
+#: python/preferences.py:1060
 msgid "Basic Streamer"
 msgstr "Trasmettitore base"
 
-#: python/preferences.py:1061
+#: python/preferences.py:1064
 msgid ""
 "Run in a reduced functionality mode that lowers the burden on the CPU and "
 "takes up less screen space."
@@ -3304,99 +3380,99 @@ msgstr ""
 "Avvia con funzionalità ridotte, diminuisce il carico sulla CPU e occupa meno "
 "spazio sullo schermo."
 
-#: python/preferences.py:1069
+#: python/preferences.py:1072
 msgid "These settings take effect after restarting"
 msgstr "Queste impostazioni avranno effetto dopo il riavvio."
 
-#: python/preferences.py:1090
+#: python/preferences.py:1093
 msgid "Reserve 24 sound effects slots"
 msgstr ""
 
-#: python/preferences.py:1091
+#: python/preferences.py:1094
 msgid "Only 12"
 msgstr ""
 
-#: python/preferences.py:1103
+#: python/preferences.py:1106
 msgid "Audio input channels"
 msgstr ""
 
-#: python/preferences.py:1108
+#: python/preferences.py:1111
 msgid "Simultaneous stream(s)"
 msgstr "Trasmissione(i) in simultanea"
 
-#: python/preferences.py:1114
+#: python/preferences.py:1117
 msgid "Simultaneous recording(s)"
 msgstr "Registrazione(i) in simultanea"
 
-#: python/preferences.py:1168
+#: python/preferences.py:1171
 msgid "Fill channel meter void space"
 msgstr "Riempi il vuoto dell'indicatore per il canale"
 
-#: python/preferences.py:1180
+#: python/preferences.py:1183
 msgid "Player Loudness Normalisation"
 msgstr ""
 
-#: python/preferences.py:1191
+#: python/preferences.py:1194
 #, fuzzy
 msgid "Indicate which tracks have loudness metadata"
 msgstr "Indica quali tracce hanno il ReplayGain"
 
-#: python/preferences.py:1192
+#: python/preferences.py:1195
 #, fuzzy
 msgid ""
 "Shows a marker in the playlists next to each track. Either a green circle or "
 "a red triangle."
 msgstr "Mostra un segno accanto ad ogni traccia nella playlist"
 
-#: python/preferences.py:1200
+#: python/preferences.py:1203
 #, fuzzy
 msgid "Adjust playback volume in dB"
 msgstr "Regola il volume di riproduzione"
 
-#: python/preferences.py:1201
+#: python/preferences.py:1204
 msgid "Effective only on newly started tracks."
 msgstr "Efficace solo sulle tracce avviate ex-novo "
 
-#: python/preferences.py:1207
+#: python/preferences.py:1210
 msgid "R128"
 msgstr ""
 
-#: python/preferences.py:1211
+#: python/preferences.py:1214
 msgid ""
 "It may not be desirable to use the default level since it is rather quiet. "
 "This should be set 4 or 5 dB higher than the ReplayGain setting."
 msgstr ""
 
-#: python/preferences.py:1216
+#: python/preferences.py:1219
 msgid "ReplayGain"
 msgstr "ReplayGain"
 
-#: python/preferences.py:1220
+#: python/preferences.py:1223
 msgid ""
 "It may not be desirable to use the default level since it is rather quiet. "
 "This should be set 4 or 5 dB lower than the R128 setting."
 msgstr ""
 
-#: python/preferences.py:1225
+#: python/preferences.py:1228
 msgid "Untagged"
 msgstr ""
 
-#: python/preferences.py:1229
+#: python/preferences.py:1232
 msgid ""
 "Set this so that any unmarked tracks are playing at a roughly similar "
 "loudness level as the marked ones."
 msgstr ""
 
-#: python/preferences.py:1238
+#: python/preferences.py:1241
 #, fuzzy
 msgid "A master level control for the media players."
 msgstr "Il controllo del volume per il lettore di sinistra"
 
-#: python/preferences.py:1249
+#: python/preferences.py:1252
 msgid "Recorder Filename (excluding the file extension)"
 msgstr ""
 
-#: python/preferences.py:1250
+#: python/preferences.py:1253
 msgid ""
 "The specifiers are $r for the number of the recorder with the rest being "
 "documented in the strftime man page.\n"
@@ -3404,24 +3480,24 @@ msgid ""
 "particular filesystems."
 msgstr ""
 
-#: python/preferences.py:1267
+#: python/preferences.py:1270
 msgid "Miscellaneous Features"
 msgstr "Impostazioni varie"
 
-#: python/preferences.py:1276
+#: python/preferences.py:1279
 msgid "Trim quiet song endings and trailing silence"
 msgstr "Elimina i finali sommessi ed il silenzio iniziale delle canzoni"
 
-#: python/preferences.py:1282
+#: python/preferences.py:1285
 msgid "End tracks containing long passages of silence"
 msgstr "Interrompi tracce che contengono lunghi passaggi di silenzio"
 
-#: python/preferences.py:1288
+#: python/preferences.py:1291
 msgid "Enable the main-player speed/pitch controls"
 msgstr ""
 "Abilita il controllo di velocità di riproduzione sul lettore principale"
 
-#: python/preferences.py:1292
+#: python/preferences.py:1295
 msgid ""
 "This option causes some extra widgets to appear below the playlists which "
 "allow the playback speed to be adjusted from 25% to 400% and a normal speed "
@@ -3431,11 +3507,11 @@ msgstr ""
 "regolare la velocità di riproduzione tra il 25% ed il 400% e un pulsante per "
 "la velocità normale."
 
-#: python/preferences.py:1297
+#: python/preferences.py:1300
 msgid "Separate left/right player volume faders"
 msgstr "Cursori del volume separati per i lettori destro/sinistro"
 
-#: python/preferences.py:1301
+#: python/preferences.py:1304
 msgid ""
 "Select this option to use an independent volume fader for the left and right "
 "music players."
@@ -3443,11 +3519,11 @@ msgstr ""
 "Selezionare questa opzione per usare un cursore indipendente per il lettore "
 "di destra e sinistra."
 
-#: python/preferences.py:1305
+#: python/preferences.py:1308
 msgid "Enlarge the time elapsed/remaining windows"
 msgstr "Allarga la finestra del tempo trascorso/restante"
 
-#: python/preferences.py:1309
+#: python/preferences.py:1312
 msgid ""
 "The time elapsed/remaining windows sometimes don't appear big enough for the "
 "text that appears in them due to unusual DPI settings or the use of a "
@@ -3457,11 +3533,11 @@ msgstr ""
 "abbastanza a causa di impostazioni anomale dei DPI o per l'utilizzo di "
 "motori di rendering diversi. Questa opzione sistema le cose."
 
-#: python/preferences.py:1315
+#: python/preferences.py:1318
 msgid "Sound an alarm when the music is due to end"
 msgstr "Avviso sonoro quando la musica si avvicina alla fine"
 
-#: python/preferences.py:1318
+#: python/preferences.py:1321
 #, fuzzy
 msgid ""
 "An alarm tone alerting the DJ that dead-air is just nine seconds away. This "
@@ -3474,12 +3550,12 @@ msgstr ""
 "Funziona anche in fase di monitoraggio del flusso ma il suono di allarme non "
 "viene mandato in onda."
 
-#: python/preferences.py:1328
+#: python/preferences.py:1331
 #, fuzzy
 msgid "Apply dither to 16 bit PCM playback"
 msgstr "Applica il dither alla riproduzione MP3 e FLAC"
 
-#: python/preferences.py:1332
+#: python/preferences.py:1335
 msgid ""
 "This feature maybe improves the sound quality a little when listening on a "
 "24 bit sound card."
@@ -3487,11 +3563,11 @@ msgstr ""
 "Questa impostazione potrebbe migliorare la qualità del suondo su schede "
 "audio a 24bit"
 
-#: python/preferences.py:1335
+#: python/preferences.py:1338
 msgid "Enable tooltips"
 msgstr "Abilita suggerimenti"
 
-#: python/preferences.py:1339
+#: python/preferences.py:1342
 msgid ""
 "This, what you are currently reading, is a tooltip. This feature turns them "
 "on or off."
@@ -3499,15 +3575,15 @@ msgstr ""
 "Questo che state leggendo adesso è un suggerimento. Questa opzione li "
 "abilita o meno."
 
-#: python/preferences.py:1358
+#: python/preferences.py:1361
 msgid "Player Settings At Startup"
 msgstr "Impostazioni del lettore all'avvio"
 
-#: python/preferences.py:1369
+#: python/preferences.py:1372
 msgid "Restore the previous session"
 msgstr "Ripristina la sessione precedente"
 
-#: python/preferences.py:1374
+#: python/preferences.py:1377
 msgid ""
 "When starting IDJC most of the main window settings will be as they were "
 "left. As an alternative you may specify below how you want the various "
@@ -3517,107 +3593,111 @@ msgstr ""
 "saranno come le avete lasciate. In alternativa potete specificare qui sotto "
 "come volete trovare le varie impostazioni all'avvio di IDJC."
 
-#: python/preferences.py:1384
+#: python/preferences.py:1387
 msgid "Player 1"
 msgstr "Lettore 1"
 
-#: python/preferences.py:1386
+#: python/preferences.py:1389
 msgid "Player 2"
 msgstr "Lettore 2"
 
 #. TC: DJ hears the stream mix.
-#: python/preferences.py:1414
+#: python/preferences.py:1417
 msgid "Monitor Stream Mix"
 msgstr "Monitora il Flusso"
 
 #. TC: A heading label for miscellaneous settings.
-#: python/preferences.py:1425
+#: python/preferences.py:1428
 msgid "General"
 msgstr "Generale"
 
-#: python/preferences.py:1475
+#: python/preferences.py:1478
 msgid "VoIP panning + mono downmix"
 msgstr ""
 
 #. TC: Keyboard and MIDI bindings configuration.
-#: python/preferences.py:1489
+#: python/preferences.py:1492
 msgid "Bindings"
 msgstr "Scorciatoie"
 
-#: python/preferences.py:1537
+#: python/preferences.py:1540
 msgid "Licence"
 msgstr "Licenza"
 
-#: python/preferences.py:1560
+#: python/preferences.py:1563
 msgid "Contributors"
 msgstr "Collaboratori"
 
-#: python/preferences.py:1567
+#: python/preferences.py:1570
 msgid "Translators"
 msgstr "Traduttori"
 
-#: python/preferences.py:1573
+#: python/preferences.py:1574
+msgid "Build Info"
+msgstr ""
+
+#: python/preferences.py:1591
 msgid "About"
 msgstr "Circa"
 
-#: python/sourceclientgui.py:89
+#: python/sourceclientgui.py:91
 msgid "Insert Attribute"
 msgstr "Inserisci attributo"
 
-#: python/sourceclientgui.py:133
+#: python/sourceclientgui.py:135
 msgid "Icecast 2 Master"
 msgstr "Icecast 2 Master"
 
-#: python/sourceclientgui.py:133
+#: python/sourceclientgui.py:135
 msgid "Shoutcast Master"
 msgstr "Shoutcast Master"
 
-#: python/sourceclientgui.py:134
+#: python/sourceclientgui.py:136
 msgid "Icecast 2 Stats/Relay"
 msgstr "Icecast 2 Stats/Relay"
 
-#: python/sourceclientgui.py:134
+#: python/sourceclientgui.py:136
 msgid "Shoutcast Stats/Relay"
 msgstr "Icecast 2 Stats/Relay"
 
-#: python/sourceclientgui.py:137
+#: python/sourceclientgui.py:139
 msgid "Enter new server connection details"
 msgstr "Inserisci i dettagli della connessione al server"
 
-#: python/sourceclientgui.py:156
+#: python/sourceclientgui.py:158
 msgid "Edit existing server connection details"
 msgstr "Modifica i dettagli della connessione"
 
-#: python/sourceclientgui.py:193
+#: python/sourceclientgui.py:195
 msgid "This server is to be scanned for audience figures"
 msgstr "Da scansionare per il pubblico in ascolto"
 
-#: python/sourceclientgui.py:206
+#: python/sourceclientgui.py:208
 msgid "Server type"
 msgstr "Tipo server"
 
-#: python/sourceclientgui.py:206
+#: python/sourceclientgui.py:208
 msgid "Port number"
 msgstr "Numero porta"
 
-#: python/sourceclientgui.py:207
+#: python/sourceclientgui.py:209
 msgid "Mount point"
 msgstr "Punto di montaggio"
 
-#: python/sourceclientgui.py:207
+#: python/sourceclientgui.py:209
 msgid "Login name"
 msgstr "Nome utente"
 
-#: python/sourceclientgui.py:449
+#: python/sourceclientgui.py:475
 msgid "Encoder Format Not Set/Compatible"
 msgstr ""
 
 #. TC: Connection button text when no details have been entered.
-#: python/sourceclientgui.py:452
+#: python/sourceclientgui.py:478
 msgid "No Master Server Configured"
 msgstr "Nessun server principale configurato"
 
-#: python/sourceclientgui.py:654
+#: python/sourceclientgui.py:680
 msgid ""
 "A table of servers with which to connect. Only one master server can be "
 "added for the purpose of streaming. All other servers will appear below the "
@@ -3629,42 +3709,42 @@ msgstr ""
 "sotto il server principale nella lista allo scopo di raccogliere statistiche "
 "che possono essere attivate per ciascun server."
 
-#: python/sourceclientgui.py:670
+#: python/sourceclientgui.py:696
 msgid "Hostname/IP address"
 msgstr "Nomehost/Indirizzo IP"
 
 #. TC: Mount point is a technical term in relation to icecast servers.
-#: python/sourceclientgui.py:683
+#: python/sourceclientgui.py:709
 #, fuzzy
 msgid "Mount point       "
 msgstr "Punto di mount     "
 
 #. TC: This is the listener count heading.
-#: python/sourceclientgui.py:692
+#: python/sourceclientgui.py:718
 msgid "Listeners"
 msgstr "Ascoltatori"
 
-#: python/sourceclientgui.py:707
+#: python/sourceclientgui.py:733
 msgid "The sum total of listeners in this server tab."
 msgstr "Il totale degli ascoltatori per questo server"
 
-#: python/sourceclientgui.py:734
+#: python/sourceclientgui.py:760
 msgid "Never"
 msgstr "Mai"
 
-#: python/sourceclientgui.py:737
+#: python/sourceclientgui.py:763
 msgid "Always"
 msgstr "Sempre"
 
-#: python/sourceclientgui.py:739
+#: python/sourceclientgui.py:765
 msgid "If connected"
 msgstr "Se connesso"
 
-#: python/sourceclientgui.py:995
+#: python/sourceclientgui.py:1021
 msgid "Custom user agent string"
 msgstr "Stringa personalizzata per i navigatori"
 
-#: python/sourceclientgui.py:1002
+#: python/sourceclientgui.py:1028
 msgid ""
 "Set this on the occasion that the server or its firewall specifically "
 "refuses to allow libshout based clients."
@@ -3672,16 +3752,16 @@ msgstr ""
 "Impostare questa opzione nell'eventualità che il server o il suo firewall "
 "rifiutino esplicitamente connessioni da client che usano libshout."
 
-#: python/sourceclientgui.py:1007
+#: python/sourceclientgui.py:1033
 msgid "If the connection breaks reconnect to the server"
 msgstr "Se la connessione si interrompe riconnettiti al server"
 
 #. TC: Label for a comma separated list of delay times.
-#: python/sourceclientgui.py:1017
+#: python/sourceclientgui.py:1043
 msgid "Delay times"
 msgstr "Tempi di ritardo"
 
-#: python/sourceclientgui.py:1021
+#: python/sourceclientgui.py:1047
 msgid ""
 "A comma separated list of delays in seconds between reconnection attempts. "
 "Note that bad values or values less than 5 will be interpreted as 5."
@@ -3689,45 +3769,45 @@ msgstr ""
 "Una lista di ritardi, separati da virgola, tra i vari tentativi di "
 "riconnessione. Valori errati o inferiori a 5 verranno interpretati come 5."
 
-#: python/sourceclientgui.py:1027
+#: python/sourceclientgui.py:1053
 msgid "Repeat the sequence of delays indefinitely."
 msgstr "Ripeti all'infinito la sequenza dei ritardi"
 
 #. TC: User specifies no dialog box to be shown.
-#: python/sourceclientgui.py:1030
+#: python/sourceclientgui.py:1056
 msgid "Quiet"
 msgstr "Calmo"
 
-#: python/sourceclientgui.py:1032
+#: python/sourceclientgui.py:1058
 msgid "Keep the reconnection dialogue box hidden at all times."
 msgstr "Tieni nascosta la finestra della riconnessone ad ogni tentativo."
 
-#: python/sourceclientgui.py:1037
+#: python/sourceclientgui.py:1063
 msgid "The contingency plan upon the stream buffer becoming full is..."
 msgstr "Il piano da attuare nel caso il buffer si stia riempiendo è..."
 
-#: python/sourceclientgui.py:1046
+#: python/sourceclientgui.py:1072
 msgid "Discard audio data for as long as needed."
 msgstr "Scarta i dati audio finché è necessario."
 
-#: python/sourceclientgui.py:1048
+#: python/sourceclientgui.py:1074
 msgid "Assume the connection is beyond saving and reconnect."
 msgstr "Assumi che la connessione sia in fase di salvataggio e riconnettiti."
 
-#: python/sourceclientgui.py:1300
+#: python/sourceclientgui.py:1357 python/format.py:1140
 msgid "Shoutcast"
 msgstr "Shoucast"
 
-#: python/sourceclientgui.py:1337
+#: python/sourceclientgui.py:1394
 #, fuzzy
 msgid "[Metadata suppressed]"
 msgstr "Sorgente dei metadati"
 
-#: python/sourceclientgui.py:1416
+#: python/sourceclientgui.py:1473
 msgid "Individual Controls"
 msgstr "Controlli individuali"
 
-#: python/sourceclientgui.py:1430
+#: python/sourceclientgui.py:1487
 #, fuzzy
 msgid ""
 "Connect to or disconnect from the radio server. If the button does not stay "
@@ -3752,12 +3832,12 @@ msgstr ""
 "server principale."
 
 #. TC: Kick whoever is on the server.
-#: python/sourceclientgui.py:1447
+#: python/sourceclientgui.py:1504
 #, fuzzy
 msgid "Kick Source"
 msgstr "Fonte"
 
-#: python/sourceclientgui.py:1449
+#: python/sourceclientgui.py:1506
 msgid ""
 "This will disconnect whoever is currently using the server, freeing it up "
 "for personal use."
@@ -3765,17 +3845,17 @@ msgstr ""
 "Questo disconnetterà chiunque stia utilizzando il server, liberandolo per un "
 "uso personale."
 
-#: python/sourceclientgui.py:1459
+#: python/sourceclientgui.py:1516
 #, fuzzy
 msgid "Timer:"
 msgstr "Cronometro"
 
-#: python/sourceclientgui.py:1463
+#: python/sourceclientgui.py:1520
 #, fuzzy
 msgid "From"
 msgstr "Da qui"
 
-#: python/sourceclientgui.py:1464
+#: python/sourceclientgui.py:1521
 msgid ""
 "Automatically connect to the server at a specific time in 24 hour format, "
 "midnight being 00:00"
@@ -3783,19 +3863,19 @@ msgstr ""
 "Connessione automatica al server ad un orario specifico nel formato a 24 "
 "ore, la mezzanotte è indicata con 00:00"
 
-#: python/sourceclientgui.py:1469
+#: python/sourceclientgui.py:1526
 msgid "Kick"
 msgstr ""
 
-#: python/sourceclientgui.py:1471
+#: python/sourceclientgui.py:1528
 msgid "Disconnect whoever is using the server just before start time."
 msgstr "Disconnetti chiunque stia usando il server poco prima dell'inizio."
 
-#: python/sourceclientgui.py:1480
+#: python/sourceclientgui.py:1537
 msgid "To"
 msgstr ""
 
-#: python/sourceclientgui.py:1481
+#: python/sourceclientgui.py:1538
 msgid ""
 "Automatically disconnect from the server at a specific time in 24 hour "
 "format."
@@ -3803,25 +3883,25 @@ msgstr ""
 "Disconnessione automatica al server ad un orario specifico nel formato a 24 "
 "ore, la mezzanotte è indicata con 00:00"
 
-#: python/sourceclientgui.py:1484
+#: python/sourceclientgui.py:1541
 #, fuzzy
 msgid "Fade out"
 msgstr "Dissolvi 5sec"
 
-#: python/sourceclientgui.py:1486
+#: python/sourceclientgui.py:1543
 msgid "Fade audio before disconnecting."
 msgstr ""
 
-#: python/sourceclientgui.py:1500
+#: python/sourceclientgui.py:1557
 msgid "At connect:"
 msgstr "Una volta connesso:"
 
 #. TC: [x] Start player (*) 1 ( ) 2
-#: python/sourceclientgui.py:1504
+#: python/sourceclientgui.py:1561
 msgid "Start player"
 msgstr "Lettore iniziale"
 
-#: python/sourceclientgui.py:1509
+#: python/sourceclientgui.py:1566
 msgid ""
 "Have one of the players start automatically when a radio server connection "
 "is successfully made."
@@ -3830,11 +3910,11 @@ msgstr ""
 "buon fine."
 
 #. TC: [x] Start recorder (*) 1 ( ) 2
-#: python/sourceclientgui.py:1517
+#: python/sourceclientgui.py:1574
 msgid "Start recorder"
 msgstr "Avvia il registratore"
 
-#: python/sourceclientgui.py:1524
+#: python/sourceclientgui.py:1581
 msgid ""
 "Have a recorder start automatically when a radio server connection is "
 "successfully made."
@@ -3842,20 +3922,21 @@ msgstr ""
 "Avvia uno dei registratori automaticamente quando una connessione al server "
 "va a buon fine."
 
-#: python/sourceclientgui.py:1529
+#: python/sourceclientgui.py:1586 python/format.py:521 python/format.py:532
+#: python/format.py:542
 msgid "Metadata"
 msgstr "Metadati"
 
-#: python/sourceclientgui.py:1539
+#: python/sourceclientgui.py:1596
 msgid "Format String"
 msgstr "Stringa di formattazione"
 
 #. TC: Label for the metadata fallback value.
-#: python/sourceclientgui.py:1541
+#: python/sourceclientgui.py:1598
 msgid "Fallback"
 msgstr "Alternativa"
 
-#: python/sourceclientgui.py:1555
+#: python/sourceclientgui.py:1612
 msgid ""
 "You can enter text to accompany the stream here and can specify placemarkers "
 "%r %t %l %s for the artist, title, album, and songname respectively, or "
@@ -3879,7 +3960,7 @@ msgstr ""
 "Se lasciato vuoto, i flussi Ogg utilizzeranno i tag standard e gli mp3 "
 "utilizzeranno %s."
 
-#: python/sourceclientgui.py:1563
+#: python/sourceclientgui.py:1620
 msgid ""
 "The fallback text to use when %r %t %l metadata is unavailable. See the "
 "format string to the left."
@@ -3887,7 +3968,7 @@ msgstr ""
 "Il testo cui ricorrere quando i metadati %r %t %l non sono disponibili. "
 "Guarda il formato dell stringa sulla sinitra."
 
-#: python/sourceclientgui.py:1565
+#: python/sourceclientgui.py:1622
 msgid ""
 "Metadata normally updates only on song title changes but you can force an "
 "immediate update here."
@@ -3895,28 +3976,28 @@ msgstr ""
 "I metadati di solito vengono aggiornati quando cambia il titolo della song "
 "in esecuzione ma potete forzare un aggiornamento automatico qui."
 
-#: python/sourceclientgui.py:1584
+#: python/sourceclientgui.py:1641
 msgid "Configuration"
 msgstr "Configurazione"
 
-#: python/sourceclientgui.py:1585
+#: python/sourceclientgui.py:1642
 msgid "The controls for configuring a stream."
 msgstr "I controlli per configurare un flusso."
 
-#: python/sourceclientgui.py:1593
+#: python/sourceclientgui.py:1650
 msgid "Connection"
 msgstr "Connessione"
 
-#: python/sourceclientgui.py:1598
+#: python/sourceclientgui.py:1655
 msgid "Format"
 msgstr "Formato"
 
 #. TC: Tab heading. User can enter information about the stream here.
-#: python/sourceclientgui.py:1607
+#: python/sourceclientgui.py:1664
 msgid "Stream Info"
 msgstr "Informazioni flusso"
 
-#: python/sourceclientgui.py:1612
+#: python/sourceclientgui.py:1669
 msgid ""
 "Enter your DJ name or station name here. Typically this information will be "
 "displayed by listener clients."
@@ -3925,7 +4006,7 @@ msgstr ""
 "informazioni saranno visualizzate attraverso i programmi usati dagli "
 "ascoltatori."
 
-#: python/sourceclientgui.py:1615
+#: python/sourceclientgui.py:1672
 msgid ""
 "The URL of your radio station. This and the rest of the information below is "
 "intended for display on a radio station listings website."
@@ -3934,19 +4015,19 @@ msgstr ""
 "informazioni qui sotto sono da intendersi come visualizzabili su di un sito "
 "web che fornisce una lista di stazioni."
 
-#: python/sourceclientgui.py:1620
+#: python/sourceclientgui.py:1677
 msgid "A description of your radio station."
 msgstr "Descrizione della vostra stazione."
 
-#: python/sourceclientgui.py:1625
+#: python/sourceclientgui.py:1682
 msgid "The musical genres you are likely to play."
 msgstr "Il genere musicale che offrirete."
 
-#: python/sourceclientgui.py:1628
+#: python/sourceclientgui.py:1685
 msgid "Make Public"
 msgstr "Rendi pubblico"
 
-#: python/sourceclientgui.py:1629
+#: python/sourceclientgui.py:1686
 msgid ""
 "Publish your radio station on a listings website. The website in question "
 "will depend on how the server to which you connect is configured."
@@ -3954,15 +4035,15 @@ msgstr ""
 "Pubblicate la vostra stazione su un sito. Il sito in questione dipenderà "
 "dalla configurazione del server cui vi connettete."
 
-#: python/sourceclientgui.py:1641
+#: python/sourceclientgui.py:1698
 msgid "Genre(s)"
 msgstr "Genere(i)"
 
-#: python/sourceclientgui.py:1651
+#: python/sourceclientgui.py:1709
 msgid "Master server admin password"
 msgstr "Password di amministrazione del server principale"
 
-#: python/sourceclientgui.py:1656
+#: python/sourceclientgui.py:1714
 msgid ""
 "This is for kick and stats on Shoutcast master servers that have an "
 "administrator password. For those that don't leave this blank (the source "
@@ -3972,47 +4053,56 @@ msgstr ""
 "password di amministrazione impostata. Per chi riempie questo campo (la "
 "password della fonte è sufficente)"
 
-#: python/sourceclientgui.py:1665
+#: python/sourceclientgui.py:1723
 msgid "Contact Details"
 msgstr "Dettagli del contatto"
 
-#: python/sourceclientgui.py:1670
+#: python/sourceclientgui.py:1727
 msgid "Internet Relay Chat connection info goes here."
 msgstr "Le informazioni per IRC vanno inserite qui"
 
-#: python/sourceclientgui.py:1673
+#: python/sourceclientgui.py:1730
 msgid "Connection info for AOL instant messenger goes here."
 msgstr "Le informazioni per AOL vanno inserite qui."
 
-#: python/sourceclientgui.py:1676
+#: python/sourceclientgui.py:1733
 msgid "ICQ instant messenger connection info goes here."
 msgstr "Le informazioni per ICQ vanno inserite qui."
 
-#: python/sourceclientgui.py:1679
+#: python/sourceclientgui.py:1736
 msgid "IRC"
 msgstr "IRC"
 
-#: python/sourceclientgui.py:1680
+#: python/sourceclientgui.py:1737
 msgid "AIM"
 msgstr "AIM"
 
-#: python/sourceclientgui.py:1681
+#: python/sourceclientgui.py:1738
 msgid "ICQ"
 msgstr "ICQ"
 
-#: python/sourceclientgui.py:1690
+#: python/sourceclientgui.py:1748
+#, fuzzy
+msgid "Use ISO-8859-1 encoding for fixed metadata"
+msgstr "Usa la codifica utf-8 quando si inviano i metadati"
+
+#: python/sourceclientgui.py:1750
+msgid "Enable this if sending to a Shoutcast V1 server."
+msgstr ""
+
+#: python/sourceclientgui.py:1754
 msgid "Extra Shoutcast"
 msgstr "Extra Shoutcast"
 
-#: python/sourceclientgui.py:1695
+#: python/sourceclientgui.py:1759
 msgid "Troubleshooting"
 msgstr "Risoluzione problemi"
 
-#: python/sourceclientgui.py:1821
+#: python/sourceclientgui.py:1890
 msgid "Stop recording."
 msgstr "Ferma la registrazione"
 
-#: python/sourceclientgui.py:1823
+#: python/sourceclientgui.py:1892
 msgid ""
 "Start recording.\n"
 "\n"
@@ -4020,20 +4110,20 @@ msgid ""
 "not valid or write permission is not granted on the selected folder."
 msgstr ""
 
-#: python/sourceclientgui.py:1828
+#: python/sourceclientgui.py:1897
 msgid "Pause recording."
 msgstr "Metti in pausa"
 
-#: python/sourceclientgui.py:1865
+#: python/sourceclientgui.py:1934
 msgid "Recording time elapsed."
 msgstr "Tempo di registrazione trascorso."
 
 #. TC: Dialog title bar text.
-#: python/sourceclientgui.py:1919
+#: python/sourceclientgui.py:1988
 msgid "Select the folder to record to"
 msgstr "Seleziona la cartella in cui registrare"
 
-#: python/sourceclientgui.py:1930
+#: python/sourceclientgui.py:1999
 msgid ""
 "Choose which stream to record or the 24 bit FLAC option. If the stream isn't "
 "already running the encoder will be started automatically using whatever "
@@ -4043,7 +4133,7 @@ msgstr ""
 "già attivo il codificatore verrà avviato automaticamente con le impostazioni "
 "attualmente configurate."
 
-#: python/sourceclientgui.py:1934
+#: python/sourceclientgui.py:2003
 msgid ""
 "Choose which directory you want to save to. All file names will be in a "
 "timestamp format and have either an oga, mp3, or flac file extension. "
@@ -4055,74 +4145,75 @@ msgstr ""
 "Importante: dovete scegliere una cartella per la quale avete i permessi "
 "necessari alla scrittura."
 
-#: python/sourceclientgui.py:2038
+#: python/sourceclientgui.py:2110
 msgid "Perform operations on multiple servers in unison."
 msgstr "Esegue le operazioni su più server alla volta."
 
-#: python/sourceclientgui.py:2050
+#: python/sourceclientgui.py:2122
 msgid "Connect"
 msgstr "Connetti"
 
-#: python/sourceclientgui.py:2067
+#: python/sourceclientgui.py:2139
 msgid "Disconnect"
 msgstr "Disconnetti"
 
-#: python/sourceclientgui.py:2075
+#: python/sourceclientgui.py:2147
 #, fuzzy
 msgid "Kick Sources"
 msgstr "Fonte"
 
-#: python/sourceclientgui.py:2084
+#: python/sourceclientgui.py:2156
 msgid "Metadata:"
 msgstr "Metadati:"
 
-#: python/sourceclientgui.py:2114
+#: python/sourceclientgui.py:2186
 msgid "Group Controls"
 msgstr "Controlli di gruppo"
 
-#: python/sourceclientgui.py:2610
+#: python/sourceclientgui.py:2692
 msgid "Recording Facility Unavailable"
 msgstr ""
 
-#: python/sourceclientgui.py:2613
+#: python/sourceclientgui.py:2695
 #, fuzzy
 msgid "No Recorders Are Correctly Configured"
 msgstr "Nessun server principale configurato"
 
 #. TC: Recorder menu format string.
-#: python/sourceclientgui.py:2626
+#: python/sourceclientgui.py:2708
+#, python-brace-format
 msgid "{numericid} [{source}] > [{directory}]"
 msgstr ""
 
-#: python/sourceclientgui.py:2628
+#: python/sourceclientgui.py:2710
 msgid "Misconfigured"
 msgstr ""
 
-#: python/sourceclientgui.py:2649
+#: python/sourceclientgui.py:2731
 msgid "Streaming Facility Unavailable"
 msgstr ""
 
-#: python/sourceclientgui.py:2651
+#: python/sourceclientgui.py:2733
 #, fuzzy
 msgid "No Streams Are Currently Configured"
 msgstr "Nessun server principale configurato"
 
-#: python/sourceclientgui.py:2654
+#: python/sourceclientgui.py:2736
 #, fuzzy
 msgid "Group Connect"
 msgstr "Controlli di gruppo"
 
-#: python/sourceclientgui.py:2660
+#: python/sourceclientgui.py:2742
 #, fuzzy
 msgid "Group Disconnect"
 msgstr "Disconnetti"
 
 #. TC: Window title bar text.
-#: python/sourceclientgui.py:2691
+#: python/sourceclientgui.py:2773
 msgid "IDJC Output"
 msgstr "Uscita IDJC"
 
-#: python/sourceclientgui.py:2707
+#: python/sourceclientgui.py:2789
 msgid ""
 "Each one of these tabs represents a separate stream recorder. The LED "
 "indicator colours represent the following: Clear=Stopped Yellow=Paused "
@@ -4131,7 +4222,7 @@ msgstr ""
 "Ognuna di queste linguette rappresenta un registratore di flusso. I colori "
 "del LED indicano: Vuoto=Fermo Giallo=Pausa Rosso=Registrazione."
 
-#: python/sourceclientgui.py:2715
+#: python/sourceclientgui.py:2797
 msgid ""
 "Each one of these tabs represents a separate radio streamer. The LED "
 "indicator colours represent the following: Clear=No connection "
@@ -4142,11 +4233,11 @@ msgstr ""
 "Vuoto=Non connesso Giallo=In attesa di autenticazione. Verde=Connesso. "
 "Lampeggiante=Perdita di pacchetti a causa di una cattiva connessione."
 
-#: python/sourceclientgui.py:2733
+#: python/sourceclientgui.py:2815
 msgid " Stream "
 msgstr " Flusso "
 
-#: python/sourceclientgui.py:2768
+#: python/sourceclientgui.py:2850
 msgid ""
 "<span weight=\"bold\" size=\"12000\">A connection to a radio server has "
 "failed.</span>\n"
@@ -4158,7 +4249,7 @@ msgstr ""
 "\n"
 "Non verrà effettuato un altro tentativo."
 
-#: python/sourceclientgui.py:2773
+#: python/sourceclientgui.py:2855
 msgid ""
 "<span weight=\"bold\" size=\"12000\">A scheduled stream disconnection has "
 "occurred.</span>"
@@ -4166,6 +4257,524 @@ msgstr ""
 "<span weight=\"bold\" size=\"12000\">E' intervenuta una disconnessione "
 "pianificata.</span>"
 
+#: python/format.py:419
+msgid "Right click for suggested values."
+msgstr ""
+
+#: python/format.py:438
+#, fuzzy
+msgid "Suggested Values"
+msgstr "Imposta valore"
+
+#: python/format.py:494
+#, fuzzy
+msgid "Pregain"
+msgstr "Lettore imposta il gain"
+
+#: python/format.py:495 python/format.py:913
+msgid "0 dB"
+msgstr ""
+
+#: python/format.py:496 python/format.py:914
+msgid "-0.5 dB"
+msgstr ""
+
+#: python/format.py:497 python/format.py:915
+msgid "-1.0 dB"
+msgstr ""
+
+#: python/format.py:498 python/format.py:916
+msgid "-1.5 dB"
+msgstr ""
+
+#: python/format.py:499 python/format.py:917
+msgid "-2.0 dB"
+msgstr ""
+
+#: python/format.py:500 python/format.py:918
+msgid "-2.5 dB"
+msgstr ""
+
+#: python/format.py:501 python/format.py:919
+msgid "-3.0 dB"
+msgstr ""
+
+#: python/format.py:502
+msgid ""
+"A blanket gain reduction to promote audio quality when using long "
+"established lossy audio codecs like mp3 with loud audio material.\n"
+"\n"
+"ReplayGain makes this feature generally unnecessary and the correct setting "
+"in that case is 0 dB."
+msgstr ""
+
+#: python/format.py:510
+#, fuzzy
+msgid "Resample Quality"
+msgstr "Qualità di ricampionamento del lettore"
+
+#: python/format.py:511
+msgid "Highest"
+msgstr "Elevata"
+
+#: python/format.py:513
+#, fuzzy
+msgid "Lowest"
+msgstr "Inferiore %"
+
+#: python/format.py:514
+msgid ""
+"All of these settings will provide adequate audio quality. The highest "
+"setting will preserve more of the original audio bandwidth at the expense of "
+"many CPU cycles."
+msgstr ""
+
+#: python/format.py:522 python/format.py:533 python/format.py:543
+#, fuzzy
+msgid "Suppressed"
+msgstr "Premuto"
+
+#: python/format.py:523 python/format.py:534
+msgid "UTF-8"
+msgstr ""
+
+#: python/format.py:524
+msgid "Latin1 *"
+msgstr ""
+
+#: python/format.py:525
+msgid ""
+"This affects the stream metadata only. Recordings will use UTF-8 for their "
+"metadata."
+msgstr ""
+
+#: python/format.py:535
+msgid ""
+"Choose whether the stream will carry dynamic metadata. In the case of Ogg "
+"streams this is important as a great many players can't handle chained Ogg "
+"streams which result from the metadata updates."
+msgstr ""
+
+#: python/format.py:544
+msgid "Latin1"
+msgstr ""
+
+#: python/format.py:545
+msgid "Choose whether to send metadata. Recordings will use UTF-8 metadata."
+msgstr ""
+
+#: python/format.py:561 python/format.py:572 python/format.py:583
+#: python/format.py:690 python/format.py:818 python/format.py:888
+#: python/format.py:897 python/format.py:971 python/format.py:994
+#: python/format.py:1003
+msgid "Mode"
+msgstr "Modo"
+
+#: python/format.py:562 python/format.py:573 python/format.py:584
+#: python/format.py:691 python/format.py:819 python/format.py:889
+#: python/format.py:898 python/format.py:972 python/format.py:995
+#: python/format.py:1004
+msgid "Mono"
+msgstr "Mono"
+
+#: python/format.py:563 python/format.py:574 python/format.py:585
+#: python/format.py:692 python/format.py:820 python/format.py:890
+#: python/format.py:899 python/format.py:973 python/format.py:996
+#: python/format.py:1005
+msgid "Stereo"
+msgstr "Stereo"
+
+#: python/format.py:564 python/format.py:575 python/format.py:586
+#: python/format.py:693
+#, fuzzy
+msgid "Joint Stereo"
+msgstr "Stereo"
+
+#: python/format.py:565
+msgid "Joint Stereo is a good choice on streams with low bitrates."
+msgstr ""
+
+#: python/format.py:576
+msgid "Due to the high bitrate selected, this codec will only support stereo."
+msgstr ""
+
+#: python/format.py:587
+msgid "Due to the low bitrate selected, this codec will only support mono."
+msgstr ""
+
+#: python/format.py:636 python/format.py:646 python/format.py:743
+#: python/format.py:753 python/format.py:763 python/format.py:869
+#: python/format.py:879 python/format.py:1032 python/format.py:1052
+#, fuzzy
+msgid "Samplerate"
+msgstr "Frequenza di campionamento"
+
+#. TC: Abbreviation of the word, standard.
+#: python/format.py:657 python/format.py:774
+msgid "Std."
+msgstr ""
+
+#. TC: v stands for version.
+#: python/format.py:659 python/format.py:776
+msgid "V 1"
+msgstr ""
+
+#. TC: v stands for version.
+#: python/format.py:661 python/format.py:778
+msgid "V 2"
+msgstr ""
+
+#: python/format.py:662
+msgid ""
+"MPEG2 introduced lower samplerate options and corresponding lower bitrates. "
+"Choose 2 if those are required."
+msgstr ""
+
+#: python/format.py:669 python/format.py:797
+msgid "Quality"
+msgstr "Qualità"
+
+#: python/format.py:670
+msgid "0 most"
+msgstr ""
+
+#. TC: * means is the recommended setting.
+#: python/format.py:673
+msgid "2 *"
+msgstr ""
+
+#: python/format.py:675
+msgid "Higher quality costs more in terms of CPU cycles."
+msgstr ""
+
+#: python/format.py:694
+msgid "Joint Stereo is a good choice on streams with low bitrates"
+msgstr ""
+
+#. TC: v stands for version.
+#: python/format.py:780
+msgid "V 2.5"
+msgstr ""
+
+#: python/format.py:787
+msgid "Complexity"
+msgstr ""
+
+#: python/format.py:790
+msgid "A quality setting that affects how heavily the CPU is used."
+msgstr ""
+
+#: python/format.py:800
+msgid "The higher this setting, the higher the bitrate."
+msgstr ""
+
+#: python/format.py:807
+msgid "Bandwidth"
+msgstr ""
+
+#: python/format.py:808
+#, fuzzy
+msgid "Ultrawide"
+msgstr "Banda ultra larga"
+
+#: python/format.py:809
+#, fuzzy
+msgid "Wide"
+msgstr "Banda larga"
+
+#: python/format.py:810
+#, fuzzy
+msgid "Narrow"
+msgstr "Banda stretta"
+
+#: python/format.py:811
+msgid "Essentially a samplerate setting."
+msgstr ""
+
+#: python/format.py:828
+msgid "24 bit"
+msgstr ""
+
+#: python/format.py:829
+msgid "20 bit"
+msgstr ""
+
+#: python/format.py:830
+msgid "16 bit"
+msgstr ""
+
+#: python/format.py:831
+msgid ""
+"24 bit records with the highest level of detail. If file size is a concern "
+"maybe FLAC is not the right codec."
+msgstr ""
+
+#: python/format.py:838 python/format.py:927
+msgid "Variability"
+msgstr ""
+
+#: python/format.py:839
+msgid "Constant"
+msgstr ""
+
+#: python/format.py:840
+msgid "±10%"
+msgstr ""
+
+#: python/format.py:841
+msgid "±20%"
+msgstr ""
+
+#: python/format.py:842
+msgid "±30%"
+msgstr ""
+
+#: python/format.py:843
+msgid "±40%"
+msgstr ""
+
+#: python/format.py:844
+msgid "±50%"
+msgstr ""
+
+#: python/format.py:845
+#, fuzzy
+msgid "This control is for enabling variable bitrate on Vorbis streams."
+msgstr "I controlli per configurare un flusso."
+
+#: python/format.py:906
+#, fuzzy
+msgid "Postgain"
+msgstr "VoIP imposta guadagno"
+
+#: python/format.py:907
+msgid "3.0 dB"
+msgstr ""
+
+#: python/format.py:908
+msgid "2.5 dB"
+msgstr ""
+
+#: python/format.py:909
+msgid "2.0 dB"
+msgstr ""
+
+#: python/format.py:910
+msgid "1.5 dB"
+msgstr ""
+
+#: python/format.py:911
+msgid "1.0 dB"
+msgstr ""
+
+#: python/format.py:912
+msgid "0.5 dB"
+msgstr ""
+
+#: python/format.py:920
+msgid "A gain adjustment for the player to apply."
+msgstr ""
+
+#: python/format.py:928
+msgid "CBR *"
+msgstr ""
+
+#: python/format.py:929
+msgid "CVBR"
+msgstr ""
+
+#: python/format.py:930
+msgid "VBR"
+msgstr ""
+
+#: python/format.py:931
+msgid ""
+"Bitrate variability. Actual VBR operation may require a higher frame size."
+msgstr ""
+
+#: python/format.py:938
+msgid "Frame Size"
+msgstr ""
+
+#: python/format.py:939
+msgid "60 ms"
+msgstr ""
+
+#: python/format.py:940
+msgid "40 ms"
+msgstr ""
+
+#: python/format.py:941
+msgid "20 ms"
+msgstr ""
+
+#: python/format.py:942
+msgid "A higher frame size may sound better on very low bitrates."
+msgstr ""
+
+#: python/format.py:949
+msgid "CPU"
+msgstr "CPU"
+
+#: python/format.py:952
+msgid "The encoder complexity setting which affects CPU load."
+msgstr ""
+
+#: python/format.py:980 python/format.py:1083
+msgid "Codec"
+msgstr ""
+
+#: python/format.py:981
+msgid "Vorbis"
+msgstr ""
+
+#: python/format.py:982
+msgid "FLAC"
+msgstr ""
+
+#: python/format.py:983
+msgid "Speex"
+msgstr ""
+
+#: python/format.py:984
+msgid "Opus"
+msgstr ""
+
+#: python/format.py:987
+msgid "Codecs of the Ogg container."
+msgstr ""
+
+#: python/format.py:1033
+msgid "96000 Hz"
+msgstr ""
+
+#: python/format.py:1034
+msgid "88200 Hz"
+msgstr ""
+
+#: python/format.py:1035
+msgid "64000 Hz"
+msgstr ""
+
+#: python/format.py:1036 python/format.py:1053
+msgid "48000 Hz"
+msgstr ""
+
+#: python/format.py:1037 python/format.py:1054
+msgid "44100 Hz"
+msgstr ""
+
+#: python/format.py:1038
+msgid "32000 Hz"
+msgstr ""
+
+#: python/format.py:1039
+msgid "24000 Hz"
+msgstr ""
+
+#: python/format.py:1040
+msgid "22050 Hz"
+msgstr ""
+
+#: python/format.py:1041
+msgid "16000 Hz"
+msgstr ""
+
+#: python/format.py:1042
+msgid "12000 Hz"
+msgstr ""
+
+#: python/format.py:1043
+msgid "11025 Hz"
+msgstr ""
+
+#: python/format.py:1044
+msgid "8000 Hz"
+msgstr ""
+
+#: python/format.py:1045
+msgid "7350 Hz"
+msgstr ""
+
+#: python/format.py:1067
+msgid "The MP2 option requires IDJC be rebuilt against libtwolame."
+msgstr ""
+
+#: python/format.py:1070
+msgid "Enable the MP3 option by installing libmp3lame."
+msgstr ""
+
+#: python/format.py:1073
+msgid "The AAC options require IDJC be rebuilt against libav libraries."
+msgstr ""
+
+#: python/format.py:1076
+msgid ""
+"Specific AAC support not present in libavcodec. More info: idjc.sourceforge."
+"net."
+msgstr ""
+
+#: python/format.py:1078
+msgid ""
+"Specific AAC+ support not present in libavcodec. More info: idjc.sourceforge."
+"net."
+msgstr ""
+
+#: python/format.py:1081
+msgid "Codecs of the MPEG family."
+msgstr ""
+
+#: python/format.py:1084
+msgid "MP2"
+msgstr ""
+
+#: python/format.py:1085
+msgid "MP3"
+msgstr ""
+
+#: python/format.py:1086
+msgid "AAC"
+msgstr ""
+
+#: python/format.py:1087
+msgid "AAC+ v2"
+msgstr ""
+
+#. TC: Codec family e.g. Xiph/Ogg, MPEG etc.
+#: python/format.py:1099
+msgid "Family"
+msgstr ""
+
+#. TC: Xiph.org Ogg container format.
+#: python/format.py:1101
+msgid "Xiph/Ogg"
+msgstr ""
+
+#: python/format.py:1102
+msgid "MPEG"
+msgstr ""
+
+#: python/format.py:1103
+msgid "Codecs have been grouped by standards body and or container format."
+msgstr ""
+
+#: python/format.py:1128
+msgid "Capabilities"
+msgstr ""
+
+#: python/format.py:1140
+#, fuzzy
+msgid "Icecast"
+msgstr "Icecast 2 Master"
+
+#: python/format.py:1140
+#, fuzzy
+msgid "Recordable"
+msgstr "Registratore"
+
+#~ msgid "Playlist types (*.m3u, *.xspf, *.pls)"
+#~ msgstr "Tipi di playlist (*.m3u, *.xspf, *.pls)"
+
 #~ msgid "Connection timer:"
 #~ msgstr "Timer di connessione:"
 
@@ -4250,13 +4859,6 @@ msgstr ""
 #~ "sensibilmente la dinamica. L'indicatore 'Str Peak' è utile per regolare "
 #~ "questo valore."
 
-#~ msgid "Highest"
-#~ msgstr "Elevata"
-
-#, fuzzy
-#~ msgid "Lowest"
-#~ msgstr "Inferiore %"
-
 #~ msgid "Prefs enable tooltips"
 #~ msgstr "Preferenze abilita suggerimenti"
 
@@ -4428,9 +5030,6 @@ msgstr ""
 #~ "all'ingresso del codificatore impedirà all'audio decodificato di superare "
 #~ "0dB"
 
-#~ msgid "Use utf-8 encoding when streaming mp3 metadata"
-#~ msgstr "Usa la codifica utf-8 quando si inviano i metadati"
-
 #~ msgid ""
 #~ "It is standard to stream mp3 metadata with iso-8859-1 character encoding "
 #~ "on shoutcast. This option should therefore not be used."
@@ -4445,15 +5044,9 @@ msgstr ""
 #~ msgid "Fastest"
 #~ msgstr "Più veloce"
 
-#~ msgid "Sample rate"
-#~ msgstr "Frequenza di campionamento"
-
 #~ msgid "Use JACK sample rate"
 #~ msgstr "Usa la frequenza di campionamento di JACK"
 
-#~ msgid "Quality"
-#~ msgstr "Qualità"
-
 #~ msgid ""
 #~ "No additional resampling will occur. The stream sample rate will be that "
 #~ "of the JACK sound server."
@@ -4578,12 +5171,6 @@ msgstr ""
 #~ msgid "This chooses the Speex format for streaming and recording."
 #~ msgstr "Sceglie il formato Speex per il flusso e la registrazione."
 
-#~ msgid "Stereo"
-#~ msgstr "Stereo"
-
-#~ msgid "Mono"
-#~ msgstr "Mono"
-
 #~ msgid "Upper %"
 #~ msgstr "Superiore %"
 
@@ -4653,15 +5240,6 @@ msgstr ""
 #~ msgid "Feature Disabled"
 #~ msgstr "Configurazione disabilitata"
 
-#~ msgid "Ultra Wide Band"
-#~ msgstr "Banda ultra larga"
-
-#~ msgid "Wide Band"
-#~ msgstr "Banda larga"
-
-#~ msgid "Narrow Band"
-#~ msgstr "Banda stretta"
-
 #~ msgid ""
 #~ "Apply intensity stereo to the audio stream. This is a very efficient "
 #~ "implementation of stereo but is only suited to voice."
@@ -4676,9 +5254,6 @@ msgstr ""
 #~ "L'invio dei metadati può essere fuorviante per l'ascoltatore durante il "
 #~ "cambio. Disattivando questa opzione potete evitarlo."
 
-#~ msgid "Mode"
-#~ msgstr "Modo"
-
 #~ msgid ""
 #~ "This is the audio bandwidth selector. Ultra Wide Band has a bandwidth of "
 #~ "16kHz; Wide Band, 8kHz; Narrow Band, 4kHz. The samplerate is twice the "
@@ -4701,9 +5276,6 @@ msgstr ""
 #~ "base alla qualità. Q8 è un buon compromesso per il parlato e Q10 "
 #~ "rappresenta la scelta migliore per la musica."
 
-#~ msgid "CPU"
-#~ msgstr "CPU"
-
 #~ msgid ""
 #~ "This sets the level of complexity in the encoder. Higher values use more "
 #~ "CPU but result in better sounding audio though not as great an "
diff --git a/python/Makefile.am b/python/Makefile.am
index da8f9ab..a0b0e1f 100644
--- a/python/Makefile.am
+++ b/python/Makefile.am
@@ -14,11 +14,12 @@ nodist_idjcpkgpython_PYTHON = __init__.py
 dist_noinst_PYTHON = __init__.py.in.in
 
 __init__.py: __init__.py.in
-	@sed -e 's|$${pkgdatadir}|${pkgdatadir}|g'	\
+	sed -e 's|$${pkgdatadir}|${pkgdatadir}|g'	\
 		 -e 's|$${pkglibdir}|${pkglibdir}|g'	\
 		 -e 's|$${exec_prefix}|${exec_prefix}|g' \
 	     -e 's|$${prefix}|${prefix}|g'			\
-	     -e 's|$${datarootdir}|${datarootdir}|g' $? >$@
+	     -e 's|$${datarootdir}|${datarootdir}|g' \
+	      $? >$@
 
 clean-local:
 	rm -f __init__.py
diff --git a/python/Makefile.in b/python/Makefile.in
index e487d8c..50bb270 100644
--- a/python/Makefile.in
+++ b/python/Makefile.in
@@ -242,6 +242,7 @@ EXEEXT = @EXEEXT@
 EXT = @EXT@
 FGREP = @FGREP@
 GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@
+GIT_PROG_EXISTS = @GIT_PROG_EXISTS@
 GLIB_CFLAGS = @GLIB_CFLAGS@
 GLIB_LIBS = @GLIB_LIBS@
 GMSGFMT = @GMSGFMT@
@@ -299,6 +300,7 @@ LN_S = @LN_S@
 LTLIBICONV = @LTLIBICONV@
 LTLIBINTL = @LTLIBINTL@
 LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
 MAKEINFO = @MAKEINFO@
 MANIFEST_TOOL = @MANIFEST_TOOL@
 MKDIR_P = @MKDIR_P@
@@ -888,11 +890,12 @@ uninstall-am: uninstall-idjcpkgpythonPYTHON \
 
 
 __init__.py: __init__.py.in
-	@sed -e 's|$${pkgdatadir}|${pkgdatadir}|g'	\
+	sed -e 's|$${pkgdatadir}|${pkgdatadir}|g'	\
 		 -e 's|$${pkglibdir}|${pkglibdir}|g'	\
 		 -e 's|$${exec_prefix}|${exec_prefix}|g' \
 	     -e 's|$${prefix}|${prefix}|g'			\
-	     -e 's|$${datarootdir}|${datarootdir}|g' $? >$@
+	     -e 's|$${datarootdir}|${datarootdir}|g' \
+	      $? >$@
 
 clean-local:
 	rm -f __init__.py
diff --git a/python/dialogs.py b/python/dialogs.py
index c91f895..4cc9afa 100644
--- a/python/dialogs.py
+++ b/python/dialogs.py
@@ -26,7 +26,7 @@ import pango
 
 from idjc import FGlobs
 from idjc.prelims import ProfileManager
-from .gtkstuff import threadslock
+from .gtkstuff import threadslock, idle_add
 
 import gettext
 t = gettext.translation(FGlobs.package_name, FGlobs.localedir, fallback=True)
@@ -207,7 +207,7 @@ class ReconnectionDialog(gtk.Dialog):
             self.label2.set_text(self.lines[1].format(countdown=self.remaining))
             if self.remaining == 0:
                 self.hide()
-                glib.idle_add(self.reconnect_idle)
+                idle_add(self.reconnect_idle)
                 
     @threadslock
     def reconnect_idle(self):
diff --git a/python/gtkstuff.py b/python/gtkstuff.py
index 3d12f71..9dc79d4 100644
--- a/python/gtkstuff.py
+++ b/python/gtkstuff.py
@@ -437,7 +437,7 @@ class WindowSizeTracker(object):
         self._window.unmaximize()
         self._window.resize(self._x, self._y)
         if self._max:
-            gobject.idle_add(threadslock(self._window.maximize))
+            idle_add(threadslock(self._window.maximize))
 
     def _on_configure_event(self, widget, event):
         if self._is_tracking and not self._max:
@@ -719,3 +719,36 @@ class FolderChooserButton(gtk.Button):
         self._current_folder = new_folder
         self._update_visual()
 
+
+def _source_wrapper(data):
+    if data[0]:
+        ret = data[1](*data[2], **data[3])
+        if ret:
+            return ret
+        data[0] = False
+
+
+def source_remove(data):
+    if data[0]:
+        glib.source_remove(data[4])
+    data[0] = False
+
+
+def timeout_add(interval, callback, *args, **kwargs):
+    data = [True, callback, args, kwargs]
+    data.append(glib.timeout_add(interval, _source_wrapper, data))
+    return data
+
+
+def timeout_add_seconds(interval, callback, *args, **kwargs):
+    data = [True, callback, args, kwargs]
+    data.append(glib.timeout_add_seconds(interval, _source_wrapper, data))
+    return data
+
+
+def idle_add(callback, *args, **kwargs):
+    data = [True, callback, args, kwargs]
+    data.append(glib.idle_add(_source_wrapper, data))
+    return data
+
+
diff --git a/python/idjcmonitor.py b/python/idjcmonitor.py
index cd3e549..76c4c75 100644
--- a/python/idjcmonitor.py
+++ b/python/idjcmonitor.py
@@ -36,7 +36,7 @@ def pid_exists(pid):
     try:
         os.kill(pid, 0)
     except OSError, e:
-        return e.errno == errno.EPERM
+        return e.errno == os.errno.EPERM
     else:
         return True
 
@@ -55,13 +55,20 @@ class IDJCMonitor(gobject.GObject):
                                     (gobject.TYPE_STRING, gobject.TYPE_UINT)),
         'streamstate-changed' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE,
                 (gobject.TYPE_INT, gobject.TYPE_BOOLEAN, gobject.TYPE_STRING)),
-        
+        'recordstate-changed' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE,
+                (gobject.TYPE_INT, gobject.TYPE_BOOLEAN, gobject.TYPE_STRING)),
+        'channelstate-changed' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE,
+                (gobject.TYPE_UINT, gobject.TYPE_BOOLEAN)),
+        'voip-mode-changed' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE,
+                                 (gobject.TYPE_UINT,)),
         'metadata-changed' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE,
                                                     (gobject.TYPE_STRING,) * 5),
         'effect-started': (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE,
                            (gobject.TYPE_STRING,) * 2 + (gobject.TYPE_UINT,)),
         'effect-stopped': (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE,
                            (gobject.TYPE_UINT,)),
+        'tracks-finishing': (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE,
+                            ()),
         'frozen' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE,
                 (gobject.TYPE_STRING, gobject.TYPE_UINT, gobject.TYPE_BOOLEAN))
     }
@@ -77,11 +84,17 @@ class IDJCMonitor(gobject.GObject):
                             'the song name from metadata tags when available'
                             ' and from the filenmame when not',
                             "", gobject.PARAM_READABLE),
-        'music_filename' : (gobject.TYPE_STRING, 'music_filename',
+        'music-filename' : (gobject.TYPE_STRING, 'music_filename',
                             'the audio file pathname of the track',
                             "", gobject.PARAM_READABLE),
         'streaminfo' : (gobject.TYPE_PYOBJECT, 'streaminfo',
-                'information about the streams', gobject.PARAM_READABLE)
+                'information about the streams', gobject.PARAM_READABLE),
+        'recordinfo' : (gobject.TYPE_PYOBJECT, 'recordinfo',
+                'information about the recorders', gobject.PARAM_READABLE),
+        'channelinfo' : (gobject.TYPE_PYOBJECT, 'channelinfo',
+                'toggle state of the audio channels', gobject.PARAM_READABLE),
+        'voip-mode' : (gobject.TYPE_UINT, 'voip-mode', 'voice over ip mixer mode',
+                                                0, 2, 0, gobject.PARAM_READABLE)
     }
     
     def __init__(self, profile):
@@ -174,19 +187,32 @@ class IDJCMonitor(gobject.GObject):
                                                 self._effect_stopped_handler)
             self.__main.connect_to_signal("quitting", self._quit_handler)
             self.__main.connect_to_signal("heartbeat", self._heartbeat_handler)
+            self.__main.connect_to_signal("channelstate_changed",
+                                                    self._channelstate_handler)
+            self.__main.connect_to_signal("voip_mode_changed",
+                                                    self._voip_mode_handler)
+            self.__main.connect_to_signal("tracks_finishing",
+                                                self._tracks_finishing_handler)
             self.__output.connect_to_signal("streamstate_changed",
                                                     self._streamstate_handler)
+            self.__output.connect_to_signal("recordstate_changed",
+                                                    self._recordstate_handler)
 
             # Start watchdog thread.
             self.__watchdog_id = gobject.timeout_add_seconds(3, self._watchdog)
 
             self.__streams = {n : (False, "unknown") for n in xrange(10)}
+            self.__recorders = {n : (False, "unknown") for n in xrange(4)}
+            self.__channels = [False] * 12
+            self.__voip_mode = 0
+            main_iface = dbus.Interface(self.__main, self.__base_interface)
             output_iface = dbus.Interface(self.__output, self.__base_interface)
             
             self.emit("launch", self.__profile, self.__pid)
             
             # Tell IDJC to initialize as empty its cache of sent data.
             # This yields a dump of server related info.
+            main_iface.new_plugin_started()
             output_iface.new_plugin_started()
         except dbus.exceptions.DBusException:
             self._start_probing()
@@ -205,6 +231,15 @@ class IDJCMonitor(gobject.GObject):
                 for id_, (conn, where) in self.__streams.iteritems():
                     if conn:
                         self._streamstate_handler(id_, 0, where)
+
+                for id_, (rec, where) in self.__recorders.iteritems():
+                    if rec:
+                        self._recordstate_handler(id_, 0, where)
+                        
+                for index, open_ in enumerate(self.__channels):
+                    if open_:
+                        self._channelstate_handler(index, 0)
+                
                 self._quit_handler()
                 return False
         elif self.__frozen:
@@ -233,6 +268,30 @@ class IDJCMonitor(gobject.GObject):
         self.notify("streaminfo")
         self.emit("streamstate-changed", numeric_id, connected, where)
 
+    def _recordstate_handler(self, numeric_id, recording, where):
+        numeric_id = int(numeric_id)
+        recording = bool(recording)
+        where = where.encode("utf-8")
+        self.__recorders[numeric_id] = (recording, where)
+        self.notify("recordinfo")
+        self.emit("recordstate-changed", numeric_id, recording, where)
+
+    def _channelstate_handler(self, numeric_id, open_):
+        numeric_id = int(numeric_id)
+        open_ = bool(open_)
+        self.__channels[numeric_id] = open_
+        self.notify("channelinfo")
+        self.emit("channelstate-changed", numeric_id, open_)
+
+    def _voip_mode_handler(self, mode):
+        mode = int(mode)
+        self.__voip_mode = mode
+        self.notify("voip-mode")
+        self.emit("voip-mode-changed", mode)
+
+    def _tracks_finishing_handler(self):
+        self.emit("tracks-finishing")
+
     def _metadata_handler(self, artist, title, album, songname, music_filename):
 
         def update_property(name, value):
@@ -269,6 +328,12 @@ class IDJCMonitor(gobject.GObject):
             return getattr(self, "_IDJCMonitor__" + name)
         if name == "streaminfo":
             return tuple(self.__streams[n] for n in xrange(10))
+        elif name == "recordinfo":
+            return tuple(self.__recorders[n] for n in xrange(4))
+        elif name == "channelinfo":
+            return tuple(self.__channels[n] for n in xrange(12))
+        elif name == "voip-mode":
+            return self.__voip_mode
         else:
             raise AttributeError("Unknown property %s in %s" % (
                                                             name, repr(self)))
diff --git a/python/irc.py b/python/irc.py
index 855d880..46af7ae 100644
--- a/python/irc.py
+++ b/python/irc.py
@@ -24,6 +24,7 @@ import json
 import time
 import sys
 import threading
+import traceback
 import gettext
 from inspect import getargspec
 from functools import wraps, partial
@@ -36,6 +37,8 @@ try:
     from irc import client
     from irc import events
 except ImportError:
+    traceback.print_exc()
+    print "No IRC support"
     HAVE_IRC = False
 else:
     HAVE_IRC = True
@@ -46,6 +49,7 @@ from .gtkstuff import DefaultEntry
 from .gtkstuff import NamedTreeRowReference
 from .gtkstuff import ConfirmationDialog
 from .gtkstuff import threadslock, gdklock
+from .gtkstuff import timeout_add, source_remove
 from .utils import string_multireplace
 from .tooltips import set_tip
 
@@ -81,13 +85,15 @@ MESSAGE_CATEGORIES = (
         # TC: IRC message subcategory, triggered once when the stream starts.
         _("On stream up"),
         # TC: IRC message subcategory, triggered once at the stream's end.
-        _("On stream down"))
+        _("On stream down"),
+        # TC: IRC message subcategory, triggered once at the stream's end.
+        _("Operations"))
 
 ASCII_C0 = "".join(chr(x) for x in range(32))
 
-CODES_AND_DESCRIPTIONS = zip((u"%r", u"%t", u"%l", u"%s", u"%n", u"%d", u"%u"),
+CODES_AND_DESCRIPTIONS = zip((u"%r", u"%t", u"%l", u"%s", u"%n", u"%d", u"%u", u"%U"),
         (_('Artist'), _('Title'), _('Album'), _('Song name'),
-         _('DJ name'), _('Description'), _('Listen URL')))
+         _('DJ name'), _('Description'), _('Listen URL'), _('Source URI')))
 
 
 class IRCEntry(gtk.Entry):  # pylint: disable=R0904
@@ -534,10 +540,11 @@ message_offset_adj = gtk.Adjustment(0, 0, 9999, 1, 10)
 message_interval_adj = gtk.Adjustment(600, 60, 9999, 1, 10)
 
 
-class MessageDialog(gtk.Dialog):
-    """Base class for a message creation dialog."""
+class ChannelsDialog(gtk.Dialog):
+    """Channels entry dialog."""
     
     icon = gtk.STOCK_NEW
+    title = "missing title"
 
     def __init__(self, title=None):
         if title is None:
@@ -546,56 +553,84 @@ class MessageDialog(gtk.Dialog):
         gtk.Dialog.__init__(
                         self, title + " - IDJC" + ProfileManager().title_extra)
 
-        hbox1 = gtk.HBox()
-        hbox1.set_spacing(6)
+        chbox = gtk.HBox()
+        chbox.set_spacing(6)
         # TC: An IRC channel #chan or user name entry box label.
         l = gtk.Label(_("Channels/Users"))
         self.channels = gtk.Entry()
-        hbox1.pack_start(l, False)
-        hbox1.pack_start(self.channels, True)
+        chbox.pack_start(l, False)
+        chbox.pack_start(self.channels, True)
         set_tip(self.channels, _("The comma or space separated list of channels"
         " and/or users to whom the message will be sent.\n\nProtected channels "
         "are included with the form:\n#channel:keyword."))
         
-        hbox2 = gtk.HBox()
-        hbox2.set_spacing(6)
+        self.mainbox = gtk.VBox()
+        self.mainbox.set_spacing(5)
+        self.mainbox.pack_start(chbox, False)
+        
+        self.hbox = gtk.HBox()
+        self.hbox.set_border_width(16)
+        self.hbox.set_spacing(5)
+        self.image = gtk.image_new_from_stock(self.icon, gtk.ICON_SIZE_DIALOG)
+        self.image.set_alignment(0.5, 0)
+        self.hbox.pack_start(self.image, False, padding=20)
+        self.hbox.pack_start(self.mainbox)
+       
+        self.get_content_area().add(self.hbox)
+        self.channels.grab_focus()
+        
+    def _from_channels(self):
+        text = self.channels.get_text().replace(",", " ").split()
+        return ",".join(x for x in text if x)
+
+    def as_tuple(self):
+        """Data extraction method."""
+
+        return (self._from_channels(),)
+
+
+class EditChannelsDialog(ChannelsDialog, EditDialogMixin):
+    """Adds delete and restore buttons to a channels dialog."""
+    
+    icon = gtk.STOCK_EDIT
+
+    def __init__(self, title, orig_data):
+        ChannelsDialog.__init__(self, title)
+        EditDialogMixin.__init__(self, orig_data)
+        
+    def from_tuple(self, orig_data):
+        """The data restore method."""
+        
+        self.channels.set_text(orig_data[0])
+
+
+class MessageDialog(ChannelsDialog):
+    """Message entry dialog."""
+    
+    def __init__(self, title=None):
+        ChannelsDialog.__init__(self, title)
+        
+        hbox = gtk.HBox()
+        hbox.set_spacing(6)
         # TC: Message text to send to an IRC channel. Widget label.
         l = gtk.Label(_("Message"))
         self.message = IRCEntry()
-        hbox2.pack_start(l, False)
-        hbox2.pack_start(self.message)
+        hbox.pack_start(l, False)
+        hbox.pack_start(self.message)
         set_tip(self.message, _("The message to send.\n\nOn the pop-up window "
         "(mouse right click) are some useful options for embedding metadata and"
         " for text formatting.\n\nThe window below displays how the message "
         "will appear to users of XChat."))
+        self.mainbox.pack_start(hbox, False)
         
         sw = gtk.ScrolledWindow()
         sw.set_policy(gtk.POLICY_NEVER, gtk.POLICY_ALWAYS)
         irc_view = IRCView()
         sw.add(irc_view)
-        vbox = gtk.VBox()
-        vbox.set_spacing(5)
-        vbox.pack_start(hbox1, False)
-        vbox.pack_start(hbox2, False)
-        vbox.pack_start(sw)
-        
-        self.hbox = gtk.HBox()
-        self.hbox.set_border_width(16)
-        self.hbox.set_spacing(5)
-        self.image = gtk.image_new_from_stock(self.icon, gtk.ICON_SIZE_DIALOG)
-        self.image.set_alignment(0.5, 0)
-        self.hbox.pack_start(self.image, False, padding=20)
-        self.hbox.pack_start(vbox)
+        self.mainbox.pack_start(sw, False)
         
         self.message.connect("changed", 
                                     lambda w: irc_view.set_text(w.get_text()))
-        
-        self.get_content_area().add(self.hbox)
-        self.channels.grab_focus()
-        
-    def _from_channels(self):
-        text = self.channels.get_text().replace(",", " ").split()
-        return ",".join(x for x in text if x)
 
     def _pack(self, widgets):
         vbox = gtk.VBox()
@@ -818,7 +853,9 @@ class IRCRowReference(NamedTreeRowReference):
         
         7: {"channels":5, "message":6},
 
-        9: {"channels":5, "message":6}
+        9: {"channels":5, "message":6},
+        
+        11: {"channels":5}
         }
 
     def get_index_for_name(self, tree_row_ref, name):
@@ -1029,25 +1066,31 @@ class IRCPane(gtk.VBox):
                     text += " " + ", ".join(opt)
             else:
                 channels = row.channels
-                message = row.message
+
+                if row.type < 11:
+                    message = row.message
                 
-                if row.type == 3:
-                    text = "+%d;%s; %s" % (row.delay, channels, message)
-                elif row.type == 5:
-                    text = "%d/%d;%s; %s" % (
-                                    row.offset, row.interval, channels, message)
-                else:
-                    text = channels + "; " + message
+                    if row.type == 3:
+                        text = "+%d;%s; %s" % (row.delay, channels, message)
+                    elif row.type == 5:
+                        text = "%d/%d;%s; %s" % (
+                                row.offset, row.interval, channels, message)
+                    elif row.type in (7, 9):
+                        text = channels + "; " + message
+                elif row.type == 11:
+                    text = channels
         else:
             text = (("Server", ) + MESSAGE_CATEGORIES)[row.type / 2]
 
         cell.props.text = text
 
 
-    # TC: Expander text encapsulating messages that play when stream goes up.
+    # TC: Dialog title text.
     _dsu = _("IRC stream up message")
-    # TC: Expander text encapsulating messages that play when stream goes down.
+    # TC: Dialog title text.
     _dsd = _("IRC stream down message")
+    # TC: Dialog title text.
+    _dso = _("IRC station operations")
 
     @glue
     def _on_new(self, mode, model, iter, dialog):
@@ -1060,28 +1103,32 @@ class IRCPane(gtk.VBox):
         elif mode in (6, 8):
             title = self._dsu if mode == 6 else self._dsd
             dialog(MessageDialog(title), self._add_message, mode)
+        elif mode == 10:
+            dialog(ChannelsDialog(self._dso), self._add_channels, mode)
         else:
-            if mode / 2 < len(MESSAGE_CATEGORIES):
-                print "there is no data entry dialog implemented for the '%s'" \
-                            " message category" % MESSAGE_CATEGORIES[mode / 2]
-            else:
-                print "unknown message category with numerical code,", mode
+            self._unhandled_mode(mode)
 
     @glue
     def _on_edit(self, mode, model, iter, dialog):
+        row = tuple(model[model.get_path(iter)])
+        
         if mode == 1:
-            dialog(EditServerDialog(tuple(model[model.get_path(iter)])[2:14]),
-                                                    self._standard_edit, 2)
-        if mode == 3:
-            dialog(EditAnnounceMessageDialog(tuple(model[model.get_path(iter)])
-                                                [4:7]), self._standard_edit, 4)
-        if mode == 5:
-            dialog(EditTimerMessageDialog(tuple(model[model.get_path(iter)])
-                                                [3:7]), self._standard_edit, 3)
-        if mode in (7, 9):
+            dialog(EditServerDialog(row[2:14]), self._standard_edit, 2)
+        elif mode == 3:
+            dialog(EditAnnounceMessageDialog(row[4:7]), self._standard_edit, 4)
+        elif mode == 5:
+            dialog(EditTimerMessageDialog(row[3:7]), self._standard_edit, 3)
+        elif mode in (7, 9):
             title = self._dsu if mode == 7 else self._dsd
-            dialog(EditMessageDialog(title, tuple(
-                model[model.get_path(iter)])[5:7]), self._standard_edit, 5)
+            dialog(EditMessageDialog(title, row[5:7]), self._standard_edit, 5)
+        elif mode == 11:
+            dialog(EditChannelsDialog(self._dso, row[5:6]), self._standard_edit, 5)
+        else:
+            self._unhandled_mode(mode)
+
+    @staticmethod
+    def _unhandled_mode(mode):
+        print "unhandled message category with numerical code,", mode
 
     def _standard_edit(self, d, model, iter, start):
         model.row_changed_block()
@@ -1120,6 +1167,11 @@ class IRCPane(gtk.VBox):
         return model.insert(parent_iter, 0, (mode + 1, 1, 0, 0, 0) 
                                                 + d.as_tuple() + ("", ) * 8)
 
+    @highlight
+    def _add_channels(self, d, model, parent_iter, mode):
+        return model.insert(parent_iter, 0, (mode + 1, 1, 0, 0, 0) 
+                                                + d.as_tuple() + ("", ) * 9)
+
 
 class ConnectionsController(list):
     """Layer between the user interface and the ServerConnection classes.
@@ -1184,8 +1236,12 @@ class IRCConnection(gtk.TreeRowReference, threading.Thread):
         self._keepalive = True
         self._have_welcome = False
         self._stream_active = stream_active
-        self.irc = client.IRC()
-        self.server = self.irc.server()
+        try:
+            self.reactor = client.Reactor()
+        except AttributeError:
+            self.reactor = client.IRC()  # Old API compatibility
+            
+        self.server = self.reactor.server()
         self.start()
         self._hooks.append((model, model.connect("row-inserted",
                                                         self._on_row_inserted)))
@@ -1333,9 +1389,9 @@ class IRCConnection(gtk.TreeRowReference, threading.Thread):
             while len(self._queue):
                 self._queue.pop(0)()
             
-            self.irc.process_once(0.2)
+            self.reactor.process_once(0.2)
         
-        self.irc.process_once()
+        self.reactor.process_once()
 
     def cleanup(self):
         for each in self._message_handlers:
@@ -1542,10 +1598,10 @@ class MessageHandler(gobject.GObject):
     def stream_active(self):
         return self._stream_active
 
-    subst_keys = ("artist", "title", "album", "songname",
-                                                "djname", "description", "url")
+    subst_keys = ("artist", "title", "album", "songname", "djname",
+                                    "description", "url", "source")
 
-    subst_tokens = ("%r", "%t", "%l", "%s", "%n", "%d", "%u")
+    subst_tokens = ("%r", "%t", "%l", "%s", "%n", "%d", "%u", "%U")
 
     subst = dict.fromkeys(subst_keys, "<No data>")
 
@@ -1624,7 +1680,7 @@ class MessageHandler(gobject.GObject):
         else:
             raise AttributeError("unknown property '%s'" % prop.name)
 
-    def issue_messages(self, delay_calc=lambda row: 0):
+    def issue_messages(self, delay_calc=lambda row: 0, forced_message=None):
         model = self.tree_row_ref.get_model()
         iter = model.get_iter(self.tree_row_ref.get_path())
         iter = model.iter_children(iter)
@@ -1637,7 +1693,10 @@ class MessageHandler(gobject.GObject):
                     targets = [x.split("!")[0] for x in row.channels.split(",")]
                     table = [("%%", "%")] + zip(self.subst_tokens, (
                                         self.subst[x] for x in self.subst_keys))
-                    message = string_multireplace(row.message, table)
+                    if forced_message is not None:
+                        message = string_multireplace(forced_message, table)
+                    else:
+                        message = string_multireplace(row.message, table)
                     self.emit("privmsg-ready", targets, message, delay_s)
           
             iter = model.iter_next(iter)
@@ -1657,11 +1716,11 @@ class MessageHandlerForType_5(MessageHandler):
             self.on_stream_active()
 
     def on_stream_active(self):
-        self._timeout_id = gobject.timeout_add(500, self._timeout)
+        self._timeout_id = timeout_add(500, self._timeout)
 
     def on_stream_inactive(self):
         if self._timeout_id is not None:
-            gobject.source_remove(self._timeout_id)
+            source_remove(self._timeout_id)
             self._timeout_id = None
 
     @threadslock
@@ -1680,7 +1739,7 @@ class MessageHandlerForType_5(MessageHandler):
             
     def cleanup(self):
         if self._timeout_id is not None:
-            gobject.source_remove(self._timeout_id)
+            source_remove(self._timeout_id)
 
 
 class MessageHandlerForType_7(MessageHandler):
@@ -1691,3 +1750,10 @@ class MessageHandlerForType_7(MessageHandler):
 class MessageHandlerForType_9(MessageHandler):
     def on_stream_inactive(self):
         self.issue_messages()
+
+class MessageHandlerForType_11(MessageHandler):
+    def on_stream_active(self):
+        self.issue_messages(forced_message="!handover acquired %U")
+    
+    def on_stream_inactive(self):
+        self.issue_messages(forced_message="!handover dropped %U")
diff --git a/python/jingles.py b/python/jingles.py
index 1a39e4e..56f1d85 100644
--- a/python/jingles.py
+++ b/python/jingles.py
@@ -34,6 +34,7 @@ from .gtkstuff import LEDDict
 from .gtkstuff import WindowSizeTracker
 from .gtkstuff import DefaultEntry
 from .gtkstuff import threadslock
+from .gtkstuff import timeout_add, source_remove
 from .tooltips import set_tip
 from .utils import LinkUUIDRegistry
 
@@ -222,7 +223,7 @@ class Effect(gtk.HBox):
                 if self.effect_length == 0.0:
                     self.effect_length = self.interlude.get_media_metadata(self.pathname, True)
                 self.effect_start = time.time()
-                self.timeout_source_id = gobject.timeout_add(playergui.PROGRESS_TIMEOUT,
+                self.timeout_source_id = timeout_add(playergui.PROGRESS_TIMEOUT,
                                 self._progress_timeout)
                 self.tabeffectname.set_text(self.trigger_label.get_text())
                 self.tabeffecttime.set_text('0.0')
@@ -258,7 +259,7 @@ class Effect(gtk.HBox):
 
     def _stop_progress(self):
         if self.timeout_source_id:
-            gobject.source_remove(self.timeout_source_id)
+            source_remove(self.timeout_source_id)
             self.timeout_source_id = None
             self.progress.set_fraction(0.0)
             self.approot.jingles.nb_effects_box.remove(self.tabwidget)
diff --git a/python/maingui.py b/python/maingui.py
index 2d09228..b80eccd 100644
--- a/python/maingui.py
+++ b/python/maingui.py
@@ -53,6 +53,7 @@ from .utils import PathStr
 from .gtkstuff import threadslock, WindowSizeTracker, ConfirmationDialog
 from .gtkstuff import IconChooserButton, IconPreviewFileChooserDialog, LEDDict
 from .gtkstuff import LabelSubst, gdklock, nullcm
+from .gtkstuff import idle_add, timeout_add, timeout_add_seconds, source_remove
 from . import midicontrols
 from .tooltips import set_tip
 from . import songdb
@@ -728,7 +729,7 @@ class OpenerTab(gtk.VBox):
         self.pack_start(self.is_microphone, False)
         
         self.freewheel_cancel = gtk.CheckButton(
-                    'This button will automatically cancel JACK freewheel mode')
+                _('This button will automatically cancel JACK freewheel mode'))
         self.pack_start(self.freewheel_cancel, False)
         set_tip(self.freewheel_cancel, _('This should be set for all buttons'
                 ' that control input from a live sound source or device.'))
@@ -1180,8 +1181,8 @@ class MicOpener(gtk.HBox):
         self._flashing_mode = False
         self._flashing_timer = 0
         self._headroom = 0.0
-        timeout = glib.timeout_add(700, self.cb_flash_timeout)
-        self.connect("destroy", lambda w: glib.source_remove(timeout))
+        timeout = timeout_add(700, self.cb_flash_timeout)
+        self.connect("destroy", lambda w: source_remove(timeout))
         self.opener_settings = OpenerSettings()
         self.opener_settings.connect("changed", self.cb_reconfigure)
 
@@ -2034,6 +2035,20 @@ class MainWindow(dbus.service.Object):
 
             print "song title: %s\n" % self.songname
 
+    @dbus.service.method(dbus_interface=PGlobs.dbus_bus_basename)
+    def new_plugin_started(self):
+        self.channel_states = [-1, ] * 12
+        self.dbus_voip_mode = -1
+
+    @dbus.service.signal(dbus_interface=PGlobs.dbus_bus_basename, signature="u")
+    def voip_mode_changed(self, mode):
+        pass
+
+    @dbus.service.method(dbus_interface=PGlobs.dbus_bus_basename,
+                                                            out_signature="s")
+    def get_database_credentials(self):
+        return json.dumps(self.topleftpane.prefs_controls.credentials())
+
     @dbus.service.method(dbus_interface=PGlobs.dbus_bus_basename,
                                                         in_signature="sssssb")
     def set_track_metadata(self, artist, title, album, songname, filename, log):
@@ -2083,6 +2098,12 @@ class MainWindow(dbus.service.Object):
         """DBus signal for plugins to attach to when new effects play"""
         pass
 
+    @dbus.service.signal(dbus_interface=PGlobs.dbus_bus_basename,
+                                                            signature="ub")
+    def channelstate_changed(self, index, is_open):
+        """DBus signal indicating audio channel toggle state"""
+        self.channel_states[index] = is_open
+
     def songname_decode(self, data):
         i = 1
         while 1:
@@ -2159,7 +2180,7 @@ class MainWindow(dbus.service.Object):
             time_lag = 0
         else:
             time_lag = int(time_lag / player.pbspeedfactor)
-        gobject.timeout_add(time_lag, self.new_songname_timeout,
+        timeout_add(time_lag, self.new_songname_timeout,
                         (song, artist, title, album, player, player_context))
 
     @threadslock
@@ -2226,7 +2247,7 @@ class MainWindow(dbus.service.Object):
                 self.player_right.advance()
         if data.startswith("cfm"):
             if self.crosspass:
-                gobject.source_remove(self.crosspass)
+                source_remove(self.crosspass)
                 self.crosspass = 0
             self.crossfade.set_value(data == "cfmright" and 100 \
                                     or data == "cfmmidl" and 48 \
@@ -2237,7 +2258,7 @@ class MainWindow(dbus.service.Object):
                 self.crossdirection = not self.crossdirection
             else:
                 self.crossdirection = (self.crossadj.get_value() <= 50)
-                self.crosspass = gobject.timeout_add(
+                self.crosspass = timeout_add(
                 int(self.passspeed_adj.get_value() * 10), self.cb_crosspass)
         if data == "Clear History":
             self.history_buffer.set_text("")
@@ -2568,7 +2589,7 @@ class MainWindow(dbus.service.Object):
         self.freewheel_button.set_active(False)
         self.save_session("atexit")
         if self.crosspass:
-            gobject.source_remove(self.crosspass)
+            source_remove(self.crosspass)
         self.server_window.cleanup()
         self.mic_opener.close_all()
         self.player_left.cleanup()
@@ -2578,9 +2599,9 @@ class MainWindow(dbus.service.Object):
         self.player_right.flush = True
         self.send_new_mixer_stats()
         self.prefs_window.songdbprefs.disconnect()
-        gobject.source_remove(self.statstimeout)
-        gobject.source_remove(self.vutimeout)
-        gobject.source_remove(self.savetimeout)
+        source_remove(self.statstimeout)
+        source_remove(self.vutimeout)
+        source_remove(self.savetimeout)
         self._mixer_ctrl.close()
         self.quitting()
         self.window.hide()
@@ -2609,6 +2630,12 @@ class MainWindow(dbus.service.Object):
 
         pass
 
+    @dbus.service.signal(dbus_interface=PGlobs.dbus_bus_basename, signature="")
+    def tracks_finishing(self):
+        """Called to notify DJ that music tracks are ending."""
+        
+        pass
+
     @dbus.service.method(dbus_interface=PGlobs.dbus_bus_basename, out_signature="u")
     def pid(self):
         """Reply with the process ID."""
@@ -2874,7 +2901,16 @@ class MainWindow(dbus.service.Object):
                 player.check_mixer_signal()
             elif player.pl_mode.get_active() == 0:
                 player.update_time_stats()
-                
+
+        ch = self.mic_opener.mic_list
+        for i in xrange(PGlobs.num_micpairs * 2):
+            if self.channel_states[i] == -1:
+                ch[i].open.emit("toggled")
+
+        if self.dbus_voip_mode != self.mixermode:
+            self.dbus_voip_mode = self.mixermode
+            self.voip_mode_changed(self.mixermode)
+
         return True
 
 
@@ -3769,6 +3805,8 @@ class MainWindow(dbus.service.Object):
         self.jingles.interlude.silence = SlotObject(0.0)
         self.sample_rate = SlotObject(0)
         self.effects_playing = SlotObject(0)
+        self.channel_states = [-1, ] * 12
+        self.dbus_voip_mode = -1
         
         self.feature_set = gtk.ToggleButton()
         self.feature_set.set_active(True)
@@ -3854,15 +3892,14 @@ class MainWindow(dbus.service.Object):
         self.prefs_window.load_player_prefs()
         self.prefs_window.apply_player_prefs()
 
-        self.vutimeout = gobject.timeout_add(50, self.vu_update)
-        self.statstimeout = gobject.timeout_add(100, self.stats_update)
+        self.vutimeout = timeout_add(50, self.vu_update)
+        self.statstimeout = timeout_add(100, self.stats_update)
 
-        self.savetimeout = gobject.timeout_add_seconds(
+        self.savetimeout = timeout_add_seconds(
                                 120, threadslock(self.save_session), "periodic")
 
         for sig in (signal.SIGINT, signal.SIGTERM, signal.SIGHUP):
-            signal.signal(sig, lambda s, f: glib.idle_add(
-                                                    threadslock(self.destroy)))
+            signal.signal(sig, lambda s, f: idle_add(threadslock(self.destroy)))
         
         (self.full_wst, self.min_wst)[bool(self.simplemixer)].apply()
         self.window.connect("configure_event", self.configure_event)
@@ -3894,7 +3931,7 @@ class MainWindow(dbus.service.Object):
         self.window.connect("key-release-event", self.cb_key_capture)
       
         self.window.show()
-        gobject.idle_add(lambda: self.prefs_window.window.realize() and False)
+        idle_add(lambda: self.prefs_window.window.realize() and False)
         
         self.player_left.treeview.emit("cursor-changed")
         self.player_right.treeview.emit("cursor-changed")
diff --git a/python/midicontrols.py b/python/midicontrols.py
index c9a4eaf..9fb0e5c 100644
--- a/python/midicontrols.py
+++ b/python/midicontrols.py
@@ -32,6 +32,7 @@ import dbus.service
 
 from idjc import FGlobs, PGlobs
 from .gtkstuff import threadslock
+from .gtkstuff import timeout_add, source_remove
 from .prelims import ProfileManager
 from .tooltips import set_tip
 
@@ -2167,9 +2168,8 @@ class BindingListModel(gtk.GenericTreeModel):
         self.highlights= owner.owner.highlights
         
     def on_realize(self, tree, column0, model_sort):
-        source= gobject.timeout_add(
-                            100, self.cb_highlights, tree, column0, model_sort)
-        tree.connect_object('destroy', gobject.source_remove, source)
+        source= timeout_add(100, self.cb_highlights, tree, column0, model_sort)
+        tree.connect_object('destroy', source_remove, source)
         
     @threadslock
     def cb_highlights(self, tree, column0, model_sort):
diff --git a/python/playergui.py b/python/playergui.py
index a027c6b..fbbe24d 100644
--- a/python/playergui.py
+++ b/python/playergui.py
@@ -53,6 +53,7 @@ from .utils import SlotObject
 from .utils import LinkUUIDRegistry
 from .utils import PathStr
 from .gtkstuff import threadslock, FolderChooserButton
+from .gtkstuff import idle_add, timeout_add, source_remove, nullcm, gdklock
 from .prelims import *
 from .tooltips import set_tip
 
@@ -66,9 +67,9 @@ def N_(text):
 
 PM = ProfileManager()
 
+EasyID3.RegisterTXXXKey('TXXX_replaygain_track_gain', 'replaygain_track_gain')
 link_uuid_reg = LinkUUIDRegistry()
 
-
 # Suppress the warning that occurs when None is placed in a ListStore element
 # where some kind of GObject is expected.
 warnings.filterwarnings("ignore",
@@ -427,9 +428,8 @@ class ExternalPL(gtk.Frame):
         self.active.show()
 
         filefilter = gtk.FileFilter()
-        filefilter.add_pattern("*.m3u")
-        filefilter.add_pattern("*.pls")
-        filefilter.add_pattern("*.xspf")
+        for each in supported.playlists:
+            filefilter.add_pattern(each)
 
         self.filechooser = gtk.FileChooserDialog(title = 
         _('Choose a playlist file') + PM.title_extra, buttons = \
@@ -482,7 +482,7 @@ class AnnouncementDialog(gtk.Dialog):
         gtk.Dialog.destroy(self)
 
     def timeout_remove(self, widget):
-        gobject.source_remove(self.timeout)
+        source_remove(self.timeout)
 
     def timer_update(self, lock=True):
         with (gdklock if lock else nullcm)():
@@ -540,6 +540,7 @@ class AnnouncementDialog(gtk.Dialog):
         ivbox.pack_start(sw, True, True, 0)
         sw.show()
         self.tv = gtk.TextView()
+        self.tv.set_wrap_mode(gtk.WRAP_WORD_CHAR)
         if mode == "active":
             self.tv.unset_flags(gtk.CAN_FOCUS)
         sw.add(self.tv)
@@ -582,7 +583,7 @@ class AnnouncementDialog(gtk.Dialog):
                 self.countdownlabel.set_attributes(self.attrlist)
                 self.oldinttime = -2
                 self.timer_update(False)
-                self.timeout = gobject.timeout_add(100, self.timer_update)
+                self.timeout = timeout_add(100, self.timer_update)
                 self.connect("destroy", self.timeout_remove)
                 chbox.pack_start(self.countdownlabel, True, False, 0)
                 self.countdownlabel.show()
@@ -665,7 +666,7 @@ class Supported(object):
 
     def __init__(self):
         self.media = [".ogg", ".oga", ".wav", ".aiff", ".au", ".txt", ".cue"]
-        self.playlists = [".m3u", ".xspf", ".pls"]
+        self.playlists = [".m3u", ".m3u8", ".xspf", ".pls"]
 
         if FGlobs.have_libmpg123:
             self.media.insert(0, ".mp3")
@@ -930,9 +931,9 @@ class CueSheet(object):
 class IDJC_Media_Player:
     playlisttype_extension = tuple(zip(
         # File format selection items from a list (user can pick only one).
-        (_('By Extension'), _('M3U playlist'),
+        (_('By Extension'), _('M3U playlist'), _('M3U8 playlist'),
         _('XSPF playlist'), _('PLS playlist')),
-        ('', 'm3u', 'xspf', 'pls'),))
+        ('', 'm3u', 'm3u8', 'xspf', 'pls'),))
 
     def make_cuesheet_playlist_entry(self, cue_pathname):
         cuesheet_liststore = CueSheetListStore()
@@ -1036,7 +1037,10 @@ class IDJC_Media_Player:
 
         # Strip away any file:// prefix
         if filename.count("file://", 0, 7):
-            filename = filename[7:]
+            host, filename = filename[7:].split("/", 1)
+            filename = "/" + urllib.unquote(filename)
+            if host not in ("", "localhost", "127.0.0.1", "::1"):
+                return NOTVALID._replace(filename=filename)
         elif filename.count("file:", 0, 5):
             filename = filename[5:]
 
@@ -1054,6 +1058,50 @@ class IDJC_Media_Player:
                             _('Bad Tag'), glib.markup_escape_text(meta_name))
         title_retval = meta_name
 
+        def gain(handle=None, prefix="", gain=None, ref=None):
+            try:
+                if ref is None:
+                    ref = str(handle[prefix + "REPLAYGAIN_REFERENCE_LOUDNESS"][0])
+            except Exception:
+                ref = None
+            else:
+                try:
+                    ref = float(ref.rstrip("dbDBLUlu"))
+                except Exception:
+                    ref = None
+                else:
+                    ref = "R128" if -23.1 < ref < -22.9 else "RG"
+
+            if gain is None:
+                gain = str(handle[prefix + "REPLAYGAIN_TRACK_GAIN"][0]).rstrip().upper()
+            else:
+                gain = gain.upper()
+            if gain.endswith("DB"):
+                if ref is None or ref == "RG":
+                    gain = gain[:-2] + "RG"
+                else:
+                    gain = gain[:-2] + "R128"
+            elif gain.endswith("LU"):
+                if ref is None or ref == "R128":
+                    gain = gain[:-2] + "R128"
+                else:
+                    gain = gain[:-2] + "RG"
+            else:
+                if ref is None or ref == "RG":
+                    gain += " RG"
+                else:
+                    gain += " R128"
+            
+            try:
+                v1, v2 = gain.split()
+                if v2 not in ("RG", "R128"):
+                    raise Exception
+                float(v1)
+            except Exception:
+                return RGDEF
+                    
+            return gain
+                    
 
         # Obtain as much metadata from ubiquitous tags as possible.
         # Files can have ape and id3 tags. ID3 has priority in this case.
@@ -1064,7 +1112,7 @@ class IDJC_Media_Player:
             artist = title = ""
         else:
             try:
-                rg = str(audio["REPLAYGAIN_TRACK_GAIN"][0].rstrip(" dB")) + " RG"
+                rg = gain(audio)
             except:
                 rg = RGDEF
             artist = audio.get("ARTIST", [u""])
@@ -1077,9 +1125,12 @@ class IDJC_Media_Player:
             pass
         else:
             try:
-                rg = str(audio["replaygain_track_gain"][0].rstrip(" dB")) + " RG"
+                rg = gain(audio, "TXXX_")
             except:
-                pass
+                try:
+                    rg = gain(audio)
+                except:
+                    pass
             try:
                 artist = audio["artist"]
             except:
@@ -1119,6 +1170,10 @@ class IDJC_Media_Player:
         elif filext == ".ogg" or filext == ".oga" or filext == ".spx":
             self.parent.mixer_write("OGGP=%s\nACTN=ogginforequest\nend\n" %
                                                                     filename)
+            
+            gval = None
+            ref = None
+            
             while 1:
                 line = self.parent.mixer_read()
                 if line == "OIR:NOT VALID\n" or line == "":
@@ -1132,13 +1187,17 @@ class IDJC_Media_Player:
                 if line.startswith("OIR:LENGTH="):
                     length = float(line[11:].strip())
                 if line.startswith("OIR:REPLAYGAIN_TRACK_GAIN="):
-                    val = line[26:].rstrip(" dB\n")
-                    if not val:
-                        rg = RGDEF
-                    else:
-                        rg = val + " RG"
+                    gval = line[26:].rstrip()
+                if line.startswith("OIR:REPLAYGAIN_REFERENCE_LOUDNESS="):
+                    ref = line[34:].rstrip()
                 if line == "OIR:end\n":
                     break
+ 
+            if gval is None:
+                rg = RGDEF
+            else:
+                rg = gain(gain=gval, ref=ref)
+ 
         elif filext == ".aac":
             try:
                 id3 = ID3(filename)
@@ -1204,8 +1263,7 @@ class IDJC_Media_Player:
                         album = "/".join((unicode(y) for y in x))
 
                     try:
-                        rg = str(unicode(audio["replaygain_track_gain"][-1]
-                                                    ).rstrip(" dB")) + " RG"
+                        rg = gain(audio)
                     except:
                         pass
 
@@ -1425,7 +1483,7 @@ class IDJC_Media_Player:
             print self.playername + (" player: the stored playlist data is not "
                                     "compatible with this version\nfiles placed"
                                     " in a queue for rescanning")
-            gobject.idle_add(self.cb_playlist_todo)
+            idle_add(self.cb_playlist_todo)
 
     @threadslock
     def cb_playlist_todo(self):
@@ -1490,7 +1548,7 @@ class IDJC_Media_Player:
         if self.is_playing == True:
             self.is_playing = False
             if self.timeout_source_id:
-                gobject.source_remove(self.timeout_source_id)
+                source_remove(self.timeout_source_id)
             # This will enable the play button to be toggled off.
             self.is_stopping = True
             self.play.set_active(False)
@@ -1685,12 +1743,12 @@ class IDJC_Media_Player:
             print "player startup was unsuccessful for file", \
                                                             self.music_filename
             # The regular code path can handle this.
-            self.timeout_source_id = gobject.idle_add(
+            self.timeout_source_id = idle_add(
                                 self.cb_play_progress_timeout, self.player_cid)
         else:
             print "player context id is %d\n" % self.player_cid
             if self.player_cid & 1:
-                self.timeout_source_id = gobject.timeout_add(PROGRESS_TIMEOUT,
+                self.timeout_source_id = timeout_add(PROGRESS_TIMEOUT,
                                 self.cb_play_progress_timeout, self.player_cid)
             else:
                 self.invoke_end_of_track_policy()
@@ -1713,7 +1771,7 @@ class IDJC_Media_Player:
 
         self.player_is_playing = False
         if self.timeout_source_id:
-            gobject.source_remove(self.timeout_source_id)
+            source_remove(self.timeout_source_id)
 
         self.progress_current_figure = 0
         self.playtime_elapsed.set_value(0)
@@ -1738,7 +1796,7 @@ class IDJC_Media_Player:
         print "player_restart %s" % self.playername
         self.parent.last_player = self.playername
 
-        gobject.source_remove(self.timeout_source_id)
+        source_remove(self.timeout_source_id)
         self.start_time = int (self.progressadj.get_value())
         self.silence_count = 0
 
@@ -1791,7 +1849,7 @@ class IDJC_Media_Player:
 
         print "player context id is %d\n" % self.player_cid
         # Restart a callback to update the progressbar.
-        self.timeout_source_id = gobject.timeout_add(
+        self.timeout_source_id = timeout_add(
             PROGRESS_TIMEOUT, self.cb_play_progress_timeout, self.player_cid)
         self.parent.send_new_mixer_stats()
         return True
@@ -2295,8 +2353,7 @@ class IDJC_Media_Player:
         # Calclulate whether to sound the DJ alarm (end of music notification)
         if self.playername in ("left", "right"):
             if rem == 10 and self.progressadj.upper > 11 and \
-                                self.alarm_cid != cid and \
-                                self.parent.prefs_window.djalarm.get_active():
+                                self.alarm_cid != cid:
                 # DJ Alarm is on and we are at the correct play position.
                 # The alarm has not sounded yet.
                 fader = "left" if self.parent.crossadj.value < 50.0 else "right"
@@ -2304,7 +2361,8 @@ class IDJC_Media_Player:
                 if self.playername == fader and (pl_mode in (3, 4) or
                                         (pl_mode == 0 and self.stop_inspect())):
                     self.parent.freewheel_button.set_active(False)
-                    gobject.timeout_add(1000, self.deferred_alarm)
+                    timeout_add(1000, self.deferred_alarm,
+                                self.parent.prefs_window.djalarm.get_active())
                     self.alarm_cid = cid
 
             # Check if the crossfade needs scheduling.
@@ -2330,9 +2388,12 @@ class IDJC_Media_Player:
         return True
 
     @threadslock
-    def deferred_alarm(self):
-        self.parent.alarm = True
-        self.parent.send_new_mixer_stats()
+    def deferred_alarm(self, make_sound):
+        if make_sound:
+            self.parent.alarm = True
+            self.parent.send_new_mixer_stats()
+        
+        self.parent.tracks_finishing()
         return False
 
     def stop_inspect(self):
@@ -2529,7 +2590,7 @@ class IDJC_Media_Player:
         if response_id != gtk.RESPONSE_ACCEPT:
             return
         gen = self.filter_allowed_controls(self.get_elements_from(chosenfiles))
-        glib.idle_add(self.file_response_idle, iter(gen)) 
+        idle_add(self.file_response_idle, iter(gen)) 
 
     @threadslock
     def file_response_idle(self, iterator):
@@ -2592,113 +2653,120 @@ class IDJC_Media_Player:
                 ext = useext
         chosenfile = main + ext
 
-        validlist = [x for x in self.liststore if x[0][0] != ">" and x[2] >= 0]
+        if ext != ".xspf":
+            # Filter out playlist controls.
+            data = [x for x in self.liststore if x[0][0] != ">" and x[2] >= 0]
+        else:
+            data = self.liststore
 
         print "Chosenfile is", chosenfile
         try:
-            pl = open(chosenfile, "w")
-        except IOError:
-            print "Can't open file for writing.  Permissions problem?"
-        else:
-            if (ext == ".m3u"):
-                try:
-                    pl.write("#EXTM3U\r\n")
-                    for each in validlist:
-                        pl.write("#EXTINF:%d,%s\r\n" % (each[2], each[3].decode(
-                                    "UTF-8").encode("ISO8859-1", "replace")))
-                        pl.write(each[1] + "\r\n")
-                except IndexError:
-                    pl.close()
-                except IOError:
-                    pl.close()
-                    print "That was odd\n"
-
-            if ext == ".pls":
-                pl.write("[playlist]\r\nNumberOfEntries=%d\r\n\r\n" % \
-                                                                len(validlist))
-                for i in range(1, len(validlist) + 1):
-                    each = validlist[i - 1]
-                    pl.write("File%d=%s\r\n" % (i, each[1]))
-                    pl.write("Title%d=%s\r\n" % (i, each[3]))
-                    pl.write("Length%d=%d\r\n\r\n" % (i, each[2]))
-                pl.write("Version=2\r\n")
-
-            if ext == ".xspf":
-                doc = mdom.getDOMImplementation().createDocument(
-                                    'http://xspf.org/ns/0/', 'playlist', None)
-
-                playlist = doc.documentElement
-                playlist.setAttribute('version', '1')
-                playlist.setAttribute('xmlns', 'http://xspf.org/ns/0/')
-                playlist.setAttribute(
-                                'xmlns:idjc', 'http://idjc.sourceforge.net/ns/')
-
-                trackList = doc.createElement('trackList')
-                playlist.appendChild(trackList)
-
-                for each in self.liststore:
-                    row = PlayerRow(*each)
-
-                    track = doc.createElement('track')
-                    trackList.appendChild(track)
-
-                    if row.rsmeta.startswith(">"):
-                        extension = doc.createElement('extension')
-                        track.appendChild(extension)
-                        extension.setAttribute(
-                            'application', 'http://idjc.sourceforge.net/ns/')
-
-                        pld = doc.createElementNS(
-                            'http://idjc.sourceforge.net/ns/', 'idjc:pld')
-                        extension.appendChild(pld)
-                        pld.setAttribute('rsmeta', row.rsmeta)
-                        pld.setAttribute('length', str(row.length))
+            with open(chosenfile, "w") as h:
+                if ext in (".m3u", ".m3u8"):
+                    if ext == ".m3u":
+                        proc = lambda x: x.decode("UTF-8").encode("ISO8859-1", "replace")
                     else:
-                        location = doc.createElement('location')
-                        track.appendChild(location)
-                        locationText = doc.createTextNode(
-                                            "file://" + urllib.quote(each[1]))
-                        location.appendChild(locationText)
-
-                        if each[6]:
-                            creator = doc.createElement('creator')
-                            track.appendChild(creator)
-                            creatorText = doc.createTextNode(each[6])
-                            creator.appendChild(creatorText)
-
-                        if each[5]:
-                            title = doc.createElement('title')
-                            track.appendChild(title)
-                            titleText = doc.createTextNode(each[5])
-                            title.appendChild(titleText)
-
-                        if each[9]:
-                            album = doc.createElement('album')
-                            track.appendChild(album)
-                            albumText = doc.createTextNode(each[9])
-                            album.appendChild(albumText)
-
-                        duration = doc.createElement('duration')
-                        track.appendChild(duration)
-                        durationText = doc.createTextNode(str(each[2] * 1000))
-                        duration.appendChild(durationText)
-
-                xmltext = doc.toxml("UTF-8").replace("><", ">\n<").splitlines()
-                spc = ""
-                for i in range(len(xmltext)):
-                    if xmltext[i][1] == "/":
-                        spc = spc[2:]
-                    if len(xmltext[i]) < 3 or xmltext[i].startswith("<?") or \
-                            xmltext[i][-2] == "/" or xmltext[i].count("<") == 2:
-                        xmltext[i] = spc + xmltext[i]
-                    else:
-                        xmltext[i] = spc + xmltext[i]
-                        if xmltext[i][len(spc) + 1] != "/":
-                            spc = spc + "  "
-                pl.write("\r\n".join(xmltext))
-                pl.write("\r\n")
-                doc.unlink()
-                pl.close()
+                        proc = lambda x: x
+                    self.write_m3u_playlist(h, data, proc)
+                elif ext == ".pls":
+                    self.write_pls_playlist(h, data)
+                elif ext == ".xspf":
+                    self.write_xspf_playlist(h, data)
+        except IOError:
+            print "problem writing out playlist file"
+            
+    def write_m3u_playlist(self, h, data, proc):
+        h.write("#EXTM3U\r\n")
+        for each in data:
+            h.write("#EXTINF:%d,%s\r\n" % (each[2], proc(each[3])))
+            h.write("file://" + urllib.quote(each[1]) + "\r\n")
+
+    def write_pls_playlist(self, h, data):
+        h.write("[playlist]\r\nNumberOfEntries=%d\r\n\r\n" % len(data))
+        for i in range(1, len(data) + 1):
+            each = data[i - 1]
+            h.write("File%d=%s\r\n" % (i, each[1]))
+            h.write("Title%d=%s\r\n" % (i, each[3]))
+            h.write("Length%d=%d\r\n\r\n" % (i, each[2]))
+        h.write("Version=2\r\n")
+
+    def write_xspf_playlist(self, h, data):
+        doc = mdom.getDOMImplementation().createDocument(
+                            'http://xspf.org/ns/0/', 'playlist', None)
+
+        playlist = doc.documentElement
+        playlist.setAttribute('version', '1')
+        playlist.setAttribute('xmlns', 'http://xspf.org/ns/0/')
+        playlist.setAttribute('xmlns:idjc', 'http://idjc.sourceforge.net/ns/')
+
+        trackList = doc.createElement('trackList')
+        playlist.appendChild(trackList)
+
+        for each in data:
+            row = PlayerRow(*each)
+
+            track = doc.createElement('track')
+            trackList.appendChild(track)
+
+            if row.rsmeta.startswith(">"):
+                extension = doc.createElement('extension')
+                track.appendChild(extension)
+                extension.setAttribute(
+                    'application', 'http://idjc.sourceforge.net/ns/')
+
+                pld = doc.createElementNS(
+                    'http://idjc.sourceforge.net/ns/', 'idjc:pld')
+                extension.appendChild(pld)
+                
+                for field, value in zip(row._fields, row):
+                    if isinstance(value, (str, int, float)):
+                        pld.setAttribute(field, str(value))                
+
+            else:
+                location = doc.createElement('location')
+                track.appendChild(location)
+                locationText = doc.createTextNode(
+                                    "file://" + urllib.quote(each[1]))
+                location.appendChild(locationText)
+
+                if each[6]:
+                    creator = doc.createElement('creator')
+                    track.appendChild(creator)
+                    creatorText = doc.createTextNode(each[6])
+                    creator.appendChild(creatorText)
+
+                if each[5]:
+                    title = doc.createElement('title')
+                    track.appendChild(title)
+                    titleText = doc.createTextNode(each[5])
+                    title.appendChild(titleText)
+
+                if each[9]:
+                    album = doc.createElement('album')
+                    track.appendChild(album)
+                    albumText = doc.createTextNode(each[9])
+                    album.appendChild(albumText)
+
+                duration = doc.createElement('duration')
+                track.appendChild(duration)
+                durationText = doc.createTextNode(str(each[2] * 1000))
+                duration.appendChild(durationText)
+
+        xmltext = doc.toxml("UTF-8").replace("><", ">\n<").splitlines()
+        spc = ""
+        for i in range(len(xmltext)):
+            if xmltext[i][1] == "/":
+                spc = spc[2:]
+            if len(xmltext[i]) < 3 or xmltext[i].startswith("<?") or \
+                    xmltext[i][-2] == "/" or xmltext[i].count("<") == 2:
+                xmltext[i] = spc + xmltext[i]
+            else:
+                xmltext[i] = spc + xmltext[i]
+                if xmltext[i][len(spc) + 1] != "/":
+                    spc = spc + "  "
+        h.write("\r\n".join(xmltext))
+        h.write("\r\n")
+        doc.unlink()
 
     def plfile_destroy(self, widget):
         self.showing_pl_save_requester = False
@@ -2779,13 +2847,13 @@ class IDJC_Media_Player:
             if callback_data == "ProgressPress":
                 self.progress_press = True
                 if self.timeout_source_id:
-                    gobject.source_remove(self.timeout_source_id)
+                    source_remove(self.timeout_source_id)
             elif callback_data == "ProgressRelease":
                 self.progress_press = False
                 if self.player_is_playing:
                     self.progress_current_figure = self.progressadj.get_value()
                     self.handle_motion_as_drop = True
-                    gobject.idle_add(self.player_progress_value_changed_emitter)
+                    idle_add(self.player_progress_value_changed_emitter)
         return False
 
     @threadslock
@@ -2806,7 +2874,7 @@ class IDJC_Media_Player:
             ext = os.path.splitext(pathnames[0])[1]
             if ext in (".cue", ".txt"):
                 return self.get_elements_from_cue(pathnames[0])
-            if ext == ".m3u":
+            elif ext in (".m3u", ".m3u8"):
                 return self.get_elements_from_m3u(pathnames[0])
             elif ext == ".pls":
                 return self.get_elements_from_pls(pathnames[0])
@@ -2879,11 +2947,18 @@ class IDJC_Media_Player:
             return
         basepath = os.path.split(filename)[0] + "/"
         data = data.splitlines()
+        
         for line, each in enumerate(data):
             if each[0] == "#":
                 continue
             if each[0] != "/":
-                each = basepath + each
+                if each.startswith("file://"):
+                    host, abspathname = each[7:].split("/", 1)
+                    if host not in ("", "localhost", "127.0.0.1", "::1"):
+                        continue
+                    each = "/" + urllib.unquote(abspathname)
+                else:
+                    each = basepath + each
             # handle special case of a single element referring to a directory
             if line == 0 and len(data) == 1 and os.path.isdir(each):
                 gen = self.get_elements_from_directory(each)
@@ -3083,7 +3158,7 @@ class IDJC_Media_Player:
                 try:
                     path, pos = treeview.get_dest_row_at_pos(x, y)
                 except (ValueError, TypeError):
-                    glib.idle_add(self.file_response_idle, elements)
+                    idle_add(self.file_response_idle, elements)
                 else:
                     for element in elements:
                         model = treeview.get_model()
@@ -3094,7 +3169,7 @@ class IDJC_Media_Player:
                         else:
                             iter_ = model.insert_after(iter_, element)
                             
-                        glib.idle_add(self.drag_data_received_data_idle,
+                        idle_add(self.drag_data_received_data_idle,
                                                         model, iter_, elements)
                         break
         else:
@@ -3122,7 +3197,7 @@ class IDJC_Media_Player:
         else:
             for element in elements:
                 iter_ = model.insert_after(iter_, element)
-                glib.idle_add(self.drag_data_received_data_idle,
+                idle_add(self.drag_data_received_data_idle,
                                                         model, iter_, elements)
                 break
             else:
@@ -3640,18 +3715,24 @@ class IDJC_Media_Player:
     def rgrowconfig(self, tv_column, cell_renderer, model, iter):
         if self.exiting:
             return
+            
         self.rowconfig(tv_column, cell_renderer, model, iter)
-        if model.get_value(iter, 0)[0] == ">":
-            cell_renderer.set_property("text", " ")
-        else:
-            if model.get_value(iter, 7) == RGDEF:
-                # Red triangle.
-                cell_renderer.set_property("markup",
-                                '<span foreground="dark red">&#x25b5;</span>')
-            else:
-                # Small green bullet point.
-                cell_renderer.set_property("markup",
-                                '<span foreground="dark green">&#x2022;</span>')
+        cell_renderer.set_property("markup", " ")
+        if model.get_value(iter, 0)[0] != ">":
+            rg = model.get_value(iter, 7)
+            if rg is not None:
+                if rg == RGDEF:
+                    # Red triangle.
+                    cell_renderer.set_property("markup",
+                                    '<span foreground="dark red">&#x25b5;</span>')
+                elif rg.endswith(" RG"):
+                    # Small green bullet point.
+                    cell_renderer.set_property("markup",
+                                    '<span foreground="dark green">&#x2022;</span>')
+                elif rg.endswith(" R128"):
+                    # Small blue bullet point.
+                    cell_renderer.set_property("markup",
+                                    '<span foreground="dark blue">&#x2022;</span>')
 
     def playtimerowconfig(self, tv_column, cell_renderer, model, iter):
         if self.exiting:
@@ -3704,9 +3785,7 @@ class IDJC_Media_Player:
                             ("text", _('No Fade'))),
         ">announcement":    (("cell-background", "dark blue"),
                             ("background-gdk", gray),
-                            ("foreground", "dark blue"),
-                            # TC: Playlist control.
-                            ("text", _('Announcement'))),
+                            ("foreground", "dark blue"),),
         ">normalspeed":     (("cell-background", "dark green"),
                             ("background-gdk", gray),
                             ("foreground", "dark green"),
@@ -3767,7 +3846,11 @@ class IDJC_Media_Player:
                 else:
                     for name, value in properties:
                         crprop(name, value)
-                    
+
+                if celltext == ">announcement":
+                    crprop("text", _('Announcement:') + " " + urllib.unquote(
+                                                    model.get_value(iter, 4)))
+
                 if celltext == ">transfer":
                     if self.playername == "left":
                         # TC: Playlist control.
@@ -4044,7 +4127,7 @@ class IDJC_Media_Player:
         self.plfilefilter_playlists = gtk.FileFilter()
         # TC: File filter text.
         self.plfilefilter_playlists.set_name(
-                                    _('Playlist types (*.m3u, *.xspf, *.pls)'))
+                    _('Playlist types') + " " + supported.playlists_as_text())
         self.plfilefilter_playlists.add_mime_type("audio/x-mpegurl")
         self.plfilefilter_playlists.add_mime_type("application/xspf+xml")
         self.plfilefilter_playlists.add_mime_type("audio/x-scpls")
diff --git a/python/popupwindow.py b/python/popupwindow.py
index 0b66724..b87c5d6 100644
--- a/python/popupwindow.py
+++ b/python/popupwindow.py
@@ -20,7 +20,7 @@ __all__ = ['PopupWindow']
 
 import gobject
 import gtk
-from .gtkstuff import threadslock
+from .gtkstuff import threadslock, timeout_add, source_remove
 
 
 class PopupWindow:
@@ -102,23 +102,24 @@ class PopupWindow:
         # Any event triggers destruction of popup windows currently open.
         if self.popup_window is not None:
             self.popup_window.destroy()
-            gobject.source_remove(self.timeout)
+            source_remove(self.timeout_id)
             self.popup_window = None
             self.message("popup window destroyed due to the sensing of an "
                                                         "event, timer removed")
             if data == "leave": return False
         if data == "enter" and self.inside_widget == False:
-            self.timeout = gobject.timeout_add(100, self.timeout_callback)
+            self.timeout_id = timeout_add(100, self.timeout_callback)
             self.inside_widget = True
             self.total_timer_count = 0
             self.message("timer started")
         if data == "leave":
-            gobject.source_remove(self.timeout)
-            self.inside_widget = False
-            self.message("timer removed")
+            if self.inside_widget:
+                source_remove(self.timeout_id)
+                self.inside_widget = False
+                self.message("timer removed")
         if data == "button" or data == "scroll" or self.inhibit_callback() \
                                                         and self.inside_widget:
-            gobject.source_remove(self.timeout)
+            source_remove(self.timeout_id)
             self.message("timer removed")
     
     def dummy(self): return False
diff --git a/python/preferences.py b/python/preferences.py
index 193bef6..e2269cc 100644
--- a/python/preferences.py
+++ b/python/preferences.py
@@ -29,6 +29,7 @@ from . import licence_window
 from . import songdb
 from . import midicontrols
 from .gtkstuff import WindowSizeTracker, DefaultEntry, threadslock
+from .gtkstuff import timeout_add, source_remove
 from .prelims import ProfileManager
 from .utils import PathStr
 from .tooltips import set_tip, MAIN_TIPS
@@ -176,9 +177,9 @@ class PanWidget(gtk.Frame):
             print "Attempt made to load a non existent pan preset"
         else:
             if self._source_id:
-                glib.source_remove(self._source_id)
+                source_remove(self._source_id)
                 
-            self._source_id = glib.timeout_add(5, self._timeout, target)
+            self._source_id = timeout_add(5, self._timeout, target)
 
     @threadslock
     def _timeout(self, target):
@@ -377,6 +378,8 @@ class AGCControl(gtk.Frame):
     def cb_open(self, widget):
         active = widget.get_active()
         self.meter.set_led(active)
+        if gtk.main_level():
+            self.approot.channelstate_changed(self.index, active)
 
     def cb_mode(self, combobox):
         mode = combobox.get_active()
@@ -1568,6 +1571,21 @@ class mixprefs:
             ("<b>fr</b> nvignot (nicotux at users.sf.net)",
             "<b>it</b>  Raffaele Morelli (raffaele.morelli at gmail.com)"))
 
+        label = gtk.Label(_('Build Info'))
+        ivbox = gtk.VBox()
+        ivbox.set_spacing(10)
+        ivbox.set_border_width(10)
+        nb.append_page(ivbox, label)
+        ivbox.show()
+
+        with open(FGlobs.pkgdatadir / "buildinfo") as f:
+            for each in f:
+                label = gtk.Label(each.rstrip())
+                label.set_use_markup(True)
+                label.set_selectable(True)
+                ivbox.pack_start(label, False)
+                label.show()
+
         vbox.show()
 
         aboutlabel = gtk.Label(_('About'))
diff --git a/python/prelims/Makefile.in b/python/prelims/Makefile.in
index 2aa0f28..959aceb 100644
--- a/python/prelims/Makefile.in
+++ b/python/prelims/Makefile.in
@@ -182,6 +182,7 @@ EXEEXT = @EXEEXT@
 EXT = @EXT@
 FGREP = @FGREP@
 GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@
+GIT_PROG_EXISTS = @GIT_PROG_EXISTS@
 GLIB_CFLAGS = @GLIB_CFLAGS@
 GLIB_LIBS = @GLIB_LIBS@
 GMSGFMT = @GMSGFMT@
@@ -239,6 +240,7 @@ LN_S = @LN_S@
 LTLIBICONV = @LTLIBICONV@
 LTLIBINTL = @LTLIBINTL@
 LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
 MAKEINFO = @MAKEINFO@
 MANIFEST_TOOL = @MANIFEST_TOOL@
 MKDIR_P = @MKDIR_P@
diff --git a/python/prelims/profiledialog.py b/python/prelims/profiledialog.py
index 63c7663..522a8ff 100644
--- a/python/prelims/profiledialog.py
+++ b/python/prelims/profiledialog.py
@@ -42,6 +42,7 @@ from ..gtkstuff import CellRendererTime
 from ..gtkstuff import threadslock
 from ..gtkstuff import IconChooserButton
 from ..gtkstuff import IconPreviewFileChooserDialog
+from ..gtkstuff import timeout_add
 
 
 import gettext
@@ -421,7 +422,7 @@ class ProfileDialog(gtk.Dialog):
     def _cb_visible(self, *args):
         self._update_data()
         if self.props.visible:
-            gobject.timeout_add(200, threadslock(self._update_data))
+            timeout_add(200, threadslock(self._update_data))
         
         
     def _cb_selection(self, ts):
diff --git a/python/songdb.py b/python/songdb.py
index ce01ada..2192c6b 100644
--- a/python/songdb.py
+++ b/python/songdb.py
@@ -44,16 +44,19 @@ else:
 from idjc import FGlobs
 from .tooltips import set_tip
 from .gtkstuff import threadslock, gdklock, DefaultEntry, NotebookSR
+from .gtkstuff import idle_add, timeout_add, source_remove
 
 
 __all__ = ['MediaPane', 'have_songdb']
 
 AMPACHE = "Ampache"
+AMPACHE_3_7 = "Ampache 3.7"
 PROKYON_3 = "Prokyon 3"
 FUZZY, CLEAN, WHERE, DIRTY = xrange(4)
 
 t = gettext.translation(FGlobs.package_name, FGlobs.localedir, fallback=True)
 _ = t.gettext
+N_ = lambda t: t
 
 
 def dirname(pathname):
@@ -131,7 +134,7 @@ class DBAccessor(threading.Thread):
     def run(self):
         """This is the worker thread."""
 
-        notify = partial(glib.idle_add, threadslock(self.notify))
+        notify = partial(idle_add, threadslock(self.notify))
         
         try:
             while self.keepalive:
@@ -177,7 +180,9 @@ class DBAccessor(threading.Thread):
                                 self._handle = sql.Connection(
                                     host=self.hostname, port=self.port,
                                     user=self.user, passwd=self.password,
-                                    db=self.database, connect_timeout=6)
+                                    db=self.database, connect_timeout=6,
+                                    charset='utf8',
+                                    compress=True)
                                 self._cursor = self._handle.cursor()
                             except sql.Error as e:
                                 notify(_("Connection failed (try %d)") %
@@ -185,16 +190,16 @@ class DBAccessor(threading.Thread):
                                 print e
                                 time.sleep(0.5)
                             else:
+                                # This causes problems if other
+                                # processes try to access the database,
+                                # so set autocommit to 1
                                 try:
-                                    self._cursor.execute('set names utf8')
-                                    self._cursor.execute(
-                                                    'set character set utf8')
-                                    self._cursor.execute(
-                                            'set character_set_connection=utf8')
+                                    self._handle.autocommit(True)
                                 except sql.MySQLError:
-                                    notify(_('Connected: utf-8 mode failed'))
+                                    notify(_('Connected: autocommit mode failed'))
                                 else:
-                                    notify(_('Connected'))
+                                    notify(_('Connected: autocommit mode set'))
+                            notify(_('Connected'))
                         else:
                             if not self.keepalive:
                                 return
@@ -225,10 +230,9 @@ class DBAccessor(threading.Thread):
         try:
             self._handle.close()
         except sql.Error:
-            glib.idle_add(threadslock(self.notify),
-                                            _('Problem dropping connection'))
+            idle_add(threadslock(self.notify), _('Problem dropping connection'))
         else:
-            glib.idle_add(threadslock(self.notify), _('Connection dropped'))
+            idle_add(threadslock(self.notify), _('Connection dropped'))
 
     @thread_only
     def replace_cursor(self, cursor):
@@ -443,6 +447,20 @@ class PrefsControls(gtk.Frame):
         for each in self._settings:
             self.textdict.update(each.textdict)
 
+    def credentials(self):
+        if self.dbtoggle.get_active():
+            active = self._notebook.get_current_page()
+        else:
+            active = None
+
+        pages = []
+        for i, settings in enumerate(self._notebook.get_children()):
+            creddict = settings.get_data()[0]
+            creddict.update({"active": i == active})
+            pages.append(creddict)
+        
+        return pages
+
     def disconnect(self):
         self.dbtoggle.set_active(False)    
         
@@ -526,14 +544,14 @@ class PageCommon(gtk.VBox):
         return False
 
     def set_col_widths(self, data):
-        """Restore column width values."""
-         
-        c = self.tree_cols.__iter__()
-        for w in data.split(","):
-            if w != "0":
-                c.next().set_fixed_width(int(w))
-            else:
-                c.next()
+        """Restore column width values. Includes a data validity check."""
+
+        if len(self.tree_cols) == data.count(",") + 1:
+            for width, col in zip(data.split(","), self.tree_cols):
+                if width != "0":
+                    col.set_fixed_width(int(width))
+        else:
+            print "can't restore column widths"
 
     def activate(self, accessor, db_type, usesettings):
         self._acc = accessor
@@ -544,7 +562,7 @@ class PageCommon(gtk.VBox):
         while self._update_id:
             context, namespace = self._update_id.popleft()
             namespace[0] = True
-            glib.source_remove(context)
+            source_remove(context)
         
         self._acc = None
         model = self.tree_view.get_model()
@@ -560,9 +578,14 @@ class PageCommon(gtk.VBox):
         """Build a TreeViewColumn list from a table of data."""
 
         list_ = []
-        for label, data_index, data_function, mw, el in parameters:
-            renderer = gtk.CellRendererText()
-            renderer.props.ellipsize = el
+        for p in parameters:
+            try:
+                # Check if there is an extra parameter to set the renderer
+                label, data_index, data_function, mw, el, renderer = p
+            except:
+                label, data_index, data_function, mw, el = p
+                renderer = gtk.CellRendererText()
+                renderer.props.ellipsize = el
             column = gtk.TreeViewColumn(label, renderer)
             if mw != -1:
                 column.set_resizable(True)
@@ -583,7 +606,7 @@ class PageCommon(gtk.VBox):
         with gdklock():
             while self._update_id:
                 context, namespace = self._update_id.popleft()
-                glib.source_remove(context)
+                source_remove(context)
                 # Idle functions to receive the following and know to clean-up.
                 namespace[0] = True
 
@@ -599,7 +622,7 @@ class PageCommon(gtk.VBox):
         # Scrap intermediate jobs whose output would merely slow down the
         # user interface responsiveness.
         namespace = [False, ()]
-        context = glib.idle_add(self._update_1, acc, cursor, rows, namespace)
+        context = idle_add(self._update_1, acc, cursor, rows, namespace)
         self._update_id.append((context, namespace))
 
 class ViewerCommon(PageCommon):
@@ -666,21 +689,65 @@ class ViewerCommon(PageCommon):
             renderer.set_property("text", "")
         elif self._db_type == "P3":
             renderer.set_property("text", "%dk" % bitrate)
-        elif bitrate > 9999 and self._db_type == AMPACHE:
+        elif bitrate > 9999 and self._db_type in (AMPACHE, AMPACHE_3_7):
             renderer.set_property("text", "%dk" % (bitrate // 1000))
         renderer.set_property("xalign", 1.0)
 
-    @staticmethod
-    def _cell_show_unknown(column, renderer, model, iter, cell):
-        text = model.get_value(iter, cell) or _('<unknown>')
+    def _query_cook_common(self, query):
+        if self._db_type == AMPACHE:
+            query = query.replace("__played_by_me__", "'1' as played_by_me")
+        else:
+            query = query.replace("__played_by_me__", """SUBSTR(MAX(CONCAT(object_count.date, IF(ISNULL(agent), NULL,
+                        IF(STRCMP(LEFT(agent,5), "IDJC:"), 2,
+                        IF(STRCMP(agent, "IDJC:1"), 0, 1))))), 11) AS played_by_me""")
+        return query.replace("__catalogs__", self.catalogs.sql())
+
+    def _cell_show_unknown(self, column, renderer, model, iter, data):
+        text, max_lastplay_date, played_by, played, played_by_me, cat = model.get(iter, *data)
+        if text is None: text = _('<unknown>')
+        weight = pango.WEIGHT_NORMAL
+        if not played:
+            col = 'black'
+            renderer.props.background_set = False
+        else:
+            value, percent, weight = self._get_played_percent(cat, max_lastplay_date)
+            col, bg_col = ViewerCommon._set_color(played_by_me, percent)
+            renderer.props.background_set = True
+            renderer.props.background = bg_col
         renderer.props.text = text
-
-    @staticmethod
-    def _cell_show_nested(column, renderer, model, iter, cell):
-        text = model.get_value(iter, cell) or _('<unknown>')
-        col = "red" if model.iter_depth(iter) == 0 else "black"
+        renderer.props.foreground = col
+        renderer.props.weight = weight
+
+    def _cell_show_nested(self, column, renderer, model, iter, data):
+        text, max_lastplay_date, played_by, played, played_by_me, cat = model.get(iter, *data)
+        if text is None: text = _('<unknown>')
+        col = "black"
+        weight = pango.WEIGHT_NORMAL
+        renderer.props.background_set = False
+        if model.iter_depth(iter) == 0:
+            col = "red"
+        elif played:
+            value, percent, weight = self._get_played_percent(cat, max_lastplay_date)
+            col, bg_col = ViewerCommon._set_color(played_by_me, percent)
+            renderer.props.background_set = True
+            renderer.props.background = bg_col
         renderer.props.text = text
         renderer.props.foreground = col
+        renderer.props.weight = weight
+
+    def _cell_progress(self, column, renderer, model, iter, data):
+        max_lastplay_date, played_by, played, cat= model.get(iter, *data)
+        if not played:
+            text = _("Not Played")
+            value = 0
+            renderer.props.visible = False
+        else:
+            value, percent, weight = self._get_played_percent(cat, max_lastplay_date)
+            text = ViewerCommon._format_lastplay_date(max_lastplay_date)
+            text += "(" + (played_by or _('<unknown>')) + ")"
+            renderer.props.visible = True
+        renderer.props.text = text
+        renderer.props.value = value
 
     @staticmethod
     def _cell_pathname(column, renderer, model, iter, data, partition, transform):
@@ -705,9 +772,7 @@ class ViewerCommon(PageCommon):
     @staticmethod
     def _cell_secs_to_h_m_s(column, renderer, model, iter, cell):
         v_in = model.get_value(iter, cell)
-        m, s = divmod(v_in, 60)
-        h, m = divmod(m, 60)
-        d, h = divmod(h, 24)
+        d, h, m, s = ViewerCommon._secs_to_h_m_s(v_in)
         if d:
             v_out = "%dd:%02d:%02d" % (d, h, m)
         else:
@@ -727,6 +792,54 @@ class ViewerCommon(PageCommon):
         else:
             renderer.set_property("text", "")
 
+    @staticmethod
+    def _secs_to_h_m_s(value):
+        m, s = divmod(value, 60)
+        h, m = divmod(m, 60)
+        d, h = divmod(h, 24)
+        return d, h, m, s
+
+    @staticmethod
+    def _format_lastplay_date(value):
+        if value is None:
+            return _("<unknown>") + " "
+        difftime = time.time() - int(value)
+        d, h, m, s = ViewerCommon._secs_to_h_m_s(difftime)
+        return "%dd %dh %dm ago " % (d, h, m)
+
+    def _get_played_percent(self, catalog, value):
+        if value is None:
+            return 0, 0.0, pango.WEIGHT_NORMAL + 50
+        now = time.time()
+        max_days_ago = self.catalogs.lpscale(catalog)
+        diff = now - int(value)
+        if diff > max_days_ago:
+            value = 0
+            percent = 0.35
+            weight = pango.WEIGHT_NORMAL + 100
+        else:
+            percent = 1.0 - (float(diff) / float(max_days_ago))
+            value = 100 * percent
+            # Refactor percent used for colors to be .4 to 1.0, as anything
+            # below about .35 starts to look to much like black.
+            percent = (percent * .6) + .4
+            # Get a weight from 500 to 900
+            weight = ((percent * .4) * 1000) + pango.WEIGHT_NORMAL + 100
+        return value, percent, weight
+
+    @staticmethod
+    def _set_color(text, percent=1.0):
+        #print "text: ", text
+        if percent == 1.0:
+            bg_col = "white"
+        elif int(text) == 1:
+            bg_col = "Powder Blue"
+        else:
+            bg_col = "Light Pink"
+        return (gtk.gdk.color_from_hsv(0.0, 1.0, percent),
+                gtk.gdk.color_from_hsv(0.6666, 1.0, percent),
+                gtk.gdk.color_from_hsv(0.3333, 1.0, percent))[int(text)], bg_col
+
 class ExpandAllButton(gtk.Button):
     def __init__(self, expanded, tooltip=None):
         expander = gtk.Expander()
@@ -741,10 +854,14 @@ class ExpandAllButton(gtk.Button):
 class TreePage(ViewerCommon):
     """Browsable UI with tree structure."""
 
-    # *depth*, *treecol*, album, album_prefix, year, disk, album_id,
-    # tracknumber, title, artist, artist_prefix, pathname, bitrate, length, catalog_id
+    # *depth*(0), *treecol*(1), album(2), album_prefix(3), year(4), disk(5),
+    # album_id(6), tracknumber(7), title(8), artist(9), artist_prefix(10),
+    # pathname(11), bitrate(12), length(13), catalog_id(14), max_date_played(15),
+    # played_by(16), played(17), played_by_me(18)
     # The order chosen negates the need for a custom sort comparison function.
-    DATA_SIGNATURE = int, str, str, str, int, int, int, int, str, str, str, str, int, int, int
+    DATA_SIGNATURE = int, str, str, str, int,\
+                     int, int, int, str, str, str, str,\
+                     int, int, int, str, str, int, str
     BLANK_ROW = tuple(x() for x in DATA_SIGNATURE[2:])
 
     def __init__(self, notebook, catalogs):
@@ -780,7 +897,7 @@ class TreePage(ViewerCommon):
         tree_collapse.connect_object("clicked", gtk.TreeView.collapse_all,
                                                                 self.tree_view)
         self.tree_cols = self._make_tv_columns(self.tree_view, (
-                ("", 1, self._cell_show_nested, 180, pango.ELLIPSIZE_END),
+                ("", (1, 15, 16, 17, 18, 14), self._cell_show_nested, 180, pango.ELLIPSIZE_END),
                 # TC: Track artist.
                 (_('Artist'), (10, 9), self._data_merge, 100, pango.ELLIPSIZE_END),
                 # TC: The disk number of the album track.
@@ -789,6 +906,7 @@ class TreePage(ViewerCommon):
                 (_('Track'), 7, self._cell_ralign, -1, pango.ELLIPSIZE_NONE),
                 # TC: Track playback time.
                 (_('Duration'), 13, self._cond_cell_secs_to_h_m_s, -1, pango.ELLIPSIZE_NONE),
+                (_('Last Played'), (15, 16, 17, 14), self._cell_progress, -1, None, gtk.CellRendererProgress()),
                 (_('Bitrate'), 12, self._cell_k, -1, pango.ELLIPSIZE_NONE),
                 (_('Filename'), (14, 11), self._cell_filename, 100, pango.ELLIPSIZE_END),
                 # TC: Directory path to a file.
@@ -839,7 +957,7 @@ class TreePage(ViewerCommon):
 
     def deactivate(self):
         while self._pulse_id:
-            glib.source_remove(self._pulse_id.popleft())
+            source_remove(self._pulse_id.popleft())
         self.progress_bar.set_fraction(0.0)
         super(TreePage, self).deactivate()
 
@@ -873,12 +991,16 @@ class TreePage(ViewerCommon):
                     "" as art_prefix,
                     CONCAT_WS('/',path,filename) as file,
                     bitrate, length,
-                    0 as catalog_id
+                    0 as catalog_id,
+                    0 as max_date_played,
+                    "" as played_by,
+                    0 as played,
+                    0 as played_by_me
                     FROM tracks
                     LEFT JOIN albums on tracks.album = albums.name
                      AND tracks.artist = albums.artist
                     ORDER BY tracks.artist, album, tracknumber, title"""
-        elif self._db_type == AMPACHE:
+        elif self._db_type in (AMPACHE, AMPACHE_3_7):
             query = """SELECT
                     album.name as album,
                     album.prefix as alb_prefix,
@@ -892,19 +1014,28 @@ class TreePage(ViewerCommon):
                     file,
                     bitrate,
                     time as length,
-                    catalog.id as catalog_id
+                    catalog.id as catalog_id,
+                    MAX(object_count.date) as max_date_played,
+                    SUBSTR(MAX(CONCAT(object_count.date, user.fullname)), 11) AS played_by,
+                    played,
+                    __played_by_me__
                     FROM song
                     LEFT JOIN artist ON song.artist = artist.id
                     LEFT JOIN album ON song.album = album.id
+                    LEFT JOIN object_count ON song.id = object_count.object_id
+                                AND object_count.object_type = "song"
+                    LEFT JOIN user ON user.id = object_count.user
                     LEFT JOIN catalog ON song.catalog = catalog.id
                     WHERE __catalogs__
+                    GROUP BY song.id
                     ORDER BY artist.name, album, disk, tracknumber, title"""
-            query = query.replace("__catalogs__", self.catalogs.sql())
+                    
+            query = self._query_cook_common(query)
         else:
             print "unsupported database type:", self._db_type
             return
             
-        self._pulse_id.append(glib.timeout_add(1000, self._progress_pulse))
+        self._pulse_id.append(timeout_add(1000, self._progress_pulse))
         self._acc.request((query,), self._handler, self._failhandler)
 
     def _drag_data(self, model, path):
@@ -951,10 +1082,9 @@ class TreePage(ViewerCommon):
         print exception
         
         notify(_('Tree fetch failed'))
-        glib.idle_add(threadslock(self.loading_label.set_text),
-                                                        _('Fetch Failed!'))
+        idle_add(threadslock(self.loading_label.set_text), _('Fetch Failed!'))
         while self._pulse_id:
-            glib.source_remove(self._pulse_id.popleft())
+            source_remove(self._pulse_id.popleft())
         
         return True  # Drop job. Don't run handler.
 
@@ -968,7 +1098,7 @@ class TreePage(ViewerCommon):
         self.loading_label.set_text(_('Populating'))
         # Turn off progress bar pulser.
         while self._pulse_id:
-            glib.source_remove(self._pulse_id.popleft())
+            source_remove(self._pulse_id.popleft())
 
         # Clean away old data.
         self.tree_view.set_model(None)
@@ -978,7 +1108,7 @@ class TreePage(ViewerCommon):
         namespace = [False, (0.0, None, None, None, {}, None, None, None, None)]
         do_max = min(max(30, rows / 100), 200)  # Data size to process.
         total = 2.0 * rows
-        context = glib.idle_add(self._update_2, acc, cursor, total, do_max,
+        context = idle_add(self._update_2, acc, cursor, total, do_max,
                                                             [], namespace)
         self._update_id.append((context, namespace))
         return False
@@ -997,7 +1127,7 @@ class TreePage(ViewerCommon):
         if not rows:
             store.sort()
             namespace = [False, (done, ) + (None, ) * 11]
-            context = glib.idle_add(self._update_3, acc, total, do_max,
+            context = idle_add(self._update_3, acc, total, do_max,
                                                         store, namespace)
             self._update_id.append((context, namespace))
             return False
@@ -1018,7 +1148,7 @@ class TreePage(ViewerCommon):
                 iter_l = letter[art_letter] = r_append(None, (-1, art_letter) + BLANK_ROW)
             if album == row[0] and artist == row[7] and \
                                 alb_prefix == row[1] and art_prefix == row[8]:
-                r_append(iter_2, (0, row[6]) + row)
+                iter_3 = r_append(iter_2, (0, row[6]) + row)
                 continue
             else:
                 if artist != row[7] or art_prefix != row[8]:
@@ -1035,7 +1165,7 @@ class TreePage(ViewerCommon):
                     else:
                         albumtext = album
                     iter_2 = r_append(iter_1, (-3, albumtext) + BLANK_ROW)
-                r_append(iter_2, (0, row[6]) + row)
+                iter_3 = r_append(iter_2, (0, row[6]) + row)
                 
         done += do_max
         self.progress_bar.set_fraction(sorted((0.0, done / total, 1.0))[1])
@@ -1073,7 +1203,7 @@ class TreePage(ViewerCommon):
             else:
                 iter_l = letter[alb_letter] = append(None, (-1, alb_letter) + BLANK_ROW)
             if album_id == row[4]:
-                append(iter_2, (0, row[6]) + row)
+                iter_3 = append(iter_2, (0, row[6]) + row)
                 continue
             else:
                 if album != row[0] or year != row[2] or alb_prefix != row[1]:
@@ -1093,7 +1223,7 @@ class TreePage(ViewerCommon):
                     else:
                         iter_2 = append(iter_1, (-3, _('Disk %d') % disk)
                                                                 + BLANK_ROW)
-                append(iter_2, (0, row[6]) + row)
+                iter_3 = append(iter_2, (0, row[6]) + row)
 
         done += do_max
         self.progress_bar.set_fraction(min(done / total, 1.0))
@@ -1148,17 +1278,21 @@ class FlatPage(ViewerCommon):
                                                                     catalogs)
  
         # Row data specification:
-        # index, ARTIST, ALBUM, TRACKNUM, TITLE, DURATION, BITRATE,
-        # pathname, disk, catalog_id
+        # index(0), ARTIST(1), ALBUM(2), TRACKNUM(3), TITLE(4), DURATION(5), BITRATE(6),
+        # pathname(7), disk(8), catalog_id(9), max_date_played(10),
+        # played_by(11), played(12), played_by_me(13)
         self.list_store = gtk.ListStore(
-                            int, str, str, int, str, int, int, str, int, int)
+                            int, str, str, int, str, int, int,
+                            str, int, int, str,
+                            str, int, str)
         self.tree_cols = self._make_tv_columns(self.tree_view, (
             ("(0)", 0, self._cell_ralign, -1, pango.ELLIPSIZE_NONE),
-            (_('Artist'), 1, self._cell_show_unknown, 100, pango.ELLIPSIZE_END),
-            (_('Album'), 2, self._cell_show_unknown, 100, pango.ELLIPSIZE_END),
+            (_('Artist'), (1, 10, 11, 12, 13, 9), self._cell_show_unknown, 100, pango.ELLIPSIZE_END),
+            (_('Album'), (2, 10, 11, 12, 13, 9), self._cell_show_unknown, 100, pango.ELLIPSIZE_END),
+            (_('Title'), (4, 10, 11, 12, 13, 9), self._cell_show_unknown, 100, pango.ELLIPSIZE_END),
+            (_('Last Played'), (10, 11, 12, 9), self._cell_progress, -1, None, gtk.CellRendererProgress()),
             (_('Disk'), 8, self._cell_ralign, -1, pango.ELLIPSIZE_NONE),
             (_('Track'), 3, self._cell_ralign, -1, pango.ELLIPSIZE_NONE),
-            (_('Title'), 4, self._cell_show_unknown, 100, pango.ELLIPSIZE_END),
             (_('Duration'), 5, self._cell_secs_to_h_m_s, -1, pango.ELLIPSIZE_NONE),
             (_('Bitrate'), 6, self._cell_k, -1, pango.ELLIPSIZE_NONE),
             (_('Filename'), (9, 7), self._cell_filename, 100, pango.ELLIPSIZE_END),
@@ -1191,7 +1325,11 @@ class FlatPage(ViewerCommon):
             {FUZZY: (CLEAN, """
                     SELECT artist,album,tracknumber,title,length,bitrate,
                     CONCAT_WS('/',path,filename) as file,
-                    0 as disk, 0 as catalog_id
+                    0 as disk, 0 as catalog_id,
+                    0 as max_date_played,
+                    "" as played_by,
+                    0 as played,
+                    0 as played_by_me
                     FROM tracks
                     WHERE MATCH (artist,album,title,filename) AGAINST (%s)
                     """),
@@ -1199,7 +1337,11 @@ class FlatPage(ViewerCommon):
             WHERE: (DIRTY, """
                     SELECT artist,album,tracknumber,title,length,bitrate,
                     CONCAT_WS('/',path,filename) as file,
-                    0 as disk, 0 as catalog_id
+                    0 as disk, 0 as catalog_id,
+                    0 as max_date_played,
+                    "" as played_by,
+                    0 as played,
+                    0 as played_by_me
                     FROM tracks WHERE (%s)
                     ORDER BY artist,album,path,tracknumber,title
                     """)},
@@ -1212,15 +1354,23 @@ class FlatPage(ViewerCommon):
                     track as tracknumber, title, time as length,bitrate,
                     file,
                     album.disk as disk,
-                    catalog.id as catalog_id
+                    catalog.id as catalog_id,
+                    MAX(object_count.date) as max_date_played,
+                    SUBSTR(MAX(CONCAT(object_count.date, user.fullname)), 11) AS played_by,
+                    played,
+                    __played_by_me__
                     FROM song
                     LEFT JOIN artist ON artist.id = song.artist
                     LEFT JOIN album ON album.id = song.album
+                    LEFT JOIN object_count ON song.id = object_count.object_id
+                                AND object_count.object_type = "song"
+                    LEFT JOIN user ON user.id = object_count.user
                     LEFT JOIN catalog ON song.catalog = catalog.id
                     WHERE
                          (MATCH(album.name) against(%s)
                           OR MATCH(artist.name) against(%s)
                           OR MATCH(title) against(%s)) AND __catalogs__
+                    GROUP BY song.id
                     """),
 
             WHERE: (DIRTY, """
@@ -1230,15 +1380,25 @@ class FlatPage(ViewerCommon):
                     track as tracknumber, title,time as length, bitrate,
                     file,
                     album.disk as disk,
-                    catalog.id as catalog_id
+                    catalog.id as catalog_id,
+                    MAX(object_count.date) as max_date_played,
+                    SUBSTR(MAX(CONCAT(object_count.date, user.fullname)), 11) AS played_by,
+                    played,
+                    __played_by_me__
                     FROM song
                     LEFT JOIN album on album.id = song.album
                     LEFT JOIN artist on artist.id = song.artist
+                    LEFT JOIN object_count ON song.id = object_count.object_id
+                                AND object_count.object_type = "song"
+                    LEFT JOIN user ON user.id = object_count.user
                     LEFT JOIN catalog ON song.catalog = catalog.id
-                    WHERE (%s) AND __catalogs__ ORDER BY
+                    WHERE (%s) AND __catalogs__
+                    GROUP BY song.id
+                    ORDER BY
                     artist.name, album.name, file, album.disk, track, title
                     """)}
     }
+    _queries_table[AMPACHE_3_7] = _queries_table[AMPACHE]
 
     def _cb_update(self, widget):
         self._old_cat_data = self.catalogs.copy_data()
@@ -1258,13 +1418,12 @@ class FlatPage(ViewerCommon):
                 self.where_entry.set_text("")
                 while self._update_id:
                     context, namespace = self._update_id.popleft()
-                    glib.source_remove(context)
+                    source_remove(context)
                     namespace[0] = True
                 self.list_store.clear()
                 return
 
-        query = query.replace("__catalogs__", self.catalogs.sql())
-
+        query = self._query_cook_common(query)
         qty = query.count("(%s)")
         if access_mode == CLEAN:
             query = (query, (user_text,) * qty)
@@ -1304,8 +1463,8 @@ class FlatPage(ViewerCommon):
         if exception[0] == 2006:
             raise
 
-        glib.idle_add(self.tree_view.set_model, None)
-        glib.idle_add(self.list_store.clear)
+        idle_add(self.tree_view.set_model, None)
+        idle_add(self.list_store.clear)
 
     ###########################################################################
     
@@ -1315,7 +1474,7 @@ class FlatPage(ViewerCommon):
             self.tree_view.set_model(None)
             self.list_store.clear()
             namespace[1] = (0, )  # found = 0
-            context = glib.idle_add(self._update_2, acc, cursor, namespace)
+            context = idle_add(self._update_2, acc, cursor, namespace)
             self._update_id.append((context, namespace))
         return False
 
@@ -1352,6 +1511,8 @@ class FlatPage(ViewerCommon):
 
 class CatalogsInterface(gobject.GObject):
     __gsignals__ = { "changed" : (gobject.SIGNAL_RUN_LAST, None, ()) }
+    time_unit_table = {N_('Minutes'): 60, N_('Hours'): 3600,
+                       N_('Days'): 86400, N_('Weeks'): 604800}
     
     def __init__(self):
         gobject.GObject.__init__(self)
@@ -1372,14 +1533,19 @@ class CatalogsInterface(gobject.GObject):
         self._dict.clear()
         for row in liststore:
             if row[0]:
-                self._dict[row[3]] = {
+                self._dict[row[5]] = {
                     "peel" : row[1], "prepend" : row[2],
-                    "name" : row[4], "path" : row[5], "last_update" : row[6],
-                    "last_clean" : row[7], "last_add" : row[8]
+                    "lpscale" : self._lpscale_calc(row[3], row[4]),
+                    "name" : row[6], "path" : row[7], "last_update" : row[8],
+                    "last_clean" : row[9], "last_add" : row[10]
                 }
                 
         self.emit("changed")
 
+    @classmethod
+    def _lpscale_calc(cls, qty, unit):
+        return qty * cls.time_unit_table[unit]
+
     def transform_path(self, catalog, path):
         if len(path) < 4:
             return False, path  # Path too short to be valid.
@@ -1420,13 +1586,16 @@ class CatalogsInterface(gobject.GObject):
 
         return self._stripped_copy(self._dict) != self._stripped_copy(other)
 
+    def lpscale(self, catalog):
+        return self._dict[catalog]["lpscale"]
+
     @staticmethod
     def _stripped_copy(_dict):
         copy = {}
         for key1, val1 in _dict.iteritems():
             copy[key1] = {}
             for key2, val2 in val1.iteritems():
-                if key2 not in ("peel", "prepend"):
+                if key2 not in ("peel", "prepend", "lpscale"):
                     copy[key1][key2] = val2
 
         return copy
@@ -1438,12 +1607,14 @@ class CatalogsPage(PageCommon):
         self.refresh = gtk.Button(stock=gtk.STOCK_REFRESH)
         self.refresh.connect("clicked", self._on_refresh)
         PageCommon.__init__(self, notebook, _("Catalogs"), self.refresh)
-        # active, peel, prepend, id, name, path, last_update, last_clean, last_add
+        
+        # active, peel, prepend, lpscale_qty, lpscale_unit, id, name, path,
+        # last_update, last_clean, last_add
         self.list_store = gtk.ListStore(
-                        int, int, str, int, str, str, int, int, int)
+                        int, int, str, int, str, int, str, str, int, int, int)
         self.tree_cols = self._make_tv_columns(self.tree_view, (
-            (_('Name'), 4, None, 65, pango.ELLIPSIZE_END),
-            (_('Catalog Path'), 5, None, 100, pango.ELLIPSIZE_END),
+            (_('Name'), 6, None, 65, pango.ELLIPSIZE_END),
+            (_('Catalog Path'), 7, None, 100, pango.ELLIPSIZE_END),
             (_('Prepend Path'), 2, None, -1, pango.ELLIPSIZE_NONE)
             ))
 
@@ -1452,21 +1623,46 @@ class CatalogsPage(PageCommon):
         rend1.connect("toggled", self._on_toggle)
         self.tree_view.insert_column_with_attributes(0, "", rend1, active=0)
 
+        col = gtk.TreeViewColumn(_('Last Played Scale'))
+
         adj = gtk.Adjustment(0.0, 0.0, 999.0, 1.0, 1.0)
         rend2 = gtk.CellRendererSpin()
         rend2.props.editable = True
         rend2.props.adjustment = adj
         rend2.props.xalign = 1.0
-        rend2.connect("editing-started", self._on_peel_editing_started)
-        rend2.connect("edited", self._on_peel_edited)
-        col = self.tree_view.insert_column_with_attributes(3, _("Path Peel"),
-                                                                rend2, text=1)
+        rend2.connect("editing-started", self._on_spin_editing_started, 3)
+        rend2.connect("edited", self._on_spin_edited, 3)
+        col.pack_start(rend2, False)
+        col.add_attribute(rend2, "text", 3)
+
+        lp_unit_scale_store = gtk.ListStore(str)
+        for each in (N_('Minutes'), N_('Hours'), N_('Days'), N_('Weeks')):
+            lp_unit_scale_store.append((each,))
+        lp_unit_scale_cr = gtk.CellRendererCombo()
+        lp_unit_scale_cr.props.has_entry = False
+        lp_unit_scale_cr.props.editable = True
+        lp_unit_scale_cr.props.model = lp_unit_scale_store
+        lp_unit_scale_cr.props.text_column = 0
+        lp_unit_scale_cr.connect("changed", self._on_lp_unit_changed)
+        col.pack_start(lp_unit_scale_cr, False)
+        col.set_cell_data_func(lp_unit_scale_cr, self._translate_scale)
+        self.tree_view.insert_column(col, 3)
 
-        rend3 = self.tree_view.get_column(4).get_cell_renderers()[0]
+        adj = gtk.Adjustment(0.0, 0.0, 999.0, 1.0, 1.0)
+        rend3 = gtk.CellRendererSpin()
         rend3.props.editable = True
-        rend3.connect("edited", self._on_prepend_edited)
-
-        for rend in (rend2, rend3):
+        rend3.props.adjustment = adj
+        rend3.props.xalign = 1.0
+        rend3.connect("editing-started", self._on_spin_editing_started, 1)
+        rend3.connect("edited", self._on_spin_edited, 1)
+        col = self.tree_view.insert_column_with_attributes(4, _("Path Peel"),
+                                                                rend3, text=1)
+
+        rend4 = self.tree_view.get_column(5).get_cell_renderers()[0]
+        rend4.props.editable = True
+        rend4.connect("edited", self._on_prepend_edited)
+
+        for rend in (rend3, rend4):
             rend.connect("editing-started", self._on_editing_started)
             rend.connect("editing-canceled", self._on_editing_cancelled)
 
@@ -1478,20 +1674,23 @@ class CatalogsPage(PageCommon):
 
     def activate(self, *args, **kwargs):
         PageCommon.activate(self, *args, **kwargs)
-        self.tree_view.get_column(0).set_visible(self._db_type in (AMPACHE,))
+        self.tree_view.get_column(0).set_visible(self._db_type in (AMPACHE, AMPACHE_3_7))
         self.refresh.clicked()
 
     def deactivate(self, *args, **kwargs):
         PageCommon.deactivate(self, *args, **kwargs)
         self.interface.clear()
 
+    def _translate_scale(self, col, cell, model, iter):
+        cell.props.text = _(model.get_value(iter, 4))
+
     def _get_active_catalogs(self):
         return tuple(x[3] for x in self.list_store if x[0])
         
     def _store_user_data(self):
         dict_ = {}
         for row in self.list_store:
-            dict_[str(row[3])] = (row[0], row[1], row[2])
+            dict_[str(row[5])] = (row[0], row[1], row[2], row[3], row[4])
         self._usesettings["catalog_data"] = dict_
         
     def _restore_user_data(self):
@@ -1499,13 +1698,16 @@ class CatalogsPage(PageCommon):
             dict_ = self._usesettings["catalog_data"]
         except:
             return
-            
+
         for row in self.list_store:
             try:
-                row[0], row[1], row[2] = dict_[str(row[3])]
+                row[0], row[1], row[2], row[3], row[4] = dict_[str(row[5])]
             except KeyError:
                 pass
-        
+            except ValueError:
+                row[0], row[1], row[2] = dict_[str(row[5])]
+                row[3], row[4] = 4, N_('Weeks') 
+
     def _on_toggle(self, renderer, path):
         iter = self.list_store.get_iter(path)
         if iter is not None:
@@ -1515,17 +1717,24 @@ class CatalogsPage(PageCommon):
             self.interface.update(self.list_store)
 
     def _on_refresh(self, widget):
-        if self._db_type == AMPACHE:
+        if self._db_type in (AMPACHE, AMPACHE_3_7):
             self.refresh.set_sensitive(False)
             self.tree_view.set_model(None)
-            query = """SELECT id, name, path, last_update, IFNULL(last_clean,0),
-                        last_add FROM catalog WHERE enabled=1 ORDER BY name"""
+            if self._db_type == AMPACHE:
+                query = """SELECT id, name, path, last_update, IFNULL(last_clean,0),
+                           last_add FROM catalog WHERE enabled=1 ORDER BY name"""
+            else:
+                query = """SELECT catalog.id, name, path, last_update, IFNULL(last_clean,0),
+                           last_add FROM catalog
+                           LEFT JOIN catalog_local on catalog.id = catalog_id
+                           AND catalog.catalog_type = "local"
+                           WHERE enabled=1 ORDER BY name"""
             self._acc.request((query,), self._handler, self._failhandler)
         
         elif self._db_type == PROKYON_3:
             self.list_store.clear()
             self.tree_view.set_model(self.list_store)
-            self.list_store.append((1, 0, "", 0, _('N/A'), _('N/A'), 0, 0, 0))
+            self.list_store.append((1, 0, "", 0, _('N/A'), 0, _('N/A'), _('N/A'), 0, 0, 0))
             self._restore_user_data()
             self.interface.update(self.list_store)
 
@@ -1535,11 +1744,11 @@ class CatalogsPage(PageCommon):
     def _on_editing_cancelled(self, rend):
         self._block_key_bindings = False
 
-    def _on_peel_editing_started(self, rend, editable, path):
-        val = self.list_store[path][1]
+    def _on_spin_editing_started(self, rend, editable, path, index):
+        val = self.list_store[path][index]
         rend.props.adjustment.props.value = val
 
-    def _on_peel_edited(self, rend, path, new_data):
+    def _on_spin_edited(self, rend, path, new_data, index):
         self._block_key_bindings = False
         row = self.list_store[path]
         try:
@@ -1547,8 +1756,8 @@ class CatalogsPage(PageCommon):
         except ValueError:
             pass
         else:
-            if val >= 0 and val != row[1]:
-                row[1] = min(val, int(rend.props.adjustment.props.upper))
+            if val >= 0 and val != row[index]:
+                row[index] = min(val, int(rend.props.adjustment.props.upper))
                 self._store_user_data()
                 self.interface.update(self.list_store)
 
@@ -1561,6 +1770,12 @@ class CatalogsPage(PageCommon):
             self._store_user_data()
             self.interface.update(self.list_store)
 
+    def _on_lp_unit_changed(self, combo, path_string, new_iter):
+        text = combo.props.model.get_value(new_iter, 0)
+        self.list_store[path_string][4] = text
+        self._store_user_data()
+        self.interface.update(self.list_store)
+
     ###########################################################################
 
     def _failhandler(self, exception, notify):
@@ -1568,8 +1783,8 @@ class CatalogsPage(PageCommon):
         if exception[0] == 2006:
             raise
         
-        glib.idle_add(threadslock(self.tree_view.set_model), self.list_store)
-        glib.idle_add(threadslock(self.refresh.set_sensitive), True)
+        idle_add(threadslock(self.tree_view.set_model), self.list_store)
+        idle_add(threadslock(self.refresh.set_sensitive), True)
 
     @threadslock
     def _update_1(self, acc, cursor, rows, namespace):
@@ -1585,7 +1800,7 @@ class CatalogsPage(PageCommon):
                 if db_row is None:
                     break
                 
-                self.list_store.append((0, 0, "") + db_row)
+                self.list_store.append((0, 0, "", 4, N_('Weeks')) + db_row)
 
         self._restore_user_data()
         self.tree_view.set_model(self.list_store)
@@ -1680,13 +1895,13 @@ class MediaPane(gtk.VBox):
     ###########################################################################
 
     def _safe_disconnect(self):
-        glib.idle_add(threadslock(self.prefs_controls.disconnect))
+        idle_add(threadslock(self.prefs_controls.disconnect))
 
     def _hand_over(self, db_name):
         self._tree_page.activate(self._acc1, db_name, self.usesettings)
         self._flat_page.activate(self._acc2, db_name, self.usesettings)
         self._catalogs_page.activate(self._acc3, db_name, self.usesettings)
-        glib.idle_add(threadslock(self.show))
+        idle_add(threadslock(self.show))
             
     def _fail_1(self, exception, notify):
         # Give up.
@@ -1774,6 +1989,21 @@ class MediaPane(gtk.VBox):
     def _stage_8(self, acc, request, cursor, notify, rows):
         request(("ALTER TABLE song ADD FULLTEXT idjc (title)",), self._stage_9,
                                                                 self._fail_2)
-
     def _stage_9(self, acc, request, cursor, notify, rows):
-        self._hand_over(AMPACHE)
+        notify("Checking ampache type")
+        request(("DESCRIBE catalog",), self._stage_10, self._fail_2)
+
+    def _stage_10(self, acc, request, cursor, notify, rows):
+        if self.schema_test("path", cursor.fetchall()):
+            notify('Found Ampache pre 3.7 schema')
+            self._hand_over(AMPACHE)
+        else:
+            request(("DESCRIBE catalog_local",), self._stage_11, self._fail_2)
+
+    def _stage_11(self, acc, request, cursor, notify, rows):
+        if self.schema_test("path", cursor.fetchall()):
+            notify('Found Ampache 3.7 schema')
+            self._hand_over(AMPACHE_3_7)
+        else:
+            notify('Unrecognised database')
+            self._safe_disconnect()
diff --git a/python/sourceclientgui.py b/python/sourceclientgui.py
index 2747407..28a0aa6 100644
--- a/python/sourceclientgui.py
+++ b/python/sourceclientgui.py
@@ -34,6 +34,7 @@ import xml.etree.ElementTree
 import ctypes
 from collections import namedtuple
 from threading import Thread
+from contextlib import closing
 
 import dbus
 import pango
@@ -44,6 +45,7 @@ from idjc import FGlobs, PGlobs
 from .utils import string_multireplace
 from .gtkstuff import DefaultEntry, threadslock, HistoryEntry
 from .gtkstuff import WindowSizeTracker, FolderChooserButton
+from .gtkstuff import timeout_add, source_remove
 from .dialogs import *
 from .irc import IRCPane
 from .format import FormatControl, FormatCodecMPEG
@@ -296,6 +298,8 @@ class StatsThread(Thread):
 
 
     def run(self):
+        class NoStats(ValueError):
+            pass
         class BadXML(ValueError):
             pass
         
@@ -313,18 +317,33 @@ class StatsThread(Thread):
         opener.addheaders = [('User-agent', 'Mozilla/5.0')]
         
         try:
-            f = opener.open(stats_url)
-            xmlfeed = f.read()
-        except:
-            print "failed to get server stats for", self.url
-            return
-        f.close()
-        try:
-            dom = mdom.parseString(xmlfeed)
-        except:
-            print "failed to parse server stats for", self.url
+            try:
+                with closing(opener.open(stats_url)) as h:
+                    data = h.read()
+            except Exception:
+                raise NoStats
+
+            try:
+                dom = mdom.parseString(data)
+            except Exception:
+                if self.is_shoutcast:
+                    # SC2 servers will return an HTML page, not XML.
+                    try:
+                        # No need to log in. :)
+                        with closing(urllib2.urlopen("http://%s/statistics" %
+                                                                hostport)) as h:
+                            data = h.read()
+                        dom = mdom.parseString(data)
+                    except Exception:
+                        raise NoStats
+
+                else:
+                    raise NoStats
+                    
+        except NoStats:
+            print "failed to obtain server stats for", self.url
             return
-        
+
         try:
             if self.is_shoutcast:
                 if dom.documentElement.tagName == u'SHOUTCASTSERVER':
@@ -437,6 +456,13 @@ class ConnectionPane(gtk.VBox):
             return 0
         return 0 if s_type >= 2 else s_type + 1
 
+    def get_source_uri(self):
+        try:
+            config = ListLine(*self.liststore[0])
+        except IndexError:
+            return "No Master Server Configured"
+        return "{0.host}:{0.port}{0.mount}".format(config)
+
     def set_button(self, tab):
         st = self.get_master_server_type()
         if st:
@@ -1227,6 +1253,15 @@ class StreamTab(Tab):
             self.send(self.connection_string)
             self.receive()
 
+    @classmethod
+    def get_latin1_text(cls, widget):
+        text = cls.get_utf8_text(widget)
+        return text.decode("utf-8").encode("latin1", "replace")
+
+    @staticmethod
+    def get_utf8_text(widget):
+        return widget.get_text().strip()
+
     def cb_server_connect(self, widget):
         if widget.get_active():
             self.start_stop_encoder(ENCODER_START)
@@ -1240,7 +1275,17 @@ class StreamTab(Tab):
             else:
                 user_agent = ""
             
-            self.troubleshooting.user_agent_entry.get_text().strip()
+            # Determine the correct character encoding for fixed metadata.
+            if d["server_type"] == 1:
+                if self.shoutcast_latin1.get_active():
+                    proc = self.get_latin1_text
+                else:
+                    proc = self.get_utf8_text
+            else:
+                if self.format_control.get_settings()["family"] == "mpeg":
+                    proc = self.get_latin1_text
+                else:
+                    proc = self.get_utf8_text
 
             self.connection_string = "\n".join((
                     "stream_source=" + str(self.numeric_id),
@@ -1252,13 +1297,13 @@ class StreamTab(Tab):
                     "login=" + d["login"],
                     "password=" + d["password"],
                     "useragent=" + user_agent,
-                    "dj_name=" + self.dj_name_entry.get_text().strip(),
-                    "listen_url=" + self.listen_url_entry.get_text().strip(),
-                    "description=" + self.description_entry.get_text().strip(),
-                    "genre=" + self.genre_entry.get_text().strip(),
-                    "irc=" + self.irc_entry.get_text().strip(),
-                    "aim=" + self.aim_entry.get_text().strip(),
-                    "icq=" + self.icq_entry.get_text().strip(),
+                    "dj_name=" + proc(self.dj_name_entry),
+                    "listen_url=" + proc(self.listen_url_entry),
+                    "description=" + proc(self.description_entry),
+                    "genre=" + proc(self.genre_entry),
+                    "irc=" + proc(self.irc_entry),
+                    "aim=" + proc(self.aim_entry),
+                    "icq=" + proc(self.icq_entry),
                     "make_public=" + str(bool(self.make_public.get_active())),
                     "command=server_connect\n"))
             self.send(self.connection_string)
@@ -1267,6 +1312,13 @@ class StreamTab(Tab):
                 self.server_connect.set_active(False)
                 self.connection_string = None
             else:
+                ircmetadata = {"djname": self.dj_name_entry.get_text().strip(),
+                    "description": self.description_entry.get_text().strip(),
+                    "url": self.listen_url_entry.get_text().strip(),
+                    "source": self.connection_pane.get_source_uri()
+                    }
+                self.ircpane.connections_controller.new_metadata(ircmetadata)
+                
                 self.connection_pane.streaming_set(True)
         else:
             self.send("command=server_disconnect\n")
@@ -1291,6 +1343,11 @@ class StreamTab(Tab):
         """Reference counting starter and stopper for the encoder."""
                 
         if command == ENCODER_START:
+            if not self.format_control.running:
+                # Custom metadata encoding may have been changed.
+                self.metadata_update.clicked()
+
+            # Must run this to bump reference counter regardless of if running.
             self.format_control.start_encoder_rc()
         elif command == ENCODER_STOP:
             self.format_control.stop_encoder_rc()
@@ -1645,8 +1702,9 @@ class StreamTab(Tab):
         stream_details_pane.show()
 
         vbox = gtk.VBox()
+        vbox.set_border_width(10)
+        vbox.set_spacing(10)
         alhbox = gtk.HBox()
-        alhbox.set_border_width(10)
         alhbox.set_spacing(3)
         label = gtk.Label(_('Master server admin password'))
         alhbox.pack_start(label, False)
@@ -1661,9 +1719,8 @@ class StreamTab(Tab):
         self.admin_password_entry.show()
         vbox.pack_start(alhbox, False)
         alhbox.show()
-              
+
         frame = CategoryFrame(" %s " % _('Contact Details'))
-        frame.set_shadow_type(gtk.SHADOW_NONE)
         frame.set_border_width(0)
         self.irc_entry = gtk.Entry()
         set_tip(self.irc_entry,
@@ -1687,6 +1744,13 @@ class StreamTab(Tab):
         vbox.pack_start(frame, False)
         frame.show_all()
 
+        self.shoutcast_latin1 = gtk.CheckButton(
+                        _('Use ISO-8859-1 encoding for fixed metadata'))
+        set_tip(self.shoutcast_latin1,
+                        _('Enable this if sending to a Shoutcast V1 server.'))
+        vbox.pack_start(self.shoutcast_latin1, False)
+        self.shoutcast_latin1.show()
+
         label = gtk.Label(_('Extra Shoutcast'))
         self.details_nb.append_page(vbox, label)
         label.show()
@@ -1734,6 +1798,7 @@ class StreamTab(Tab):
             "irc_data" : (self.ircpane, "marshall"),
             "format_data" : (self.format_control, "marshall"),
             "details_nb" : (self.details_nb, "current_page"),
+            "shoutcast_latin1" : (self.shoutcast_latin1, "active"),
         }
                                 
         self.objects.update(self.troubleshooting.objects)
@@ -1758,14 +1823,16 @@ class RecordTab(Tab):
                         filename = datetime.datetime.today().strftime(self.parentobject.scg.parent.prefs_window.recorder_filename.get_text().strip())
                         table = (("$$", "$"), ("$r", "%02d" % (self.parentobject.numeric_id + 1)))
                         filename = string_multireplace(filename, table)
+                        folder = sd.file_chooser_button.get_current_folder()
                         self.parentobject.send("record_source=%d\n"
                             "record_filename=%s\n"
                             "record_folder=%s\ncommand=recorder_start\n" % (
-                            num_id, filename,
-                            sd.file_chooser_button.get_current_folder()))
+                            num_id, filename, folder))
                         sd.set_sensitive(False)
                         self.parentobject.time_indicator.set_sensitive(True)
+                        self.path = folder
                         self.recording = True
+                        self.parentobject.recordstate(True, self.path)
                         if self.parentobject.receive() == "failed":
                             self.stop_button.clicked()
                 else:
@@ -1783,6 +1850,7 @@ class RecordTab(Tab):
                         self.parentobject.time_indicator.set_sensitive(False)
                         if self.pause_button.get_active():
                             self.pause_button.set_active(False)
+                        self.parentobject.recordstate(False, self.path)
                     else:
                         widget.set_active(True)
             elif userdata == "stop":
@@ -1809,6 +1877,7 @@ class RecordTab(Tab):
             CategoryFrame.__init__(self)
             self.parentobject = parent
             self.stop_pressed = False
+            self.path = None
             self.recording = False
             hbox = gtk.HBox()
             hbox.set_border_width(3)
@@ -1947,6 +2016,9 @@ class RecordTab(Tab):
         Tab.show_indicator(self, colour)
         self.scg.parent.recording_panel.indicator[self.numeric_id
                                                         ].set_indicator(colour)
+       
+    def recordstate(self, state, path):
+        self.scg._handle_recordstate(self.numeric_id, state, path)
         
     def __init__(self, scg, numeric_id, indicator_lookup):
         Tab.__init__(self, scg, numeric_id, indicator_lookup)
@@ -2133,6 +2205,7 @@ class SourceClientGui(dbus.service.Object):
     def new_plugin_started(self):
         print "streamstate_cache purge"
         self._streamstate_cache = {}
+        self._recordstate_cache = {}
 
     def monitor(self):
         self.led_alternate = not self.led_alternate
@@ -2151,8 +2224,12 @@ class SourceClientGui(dbus.service.Object):
                     rectab.show_indicator(("clear", "red", "amber", "clear")[
                                                         int(recorder_state)])
                     rectab.time_indicator.set_value(int(recorded_seconds))
-                    if recorder_state != "0":
+                    rec_state = recorder_state != "0"
+                    if rec_state:
                         recording = True
+                        
+                    self._handle_recordstate(rectab.numeric_id, rec_state,
+                                            rectab.record_buttons.path)
         update_listeners = False
         l_count = 0
         for streamtab in self.streamtabframe.tabs:
@@ -2255,10 +2332,21 @@ class SourceClientGui(dbus.service.Object):
             self.streamstate_changed(numeric_id, connected,
                                     streamtab.server_connect_label.get_text())
 
+    def _handle_recordstate(self, numeric_id, state, pathname):
+        cache = self._recordstate_cache
+
+        if cache is not None and (numeric_id not in cache or cache[numeric_id] != state):
+            cache[numeric_id] = state
+            self.recordstate_changed(numeric_id, state, pathname or "")
+
     @dbus.service.signal(dbus_interface=PGlobs.dbus_bus_basename, signature="uus")
     def streamstate_changed(self, numeric_id, state, where):
         pass
-        
+
+    @dbus.service.signal(dbus_interface=PGlobs.dbus_bus_basename, signature="uus")
+    def recordstate_changed(self, numeric_id, state, where):
+        pass
+
     def stop_streaming_all(self):
         for streamtab in self.streamtabframe.tabs:
             streamtab.server_connect.set_active(False)
@@ -2272,7 +2360,7 @@ class SourceClientGui(dbus.service.Object):
         self.stop_recording_all()
         self.stop_streaming_all()
         self.stop_irc_all()
-        gobject.source_remove(self.monitor_source_id)
+        source_remove(self.monitor_source_id)
         self.monitor()
     def app_exit(self):
         if self.parent.session_loaded:
@@ -2341,17 +2429,11 @@ class SourceClientGui(dbus.service.Object):
         if self.receive() == "succeeded":
             print "updated song metadata successfully"
 
-        common = {"artist": artist, "title": title, "album": album,
+        ircmetadata = {"artist": artist, "title": title, "album": album,
                                                         "songname": songname}
-        # Update the custom metadata on all stream tabs.
+        # Update the song metadata on all stream tabs.
         for tab in self.streamtabframe.tabs:  
             tab.metadata_update.clicked()
-            ircmetadata = {"djname": tab.dj_name_entry.get_text(),
-                                "description": tab.description_entry.get_text(),
-                                "url": tab.listen_url_entry.get_text()
-            }
-            ircmetadata.update(common)
-
             tab.ircpane.connections_controller.new_metadata(ircmetadata)
         
     def source_client_open(self):
@@ -2759,7 +2841,7 @@ class SourceClientGui(dbus.service.Object):
         self.last_message_time = 0
         self.connection_string = None
         self.is_shoutcast = False
-        self._streamstate_cache = None
+        self._streamstate_cache = self._recordstate_cache = None
         self.artist = self.title = self.album = self.songname = ""
 
         self.dialog_group = dialog_group()
@@ -2773,7 +2855,7 @@ class SourceClientGui(dbus.service.Object):
             _('<span weight="bold" size="12000">A scheduled stream'
             ' disconnection has occurred.</span>'))
         
-        self.monitor_source_id = gobject.timeout_add(250, threadslock(self.monitor))
+        self.monitor_source_id = timeout_add(250, threadslock(self.monitor))
         self.window.realize()   # Prevent a rendering bug.
         
         dbus.service.Object.__init__(self,

-- 
idjc packaging



More information about the pkg-multimedia-commits mailing list