[boinc-app-seti] 01/04: Imported Upstream version 7.07~svn1976

Gianfranco Costamagna locutusofborg-guest at alioth.debian.org
Thu Sep 5 07:28:01 UTC 2013


This is an automated email from the git hooks/post-receive script.

locutusofborg-guest pushed a commit to annotated tag debian/7.07_svn1976-1
in repository boinc-app-seti.

commit 14e9127047b285b291dba32549b878a453a8a457
Author: Gianfranco Costamagna <costamagnagianfranco at yahoo.it>
Date:   Wed Sep 4 18:43:22 2013 +0200

    Imported Upstream version 7.07~svn1976
---
 _autosetup                             |    4 +-
 build_android_client.sh                |   59 +
 client/Makefile.am                     |    3 +
 client/analyzeFuncs.cpp                |   11 +-
 client/analyzeFuncs.h                  |   10 +
 client/analyzePoT.cpp                  | 1344 +++----
 client/pulsefind.h                     |    7 +
 client/sah_gfx_main.cpp                |  134 +-
 client/sah_gfx_main.h                  |   86 +-
 client/seti.cpp                        |  109 +-
 client/vector/analyzeFuncs_fpu.cpp     |    2 +-
 client/vector/analyzeFuncs_neon.S      | 2690 +++++++++++++
 client/vector/analyzeFuncs_vector.cpp  |  193 +-
 client/vector/analyzeFuncs_vector.h    |   98 +-
 client/vector/analyzeFuncs_vfp.S       | 2243 +++++++++++
 client/vector/analyzeFuncs_vfp_aux.cpp |  222 ++
 client/vector/fp_arm.h                 |   98 +
 client/vector/hires_timer.cpp          |   25 +-
 client/vector/hires_timer.h            |    7 +-
 client/worker.cpp                      |   10 +
 compile                                |   99 -
 config.guess                           | 1465 -------
 config.sub                             | 1569 --------
 configure.ac                           |   27 +-
 db/schema_master.cpp                   | 2086 +++++++++-
 db/schema_master.h                     |  190 +
 db/schema_master.sql                   |   10 +-
 depcomp                                |  464 ---
 install-sh                             |  251 --
 ltmain.sh                              | 6496 --------------------------------
 m4/libtool.m4                          | 6163 ------------------------------
 m4/sah_namespace.m4                    |    8 +-
 missing                                |  336 --
 33 files changed, 8824 insertions(+), 17695 deletions(-)

diff --git a/_autosetup b/_autosetup
index bb12e42..db600cd 100755
--- a/_autosetup
+++ b/_autosetup
@@ -122,8 +122,8 @@ check_version()
       # build_lsc_aux "automake-1.8.5"
   fi
 
-  ## ---------- ok, now run aclocal, automake, autohead and autoconf
-  cmdline="aclocal -I m4 && autoheader && automake && autoconf";
+  ## ---------- ok, now run autoreconf
+  cmdline="autoreconf -i";
 echo "$cmdline"
 if eval $cmdline; then
     echo "Done, now run ./configure"
diff --git a/build_android_client.sh b/build_android_client.sh
new file mode 100755
index 0000000..cc7f245
--- /dev/null
+++ b/build_android_client.sh
@@ -0,0 +1,59 @@
+#!/bin/sh
+
+#
+# See: http://boinc.berkeley.edu/trac/wiki/AndroidBuildApp#
+#
+
+# Script to compile various BOINC libraries for Android to be used
+# by science applications
+
+COMPILEBOINC="yes"
+CONFIGURE="yes"
+MAKECLEAN="yes"
+
+export BOINC="../boinc" #BOINC source code
+export OPENSSL_DIR=$BOINC/../boinc_depends_android_eclipse/openssl
+export CURL_DIR=$BOINC/../boinc_depends_android_eclipse/curl
+export PKG_CONFIG_DEBUG_SPEW=1
+
+export ANDROIDTC="/usr/arm-linux-androideabi"
+export TCBINARIES="$ANDROIDTC/bin"
+export TCINCLUDES="$ANDROIDTC/arm-linux-androideabi"
+export TCSYSROOT="$ANDROIDTC/sysroot"
+export STDCPPTC="$TCINCLUDES/lib/libstdc++.a"
+
+export CROSS_PREFIX=arm-linux-androideabi
+export ac_cv_host=${CROSS_PREFIX}
+
+export PATH="$PATH:$TCBINARIES:$TCINCLUDES/bin"
+export CC=${CROSS_PREFIX}-gcc
+export CCAS=${CROSS_PREFIX}-gcc
+export CXX=${CROSS_PREFIX}-g++
+export LD=${CROSS_PREFIX}-ld
+export NM=${CROSS_PREFIX}-nm
+export AR=${CROSS_PREFIX}-ar
+export STRIP=${CROSS_PREFIX}-strip
+export RANLIB=${CROSS_PREFIX}-ranlib
+
+export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -O3 -fomit-frame-pointer -mfloat-abi=softfp -march=armv7-a -mtune=cortex-a9 -mfpu=vfpv3-d16"
+export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -funroll-loops -fexceptions -O3 -fomit-frame-pointer -mfloat-abi=softfp -march=armv7-a -mtune=cortex-a9 -mfpu=vfpv3-d16"
+export CCASFLAGS="${CFLAGS}"
+export LDFLAGS="-L$TCINCLUDES/lib/armv7-a -L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -lstdc++"
+export LIBS="/usr/arm-linux-androideabi/arm-linux-androideabi/lib/armv7-a/libstdc++.a"
+export PKG_CONFIG_SYSROOT_DIR=$TCSYSROOT
+export PKG_CONFIG_PATH=$CURL_DIR/lib/pkgconfig:$OPENSSL_DIR/lib/pkgconfig
+
+if [ -n "$COMPILEBOINC" ]; then
+echo "==================building Libraries from $BOINC=========================="
+if [ -n "$MAKECLEAN" ]; then
+make clean
+fi
+if [ -n "$CONFIGURE" ]; then
+./_autosetup
+./configure -C --host=${ac_cv_host} --prefix="${ANDROIDTC}/arm-linux-androideabi" --exec-prefix="${ANDROIDTC}/arm-linux-androideabi" --with-boinc-platform="arm-android-linux-gnu" --with-ssl=$TCINCLUDES --disable-graphics --disable-server 
+fi
+make
+
+echo "=============================BOINC done============================="
+
+fi
diff --git a/client/Makefile.am b/client/Makefile.am
index cefb71d..bed9cf5 100644
--- a/client/Makefile.am
+++ b/client/Makefile.am
@@ -71,6 +71,9 @@ seti_boinc_SOURCES = \
     vector/analyzeFuncs_avx.cpp \
     vector/analyzeFuncs_x86_64.cpp \
     vector/analyzeFuncs_altivec.cpp \
+    vector/analyzeFuncs_neon.S \
+    vector/analyzeFuncs_vfp.S \
+    vector/analyzeFuncs_vfp_aux.cpp \
     vector/x86_float4.cpp \
     vector/hires_timer.cpp \
     analyzeFuncs.cpp \
diff --git a/client/analyzeFuncs.cpp b/client/analyzeFuncs.cpp
index c2a8480..c1ddfce 100644
--- a/client/analyzeFuncs.cpp
+++ b/client/analyzeFuncs.cpp
@@ -171,7 +171,8 @@ int seti_analyze (ANALYSIS_STATE& state) {
 
     use_transposed_pot= (!notranspose_flag) &&
                         ((app_init_data.host_info.m_nbytes != 0)  &&
-                        (app_init_data.host_info.m_nbytes >= (double)(96*1024*1024)));
+                        (app_init_data.host_info.m_nbytes >= MIN_TRANSPOSE_MEMORY));
+   
     int num_cfft                  = 0;
     float chirprate;
     int last_chirp_ind = - 1 << 20, chirprateind;
@@ -336,7 +337,7 @@ int seti_analyze (ANALYSIS_STATE& state) {
     // Initialize TrigArrays for testing if we have the memory....
     // If we can't tell how much memory we have, assume we have plenty.
     if ((app_init_data.host_info.m_nbytes == 0)  ||
-            (app_init_data.host_info.m_nbytes >= (double)(64*1024*1024))) {
+            (app_init_data.host_info.m_nbytes >= MIN_TRIGARRAY_MEMORY)) {
         InitTrigArray (NumDataPoints, MinChirpStep,
                        TESTCHIRPIND,
                        swi.subband_sample_rate);
@@ -357,7 +358,7 @@ int seti_analyze (ANALYSIS_STATE& state) {
                     state.icfft == 0);
 
     if ((app_init_data.host_info.m_nbytes == 0)  ||
-            (app_init_data.host_info.m_nbytes >= (double)(64*1024*1024))) {
+            (app_init_data.host_info.m_nbytes >= MIN_TRIGARRAY_MEMORY)) {
         FreeTrigArray();
         // If we're using TrigArrays, reallocate & reinit
         if ((ChirpData == v_ChirpData) || (ChirpData == fpu_opt_ChirpData)) {
@@ -726,7 +727,7 @@ int seti_analyze (ANALYSIS_STATE& state) {
 
     if (ChirpFftPairs) free(ChirpFftPairs);
     if ((app_init_data.host_info.m_nbytes == 0)  ||
-            (app_init_data.host_info.m_nbytes >= (double)(64*1024*1024))) {
+            (app_init_data.host_info.m_nbytes >= MIN_TRIGARRAY_MEMORY)) {
         FreeTrigArray();
     }
 
@@ -973,7 +974,7 @@ int v_ChirpData(
         // If we have more than 64MB, we'll cache the chirp table.  If not
         // we'll calculate it each time.
         bool CacheChirpCalc=((app_init_data.host_info.m_nbytes == 0)  ||
-                             (app_init_data.host_info.m_nbytes >= (double)(64*1024*1024)));
+                             (app_init_data.host_info.m_nbytes >= MIN_TRIGARRAY_MEMORY));
 
         // calculate trigonometric array
         // this function returns w/o doing nothing when sign of chirp_rate_ind
diff --git a/client/analyzeFuncs.h b/client/analyzeFuncs.h
index 954cc02..18c5328 100644
--- a/client/analyzeFuncs.h
+++ b/client/analyzeFuncs.h
@@ -54,6 +54,16 @@
 #define TRIPLET_PROGRESS_FACTOR         0.1f
 #define PULSE_PROGRESS_FACTOR(N)        (N/14.0f)
 */
+#define KILOBYTE 1024L
+#define MEGABYTE 1048576L
+
+#ifdef ANDROID
+#define MIN_TRANSPOSE_MEMORY static_cast<double>(512*MEGABYTE)
+#define MIN_TRIGARRAY_MEMORY static_cast<double>(384*MEGABYTE)
+#else
+#define MIN_TRANSPOSE_MEMORY static_cast<double>(96*MEGABYTE)
+#define MIN_TRIGARRAY_MEMORY static_cast<double>(64*MEGABYTE)
+#endif
 
 #define PROGRESS_DISPLAY_RES 1.0
 // for text-only versions: display progress with every 1%
diff --git a/client/analyzePoT.cpp b/client/analyzePoT.cpp
index 0906b30..54f9d78 100644
--- a/client/analyzePoT.cpp
+++ b/client/analyzePoT.cpp
@@ -1,672 +1,672 @@
-// Copyright 2003 Regents of the University of California
-
-// SETI_BOINC is free software; you can redistribute it and/or modify it under
-// the terms of the GNU General Public License as published by the Free
-// Software Foundation; either version 2, or (at your option) any later
-// version.
-
-// SETI_BOINC 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 SETI_BOINC; see the file COPYING.  If not, write to the Free Software
-// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-
-// In addition, as a special exception, the Regents of the University of
-// California give permission to link the code of this program with libraries
-// that provide specific optimized fast Fourier transform (FFT) functions and
-// distribute a linked executable.  You must obey the GNU General Public
-// License in all respects for all of the code used other than the FFT library
-// itself.  Any modification required to support these libraries must be
-// distributed in source code form.  If you modify this file, you may extend
-// this exception to your version of the file, but you are not obligated to
-// do so. If you do not wish to do so, delete this exception statement from
-// your version.
-
-// $Id: analyzePoT.cpp,v 1.24.2.13 2007/08/10 00:38:47 korpela Exp $
-//
-
-#include "sah_config.h"
-
-#include <cstdio>
-#include <cmath>
-#include <cstring>
-#include <cstdlib>
-
-#ifdef HAVE_UNISTD_H
-#include <unistd.h>
-#endif
-
-#ifdef BOINC_APP_GRAPHICS
-#include "sah_gfx_main.h"
-#endif
-
-#include "util.h"
-#include "malloc_a.h"
-#include "analyze.h"
-#include "seti.h"
-#include "worker.h"
-#include "analyzeFuncs.h"
-#include "analyzePoT.h"
-#include "analyzeReport.h"
-#include "gaussfit.h"
-#include "pulsefind.h"
-#include "chirpfft.h"
-#include "filesys.h"
-#include "util.h"
-#include "s_util.h"
-#include "progress.h"
-
-//#define DEBUG_POT
-
-// Compile time inits.  Command line parms of setiathome_test can
-// change a number of these.
-PoTInfo_t PoTInfo =  {0};
-
-int analyze_pot(
-    float *PowerSpectrum,
-    int NumDataPoints,
-    ChirpFftPair_t &cfft
-) {
-
-
-    // This function analyses Power over Time for the current data block.
-    // The PoT array  is created by taking an array of power spectra (a
-    // standard row-major 2D array)  and extracting the PoT as column-major
-    // data.  We essentialy turn the array on its side.
-
-    int  retval = 0,
-                  i,
-                  FftLength=cfft.FftLen,  // Current FFT length
-                            ThisPoT,          // index of current PoT along the freq axis
-                            PoTLen,           // compliment of FFT length - determines time res
-                            PulsePoTLen,      // length of PoT segment passed to pulse finders
-                            Overlap,          // PoT segment overlap in bins
-                            TOffset,          // index into ThisPoT of current pulse segment
-                            PulsePoTNum  = 0, // the oridinal position of a pulse PoT w/in a full PoT
-                                           NumPulsePoTs = 0, // the number of pulse PoTs w/in a full PoT.  This is
-                                                          //   constant regardless of FFT or PoT length and is
-                                                          //   determined by slew rate.
-                                                          AdvanceBy;        // the number of bins to advance for the next pulse PoT
-
-    float ProgressAddFactor = 0.0,    // sum of progress adds for ThisPoT
-                              ProgressPerPulsePoT = 0.0;  // for local progress display
-
-    bool SkipGauss   = false,
-                       SkipPulse   = false,
-                                     SkipTriplet = false,
-                                                   TOffsetOK   = true;
-
-    static float  *GaussPoT = NULL,
-                              *PulsePoT = NULL;
-
-#ifdef DUMP_POWER_SPECTRA
-
-    if (ul_FftLength == FFT_TO_DUMP) {
-        for (i=0;i<ul_NumDataPoints;i++) {
-            fprintf(stdout,"%f\n",fp_PowerSpectrum[i]);
-        }
-    }
-#endif
-#ifdef DEBUG_POT
-    fprintf(stderr, "========= FftLength = %d =========\n", FftLength);
-#endif
-
-    PoTLen              = NumDataPoints / FftLength;               // in bins
-    GetPulsePoTLen(PoTLen, &PulsePoTLen, &Overlap);     // in bins
-    AdvanceBy  = PulsePoTLen - Overlap;     // in bins
-
-    // Max limits how *slow* the slewrate can be, while Min limits how
-    // *fast* the slewrate can be.  Max is limited only by the client
-    // memory budget.
-    if(PulsePoTLen > PoTInfo.TripletMax || PulsePoTLen < PoTInfo.TripletMin)
-        SkipTriplet = true;
-    SkipGauss = !(cfft.GaussFit);
-    SkipPulse = !(cfft.PulseFind);
-
-    if(!SkipPulse || !SkipTriplet) {
-        // NumPulsePoTs is the number of PoT segments that we pass to the pulse
-        // detectors per frequency bin.  ProgressPerPulsePoT is the inverse of
-        // number of pulse detection segments in the entire data block, taking
-        // into account that we skip the first (DC) frequency bin.  An assumption
-        // is made here that minimum pulse/triplet PoT length will always be
-        // greater than 1. Otherwise, AdvanceBy can become zero and a divide by
-        // zero can occur.  The assumption is also made that FftLength is always
-        // greater than 1!
-        NumPulsePoTs = 1 + (PoTLen-PulsePoTLen)/AdvanceBy + ((PoTLen-PulsePoTLen)%AdvanceBy ? 1 : 0);
-        ProgressPerPulsePoT = (float)1 / ((FftLength - 1) * NumPulsePoTs);
-    }
-
-#ifdef DEBUG_POT
-    fprintf(stderr, "SlewRate = %f\n", PoTInfo.SlewRate);
-    fprintf(stderr, "PoTLen = %d\n", PoTLen);
-    fprintf(stderr, "MaxPoTLen = %d\n", PoTInfo.MaxPoTLen);
-    fprintf(stderr, "PoTDuration = %f\n", PoTInfo.WUDuration);
-    fprintf(stderr, "BeamRate = %f\n", PoTInfo.BeamRate);
-    fprintf(stderr, "PulsePoTLen = %d\n", PulsePoTLen);
-    fprintf(stderr, "Overlap = %d\n", Overlap);
-    fprintf(stderr, "AdvanceBy = %d\n", AdvanceBy);
-    fprintf(stderr, "min_slew = %f\n", PoTInfo.min_slew);
-    fprintf(stderr, "max_slew = %f\n", PoTInfo.max_slew);
-    fprintf(stderr, "PulseOverlapFactor = %f\n", PoTInfo.PulseOverlapFactor);
-    fprintf(stderr, "PulseBeams = %f\n", PoTInfo.PulseBeams);
-    fprintf(stderr, "PulseThresh = %f\n", PoTInfo.PulseThresh);
-    fprintf(stderr, "PulseMax = %d\n", PoTInfo.PulseMax);
-    fprintf(stderr, "PulseMin = %d\n", PoTInfo.PulseMin);
-    fprintf(stderr, "PulseFftMax = %d\n", PoTInfo.PulseFftMax);
-    fprintf(stderr, "TripletThresh = %f\n", PoTInfo.TripletThresh);
-    fprintf(stderr, "TripletMax = %d\n", PoTInfo.TripletMax);
-    fprintf(stderr, "TripletMin = %d\n", PoTInfo.TripletMin);
-#endif
-
-#ifndef USE_PULSE
-
-    SkipPulse = TRUE;
-#endif
-#ifndef USE_TRIPLET
-
-    SkipTriplet = TRUE;
-#endif
-
-    // Get memory fot the PoT arrays. The PoT array for gausian analysis is
-    // of set size.  The PoT array for pulse analysis is sized to cover
-    // PulseBeams beams, regardless of whether this violates either the
-    // triplet or pulse limits on array size.
-    if(!GaussPoT) {
-        GaussPoT = (float *)malloc_a(swi.analysis_cfg.gauss_pot_length * sizeof(float), MEM_ALIGN);
-        if(GaussPoT == NULL) {
-            SETIERROR(MALLOC_FAILED, "GaussPoT == NULL");
-        }
-    }
-    if(!PulsePoT) {
-        PulsePoT = (float *)calloc_a(PoTInfo.MaxPoTLen+3, sizeof(float), MEM_ALIGN);
-        if(PulsePoT == NULL) {
-            SETIERROR(MALLOC_FAILED, "PulsePoT == NULL");
-        }
-    }
-
-    // Look for gaussians ---------------------------------------------------
-    if(!SkipGauss && (analysis_state.PoT_activity == POT_DOING_GAUSS ||
-                      analysis_state.PoT_activity == POT_INACTIVE)) {
-
-#ifdef BOINC_APP_GRAPHICS
-        if (sah_graphics)
-            strcpy(sah_graphics->status, "Searching for Gaussians");
-#endif
-
-        // If we are back from being interrupted in the middle of gaussian PoT
-        // analysis, load state and continue.  Otherwise start anew, skipping
-        // the DC (0) bin.
-        if(analysis_state.PoT_activity == POT_DOING_GAUSS) {
-            ThisPoT = analysis_state.PoT_freq_bin;
-        } else {
-            ThisPoT = 1; // skip the DC bin on start of new cfft pair
-        }
-
-        // Initial display of local Progress / CPU time. Assumes that
-        // we start ThisPoT at 1 each time in!
-#ifdef BOINC_APP_GRAPHICS
-        if (sah_graphics)
-            sah_graphics->local_progress = ((float)ThisPoT-1)/(FftLength-1);
-#endif
-
-        // loop through frequencies
-        for(; ThisPoT < FftLength; ThisPoT++) {
-
-            // Create PowerOfTime array for gaussian fit
-            retval = GetFixedPoT(
-                         PowerSpectrum,
-                         NumDataPoints,
-                         FftLength,
-                         GaussPoT,
-                         swi.analysis_cfg.gauss_pot_length,
-                         ThisPoT
-                     );
-            if (retval)
-                continue;
-
-            retval = GaussFit(GaussPoT, FftLength, ThisPoT);
-            if (retval)
-                SETIERROR(retval,"from GaussFit");
-
-
-
-            progress += ProgressUnitSize * GaussianProgressUnits() / (float)(FftLength - 1);
-            progress=std::min(progress,1.0); // prevent display of > 100%
-            fraction_done(progress,remaining);
-            
-            // At the end of each frequency bin we update progress and save state.
-#ifdef BOINC_APP_GRAPHICS
-            if (!nographics()) {
-                sah_graphics->local_progress = ((float)ThisPoT)/(FftLength-1);
-            }
-#endif  
-            analysis_state.PoT_freq_bin = ThisPoT;
-            analysis_state.PoT_activity = POT_DOING_GAUSS;
-            retval = checkpoint();
-            if (retval)
-                SETIERROR(retval,"from checkpoint()");
-
-        }   // end loop through frequencies
-
-        analysis_state.PoT_freq_bin = -1;
-        analysis_state.PoT_activity = POT_INACTIVE;
-
-    }   // end looking for gaussians
-
-
-    // Look for pulses -------------------------------------------------------
-    if(!SkipPulse || !SkipTriplet) {
-
-#ifdef BOINC_APP_GRAPHICS
-        if (sah_graphics) {
-            strcpy(sah_graphics->status, "Searching for Pulses / Triplets");
-            // init local progress for pulse search
-            sah_graphics->local_progress = 0;
-        }
-#endif
-
-
-        // If we are back from being interrupted in the middle of pulse PoT
-        // analysis, load state and continue.  Otherwise start anew, skipping
-        // the DC (0) bin.
-        if(analysis_state.PoT_activity == POT_DOING_PULSE) {
-            ThisPoT = analysis_state.PoT_freq_bin;
-        } else {
-            ThisPoT = 1; // skip the DC bin on start of new cfft pair
-        }
-
-        PulsePoTNum = 0;
-
-#ifdef BOINC_APP_GRAPHICS
-        // Inital display of Local Progress
-        if (sah_graphics) {
-            sah_graphics->local_progress = (((ThisPoT-1) * NumPulsePoTs) +
-                                            PulsePoTNum)                   *
-                                           ProgressPerPulsePoT;
-        }
-#endif
-
-        // loop through frequencies
-        for(; ThisPoT < FftLength; ThisPoT++) {
-
-            // loop through time for each frequency.  PulsePoTNum is
-            // used only for progress calculation.
-            for(TOffset = 0, PulsePoTNum = 1, TOffsetOK = true;
-                    TOffsetOK;
-                    PulsePoTNum++, TOffset += AdvanceBy) {
-
-                // Create PowerOfTime array for pulse detection.  If there
-                // are not enough points left in this PoT, adjust TOffset
-                // to get the latest possible pulse PoT.
-                if(TOffset + PulsePoTLen >= PoTLen) {
-                    TOffsetOK = false;
-                    TOffset = PoTLen - PulsePoTLen;
-                }
-                if (use_transposed_pot) {
-                  memcpy(PulsePoT, &PowerSpectrum[ThisPoT * PoTLen + TOffset], PulsePoTLen*sizeof(float));
-		} else {
-                   for(i = 0; i < PulsePoTLen; i++) {
-                       PulsePoT[i] = PowerSpectrum[ThisPoT + (TOffset+i) * FftLength];
-                   }
-		}
-
-                if(!SkipTriplet) {
-                    retval = find_triplets(PulsePoT,
-                                           PulsePoTLen,
-                                           (float)PoTInfo.TripletThresh,
-                                           TOffset,
-                                           ThisPoT);
-                    if (retval)
-                        SETIERROR(retval,"from find_triplets()");
-                }
-
-                if(!SkipPulse) {
-                    retval = find_pulse(PulsePoT,
-                                        PulsePoTLen,
-                                        (float)PoTInfo.PulseThresh,
-                                        TOffset,
-                                        ThisPoT
-                                       );
-                    if (retval)
-                        SETIERROR(retval,"from find_pulse()");
-                }
-
-                // At the end of each pulse PoT we update progress.  Progress
-                // will thus get updted several times per frequency bin.
-#ifdef BOINC_APP_GRAPHICS
-                if (sah_graphics)
-                {
-                    sah_graphics->local_progress = (((ThisPoT-1) * NumPulsePoTs) +
-                                                    PulsePoTNum)                   *
-                                                   ProgressPerPulsePoT;
-                }
-#endif
-                if(!SkipTriplet) {
-                    progress += (ProgressUnitSize * TripletProgressUnits()) /
-                                (float)(FftLength - 1) / NumPulsePoTs;
-                }
-                if(!SkipPulse) {
-                    progress += (ProgressUnitSize * PulseProgressUnits(PulsePoTLen, FftLength - 1)) /
-                                (float)(FftLength - 1) / NumPulsePoTs;
-
-                }
-                progress=std::min(progress,1.0); // prevent display of > 100%
-                fraction_done(progress,remaining);
-
-            }  // end loop through time for each frequency
-
-            // At the end of each frequency bin we save state.
-            analysis_state.PoT_activity = POT_DOING_PULSE;
-            analysis_state.PoT_freq_bin = ThisPoT;
-            retval = checkpoint();
-            if (retval)
-                SETIERROR(retval,"from checkpoint()");
-
-        }   // end loop through frequencies
-
-        analysis_state.PoT_freq_bin = -1;
-        analysis_state.PoT_activity = POT_INACTIVE;
-
-    }   // end looking for pulses
-
-
-    return (retval);   // no error return point
-}
-
-int GetFixedPoT(
-    float fp_PowerSpectrum[],
-    int ul_NumDataPoints,
-    int ul_FftLength,
-    float fp_PoT[],
-    int ul_PoTLen,
-    int ul_PoT
-) {
-
-    // This routine returns a PoT array of fixed length, regardless
-    // of the actual number of time bins in the current data block.
-
-    int    ul_PoT_i,
-    ul_PoTChunkSize,
-    ul_PoTChunk_i,
-    ul_PoTChunkLimit,
-    ul_NumSpectra,
-    ul_PoTsPerSpec,
-    ul_MidPoint,
-    ul_BaseSpec,
-    ul_SubPoT_i;
-
-    float  f_Factor,
-    f_BaseSpecPowerPerPoT    = 0.0,
-                               f_AftSpecPowerPerPoT     = 0.0,
-                                                          f_ForwardSpecPowerPerPoT = 0.0,
-                                                                                     f_BaseWeight;
-
-    ul_NumSpectra    = ul_NumDataPoints / ul_FftLength;
-    ul_PoTChunkSize  = ul_NumSpectra / ul_PoTLen;
-
-    // Populate PoT
-
-    // For setiathome_enhanced, the number of spectra is the same as the
-    // number of elements in a PoT array more times than not (16K FFT length).
-    // For an 0.426 angle range, there are 2.2104e10 cases where they're equal
-    // and 2.2082e10 cases where they're not. Copying directly rather than
-    // adding also means no FLOP_counter increment is needed.
-    if (ul_NumSpectra == ul_PoTLen) {
-        if (use_transposed_pot) {
-          memcpy(fp_PoT, &fp_PowerSpectrum[ul_PoT * ul_NumSpectra],
-               swi.analysis_cfg.gauss_pot_length * sizeof(float));
-        } else { 
-          for (ul_PoT_i = 0, ul_PoTChunk_i = 0;
-                ul_PoT_i < swi.analysis_cfg.gauss_pot_length;
-                ul_PoT_i++, ul_PoTChunk_i += ul_FftLength) {
-            fp_PoT[ul_PoT_i] = fp_PowerSpectrum[ul_PoT + ul_PoTChunk_i];
-          }
-	}
-        // If the number of spectra is greater than the number
-        // of elements in a PoT array, we add sum adjacent spectra
-        // into PoT elements.
-        // ul_PoTChunkSize indicates how many time-wise
-        // power spectra bins are added together to make one PoT bin.
-    } else if (ul_NumSpectra > ul_PoTLen) {
-        ul_PoTChunk_i = 0;
-		int blksize = UNSTDMAX(1, UNSTDMIN(pow2((unsigned int) sqrt((float) ((ul_PoTChunkSize) / 32)) * 32), 512));
-        for (ul_PoT_i = 0; ul_PoT_i < swi.analysis_cfg.gauss_pot_length; ul_PoT_i++) {
-            fp_PoT[ul_PoT_i] = 0.0;
-            ul_PoTChunkLimit = ul_PoTChunk_i + ul_PoTChunkSize;
-
-            // Stuff chunk of power spectra bins into 1 PoT bin
-			int b,chunk_i;
-			float total = 0.0f,partial;
-	        if (use_transposed_pot) {
-			  for (b=0;b<ul_PoTChunkSize/blksize;b++)
-			  {
-				partial=0.0f;
-				for (chunk_i=0;chunk_i<blksize;chunk_i++)
-				{
-				  partial += fp_PowerSpectrum[ul_PoT * ul_NumSpectra + ul_PoTChunk_i + chunk_i];					
-				}
-				ul_PoTChunk_i += blksize;
-				total+=partial;
-			  }
-              for (; ul_PoTChunk_i < ul_PoTChunkLimit; ul_PoTChunk_i++) {
-                total += fp_PowerSpectrum[ul_PoT * ul_NumSpectra + ul_PoTChunk_i];
-              }
-			  fp_PoT[ul_PoT_i] = total;
-            } else { 
-			  for (b=0;b<ul_PoTChunkSize/blksize;b++)
-			  {
-				partial=0.0f;
-				for (chunk_i=0;chunk_i<blksize;chunk_i++)
-				{
-				  partial += fp_PowerSpectrum[ul_PoT +
-                                          ul_FftLength * (ul_PoTChunk_i+chunk_i)];
-				}
-				ul_PoTChunk_i += blksize;
-				total+=partial;
-			  }
-              for (; ul_PoTChunk_i < ul_PoTChunkLimit; ul_PoTChunk_i++) {
-                total += fp_PowerSpectrum[ul_PoT +
-                                          ul_FftLength * ul_PoTChunk_i];
-              }
-	          fp_PoT[ul_PoT_i] = total;
-            }
-        }
-        analysis_state.FLOP_counter+=((double)ul_NumSpectra+swi.analysis_cfg.gauss_pot_length);
-    } else {
-        // If the number of spectra is less than the the number
-        // of elements in a PoT array, we smear the power in each
-        // spectrum over more than one PoT element.  Further, we
-        // perform a linear interpolation to smooth the transition
-        // from one spectrum to the next. That is, we allow the
-        // spectra before or after our "base" spectrum to effect
-        // the powers that go into a given PoT bin.  The closer
-        // in time that the PoT bin is to the "before" or "after"
-        // spectra, the more that PoT bin is effected by the
-        // neighboring spectrum.
-        // NOTE : This is all effectively turned off by not letting
-        //        gaussfit() see data analyzed with an FFT length
-        //        greater than GAUSS_POT_LEN.
-
-        ul_PoTsPerSpec = ul_PoTLen / ul_NumSpectra;
-        // Number of PoT bins over which to smear 1 spectrum.
-        f_Factor = 1.0f / ul_PoTsPerSpec;
-        // For dividing up 1 spectrum's power pre-interpolation.
-        ul_MidPoint = ul_PoTsPerSpec / 2;
-
-        for (ul_PoT_i = 0; ul_PoT_i < swi.analysis_cfg.gauss_pot_length; ul_PoT_i++) {
-            ul_BaseSpec = int(ul_PoT_i / ul_PoTsPerSpec);
-            // The spectrum bounding the current PoT bin.
-            ul_SubPoT_i = ul_PoT_i - ul_PoTsPerSpec * ul_BaseSpec;
-            // Relative to the start of the base spectrum.
-            // Powers pre-interpolation.
-            if (use_transposed_pot) {
-              f_BaseSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
-                                    * ul_NumSpectra + ul_BaseSpec] * f_Factor;
-	    } else {
-              f_BaseSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
-                                    + ul_FftLength * ul_BaseSpec] * f_Factor;
-            }
-            if (ul_BaseSpec > 0) {
-                if (use_transposed_pot) {
-                  f_AftSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
-                                       * ul_NumSpectra + (ul_BaseSpec-1)] * f_Factor;
-                } else {
-                  f_AftSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
-                                                        + ul_FftLength * (ul_BaseSpec-1)] * f_Factor;
-                }
-            }
-            if (ul_BaseSpec < ul_NumSpectra - 1) {
-                if (use_transposed_pot) {
-                  f_ForwardSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
-                                           * ul_NumSpectra + (ul_BaseSpec+1)] * f_Factor;
-                } else {
-                  f_ForwardSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
-                                           + ul_FftLength * (ul_BaseSpec+1)] * f_Factor;
-                }
-            }
-
-            // Begin interpolation.
-            if (ul_SubPoT_i < ul_MidPoint) {
-                // Use the Aft spectrum if there is one.
-                // If not, use non-interpoated powers.
-                if (ul_BaseSpec == 0) {
-                    fp_PoT[ul_PoT_i] = f_BaseSpecPowerPerPoT;
-                } else {
-                    f_BaseWeight = (float)(ul_PoTsPerSpec - (ul_MidPoint - ul_SubPoT_i)) / ul_PoTsPerSpec;
-                    fp_PoT[ul_PoT_i] = (f_BaseSpecPowerPerPoT * f_BaseWeight)
-                                       + (f_AftSpecPowerPerPoT * (1.0f - f_BaseWeight));
-                }
-            } else {
-                // Use the Forward spectrum if there is one.
-                // If not, use non-interpoated powers.
-                if (ul_BaseSpec == ul_NumSpectra-1) {
-                    fp_PoT[ul_PoT_i] = f_BaseSpecPowerPerPoT;
-                } else {
-                    f_BaseWeight = (float)(ul_PoTsPerSpec - (ul_SubPoT_i - ul_MidPoint)) / ul_PoTsPerSpec;
-                    fp_PoT[ul_PoT_i] = (f_BaseSpecPowerPerPoT * f_BaseWeight)
-                                       + (f_ForwardSpecPowerPerPoT * (1.0f - f_BaseWeight));
-                }
-            }
-        } // end for ul_PoT_i < swi.analysis_cfg.gauss_pot_length
-        analysis_state.FLOP_counter+=(double)(9*swi.analysis_cfg.gauss_pot_length);
-    }
-    return 0;
-}
-
-void ComputePoTInfo(int num_cfft, int NumDataPoints) {
-
-    // Tis routine calculates various PoT values based on program constants
-    // and data contained in the current WU.
-
-    // A note on "sigma", calculated here and used by the gaussian finder:
-    // The sigma calculated here is in units of PoT, ie, in bins of the
-    // Power Of Time arrays.  Gaussian PoT arrays are of fixed length, given by
-    // GAUSS_POT_LEN.  The basic definition of sigma here is that it is the
-    // amount of time it takes to cover 1/2 the half-power-beamwidth of the
-    // serendip feed.  This is also a constant - BEAM_WIDTH - in units of
-    // degrees.  We scan BEAM_WIDTH degrees at a given, but variable, slew rate.
-
-
-    volatile double DegPerPotBin;    // slew rate in degrees per PoT bin
-    volatile float ftmp;             // temporary to ensure float rounding
-    int i, MinFftLen;
-
-    // jeffc - is there really any need for these PoTInfo fields
-    // at this point?
-    PoTInfo.min_slew  = swi.analysis_cfg.pot_min_slew;
-    PoTInfo.max_slew  = swi.analysis_cfg.pot_max_slew;
-    PoTInfo.PulseOverlapFactor = swi.analysis_cfg.pot_overlap_factor; // ?
-    PoTInfo.PulseBeams  = swi.analysis_cfg.pulse_beams;
-    PoTInfo.PulseThresh  = swi.analysis_cfg.pulse_thresh;
-    PoTInfo.PulseMax  = swi.analysis_cfg.pulse_max;
-    PoTInfo.PulseMin  = swi.analysis_cfg.pulse_min;
-    PoTInfo.PulseFftMax  = swi.analysis_cfg.pulse_fft_max;
-    PoTInfo.TripletThresh  = swi.analysis_cfg.triplet_thresh;
-    PoTInfo.TripletMax  = swi.analysis_cfg.triplet_max;
-    PoTInfo.TripletMin  = swi.analysis_cfg.triplet_min;
-    PoTInfo.GaussChiSqThresh      = swi.analysis_cfg.gauss_chi_sq_thresh;
-    PoTInfo.GaussPowerThresh      = swi.analysis_cfg.gauss_power_thresh;
-    PoTInfo.GaussPeakPowerThresh  = swi.analysis_cfg.gauss_peak_power_thresh;
-
-    // Find the max fft length in the chirp/fft table
-    for(i = 1, MinFftLen = ChirpFftPairs[0].FftLen; i < num_cfft; i++) {
-        if(ChirpFftPairs[i].FftLen < MinFftLen) {
-            MinFftLen = ChirpFftPairs[i].FftLen;
-        }
-    }
-
-    PoTInfo.MaxPoTLen  = NumDataPoints / MinFftLen;
-    ftmp               = (float)(swi.nsamples / swi.subband_sample_rate);
-    PoTInfo.WUDuration = ftmp;
-
-    // Here we calculate slew rate and slew related values.
-    // If there is no telescope movement, slew related values remain
-    // in their initialized state (zero).
-    if(swi.angle_range != 0.0) {
-        ftmp                        = (float)(swi.angle_range / PoTInfo.WUDuration);
-        PoTInfo.SlewRate            = ftmp;
-        ftmp                        = (float)(PoTInfo.SlewRate / swi.beam_width);
-        PoTInfo.BeamRate            = ftmp;
-        DegPerPotBin                = swi.angle_range / swi.analysis_cfg.gauss_pot_length;
-        ftmp                        = (float)((swi.beam_width/2.0f) / DegPerPotBin);
-        PoTInfo.GaussSigma          = ftmp;
-        PoTInfo.GaussSigmaSq        = PoTInfo.GaussSigma * PoTInfo.GaussSigma;
-        PoTInfo.GaussTOffsetStart   = static_cast<int>(floor(swi.analysis_cfg.pot_t_offset * PoTInfo.GaussSigma+0.5));
-        PoTInfo.GaussTOffsetStop    = swi.analysis_cfg.gauss_pot_length - PoTInfo.GaussTOffsetStart;
-    }
-}
-
-void GetPulsePoTLen(long FullPoTLen, int * PulsePoTLen, int * PulseOverlap) {
-
-    // This routine, given the time axis length of a WU in bins and data available
-    // in the PoTInfo struct, will calculate how many time bins to pass the pulse
-    // detectors for the given time axis length.  Time axis length in seconds is
-    // is constant, while length in bins is inversely proportional to FFT length.
-
-    // If slew rate is so low that, over the duration of the entire WU,
-    // we do not cover the number of beams passed to each call of the
-    // pulse finders then assume that we will be passing the entire PoT
-    // to the pulse finders.  This also takes care of the case where slew
-    // rate is zero.  Otherwise, calculate that portion of the PoT that
-    // we will be passing.
-
-    // NOTE: the code calling this routine may be concerned with either pulse finding
-    // or triplet finding.  There may be different max and/or min PoT length constraints
-    // between these 2 algorithms.  Thus, this routine just returns the length that
-    // will contain PoTInfo.PulseBeams worth of data.  It is up to the calling code
-    // to then apply any length constaints.
-
-    double       BinRate,                // function of time resolution and slew rate
-    BinsPerBeam;            // function of time res, slew rate, and beam width
-
-    // jeffc - the following line in temporary.  Pulse beams will go into the
-    // analysis config.
-    //PoTInfo.PulseBeams = 1.0;
-
-    BinRate             = FullPoTLen / PoTInfo.WUDuration;             // in bins/second
-
-    if(PoTInfo.BeamRate * PoTInfo.WUDuration < PoTInfo.PulseBeams) {
-        BinsPerBeam     = (float)FullPoTLen;    // slow slew - pass FullPoT
-    } else {
-        BinsPerBeam     = BinRate / PoTInfo.BeamRate;           // we will pass a portion of FullPoT
-    }
-
-    *PulsePoTLen         = IROUND(BinsPerBeam * PoTInfo.PulseBeams);              // in bins
-    if(*PulsePoTLen > FullPoTLen) {
-        *PulsePoTLen = FullPoTLen;    // pulse PoT longer than full PoT
-    }        // ... so pass as much as we can
-    // ... ie the full PoT
-
-    *PulseOverlap        = IROUND(BinsPerBeam * PoTInfo.PulseOverlapFactor);      // in bins
-
-#ifdef DEBUG_POT
-
-    fprintf(stderr, "BinRate = %f\n", BinRate);
-    fprintf(stderr, "BinsPerBeam = %f\n", BinsPerBeam);
-#endif
-
-}
-
+// Copyright 2003 Regents of the University of California
+
+// SETI_BOINC is free software; you can redistribute it and/or modify it under
+// the terms of the GNU General Public License as published by the Free
+// Software Foundation; either version 2, or (at your option) any later
+// version.
+
+// SETI_BOINC 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 SETI_BOINC; see the file COPYING.  If not, write to the Free Software
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+// In addition, as a special exception, the Regents of the University of
+// California give permission to link the code of this program with libraries
+// that provide specific optimized fast Fourier transform (FFT) functions and
+// distribute a linked executable.  You must obey the GNU General Public
+// License in all respects for all of the code used other than the FFT library
+// itself.  Any modification required to support these libraries must be
+// distributed in source code form.  If you modify this file, you may extend
+// this exception to your version of the file, but you are not obligated to
+// do so. If you do not wish to do so, delete this exception statement from
+// your version.
+
+// $Id: analyzePoT.cpp,v 1.24.2.13 2007/08/10 00:38:47 korpela Exp $
+//
+
+#include "sah_config.h"
+
+#include <cstdio>
+#include <cmath>
+#include <cstring>
+#include <cstdlib>
+
+#ifdef HAVE_UNISTD_H
+#include <unistd.h>
+#endif
+
+#ifdef BOINC_APP_GRAPHICS
+#include "sah_gfx_main.h"
+#endif
+
+#include "util.h"
+#include "malloc_a.h"
+#include "analyze.h"
+#include "seti.h"
+#include "worker.h"
+#include "analyzeFuncs.h"
+#include "analyzePoT.h"
+#include "analyzeReport.h"
+#include "gaussfit.h"
+#include "pulsefind.h"
+#include "chirpfft.h"
+#include "filesys.h"
+#include "util.h"
+#include "s_util.h"
+#include "progress.h"
+
+//#define DEBUG_POT
+
+// Compile time inits.  Command line parms of setiathome_test can
+// change a number of these.
+PoTInfo_t PoTInfo =  {0};
+
+int analyze_pot(
+    float *PowerSpectrum,
+    int NumDataPoints,
+    ChirpFftPair_t &cfft
+) {
+
+
+    // This function analyses Power over Time for the current data block.
+    // The PoT array  is created by taking an array of power spectra (a
+    // standard row-major 2D array)  and extracting the PoT as column-major
+    // data.  We essentialy turn the array on its side.
+
+    int  retval = 0,
+                  i,
+                  FftLength=cfft.FftLen,  // Current FFT length
+                            ThisPoT,          // index of current PoT along the freq axis
+                            PoTLen,           // compliment of FFT length - determines time res
+                            PulsePoTLen,      // length of PoT segment passed to pulse finders
+                            Overlap,          // PoT segment overlap in bins
+                            TOffset,          // index into ThisPoT of current pulse segment
+                            PulsePoTNum  = 0, // the oridinal position of a pulse PoT w/in a full PoT
+                                           NumPulsePoTs = 0, // the number of pulse PoTs w/in a full PoT.  This is
+                                                          //   constant regardless of FFT or PoT length and is
+                                                          //   determined by slew rate.
+                                                          AdvanceBy;        // the number of bins to advance for the next pulse PoT
+
+    float ProgressAddFactor = 0.0,    // sum of progress adds for ThisPoT
+                              ProgressPerPulsePoT = 0.0;  // for local progress display
+
+    bool SkipGauss   = false,
+                       SkipPulse   = false,
+                                     SkipTriplet = false,
+                                                   TOffsetOK   = true;
+
+    static float  *GaussPoT = NULL,
+                              *PulsePoT = NULL;
+
+#ifdef DUMP_POWER_SPECTRA
+
+    if (ul_FftLength == FFT_TO_DUMP) {
+        for (i=0;i<ul_NumDataPoints;i++) {
+            fprintf(stdout,"%f\n",fp_PowerSpectrum[i]);
+        }
+    }
+#endif
+#ifdef DEBUG_POT
+    fprintf(stderr, "========= FftLength = %d =========\n", FftLength);
+#endif
+
+    PoTLen              = NumDataPoints / FftLength;               // in bins
+    GetPulsePoTLen(PoTLen, &PulsePoTLen, &Overlap);     // in bins
+    AdvanceBy  = PulsePoTLen - Overlap;     // in bins
+
+    // Max limits how *slow* the slewrate can be, while Min limits how
+    // *fast* the slewrate can be.  Max is limited only by the client
+    // memory budget.
+    if(PulsePoTLen > PoTInfo.TripletMax || PulsePoTLen < PoTInfo.TripletMin)
+        SkipTriplet = true;
+    SkipGauss = !(cfft.GaussFit);
+    SkipPulse = !(cfft.PulseFind);
+
+    if(!SkipPulse || !SkipTriplet) {
+        // NumPulsePoTs is the number of PoT segments that we pass to the pulse
+        // detectors per frequency bin.  ProgressPerPulsePoT is the inverse of
+        // number of pulse detection segments in the entire data block, taking
+        // into account that we skip the first (DC) frequency bin.  An assumption
+        // is made here that minimum pulse/triplet PoT length will always be
+        // greater than 1. Otherwise, AdvanceBy can become zero and a divide by
+        // zero can occur.  The assumption is also made that FftLength is always
+        // greater than 1!
+        NumPulsePoTs = 1 + (PoTLen-PulsePoTLen)/AdvanceBy + ((PoTLen-PulsePoTLen)%AdvanceBy ? 1 : 0);
+        ProgressPerPulsePoT = (float)1 / ((FftLength - 1) * NumPulsePoTs);
+    }
+
+#ifdef DEBUG_POT
+    fprintf(stderr, "SlewRate = %f\n", PoTInfo.SlewRate);
+    fprintf(stderr, "PoTLen = %d\n", PoTLen);
+    fprintf(stderr, "MaxPoTLen = %d\n", PoTInfo.MaxPoTLen);
+    fprintf(stderr, "PoTDuration = %f\n", PoTInfo.WUDuration);
+    fprintf(stderr, "BeamRate = %f\n", PoTInfo.BeamRate);
+    fprintf(stderr, "PulsePoTLen = %d\n", PulsePoTLen);
+    fprintf(stderr, "Overlap = %d\n", Overlap);
+    fprintf(stderr, "AdvanceBy = %d\n", AdvanceBy);
+    fprintf(stderr, "min_slew = %f\n", PoTInfo.min_slew);
+    fprintf(stderr, "max_slew = %f\n", PoTInfo.max_slew);
+    fprintf(stderr, "PulseOverlapFactor = %f\n", PoTInfo.PulseOverlapFactor);
+    fprintf(stderr, "PulseBeams = %f\n", PoTInfo.PulseBeams);
+    fprintf(stderr, "PulseThresh = %f\n", PoTInfo.PulseThresh);
+    fprintf(stderr, "PulseMax = %d\n", PoTInfo.PulseMax);
+    fprintf(stderr, "PulseMin = %d\n", PoTInfo.PulseMin);
+    fprintf(stderr, "PulseFftMax = %d\n", PoTInfo.PulseFftMax);
+    fprintf(stderr, "TripletThresh = %f\n", PoTInfo.TripletThresh);
+    fprintf(stderr, "TripletMax = %d\n", PoTInfo.TripletMax);
+    fprintf(stderr, "TripletMin = %d\n", PoTInfo.TripletMin);
+#endif
+
+#ifndef USE_PULSE
+
+    SkipPulse = TRUE;
+#endif
+#ifndef USE_TRIPLET
+
+    SkipTriplet = TRUE;
+#endif
+
+    // Get memory fot the PoT arrays. The PoT array for gausian analysis is
+    // of set size.  The PoT array for pulse analysis is sized to cover
+    // PulseBeams beams, regardless of whether this violates either the
+    // triplet or pulse limits on array size.
+    if(!GaussPoT) {
+        GaussPoT = (float *)malloc_a(swi.analysis_cfg.gauss_pot_length * sizeof(float), MEM_ALIGN);
+        if(GaussPoT == NULL) {
+            SETIERROR(MALLOC_FAILED, "GaussPoT == NULL");
+        }
+    }
+    if(!PulsePoT) {
+        PulsePoT = (float *)calloc_a(PoTInfo.MaxPoTLen+3, sizeof(float), MEM_ALIGN);
+        if(PulsePoT == NULL) {
+            SETIERROR(MALLOC_FAILED, "PulsePoT == NULL");
+        }
+    }
+
+    // Look for gaussians ---------------------------------------------------
+    if(!SkipGauss && (analysis_state.PoT_activity == POT_DOING_GAUSS ||
+                      analysis_state.PoT_activity == POT_INACTIVE)) {
+
+#ifdef BOINC_APP_GRAPHICS
+        if (sah_graphics)
+            strcpy(sah_graphics->status, "Searching for Gaussians");
+#endif
+
+        // If we are back from being interrupted in the middle of gaussian PoT
+        // analysis, load state and continue.  Otherwise start anew, skipping
+        // the DC (0) bin.
+        if(analysis_state.PoT_activity == POT_DOING_GAUSS) {
+            ThisPoT = analysis_state.PoT_freq_bin;
+        } else {
+            ThisPoT = 1; // skip the DC bin on start of new cfft pair
+        }
+
+        // Initial display of local Progress / CPU time. Assumes that
+        // we start ThisPoT at 1 each time in!
+#ifdef BOINC_APP_GRAPHICS
+        if (sah_graphics)
+            sah_graphics->local_progress = ((float)ThisPoT-1)/(FftLength-1);
+#endif
+
+        // loop through frequencies
+        for(; ThisPoT < FftLength; ThisPoT++) {
+
+            // Create PowerOfTime array for gaussian fit
+            retval = GetFixedPoT(
+                         PowerSpectrum,
+                         NumDataPoints,
+                         FftLength,
+                         GaussPoT,
+                         swi.analysis_cfg.gauss_pot_length,
+                         ThisPoT
+                     );
+            if (retval)
+                continue;
+
+            retval = GaussFit(GaussPoT, FftLength, ThisPoT);
+            if (retval)
+                SETIERROR(retval,"from GaussFit");
+
+
+
+            progress += ProgressUnitSize * GaussianProgressUnits() / (float)(FftLength - 1);
+            progress=std::min(progress,1.0); // prevent display of > 100%
+            fraction_done(progress,remaining);
+            
+            // At the end of each frequency bin we update progress and save state.
+#ifdef BOINC_APP_GRAPHICS
+            if (!nographics()) {
+                sah_graphics->local_progress = ((float)ThisPoT)/(FftLength-1);
+            }
+#endif  
+            analysis_state.PoT_freq_bin = ThisPoT;
+            analysis_state.PoT_activity = POT_DOING_GAUSS;
+            retval = checkpoint();
+            if (retval)
+                SETIERROR(retval,"from checkpoint()");
+
+        }   // end loop through frequencies
+
+        analysis_state.PoT_freq_bin = -1;
+        analysis_state.PoT_activity = POT_INACTIVE;
+
+    }   // end looking for gaussians
+
+
+    // Look for pulses -------------------------------------------------------
+    if(!SkipPulse || !SkipTriplet) {
+
+#ifdef BOINC_APP_GRAPHICS
+        if (sah_graphics) {
+            strcpy(sah_graphics->status, "Searching for Pulses / Triplets");
+            // init local progress for pulse search
+            sah_graphics->local_progress = 0;
+        }
+#endif
+
+
+        // If we are back from being interrupted in the middle of pulse PoT
+        // analysis, load state and continue.  Otherwise start anew, skipping
+        // the DC (0) bin.
+        if(analysis_state.PoT_activity == POT_DOING_PULSE) {
+            ThisPoT = analysis_state.PoT_freq_bin;
+        } else {
+            ThisPoT = 1; // skip the DC bin on start of new cfft pair
+        }
+
+        PulsePoTNum = 0;
+
+#ifdef BOINC_APP_GRAPHICS
+        // Inital display of Local Progress
+        if (sah_graphics) {
+            sah_graphics->local_progress = (((ThisPoT-1) * NumPulsePoTs) +
+                                            PulsePoTNum)                   *
+                                           ProgressPerPulsePoT;
+        }
+#endif
+
+        // loop through frequencies
+        for(; ThisPoT < FftLength; ThisPoT++) {
+
+            // loop through time for each frequency.  PulsePoTNum is
+            // used only for progress calculation.
+            for(TOffset = 0, PulsePoTNum = 1, TOffsetOK = true;
+                    TOffsetOK;
+                    PulsePoTNum++, TOffset += AdvanceBy) {
+
+                // Create PowerOfTime array for pulse detection.  If there
+                // are not enough points left in this PoT, adjust TOffset
+                // to get the latest possible pulse PoT.
+                if(TOffset + PulsePoTLen >= PoTLen) {
+                    TOffsetOK = false;
+                    TOffset = PoTLen - PulsePoTLen;
+                }
+                if (use_transposed_pot) {
+                  memcpy(PulsePoT, &PowerSpectrum[ThisPoT * PoTLen + TOffset], PulsePoTLen*sizeof(float));
+		} else {
+                   for(i = 0; i < PulsePoTLen; i++) {
+                       PulsePoT[i] = PowerSpectrum[ThisPoT + (TOffset+i) * FftLength];
+                   }
+		}
+
+                if(!SkipTriplet) {
+                    retval = find_triplets(PulsePoT,
+                                           PulsePoTLen,
+                                           (float)PoTInfo.TripletThresh,
+                                           TOffset,
+                                           ThisPoT);
+                    if (retval)
+                        SETIERROR(retval,"from find_triplets()");
+                }
+
+                if(!SkipPulse) {
+                    retval = find_pulse(PulsePoT,
+                                        PulsePoTLen,
+                                        (float)PoTInfo.PulseThresh,
+                                        TOffset,
+                                        ThisPoT
+                                       );
+                    if (retval)
+                        SETIERROR(retval,"from find_pulse()");
+                }
+
+                // At the end of each pulse PoT we update progress.  Progress
+                // will thus get updted several times per frequency bin.
+#ifdef BOINC_APP_GRAPHICS
+                if (sah_graphics)
+                {
+                    sah_graphics->local_progress = (((ThisPoT-1) * NumPulsePoTs) +
+                                                    PulsePoTNum)                   *
+                                                   ProgressPerPulsePoT;
+                }
+#endif
+                if(!SkipTriplet) {
+                    progress += (ProgressUnitSize * TripletProgressUnits()) /
+                                (float)(FftLength - 1) / NumPulsePoTs;
+                }
+                if(!SkipPulse) {
+                    progress += (ProgressUnitSize * PulseProgressUnits(PulsePoTLen, FftLength - 1)) /
+                                (float)(FftLength - 1) / NumPulsePoTs;
+
+                }
+                progress=std::min(progress,1.0); // prevent display of > 100%
+                fraction_done(progress,remaining);
+
+            }  // end loop through time for each frequency
+
+            // At the end of each frequency bin we save state.
+            analysis_state.PoT_activity = POT_DOING_PULSE;
+            analysis_state.PoT_freq_bin = ThisPoT;
+            retval = checkpoint();
+            if (retval)
+                SETIERROR(retval,"from checkpoint()");
+
+        }   // end loop through frequencies
+
+        analysis_state.PoT_freq_bin = -1;
+        analysis_state.PoT_activity = POT_INACTIVE;
+
+    }   // end looking for pulses
+
+
+    return (retval);   // no error return point
+}
+
+int GetFixedPoT(
+    float fp_PowerSpectrum[],
+    int ul_NumDataPoints,
+    int ul_FftLength,
+    float fp_PoT[],
+    int ul_PoTLen,
+    int ul_PoT
+) {
+
+    // This routine returns a PoT array of fixed length, regardless
+    // of the actual number of time bins in the current data block.
+
+    int    ul_PoT_i,
+    ul_PoTChunkSize,
+    ul_PoTChunk_i,
+    ul_PoTChunkLimit,
+    ul_NumSpectra,
+    ul_PoTsPerSpec,
+    ul_MidPoint,
+    ul_BaseSpec,
+    ul_SubPoT_i;
+
+    float  f_Factor,
+    f_BaseSpecPowerPerPoT    = 0.0,
+                               f_AftSpecPowerPerPoT     = 0.0,
+                                                          f_ForwardSpecPowerPerPoT = 0.0,
+                                                                                     f_BaseWeight;
+
+    ul_NumSpectra    = ul_NumDataPoints / ul_FftLength;
+    ul_PoTChunkSize  = ul_NumSpectra / ul_PoTLen;
+
+    // Populate PoT
+
+    // For setiathome_enhanced, the number of spectra is the same as the
+    // number of elements in a PoT array more times than not (16K FFT length).
+    // For an 0.426 angle range, there are 2.2104e10 cases where they're equal
+    // and 2.2082e10 cases where they're not. Copying directly rather than
+    // adding also means no FLOP_counter increment is needed.
+    if (ul_NumSpectra == ul_PoTLen) {
+        if (use_transposed_pot) {
+          memcpy(fp_PoT, &fp_PowerSpectrum[ul_PoT * ul_NumSpectra],
+               swi.analysis_cfg.gauss_pot_length * sizeof(float));
+        } else { 
+          for (ul_PoT_i = 0, ul_PoTChunk_i = 0;
+                ul_PoT_i < swi.analysis_cfg.gauss_pot_length;
+                ul_PoT_i++, ul_PoTChunk_i += ul_FftLength) {
+            fp_PoT[ul_PoT_i] = fp_PowerSpectrum[ul_PoT + ul_PoTChunk_i];
+          }
+	}
+        // If the number of spectra is greater than the number
+        // of elements in a PoT array, we add sum adjacent spectra
+        // into PoT elements.
+        // ul_PoTChunkSize indicates how many time-wise
+        // power spectra bins are added together to make one PoT bin.
+    } else if (ul_NumSpectra > ul_PoTLen) {
+        ul_PoTChunk_i = 0;
+		int blksize = UNSTDMAX(1, UNSTDMIN(pow2((unsigned int) sqrt((float) ((ul_PoTChunkSize) / 32)) * 32), 512));
+        for (ul_PoT_i = 0; ul_PoT_i < swi.analysis_cfg.gauss_pot_length; ul_PoT_i++) {
+            fp_PoT[ul_PoT_i] = 0.0;
+            ul_PoTChunkLimit = ul_PoTChunk_i + ul_PoTChunkSize;
+
+            // Stuff chunk of power spectra bins into 1 PoT bin
+			int b,chunk_i;
+			float total = 0.0f,partial;
+	        if (use_transposed_pot) {
+			  for (b=0;b<ul_PoTChunkSize/blksize;b++)
+			  {
+				partial=0.0f;
+				for (chunk_i=0;chunk_i<blksize;chunk_i++)
+				{
+				  partial += fp_PowerSpectrum[ul_PoT * ul_NumSpectra + ul_PoTChunk_i + chunk_i];					
+				}
+				ul_PoTChunk_i += blksize;
+				total+=partial;
+			  }
+              for (; ul_PoTChunk_i < ul_PoTChunkLimit; ul_PoTChunk_i++) {
+                total += fp_PowerSpectrum[ul_PoT * ul_NumSpectra + ul_PoTChunk_i];
+              }
+			  fp_PoT[ul_PoT_i] = total;
+            } else { 
+			  for (b=0;b<ul_PoTChunkSize/blksize;b++)
+			  {
+				partial=0.0f;
+				for (chunk_i=0;chunk_i<blksize;chunk_i++)
+				{
+				  partial += fp_PowerSpectrum[ul_PoT +
+                                          ul_FftLength * (ul_PoTChunk_i+chunk_i)];
+				}
+				ul_PoTChunk_i += blksize;
+				total+=partial;
+			  }
+              for (; ul_PoTChunk_i < ul_PoTChunkLimit; ul_PoTChunk_i++) {
+                total += fp_PowerSpectrum[ul_PoT +
+                                          ul_FftLength * ul_PoTChunk_i];
+              }
+	          fp_PoT[ul_PoT_i] = total;
+            }
+        }
+        analysis_state.FLOP_counter+=((double)ul_NumSpectra+swi.analysis_cfg.gauss_pot_length);
+    } else {
+        // If the number of spectra is less than the the number
+        // of elements in a PoT array, we smear the power in each
+        // spectrum over more than one PoT element.  Further, we
+        // perform a linear interpolation to smooth the transition
+        // from one spectrum to the next. That is, we allow the
+        // spectra before or after our "base" spectrum to effect
+        // the powers that go into a given PoT bin.  The closer
+        // in time that the PoT bin is to the "before" or "after"
+        // spectra, the more that PoT bin is effected by the
+        // neighboring spectrum.
+        // NOTE : This is all effectively turned off by not letting
+        //        gaussfit() see data analyzed with an FFT length
+        //        greater than GAUSS_POT_LEN.
+
+        ul_PoTsPerSpec = ul_PoTLen / ul_NumSpectra;
+        // Number of PoT bins over which to smear 1 spectrum.
+        f_Factor = 1.0f / ul_PoTsPerSpec;
+        // For dividing up 1 spectrum's power pre-interpolation.
+        ul_MidPoint = ul_PoTsPerSpec / 2;
+
+        for (ul_PoT_i = 0; ul_PoT_i < swi.analysis_cfg.gauss_pot_length; ul_PoT_i++) {
+            ul_BaseSpec = int(ul_PoT_i / ul_PoTsPerSpec);
+            // The spectrum bounding the current PoT bin.
+            ul_SubPoT_i = ul_PoT_i - ul_PoTsPerSpec * ul_BaseSpec;
+            // Relative to the start of the base spectrum.
+            // Powers pre-interpolation.
+            if (use_transposed_pot) {
+              f_BaseSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
+                                    * ul_NumSpectra + ul_BaseSpec] * f_Factor;
+	    } else {
+              f_BaseSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
+                                    + ul_FftLength * ul_BaseSpec] * f_Factor;
+            }
+            if (ul_BaseSpec > 0) {
+                if (use_transposed_pot) {
+                  f_AftSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
+                                       * ul_NumSpectra + (ul_BaseSpec-1)] * f_Factor;
+                } else {
+                  f_AftSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
+                                                        + ul_FftLength * (ul_BaseSpec-1)] * f_Factor;
+                }
+            }
+            if (ul_BaseSpec < ul_NumSpectra - 1) {
+                if (use_transposed_pot) {
+                  f_ForwardSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
+                                           * ul_NumSpectra + (ul_BaseSpec+1)] * f_Factor;
+                } else {
+                  f_ForwardSpecPowerPerPoT = fp_PowerSpectrum[ul_PoT
+                                           + ul_FftLength * (ul_BaseSpec+1)] * f_Factor;
+                }
+            }
+
+            // Begin interpolation.
+            if (ul_SubPoT_i < ul_MidPoint) {
+                // Use the Aft spectrum if there is one.
+                // If not, use non-interpoated powers.
+                if (ul_BaseSpec == 0) {
+                    fp_PoT[ul_PoT_i] = f_BaseSpecPowerPerPoT;
+                } else {
+                    f_BaseWeight = (float)(ul_PoTsPerSpec - (ul_MidPoint - ul_SubPoT_i)) / ul_PoTsPerSpec;
+                    fp_PoT[ul_PoT_i] = (f_BaseSpecPowerPerPoT * f_BaseWeight)
+                                       + (f_AftSpecPowerPerPoT * (1.0f - f_BaseWeight));
+                }
+            } else {
+                // Use the Forward spectrum if there is one.
+                // If not, use non-interpoated powers.
+                if (ul_BaseSpec == ul_NumSpectra-1) {
+                    fp_PoT[ul_PoT_i] = f_BaseSpecPowerPerPoT;
+                } else {
+                    f_BaseWeight = (float)(ul_PoTsPerSpec - (ul_SubPoT_i - ul_MidPoint)) / ul_PoTsPerSpec;
+                    fp_PoT[ul_PoT_i] = (f_BaseSpecPowerPerPoT * f_BaseWeight)
+                                       + (f_ForwardSpecPowerPerPoT * (1.0f - f_BaseWeight));
+                }
+            }
+        } // end for ul_PoT_i < swi.analysis_cfg.gauss_pot_length
+        analysis_state.FLOP_counter+=(double)(9*swi.analysis_cfg.gauss_pot_length);
+    }
+    return 0;
+}
+
+void ComputePoTInfo(int num_cfft, int NumDataPoints) {
+
+    // Tis routine calculates various PoT values based on program constants
+    // and data contained in the current WU.
+
+    // A note on "sigma", calculated here and used by the gaussian finder:
+    // The sigma calculated here is in units of PoT, ie, in bins of the
+    // Power Of Time arrays.  Gaussian PoT arrays are of fixed length, given by
+    // GAUSS_POT_LEN.  The basic definition of sigma here is that it is the
+    // amount of time it takes to cover 1/2 the half-power-beamwidth of the
+    // serendip feed.  This is also a constant - BEAM_WIDTH - in units of
+    // degrees.  We scan BEAM_WIDTH degrees at a given, but variable, slew rate.
+
+
+    volatile double DegPerPotBin;    // slew rate in degrees per PoT bin
+    volatile float ftmp;             // temporary to ensure float rounding
+    int i, MinFftLen;
+
+    // jeffc - is there really any need for these PoTInfo fields
+    // at this point?
+    PoTInfo.min_slew  = swi.analysis_cfg.pot_min_slew;
+    PoTInfo.max_slew  = swi.analysis_cfg.pot_max_slew;
+    PoTInfo.PulseOverlapFactor = swi.analysis_cfg.pot_overlap_factor; // ?
+    PoTInfo.PulseBeams  = swi.analysis_cfg.pulse_beams;
+    PoTInfo.PulseThresh  = swi.analysis_cfg.pulse_thresh;
+    PoTInfo.PulseMax  = swi.analysis_cfg.pulse_max;
+    PoTInfo.PulseMin  = swi.analysis_cfg.pulse_min;
+    PoTInfo.PulseFftMax  = swi.analysis_cfg.pulse_fft_max;
+    PoTInfo.TripletThresh  = swi.analysis_cfg.triplet_thresh;
+    PoTInfo.TripletMax  = swi.analysis_cfg.triplet_max;
+    PoTInfo.TripletMin  = swi.analysis_cfg.triplet_min;
+    PoTInfo.GaussChiSqThresh      = swi.analysis_cfg.gauss_chi_sq_thresh;
+    PoTInfo.GaussPowerThresh      = swi.analysis_cfg.gauss_power_thresh;
+    PoTInfo.GaussPeakPowerThresh  = swi.analysis_cfg.gauss_peak_power_thresh;
+
+    // Find the max fft length in the chirp/fft table
+    for(i = 1, MinFftLen = ChirpFftPairs[0].FftLen; i < num_cfft; i++) {
+        if(ChirpFftPairs[i].FftLen < MinFftLen) {
+            MinFftLen = ChirpFftPairs[i].FftLen;
+        }
+    }
+
+    PoTInfo.MaxPoTLen  = NumDataPoints / MinFftLen;
+    ftmp               = (float)(swi.nsamples / swi.subband_sample_rate);
+    PoTInfo.WUDuration = ftmp;
+
+    // Here we calculate slew rate and slew related values.
+    // If there is no telescope movement, slew related values remain
+    // in their initialized state (zero).
+    if(swi.angle_range != 0.0) {
+        ftmp                        = (float)(swi.angle_range / PoTInfo.WUDuration);
+        PoTInfo.SlewRate            = ftmp;
+        ftmp                        = (float)(PoTInfo.SlewRate / swi.beam_width);
+        PoTInfo.BeamRate            = ftmp;
+        DegPerPotBin                = swi.angle_range / swi.analysis_cfg.gauss_pot_length;
+        ftmp                        = (float)((swi.beam_width/2.0f) / DegPerPotBin);
+        PoTInfo.GaussSigma          = ftmp;
+        PoTInfo.GaussSigmaSq        = PoTInfo.GaussSigma * PoTInfo.GaussSigma;
+        PoTInfo.GaussTOffsetStart   = static_cast<int>(floor(swi.analysis_cfg.pot_t_offset * PoTInfo.GaussSigma+0.5));
+        PoTInfo.GaussTOffsetStop    = swi.analysis_cfg.gauss_pot_length - PoTInfo.GaussTOffsetStart;
+    }
+}
+
+void GetPulsePoTLen(long FullPoTLen, int * PulsePoTLen, int * PulseOverlap) {
+
+    // This routine, given the time axis length of a WU in bins and data available
+    // in the PoTInfo struct, will calculate how many time bins to pass the pulse
+    // detectors for the given time axis length.  Time axis length in seconds is
+    // is constant, while length in bins is inversely proportional to FFT length.
+
+    // If slew rate is so low that, over the duration of the entire WU,
+    // we do not cover the number of beams passed to each call of the
+    // pulse finders then assume that we will be passing the entire PoT
+    // to the pulse finders.  This also takes care of the case where slew
+    // rate is zero.  Otherwise, calculate that portion of the PoT that
+    // we will be passing.
+
+    // NOTE: the code calling this routine may be concerned with either pulse finding
+    // or triplet finding.  There may be different max and/or min PoT length constraints
+    // between these 2 algorithms.  Thus, this routine just returns the length that
+    // will contain PoTInfo.PulseBeams worth of data.  It is up to the calling code
+    // to then apply any length constaints.
+
+    double       BinRate,                // function of time resolution and slew rate
+    BinsPerBeam;            // function of time res, slew rate, and beam width
+
+    // jeffc - the following line in temporary.  Pulse beams will go into the
+    // analysis config.
+    //PoTInfo.PulseBeams = 1.0;
+
+    BinRate             = FullPoTLen / PoTInfo.WUDuration;             // in bins/second
+
+    if(PoTInfo.BeamRate * PoTInfo.WUDuration < PoTInfo.PulseBeams) {
+        BinsPerBeam     = (float)FullPoTLen;    // slow slew - pass FullPoT
+    } else {
+        BinsPerBeam     = BinRate / PoTInfo.BeamRate;           // we will pass a portion of FullPoT
+    }
+
+    *PulsePoTLen         = IROUND(BinsPerBeam * PoTInfo.PulseBeams);              // in bins
+    if(*PulsePoTLen > FullPoTLen) {
+        *PulsePoTLen = FullPoTLen;    // pulse PoT longer than full PoT
+    }        // ... so pass as much as we can
+    // ... ie the full PoT
+
+    *PulseOverlap        = IROUND(BinsPerBeam * PoTInfo.PulseOverlapFactor);      // in bins
+
+#ifdef DEBUG_POT
+
+    fprintf(stderr, "BinRate = %f\n", BinRate);
+    fprintf(stderr, "BinsPerBeam = %f\n", BinsPerBeam);
+#endif
+
+}
+
diff --git a/client/pulsefind.h b/client/pulsefind.h
index 6108493..8ada742 100644
--- a/client/pulsefind.h
+++ b/client/pulsefind.h
@@ -26,6 +26,9 @@
 // your version.
 
 // $Id: pulsefind.h,v 1.3.2.3 2007/06/08 03:09:45 korpela Exp $
+//
+#ifndef _PULSEFIND_H_
+#define _PULSEFIND_H_
 
 // constants for integerized period in preplanning
 #define C3X2TO14 0xC000
@@ -67,6 +70,9 @@ struct FoldSet {
 
 // forward declare folding sets
 
+extern FoldSet vfpFoldMain;     // in analyzeFuncs_neon.cpp
+extern FoldSet neonFoldMain;     // in analyzeFuncs_neon.cpp
+extern FoldSet AVXfold_a;       // in analyzeFuncs_avx.cpp
 extern FoldSet AVXfold_a;       // in analyzeFuncs_avx.cpp
 extern FoldSet AVXfold_c;       // in analyzeFuncs_avx.cpp
 extern FoldSet sse_ben_fold;    // in analyzeFuncs_sse.cpp
@@ -83,3 +89,4 @@ int find_triplets(const float * fp_PulsePot, int PulsePotLen, float triplet_thre
 int find_pulse(const float * fp_PulsePot, int PulsePotLen, float pulse_thresh, int TOffset, int ul_PoT);
 
 int CopyFoldSet(FoldSet *dst, FoldSet *src);
+#endif
diff --git a/client/sah_gfx_main.cpp b/client/sah_gfx_main.cpp
index 0abe756..af0dee0 100644
--- a/client/sah_gfx_main.cpp
+++ b/client/sah_gfx_main.cpp
@@ -1,67 +1,67 @@
-
-// Copyright 2007 Regents of the University of California
-
-// SETI_BOINC is free software; you can redistribute it and/or modify it under
-// the terms of the GNU General Public License as published by the Free
-// Software Foundation; either version 2, or (at your option) any later
-// version.
-
-// SETI_BOINC 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 SETI_BOINC; see the file COPYING.  If not, write to the Free Software
-// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-
-// In addition, as a special exception, the Regents of the University of
-// California give permission to link the code of this program with libraries
-// that provide specific optimized fast Fourier transform (FFT) functions and
-// distribute a linked executable.  You must obey the GNU General Public 
-// License in all respects for all of the code used other than the FFT library
-// itself.  Any modification required to support these libraries must be
-// distributed in source code form.  If you modify this file, you may extend 
-// this exception to your version of the file, but you are not obligated to 
-// do so. If you do not wish to do so, delete this exception statement from 
-// your version.
-
-#include "sah_gfx_main.h"
-#include "boinc_api.h"
-#include "graphics2.h"
-
-extern double progress;
-SAH_SHMEM* sah_shmem;
-REDUCED_ARRAY_GEN rarray;
-GDATA* sah_graphics;
-bool nographics_flag = false;
-
-void update_shmem() {
-    if (sah_graphics->countdown > 0) {
-        sah_graphics->countdown--;
-    }
-    boinc_wu_cpu_time(sah_graphics->cpu_time);
-    sah_graphics->progress=progress;
-}
-
-void sah_graphics_init(APP_INIT_DATA& app_init_data) {
-    if (nographics_flag) return;
-    if ((app_init_data.host_info.m_nbytes != 0)  &&
-        (app_init_data.host_info.m_nbytes <= (double)(48*1024*1024))
-    ) {
-        fprintf(stderr,"Low memory machine... Disabling graphics.\n");
-        fprintf(stderr,"%f <= %f\n",app_init_data.host_info.m_nbytes,(double)48*1024*1024);
-        nographics_flag = true;
-        return;
-    }
-    sah_shmem = (SAH_SHMEM*)boinc_graphics_make_shmem("setiathome", sizeof(SAH_SHMEM));
-    if (!sah_shmem) {
-        sah_shmem=(SAH_SHMEM*)boinc_graphics_get_shmem("setiathome");
-    }
-    if (!sah_shmem) {
-        nographics_flag = true;
-        return;
-    }
-    sah_graphics = &(sah_shmem->gdata);
-    boinc_register_timer_callback(update_shmem);
-}
+
+// Copyright 2007 Regents of the University of California
+
+// SETI_BOINC is free software; you can redistribute it and/or modify it under
+// the terms of the GNU General Public License as published by the Free
+// Software Foundation; either version 2, or (at your option) any later
+// version.
+
+// SETI_BOINC 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 SETI_BOINC; see the file COPYING.  If not, write to the Free Software
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+// In addition, as a special exception, the Regents of the University of
+// California give permission to link the code of this program with libraries
+// that provide specific optimized fast Fourier transform (FFT) functions and
+// distribute a linked executable.  You must obey the GNU General Public 
+// License in all respects for all of the code used other than the FFT library
+// itself.  Any modification required to support these libraries must be
+// distributed in source code form.  If you modify this file, you may extend 
+// this exception to your version of the file, but you are not obligated to 
+// do so. If you do not wish to do so, delete this exception statement from 
+// your version.
+
+#include "sah_gfx_main.h"
+#include "boinc_api.h"
+#include "graphics2.h"
+
+extern double progress;
+SAH_SHMEM* sah_shmem;
+REDUCED_ARRAY_GEN rarray;
+GDATA* sah_graphics;
+bool nographics_flag = false;
+
+void update_shmem() {
+    if (sah_graphics->countdown > 0) {
+        sah_graphics->countdown--;
+    }
+    boinc_wu_cpu_time(sah_graphics->cpu_time);
+    sah_graphics->progress=progress;
+}
+
+void sah_graphics_init(APP_INIT_DATA& app_init_data) {
+    if (nographics_flag) return;
+    if ((app_init_data.host_info.m_nbytes != 0)  &&
+        (app_init_data.host_info.m_nbytes <= (double)(48*1024*1024))
+    ) {
+        fprintf(stderr,"Low memory machine... Disabling graphics.\n");
+        fprintf(stderr,"%f <= %f\n",app_init_data.host_info.m_nbytes,(double)48*1024*1024);
+        nographics_flag = true;
+        return;
+    }
+    sah_shmem = (SAH_SHMEM*)boinc_graphics_make_shmem("setiathome", sizeof(SAH_SHMEM));
+    if (!sah_shmem) {
+        sah_shmem=(SAH_SHMEM*)boinc_graphics_get_shmem("setiathome");
+    }
+    if (!sah_shmem) {
+        nographics_flag = true;
+        return;
+    }
+    sah_graphics = &(sah_shmem->gdata);
+    boinc_register_timer_callback(update_shmem);
+}
diff --git a/client/sah_gfx_main.h b/client/sah_gfx_main.h
index 30eb172..5a12bc9 100644
--- a/client/sah_gfx_main.h
+++ b/client/sah_gfx_main.h
@@ -1,43 +1,43 @@
-// Copyright 2007 Regents of the University of California
-
-// SETI_BOINC is free software; you can redistribute it and/or modify it under
-// the terms of the GNU General Public License as published by the Free
-// Software Foundation; either version 2, or (at your option) any later
-// version.
-
-// SETI_BOINC 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 SETI_BOINC; see the file COPYING.  If not, write to the Free Software
-// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-
-// In addition, as a special exception, the Regents of the University of
-// California give permission to link the code of this program with libraries
-// that provide specific optimized fast Fourier transform (FFT) functions and
-// distribute a linked executable.  You must obey the GNU General Public 
-// License in all respects for all of the code used other than the FFT library
-// itself.  Any modification required to support these libraries must be
-// distributed in source code form.  If you modify this file, you may extend 
-// this exception to your version of the file, but you are not obligated to 
-// do so. If you do not wish to do so, delete this exception statement from 
-// your version.
-
-#include <vector>
-#include "gdata.h"
-#include "boinc_api.h"
-
-extern SAH_SHMEM* sah_shmem;
-extern REDUCED_ARRAY_GEN rarray;
-extern GDATA* sah_graphics;
-extern bool nographics_flag;
-
-inline bool nographics() {
-    if (nographics_flag) return true;
-    if (!sah_graphics) return true;
-    if (!sah_graphics->countdown) return true;
-    return false;
-}
-extern void sah_graphics_init(APP_INIT_DATA&);
+// Copyright 2007 Regents of the University of California
+
+// SETI_BOINC is free software; you can redistribute it and/or modify it under
+// the terms of the GNU General Public License as published by the Free
+// Software Foundation; either version 2, or (at your option) any later
+// version.
+
+// SETI_BOINC 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 SETI_BOINC; see the file COPYING.  If not, write to the Free Software
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+// In addition, as a special exception, the Regents of the University of
+// California give permission to link the code of this program with libraries
+// that provide specific optimized fast Fourier transform (FFT) functions and
+// distribute a linked executable.  You must obey the GNU General Public 
+// License in all respects for all of the code used other than the FFT library
+// itself.  Any modification required to support these libraries must be
+// distributed in source code form.  If you modify this file, you may extend 
+// this exception to your version of the file, but you are not obligated to 
+// do so. If you do not wish to do so, delete this exception statement from 
+// your version.
+
+#include <vector>
+#include "gdata.h"
+#include "boinc_api.h"
+
+extern SAH_SHMEM* sah_shmem;
+extern REDUCED_ARRAY_GEN rarray;
+extern GDATA* sah_graphics;
+extern bool nographics_flag;
+
+inline bool nographics() {
+    if (nographics_flag) return true;
+    if (!sah_graphics) return true;
+    if (!sah_graphics->countdown) return true;
+    return false;
+}
+extern void sah_graphics_init(APP_INIT_DATA&);
diff --git a/client/seti.cpp b/client/seti.cpp
index 9e48b7c..4b53a5d 100644
--- a/client/seti.cpp
+++ b/client/seti.cpp
@@ -71,6 +71,8 @@
 #include "seti_header.h"
 #include "analyze.h"
 #include "analyzeFuncs.h"
+#include "vector/analyzeFuncs_vector.h"
+#include "pulsefind.h"
 #include "analyzeReport.h"
 #include "analyzePoT.h"
 #include "malloc_a.h"
@@ -388,12 +390,15 @@ int result_group_end() {
 
   return 0;
 }
+  
 
 int checkpoint(BOOLEAN force_checkpoint) {
 
   int retval=0, i, l=xml_indent_level;
   xml_indent_level=0;
-  MFILE state_file;
+// Making state_file static to avoid overhead of reallocating of buffers on 
+// every call.  
+  static MFILE state_file;
   char buf[2048];
   std::string enc_field, str;
 
@@ -589,6 +594,51 @@ BOINCASSERT(_CrtCheckMemory());
    if (retval < 0) SETIERROR(WRITE_FAILED,"in checkpoint()");
   }
 
+  if (BaseLineSmooth != NULL) {
+   for (i=0;i<num_BLS;i++) {
+     if ( BaseLineSmoothFuncs[i].func == BaseLineSmooth ) {
+       state_file.printf("<baseline_smooth>%s</baseline_smooth>\n",
+         BaseLineSmoothFuncs[i].nom);
+       break;
+     }
+   }
+  }
+
+  if (GetPowerSpectrum != NULL) {
+   for (i=0;i<num_GPS;i++) {
+     if ( GetPowerSpectrumFuncs[i].func == GetPowerSpectrum ) {
+       state_file.printf("<get_power_spectrum>%s</get_power_spectrum>\n",
+         GetPowerSpectrumFuncs[i].nom);
+       break;
+     }
+   }
+  }
+
+  if (ChirpData != NULL) {
+   for (i=0;i<num_CD;i++) {
+     if ( ChirpDataFuncs[i].func == ChirpData ) {
+       state_file.printf("<chirp_data>%s</chirp_data>\n",
+         ChirpDataFuncs[i].nom);
+       break;
+     }
+   }
+  }
+
+  if (Transpose != NULL) {
+   for (i=0;i<num_TP;i++) {
+     if ( TransposeFuncs[i].func == Transpose ) {
+       state_file.printf("<transpose>%s</transpose>\n",
+         TransposeFuncs[i].nom);
+       break;
+     }
+   }
+  }
+
+  if (strlen(Foldmain.name) != 0) {
+   state_file.printf("<folding>%s</folding>\n",
+      Foldmain.name);
+  }
+
   // The result (outfile) and state mfiles are now synchronized.
   // Flush them both.
   retval = outfile.flush();
@@ -627,6 +677,7 @@ BOINCASSERT(_CrtCheckMemory());
 //
 int parse_state_file(ANALYSIS_STATE& as) {
   static char buf[8192];
+  std::string fname;
   int ncfft, fl, PoT_freq_bin, PoT_activity;
   double cr=0,flops=0;
   FILE* state_file;
@@ -796,6 +847,62 @@ BOINCASSERT(_CrtCheckMemory());
       }  // end while in best_triplet
     }  // end if in best_triplet
 
+    // Restore best functions that were determined earlier.
+    else if (parse_str(buf,"<baseline_smooth>",fname)) {
+      int i; 
+      for (i=0;i<num_BLS;i++) {
+        if (strcmp(fname.c_str(),BaseLineSmoothFuncs[i].nom)==0) {
+          BaseLineSmooth=BaseLineSmoothFuncs[i].func;
+          found_baseline_smooth=true;
+          break;
+        }
+      }
+    }
+
+    else if (parse_str(buf,"<get_power_spectrum>",fname)) {
+      int i; 
+      for (i=0;i<num_GPS;i++) {
+        if (strcmp(fname.c_str(),GetPowerSpectrumFuncs[i].nom)==0) {
+          GetPowerSpectrum=GetPowerSpectrumFuncs[i].func;
+          found_get_power_spectrum=true;
+          break;
+        }
+      }
+    }
+
+    else if (parse_str(buf,"<chirp_data>",fname)) {
+      int i; 
+      for (i=0;i<num_CD;i++) {
+        if (strcmp(fname.c_str(),ChirpDataFuncs[i].nom)==0) {
+          ChirpData=ChirpDataFuncs[i].func;
+          found_chirp_data=true;
+          break;
+        }
+      }
+    }
+
+    else if (parse_str(buf,"<transpose>",fname)) {
+      int i; 
+      for (i=0;i<num_TP;i++) {
+        if (strcmp(fname.c_str(),TransposeFuncs[i].nom)==0) {
+          Transpose=TransposeFuncs[i].func;
+          found_transpose=true;
+          break;
+        }
+      }
+    }
+
+    else if (parse_str(buf,"<folding>",fname)) {
+      int i; 
+      for (i=0;i<num_FS;i++) {
+        if (strcmp(fname.c_str(),FoldSubs[i].fsp->name)==0) {
+          CopyFoldSet(&Foldmain,FoldSubs[i].fsp);
+          found_folding=true;
+          break;
+        }
+      }
+    }
+
   }  // end main parsing loop
 
   fclose(state_file);
diff --git a/client/vector/analyzeFuncs_fpu.cpp b/client/vector/analyzeFuncs_fpu.cpp
index 0bbe8db..74d3596 100644
--- a/client/vector/analyzeFuncs_fpu.cpp
+++ b/client/vector/analyzeFuncs_fpu.cpp
@@ -268,7 +268,7 @@ int fpu_opt_ChirpData (
     // If we have more than 64MB, we'll cache the chirp table.  If not
     // we'll calculate it each time.
     bool CacheChirpCalc=((app_init_data.host_info.m_nbytes == 0)  ||
-                             (app_init_data.host_info.m_nbytes >= (double)(64*1024*1024)));
+                             (app_init_data.host_info.m_nbytes >= MIN_TRIGARRAY_MEMORY));
     // calculate trigonometric array
     // this function returns w/o doing nothing when sign of chirp_rate_ind
     // reverses.  so we have to take care of it.
diff --git a/client/vector/analyzeFuncs_neon.S b/client/vector/analyzeFuncs_neon.S
new file mode 100644
index 0000000..b57f639
--- /dev/null
+++ b/client/vector/analyzeFuncs_neon.S
@@ -0,0 +1,2690 @@
+// Copyright (c) 1999-2011 Regents of the University of California
+//
+// FFTW: Copyright (c) 2003,2006 Matteo Frigo
+//       Copyright (c) 2003,2006 Massachusets Institute of Technology
+//
+// fft8g.[cpp,h]: Copyright (c) 1995-2001 Takya Ooura
+//
+// ASMLIB: Copyright (c) 2004 Agner Fog
+
+// This program is free software; you can redistribute it and/or modify it 
+// under the terms of the GNU General Public License as published by the 
+// Free Software Foundation; either version 2, or (at your option) any later
+// version.
+
+// This program is distributed in the hope that it will be useful, but WITHOUT
+// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
+// more details.
+
+// You should have received a copy of the GNU General Public License along
+// with this program; see the file COPYING.  If not, write to the Free Software
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+// In addition, as a special exception, the Regents of the University of
+// California give permission to link the code of this program with libraries
+// that provide specific optimized fast Fourier transform (FFT) functions
+// as an alternative to FFTW and distribute a linked executable and 
+// source code.  You must obey the GNU General Public License in all 
+// respects for all of the code used other than the FFT library itself.  
+// Any modification required to support these libraries must be distributed 
+// under the terms of this license.  If you modify this program, you may extend 
+// this exception to your version of the program, but you are not obligated to 
+// do so. If you do not wish to do so, delete this exception statement from 
+// your version.  Please be aware that FFTW and ASMLIB are not covered by 
+// this exception, therefore you may not use FFTW and ASMLIB in any derivative 
+// work so modified without permission of the authors of those packages.
+
+#ifdef __arm__
+/*
+ * vfp_ChirpData.S
+ * Author: Mateusz Szpakowski
+ */
+ 
+                .arch armv7-a
+                .fpu neon
+                .eabi_attribute 20, 1
+                .eabi_attribute 21, 1
+                .eabi_attribute 23, 3
+                .eabi_attribute 24, 1
+                .eabi_attribute 25, 1
+                .eabi_attribute 26, 2
+                .eabi_attribute 30, 2
+                .eabi_attribute 18, 4
+                .text
+                .align  2
+.Lhalfd:
+                .double 0.5
+.LroundVal:
+                .double 4503599627370496.0
+                .align 4
+.Linc8d:
+                .double 0,1,2,3,4,5,6,7
+.Lsinapprox:
+                .float 1.5707963268,1.5707963268,1.5707963268,1.5707963268
+                .float -0.6466386396,-0.6466386396,-0.6466386396,-0.6466386396
+                .float 0.0679105987,0.0679105987,0.0679105987,0.0679105987
+                .float -0.0011573807,-0.0011573807,-0.0011573807,-0.0011573807
+.Lcosapprox:
+                .float 1.0,1.0,1.0,1.0
+                .float -1.2341299769,-1.2341299769,-1.2341299769,-1.2341299769
+                .float 0.2465220241,0.2465220241,0.2465220241,0.2465220241
+                .float -0.0123926179,-0.0123926179,-0.0123926179,-0.0123926179
+.Ltwosq:
+                .float 2.0,2.0,2.0,2.0
+                .float 2.0,2.0,2.0,2.0
+                .float 2.0,2.0,2.0,2.0
+                .float 2.0,2.0,2.0,2.0
+                
+                .align  2
+                .global _Z14neon_ChirpDataPA2_fS0_idid
+                .type   _Z14neon_ChirpDataPA2_fS0_idid, %function
+_Z14neon_ChirpDataPA2_fS0_idid:
+                push {r4,r5,r6,r7,r8,r9,r10,r11,r12,lr}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+#define stargidx (40+64)
+                /* r0 - input data
+                 * r1 - output data
+                 * r2 - chirprateind
+                 * sp[0-1] - chirp_rate
+                 * sp[2] - numDataPoints
+                 * sp[4-5] - sample_rate
+                 */
+                tst r2,r2
+                bne .Lrealfunc
+                mov r3,r0   // swap addresses
+                mov r0,r1
+                mov r1,r3
+                ldr r2,[sp,#stargidx+8]     // numDataPoints
+                lsl r2,r2,#3
+                bl memcpy(PLT)
+                b .Lendoffunc
+                /*
+                 * real functions
+                 */
+.Lrealfunc:
+                ldr r4,.LGOT1
+.LPIC1:
+                add r4,pc,r4
+                ldr r5,.LGOT1+4
+                ldr r5,[r4,r5]
+                
+                ldr r3,[sp,#stargidx+8]     // numDataPoints
+                
+                add r6,r3,r3,lsl #1
+                lsl r6,r6,#2
+                fldd d0,[r5,#32]
+                fmsr s4,r6
+                fuitod d1,s4
+                faddd d0,d0,d1
+                fstd d0,[r5,#32]
+                
+                add r3,r0,r3,lsl #3
+                sub r3,r3,#8*15
+                
+                fldd d11,.Lhalfd
+                fldd d9,[sp,#stargidx]        // chirp_rate
+                fldd d10,[sp,#stargidx+16]   // sample_rate
+                fmuld d10,d10,d10
+                fmuld d9,d9,d11
+                fdivd d9,d9,d10
+                
+                fldd d10,.LroundVal
+                fsubd d11,d11,d11   // zero
+                fcmpd d9,d11
+                fmstat
+                fnegdmi d10,d10     // negate is negative srate
+                
+                sub sp,sp,#16+64
+                add r7,sp,#16
+                add r11,sp,#16+32
+                fstmiad sp,{d9,d10}
+                
+                mov r4,#0       // i
+                
+                adr r5,.Linc8d
+                adr r6,.Lsinapprox
+                adr r10,.Lcosapprox
+                adr r9,.Ltwosq
+                
+                cmp r0,r3
+                bhs .Lendmainloop
+.Lmainloop:
+                add r8,r4,#8
+                fmsr s8,r4
+                fmsr s9,r8
+                fuitod d0,s8
+                fuitod d1,s9
+                fldmiad r5,{d8,d9,d10,d11,d12,d13,d14,d15}
+                fldmiad sp,{d2,d3}
+                faddd d16,d8,d0
+                faddd d17,d9,d0
+                faddd d18,d10,d0
+                faddd d19,d11,d0
+                faddd d20,d12,d0
+                faddd d21,d13,d0
+                faddd d22,d14,d0
+                faddd d23,d15,d0
+                faddd d24,d8,d1
+                faddd d25,d9,d1
+                faddd d26,d10,d1
+                faddd d27,d11,d1
+                faddd d28,d12,d1
+                faddd d29,d13,d1
+                faddd d30,d14,d1
+                faddd d31,d15,d1
+                // square of i
+                fmuld d16,d16,d16
+                fmuld d17,d17,d17
+                fmuld d18,d18,d18
+                fmuld d19,d19,d19
+                fmuld d20,d20,d20
+                fmuld d21,d21,d21
+                fmuld d22,d22,d22
+                fmuld d23,d23,d23
+                fmuld d24,d24,d24
+                fmuld d25,d25,d25
+                fmuld d26,d26,d26
+                fmuld d27,d27,d27
+                fmuld d28,d28,d28
+                fmuld d29,d29,d29
+                fmuld d30,d30,d30
+                fmuld d31,d31,d31
+                // multiply by srate
+                fmuld d16,d16,d2
+                fmuld d17,d17,d2
+                fmuld d18,d18,d2
+                fmuld d19,d19,d2
+                fmuld d20,d20,d2
+                fmuld d21,d21,d2
+                fmuld d22,d22,d2
+                fmuld d23,d23,d2
+                fmuld d24,d24,d2
+                fmuld d25,d25,d2
+                fmuld d26,d26,d2
+                fmuld d27,d27,d2
+                fmuld d28,d28,d2
+                fmuld d29,d29,d2
+                fmuld d30,d30,d2
+                fmuld d31,d31,d2
+                
+                // rounding to -0.5/+0.5
+                faddd d8,d16,d3
+                faddd d9,d17,d3
+                faddd d10,d18,d3
+                faddd d11,d19,d3
+                faddd d12,d20,d3
+                faddd d13,d21,d3
+                faddd d14,d22,d3
+                faddd d15,d23,d3
+                fsubd d8,d8,d3
+                fsubd d9,d9,d3
+                fsubd d10,d10,d3
+                fsubd d11,d11,d3
+                fsubd d12,d12,d3
+                fsubd d13,d13,d3
+                fsubd d14,d14,d3
+                fsubd d15,d15,d3
+                fsubd d16,d16,d8
+                fsubd d17,d17,d9
+                fsubd d18,d18,d10
+                fsubd d19,d19,d11
+                fsubd d20,d20,d12
+                fsubd d21,d21,d13
+                fsubd d22,d22,d14
+                fsubd d23,d23,d15
+                
+                faddd d8,d24,d3
+                faddd d9,d25,d3
+                faddd d10,d26,d3
+                faddd d11,d27,d3
+                faddd d12,d28,d3
+                faddd d13,d29,d3
+                faddd d14,d30,d3
+                faddd d15,d31,d3
+                fsubd d8,d8,d3
+                fsubd d9,d9,d3
+                fsubd d10,d10,d3
+                fsubd d11,d11,d3
+                fsubd d12,d12,d3
+                fsubd d13,d13,d3
+                fsubd d14,d14,d3
+                fsubd d15,d15,d3
+                fsubd d24,d24,d8
+                fsubd d25,d25,d9
+                fsubd d26,d26,d10
+                fsubd d27,d27,d11
+                fsubd d28,d28,d12
+                fsubd d29,d29,d13
+                fsubd d30,d30,d14
+                fsubd d31,d31,d15
+                // to single precision
+                fcvtsd s0,d16
+                fcvtsd s1,d17
+                fcvtsd s2,d18
+                fcvtsd s3,d19
+                fcvtsd s4,d20
+                fcvtsd s5,d21
+                fcvtsd s6,d22
+                fcvtsd s7,d23
+                fcvtsd s8,d24
+                fcvtsd s9,d25
+                fcvtsd s10,d26
+                fcvtsd s11,d27
+                fcvtsd s12,d28
+                fcvtsd s13,d29
+                fcvtsd s14,d30
+                fcvtsd s15,d31
+                
+                //fldmias r6,{s8,s9,s10,s11,s12,s13,s14,s15}
+                vldmia r6,{q8,q9,q10,q11}
+                // square of y
+                vmul.f32 q4,q0,q0
+                vmul.f32 q5,q1,q1
+                vmul.f32 q6,q2,q2
+                vmul.f32 q7,q3,q3
+                // sine
+                vmul.f32 q12,q4,q11
+                vmul.f32 q13,q5,q11
+                vmul.f32 q14,q6,q11
+                vmul.f32 q15,q7,q11
+                vadd.f32 q12,q12,q10
+                vadd.f32 q13,q13,q10
+                vadd.f32 q14,q14,q10
+                vadd.f32 q15,q15,q10
+                vmul.f32 q12,q12,q4
+                vmul.f32 q13,q13,q5
+                vmul.f32 q14,q14,q6
+                vmul.f32 q15,q15,q7
+                vadd.f32 q12,q12,q9
+                vadd.f32 q13,q13,q9
+                vadd.f32 q14,q14,q9
+                vadd.f32 q15,q15,q9
+                vmul.f32 q12,q12,q4
+                vmul.f32 q13,q13,q5
+                vmul.f32 q14,q14,q6
+                vmul.f32 q15,q15,q7
+                vadd.f32 q12,q12,q8
+                vadd.f32 q13,q13,q8
+                vadd.f32 q14,q14,q8
+                vadd.f32 q15,q15,q8
+                vmul.f32 q12,q12,q0
+                vmul.f32 q13,q13,q1
+                vmul.f32 q14,q14,q2
+                vmul.f32 q15,q15,q3
+                vldmia r10,{q0,q1,q2,q3}
+                // cosine
+                vmul.f32 q8,q4,q3
+                vmul.f32 q9,q5,q3
+                vmul.f32 q10,q6,q3
+                vmul.f32 q11,q7,q3
+                vadd.f32 q8,q8,q2
+                vadd.f32 q9,q9,q2
+                vadd.f32 q10,q10,q2
+                vadd.f32 q11,q11,q2
+                vmul.f32 q8,q8,q4
+                vmul.f32 q9,q9,q5
+                vmul.f32 q10,q10,q6
+                vmul.f32 q11,q11,q7
+                vadd.f32 q8,q8,q1
+                vadd.f32 q9,q9,q1
+                vadd.f32 q10,q10,q1
+                vadd.f32 q11,q11,q1
+                vmul.f32 q8,q8,q4
+                vmul.f32 q9,q9,q5
+                vmul.f32 q10,q10,q6
+                vmul.f32 q11,q11,q7
+                vadd.f32 q8,q8,q0
+                vadd.f32 q9,q9,q0
+                vadd.f32 q10,q10,q0
+                vadd.f32 q11,q11,q0
+                // q8-q11 - cosine, q12-q15 - sine
+                // doubling cosine/sine
+                vmul.f32 q4,q8,q12      // c*s
+                vmul.f32 q5,q9,q13
+                vmul.f32 q6,q10,q14
+                vmul.f32 q7,q11,q15
+                vmul.f32 q0,q8,q8       // c*c
+                vmul.f32 q1,q9,q9
+                vmul.f32 q2,q10,q10
+                vmul.f32 q3,q11,q11
+                vmls.f32 q0,q12,q12    // c*c-s*s
+                vmls.f32 q1,q13,q13
+                vmls.f32 q2,q14,q14
+                vmls.f32 q3,q15,q15
+                vadd.f32 q4,q4,q4   // 2*c*s
+                vadd.f32 q5,q5,q5
+                vadd.f32 q6,q6,q6
+                vadd.f32 q7,q7,q7
+                // next doubling cosine/sine
+                vmul.f32 q8,q0,q4      // cd1 = x*y
+                vmul.f32 q9,q1,q5
+                vmul.f32 q10,q2,q6
+                vmul.f32 q11,q3,q7
+                vmul.f32 q4,q4,q4    // cd3 = y*y
+                vmul.f32 q5,q5,q5
+                vmul.f32 q6,q6,q6
+                vmul.f32 q7,q7,q7
+                vmul.f32 q0,q0,q0    // cd2 = x*x
+                vmul.f32 q1,q1,q1
+                vmul.f32 q2,q2,q2
+                vmul.f32 q3,q3,q3
+                vadd.f32 q12,q0,q4  // norm = cd2+cd3
+                vadd.f32 q13,q1,q5
+                vadd.f32 q14,q2,q6
+                vadd.f32 q15,q3,q7
+                vadd.f32 q8,q8,q8   // s = cd1*2
+                vadd.f32 q9,q9,q9
+                vadd.f32 q10,q10,q10
+                vadd.f32 q11,q11,q11
+                vsub.f32 q0,q0,q4     // c = cd2-cd3
+                vsub.f32 q1,q1,q5
+                vsub.f32 q2,q2,q6
+                vsub.f32 q3,q3,q7
+                // c - q0-q3, s - q8-q11, norm - q12-q15
+                vstmia r7,{q8,q9,q10,q11}
+                vldmia r9,{q4,q5,q6,q7}
+                // reciprocal of magnitude
+                // iter 1: invmag = 2.0-mag
+                vsub.f32 q4,q4,q12
+                vsub.f32 q5,q5,q13
+                vsub.f32 q6,q6,q14
+                vsub.f32 q7,q7,q15
+                // iter 2: invmag = invmag*(2.0-mag*invmag)
+                vrecps.f32 q8,q4,q12
+                vrecps.f32 q9,q5,q13
+                vrecps.f32 q10,q6,q14
+                vrecps.f32 q11,q7,q15
+                vmul.f32 q4,q4,q8
+                vmul.f32 q5,q5,q9
+                vmul.f32 q6,q6,q10
+                vmul.f32 q7,q7,q11
+                vldmia r7,{q8,q9,q10,q11}
+                // invnorm - q4-q7
+                // correct cosine/sine
+                vmul.f32 q0,q0,q4
+                vmul.f32 q1,q1,q5
+                vmul.f32 q2,q2,q6
+                vmul.f32 q3,q3,q7
+                vmul.f32 q8,q8,q4
+                vmul.f32 q9,q9,q5
+                vmul.f32 q10,q10,q6
+                vmul.f32 q11,q11,q7
+                vzip.32 q0,q8
+                vzip.32 q1,q9
+                vzip.32 q2,q10
+                vzip.32 q3,q11
+                vstmia r7,{q2,q3}
+                vstmia r11,{q10,q11}
+                // multiply by data
+                pld [r0,#256]
+                vldmia r0!,{q12,q13,q14,q15}
+                vmul.f32 q4,q12,q0
+                vmul.f32 q5,q13,q8
+                vmul.f32 q6,q14,q1
+                vmul.f32 q7,q15,q9
+                vrev64.32 q2,q0
+                vrev64.32 q10,q8
+                vrev64.32 q3,q1
+                vrev64.32 q11,q9
+                vmul.f32 q2,q2,q12
+                vmul.f32 q10,q10,q13
+                vmul.f32 q3,q3,q14
+                vmul.f32 q11,q11,q15
+                fnegs s17,s17
+                fnegs s19,s19
+                fnegs s21,s21
+                fnegs s23,s23
+                fnegs s25,s25
+                fnegs s27,s27
+                fnegs s29,s29
+                fnegs s31,s31
+                vtrn.32 q4,q2
+                vtrn.32 q5,q10
+                vtrn.32 q6,q3
+                vtrn.32 q7,q11
+                vadd.f32 q4,q4,q2
+                vadd.f32 q5,q5,q10
+                vadd.f32 q6,q6,q3
+                vadd.f32 q7,q7,q11
+                vstmia r1!,{q4,q5,q6,q7}
+                vldmia r7,{q0,q1}
+                vldmia r11,{q8,q9}
+                pld [r0,#256]
+                vldmia r0!,{q12,q13,q14,q15}
+                vmul.f32 q4,q12,q0
+                vmul.f32 q5,q13,q8
+                vmul.f32 q6,q14,q1
+                vmul.f32 q7,q15,q9
+                vrev64.32 q2,q0
+                vrev64.32 q10,q8
+                vrev64.32 q3,q1
+                vrev64.32 q11,q9
+                vmul.f32 q2,q2,q12
+                vmul.f32 q10,q10,q13
+                vmul.f32 q3,q3,q14
+                vmul.f32 q11,q11,q15
+                fnegs s17,s17
+                fnegs s19,s19
+                fnegs s21,s21
+                fnegs s23,s23
+                fnegs s25,s25
+                fnegs s27,s27
+                fnegs s29,s29
+                fnegs s31,s31
+                vtrn.32 q4,q2
+                vtrn.32 q5,q10
+                vtrn.32 q6,q3
+                vtrn.32 q7,q11
+                vadd.f32 q4,q4,q2
+                vadd.f32 q5,q5,q10
+                vadd.f32 q6,q6,q3
+                vadd.f32 q7,q7,q11
+                vstmia r1!,{q4,q5,q6,q7}
+                
+                add r4,r4,#16
+                cmp r0,r3
+                blo .Lmainloop
+.Lendmainloop:
+                add r3,r3,#8*15
+                cmp r0,r3
+                bhs .Lendsmallloop
+                adr r6,.Lsincosapprox
+.Lsmallloop:
+                fmsr s24,r4
+                fldmiad sp,{d9,d10}
+                fuitod d0,s24
+                // square of i
+                fmuld d0,d0,d0
+                // multiply by srate
+                fmuld d0,d0,d9
+                // rounding to -0.5/+0.5
+                faddd d12,d0,d10
+                fsubd d12,d12,d10
+                fsubd d0,d0,d12
+                fcvtsd s24,d0
+                
+                fldmias r6,{s8,s9,s10,s11,s12,s13,s14,s15}
+                // square of y
+                fmuls s0,s24,s24
+                // sine/cosine
+                fmuls s16,s0,s11
+                fmuls s17,s0,s15
+                fadds s16,s16,s10
+                fadds s17,s17,s14
+                fmuls s16,s16,s0
+                fmuls s17,s17,s0
+                fadds s16,s16,s9
+                fadds s17,s17,s13
+                fmuls s16,s16,s0
+                fmuls s17,s17,s0
+                fadds s16,s16,s8
+                fadds s17,s17,s12   // s16 - sine
+                fmuls s16,s16,s24   // s17 - cosine
+                // doubling cosine/sine
+                fmuls s18,s16,s17
+                fmuls s19,s16,s16
+                fmuls s20,s17,s17
+                fadds s18,s18,s18  // y=2*s*c
+                fsubs s19,s20,s19  // x=c*c-s*s
+                fmuls s21,s18,s19  // cd1
+                fmuls s22,s19,s19  // cd2
+                fmuls s23,s18,s18  // cd3
+                fsubs s8,s22,s23  // c
+                fadds s9,s21,s21  // s
+                // compute 1.0/norm
+                fadds s10,s22,s23 // mag
+                // reciprocal
+                flds s11,.Ltwos
+                // iter1: invmag = 2.0-mag
+                fsubs s12,s11,s10
+                // iter2: invmag = invmag*(2.0-invmag*mag)
+                fmuls s13,s12,s10
+                fsubs s13,s11,s13
+                fmuls s12,s12,s13
+                // iter3: invmag = invmag*(2.0-invmag*mag)
+                fmuls s13,s12,s10
+                fsubs s13,s11,s13
+                fmuls s12,s12,s13
+                // correct cosine/sine
+                fmuls s8,s8,s12
+                fmuls s9,s9,s12
+                // multiply data
+                fldmias r0!,{s14,s15}
+                fmuls s6,s14,s8
+                fmuls s7,s14,s9
+                fnmacs s6,s15,s9
+                fmacs s7,s15,s8
+                fstmias r1!,{s6,s7}
+                
+                add r4,r4,#1
+                cmp r0,r3
+                blo .Lsmallloop
+.Lendsmallloop:
+                add sp,sp,#16+64
+.Lendoffunc:
+                mov r0,#0
+                vpop {d8,d9,d10,d11,d12,d13,d14,d15}
+                pop {r4,r5,r6,r7,r8,r9,r10,r11,r12,lr}
+                bx lr
+                
+                .align  2
+.LGOT1:
+                .word _GLOBAL_OFFSET_TABLE_-(.LPIC1+8)
+                .word analysis_state(GOT)
+                .align 2
+.Ltwos:
+                .float 2.0
+.Lsincosapprox:
+                .float 1.5707963268,-0.6466386396,0.0679105987,-0.0011573807   // sine
+                .float 1.0,-1.2341299769,0.2465220241,-0.0123926179     // cosine
+/*
+ * neon_FoldSubs.S
+ * Author: Mateusz Szpakowski
+ */
+ 
+                .arch armv7-a
+                .fpu neon
+                .eabi_attribute 20, 1
+                .eabi_attribute 21, 1
+                .eabi_attribute 23, 3
+                .eabi_attribute 24, 1
+                .eabi_attribute 25, 1
+                .eabi_attribute 26, 2
+                .eabi_attribute 30, 2
+                .eabi_attribute 18, 4
+                .text
+                .align  2
+                /*****
+                 * fold array by 3
+                 ******/
+                .global neon_foldArrayBy3_ll31
+                .type neon_foldArrayBy3_ll31, %function
+neon_foldArrayBy3_ll31:
+                push {r4,r5,r6,lr}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r6,r0,r4,lsl #2 // end
+                
+                veor.i32 q12,q12,q12
+                sub r6,r6,#4*15
+                cmp r0,r6
+                bhs .Lendf3loop1
+.Lf3loop1:
+.macro FOLDBY3_CORE
+                vldmia r0!,{q0,q1,q2,q3}
+                vldmia r2!,{q4,q5,q6,q7}
+                vldmia r3!,{q8,q9,q10,q11}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 q3,q3,q7
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 q3,q3,q11
+                vstmia r5!,{q0,q1,q2,q3}
+                
+                vmax.f32 q13,q0,q1
+                vmax.f32 q14,q2,q3
+                vmax.f32 q12,q12,q13
+                vmax.f32 q12,q12,q14
+.endm
+                FOLDBY3_CORE
+
+                cmp r0,r6
+                blo .Lf3loop1
+.Lendf3loop1:
+                and r4,r4,#15
+                cmp r4,#8
+                blo .Lf3lt8
+                beq .Lf3eq8
+                
+                cmp r4,#12
+                blo .Lf3lt12
+                beq .Lf3eq12
+                
+                cmp r4,#14
+                blo .Lf3lt14
+                beq .Lf3eq14
+                // 15 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r0!,{s12,s13,s14}
+                vldmia r2!,{q4,q5,q6}
+                vldmia r2!,{s28,s29,s30}
+                vldmia r3!,{q8,q9,q10}
+                vldmia r3!,{d22}
+                vldmia r3!, {s15}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 d6,d6,d14
+                vadd.f32 s14,s14,s30
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 d6,d6,d22
+                vadd.f32 s14,s14,s15
+                
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{s12,s13,s14}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 q12,q12,q3
+                
+                b .Lf3end
+.Lf3eq14:
+                // 14 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r0!,{d6}
+                vldmia r2!,{q4,q5,q6}
+                vldmia r2!,{d14}
+                vldmia r3!,{q8,q9,q10}
+                vldmia r3!,{d22}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 d6,d6,d14
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 d6,d6,d22
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{d6}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 d24,d24,d6
+                
+                b .Lf3end
+.Lf3lt14:
+                // 13 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r0!,{s12}
+                vldmia r2!,{q4,q5,q6}
+                vldmia r2!,{s13}
+                vldmia r3!,{q8,q9,q10}
+                vldmia r3!,{s14}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                fadds s12,s12,s13
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                fadds s12,s12,s14
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{s12}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 d24,d24,d6
+                
+                b .Lf3end
+.Lf3eq12:
+                // 12 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r2!,{q4,q5,q6}
+                vldmia r3!,{q8,q9,q10}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vstmia r5!,{q0,q1,q2}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                
+                b .Lf3end
+.Lf3lt12:
+                cmp r4,#10
+                blo .Lf3lt10
+                beq .Lf3eq10
+                // 11 elems
+                vldmia r0!,{q0,q1}
+                vldmia r0!,{s8,s9,s10}
+                vldmia r2!,{q4,q5}
+                vldmia r2!,{s24,s25,s26}
+                vldmia r3!,{q8,q9}
+                vldmia r3!,{d20}
+                vldmia r3!,{s11}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 d4,d4,d12
+                vadd.f32 s10,s10,s26
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 d4,d4,d20
+                vadd.f32 s10,s10,s11
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{s8,s9,s10}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                
+                b .Lf3end
+.Lf3eq10:
+                // 10 elems
+                vldmia r0!,{q0,q1}
+                vldmia r0!,{d4}
+                vldmia r2!,{q4,q5}
+                vldmia r2!,{d12}
+                vldmia r3!,{q8,q9}
+                vldmia r3!,{d20}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 d4,d4,d12
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 d4,d4,d20
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{d4}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 d24,d24,d4
+                
+                b .Lf3end
+.Lf3lt10:
+                // 9 elems
+                vldmia r0!,{q0,q1}
+                vldmia r0!,{s8}
+                vldmia r2!,{q4,q5}
+                vldmia r2!,{s9}
+                vldmia r3!,{q8,q9}
+                vldmia r3!,{s10}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                fadds s8,s8,s9
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                fadds s8,s8,s10
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{s8}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 d24,d24,d4
+
+                b .Lf3end
+.Lf3eq8:
+                // 8 elems
+                vldmia r0!,{q0,q1}
+                vldmia r2!,{q4,q5}
+                vldmia r3!,{q8,q9}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vstmia r5!,{q0,q1}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                
+                b .Lf3end
+.Lf3lt8:
+                cmp r4,#4
+                blo .Lf3lt4
+                beq .Lf3eq4
+                
+                cmp r4,#6
+                blo .Lf3lt6
+                beq .Lf3eq6
+                // 7 elems
+                vldmia r0!,{q0}
+                vldmia r0!,{s4,s5,s6}
+                vldmia r2!,{q4}
+                vldmia r2!,{s20,s21,s22}
+                vldmia r3!,{q8}
+                vldmia r3!,{d18}
+                vldmia r3!,{s7}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 d2,d2,d10
+                vadd.f32 s6,s6,s22
+                vadd.f32 q0,q0,q8
+                vadd.f32 d2,d2,d18
+                vadd.f32 s6,s6,s7
+                vstmia r5!,{q0}
+                vstmia r5!,{s4,s5,s6}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                
+                b .Lf3end
+.Lf3eq6:
+                // 6 elems
+                vldmia r0!,{q0}
+                vldmia r0!,{d2}
+                vldmia r2!,{q4}
+                vldmia r2!,{d10}
+                vldmia r3!,{q8}
+                vldmia r3!,{d18}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 d2,d2,d10
+                vadd.f32 q0,q0,q8
+                vadd.f32 d2,d2,d18
+                vstmia r5!,{q0}
+                vstmia r5!,{d2}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 d24,d24,d2
+                
+                b .Lf3end
+.Lf3lt6:
+                // 5 elems
+                vldmia r0!,{q0}
+                vldmia r0!,{s4}
+                vldmia r2!,{q4}
+                vldmia r2!,{s20}
+                vldmia r3!,{q8}
+                vldmia r3!,{s5}
+                
+                vadd.f32 q0,q0,q4
+                fadds s4,s4,s20
+                vadd.f32 q0,q0,q8
+                fadds s4,s4,s5
+                vstmia r5!,{q0}
+                vstmia r5!,{s4}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 d24,d24,d2
+                
+                b .Lf3end
+.Lf3eq4:
+                // 4 elems
+                vldmia r0!,{q0}
+                vldmia r2!,{q4}
+                vldmia r3!,{q8}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q0,q0,q8
+                vstmia r5!,{q0}
+                
+                vmax.f32 q12,q12,q0
+                
+                b .Lf3end
+.Lf3lt4:
+                cmp r4,#2
+                blo .Lf3lt2
+                beq .Lf3eq2
+                // 3 elems
+                vldmia r0!,{s0,s1,s2}
+                vldmia r2!,{s16,s17,s18}
+                vldmia r3!,{d16}
+                vldmia r3!,{s3}
+                
+                vadd.f32 d0,d0,d8
+                vadd.f32 s2,s2,s18
+                vadd.f32 d0,d0,d16
+                vadd.f32 s2,s2,s3
+                vstmia r5!,{s0,s1,s2}
+                
+                vmax.f32 q12,q12,q0
+                
+                b .Lf3end
+.Lf3eq2:
+                // 2 elems
+                vldmia r0!,{d0}
+                vldmia r2!,{d4}
+                vldmia r3!,{d8}
+                
+                vadd.f32 d0,d0,d4
+                vadd.f32 d0,d0,d8
+                vstmia r5!,{d0}
+                
+                vmax.f32 d24,d24,d0
+                
+                b .Lf3end
+.Lf3lt2:
+                cmp r4,#0
+                beq .Lf3eq0
+                
+                vldmia r0!,{s0}
+                vldmia r2!,{s1}
+                vldmia r3!,{s2}
+                
+                vadd.f32 s0,s0,s1
+                vadd.f32 s0,s0,s2
+                vstmia r5!,{s0}
+                
+                vmax.f32 d24,d24,d0
+.Lf3eq0:
+.Lf3end:
+                vpmax.f32 d24,d24,d25
+                vpmax.f32 d0,d24,d24
+
+                fmrs r0,s0
+                vpop {d8,d9,d10,d11,d12,d13,d14,d15}
+                pop {r4,r5,r6,lr}
+                bx lr
+                
+                
+                .global neon_foldArrayBy3_lge31
+                .type neon_foldArrayBy3_lge31, %function
+neon_foldArrayBy3_lge31:
+                push {r4,r5,r6,lr}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r6,r0,r4,lsl #2 // end
+                
+                veor.i32 q12,q12,q12
+                sub r6,r6,#4*31
+                cmp r0,r6
+                bhs .Lendf3loop2
+.Lf3loop2:
+                FOLDBY3_CORE
+                FOLDBY3_CORE
+                
+                cmp r0,r6
+                blo .Lf3loop2
+.Lendf3loop2:                
+                add r6,r6,#4*16
+                cmp r0,r6
+                bhs .Lendf3loop1
+.Lf3loop3:
+                FOLDBY3_CORE
+
+                cmp r0,r6
+                blo .Lf3loop3
+.Lendf3loop3:
+                b .Lendf3loop1
+               
+.Lfoldby3sel:
+.rept 31
+                .word neon_foldArrayBy3_ll31
+.endr
+                .word neon_foldArrayBy3_lge31
+               
+                /******
+                 * fold array by 4
+                 ******/
+                .global neon_foldArrayBy4_ll31
+                .type neon_foldArrayBy4_ll31, %function
+neon_foldArrayBy4_ll31:
+                push {r4,r5,r6,r7,r8,lr}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                ldr r6,[r1,#16] // tmp2
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                add r6,r0,r6,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r7,r0,r4,lsl #2 // end
+                
+                veor.i32 q12,q12,q12
+                sub r7,r7,#4*15
+                cmp r0,r7
+                bhs .Lendf4loop1
+.Lf4loop1:
+.macro FOLDBY4_CORE
+                vldmia r0!,{q0,q1,q2,q3}
+                vldmia r2!,{q4,q5,q6,q7}
+                vldmia r3!,{q8,q9,q10,q11}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 q3,q3,q7
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 q3,q3,q11
+                vldmia r6!,{q8,q9,q10,q11}
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 q3,q3,q11
+                vstmia r5!,{q0,q1,q2,q3}
+                
+                vmax.f32 q13,q0,q1
+                vmax.f32 q14,q2,q3
+                vmax.f32 q12,q12,q13
+                vmax.f32 q12,q12,q14
+.endm
+                FOLDBY4_CORE
+
+                cmp r0,r7
+                blo .Lf4loop1
+.Lendf4loop1:
+                and r4,r4,#15
+                cmp r4,#8
+                blo .Lf4lt8
+                beq .Lf4eq8
+                
+                cmp r4,#12
+                blo .Lf4lt12
+                beq .Lf4eq12
+                
+                cmp r4,#14
+                blo .Lf4lt14
+                beq .Lf4eq14
+                // 15 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r0!,{s12,s13,s14}
+                vldmia r2!,{q4,q5,q6}
+                vldmia r2!,{s28,s29,s30}
+                vldmia r3!,{q8,q9,q10}
+                vldmia r3!,{d22}
+                vldmia r3, {s15}
+                vldmia r6!,{q13,q14,q15}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 d6,d6,d14
+                vadd.f32 s14,s14,s30
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 d6,d6,d22
+                vadd.f32 s14,s14,s15
+                vldmia r6!,{s16,s17,s18}
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 q2,q2,q15
+                vadd.f32 d6,d6,d8
+                vadd.f32 s14,s14,s18
+                
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{s12,s13,s14}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 q12,q12,q3
+                
+                b .Lf4end
+.Lf4eq14:
+                // 14 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r0!,{d6}
+                vldmia r2!,{q4,q5,q6}
+                vldmia r2!,{d14}
+                vldmia r3!,{q8,q9,q10}
+                vldmia r3!,{d22}
+                vldmia r6!,{q13,q14,q15}
+                vldmia r6!,{d7}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 d6,d6,d14
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 d6,d6,d22
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 q2,q2,q15
+                vadd.f32 d6,d6,d7
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{d6}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 d24,d24,d6
+                
+                b .Lf4end
+.Lf4lt14:
+                // 13 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r0!,{s12}
+                vldmia r2!,{q4,q5,q6}
+                vldmia r2!,{s13}
+                vldmia r3!,{q8,q9,q10}
+                vldmia r3!,{s14}
+                vldmia r6!,{q13,q14,q15}
+                vldmia r6!,{s15}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                fadds s12,s12,s13
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                fadds s12,s12,s14
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 q2,q2,q15
+                fadds s12,s12,s15
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{s12}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 d24,d24,d6
+                
+                b .Lf4end
+.Lf4eq12:
+                // 12 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r2!,{q4,q5,q6}
+                vldmia r3!,{q8,q9,q10}
+                vldmia r6!,{q13,q14,q15}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 q2,q2,q15
+                vstmia r5!,{q0,q1,q2}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                
+                b .Lf4end
+.Lf4lt12:
+                cmp r4,#10
+                blo .Lf4lt10
+                beq .Lf4eq10
+                // 11 elems
+                vldmia r0!,{q0,q1}
+                vldmia r0!,{s8,s9,s10}
+                vldmia r2!,{q4,q5}
+                vldmia r2!,{s24,s25,s26}
+                vldmia r3!,{q8,q9}
+                vldmia r3!,{d20}
+                vldmia r3!,{s11}
+                vldmia r6!,{q13,q14}
+                vldmia r6!,{s12,s13,s14}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 d4,d4,d12
+                vadd.f32 s10,s10,s26
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 d4,d4,d20
+                vadd.f32 s10,s10,s11
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 d4,d4,d6
+                vadd.f32 s10,s10,s14
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{s8,s9,s10}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                
+                b .Lf4end
+.Lf4eq10:
+                // 10 elems
+                vldmia r0!,{q0,q1}
+                vldmia r0!,{d4}
+                vldmia r2!,{q4,q5}
+                vldmia r2!,{d12}
+                vldmia r3!,{q8,q9}
+                vldmia r3!,{d20}
+                vldmia r6!,{q13,q14}
+                vldmia r6!,{d5}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 d4,d4,d12
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 d4,d4,d20
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 d4,d4,d5
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{d4}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 d24,d24,d4
+                
+                b .Lf4end
+.Lf4lt10:
+                // 9 elems
+                vldmia r0!,{q0,q1}
+                vldmia r0!,{s8}
+                vldmia r2!,{q4,q5}
+                vldmia r2!,{s9}
+                vldmia r3!,{q8,q9}
+                vldmia r3!,{s10}
+                vldmia r6!,{q13,q14}
+                vldmia r6!,{s11}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                fadds s8,s8,s9
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                fadds s8,s8,s10
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                fadds s8,s8,s11
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{s8}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 d24,d24,d4
+
+                b .Lf4end
+.Lf4eq8:
+                // 8 elems
+                vldmia r0!,{q0,q1}
+                vldmia r2!,{q4,q5}
+                vldmia r3!,{q8,q9}
+                vldmia r6!,{q13,q14}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vstmia r5!,{q0,q1}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                
+                b .Lf4end
+.Lf4lt8:
+                cmp r4,#4
+                blo .Lf4lt4
+                beq .Lf4eq4
+                
+                cmp r4,#6
+                blo .Lf4lt6
+                beq .Lf4eq6
+                // 7 elems
+                vldmia r0!,{q0}
+                vldmia r0!,{s4,s5,s6}
+                vldmia r2!,{q4}
+                vldmia r2!,{s20,s21,s22}
+                vldmia r3!,{q8}
+                vldmia r3!,{d18}
+                vldmia r3!,{s7}
+                vldmia r6!,{q13}
+                vldmia r6!,{s8,s9,s10}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 d2,d2,d10
+                vadd.f32 s6,s6,s22
+                vadd.f32 q0,q0,q8
+                vadd.f32 d2,d2,d18
+                vadd.f32 s6,s6,s7
+                vadd.f32 q0,q0,q13
+                vadd.f32 d2,d2,d4
+                vadd.f32 s6,s6,s10
+                vstmia r5!,{q0}
+                vstmia r5!,{s4,s5,s6}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                
+                b .Lf4end
+.Lf4eq6:
+                // 6 elems
+                vldmia r0!,{q0}
+                vldmia r0!,{d2}
+                vldmia r2!,{q4}
+                vldmia r2!,{d10}
+                vldmia r3!,{q8}
+                vldmia r3!,{d18}
+                vldmia r6!,{q13}
+                vldmia r6!,{d3}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 d2,d2,d10
+                vadd.f32 q0,q0,q8
+                vadd.f32 d2,d2,d18
+                vadd.f32 q0,q0,q13
+                vadd.f32 d2,d2,d3
+                vstmia r5!,{q0}
+                vstmia r5!,{d2}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 d24,d24,d2
+                
+                b .Lf4end
+.Lf4lt6:
+                // 5 elems
+                vldmia r0!,{q0}
+                vldmia r0!,{s4}
+                vldmia r2!,{q4}
+                vldmia r2!,{s20}
+                vldmia r3!,{q8}
+                vldmia r3!,{s5}
+                vldmia r6!,{q13}
+                vldmia r6!,{s6}
+                
+                vadd.f32 q0,q0,q4
+                fadds s4,s4,s20
+                vadd.f32 q0,q0,q8
+                fadds s4,s4,s5
+                vadd.f32 q0,q0,q13
+                fadds s4,s4,s6
+                vstmia r5!,{q0}
+                vstmia r5!,{s4}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 d24,d24,d2
+                
+                b .Lf4end
+.Lf4eq4:
+                // 4 elems
+                vldmia r0!,{q0}
+                vldmia r2!,{q4}
+                vldmia r3!,{q8}
+                vldmia r6!,{q13}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q0,q0,q8
+                vadd.f32 q0,q0,q13
+                vstmia r5!,{q0}
+                
+                vmax.f32 q12,q12,q0
+                
+                b .Lf4end
+.Lf4lt4:
+                cmp r4,#2
+                blo .Lf4lt2
+                beq .Lf4eq2
+                // 3 elems
+                vldmia r0!,{s0,s1,s2}
+                vldmia r2!,{s16,s17,s18}
+                vldmia r3!,{d16}
+                vldmia r3!,{s3}
+                vldmia r6!,{s4,s5,s6}
+                
+                vadd.f32 d0,d0,d8
+                vadd.f32 s2,s2,s18
+                vadd.f32 d0,d0,d16
+                vadd.f32 s2,s2,s3
+                vadd.f32 d0,d0,d2
+                vadd.f32 s2,s2,s6
+                vstmia r5!,{s0,s1,s2}
+                
+                vmax.f32 q12,q12,q0
+                
+                b .Lf4end
+.Lf4eq2:
+                // 2 elems
+                vldmia r0!,{d0}
+                vldmia r2!,{d4}
+                vldmia r3!,{d8}
+                vldmia r6!,{d12}
+                
+                vadd.f32 d0,d0,d4
+                vadd.f32 d0,d0,d8
+                vadd.f32 d0,d0,d12
+                vstmia r5!,{d0}
+                
+                vmax.f32 d24,d24,d0
+                
+                b .Lf4end
+.Lf4lt2:
+                cmp r4,#0
+                beq .Lf4eq0
+                
+                vldmia r0!,{s0}
+                vldmia r2!,{s1}
+                vldmia r3!,{s2}
+                vldmia r6!,{s3}
+                
+                vadd.f32 s0,s0,s1
+                vadd.f32 s0,s0,s2
+                vadd.f32 s0,s0,s3
+                vstmia r5!,{s0}
+                
+                vmax.f32 d24,d24,d0
+.Lf4eq0:
+.Lf4end:
+                vpmax.f32 d24,d24,d25
+                vpmax.f32 d0,d24,d24
+
+                fmrs r0,s0
+                vpop {d8,d9,d10,d11,d12,d13,d14,d15}
+                pop {r4,r5,r6,r7,r8,lr}
+                bx lr
+                
+                
+                .global neon_foldArrayBy4_lge31
+                .type neon_foldArrayBy4_lge31, %function
+neon_foldArrayBy4_lge31:
+                push {r4,r5,r6,r7,r8,lr}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                ldr r6,[r1,#16] // tmp2
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                add r6,r0,r6,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r7,r0,r4,lsl #2 // end
+                
+                veor.i32 q12,q12,q12
+                sub r7,r7,#4*31
+                cmp r0,r7
+                bhs .Lendf4loop2
+.Lf4loop2:
+                FOLDBY4_CORE
+                FOLDBY4_CORE
+                
+                cmp r0,r7
+                blo .Lf4loop2
+.Lendf4loop2:
+                add r7,r7,#4*16
+                cmp r0,r7
+                bhs .Lendf4loop1
+.Lf4loop3:
+                FOLDBY4_CORE
+
+                cmp r0,r7
+                blo .Lf4loop3
+.Lendf4loop3:
+                b .Lendf4loop1
+                
+.Lfoldby4sel:
+.rept 31
+                .word neon_foldArrayBy4_ll31
+.endr
+                .word neon_foldArrayBy4_lge31
+
+                /******
+                 * fold array by 5
+                 ******/
+                .global neon_foldArrayBy5_ll31
+                .type neon_foldArrayBy5_ll31, %function
+neon_foldArrayBy5_ll31:
+                push {r4,r5,r6,r7,r8,lr}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                ldrd r6,[r1,#16] // tmp2
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                add r6,r0,r6,lsl #2
+                add r7,r0,r7,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r8,r0,r4,lsl #2 // end
+                
+                veor.i32 q12,q12,q12
+                sub r8,r8,#4*15
+                cmp r0,r8
+                bhs .Lendf5loop1
+.Lf5loop1:
+.macro FOLDBY5_CORE
+                vldmia r0!,{q0,q1,q2,q3}
+                vldmia r2!,{q4,q5,q6,q7}
+                vldmia r3!,{q8,q9,q10,q11}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 q3,q3,q7
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 q3,q3,q11
+                vldmia r6!,{q8,q9,q10,q11}
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 q3,q3,q11
+                vldmia r7!,{q8,q9,q10,q11}
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 q3,q3,q11
+                vstmia r5!,{q0,q1,q2,q3}
+                
+                vmax.f32 q13,q0,q1
+                vmax.f32 q14,q2,q3
+                vmax.f32 q12,q12,q13
+                vmax.f32 q12,q12,q14
+.endm
+                FOLDBY5_CORE
+
+                cmp r0,r8
+                blo .Lf5loop1
+.Lendf5loop1:
+                and r4,r4,#15
+                cmp r4,#8
+                blo .Lf5lt8
+                beq .Lf5eq8
+                
+                cmp r4,#12
+                blo .Lf5lt12
+                beq .Lf5eq12
+                
+                cmp r4,#14
+                blo .Lf5lt14
+                beq .Lf5eq14
+                // 15 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r0!,{s12,s13,s14}
+                vldmia r2!,{q4,q5,q6}
+                vldmia r2!,{s28,s29,s30}
+                vldmia r3!,{q8,q9,q10}
+                vldmia r3!,{d22}
+                vldmia r3, {s15}
+                vldmia r6!,{q13,q14,q15}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 d6,d6,d14
+                vadd.f32 s14,s14,s30
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 d6,d6,d22
+                vadd.f32 s14,s14,s15
+                vldmia r6!,{s16,s17,s18}
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 q2,q2,q15
+                vadd.f32 d6,d6,d8
+                vadd.f32 s14,s14,s18
+                vldmia r7!,{q13,q14,q15}
+                vldmia r7!,{s16,s17,s18}
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 q2,q2,q15
+                vadd.f32 d6,d6,d8
+                vadd.f32 s14,s14,s18
+                
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{s12,s13,s14}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 q12,q12,q3
+                
+                b .Lf5end
+.Lf5eq14:
+                // 14 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r0!,{d6}
+                vldmia r2!,{q4,q5,q6}
+                vldmia r2!,{d14}
+                vldmia r3!,{q8,q9,q10}
+                vldmia r3!,{d22}
+                vldmia r6!,{q13,q14,q15}
+                vldmia r6!,{d7}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 d6,d6,d14
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                vadd.f32 d6,d6,d22
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 q2,q2,q15
+                vadd.f32 d6,d6,d7
+                vldmia r7!,{q13,q14,q15}
+                vldmia r7!,{d7}
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 q2,q2,q15
+                vadd.f32 d6,d6,d7
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{d6}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 d24,d24,d6
+                
+                b .Lf5end
+.Lf5lt14:
+                // 13 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r0!,{s12}
+                vldmia r2!,{q4,q5,q6}
+                vldmia r2!,{s13}
+                vldmia r3!,{q8,q9,q10}
+                vldmia r3!,{s14}
+                vldmia r6!,{q13,q14,q15}
+                vldmia r6!,{s15}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                fadds s12,s12,s13
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q2,q2,q10
+                fadds s12,s12,s14
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 q2,q2,q15
+                fadds s12,s12,s15
+                vldmia r7!,{q13,q14,q15}
+                vldmia r7!,{s15}
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 q2,q2,q15
+                fadds s12,s12,s15
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{s12}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 d24,d24,d6
+                
+                b .Lf5end
+.Lf5eq12:
+                // 12 elems
+                vldmia r0!,{q0,q1,q2}
+                vldmia r2!,{q3,q4,q5}
+                vldmia r3!,{q6,q7,q8}
+                vldmia r6!,{q9,q10,q11}
+                vldmia r7!,{q13,q14,q15}
+                
+                vadd.f32 q0,q0,q3
+                vadd.f32 q1,q1,q4
+                vadd.f32 q2,q2,q5
+                vadd.f32 q0,q0,q6
+                vadd.f32 q1,q1,q7
+                vadd.f32 q2,q2,q8
+                vadd.f32 q0,q0,q9
+                vadd.f32 q1,q1,q10
+                vadd.f32 q2,q2,q11
+                vadd.f32 q0,q0,q13
+                vadd.f32 q1,q1,q14
+                vadd.f32 q2,q2,q15
+                vstmia r5!,{q0,q1,q2}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                
+                b .Lf5end
+.Lf5lt12:
+                cmp r4,#10
+                blo .Lf5lt10
+                beq .Lf5eq10
+                // 11 elems
+                vldmia r0!,{q0,q1}
+                vldmia r0!,{s8,s9,s10}
+                vldmia r2!,{q7,q8}
+                vldmia r2!,{d6}
+                vldmia r2!,{s11}
+                vldmia r3!,{q9,q10}
+                vldmia r3!,{s14,s15,s16}
+                vldmia r6!,{q11}
+                vldmia r6!,{q13}
+                vldmia r6!,{s18,s19,s20}
+                vldmia r7!,{q14}
+                vldmia r7!,{q15}
+                vldmia r7!,{s22,s23,s24}
+
+                vadd.f32 q0,q0,q7
+                vadd.f32 q1,q1,q8
+                vadd.f32 d4,d4,d6
+                vadd.f32 s10,s10,s11
+                vadd.f32 q0,q0,q9
+                vadd.f32 q1,q1,q10
+                vadd.f32 d4,d4,d7
+                vadd.f32 s10,s10,s16
+                vadd.f32 q0,q0,q11
+                vadd.f32 q1,q1,q13
+                vadd.f32 d4,d4,d9
+                vadd.f32 s10,s10,s20
+                vadd.f32 q0,q0,q14
+                vadd.f32 q1,q1,q15
+                vadd.f32 d4,d4,d11
+                vadd.f32 s10,s10,s24
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{s8,s9,s10}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                
+                b .Lf5end
+.Lf5eq10:
+                // 10 elems
+                vldmia r0!,{q0,q1}
+                vldmia r0!,{d4}
+                vldmia r2!,{q3,q4}
+                vldmia r2!,{d5}
+                vldmia r3!,{q5,q6}
+                vldmia r3!,{d14}
+                vldmia r6!,{q8,q9}
+                vldmia r6!,{d15}
+                vldmia r7!,{q10,q11}
+                vldmia r7!,{d26}
+                
+                vadd.f32 q0,q0,q3
+                vadd.f32 q1,q1,q4
+                vadd.f32 d4,d4,d5
+                vadd.f32 q0,q0,q5
+                vadd.f32 q1,q1,q6
+                vadd.f32 d4,d4,d14
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 d4,d4,d15
+                vadd.f32 q0,q0,q10
+                vadd.f32 q1,q1,q11
+                vadd.f32 d4,d4,d26
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{d4}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 d24,d24,d4
+                
+                b .Lf5end
+.Lf5lt10:
+                // 9 elems
+                vldmia r0!,{q0,q1}
+                vldmia r0!,{s8}
+                vldmia r2!,{q4,q5}
+                vldmia r2!,{s9}
+                vldmia r3!,{q6,q7}
+                vldmia r3!,{s10}
+                vldmia r6!,{q8,q9}
+                vldmia r6!,{s11}
+                vldmia r7!,{q10,q11}
+                vldmia r7!,{s12}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                fadds s8,s8,s9
+                vadd.f32 q0,q0,q6
+                vadd.f32 q1,q1,q7
+                fadds s8,s8,s10
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                fadds s8,s8,s11
+                vadd.f32 q0,q0,q10
+                vadd.f32 q1,q1,q11
+                fadds s8,s8,s12
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{s8}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 d24,d24,d4
+
+                b .Lf5end
+.Lf5eq8:
+                // 8 elems
+                vldmia r0!,{q0,q1}
+                vldmia r2!,{q2,q3}
+                vldmia r3!,{q4,q5}
+                vldmia r6!,{q8,q9}
+                vldmia r7!,{q10,q11}
+                
+                vadd.f32 q0,q0,q2
+                vadd.f32 q1,q1,q3
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q0,q0,q8
+                vadd.f32 q1,q1,q9
+                vadd.f32 q0,q0,q10
+                vadd.f32 q1,q1,q11
+                vstmia r5!,{q0,q1}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                
+                b .Lf5end
+.Lf5lt8:
+                cmp r4,#4
+                blo .Lf5lt4
+                beq .Lf5eq4
+                
+                cmp r4,#6
+                blo .Lf5lt6
+                beq .Lf5eq6
+                // 7 elems
+                vldmia r0!,{q0}
+                vldmia r0!,{s4,s5,s6}
+                vldmia r2!,{q2}
+                vldmia r2!,{d6}
+                vldmia r2!,{s7}
+                vldmia r3!,{q4}
+                vldmia r3!,{s20,s21,s22}
+                vldmia r6!,{q6}
+                vldmia r6!,{s28,s29,s30}
+                vldmia r7!,{q8}
+                vldmia r7!,{d7}
+                vldmia r7!,{s31}
+                
+                vadd.f32 q0,q0,q2
+                vadd.f32 d2,d2,d6
+                vadd.f32 s6,s6,s7
+                vadd.f32 q0,q0,q4
+                vadd.f32 d2,d2,d10
+                vadd.f32 s6,s6,s22
+                vadd.f32 q0,q0,q6
+                vadd.f32 d2,d2,d14
+                vadd.f32 s6,s6,s30
+                vadd.f32 q0,q0,q8
+                vadd.f32 d2,d2,d7
+                vadd.f32 s6,s6,s31
+                vstmia r5!,{q0}
+                vstmia r5!,{s4,s5,s6}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                
+                b .Lf5end
+.Lf5eq6:
+                // 6 elems
+                vldmia r0!,{q0}
+                vldmia r0!,{d2}
+                vldmia r2!,{q2}
+                vldmia r2!,{d6}
+                vldmia r3!,{q4}
+                vldmia r3!,{d10}
+                vldmia r6!,{q6}
+                vldmia r6!,{d14}
+                vldmia r7!,{q8}
+                vldmia r7!,{d15}
+                
+                vadd.f32 q0,q0,q2
+                vadd.f32 d2,d2,d6
+                vadd.f32 q0,q0,q4
+                vadd.f32 d2,d2,d10
+                vadd.f32 q0,q0,q6
+                vadd.f32 d2,d2,d14
+                vadd.f32 q0,q0,q8
+                vadd.f32 d2,d2,d15
+                vstmia r5!,{q0}
+                vstmia r5!,{d2}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 d24,d24,d2
+                
+                b .Lf5end
+.Lf5lt6:
+                // 5 elems
+                vldmia r0!,{q0}
+                vldmia r0!,{s4}
+                vldmia r2!,{q2}
+                vldmia r2!,{s5}
+                vldmia r3!,{q4}
+                vldmia r3!,{s6}
+                vldmia r6!,{q6}
+                vldmia r6!,{s7}
+                vldmia r7!,{q8}
+                vldmia r7!,{s12}
+                
+                vadd.f32 q0,q0,q2
+                fadds s4,s4,s5
+                vadd.f32 q0,q0,q4
+                fadds s4,s4,s6
+                vadd.f32 q0,q0,q6
+                fadds s4,s4,s7
+                vadd.f32 q0,q0,q8
+                fadds s4,s4,s12
+                vstmia r5!,{q0}
+                vstmia r5!,{s4}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 d24,d24,d2
+                
+                b .Lf5end
+.Lf5eq4:
+                // 4 elems
+                vldmia r0!,{q0}
+                vldmia r2!,{q4}
+                vldmia r3!,{q8}
+                vldmia r6!,{q13}
+                vldmia r7!,{q14}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q0,q0,q8
+                vadd.f32 q0,q0,q13
+                vadd.f32 q0,q0,q14
+                vstmia r5!,{q0}
+                
+                vmax.f32 q12,q12,q0
+                
+                b .Lf5end
+.Lf5lt4:
+                cmp r4,#2
+                blo .Lf5lt2
+                beq .Lf5eq2
+                // 3 elems
+                vldmia r0!,{s0,s1,s2}
+                vldmia r2!,{d2}
+                vldmia r2!,{s3}
+                vldmia r3!,{s6,s7,s8}
+                vldmia r6!,{s10,s11,s12}
+                vldmia r7!,{s14,s15,s16}
+                
+                vadd.f32 d0,d0,d2
+                vadd.f32 s2,s2,s3
+                vadd.f32 d0,d0,d3
+                vadd.f32 s2,s2,s8
+                vadd.f32 d0,d0,d5
+                vadd.f32 s2,s2,s12
+                vadd.f32 d0,d0,d7
+                vadd.f32 s2,s2,s16
+                vstmia r5!,{s0,s1,s2}
+                
+                vmax.f32 q12,q12,q0
+                
+                b .Lf5end
+.Lf5eq2:
+                // 2 elems
+                vldmia r0!,{d0}
+                vldmia r2!,{d4}
+                vldmia r3!,{d8}
+                vldmia r6!,{d12}
+                vldmia r7!,{d13}
+                
+                vadd.f32 d0,d0,d4
+                vadd.f32 d0,d0,d8
+                vadd.f32 d0,d0,d12
+                vadd.f32 d0,d0,d13
+                vstmia r5!,{d0}
+                
+                vmax.f32 d24,d24,d0
+                
+                b .Lf5end
+.Lf5lt2:
+                cmp r4,#0
+                beq .Lf5eq0
+                
+                vldmia r0!,{s0}
+                vldmia r2!,{s1}
+                vldmia r3!,{s2}
+                vldmia r6!,{s3}
+                vldmia r7!,{s4}
+                
+                vadd.f32 s0,s0,s1
+                vadd.f32 s0,s0,s2
+                vadd.f32 s0,s0,s3
+                vadd.f32 s0,s0,s4
+                vstmia r5!,{s0}
+                
+                vmax.f32 d24,d24,d0
+.Lf5eq0:
+.Lf5end:
+                vpmax.f32 d24,d24,d25
+                vpmax.f32 d0,d24,d24
+
+                fmrs r0,s0
+                vpop {d8,d9,d10,d11,d12,d13,d14,d15}
+                pop {r4,r5,r6,r7,r8,lr}
+                bx lr
+                
+.Lfoldby5sel:
+.rept 31
+                .word neon_foldArrayBy5_ll31
+.endr
+                .word neon_foldArrayBy5_lge31
+
+                
+                .global neon_foldArrayBy5_lge31
+                .type neon_foldArrayBy5_lge31, %function
+neon_foldArrayBy5_lge31:
+                push {r4,r5,r6,r7,r8,lr}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                ldrd r6,[r1,#16] // tmp2
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                add r6,r0,r6,lsl #2
+                add r7,r0,r7,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r8,r0,r4,lsl #2 // end
+                
+                veor.i32 q12,q12,q12
+                sub r8,r8,#4*31
+                cmp r0,r8
+                bhs .Lendf5loop2
+.Lf5loop2:
+                FOLDBY5_CORE
+                FOLDBY5_CORE
+                
+                cmp r0,r8
+                blo .Lf5loop2
+.Lendf5loop2:
+                add r8,r8,#4*16
+                cmp r0,r8
+                bhs .Lendf5loop1
+.Lf5loop3:
+                FOLDBY5_CORE
+
+                cmp r0,r8
+                blo .Lf5loop3
+.Lendf5loop3:
+                b .Lendf5loop1
+                
+
+                /*****
+                 * fold array by 2
+                 ******/
+                .global neon_foldArrayBy2_ll31
+                .type neon_foldArrayBy2_ll31, %function
+neon_foldArrayBy2_ll31:
+                push {r4,r5,r6,lr}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+                
+                ldr r0,[r0,#4] // ss1
+                ldrd r2,[r1,#8] // tmp0
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r6,r2,r4,lsl #2 // end
+                
+                veor.i32 q12,q12,q12
+                sub r6,r6,#4*15
+                cmp r2,r6
+                bhs .Lendf2loop1
+.Lf2loop1:
+.macro FOLDBY2_CORE
+                vldmia r2!,{q0,q1,q2,q3}
+                vldmia r3!,{q4,q5,q6,q7}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 q3,q3,q7
+                vstmia r5!,{q0,q1,q2,q3}
+                
+                vmax.f32 q13,q0,q1
+                vmax.f32 q14,q2,q3
+                vmax.f32 q12,q12,q13
+                vmax.f32 q12,q12,q14
+.endm
+                FOLDBY2_CORE
+
+                cmp r2,r6
+                blo .Lf2loop1
+.Lendf2loop1:
+                and r4,r4,#15
+                cmp r4,#8
+                blo .Lf2lt8
+                beq .Lf2eq8
+                
+                cmp r4,#12
+                blo .Lf2lt12
+                beq .Lf2eq12
+                
+                cmp r4,#14
+                blo .Lf2lt14
+                beq .Lf2eq14
+                // 15 elems
+                vldmia r2!,{q0,q1,q2}
+                vldmia r2!,{s12,s13,s14}
+                vldmia r3!,{q4,q5,q6}
+                vldmia r3!,{s28,s29}
+                vldmia r3!,{s15}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 d6,d6,d14
+                vadd.f32 s14,s14,s15
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{s12,s13,s14}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 q12,q12,q3
+                
+                b .Lf2end
+.Lf2eq14:
+                // 14 elems
+                vldmia r2!,{q0,q1,q2}
+                vldmia r2!,{d6}
+                vldmia r3!,{q4,q5,q6}
+                vldmia r3!,{d14}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vadd.f32 d6,d6,d14
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{d6}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 d24,d24,d6
+                
+                b .Lf2end
+.Lf2lt14:
+                // 13 elems
+                vldmia r2!,{q0,q1,q2}
+                vldmia r2!,{s12}
+                vldmia r3!,{q4,q5,q6}
+                vldmia r3!,{s13}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                fadds s12,s12,s13
+                vstmia r5!,{q0,q1,q2}
+                vstmia r5!,{s12}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                vmax.f32 d24,d24,d6
+                
+                b .Lf2end
+.Lf2eq12:
+                // 12 elems
+                vldmia r2!,{q0,q1,q2}
+                vldmia r3!,{q4,q5,q6}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 q2,q2,q6
+                vstmia r5!,{q0,q1,q2}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                
+                b .Lf2end
+.Lf2lt12:
+                cmp r4,#10
+                blo .Lf2lt10
+                beq .Lf2eq10
+                // 11 elems
+                vldmia r2!,{q0,q1}
+                vldmia r2!,{s8,s9,s10}
+                vldmia r3!,{q4,q5}
+                vldmia r3!,{s24,s25}
+                vldmia r3!,{s11}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 d4,d4,d12
+                vadd.f32 s10,s10,s11
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{s8,s9,s10}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 q12,q12,q2
+                
+                b .Lf2end
+.Lf2eq10:
+                // 10 elems
+                vldmia r2!,{q0,q1}
+                vldmia r2!,{d4}
+                vldmia r3!,{q4,q5}
+                vldmia r3!,{d12}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vadd.f32 d4,d4,d12
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{d4}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 d24,d24,d4
+                
+                b .Lf2end
+.Lf2lt10:
+                // 9 elems
+                vldmia r2!,{q0,q1}
+                vldmia r2!,{s8}
+                vldmia r3!,{q4,q5}
+                vldmia r3!,{s9}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                fadds s8,s8,s9
+                vstmia r5!,{q0,q1}
+                vstmia r5!,{s8}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                vmax.f32 d24,d24,d4
+
+                b .Lf2end
+.Lf2eq8:
+                // 8 elems
+                vldmia r2!,{q0,q1}
+                vldmia r3!,{q4,q5}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 q1,q1,q5
+                vstmia r5!,{q0,q1}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                
+                b .Lf2end
+.Lf2lt8:
+                cmp r4,#4
+                blo .Lf2lt4
+                beq .Lf2eq4
+                
+                cmp r4,#6
+                blo .Lf2lt6
+                beq .Lf2eq6
+                // 7 elems
+                vldmia r2!,{q0}
+                vldmia r2!,{s4,s5,s6}
+                vldmia r3!,{q4}
+                vldmia r3!,{s20,s21}
+                vldmia r3!,{s7}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 d2,d2,d10
+                vadd.f32 s6,s6,s7
+                vstmia r5!,{q0}
+                vstmia r5!,{s4,s5,s6}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 q12,q12,q1
+                
+                b .Lf2end
+.Lf2eq6:
+                // 6 elems
+                vldmia r2!,{q0}
+                vldmia r2!,{d2}
+                vldmia r3!,{q4}
+                vldmia r3!,{d10}
+                
+                vadd.f32 q0,q0,q4
+                vadd.f32 d2,d2,d10
+                vstmia r5!,{q0}
+                vstmia r5!,{d2}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 d24,d24,d2
+                
+                b .Lf2end
+.Lf2lt6:
+                // 5 elems
+                vldmia r2!,{q0}
+                vldmia r2!,{s4}
+                vldmia r3!,{q4}
+                vldmia r3!,{s5}
+                
+                vadd.f32 q0,q0,q4
+                fadds s4,s4,s5
+                vstmia r5!,{q0}
+                vstmia r5!,{s4}
+                
+                vmax.f32 q12,q12,q0
+                vmax.f32 d24,d24,d2
+                
+                b .Lf2end
+.Lf2eq4:
+                // 4 elems
+                vldmia r2!,{q0}
+                vldmia r3!,{q4}
+                
+                vadd.f32 q0,q0,q4
+                vstmia r5!,{q0}
+                
+                vmax.f32 q12,q12,q0
+                
+                b .Lf2end
+.Lf2lt4:
+                cmp r4,#2
+                blo .Lf2lt2
+                beq .Lf2eq2
+                // 3 elems
+                vldmia r2!,{s0,s1,s2}
+                vldmia r3!,{s16,s17}
+                vldmia r3!,{s3}
+                
+                vadd.f32 d0,d0,d8
+                vadd.f32 s2,s2,s3
+                vstmia r5!,{s0,s1,s2}
+                
+                vmax.f32 q12,q12,q0
+                
+                b .Lf2end
+.Lf2eq2:
+                // 2 elems
+                vldmia r2!,{d0}
+                vldmia r3!,{d4}
+                
+                vadd.f32 d0,d0,d4
+                vstmia r5!,{d0}
+                
+                vmax.f32 d24,d24,d0
+                
+                b .Lf2end
+.Lf2lt2:
+                cmp r4,#0
+                beq .Lf2eq0
+                
+                vldmia r2!,{s0}
+                vldmia r3!,{s1}
+                
+                vadd.f32 s0,s0,s1
+                vstmia r5!,{s0}
+                
+                vmax.f32 d24,d24,d0
+.Lf2eq0:
+.Lf2end:
+                vpmax.f32 d24,d24,d25
+                vpmax.f32 d0,d24,d24
+
+                fmrs r0,s0
+                vpop {d8,d9,d10,d11,d12,d13,d14,d15}
+                pop {r4,r5,r6,lr}
+                bx lr
+                
+                
+                .global neon_foldArrayBy2_lge31
+                .type neon_foldArrayBy2_lge31, %function
+neon_foldArrayBy2_lge31:
+                push {r4,r5,r6,lr}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+                
+                ldr r0,[r0,#4] // ss1
+                ldrd r2,[r1,#8] // tmp0
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r6,r2,r4,lsl #2 // end
+                
+                veor.i32 q12,q12,q12
+                sub r6,r6,#4*31
+                cmp r2,r6
+                bhs .Lendf2loop2
+.Lf2loop2:
+                FOLDBY2_CORE
+                FOLDBY2_CORE
+                
+                cmp r2,r6
+                blo .Lf2loop2
+.Lendf2loop2:
+                add r6,r6,#4*16
+                cmp r2,r6
+                bhs .Lendf2loop1
+.Lf2loop3:
+                FOLDBY2_CORE
+
+                cmp r2,r6
+                blo .Lf2loop3
+.Lendf2loop3:
+                b .Lendf2loop1
+                
+.Lfoldby2sel:
+.rept 31
+                .word neon_foldArrayBy2_ll31
+.endr
+                .word neon_foldArrayBy2_lge31
+                
+                .align 2
+.Lname:
+                .string "opt NEON"
+                
+                .align 2
+                .global neonFoldMain
+neonFoldMain:
+                .word .Lfoldby3sel
+                .word .Lfoldby4sel
+                .word .Lfoldby5sel
+                .word .Lfoldby2sel
+                .word .Lfoldby2sel
+                .word .Lname
+                /*
+
+
+ * _Z21neon_GetPowerSpectrumPA2_fPfi.S
+ * Author: Mateusz Szpakowski
+ */
+ 
+                .arch armv7-a
+                .fpu neon
+                .eabi_attribute 20, 1
+                .eabi_attribute 21, 1
+                .eabi_attribute 23, 3
+                .eabi_attribute 24, 1
+                .eabi_attribute 25, 1
+                .eabi_attribute 26, 2
+                .eabi_attribute 30, 2
+                .eabi_attribute 18, 4
+                .text
+                .align  2
+                .global _Z21neon_GetPowerSpectrumPA2_fPfi
+                .type   _Z21neon_GetPowerSpectrumPA2_fPfi, %function
+_Z21neon_GetPowerSpectrumPA2_fPfi:
+                push {r4,r5}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+                ldr r3,.LGOTa
+.LPICa:
+                add r3,pc,r3
+                ldr r4,.LGOTa+4
+                ldr r4,[r3,r4]
+                add r5,r2,r2,lsl #1
+                fldd d0,[r4,#32]
+                fmsr s4,r5
+                fuitod d1,s4
+                faddd d0,d0,d1
+                fstd d0,[r4,#32]
+                
+                cmp r2,#4096
+                blo .Lsecondversion
+                
+                add r2,r0,r2, lsl #3
+                sub r2,r2,#31*8
+                /* r0 - freqData
+                 * r1 - PowerSpectrum
+                 * r2 - end of freqData
+                 */
+                cmp r0,r2
+                bhs .Lendmainloopa
+.Lmainloopa:
+                pld [r0,#128]
+                vldmia r0!,{q0,q1,q2,q3,q4,q5,q6,q7}
+                vmul.f32 q0,q0,q0
+                vmul.f32 q1,q1,q1
+                vmul.f32 q2,q2,q2
+                vmul.f32 q3,q3,q3
+                vmul.f32 q4,q4,q4
+                vmul.f32 q5,q5,q5
+                vmul.f32 q6,q6,q6
+                vmul.f32 q7,q7,q7
+                vpadd.f32 d16,d0,d1
+                vpadd.f32 d17,d2,d3
+                vpadd.f32 d18,d4,d5
+                vpadd.f32 d19,d6,d7
+                vpadd.f32 d20,d8,d9
+                vpadd.f32 d21,d10,d11
+                vpadd.f32 d22,d12,d13
+                vpadd.f32 d23,d14,d15
+                
+                pld [r0,#128]
+                vldmia r0!,{q0,q1,q2,q3,q4,q5,q6,q7}
+                vstmia r1!,{q8,q9,q10,q11}
+                vmul.f32 q0,q0,q0
+                vmul.f32 q1,q1,q1
+                vmul.f32 q2,q2,q2
+                vmul.f32 q3,q3,q3
+                vmul.f32 q4,q4,q4
+                vmul.f32 q5,q5,q5
+                vmul.f32 q6,q6,q6
+                vmul.f32 q7,q7,q7
+                vpadd.f32 d16,d0,d1
+                vpadd.f32 d17,d2,d3
+                vpadd.f32 d18,d4,d5
+                vpadd.f32 d19,d6,d7
+                vpadd.f32 d20,d8,d9
+                vpadd.f32 d21,d10,d11
+                vpadd.f32 d22,d12,d13
+                vpadd.f32 d23,d14,d15
+                vstmia r1!,{q8,q9,q10,q11}
+                
+                cmp r0,r2
+                blo .Lmainloopa
+
+.Lendmainloopa:
+                add r2,r2,#8*24
+                bhs .Lendsmallloopa
+.Lsmallloopa:
+                vldmia r0!,{q0,q1,q2,q3}
+                vmul.f32 q0,q0,q0
+                vmul.f32 q1,q1,q1
+                vmul.f32 q2,q2,q2
+                vmul.f32 q3,q3,q3
+                vpadd.f32 d16,d0,d1
+                vpadd.f32 d17,d2,d3
+                vpadd.f32 d18,d4,d5
+                vpadd.f32 d19,d6,d7
+                vstmia r1!,{q8,q9,q10,q11}
+                cmp r0,r2
+                blo .Lsmallloopa
+.Lendsmallloopa:
+                add r2,r2,#8*7
+                cmp r0,r2                
+                beq .Lendmicroloop
+.Lmicroloop:
+                fldmias r0!,{s0,s1}
+                fmuls s2,s0,s0
+                fmacs s2,s1,s1
+                fstmias r1!,{s2}
+                
+                cmp r0,r2
+                blo .Lmicroloop
+.Lendmicroloop:
+                mov r0,#0
+                vpop {d8,d9,d10,d11,d12,d13,d14,d15}
+                pop {r4,r5}
+                bx lr
+                
+
+                /*
+                 * second version
+                 */
+.Lsecondversion:
+                add r2,r0,r2, lsl #3
+                sub r2,r2,#31*8
+                /* r0 - freqData
+                 * r1 - PowerSpectrum
+                 * r2 - end of freqData
+                 */
+                cmp r0,r2
+                bhs .Lendmainloop2
+.Lmainloop2:
+                vldmia r0!,{q0,q1,q2,q3,q4,q5,q6,q7}
+                vldmia r0!,{q8,q9,q10,q11,q12,q13,q14,q15}
+                vuzp.32 q0,q1
+                vuzp.32 q2,q3
+                vuzp.32 q4,q5
+                vuzp.32 q6,q7
+                vuzp.32 q8,q9
+                vuzp.32 q10,q11
+                vuzp.32 q12,q13
+                vuzp.32 q14,q15
+                vmul.f32 q0,q0,q0
+                vmul.f32 q2,q2,q2
+                vmul.f32 q4,q4,q4
+                vmul.f32 q6,q6,q6
+                vmul.f32 q8,q8,q8
+                vmul.f32 q10,q10,q10
+                vmul.f32 q12,q12,q12
+                vmul.f32 q14,q14,q14
+                vmla.f32 q0,q1,q1
+                vmla.f32 q2,q3,q3
+                vmla.f32 q4,q5,q5
+                vmla.f32 q6,q7,q7
+                vmla.f32 q8,q9,q9
+                vmla.f32 q10,q11,q11
+                vmla.f32 q12,q13,q13
+                vmla.f32 q14,q15,q15
+                vstmia r1!,{q0}
+                vstmia r1!,{q2}
+                vstmia r1!,{q4}
+                vstmia r1!,{q6}
+                vstmia r1!,{q8}
+                vstmia r1!,{q10}
+                vstmia r1!,{q12}
+                vstmia r1!,{q14}
+                
+                cmp r0,r2
+                blo .Lmainloop2
+
+.Lendmainloop2:
+                add r2,r2,#8*24
+                bhs .Lendsmallloop2
+.Lsmallloop2:
+                vldmia r0!,{q0,q1,q2,q3}
+                vmul.f32 q0,q0,q0
+                vmul.f32 q1,q1,q1
+                vmul.f32 q2,q2,q2
+                vmul.f32 q3,q3,q3
+                vpadd.f32 d16,d0,d1
+                vpadd.f32 d17,d2,d3
+                vpadd.f32 d18,d4,d5
+                vpadd.f32 d19,d6,d7
+                vstmia r1!,{q8,q9,q10,q11}
+                cmp r0,r2
+                blo .Lsmallloop2
+.Lendsmallloop2:
+                add r2,r2,#8*7
+                cmp r0,r2                
+                beq .Lendmicroloop
+.Lmicroloop2:
+                fldmias r0!,{s0,s1}
+                fmuls s2,s0,s0
+                fmacs s2,s1,s1
+                fstmias r1!,{s2}
+                
+                cmp r0,r2
+                blo .Lmicroloop2
+                b .Lendmicroloop
+                
+                .align  2
+.LGOTa:
+                .word _GLOBAL_OFFSET_TABLE_-(.LPICa+8)
+                .word analysis_state(GOT)
+
+#endif // __arm__
diff --git a/client/vector/analyzeFuncs_vector.cpp b/client/vector/analyzeFuncs_vector.cpp
index 811f6b9..a80892b 100644
--- a/client/vector/analyzeFuncs_vector.cpp
+++ b/client/vector/analyzeFuncs_vector.cpp
@@ -127,6 +127,9 @@
 #define BA_FMA     0x00004000
 #define BA_FMA4    0x00008000
 #define BA_ALTVC   0x00100000
+#define BA_NEON    0x00200000
+#define BA_VFP     0x00400000
+
 
 uint32_t CPUCaps = BA_ANY;
 
@@ -239,7 +242,7 @@ void SetCapabilities(void) {
 #endif
 
 #elif defined(__i386__) || defined (__x86_64__)
-  /* we're goping to rely on signal handling to keep us out of trouble */
+  /* we're hoping to rely on signal handling to keep us out of trouble */
   CPUCaps |= (BA_MMX | BA_SSE | BA_SSE2 | BA_SSE3 | BA_3Dnow | BA_3DnowP | BA_MMX_P );
 #if defined(USE_AVX)                    
   CPUCaps |= BA_AVX;
@@ -248,25 +251,30 @@ void SetCapabilities(void) {
 #elif defined(USE_ALTIVEC)
   CPUCaps |= BA_ALTVC;
 
+#elif defined(__arm__)
+
+#if defined(HAVE_CPU_FEATURES_H) && defined(ANDROID)
+  uint64_t features=android_getCpuFeatures();
+  if (features & ANDROID_CPU_ARM_FEATURE_ARMv7) CPUCaps |= BA_VFP;
+  if (features & ANDROID_CPU_ARM_FEATURE_NEON)  CPUCaps |= BA_NEON;
+#else
+  CPUCaps |= BA_VFP;
+  CPUCaps |= BA_NEON;
 #endif
-}
 
+#endif
+}
 
-struct BLStb {
-  BaseLineSmooth_func func;
-  int ba;
-  const char * const nom;
-};
+/***************************************************************************/
 
 BLStb BaseLineSmoothFuncs[]={
       v_BaseLineSmooth, BA_ANY, "v_BaseLineSmooth",
 };
 
-struct GPStb {
-  GetPowerSpectrum_func func;
-  int ba;
-  const char * const nom;
-};
+const int num_BLS=(sizeof(BaseLineSmoothFuncs)/sizeof(BLStb));
+bool found_baseline_smooth=false;
+
+/***************************************************************************/
 
 GPStb GetPowerSpectrumFuncs[]={
     v_GetPowerSpectrum, BA_ANY, "v_GetPowerSpectrum",
@@ -287,14 +295,17 @@ GPStb GetPowerSpectrumFuncs[]={
      v_avxGetPowerSpectrum, BA_AVX, "v_avxGetPowerSpectrum", 
 #  endif
 #endif
-
+#ifdef __arm__
+     vfp_GetPowerSpectrum, BA_VFP, "vfp_GetPowerSpectrum",
+     neon_GetPowerSpectrum, BA_NEON, "neon_GetPowerSpectrum",
+#endif
 };
 
-struct CDtb {
-  ChirpData_func func;
-  int ba;
-  const char * const nom;
-};
+const int num_GPS=(sizeof(GetPowerSpectrumFuncs)/sizeof(GPStb));
+bool found_get_power_spectrum=false;
+
+/***************************************************************************/
+
 CDtb ChirpDataFuncs[]={
     v_ChirpData, BA_ANY, "v_ChirpData",
     fpu_ChirpData, BA_ANY, "fpu_ChirpData",
@@ -327,14 +338,16 @@ CDtb ChirpDataFuncs[]={
      avx_ChirpData_d, BA_AVX, "avx_ChirpData_d", 
 #  endif
 #endif
+#ifdef __arm__
+     vfp_ChirpData, BA_VFP, "vfp_ChirpData",
+     neon_ChirpData, BA_NEON, "neon_ChirpData",
+#endif
 };
 
+const int num_CD=(sizeof(ChirpDataFuncs)/sizeof(CDtb));
+bool found_chirp_data=false;
 
-struct TPtb {
-  Transpose_func func;
-  int ba;
-  const char * const nom;
-};
+/***************************************************************************/
 
 TPtb TransposeFuncs[]={
     v_Transpose, BA_ANY, "v_Transpose", 
@@ -370,12 +383,19 @@ TPtb TransposeFuncs[]={
      v_avxTranspose8x8ntw_b, BA_AVX, "v_avxTranspose8x8ntw_b", 
 #  endif
 #endif
+#ifdef __arm__
+    v_pfTranspose2, BA_VFP, "v_pfTranspose2",      
+    v_pfTranspose4, BA_VFP, "v_pfTranspose4",      
+    v_pfTranspose8, BA_VFP, "v_pfTranspose8",      
+    v_vfpTranspose2, BA_VFP, "v_vfpTranspose2",
+#endif
 };
 
-struct FolSub {
-  FoldSet *fsp;
-  int      ba;
-};
+const int num_TP=(sizeof(TransposeFuncs)/sizeof(TPtb));
+bool found_transpose=false;
+
+/***************************************************************************/
+
 
 FolSub FoldSubs[] = {
   &swifold,      BA_ANY,
@@ -394,8 +414,14 @@ FolSub FoldSubs[] = {
   &AVXfold_a,    BA_AVX,
   &AVXfold_c,    BA_AVX,
 #endif
+#ifdef __arm__
+  &vfpFoldMain,  BA_VFP,
+  &neonFoldMain, BA_NEON,
+#endif
 };
 
+const int num_FS=(sizeof(FoldSubs)/sizeof(FolSub));
+bool found_folding=false;
 
 static bool do_print;
 
@@ -418,8 +444,10 @@ bool TestBoincSignalHandling() {
         __asm__ ("movq %cr4,%rax");
 #elif defined(__i386__) 
         __asm__ ("movl %cr4,%eax");
-#elif defined(__ppc__) || defined(__sparc__)
+#elif defined(__ppc__) || defined(__sparc__) 
         __asm__ (".long %0": : "i" (0xfeedface) );
+#elif defined(__arm__)
+        __asm__ (".word 0xf7f000f0" );
 #endif
 #elif defined(_MSC_VER) && ( defined(_M_IX86) || defined(_M_X64) )
 #ifndef _NDEBUG
@@ -664,7 +692,7 @@ extern void InitTrigArray(int len, double ChirpStep, int InitInd, double SampleR
 
 ChirpData_func ChooseChirpData() {
     bool CacheChirpCalc=((app_init_data.host_info.m_nbytes == 0)  ||
-                             (app_init_data.host_info.m_nbytes >= (double)(64*1024*1024)));
+                             (app_init_data.host_info.m_nbytes >= MIN_TRIGARRAY_MEMORY));
     if (default_functions_flag) {
       if (do_print)
         fprintf(stderr,"%32s (default)\n",ChirpDataFuncs[0].nom);
@@ -1302,15 +1330,110 @@ void ChooseFunctions(BaseLineSmooth_func *baseline_smooth,
         hires_timer durtimer;
         double TestDur=0;
         durtimer.start();
-        *baseline_smooth=ChooseBaseLineSmooth();
+#ifdef ANDROID
+        // low memory android is a special case because android will kill
+        // without warning to free memory.  Testing the functions could trigger
+        // a loop. So we'll choose what fits the processor and return
+        if (app_init_data.host_info.m_nbytes &&
+           (app_init_data.host_info.m_nbytes < MIN_TRANSPOSE_MEMORY)) {
+             *baseline_smooth=v_BaseLineSmooth;
+             found_baseline_smooth=true;
+             if (do_print) fprintf(stderr,"%32s (no other)\n",
+                                   "v_BaseLineSmooth");
+             if (CPUCaps & BA_NEON) {
+                 *get_power_spectrum=neon_GetPowerSpectrum;
+                 found_get_power_spectrum=true;
+                 if (do_print) fprintf(stderr,"%32s (CPU Caps)\n",
+                                       "neon_GetPowerSpectrum");
+                 *chirp_data=neon_ChirpData;
+                 found_chirp_data=true;
+                 if (do_print) fprintf(stderr,"%32s (CPU Caps)\n",
+                                    "neon_ChirpData");
+             } else if (CPUCaps & BA_VFP) {
+                 *get_power_spectrum=vfp_GetPowerSpectrum;
+                 found_get_power_spectrum=true;
+                 if (do_print) fprintf(stderr,"%32s (CPU Caps)\n",
+                                       "vfp_GetPowerSpectrum");
+                 *chirp_data=vfp_ChirpData;
+                 found_chirp_data=true;
+                 if (do_print) fprintf(stderr,"%32s (CPU Caps)\n",
+                                    "vfp_ChirpData");
+             } else {
+                 *get_power_spectrum=v_GetPowerSpectrum;
+                 found_get_power_spectrum=true;
+                 if (do_print) fprintf(stderr,"%32s (default)\n",
+                                       "v_GetPowerSpectrum");
+                 *chirp_data=v_ChirpData;
+                 found_chirp_data=true;
+                 if (do_print) fprintf(stderr,"%32s (default)\n",
+                                       "v_ChirpData");
+             }   
+             *transpose=v_Transpose4;   
+             found_transpose=true;
+             if (do_print) fprintf(stderr,"%32s (default)\n",
+                                   "v_Transpose4");
+             if (CPUCaps & BA_NEON) {
+                 CopyFoldSet(&Foldmain, &neonFoldMain);
+                 found_folding=true;
+                 if (do_print) fprintf(stderr,"%32s (CPU Caps)\n",
+                                       "neonFoldMain");
+             } else if (CPUCaps & BA_VFP) {
+                 CopyFoldSet(&Foldmain, &vfpFoldMain);
+                 found_folding=true;
+                 if (do_print) fprintf(stderr,"%32s (CPU Caps)\n",
+                                       "vfpFoldMain");
+             } else {
+                 CopyFoldSet(&Foldmain, &swifold);
+                 found_folding=true;
+                 if (do_print) fprintf(stderr,"%32s (default)\n",
+                                       "swifold");
+             }
+             TestDur+=durtimer.stop();
+             if (verbose)
+                 fprintf(stderr,"%32s %8.2f seconds\n\n","Test duration",TestDur);
+             if (do_print) {
+                 fflush(stderr);
+             }
+             return;
+        }
+#endif
+              
+        if (!found_baseline_smooth) {
+            *baseline_smooth=ChooseBaseLineSmooth();
+        } else {
+            if (do_print) fprintf(stderr,"BaseLineSmooth retrieved from state file\n");
+            *baseline_smooth=*BaseLineSmooth;
+        }
         fflush(stderr);
-        *get_power_spectrum=ChooseGetPowerSpectrum();
+        if (!found_get_power_spectrum) {
+            *get_power_spectrum=ChooseGetPowerSpectrum();
+        } else {
+            if (do_print) fprintf(stderr,"GetPowerSpectrum retrieved from state file\n");
+            *get_power_spectrum=*GetPowerSpectrum;
+        }
         fflush(stderr);
-        *chirp_data=ChooseChirpData();
+        if (!found_chirp_data) {
+            *chirp_data=ChooseChirpData();
+        } else {
+            if (do_print) fprintf(stderr,"ChirpData retrieved from state file\n");
+            *chirp_data=*ChirpData;
+        }
         fflush(stderr);
-        *transpose=ChooseTranspose();
+        if (!found_transpose) {
+            *transpose=ChooseTranspose();
+        } else {
+            if (do_print) fprintf(stderr,"Transpose retrieved from state file\n");
+            *transpose=*Transpose;
+        }
         fflush(stderr);
-        ChooseFoldSubs(ChirpFftPairs, num_cfft, nsamples);
+        // ChooseFoldSubs is inconsistent in that it directly sets a global
+        // variable.  Maybe we should make it consistent with the others
+        // at some point. --EK
+        if (!found_folding) {
+            ChooseFoldSubs(ChirpFftPairs, num_cfft, nsamples);
+        } else {
+            if (do_print) fprintf(stderr,"Folding Subs retrieved from state file\n");
+        }
         fflush(stderr);
         TestDur+=durtimer.stop();
         if (verbose)
@@ -1318,7 +1441,7 @@ void ChooseFunctions(BaseLineSmooth_func *baseline_smooth,
     }
 
     if (do_print) {
-      fflush(stderr);
+        fflush(stderr);
     }
 
 }
diff --git a/client/vector/analyzeFuncs_vector.h b/client/vector/analyzeFuncs_vector.h
index d2e482e..bc41229 100644
--- a/client/vector/analyzeFuncs_vector.h
+++ b/client/vector/analyzeFuncs_vector.h
@@ -29,8 +29,12 @@
 #ifndef ANALYZEFUNCS_VECTOR_H
 #define ANALYZEFUNCS_VECTOR_H
 
+#ifdef HAVE_CPU_FEATURES_H
+#include <cpu-features.h>
+#endif
+
 #include "chirpfft.h"
-#define FUNCTION_FILE_NAME "functions.sah"
+#include "pulsefind.h"
 
 #define TWO_TO_52 4.503599627370496e15
 // 2^52+2^51 recommended by AMD optimization manual, scaled to 2^64+2^63 for X87
@@ -51,6 +55,60 @@ typedef int (*GetPowerSpectrum_func)(sah_complex *, float*, int);
 typedef int  (*ChirpData_func)(sah_complex *, sah_complex *, int, double, int, double); 
 typedef int (*Transpose_func)(int, int , float *, float *);
 
+struct BLStb {
+  BaseLineSmooth_func func;
+  int ba;
+  const char * const nom;
+};
+
+extern const int num_BLS;
+extern bool found_baseline_smooth;
+
+extern BLStb BaseLineSmoothFuncs[];
+
+struct GPStb {
+  GetPowerSpectrum_func func;
+  int ba;
+  const char * const nom;
+};
+
+extern const int num_GPS;
+extern bool found_get_power_spectrum;
+
+extern GPStb GetPowerSpectrumFuncs[];
+
+struct CDtb {
+  ChirpData_func func;
+  int ba;
+  const char * const nom;
+};
+
+extern const int num_CD;
+extern bool found_chirp_data;
+
+extern CDtb ChirpDataFuncs[];
+
+struct TPtb {
+  Transpose_func func;
+  int ba;
+  const char * const nom;
+};
+
+extern const int num_TP;
+extern bool found_transpose;
+
+extern TPtb TransposeFuncs[];
+
+struct FolSub {
+  FoldSet *fsp;
+  int      ba;
+};
+
+extern FolSub FoldSubs[];
+
+extern const int num_FS;
+extern bool found_folding;
+
 extern void ChooseFunctions(
     BaseLineSmooth_func *, 
     GetPowerSpectrum_func *,
@@ -177,10 +235,12 @@ extern int sse3_ChirpData_ak8(
 #endif
 
 extern int v_vTranspose(int i, int j, float *in, float *out);
-#if defined(__i386__) || defined(__x86_64__) || defined(USE_SSE)
+#if defined(__i386__) || defined(__x86_64__) || defined(USE_SSE) || defined(__arm__)
 extern int v_pfTranspose2(int i, int j, float *in, float *out);
 extern int v_pfTranspose4(int i, int j, float *in, float *out);
 extern int v_pfTranspose8(int i, int j, float *in, float *out);
+#endif
+#if defined(__i386__) || defined(__x86_64__) || defined(USE_SSE) 
 extern int v_vTranspose4(int i, int j, float *in, float *out);
 extern int v_vTranspose4np(int i, int j, float *in, float *out);
 extern int v_vTranspose4ntw(int i, int j, float *in, float *out);
@@ -188,6 +248,9 @@ extern int v_vTranspose4x8ntw(int i, int j, float *in, float *out);
 extern int v_vTranspose4x16ntw(int i, int j, float *in, float *out);
 extern int v_vpfTranspose8x4ntw(int i, int j, float *in, float *out);
 #endif
+#if defined(__arm__) 
+extern int v_vfpTranspose2(int i, int j, float *in, float *out);
+#endif
 
 
 #if defined(__i386__) || defined(__x86_64__) || defined(USE_SSE)
@@ -294,4 +357,35 @@ extern int v_avxGetPowerSpectrum(
 );
 #endif
 
+#if defined(__arm__)
+extern int neon_GetPowerSpectrum(
+    sah_complex * cx_FreqData,
+    float * fp_PowerSpectrum,
+    int ul_NumDataPoints
+  );
+extern int vfp_GetPowerSpectrum(
+    sah_complex * cx_FreqData,
+    float * fp_PowerSpectrum,
+    int ul_NumDataPoints
+  );
+
+extern int vfp_ChirpData (
+  sah_complex * cx_DataArray,
+  sah_complex * cx_ChirpDataArray,
+  int ChirpRateInd,
+  double ChirpRate,
+  int  ul_NumDataPoints,
+  double sample_rate
+);
+extern int neon_ChirpData (
+  sah_complex * cx_DataArray,
+  sah_complex * cx_ChirpDataArray,
+  int ChirpRateInd,
+  double ChirpRate,
+  int  ul_NumDataPoints,
+  double sample_rate
+);
+
+#endif
+
 #endif
diff --git a/client/vector/analyzeFuncs_vfp.S b/client/vector/analyzeFuncs_vfp.S
new file mode 100644
index 0000000..739322b
--- /dev/null
+++ b/client/vector/analyzeFuncs_vfp.S
@@ -0,0 +1,2243 @@
+// Copyright (c) 1999-2011 Regents of the University of California
+//
+// FFTW: Copyright (c) 2003,2006 Matteo Frigo
+//       Copyright (c) 2003,2006 Massachusets Institute of Technology
+//
+// fft8g.[cpp,h]: Copyright (c) 1995-2001 Takya Ooura
+//
+// ASMLIB: Copyright (c) 2004 Agner Fog
+
+// This program is free software; you can redistribute it and/or modify it 
+// under the terms of the GNU General Public License as published by the 
+// Free Software Foundation; either version 2, or (at your option) any later
+// version.
+
+// This program is distributed in the hope that it will be useful, but WITHOUT
+// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
+// more details.
+
+// You should have received a copy of the GNU General Public License along
+// with this program; see the file COPYING.  If not, write to the Free Software
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+// In addition, as a special exception, the Regents of the University of
+// California give permission to link the code of this program with libraries
+// that provide specific optimized fast Fourier transform (FFT) functions
+// as an alternative to FFTW and distribute a linked executable and 
+// source code.  You must obey the GNU General Public License in all 
+// respects for all of the code used other than the FFT library itself.  
+// Any modification required to support these libraries must be distributed 
+// under the terms of this license.  If you modify this program, you may extend 
+// this exception to your version of the program, but you are not obligated to 
+// do so. If you do not wish to do so, delete this exception statement from 
+// your version.  Please be aware that FFTW and ASMLIB are not covered by 
+// this exception, therefore you may not use FFTW and ASMLIB in any derivative 
+// work so modified without permission of the authors of those packages.
+
+#ifdef __arm__
+/*
+ * vfp_ChirpData.S
+ * Author: Mateusz Szpakowski
+ */
+ 
+                .arch armv6
+                .fpu vfp
+                .eabi_attribute 20, 1
+                .eabi_attribute 21, 1
+                .eabi_attribute 23, 3
+                .eabi_attribute 24, 1
+                .eabi_attribute 25, 1
+                .eabi_attribute 26, 2
+                .eabi_attribute 30, 2
+                .eabi_attribute 18, 4
+                .text
+                .align  2
+.Lhalfd:
+                .double 0.5
+.LroundVal:
+                .double 4503599627370496.0
+.Linc8d:
+                .double 0,1,2,3,4,5,6,7
+.Lsincosapprox:
+                .float 1.5707963268,-0.6466386396,0.0679105987,-0.0011573807   // sine
+                .float 1.0,-1.2341299769,0.2465220241,-0.0123926179     // cosine
+                
+                .align  2
+                .global _Z13vfp_ChirpDataPA2_fS0_idid
+                .type   _Z13vfp_ChirpDataPA2_fS0_idid, %function
+_Z13vfp_ChirpDataPA2_fS0_idid:
+                push {r4,r5,r6,r7,r8,lr}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+#define stargidx (24+64)
+                /* r0 - input data
+                 * r1 - output data
+                 * r2 - chirprateind
+                 * sp[0-1] - chirp_rate
+                 * sp[2] - numDataPoints
+                 * sp[4-5] - sample_rate
+                 */
+                tst r2,r2
+                bne .Lrealfunc
+                mov r3,r0   // swap addresses
+                mov r0,r1
+                mov r1,r3
+                ldr r2,[sp,#stargidx+8]     // numDataPoints
+                lsl r2,r2,#3
+                bl memcpy(PLT)
+                b .Lendoffunc
+                /*
+                 * real functions
+                 */
+.Lrealfunc:
+                ldr r4,.LGOT1
+.LPIC1:
+                add r4,pc,r4
+                ldr r5,.LGOT1+4
+                ldr r5,[r4,r5]
+                
+                ldr r3,[sp,#stargidx+8]     // numDataPoints
+                
+                add r6,r3,r3,lsl #1
+                lsl r6,r6,#2
+                fldd d0,[r5,#32]
+                fmsr s4,r6
+                fuitod d1,s4
+                faddd d0,d0,d1
+                fstd d0,[r5,#32]
+                
+                add r3,r0,r3,lsl #3
+                sub r3,r3,#8*7
+                
+                fldd d11,.Lhalfd
+                fldd d9,[sp,#stargidx]        // chirp_rate
+                fldd d10,[sp,#stargidx+16]   // sample_rate
+                fmuld d10,d10,d10
+                fmuld d9,d9,d11
+                fdivd d9,d9,d10
+                
+                fldd d10,.LroundVal
+                fsubd d11,d11,d11   // zero
+                fcmpd d9,d11
+                fmstat
+                fnegdmi d10,d10     // negate is negative srate
+                
+                sub sp,sp,#24+32+8
+                add r7,sp,#24
+                fstmiad sp,{d9,d10}
+                
+                mov r4,#0       // i
+                
+                adr r5,.Linc8d
+                adr r6,.Lsincosapprox
+                adr r8,.Lsincosapprox+4*4
+                
+                cmp r0,r3
+                bhs .Lendmainloop
+.Lmainloop:
+                fmsr s24,r4
+                fuitod d8,s24
+                fldmiad r5,{d0,d1,d2,d3,d4,d5,d6,d7}
+                fldmiad sp,{d9,d10}
+                faddd d0,d0,d8
+                faddd d1,d1,d8
+                faddd d2,d2,d8
+                faddd d3,d3,d8
+                faddd d4,d4,d8
+                faddd d5,d5,d8
+                faddd d6,d6,d8
+                faddd d7,d7,d8
+                // square of i
+                fmuld d0,d0,d0
+                fmuld d1,d1,d1
+                fmuld d2,d2,d2
+                fmuld d3,d3,d3
+                fmuld d4,d4,d4
+                fmuld d5,d5,d5
+                fmuld d6,d6,d6
+                fmuld d7,d7,d7
+                // multiply by srate
+                fmuld d0,d0,d9
+                fmuld d1,d1,d9
+                fmuld d2,d2,d9
+                fmuld d3,d3,d9
+                fmuld d4,d4,d9
+                fmuld d5,d5,d9
+                fmuld d6,d6,d9
+                fmuld d7,d7,d9
+                
+                // rounding to -0.5/+0.5
+                faddd d12,d0,d10
+                faddd d13,d1,d10
+                faddd d14,d2,d10
+                faddd d15,d3,d10
+                fsubd d12,d12,d10
+                fsubd d13,d13,d10
+                fsubd d14,d14,d10
+                fsubd d15,d15,d10
+                fsubd d0,d0,d12
+                fsubd d1,d1,d13
+                fsubd d2,d2,d14
+                fsubd d3,d3,d15
+                // second half of xxxx
+                faddd d12,d4,d10
+                faddd d13,d5,d10
+                faddd d14,d6,d10
+                faddd d15,d7,d10
+                fsubd d12,d12,d10
+                fsubd d13,d13,d10
+                fsubd d14,d14,d10
+                fsubd d15,d15,d10
+                fsubd d4,d4,d12
+                fsubd d5,d5,d13
+                fsubd d6,d6,d14
+                fsubd d7,d7,d15
+                // to single precision
+                fcvtsd s24,d0
+                fcvtsd s25,d1
+                fcvtsd s26,d2
+                fcvtsd s27,d3
+                fcvtsd s28,d4
+                fcvtsd s29,d5
+                fcvtsd s30,d6
+                fcvtsd s31,d7
+                
+                fldmias r6,{s16,s17,s18,s19}
+                // square of y
+                fmuls s0,s24,s24
+                fmuls s1,s25,s25
+                fmuls s2,s26,s26
+                fmuls s3,s27,s27
+                fmuls s4,s28,s28
+                fmuls s5,s29,s29
+                fmuls s6,s30,s30
+                fmuls s7,s31,s31
+                // sine
+                fmuls s8,s0,s19
+                fmuls s9,s1,s19
+                fmuls s10,s2,s19
+                fmuls s11,s3,s19
+                fmuls s12,s4,s19
+                fmuls s13,s5,s19
+                fmuls s14,s6,s19
+                fmuls s15,s7,s19
+                fadds s8,s8,s18
+                fadds s9,s9,s18
+                fadds s10,s10,s18
+                fadds s11,s11,s18
+                fadds s12,s12,s18
+                fadds s13,s13,s18
+                fadds s14,s14,s18
+                fadds s15,s15,s18
+                fmuls s8,s8,s0
+                fmuls s9,s9,s1
+                fmuls s10,s10,s2
+                fmuls s11,s11,s3
+                fmuls s12,s12,s4
+                fmuls s13,s13,s5
+                fmuls s14,s14,s6
+                fmuls s15,s15,s7
+                fadds s8,s8,s17
+                fadds s9,s9,s17
+                fadds s10,s10,s17
+                fadds s11,s11,s17
+                fadds s12,s12,s17
+                fadds s13,s13,s17
+                fadds s14,s14,s17
+                fadds s15,s15,s17
+                fmuls s8,s8,s0
+                fmuls s9,s9,s1
+                fmuls s10,s10,s2
+                fmuls s11,s11,s3
+                fmuls s12,s12,s4
+                fmuls s13,s13,s5
+                fmuls s14,s14,s6
+                fmuls s15,s15,s7
+                fadds s8,s8,s16
+                fadds s9,s9,s16
+                fadds s10,s10,s16
+                fadds s11,s11,s16
+                fadds s12,s12,s16
+                fadds s13,s13,s16
+                fadds s14,s14,s16
+                fadds s15,s15,s16
+                fmuls s8,s8,s24
+                fmuls s9,s9,s25
+                fmuls s10,s10,s26
+                fmuls s11,s11,s27
+                fmuls s12,s12,s28
+                fmuls s13,s13,s29
+                fmuls s14,s14,s30
+                fmuls s15,s15,s31
+                fldmias r8,{s24,s25,s26,s27}
+                // cosine
+                fmuls s16,s0,s27
+                fmuls s17,s1,s27
+                fmuls s18,s2,s27
+                fmuls s19,s3,s27
+                fmuls s20,s4,s27
+                fmuls s21,s5,s27
+                fmuls s22,s6,s27
+                fmuls s23,s7,s27
+                fadds s16,s16,s26
+                fadds s17,s17,s26
+                fadds s18,s18,s26
+                fadds s19,s19,s26
+                fadds s20,s20,s26
+                fadds s21,s21,s26
+                fadds s22,s22,s26
+                fadds s23,s23,s26
+                fmuls s16,s16,s0
+                fmuls s17,s17,s1
+                fmuls s18,s18,s2
+                fmuls s19,s19,s3
+                fmuls s20,s20,s4
+                fmuls s21,s21,s5
+                fmuls s22,s22,s6
+                fmuls s23,s23,s7
+                fadds s16,s16,s25
+                fadds s17,s17,s25
+                fadds s18,s18,s25
+                fadds s19,s19,s25
+                fadds s20,s20,s25
+                fadds s21,s21,s25
+                fadds s22,s22,s25
+                fadds s23,s23,s25
+                fmuls s16,s16,s0
+                fmuls s17,s17,s1
+                fmuls s18,s18,s2
+                fmuls s19,s19,s3
+                fmuls s20,s20,s4
+                fmuls s21,s21,s5
+                fmuls s22,s22,s6
+                fmuls s23,s23,s7
+                fadds s16,s16,s24
+                fadds s17,s17,s24
+                fadds s18,s18,s24
+                fadds s19,s19,s24
+                fadds s20,s20,s24
+                fadds s21,s21,s24
+                fadds s22,s22,s24
+                fadds s23,s23,s24
+                // load sine
+                // doubling cosine/sine
+                fmuls s0,s8,s16 // c*s
+                fmuls s1,s9,s17
+                fmuls s2,s10,s18
+                fmuls s3,s11,s19
+                fmuls s4,s12,s20
+                fmuls s5,s13,s21
+                fmuls s6,s14,s22
+                fmuls s7,s15,s23
+                fmuls s16,s16,s16 // c*c
+                fmuls s17,s17,s17
+                fmuls s18,s18,s18
+                fmuls s19,s19,s19
+                fmuls s20,s20,s20
+                fmuls s21,s21,s21
+                fmuls s22,s22,s22
+                fmuls s23,s23,s23
+                fnmacs s16,s8,s8  // c*c-s*s = x
+                fnmacs s17,s9,s9
+                fnmacs s18,s10,s10
+                fnmacs s19,s11,s11
+                fnmacs s20,s12,s12
+                fnmacs s21,s13,s13
+                fnmacs s22,s14,s14
+                fnmacs s23,s15,s15
+                fadds s0,s0,s0  // 2*s*c = y
+                fadds s1,s1,s1
+                fadds s2,s2,s2
+                fadds s3,s3,s3
+                fadds s4,s4,s4
+                fadds s5,s5,s5
+                fadds s6,s6,s6
+                fadds s7,s7,s7
+                fmuls s8,s0,s16 // cd1 = x*y
+                fmuls s9,s1,s17
+                fmuls s10,s2,s18
+                fmuls s11,s3,s19
+                fmuls s12,s4,s20
+                fmuls s13,s5,s21
+                fmuls s14,s6,s22
+                fmuls s15,s7,s23
+                fmuls s0,s0,s0 // cd3 = y*y
+                fmuls s1,s1,s1
+                fmuls s2,s2,s2
+                fmuls s3,s3,s3
+                fmuls s4,s4,s4
+                fmuls s5,s5,s5
+                fmuls s6,s6,s6
+                fmuls s7,s7,s7
+                fmuls s24,s16,s16 // cd2 = x*x
+                fmuls s25,s17,s17
+                fmuls s26,s18,s18
+                fmuls s27,s19,s19
+                fmuls s28,s20,s20
+                fmuls s29,s21,s21
+                fmuls s30,s22,s22
+                fmuls s31,s23,s23
+                fadds s24,s24,s0  // norm = x*x+y*y
+                fadds s25,s25,s1
+                fadds s26,s26,s2
+                fadds s27,s27,s3
+                fadds s28,s28,s4
+                fadds s29,s29,s5
+                fadds s30,s30,s6
+                fadds s31,s31,s7
+                fmscs s0,s16,s16   // c = x*x-y*y
+                fmscs s1,s17,s17
+                fmscs s2,s18,s18
+                fmscs s3,s19,s19
+                fmscs s4,s20,s20
+                fmscs s5,s21,s21
+                fmscs s6,s22,s22
+                fmscs s7,s23,s23
+                fadds s16,s8,s8     // s = 2*x*y
+                fadds s17,s9,s9
+                fadds s18,s10,s10
+                fadds s19,s11,s11
+                fadds s20,s12,s12
+                fadds s21,s13,s13
+                fadds s22,s14,s14
+                fadds s23,s15,s15
+                fsts s7,[sp,#24+64]
+                flds s7,.Ltwos
+                fstmias r7,{s16,s17,s18,s19,s20,s21,s22,s23}
+                // reciprocal of magnitude
+                // iter 1: invmag = 2.0-mag
+                fsubs s8,s7,s24
+                fsubs s9,s7,s25
+                fsubs s10,s7,s26
+                fsubs s11,s7,s27
+                fsubs s12,s7,s28
+                fsubs s13,s7,s29
+                fsubs s14,s7,s30
+                fsubs s15,s7,s31
+                // iter 2: invmag = invmag*(2.0-mag*invmag)
+                fmuls s16,s8,s24
+                fmuls s17,s9,s25
+                fmuls s18,s10,s26
+                fmuls s19,s11,s27
+                fmuls s20,s12,s28
+                fmuls s21,s13,s29
+                fmuls s22,s14,s30
+                fmuls s23,s15,s31
+                fsubs s16,s7,s16
+                fsubs s17,s7,s17
+                fsubs s18,s7,s18
+                fsubs s19,s7,s19
+                fsubs s20,s7,s20
+                fsubs s21,s7,s21
+                fsubs s22,s7,s22
+                fsubs s23,s7,s23
+                fmuls s8,s16,s8
+                fmuls s9,s17,s9
+                fmuls s10,s18,s10
+                fmuls s11,s19,s11
+                fmuls s12,s20,s12
+                fmuls s13,s21,s13
+                fmuls s14,s22,s14
+                fmuls s15,s23,s15
+                // iter 3: invmag = invmag*(2.0-mag*invmag)
+                fmuls s16,s8,s24
+                fmuls s17,s9,s25
+                fmuls s18,s10,s26
+                fmuls s19,s11,s27
+                fmuls s20,s12,s28
+                fmuls s21,s13,s29
+                fmuls s22,s14,s30
+                fmuls s23,s15,s31
+                fsubs s16,s7,s16
+                fsubs s17,s7,s17
+                fsubs s18,s7,s18
+                fsubs s19,s7,s19
+                fsubs s20,s7,s20
+                fsubs s21,s7,s21
+                fsubs s22,s7,s22
+                fsubs s23,s7,s23
+                fmuls s8,s16,s8
+                fmuls s9,s17,s9
+                fmuls s10,s18,s10
+                fmuls s11,s19,s11
+                fmuls s12,s20,s12
+                fmuls s13,s21,s13
+                fmuls s14,s22,s14
+                fmuls s15,s23,s15
+                // restore sine values
+                fldmias r7,{s16,s17,s18,s19,s20,s21,s22,s23}
+                // correct cosine/sine
+                flds s7,[sp,#24+64]
+                fmuls s0,s0,s8
+                fmuls s1,s1,s9
+                fmuls s2,s2,s10
+                fmuls s3,s3,s11
+                fmuls s4,s4,s12
+                fmuls s5,s5,s13
+                fmuls s6,s6,s14
+                fmuls s7,s7,s15
+                fmuls s16,s16,s8
+                fmuls s17,s17,s9
+                fmuls s18,s18,s10
+                fmuls s19,s19,s11
+                fmuls s20,s20,s12
+                fmuls s21,s21,s13
+                fmuls s22,s22,s14
+                fmuls s23,s23,s15
+                pld [r0,#128]
+                // multiply by data
+                fldmias r0!,{s8,s9,s10,s11,s12,s13,s14,s15}
+                fmuls s24,s8,s0
+                fmuls s25,s9,s0
+                fmuls s26,s10,s1
+                fmuls s27,s11,s1
+                fmuls s28,s12,s2
+                fmuls s29,s13,s2
+                fmuls s30,s14,s3
+                fmuls s31,s15,s3
+                fnmacs s24,s9,s16
+                fmacs s25,s8,s16
+                fnmacs s26,s11,s17
+                fmacs s27,s10,s17
+                fnmacs s28,s13,s18
+                fmacs s29,s12,s18
+                fnmacs s30,s15,s19
+                fmacs s31,s14,s19
+                fstmias r1!,{s24,s25,s26,s27,s28,s29,s30,s31}
+                pld [r0,#128]
+                fldmias r0!,{s8,s9,s10,s11,s12,s13,s14,s15}
+                fmuls s24,s8,s4
+                fmuls s25,s9,s4
+                fmuls s26,s10,s5
+                fmuls s27,s11,s5
+                fmuls s28,s12,s6
+                fmuls s29,s13,s6
+                fmuls s30,s14,s7
+                fmuls s31,s15,s7
+                fnmacs s24,s9,s20
+                fmacs s25,s8,s20
+                fnmacs s26,s11,s21
+                fmacs s27,s10,s21
+                fnmacs s28,s13,s22
+                fmacs s29,s12,s22
+                fnmacs s30,s15,s23
+                fmacs s31,s14,s23
+                fstmias r1!,{s24,s25,s26,s27,s28,s29,s30,s31}
+                
+                add r4,r4,#8
+                cmp r0,r3
+                blo .Lmainloop
+.Lendmainloop:
+                add r3,r3,#8*7
+                cmp r0,r3
+                bhs .Lendsmallloop
+.Lsmallloop:
+                fmsr s24,r4
+                fldmiad sp,{d9,d10}
+                fuitod d0,s24
+                // square of i
+                fmuld d0,d0,d0
+                // multiply by srate
+                fmuld d0,d0,d9
+                // rounding to -0.5/+0.5
+                faddd d12,d0,d10
+                fsubd d12,d12,d10
+                fsubd d0,d0,d12
+                fcvtsd s24,d0
+                
+                fldmias r6,{s8,s9,s10,s11,s12,s13,s14,s15}
+                // square of y
+                fmuls s0,s24,s24
+                // sine/cosine
+                fmuls s16,s0,s11
+                fmuls s17,s0,s15
+                fadds s16,s16,s10
+                fadds s17,s17,s14
+                fmuls s16,s16,s0
+                fmuls s17,s17,s0
+                fadds s16,s16,s9
+                fadds s17,s17,s13
+                fmuls s16,s16,s0
+                fmuls s17,s17,s0
+                fadds s16,s16,s8
+                fadds s17,s17,s12   // s16 - sine
+                fmuls s16,s16,s24   // s17 - cosine
+                // doubling cosine/sine
+                fmuls s18,s16,s17
+                fmuls s19,s16,s16
+                fmuls s20,s17,s17
+                fadds s18,s18,s18  // y=2*s*c
+                fsubs s19,s20,s19  // x=c*c-s*s
+                fmuls s21,s18,s19  // cd1
+                fmuls s22,s19,s19  // cd2
+                fmuls s23,s18,s18  // cd3
+                fsubs s8,s22,s23  // c
+                fadds s9,s21,s21  // s
+                // compute 1.0/norm
+                fadds s10,s22,s23 // mag
+                // reciprocal
+                flds s11,.Ltwos
+                // iter1: invmag = 2.0-mag
+                fsubs s12,s11,s10
+                // iter2: invmag = invmag*(2.0-invmag*mag)
+                fmuls s13,s12,s10
+                fsubs s13,s11,s13
+                fmuls s12,s12,s13
+                // correct cosine/sine
+                fmuls s8,s8,s12
+                fmuls s9,s9,s12
+                // multiply data
+                fldmias r0!,{s14,s15}
+                fmuls s6,s14,s8
+                fmuls s7,s14,s9
+                fnmacs s6,s15,s9
+                fmacs s7,s15,s8
+                fstmias r1!,{s6,s7}
+                
+                add r4,r4,#1
+                cmp r0,r3
+                blo .Lsmallloop
+.Lendsmallloop:
+                add sp,sp,#24+32+8
+.Lendoffunc:
+                mov r0,#0
+                vpop {d8,d9,d10,d11,d12,d13,d14,d15}
+                pop {r4,r5,r6,r7,r8,lr}
+                bx lr
+                
+                .align  2
+.LGOT1:
+                .word _GLOBAL_OFFSET_TABLE_-(.LPIC1+8)
+                .word analysis_state(GOT)
+.Ltwos:
+                .float 2.0
+/*
+ * vfp_FoldSubs.S
+ * Author: Mateusz Szpakowski
+ */
+ 
+                .arch armv6
+                .fpu vfp
+                .eabi_attribute 20, 1
+                .eabi_attribute 21, 1
+                .eabi_attribute 23, 3
+                .eabi_attribute 24, 1
+                .eabi_attribute 25, 1
+                .eabi_attribute 26, 2
+                .eabi_attribute 30, 2
+                .eabi_attribute 18, 4
+                .text
+                .align  2
+                /*****
+                 * fold array by 3 
+                 ******/
+.Lzeros:
+                .float 0.0,0.0
+                
+                .global vfp_foldArrayBy3_ll31
+                .type vfp_foldArrayBy3_ll31, %function
+vfp_foldArrayBy3_ll31:
+                push {r4,r5,r6,lr}
+                vpush {d8,d9,d10,d11,d12}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r6,r0,r4,lsl #2 // end
+                
+                fldd d12,.Lzeros
+                sub r6,r6,#4*7
+                cmp r0,r6
+                bhs .Lendf3loop2
+.Lf3loop2:
+.macro FOLDBY3_CORE
+                fldmias r0!,{s0,s1,s2,s3,s4,s5,s6,s7}
+                fldmias r2!,{s8,s9,s10,s11,s12,s13,s14,s15}
+                fldmias r3!,{s16,s17,s18,s19,s20,s21,s22,s23}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s5,s5,s13
+                fadds s6,s6,s14
+                fadds s7,s7,s15
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fadds s4,s4,s20
+                fadds s5,s5,s21
+                fadds s6,s6,s22
+                fadds s7,s7,s23
+                fstmias r5!,{s0,s1,s2,s3,s4,s5,s6,s7}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcmpes s24,s6
+                fcpysmi s25,s5
+                fmstat
+                fcmpes s25,s7
+                fcpysmi s24,s6
+                fmstat
+                fcpysmi s25,s7
+.endm
+                FOLDBY3_CORE
+
+                cmp r0,r6
+                blo .Lf3loop2
+.Lendf3loop2:
+                and r4,r4,#7
+                cmp r4,#4
+                blo .Lf3lt4
+                beq .Lf3eq4
+
+                cmp r4,#6
+                blo .Lf3lt6                
+                beq .Lf3eq6
+                
+                fldmias r0!,{s0,s1,s2,s3,s4,s5,s6}
+                fldmias r2!,{s8,s9,s10,s11,s12,s13,s14}
+                fldmias r3!,{s16,s17,s18,s19,s20,s21,s22}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s5,s5,s13
+                fadds s6,s6,s14
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fadds s4,s4,s20
+                fadds s5,s5,s21
+                fadds s6,s6,s22
+                fstmias r5!,{s0,s1,s2,s3,s4,s5,s6}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcmpes s24,s6
+                fcpysmi s25,s5
+                fmstat
+                fcpysmi s24,s6
+                b .Lf3end
+.Lf3eq6:
+                fldmias r0!,{s0,s1,s2,s3,s4,s5}
+                fldmias r2!,{s8,s9,s10,s11,s12,s13}
+                fldmias r3!,{s16,s17,s18,s19,s20,s21}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s5,s5,s13
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fadds s4,s4,s20
+                fadds s5,s5,s21
+                fstmias r5!,{s0,s1,s2,s3,s4,s5}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcpysmi s25,s5
+                b .Lf3end
+.Lf3lt6:
+                fldmias r0!,{s0,s1,s2,s3,s4}
+                fldmias r2!,{s8,s9,s10,s11,s12}
+                fldmias r3!,{s16,s17,s18,s19,s20}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fadds s4,s4,s20
+                fstmias r5!,{s0,s1,s2,s3,s4}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcpysmi s24,s4
+                b .Lf3end
+.Lf3eq4:
+                fldmias r0!,{s0,s1,s2,s3}
+                fldmias r2!,{s8,s9,s10,s11}
+                fldmias r3!,{s16,s17,s18,s19}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fstmias r5!,{s0,s1,s2,s3}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcpysmi s25,s3
+                b .Lf3end
+.Lf3lt4:
+                cmp r4,#2
+                blo .Lf3lt2
+                beq .Lf3eq2
+                
+                fldmias r0!,{s0,s1,s2}
+                fldmias r2!,{s8,s9,s10}
+                fldmias r3!,{s16,s17,s18}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fstmias r5!,{s0,s1,s2}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcpysmi s24,s2
+                b .Lf3end
+.Lf3eq2:
+                fldmias r0!,{s0,s1}
+                fldmias r2!,{s8,s9}
+                fldmias r3!,{s16,s17}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fstmias r5!,{s0,s1}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcpysmi s25,s1
+                b .Lf3end
+.Lf3lt2:
+                cmp r4,#0
+                beq .Lf3eq0
+                fldmias r0!,{s0}
+                fldmias r2!,{s1}
+                fldmias r3!,{s2}
+                
+                fadds s0,s0,s1
+                fadds s0,s0,s2
+                fstmias r5!,{s0}
+                
+                fcmpes s24,s0
+                fmstat
+                fcpysmi s24,s0
+.Lf3eq0:
+
+.Lf3end:
+                fcmpes s24,s25
+                fmstat
+                fcpysmi s24,s25
+                
+                fmrs r0,s24
+                vpop {d8,d9,d10,d11,d12}
+                pop {r4,r5,r6,lr}
+                bx lr
+                
+.Lzeros1:
+                .float 0.0,0.0
+                
+                .global vfp_foldArrayBy3_lge31
+                .type vfp_foldArrayBy3_lge31, %function
+vfp_foldArrayBy3_lge31:
+                push {r4,r5,r6,lr}
+                vpush {d8,d9,d10,d11,d12}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r6,r0,r4,lsl #2 // end
+                
+                fldd d12,.Lzeros1
+                sub r6,r6,#4*31
+                cmp r0,r6
+                bhs .Lendf3loop4
+.Lf3loop4:
+                FOLDBY3_CORE
+                FOLDBY3_CORE
+                FOLDBY3_CORE
+                FOLDBY3_CORE
+                
+                cmp r0,r6
+                blo .Lf3loop4
+.Lendf3loop4:
+                add r6,r6,#4*24
+                cmp r0,r6
+                bhs .Lendf3loop2
+.Lf3loop5:
+                FOLDBY3_CORE
+                
+                cmp r0,r6
+                blo .Lf3loop5
+.Lendf3loop5:
+                b .Lendf3loop2                
+                
+.Lfoldby3sel:
+.rept 31
+                .word vfp_foldArrayBy3_ll31
+.endr
+                .word vfp_foldArrayBy3_lge31
+                
+.Lzeros2:
+                .float 0.0,0.0
+                /*****
+                 * fold array by 4
+                 ******/
+                .global vfp_foldArrayBy4_ll31
+                .type vfp_foldArrayBy4_ll31, %function
+vfp_foldArrayBy4_ll31:
+                push {r4,r5,r6,r7,r8,lr}
+                vpush {d8,d9,d10,d11,d12}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                ldr r6,[r1,#16] // tmp2
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                add r6,r0,r6,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r7,r0,r4,lsl #2 // end
+                
+                fldd d12,.Lzeros2
+                sub r7,r7,#4*7
+                cmp r0,r7
+                bhs .Lendf4loop2
+.Lf4loop2:
+.macro FOLDBY4_CORE
+                fldmias r0!,{s0,s1,s2,s3,s4,s5,s6,s7}
+                fldmias r2!,{s8,s9,s10,s11,s12,s13,s14,s15}
+                fldmias r3!,{s16,s17,s18,s19,s20,s21,s22,s23}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s5,s5,s13
+                fadds s6,s6,s14
+                fadds s7,s7,s15
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fldmias r6!,{s8,s9,s10,s11,s12,s13,s14,s15}
+                fadds s4,s4,s20
+                fadds s5,s5,s21
+                fadds s6,s6,s22
+                fadds s7,s7,s23
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s5,s5,s13
+                fadds s6,s6,s14
+                fadds s7,s7,s15
+                
+                fstmias r5!,{s0,s1,s2,s3,s4,s5,s6,s7}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcmpes s24,s6
+                fcpysmi s25,s5
+                fmstat
+                fcmpes s25,s7
+                fcpysmi s24,s6
+                fmstat
+                fcpysmi s25,s7
+.endm
+                FOLDBY4_CORE
+
+                cmp r0,r7
+                blo .Lf4loop2
+.Lendf4loop2:
+                and r4,r4,#7
+                cmp r4,#4
+                blo .Lf4lt4
+                beq .Lf4eq4
+
+                cmp r4,#6
+                blo .Lf4lt6                
+                beq .Lf4eq6
+                
+                fldmias r0!,{s0,s1,s2,s3,s4,s5,s6}
+                fldmias r2!,{s8,s9,s10,s11,s12,s13,s14}
+                fldmias r3!,{s16,s17,s18,s19,s20,s21,s22}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s5,s5,s13
+                fadds s6,s6,s14
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fadds s4,s4,s20
+                fadds s5,s5,s21
+                fadds s6,s6,s22
+                fldmias r6!,{s16,s17,s18,s19,s20,s21,s22}
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fadds s4,s4,s20
+                fadds s5,s5,s21
+                fadds s6,s6,s22
+                fstmias r5!,{s0,s1,s2,s3,s4,s5,s6}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcmpes s24,s6
+                fcpysmi s25,s5
+                fmstat
+                fcpysmi s24,s6
+                b .Lf4end
+.Lf4eq6:
+                fldmias r0!,{s0,s1,s2,s3,s4,s5}
+                fldmias r2!,{s6,s7,s8,s9,s10,s11}
+                fldmias r3!,{s12,s13,s14,s15,s16,s17}
+                fldmias r6!,{s18,s19,s20,s21,s22,s23}
+                
+                fadds s0,s0,s6
+                fadds s1,s1,s7
+                fadds s2,s2,s8
+                fadds s3,s3,s9
+                fadds s4,s4,s10
+                fadds s5,s5,s11
+                fadds s0,s0,s12
+                fadds s1,s1,s13
+                fadds s2,s2,s14
+                fadds s3,s3,s15
+                fadds s4,s4,s16
+                fadds s5,s5,s17
+                fadds s0,s0,s18
+                fadds s1,s1,s19
+                fadds s2,s2,s20
+                fadds s3,s3,s21
+                fadds s4,s4,s22
+                fadds s5,s5,s23
+                fstmias r5!,{s0,s1,s2,s3,s4,s5}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcpysmi s25,s5
+                b .Lf4end
+.Lf4lt6:
+                fldmias r0!,{s0,s1,s2,s3,s4}
+                fldmias r2!,{s6,s7,s8,s9,s10}
+                fldmias r3!,{s12,s13,s14,s15,s16}
+                fldmias r6!,{s18,s19,s20,s21,s22}
+                
+                fadds s0,s0,s6
+                fadds s1,s1,s7
+                fadds s2,s2,s8
+                fadds s3,s3,s9
+                fadds s4,s4,s10
+                fadds s0,s0,s12
+                fadds s1,s1,s13
+                fadds s2,s2,s14
+                fadds s3,s3,s15
+                fadds s4,s4,s16
+                fadds s0,s0,s18
+                fadds s1,s1,s19
+                fadds s2,s2,s20
+                fadds s3,s3,s21
+                fadds s4,s4,s22
+                fstmias r5!,{s0,s1,s2,s3,s4}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcpysmi s24,s4
+                b .Lf4end
+.Lf4eq4:
+                fldmias r0!,{s0,s1,s2,s3}
+                fldmias r2!,{s6,s7,s8,s9}
+                fldmias r3!,{s12,s13,s14,s15}
+                fldmias r6!,{s18,s19,s20,s21}
+                
+                fadds s0,s0,s6
+                fadds s1,s1,s7
+                fadds s2,s2,s8
+                fadds s3,s3,s9
+                fadds s0,s0,s12
+                fadds s1,s1,s13
+                fadds s2,s2,s14
+                fadds s3,s3,s15
+                fadds s0,s0,s18
+                fadds s1,s1,s19
+                fadds s2,s2,s20
+                fadds s3,s3,s21
+                fstmias r5!,{s0,s1,s2,s3}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcpysmi s25,s3
+                b .Lf4end
+.Lf4lt4:
+                cmp r4,#2
+                blo .Lf4lt2
+                beq .Lf4eq2
+                
+                fldmias r0!,{s0,s1,s2}
+                fldmias r2!,{s6,s7,s8}
+                fldmias r3!,{s12,s13,s14}
+                fldmias r6!,{s18,s19,s20}
+                
+                fadds s0,s0,s6
+                fadds s1,s1,s7
+                fadds s2,s2,s8
+                fadds s0,s0,s12
+                fadds s1,s1,s13
+                fadds s2,s2,s14
+                fadds s0,s0,s18
+                fadds s1,s1,s19
+                fadds s2,s2,s20
+                fstmias r5!,{s0,s1,s2}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcpysmi s24,s2
+                b .Lf4end
+.Lf4eq2:
+                fldmias r0!,{s0,s1}
+                fldmias r2!,{s6,s7}
+                fldmias r3!,{s12,s13}
+                fldmias r6!,{s18,s19}
+                
+                fadds s0,s0,s6
+                fadds s1,s1,s7
+                fadds s0,s0,s12
+                fadds s1,s1,s13
+                fadds s0,s0,s18
+                fadds s1,s1,s19
+                fstmias r5!,{s0,s1}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcpysmi s25,s1
+                b .Lf4end
+.Lf4lt2:
+                cmp r4,#0
+                beq .Lf4eq0
+                fldmias r0!,{s0}
+                fldmias r2!,{s1}
+                fldmias r3!,{s2}
+                fldmias r6!,{s3}
+                
+                fadds s0,s0,s1
+                fadds s0,s0,s2
+                fadds s0,s0,s3
+                fstmias r5!,{s0}
+                
+                fcmpes s24,s0
+                fmstat
+                fcpysmi s24,s0
+.Lf4eq0:
+                
+.Lf4end:
+                fcmpes s24,s25
+                fmstat
+                fcpysmi s24,s25
+                
+                fmrs r0,s24
+                vpop {d8,d9,d10,d11,d12}
+                pop {r4,r5,r6,r7,r8,lr}
+                bx lr
+                
+.Lzeros2_1:
+                .float 0.0,0.0
+                .global vfp_foldArrayBy4_lge31
+                .type vfp_foldArrayBy4_lge31, %function
+vfp_foldArrayBy4_lge31:
+                push {r4,r5,r6,r7,r8,lr}
+                vpush {d8,d9,d10,d11,d12}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                ldr r6,[r1,#16] // tmp2
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                add r6,r0,r6,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r7,r0,r4,lsl #2 // end
+               
+                fldd d12,.Lzeros2_1
+                sub r7,r7,#4*31
+                cmp r0,r7
+                bhs .Lendf4loop4
+.Lf4loop4:
+                FOLDBY4_CORE
+                FOLDBY4_CORE
+                FOLDBY4_CORE
+                FOLDBY4_CORE
+
+                cmp r0,r7
+                blo .Lf4loop4
+.Lendf4loop4:
+                add r7,r7,#4*24
+                cmp r0,r7
+                bhs .Lendf4loop2
+.Lf4loop5:
+                FOLDBY4_CORE
+                
+                cmp r0,r7
+                blo .Lf4loop5
+.Lendf4loop5:
+                b .Lendf4loop2
+                
+.Lfoldby4sel:
+.rept 31
+                .word vfp_foldArrayBy4_ll31
+.endr
+                .word vfp_foldArrayBy4_lge31
+
+.Lzeros3:
+                .float 0.0,0.0
+                /*****
+                 * fold array by 5 
+                 ******/
+                .global vfp_foldArrayBy5_ll31
+                .type vfp_foldArrayBy5_ll31, %function
+vfp_foldArrayBy5_ll31:
+                push {r4,r5,r6,r7,r8,lr}
+                vpush {d8,d9,d10,d11,d12}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                ldrd r6,[r1,#16] // tmp2,tmp3
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                add r6,r0,r6,lsl #2
+                add r7,r0,r7,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r8,r0,r4,lsl #2 // end
+                
+                fldd d12,.Lzeros3
+                sub r8,r8,#4*7
+                cmp r0,r8
+                bhs .Lendf5loop2
+.Lf5loop2:
+.macro FOLDBY5_CORE
+                fldmias r0!,{s0,s1,s2,s3,s4,s5,s6,s7}
+                fldmias r2!,{s8,s9,s10,s11,s12,s13,s14,s15}
+                fldmias r3!,{s16,s17,s18,s19,s20,s21,s22,s23}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s5,s5,s13
+                fadds s6,s6,s14
+                fadds s7,s7,s15
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fldmias r6!,{s8,s9,s10,s11,s12,s13,s14,s15}
+                fadds s4,s4,s20
+                fadds s5,s5,s21
+                fadds s6,s6,s22
+                fadds s7,s7,s23
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fldmias r7!,{s16,s17,s18,s19,s20,s21,s22,s23}
+                fadds s5,s5,s13
+                fadds s6,s6,s14
+                fadds s7,s7,s15
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fadds s4,s4,s20
+                fadds s5,s5,s21
+                fadds s6,s6,s22
+                fadds s7,s7,s23
+                
+                fstmias r5!,{s0,s1,s2,s3,s4,s5,s6,s7}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcmpes s24,s6
+                fcpysmi s25,s5
+                fmstat
+                fcmpes s25,s7
+                fcpysmi s24,s6
+                fmstat
+                fcpysmi s25,s7
+.endm
+                FOLDBY5_CORE
+                
+                cmp r0,r8
+                blo .Lf5loop2
+.Lendf5loop2:
+                and r4,r4,#7
+                cmp r4,#4
+                blo .Lf5lt4
+                beq .Lf5eq4
+
+                cmp r4,#6
+                blo .Lf5lt6                
+                beq .Lf5eq6
+                
+                fldmias r0!,{s0,s1,s2,s3,s4,s5,s6}
+                fldmias r2!,{s8,s9,s10,s11,s12,s13,s14}
+                fldmias r3!,{s16,s17,s18,s19,s20,s21,s22}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s5,s5,s13
+                fadds s6,s6,s14
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fadds s4,s4,s20
+                fadds s5,s5,s21
+                fadds s6,s6,s22
+                fldmias r6!,{s16,s17,s18,s19,s20,s21,s22}
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fadds s4,s4,s20
+                fadds s5,s5,s21
+                fadds s6,s6,s22
+                fldmias r7!,{s16,s17,s18,s19,s20,s21,s22}
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fadds s4,s4,s20
+                fadds s5,s5,s21
+                fadds s6,s6,s22
+                fstmias r5!,{s0,s1,s2,s3,s4,s5,s6}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcmpes s24,s6
+                fcpysmi s25,s5
+                fmstat
+                fcpysmi s24,s6
+                b .Lf5end
+.Lf5eq6:
+                fldmias r0!,{s0,s1,s2,s3,s4,s5}
+                fldmias r2!,{s6,s7,s8,s9,s10,s11}
+                fldmias r3!,{s12,s13,s14,s15,s16,s17}
+                fldmias r6!,{s18,s19,s20,s21,s22,s23}
+                
+                fadds s0,s0,s6
+                fadds s1,s1,s7
+                fadds s2,s2,s8
+                fadds s3,s3,s9
+                fadds s4,s4,s10
+                fadds s5,s5,s11
+                fadds s0,s0,s12
+                fadds s1,s1,s13
+                fadds s2,s2,s14
+                fadds s3,s3,s15
+                fadds s4,s4,s16
+                fadds s5,s5,s17
+                fadds s0,s0,s18
+                fadds s1,s1,s19
+                fadds s2,s2,s20
+                fadds s3,s3,s21
+                fadds s4,s4,s22
+                fadds s5,s5,s23
+                fldmias r7!,{s18,s19,s20,s21,s22,s23}
+                fadds s0,s0,s18
+                fadds s1,s1,s19
+                fadds s2,s2,s20
+                fadds s3,s3,s21
+                fadds s4,s4,s22
+                fadds s5,s5,s23
+                fstmias r5!,{s0,s1,s2,s3,s4,s5}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcpysmi s25,s5
+                b .Lf5end
+.Lf5lt6:
+                fldmias r0!,{s0,s1,s2,s3,s4}
+                fldmias r2!,{s6,s7,s8,s9,s10}
+                fldmias r3!,{s12,s13,s14,s15,s16}
+                fldmias r6!,{s18,s19,s20,s21,s22}
+                
+                fadds s0,s0,s6
+                fadds s1,s1,s7
+                fadds s2,s2,s8
+                fadds s3,s3,s9
+                fadds s4,s4,s10
+                fadds s0,s0,s12
+                fadds s1,s1,s13
+                fadds s2,s2,s14
+                fadds s3,s3,s15
+                fadds s4,s4,s16
+                fadds s0,s0,s18
+                fadds s1,s1,s19
+                fadds s2,s2,s20
+                fadds s3,s3,s21
+                fadds s4,s4,s22
+                fldmias r7!,{s18,s19,s20,s21,s22}
+                fadds s0,s0,s18
+                fadds s1,s1,s19
+                fadds s2,s2,s20
+                fadds s3,s3,s21
+                fadds s4,s4,s22
+                fstmias r5!,{s0,s1,s2,s3,s4}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcpysmi s24,s4
+                b .Lf5end
+.Lf5eq4:
+                fldmias r0!,{s0,s1,s2,s3}
+                fldmias r2!,{s4,s5,s6,s7}
+                fldmias r3!,{s8,s9,s10,s11}
+                fldmias r6!,{s12,s13,s14,s15}
+                fldmias r7!,{s16,s17,s18,s19}
+                
+                fadds s0,s0,s4
+                fadds s1,s1,s5
+                fadds s2,s2,s6
+                fadds s3,s3,s7
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s0,s0,s12
+                fadds s1,s1,s13
+                fadds s2,s2,s14
+                fadds s3,s3,s15
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fadds s3,s3,s19
+                fstmias r5!,{s0,s1,s2,s3}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcpysmi s25,s3
+                b .Lf5end
+.Lf5lt4:
+                cmp r4,#2
+                blo .Lf5lt2
+                beq .Lf5eq2
+                
+                fldmias r0!,{s0,s1,s2}
+                fldmias r2!,{s4,s5,s6}
+                fldmias r3!,{s8,s9,s10}
+                fldmias r6!,{s12,s13,s14}
+                fldmias r7!,{s16,s17,s18}
+                
+                fadds s0,s0,s4
+                fadds s1,s1,s5
+                fadds s2,s2,s6
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s0,s0,s12
+                fadds s1,s1,s13
+                fadds s2,s2,s14
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fadds s2,s2,s18
+                fstmias r5!,{s0,s1,s2}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcpysmi s24,s2
+                b .Lf5end
+.Lf5eq2:
+                fldmias r0!,{s0,s1}
+                fldmias r2!,{s4,s5}
+                fldmias r3!,{s8,s9}
+                fldmias r6!,{s12,s13}
+                fldmias r7!,{s16,s17}
+                
+                fadds s0,s0,s4
+                fadds s1,s1,s5
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s0,s0,s12
+                fadds s1,s1,s13
+                fadds s0,s0,s16
+                fadds s1,s1,s17
+                fstmias r5!,{s0,s1}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcpysmi s25,s1
+                b .Lf5end
+.Lf5lt2:
+                cmp r4,#0
+                beq .Lf5eq0
+                fldmias r0!,{s0}
+                fldmias r2!,{s1}
+                fldmias r3!,{s2}
+                fldmias r6!,{s3}
+                fldmias r7!,{s4}
+                
+                fadds s0,s0,s1
+                fadds s0,s0,s2
+                fadds s0,s0,s3
+                fadds s0,s0,s4
+                fstmias r5!,{s0}
+                
+                fcmpes s24,s0
+                fmstat
+                fcpysmi s24,s0
+.Lf5eq0:
+
+.Lf5end:        
+                fcmpes s24,s25
+                fmstat
+                fcpysmi s24,s25
+                
+                fmrs r0,s24
+                vpop {d8,d9,d10,d11,d12}
+                pop {r4,r5,r6,r7,r8,lr}
+                bx lr
+
+.Lzeros3_1:
+                .float 0.0,0.0
+                
+                .global vfp_foldArrayBy5_lge31
+                .type vfp_foldArrayBy5_lge31, %function
+vfp_foldArrayBy5_lge31:
+                push {r4,r5,r6,r7,r8,lr}
+                vpush {d8,d9,d10,d11,d12}
+                
+                ldr r0,[r0] // ss0
+                ldrd r2,[r1,#8] // tmp0
+                ldrd r6,[r1,#16] // tmp2,tmp3
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                add r6,r0,r6,lsl #2
+                add r7,r0,r7,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r8,r0,r4,lsl #2 // end
+                
+                fldd d12,.Lzeros3_1
+                sub r8,r8,#4*31
+                cmp r0,r8
+                bhs .Lendf5loop4
+.Lf5loop4:
+                FOLDBY5_CORE
+                FOLDBY5_CORE
+                FOLDBY5_CORE
+                FOLDBY5_CORE
+                
+                cmp r0,r8
+                blo .Lf5loop4
+.Lendf5loop4:
+                add r8,r8,#4*24
+                cmp r0,r8
+                bhs .Lendf5loop2
+.Lf5loop5:
+                FOLDBY5_CORE
+                
+                cmp r0,r8
+                blo .Lf5loop5
+.Lendf5loop5:
+                b .Lendf5loop2
+
+.Lfoldby5sel:
+.rept 31
+                .word vfp_foldArrayBy5_ll31
+.endr
+                .word vfp_foldArrayBy5_lge31
+                
+.Lzeros4:
+                .float 0.0,0.0
+                /*****
+                 * fold array by 2
+                 ******/
+                .global vfp_foldArrayBy2_ll31
+                .type vfp_foldArrayBy2_ll31, %function
+vfp_foldArrayBy2_ll31:
+                push {r4,r5,r6,lr}
+                vpush {d8,d9,d10,d11,d12}
+                
+                ldr r0,[r0,#4] // ss1
+                ldrd r2,[r1,#8] // tmp0
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r6,r2,r4,lsl #2 // end
+                
+                fldd d12,.Lzeros4
+                sub r6,r6,#4*7
+                cmp r2,r6
+                bhs .Lendf2loop2
+.Lf2loop2:
+.macro FOLDBY2_CORE
+                fldmias r2!,{s0,s1,s2,s3,s4,s5,s6,s7}
+                fldmias r3!,{s8,s9,s10,s11,s12,s13,s14,s15}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s5,s5,s13
+                fadds s6,s6,s14
+                fadds s7,s7,s15
+                fstmias r5!,{s0,s1,s2,s3,s4,s5,s6,s7}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcmpes s24,s6
+                fcpysmi s25,s5
+                fmstat
+                fcmpes s25,s7
+                fcpysmi s24,s6
+                fmstat
+                fcpysmi s25,s7
+.endm
+                FOLDBY2_CORE
+
+                cmp r2,r6
+                blo .Lf2loop2
+.Lendf2loop2:
+                and r4,r4,#7
+                cmp r4,#4
+                blo .Lf2lt4
+                beq .Lf2eq4
+
+                cmp r4,#6
+                blo .Lf2lt6                
+                beq .Lf2eq6
+                
+                fldmias r2!,{s0,s1,s2,s3,s4,s5,s6}
+                fldmias r3!,{s8,s9,s10,s11,s12,s13,s14}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s5,s5,s13
+                fadds s6,s6,s14
+                fstmias r5!,{s0,s1,s2,s3,s4,s5,s6}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcmpes s24,s6
+                fcpysmi s25,s5
+                fmstat
+                fcpysmi s24,s6
+                b .Lf2end
+.Lf2eq6:
+                fldmias r2!,{s0,s1,s2,s3,s4,s5}
+                fldmias r3!,{s8,s9,s10,s11,s12,s13}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                fadds s5,s5,s13
+                fstmias r5!,{s0,s1,s2,s3,s4,s5}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcmpes s25,s5
+                fcpysmi s24,s4
+                fmstat
+                fcpysmi s25,s5
+                b .Lf2end
+.Lf2lt6:
+                fldmias r2!,{s0,s1,s2,s3,s4}
+                fldmias r3!,{s8,s9,s10,s11,s12}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                fadds s4,s4,s12
+                
+                fstmias r5!,{s0,s1,s2,s3,s4}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcmpes s24,s4
+                fcpysmi s25,s3
+                fmstat
+                fcpysmi s24,s4
+                b .Lf2end
+.Lf2eq4:
+                fldmias r2!,{s0,s1,s2,s3}
+                fldmias r3!,{s8,s9,s10,s11}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                fadds s3,s3,s11
+                
+                fstmias r5!,{s0,s1,s2,s3}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcmpes s25,s3
+                fcpysmi s24,s2
+                fmstat
+                fcpysmi s25,s3
+                b .Lf2end
+.Lf2lt4:
+                cmp r4,#2
+                blo .Lf2lt2
+                beq .Lf2eq2
+                
+                fldmias r2!,{s0,s1,s2}
+                fldmias r3!,{s8,s9,s10}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                fadds s2,s2,s10
+                
+                fstmias r5!,{s0,s1,s2}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcmpes s24,s2
+                fcpysmi s25,s1
+                fmstat
+                fcpysmi s24,s2
+                b .Lf2end
+.Lf2eq2:
+                fldmias r2!,{s0,s1}
+                fldmias r3!,{s8,s9}
+                
+                fadds s0,s0,s8
+                fadds s1,s1,s9
+                
+                fstmias r5!,{s0,s1}
+                
+                fcmpes s24,s0
+                fmstat
+                fcmpes s25,s1
+                fcpysmi s24,s0
+                fmstat
+                fcpysmi s25,s1
+                b .Lf2end
+.Lf2lt2:
+                cmp r4,#0
+                beq .Lf2eq0
+                fldmias r2!,{s0}
+                fldmias r3!,{s1}
+                
+                fadds s0,s0,s1
+                fstmias r5!,{s0}
+                
+                fcmpes s24,s0
+                fmstat
+                fcpysmi s24,s0
+.Lf2eq0:
+
+.Lf2end:
+                fcmpes s24,s25
+                fmstat
+                fcpysmi s24,s25
+                
+                fmrs r0,s24
+                vpop {d8,d9,d10,d11,d12}
+                pop {r4,r5,r6,lr}
+                bx lr
+                
+                .global vfp_foldArrayBy2_lge31
+                .type vfp_foldArrayBy2_lge31, %function
+vfp_foldArrayBy2_lge31:
+                push {r4,r5,r6,lr}
+                vpush {d8,d9,d10,d11,d12}
+                
+                ldr r0,[r0,#4] // ss1
+                ldrd r2,[r1,#8] // tmp0
+                add r2,r0,r2,lsl #2
+                add r3,r0,r3,lsl #2
+                ldrd r4,[r1]  // di,dest
+                add r6,r2,r4,lsl #2 // end
+                
+                fldd d12,.Lzeros4
+                sub r6,r6,#4*31
+                cmp r2,r6
+                bhs .Lendf2loop4
+.Lf2loop4:
+                FOLDBY2_CORE
+                FOLDBY2_CORE
+                FOLDBY2_CORE
+                FOLDBY2_CORE
+
+                cmp r2,r6
+                blo .Lf2loop4
+.Lendf2loop4:
+                add r6,r6,#4*24
+                cmp r2,r6
+                bhs .Lendf2loop2
+.Lf2loop5:
+                FOLDBY2_CORE
+                
+                cmp r2,r6
+                blo .Lf2loop5
+                b .Lendf2loop2
+                
+.Lfoldby2sel:
+.rept 31
+                .word vfp_foldArrayBy2_ll31
+.endr
+                .word vfp_foldArrayBy2_lge31
+                
+                .align 2
+.Lname:
+                .string "opt VFP"
+                
+                .align 2
+                .global vfpFoldMain
+vfpFoldMain:
+                .word .Lfoldby3sel
+                .word .Lfoldby4sel
+                .word .Lfoldby5sel
+                .word .Lfoldby2sel
+                .word .Lfoldby2sel
+                .word .Lname
+                /*
+ * vfp_GetPowerSpectrum.S
+ * Author: Mateusz Szpakowski
+ */
+ 
+                .arch armv6
+                .fpu vfp
+                .eabi_attribute 20, 1
+                .eabi_attribute 21, 1
+                .eabi_attribute 23, 3
+                .eabi_attribute 24, 1
+                .eabi_attribute 25, 1
+                .eabi_attribute 26, 2
+                .eabi_attribute 30, 2
+                .eabi_attribute 18, 4
+                .text
+                .align  2
+                .global _Z20vfp_GetPowerSpectrumPA2_fPfi
+                .type   _Z20vfp_GetPowerSpectrumPA2_fPfi, %function
+_Z20vfp_GetPowerSpectrumPA2_fPfi:
+                push {r4,r5}
+                vpush {d8,d9,d10,d11,d12,d13,d14,d15}
+                
+                ldr r3,.LGOTa
+.LPICa:
+                add r3,pc,r3
+                ldr r4,.LGOTa+4
+                ldr r4,[r3,r4]
+                add r5,r2,r2,lsl #1
+                fldd d0,[r4,#32]
+                fmsr s4,r5
+                fuitod d1,s4
+                faddd d0,d0,d1
+                fstd d0,[r4,#32]
+                
+                add r2,r0,r2,lsl #3
+                sub r2,r2,#15*8
+                /* r0 - freqData
+                 * r1 - PowerSpectrum
+                 * r2 - end of freqData
+                 */
+                cmp r0,r2
+                bhs .Lendmainloopa
+.Lmainloopa:
+                pld [r0,#64]
+                fldmias r0!,{s0,s1,s2,s3,s4,s5,s6,s7,s8,s9,s10,s11,s12,s13,s14,s15}
+                fmuls s16,s0,s0
+                fmuls s17,s2,s2
+                fmuls s18,s4,s4
+                fmuls s19,s6,s6
+                fmuls s20,s8,s8
+                fmuls s21,s10,s10
+                fmuls s22,s12,s12
+                fmuls s23,s14,s14
+                fmacs s16,s1,s1
+                fmacs s17,s3,s3
+                fmacs s18,s5,s5
+                fmacs s19,s7,s7
+                fmacs s20,s9,s9
+                fmacs s21,s11,s11
+                fmacs s22,s13,s13
+                fmacs s23,s15,s15
+                
+                pld [r0,#64]
+                fldmias r0!,{s0,s1,s2,s3,s4,s5,s6,s7,s8,s9,s10,s11,s12,s13,s14,s15}
+                fstmias r1!,{s16,s17,s18,s19,s20,s21,s22,s23}
+                
+                fmuls s24,s0,s0
+                fmuls s25,s2,s2
+                fmuls s26,s4,s4
+                fmuls s27,s6,s6
+                fmuls s28,s8,s8
+                fmuls s29,s10,s10
+                fmuls s30,s12,s12
+                fmuls s31,s14,s14
+                fmacs s24,s1,s1
+                fmacs s25,s3,s3
+                fmacs s26,s5,s5
+                fmacs s27,s7,s7
+                fmacs s28,s9,s9
+                fmacs s29,s11,s11
+                fmacs s30,s13,s13
+                fmacs s31,s15,s15
+                fstmias r1!,{s24,s25,s26,s27,s28,s29,s30,s31}
+                
+                cmp r0,r2
+                blo .Lmainloopa
+.Lendmainloopa:
+                add r2,r2,#8*12
+                bhs .Lendsmallloopa
+.Lsmallloopa:
+                fldmias r0!,{s0,s1,s2,s3,s4,s5,s6,s7}
+                fmuls s16,s0,s0
+                fmuls s17,s2,s2
+                fmuls s18,s4,s4
+                fmuls s19,s6,s6
+                fmacs s16,s1,s1
+                fmacs s17,s3,s3
+                fmacs s18,s5,s5
+                fmacs s19,s7,s7
+                fstmias r1!,{s16,s17,s18,s19}
+                cmp r0,r2
+                blo .Lsmallloopa
+.Lendsmallloopa:
+                add r2,r2,#8*3
+                cmp r0,r2                
+                beq .Lendmicroloop
+.Lmicroloop:
+                fldmias r0!,{s0,s1}
+                fmuls s2,s0,s0
+                fmacs s2,s1,s1
+                fstmias r1!,{s2}
+                
+                cmp r0,r2
+                blo .Lmicroloop
+                
+.Lendmicroloop:
+                mov r0,#0
+                vpop {d8,d9,d10,d11,d12,d13,d14,d15}
+                pop {r4,r5}
+                bx lr
+                
+                .align  2
+.LGOTa:
+                .word _GLOBAL_OFFSET_TABLE_-(.LPICa+8)
+                .word analysis_state(GOT)
+                
+#endif // __arm__
diff --git a/client/vector/analyzeFuncs_vfp_aux.cpp b/client/vector/analyzeFuncs_vfp_aux.cpp
new file mode 100644
index 0000000..d127993
--- /dev/null
+++ b/client/vector/analyzeFuncs_vfp_aux.cpp
@@ -0,0 +1,222 @@
+// Copyright 2003 Regents of the University of California
+
+// SETI_BOINC is free software; you can redistribute it and/or modify it under
+// the terms of the GNU General Public License as published by the Free
+// Software Foundation; either version 2, or (at your option) any later
+// version.
+
+// SETI_BOINC 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 SETI_BOINC; see the file COPYING.  If not, write to the Free Software
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+// In addition, as a special exception, the Regents of the University of
+// California give permission to link the code of this program with libraries
+// that provide specific optimized fast Fourier transform (FFT) functions and
+// distribute a linked executable.  You must obey the GNU General Public
+// License in all respects for all of the code used other than the FFT library
+// itself.  Any modification required to support these libraries must be
+// distributed in source code form.  If you modify this file, you may extend
+// this exception to your version of the file, but you are not obligated to
+// do so. If you do not wish to do so, delete this exception statement from
+// your version.
+
+// $Id: analyzeFuncs_sse.cpp,v 1.1.2.10 2007/06/08 03:09:47 korpela Exp $
+//
+
+// This file is empty is __i386__ is not defined
+#include "sah_config.h"
+#include <vector>
+#include <cmath>
+
+#if defined(__arm__)
+
+#define INVALID_CHIRP 2e+20
+
+#include "analyzeFuncs.h"
+#include "analyzeFuncs_vector.h"
+#include "analyzePoT.h"
+#include "analyzeReport.h"
+#include "gaussfit.h"
+#include "s_util.h"
+#include "diagnostics.h"
+#include "asmlib.h"
+#include "pulsefind.h"
+
+
+// ARM prefetch
+
+inline void pld(void *arg1,const int arg2=0) {
+    __asm__ __volatile__ (
+      "pld [%0,%1]\n"
+      : 
+      : "r" (arg1), "Jr" (arg2)
+    );
+}
+
+
+    
+template <int x>
+inline void v_pfsubTranspose(float *in, float *out, int xline, int yline) {
+    // Transpose an X by X subsection of a XLINE by YLINE matrix into the
+    // appropriate part of a YLINE by XLINE matrix.  "IN" points to the first
+    // (lowest address) element of the input submatrix.  "OUT" points to the
+    // first (lowest address) element of the output submatrix.
+    int i,j;
+    float *p;
+    register float tmp[x*x];
+    for (j=0;j<x;j++) {
+        p=in+j*xline;
+        pld(out+j*yline);
+        for (i=0;i<x;i++) {
+            tmp[j+i*x]=*(p++);
+        }
+    }
+    for (j=0;j<x;j++) {
+        p=out+j*yline;
+        for (i=0;i<x;i++) {
+            *(p++)=tmp[i+j*x];
+        }
+        pld(in+j*xline+x);
+    }
+}
+
+int v_pfTranspose2(int x, int y, float *in, float *out) {
+// Attempts to improve cache hit ratio by transposing 4 elements at a time.
+    int i,j;
+    for (j=0;j<y-1;j+=2) {
+        for (i=0;i<x-1;i+=2) {
+            v_pfsubTranspose<2>(in+j*x+i,out+y*i+j,x,y);
+        }
+        for (;i<x;i++) {
+            out[i*y+j]=in[j*x+i];
+        }
+    }
+    for (;j<y;j++) {
+        for (i=0;i<x;i++) {
+            out[i*y+j]=in[j*x+i];
+        }
+    }
+    return 0;
+}
+
+int v_pfTranspose4(int x, int y, float *in, float *out) {
+// Attempts to improve cache hit ratio by transposing 16 elements at a time.
+    int i,j;
+    for (j=0;j<y-3;j+=4) {
+        for (i=0;i<x-3;i+=4) {
+            v_pfsubTranspose<4>(in+j*x+i,out+y*i+j,x,y);
+        }
+        for (;i<x-1;i+=2) {
+            v_pfsubTranspose<2>(in+j*x+i,out+y*i+j,x,y);
+        }
+        for (;i<x;i++) {
+            out[i*y+j]=in[j*x+i];
+        }
+    }
+    for (;j<y-1;j+=2) {
+        for (i=0;i<x-1;i+=2) {
+            v_pfsubTranspose<2>(in+j*x+i,out+y*i+j,x,y);
+        }
+        for (;i<x;i++) {
+            out[i*y+j]=in[j*x+i];
+        }
+    }
+    for (;j<y;j++) {
+        for (i=0;i<x;i++) {
+            out[i*y+j]=in[j*x+i];
+        }
+    }
+    return 0;
+}
+
+int v_pfTranspose8(int x, int y, float *in, float *out) {
+// Attempts to improve cache hit ratio by transposing 64 elements at a time.
+    int i,j;
+    for (j=0;j<y-7;j+=8) {
+        for (i=0;i<x-7;i+=8) {
+            v_pfsubTranspose<8>(in+j*x+i,out+y*i+j,x,y);
+        }
+        for (;i<x-3;i+=4) {
+            v_pfsubTranspose<4>(in+j*x+i,out+y*i+j,x,y);
+        }
+        for (;i<x-1;i+=2) {
+            v_pfsubTranspose<2>(in+j*x+i,out+y*i+j,x,y);
+        }
+        for (;i<x;i++) {
+            out[i*y+j]=in[j*x+i];
+        }
+    }
+    for (j=0;j<y-3;j+=4) {
+        for (i=0;i<x-3;i+=4) {
+            v_pfsubTranspose<4>(in+j*x+i,out+y*i+j,x,y);
+        }
+        for (;i<x-1;i+=2) {
+            v_pfsubTranspose<2>(in+j*x+i,out+y*i+j,x,y);
+        }
+        for (;i<x;i++) {
+            out[i*y+j]=in[j*x+i];
+        }
+    }
+    for (;j<y-1;j+=2) {
+        for (i=0;i<x-1;i+=2) {
+            v_pfsubTranspose<2>(in+j*x+i,out+y*i+j,x,y);
+        }
+        for (;i<x;i++) {
+            out[i*y+j]=in[j*x+i];
+        }
+    }
+    for (;j<y;j++) {
+        for (i=0;i<x;i++) {
+            out[i*y+j]=in[j*x+i];
+        }
+    }
+    return 0;
+}
+
+static inline int vfp_subTranspose2(int x, int y, float *in, float *out) {
+// Attempts to improve cache hit ratio by transposing 4 elements at a time.
+    __asm__ __volatile__ (
+        "fldmias  %2, {s4, s5}\n"
+        "fldmias  %3, {s6, s7}\n"
+        "vmov.f32 s3,s6\n"
+        "vmov.f32 s6,s5\n"
+        "vmov.f32 s5,s3\n"
+        "fstmias  %0, {s4, s5}\n"
+        "fstmias  %1, {s6, s7}\n"
+    :  
+    : "r" (out), "r" (out+y), "r" (in), "r" (in+x)
+    : "s3", "s4", "s5", "s6", "s7" );
+    return 0;
+}
+        
+int v_vfpTranspose2(int x, int y, float *in, float *out) {
+// Attempts to improve cache hit ratio by transposing 4 elements at a time.
+    int i,j;
+    for (j=0;j<y-1;j+=2) {
+        for (i=0;i<x-1;i+=2) {
+            vfp_subTranspose2(x,y,in+j*x+i,out+y*i+j);
+        }
+        for (;i<x;i++) {
+            out[i*y+j]=in[j*x+i];
+        }
+    }
+    for (;j<y;j++) {
+        for (i=0;i<x;i++) {
+            out[i*y+j]=in[j*x+i];
+        }
+    }
+    return 0;
+}
+
+
+
+
+
+#endif // (__arm__) 
+
+
diff --git a/client/vector/fp_arm.h b/client/vector/fp_arm.h
new file mode 100644
index 0000000..93ae23b
--- /dev/null
+++ b/client/vector/fp_arm.h
@@ -0,0 +1,98 @@
+// Copyright (c) 1999-2013 Regents of the University of California
+//
+// FFTW: Copyright (c) 2003,2006 Matteo Frigo
+//       Copyright (c) 2003,2006 Massachusets Institute of Technology
+//
+// fft8g.[cpp,h]: Copyright (c) 1995-2001 Takya Ooura
+//
+// ASMLIB: Copyright (c) 2004 Agner Fog
+
+// This program is free software; you can redistribute it and/or modify it 
+// under the terms of the GNU General Public License as published by the 
+// Free Software Foundation; either version 2, or (at your option) any later
+// version.
+
+// This program is distributed in the hope that it will be useful, but WITHOUT
+// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
+// more details.
+
+// You should have received a copy of the GNU General Public License along
+// with this program; see the file COPYING.  If not, write to the Free Software
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+// In addition, as a special exception, the Regents of the University of
+// California give permission to link the code of this program with libraries
+// that provide specific optimized fast Fourier transform (FFT) functions
+// as an alternative to FFTW and distribute a linked executable and 
+// source code.  You must obey the GNU General Public License in all 
+// respects for all of the code used other than the FFT library itself.  
+// Any modification required to support these libraries must be distributed 
+// under the terms of this license.  If you modify this program, you may extend 
+// this exception to your version of the program, but you are not obligated to 
+// do so. If you do not wish to do so, delete this exception statement from 
+// your version.  Please be aware that FFTW and ASMLIB are not covered by 
+// this exception, therefore you may not use FFTW and ASMLIB in any derivative 
+// work so modified without permission of the authors of those packages.
+//
+
+#if defined(__arm__) && !defined(_RC_CHOP)
+
+// Exception masks
+#define _EM_INVALID     0x00000100      // Invalid Operation
+#define _EM_ZERODIVIDE  0x00000200      // Divide by zero
+#define _EM_OVERFLOW    0x00000400      // Overflow
+#define _EM_UNDERFLOW   0x00000800      // Underflow
+#define _EM_INEXACT     0x00001000      // Inexact result
+#define _EM_DENORMAL    0x00008000      // Denormal result
+#define _MCW_EM (_EM_INVALID|_EM_ZERODIVIDE|_EM_OVERFLOW|_EM_UNDERFLOW|_EM_INEXACT|_EM_DENORMAL)
+
+// Rounding control
+#define _RC_CHOP        0x000c0000      // Truncate
+#define _RC_DOWN        0x00080000      // Round down
+#define _RC_UP          0x00040000      // Round up
+#define _RC_NEAREST     0x00000000      // Round to nearest
+#define _MCW_RC (_RC_CHOP|_RC_UP|_RC_DOWN|_RC_NEAREST)
+
+#define _NAN_DEFAULT    0x00200000      // Use default NaN rather than propogating NaN
+#define _MCW_NAN _NAN_DEFAULT  
+
+#define _FLUSH_TO_ZERO  0x00100000      // Replaces denormalized numbers with zero
+#define _MCW_FLUSH_TO_ZERO _FLUSH_TO_ZERO
+
+#if 0
+These VFP vector mode has been deprecated
+#define _VECTOR_LEN(x) ((((x)-1)&7)<<16)  // Set length of vectors to x 
+#define _MCW_VECTOR_LEN_MASK _VECTOR_LEN(8)
+
+#define _VECTOR_STRIDE(x) (((x)==2)?(3<<20):0)
+#define _MCW_VECTOR_STRIDE_MASK (3<<20)
+#endif
+
+static unsigned int save_cw;
+
+inline static unsigned int controlfp(unsigned int flags, unsigned int mask)  {
+    register unsigned int cw;
+    __asm__ __volatile__ (
+      "fmrx %0,fpscr\n"
+      : "=r" (cw)
+    );
+    save_cw=cw;
+    cw=(cw & ~mask) | (flags & mask);
+    __asm__ __volatile__ (
+      "fmxr fpscr,%0\n"
+      : : "r" (cw)
+    );
+    return cw;
+}
+
+inline static unsigned int restorefp() {
+    __asm__ __volatile__ (
+      "fmxr fpscr,%0\n"
+      : : "r" (save_cw)
+    );
+    return save_cw;
+}
+
+#endif
+
diff --git a/client/vector/hires_timer.cpp b/client/vector/hires_timer.cpp
index 2c7979b..e46b913 100644
--- a/client/vector/hires_timer.cpp
+++ b/client/vector/hires_timer.cpp
@@ -41,13 +41,17 @@
 #include "hires_timer.h"
 #include "diagnostics.h"
 #include <cmath>
-#include <time.h>
 
 #ifdef HAVE_SYS_TYPES_H
 #include <sys/types.h>
 #endif
 #ifdef HAVE_SYS_TIME_H
 #include <sys/time.h>
+#ifdef TIME_WITH_SYS_TIME
+#include <time.h>
+#endif
+#else
+#include <time.h>
 #endif
 #ifdef HAVE_MACH_MACH_TIME_H
 #include <mach/mach_time.h>
@@ -194,6 +198,25 @@ static inline tick_t get_ticks() {
   return __rdtsc();
 }
 
+#elif defined(HAVE_CLOCK_GETTIME)
+
+#if defined(CLOCK_PROCESS_CPUTIME_ID)
+#define METHOD CLOCK_PROCESS_CPUTIME_ID
+#elif defined(CLOCK_MONOTONIC)
+#define METHOD CLOCK_MONOTONIC
+#elif defined(CLOCK_REALTIME)
+#define METHOD CLOCK_REALTIME
+#elif defined(CLOCK_SGI_CYCLE) 
+#define METHOD CLOCK_SGI_CYCLE
+#endif
+
+static inline tick_t get_ticks() {
+     struct timespec t;
+     clock_gettime(METHOD, &t);
+     return static_cast<tick_t>(t.tv_nsec)+static_cast<tick_t>(t.tv_sec)*static_cast<tick_t>(1000000000LL);
+}
+
+
 #elif defined(HAVE_MICROTIME) 
 static inline tick_t get_ticks() {
   struct timeval tsp;
diff --git a/client/vector/hires_timer.h b/client/vector/hires_timer.h
index a8134e8..db571c2 100644
--- a/client/vector/hires_timer.h
+++ b/client/vector/hires_timer.h
@@ -37,6 +37,7 @@
 // $Id: hires_timer.h,v 1.1.2.4 2006/12/14 22:22:00 korpela Exp $
 //
 #include "sah_config.h"
+#include <cstdio>
 #ifdef HAVE_INTTYPES_H
 #include <inttypes.h>
 #endif
@@ -45,9 +46,13 @@
 #endif
 #ifdef HAVE_SYS_TIME_H
 #include <sys/time.h>
-#elif defined(HAVE_TIME_H)
+#ifdef TIME_WITH_SYS_TIME
 #include <time.h>
 #endif
+#else
+#include <time.h>
+#endif
+
 
 #if defined(HAVE_HRTIME_T) && defined(HAVE_GETHRTIME)
 typedef hrtime_t tick_t;
diff --git a/client/worker.cpp b/client/worker.cpp
index d798c9a..bcf1a43 100644
--- a/client/worker.cpp
+++ b/client/worker.cpp
@@ -56,6 +56,10 @@
 #include "filesys.h"
 #include "boinc_api.h"
 
+#ifdef __arm__
+#include <vector/fp_arm.h>
+#endif
+
 #include "worker.h"
 
 using std::string;
@@ -143,6 +147,12 @@ void worker() {
 #if defined(__GNUC__) && defined (__i386__)
   __asm__ __volatile__ ("andl $-16, %esp");
 #endif
+
+// Set up the FPU if necessary.
+#ifdef __arm__
+  controlfp(_RC_NEAREST|_NAN_DEFAULT|_FLUSH_TO_ZERO,_MCW_EM|_MCW_RC|_MCW_NAN|_MCW_FLUSH_TO_ZERO);
+#endif
+
   try {
     retval = common_init();
     if (retval) SETIERROR(retval,"from common_init() in worker()");
diff --git a/compile b/compile
deleted file mode 100755
index 9bb997a..0000000
--- a/compile
+++ /dev/null
@@ -1,99 +0,0 @@
-#! /bin/sh
-
-# Wrapper for compilers which do not understand `-c -o'.
-
-# Copyright 1999, 2000 Free Software Foundation, Inc.
-# Written by Tom Tromey <tromey at cygnus.com>.
-#
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2, or (at your option)
-# any later version.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-# Usage:
-# compile PROGRAM [ARGS]...
-# `-o FOO.o' is removed from the args passed to the actual compile.
-
-prog=$1
-shift
-
-ofile=
-cfile=
-args=
-while test $# -gt 0; do
-   case "$1" in
-    -o)
-       # configure might choose to run compile as `compile cc -o foo foo.c'.
-       # So we do something ugly here.
-       ofile=$2
-       shift
-       case "$ofile" in
-	*.o | *.obj)
-	   ;;
-	*)
-	   args="$args -o $ofile"
-	   ofile=
-	   ;;
-       esac
-       ;;
-    *.c)
-       cfile=$1
-       args="$args $1"
-       ;;
-    *)
-       args="$args $1"
-       ;;
-   esac
-   shift
-done
-
-if test -z "$ofile" || test -z "$cfile"; then
-   # If no `-o' option was seen then we might have been invoked from a
-   # pattern rule where we don't need one.  That is ok -- this is a
-   # normal compilation that the losing compiler can handle.  If no
-   # `.c' file was seen then we are probably linking.  That is also
-   # ok.
-   exec "$prog" $args
-fi
-
-# Name of file we expect compiler to create.
-cofile=`echo $cfile | sed -e 's|^.*/||' -e 's/\.c$/.o/'`
-
-# Create the lock directory.
-# Note: use `[/.-]' here to ensure that we don't use the same name
-# that we are using for the .o file.  Also, base the name on the expected
-# object file name, since that is what matters with a parallel build.
-lockdir=`echo $cofile | sed -e 's|[/.-]|_|g'`.d
-while true; do
-   if mkdir $lockdir > /dev/null 2>&1; then
-      break
-   fi
-   sleep 1
-done
-# FIXME: race condition here if user kills between mkdir and trap.
-trap "rmdir $lockdir; exit 1" 1 2 15
-
-# Run the compile.
-"$prog" $args
-status=$?
-
-if test -f "$cofile"; then
-   mv "$cofile" "$ofile"
-fi
-
-rmdir $lockdir
-exit $status
diff --git a/config.guess b/config.guess
deleted file mode 100755
index 45bee13..0000000
--- a/config.guess
+++ /dev/null
@@ -1,1465 +0,0 @@
-#! /bin/sh
-# Attempt to guess a canonical system name.
-#   Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
-#   2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
-
-timestamp='2005-04-22'
-
-# This file is free software; you can redistribute it and/or modify it
-# under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful, but
-# WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-# General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-#
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-# Originally written by Per Bothner <per at bothner.com>.
-# Please send patches to <config-patches at gnu.org>.  Submit a context
-# diff and a properly formatted ChangeLog entry.
-#
-# This script attempts to guess a canonical system name similar to
-# config.sub.  If it succeeds, it prints the system name on stdout, and
-# exits with 0.  Otherwise, it exits with 1.
-#
-# The plan is that this can be called by configure scripts if you
-# don't specify an explicit build system type.
-
-me=`echo "$0" | sed -e 's,.*/,,'`
-
-usage="\
-Usage: $0 [OPTION]
-
-Output the configuration name of the system \`$me' is run on.
-
-Operation modes:
-  -h, --help         print this help, then exit
-  -t, --time-stamp   print date of last modification, then exit
-  -v, --version      print version number, then exit
-
-Report bugs and patches to <config-patches at gnu.org>."
-
-version="\
-GNU config.guess ($timestamp)
-
-Originally written by Per Bothner.
-Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005
-Free Software Foundation, Inc.
-
-This is free software; see the source for copying conditions.  There is NO
-warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
-
-help="
-Try \`$me --help' for more information."
-
-# Parse command line
-while test $# -gt 0 ; do
-  case $1 in
-    --time-stamp | --time* | -t )
-       echo "$timestamp" ; exit 0 ;;
-    --version | -v )
-       echo "$version" ; exit 0 ;;
-    --help | --h* | -h )
-       echo "$usage"; exit 0 ;;
-    -- )     # Stop option processing
-       shift; break ;;
-    - )	# Use stdin as input.
-       break ;;
-    -* )
-       echo "$me: invalid option $1$help" >&2
-       exit 1 ;;
-    * )
-       break ;;
-  esac
-done
-
-if test $# != 0; then
-  echo "$me: too many arguments$help" >&2
-  exit 1
-fi
-
-trap 'exit 1' 1 2 15
-
-# CC_FOR_BUILD -- compiler used by this script. Note that the use of a
-# compiler to aid in system detection is discouraged as it requires
-# temporary files to be created and, as you can see below, it is a
-# headache to deal with in a portable fashion.
-
-# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still
-# use `HOST_CC' if defined, but it is deprecated.
-
-# Portable tmp directory creation inspired by the Autoconf team.
-
-set_cc_for_build='
-trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ;
-trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ;
-: ${TMPDIR=/tmp} ;
- { tmp=`(umask 077 && mktemp -d -q "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } ||
- { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } ||
- { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } ||
- { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ;
-dummy=$tmp/dummy ;
-tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ;
-case $CC_FOR_BUILD,$HOST_CC,$CC in
- ,,)    echo "int x;" > $dummy.c ;
-	for c in cc gcc c89 c99 ; do
-	  if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then
-	     CC_FOR_BUILD="$c"; break ;
-	  fi ;
-	done ;
-	if test x"$CC_FOR_BUILD" = x ; then
-	  CC_FOR_BUILD=no_compiler_found ;
-	fi
-	;;
- ,,*)   CC_FOR_BUILD=$CC ;;
- ,*,*)  CC_FOR_BUILD=$HOST_CC ;;
-esac ;'
-
-# This is needed to find uname on a Pyramid OSx when run in the BSD universe.
-# (ghazi at noc.rutgers.edu 1994-08-24)
-if (test -f /.attbin/uname) >/dev/null 2>&1 ; then
-	PATH=$PATH:/.attbin ; export PATH
-fi
-
-UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown
-UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown
-UNAME_SYSTEM=`(uname -s) 2>/dev/null`  || UNAME_SYSTEM=unknown
-UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
-
-# Note: order is significant - the case branches are not exclusive.
-
-case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
-    *:NetBSD:*:*)
-	# NetBSD (nbsd) targets should (where applicable) match one or
-	# more of the tupples: *-*-netbsdelf*, *-*-netbsdaout*,
-	# *-*-netbsdecoff* and *-*-netbsd*.  For targets that recently
-	# switched to ELF, *-*-netbsd* would select the old
-	# object file format.  This provides both forward
-	# compatibility and a consistent mechanism for selecting the
-	# object file format.
-	#
-	# Note: NetBSD doesn't particularly care about the vendor
-	# portion of the name.  We always set it to "unknown".
-	sysctl="sysctl -n hw.machine_arch"
-	UNAME_MACHINE_ARCH=`(/sbin/$sysctl 2>/dev/null || \
-	    /usr/sbin/$sysctl 2>/dev/null || echo unknown)`
-	case "${UNAME_MACHINE_ARCH}" in
-	    armeb) machine=armeb-unknown ;;
-	    arm*) machine=arm-unknown ;;
-	    sh3el) machine=shl-unknown ;;
-	    sh3eb) machine=sh-unknown ;;
-	    *) machine=${UNAME_MACHINE_ARCH}-unknown ;;
-	esac
-	# The Operating System including object format, if it has switched
-	# to ELF recently, or will in the future.
-	case "${UNAME_MACHINE_ARCH}" in
-	    arm*|i386|m68k|ns32k|sh3*|sparc|vax)
-		eval $set_cc_for_build
-		if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
-			| grep __ELF__ >/dev/null
-		then
-		    # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout).
-		    # Return netbsd for either.  FIX?
-		    os=netbsd
-		else
-		    os=netbsdelf
-		fi
-		;;
-	    *)
-	        os=netbsd
-		;;
-	esac
-	# The OS release
-	# Debian GNU/NetBSD machines have a different userland, and
-	# thus, need a distinct triplet. However, they do not need
-	# kernel version information, so it can be replaced with a
-	# suitable tag, in the style of linux-gnu.
-	case "${UNAME_VERSION}" in
-	    Debian*)
-		release='-gnu'
-		;;
-	    *)
-		release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'`
-		;;
-	esac
-	# Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
-	# contains redundant information, the shorter form:
-	# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used.
-	echo "${machine}-${os}${release}"
-	exit 0 ;;
-    amd64:OpenBSD:*:*)
-	echo x86_64-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    amiga:OpenBSD:*:*)
-	echo m68k-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    cats:OpenBSD:*:*)
-	echo arm-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    hp300:OpenBSD:*:*)
-	echo m68k-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    luna88k:OpenBSD:*:*)
-    	echo m88k-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    mac68k:OpenBSD:*:*)
-	echo m68k-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    macppc:OpenBSD:*:*)
-	echo powerpc-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    mvme68k:OpenBSD:*:*)
-	echo m68k-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    mvme88k:OpenBSD:*:*)
-	echo m88k-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    mvmeppc:OpenBSD:*:*)
-	echo powerpc-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    sgi:OpenBSD:*:*)
-	echo mips64-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    sun3:OpenBSD:*:*)
-	echo m68k-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    *:OpenBSD:*:*)
-	echo ${UNAME_MACHINE}-unknown-openbsd${UNAME_RELEASE}
-	exit 0 ;;
-    *:ekkoBSD:*:*)
-	echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE}
-	exit 0 ;;
-    macppc:MirBSD:*:*)
-	echo powerppc-unknown-mirbsd${UNAME_RELEASE}
-	exit 0 ;;
-    *:MirBSD:*:*)
-	echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE}
-	exit 0 ;;
-    alpha:OSF1:*:*)
-	case $UNAME_RELEASE in
-	*4.0)
-		UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'`
-		;;
-	*5.*)
-	        UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'`
-		;;
-	esac
-	# According to Compaq, /usr/sbin/psrinfo has been available on
-	# OSF/1 and Tru64 systems produced since 1995.  I hope that
-	# covers most systems running today.  This code pipes the CPU
-	# types through head -n 1, so we only detect the type of CPU 0.
-	ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^  The alpha \(.*\) processor.*$/\1/p' | head -n 1`
-	case "$ALPHA_CPU_TYPE" in
-	    "EV4 (21064)")
-		UNAME_MACHINE="alpha" ;;
-	    "EV4.5 (21064)")
-		UNAME_MACHINE="alpha" ;;
-	    "LCA4 (21066/21068)")
-		UNAME_MACHINE="alpha" ;;
-	    "EV5 (21164)")
-		UNAME_MACHINE="alphaev5" ;;
-	    "EV5.6 (21164A)")
-		UNAME_MACHINE="alphaev56" ;;
-	    "EV5.6 (21164PC)")
-		UNAME_MACHINE="alphapca56" ;;
-	    "EV5.7 (21164PC)")
-		UNAME_MACHINE="alphapca57" ;;
-	    "EV6 (21264)")
-		UNAME_MACHINE="alphaev6" ;;
-	    "EV6.7 (21264A)")
-		UNAME_MACHINE="alphaev67" ;;
-	    "EV6.8CB (21264C)")
-		UNAME_MACHINE="alphaev68" ;;
-	    "EV6.8AL (21264B)")
-		UNAME_MACHINE="alphaev68" ;;
-	    "EV6.8CX (21264D)")
-		UNAME_MACHINE="alphaev68" ;;
-	    "EV6.9A (21264/EV69A)")
-		UNAME_MACHINE="alphaev69" ;;
-	    "EV7 (21364)")
-		UNAME_MACHINE="alphaev7" ;;
-	    "EV7.9 (21364A)")
-		UNAME_MACHINE="alphaev79" ;;
-	esac
-	# A Pn.n version is a patched version.
-	# A Vn.n version is a released version.
-	# A Tn.n version is a released field test version.
-	# A Xn.n version is an unreleased experimental baselevel.
-	# 1.2 uses "1.2" for uname -r.
-	echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
-	exit 0 ;;
-    Alpha\ *:Windows_NT*:*)
-	# How do we know it's Interix rather than the generic POSIX subsystem?
-	# Should we change UNAME_MACHINE based on the output of uname instead
-	# of the specific Alpha model?
-	echo alpha-pc-interix
-	exit 0 ;;
-    21064:Windows_NT:50:3)
-	echo alpha-dec-winnt3.5
-	exit 0 ;;
-    Amiga*:UNIX_System_V:4.0:*)
-	echo m68k-unknown-sysv4
-	exit 0;;
-    *:[Aa]miga[Oo][Ss]:*:*)
-	echo ${UNAME_MACHINE}-unknown-amigaos
-	exit 0 ;;
-    *:[Mm]orph[Oo][Ss]:*:*)
-	echo ${UNAME_MACHINE}-unknown-morphos
-	exit 0 ;;
-    *:OS/390:*:*)
-	echo i370-ibm-openedition
-	exit 0 ;;
-    *:z/VM:*:*)
-	echo s390-ibm-zvmoe
-	exit 0 ;;
-    *:OS400:*:*)
-        echo powerpc-ibm-os400
-	exit 0 ;;
-    arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
-	echo arm-acorn-riscix${UNAME_RELEASE}
-	exit 0;;
-    SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*)
-	echo hppa1.1-hitachi-hiuxmpp
-	exit 0;;
-    Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*)
-	# akee at wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE.
-	if test "`(/bin/universe) 2>/dev/null`" = att ; then
-		echo pyramid-pyramid-sysv3
-	else
-		echo pyramid-pyramid-bsd
-	fi
-	exit 0 ;;
-    NILE*:*:*:dcosx)
-	echo pyramid-pyramid-svr4
-	exit 0 ;;
-    DRS?6000:unix:4.0:6*)
-	echo sparc-icl-nx6
-	exit 0 ;;
-    DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*)
-	case `/usr/bin/uname -p` in
-	    sparc) echo sparc-icl-nx7 && exit 0 ;;
-	esac ;;
-    sun4H:SunOS:5.*:*)
-	echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
-	exit 0 ;;
-    sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*)
-	echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
-	exit 0 ;;
-    i86pc:SunOS:5.*:*)
-	echo i386-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
-	exit 0 ;;
-    sun4*:SunOS:6*:*)
-	# According to config.sub, this is the proper way to canonicalize
-	# SunOS6.  Hard to guess exactly what SunOS6 will be like, but
-	# it's likely to be more like Solaris than SunOS4.
-	echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
-	exit 0 ;;
-    sun4*:SunOS:*:*)
-	case "`/usr/bin/arch -k`" in
-	    Series*|S4*)
-		UNAME_RELEASE=`uname -v`
-		;;
-	esac
-	# Japanese Language versions have a version number like `4.1.3-JL'.
-	echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'`
-	exit 0 ;;
-    sun3*:SunOS:*:*)
-	echo m68k-sun-sunos${UNAME_RELEASE}
-	exit 0 ;;
-    sun*:*:4.2BSD:*)
-	UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null`
-	test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3
-	case "`/bin/arch`" in
-	    sun3)
-		echo m68k-sun-sunos${UNAME_RELEASE}
-		;;
-	    sun4)
-		echo sparc-sun-sunos${UNAME_RELEASE}
-		;;
-	esac
-	exit 0 ;;
-    aushp:SunOS:*:*)
-	echo sparc-auspex-sunos${UNAME_RELEASE}
-	exit 0 ;;
-    # The situation for MiNT is a little confusing.  The machine name
-    # can be virtually everything (everything which is not
-    # "atarist" or "atariste" at least should have a processor
-    # > m68000).  The system name ranges from "MiNT" over "FreeMiNT"
-    # to the lowercase version "mint" (or "freemint").  Finally
-    # the system name "TOS" denotes a system which is actually not
-    # MiNT.  But MiNT is downward compatible to TOS, so this should
-    # be no problem.
-    atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*)
-        echo m68k-atari-mint${UNAME_RELEASE}
-	exit 0 ;;
-    atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*)
-	echo m68k-atari-mint${UNAME_RELEASE}
-        exit 0 ;;
-    *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*)
-        echo m68k-atari-mint${UNAME_RELEASE}
-	exit 0 ;;
-    milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*)
-        echo m68k-milan-mint${UNAME_RELEASE}
-        exit 0 ;;
-    hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*)
-        echo m68k-hades-mint${UNAME_RELEASE}
-        exit 0 ;;
-    *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*)
-        echo m68k-unknown-mint${UNAME_RELEASE}
-        exit 0 ;;
-    m68k:machten:*:*)
-	echo m68k-apple-machten${UNAME_RELEASE}
-	exit 0 ;;
-    powerpc:machten:*:*)
-	echo powerpc-apple-machten${UNAME_RELEASE}
-	exit 0 ;;
-    RISC*:Mach:*:*)
-	echo mips-dec-mach_bsd4.3
-	exit 0 ;;
-    RISC*:ULTRIX:*:*)
-	echo mips-dec-ultrix${UNAME_RELEASE}
-	exit 0 ;;
-    VAX*:ULTRIX*:*:*)
-	echo vax-dec-ultrix${UNAME_RELEASE}
-	exit 0 ;;
-    2020:CLIX:*:* | 2430:CLIX:*:*)
-	echo clipper-intergraph-clix${UNAME_RELEASE}
-	exit 0 ;;
-    mips:*:*:UMIPS | mips:*:*:RISCos)
-	eval $set_cc_for_build
-	sed 's/^	//' << EOF >$dummy.c
-#ifdef __cplusplus
-#include <stdio.h>  /* for printf() prototype */
-	int main (int argc, char *argv[]) {
-#else
-	int main (argc, argv) int argc; char *argv[]; {
-#endif
-	#if defined (host_mips) && defined (MIPSEB)
-	#if defined (SYSTYPE_SYSV)
-	  printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0);
-	#endif
-	#if defined (SYSTYPE_SVR4)
-	  printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0);
-	#endif
-	#if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD)
-	  printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0);
-	#endif
-	#endif
-	  exit (-1);
-	}
-EOF
-	$CC_FOR_BUILD -o $dummy $dummy.c \
-	  && $dummy `echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` \
-	  && exit 0
-	echo mips-mips-riscos${UNAME_RELEASE}
-	exit 0 ;;
-    Motorola:PowerMAX_OS:*:*)
-	echo powerpc-motorola-powermax
-	exit 0 ;;
-    Motorola:*:4.3:PL8-*)
-	echo powerpc-harris-powermax
-	exit 0 ;;
-    Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*)
-	echo powerpc-harris-powermax
-	exit 0 ;;
-    Night_Hawk:Power_UNIX:*:*)
-	echo powerpc-harris-powerunix
-	exit 0 ;;
-    m88k:CX/UX:7*:*)
-	echo m88k-harris-cxux7
-	exit 0 ;;
-    m88k:*:4*:R4*)
-	echo m88k-motorola-sysv4
-	exit 0 ;;
-    m88k:*:3*:R3*)
-	echo m88k-motorola-sysv3
-	exit 0 ;;
-    AViiON:dgux:*:*)
-        # DG/UX returns AViiON for all architectures
-        UNAME_PROCESSOR=`/usr/bin/uname -p`
-	if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ]
-	then
-	    if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \
-	       [ ${TARGET_BINARY_INTERFACE}x = x ]
-	    then
-		echo m88k-dg-dgux${UNAME_RELEASE}
-	    else
-		echo m88k-dg-dguxbcs${UNAME_RELEASE}
-	    fi
-	else
-	    echo i586-dg-dgux${UNAME_RELEASE}
-	fi
- 	exit 0 ;;
-    M88*:DolphinOS:*:*)	# DolphinOS (SVR3)
-	echo m88k-dolphin-sysv3
-	exit 0 ;;
-    M88*:*:R3*:*)
-	# Delta 88k system running SVR3
-	echo m88k-motorola-sysv3
-	exit 0 ;;
-    XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3)
-	echo m88k-tektronix-sysv3
-	exit 0 ;;
-    Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD)
-	echo m68k-tektronix-bsd
-	exit 0 ;;
-    *:IRIX*:*:*)
-	echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'`
-	exit 0 ;;
-    ????????:AIX?:[12].1:2)   # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX.
-	echo romp-ibm-aix      # uname -m gives an 8 hex-code CPU id
-	exit 0 ;;              # Note that: echo "'`uname -s`'" gives 'AIX '
-    i*86:AIX:*:*)
-	echo i386-ibm-aix
-	exit 0 ;;
-    ia64:AIX:*:*)
-	if [ -x /usr/bin/oslevel ] ; then
-		IBM_REV=`/usr/bin/oslevel`
-	else
-		IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
-	fi
-	echo ${UNAME_MACHINE}-ibm-aix${IBM_REV}
-	exit 0 ;;
-    *:AIX:2:3)
-	if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then
-		eval $set_cc_for_build
-		sed 's/^		//' << EOF >$dummy.c
-		#include <sys/systemcfg.h>
-
-		main()
-			{
-			if (!__power_pc())
-				exit(1);
-			puts("powerpc-ibm-aix3.2.5");
-			exit(0);
-			}
-EOF
-		$CC_FOR_BUILD -o $dummy $dummy.c && $dummy && exit 0
-		echo rs6000-ibm-aix3.2.5
-	elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then
-		echo rs6000-ibm-aix3.2.4
-	else
-		echo rs6000-ibm-aix3.2
-	fi
-	exit 0 ;;
-    *:AIX:*:[45])
-	IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'`
-	if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then
-		IBM_ARCH=rs6000
-	else
-		IBM_ARCH=powerpc
-	fi
-	if [ -x /usr/bin/oslevel ] ; then
-		IBM_REV=`/usr/bin/oslevel`
-	else
-		IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
-	fi
-	echo ${IBM_ARCH}-ibm-aix${IBM_REV}
-	exit 0 ;;
-    *:AIX:*:*)
-	echo rs6000-ibm-aix
-	exit 0 ;;
-    ibmrt:4.4BSD:*|romp-ibm:BSD:*)
-	echo romp-ibm-bsd4.4
-	exit 0 ;;
-    ibmrt:*BSD:*|romp-ibm:BSD:*)            # covers RT/PC BSD and
-	echo romp-ibm-bsd${UNAME_RELEASE}   # 4.3 with uname added to
-	exit 0 ;;                           # report: romp-ibm BSD 4.3
-    *:BOSX:*:*)
-	echo rs6000-bull-bosx
-	exit 0 ;;
-    DPX/2?00:B.O.S.:*:*)
-	echo m68k-bull-sysv3
-	exit 0 ;;
-    9000/[34]??:4.3bsd:1.*:*)
-	echo m68k-hp-bsd
-	exit 0 ;;
-    hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*)
-	echo m68k-hp-bsd4.4
-	exit 0 ;;
-    9000/[34678]??:HP-UX:*:*)
-	HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
-	case "${UNAME_MACHINE}" in
-	    9000/31? )            HP_ARCH=m68000 ;;
-	    9000/[34]?? )         HP_ARCH=m68k ;;
-	    9000/[678][0-9][0-9])
-		if [ -x /usr/bin/getconf ]; then
-		    sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null`
-                    sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null`
-                    case "${sc_cpu_version}" in
-                      523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0
-                      528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1
-                      532)                      # CPU_PA_RISC2_0
-                        case "${sc_kernel_bits}" in
-                          32) HP_ARCH="hppa2.0n" ;;
-                          64) HP_ARCH="hppa2.0w" ;;
-			  '') HP_ARCH="hppa2.0" ;;   # HP-UX 10.20
-                        esac ;;
-                    esac
-		fi
-		if [ "${HP_ARCH}" = "" ]; then
-		    eval $set_cc_for_build
-		    sed 's/^              //' << EOF >$dummy.c
-
-              #define _HPUX_SOURCE
-              #include <stdlib.h>
-              #include <unistd.h>
-
-              int main ()
-              {
-              #if defined(_SC_KERNEL_BITS)
-                  long bits = sysconf(_SC_KERNEL_BITS);
-              #endif
-                  long cpu  = sysconf (_SC_CPU_VERSION);
-
-                  switch (cpu)
-              	{
-              	case CPU_PA_RISC1_0: puts ("hppa1.0"); break;
-              	case CPU_PA_RISC1_1: puts ("hppa1.1"); break;
-              	case CPU_PA_RISC2_0:
-              #if defined(_SC_KERNEL_BITS)
-              	    switch (bits)
-              		{
-              		case 64: puts ("hppa2.0w"); break;
-              		case 32: puts ("hppa2.0n"); break;
-              		default: puts ("hppa2.0"); break;
-              		} break;
-              #else  /* !defined(_SC_KERNEL_BITS) */
-              	    puts ("hppa2.0"); break;
-              #endif
-              	default: puts ("hppa1.0"); break;
-              	}
-                  exit (0);
-              }
-EOF
-		    (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy`
-		    test -z "$HP_ARCH" && HP_ARCH=hppa
-		fi ;;
-	esac
-	if [ ${HP_ARCH} = "hppa2.0w" ]
-	then
-	    # avoid double evaluation of $set_cc_for_build
-	    test -n "$CC_FOR_BUILD" || eval $set_cc_for_build
-	    if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E -) | grep __LP64__ >/dev/null
-	    then
-		HP_ARCH="hppa2.0w"
-	    else
-		HP_ARCH="hppa64"
-	    fi
-	fi
-	echo ${HP_ARCH}-hp-hpux${HPUX_REV}
-	exit 0 ;;
-    ia64:HP-UX:*:*)
-	HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
-	echo ia64-hp-hpux${HPUX_REV}
-	exit 0 ;;
-    3050*:HI-UX:*:*)
-	eval $set_cc_for_build
-	sed 's/^	//' << EOF >$dummy.c
-	#include <unistd.h>
-	int
-	main ()
-	{
-	  long cpu = sysconf (_SC_CPU_VERSION);
-	  /* The order matters, because CPU_IS_HP_MC68K erroneously returns
-	     true for CPU_PA_RISC1_0.  CPU_IS_PA_RISC returns correct
-	     results, however.  */
-	  if (CPU_IS_PA_RISC (cpu))
-	    {
-	      switch (cpu)
-		{
-		  case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break;
-		  case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break;
-		  case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break;
-		  default: puts ("hppa-hitachi-hiuxwe2"); break;
-		}
-	    }
-	  else if (CPU_IS_HP_MC68K (cpu))
-	    puts ("m68k-hitachi-hiuxwe2");
-	  else puts ("unknown-hitachi-hiuxwe2");
-	  exit (0);
-	}
-EOF
-	$CC_FOR_BUILD -o $dummy $dummy.c && $dummy && exit 0
-	echo unknown-hitachi-hiuxwe2
-	exit 0 ;;
-    9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* )
-	echo hppa1.1-hp-bsd
-	exit 0 ;;
-    9000/8??:4.3bsd:*:*)
-	echo hppa1.0-hp-bsd
-	exit 0 ;;
-    *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*)
-	echo hppa1.0-hp-mpeix
-	exit 0 ;;
-    hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* )
-	echo hppa1.1-hp-osf
-	exit 0 ;;
-    hp8??:OSF1:*:*)
-	echo hppa1.0-hp-osf
-	exit 0 ;;
-    i*86:OSF1:*:*)
-	if [ -x /usr/sbin/sysversion ] ; then
-	    echo ${UNAME_MACHINE}-unknown-osf1mk
-	else
-	    echo ${UNAME_MACHINE}-unknown-osf1
-	fi
-	exit 0 ;;
-    parisc*:Lites*:*:*)
-	echo hppa1.1-hp-lites
-	exit 0 ;;
-    C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*)
-	echo c1-convex-bsd
-        exit 0 ;;
-    C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*)
-	if getsysinfo -f scalar_acc
-	then echo c32-convex-bsd
-	else echo c2-convex-bsd
-	fi
-        exit 0 ;;
-    C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*)
-	echo c34-convex-bsd
-        exit 0 ;;
-    C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*)
-	echo c38-convex-bsd
-        exit 0 ;;
-    C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*)
-	echo c4-convex-bsd
-        exit 0 ;;
-    CRAY*Y-MP:*:*:*)
-	echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
-	exit 0 ;;
-    CRAY*[A-Z]90:*:*:*)
-	echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \
-	| sed -e 's/CRAY.*\([A-Z]90\)/\1/' \
-	      -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \
-	      -e 's/\.[^.]*$/.X/'
-	exit 0 ;;
-    CRAY*TS:*:*:*)
-	echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
-	exit 0 ;;
-    CRAY*T3E:*:*:*)
-	echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
-	exit 0 ;;
-    CRAY*SV1:*:*:*)
-	echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
-	exit 0 ;;
-    *:UNICOS/mp:*:*)
-	echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
-	exit 0 ;;
-    F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*)
-	FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
-        FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
-        FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'`
-        echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
-        exit 0 ;;
-    5000:UNIX_System_V:4.*:*)
-        FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
-        FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'`
-        echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
-	exit 0 ;;
-    i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*)
-	echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE}
-	exit 0 ;;
-    sparc*:BSD/OS:*:*)
-	echo sparc-unknown-bsdi${UNAME_RELEASE}
-	exit 0 ;;
-    *:BSD/OS:*:*)
-	echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE}
-	exit 0 ;;
-    *:FreeBSD:*:*)
-	echo ${UNAME_MACHINE}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`
-	exit 0 ;;
-    i*:CYGWIN*:*)
-	echo ${UNAME_MACHINE}-pc-cygwin
-	exit 0 ;;
-    i*:MINGW*:*)
-	echo ${UNAME_MACHINE}-pc-mingw32
-	exit 0 ;;
-    i*:PW*:*)
-	echo ${UNAME_MACHINE}-pc-pw32
-	exit 0 ;;
-    x86:Interix*:[34]*)
-	echo i586-pc-interix${UNAME_RELEASE}|sed -e 's/\..*//'
-	exit 0 ;;
-    [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*)
-	echo i${UNAME_MACHINE}-pc-mks
-	exit 0 ;;
-    i*:Windows_NT*:* | Pentium*:Windows_NT*:*)
-	# How do we know it's Interix rather than the generic POSIX subsystem?
-	# It also conflicts with pre-2.0 versions of AT&T UWIN. Should we
-	# UNAME_MACHINE based on the output of uname instead of i386?
-	echo i586-pc-interix
-	exit 0 ;;
-    i*:UWIN*:*)
-	echo ${UNAME_MACHINE}-pc-uwin
-	exit 0 ;;
-    amd64:CYGWIN*:*:*)
-	echo x86_64-unknown-cygwin
-	exit 0 ;;
-    p*:CYGWIN*:*)
-	echo powerpcle-unknown-cygwin
-	exit 0 ;;
-    prep*:SunOS:5.*:*)
-	echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
-	exit 0 ;;
-    *:GNU:*:*)
-	# the GNU system
-	echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
-	exit 0 ;;
-    *:GNU/*:*:*)
-	# other systems with GNU libc and userland
-	echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-gnu
-	exit 0 ;;
-    i*86:Minix:*:*)
-	echo ${UNAME_MACHINE}-pc-minix
-	exit 0 ;;
-    arm*:Linux:*:*)
-	echo ${UNAME_MACHINE}-unknown-linux-gnu
-	exit 0 ;;
-    cris:Linux:*:*)
-	echo cris-axis-linux-gnu
-	exit 0 ;;
-    crisv32:Linux:*:*)
-	echo crisv32-axis-linux-gnu
-	exit 0 ;;
-    frv:Linux:*:*)
-    	echo frv-unknown-linux-gnu
-	exit 0 ;;
-    ia64:Linux:*:*)
-	echo ${UNAME_MACHINE}-unknown-linux-gnu
-	exit 0 ;;
-    m32r*:Linux:*:*)
-	echo ${UNAME_MACHINE}-unknown-linux-gnu
-	exit 0 ;;
-    m68*:Linux:*:*)
-	echo ${UNAME_MACHINE}-unknown-linux-gnu
-	exit 0 ;;
-    mips:Linux:*:*)
-	eval $set_cc_for_build
-	sed 's/^	//' << EOF >$dummy.c
-	#undef CPU
-	#undef mips
-	#undef mipsel
-	#if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL)
-	CPU=mipsel
-	#else
-	#if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB)
-	CPU=mips
-	#else
-	CPU=
-	#endif
-	#endif
-EOF
-	eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep ^CPU=`
-	test x"${CPU}" != x && echo "${CPU}-unknown-linux-gnu" && exit 0
-	;;
-    mips64:Linux:*:*)
-	eval $set_cc_for_build
-	sed 's/^	//' << EOF >$dummy.c
-	#undef CPU
-	#undef mips64
-	#undef mips64el
-	#if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL)
-	CPU=mips64el
-	#else
-	#if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB)
-	CPU=mips64
-	#else
-	CPU=
-	#endif
-	#endif
-EOF
-	eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep ^CPU=`
-	test x"${CPU}" != x && echo "${CPU}-unknown-linux-gnu" && exit 0
-	;;
-    ppc:Linux:*:*)
-	echo powerpc-unknown-linux-gnu
-	exit 0 ;;
-    ppc64:Linux:*:*)
-	echo powerpc64-unknown-linux-gnu
-	exit 0 ;;
-    alpha:Linux:*:*)
-	case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in
-	  EV5)   UNAME_MACHINE=alphaev5 ;;
-	  EV56)  UNAME_MACHINE=alphaev56 ;;
-	  PCA56) UNAME_MACHINE=alphapca56 ;;
-	  PCA57) UNAME_MACHINE=alphapca56 ;;
-	  EV6)   UNAME_MACHINE=alphaev6 ;;
-	  EV67)  UNAME_MACHINE=alphaev67 ;;
-	  EV68*) UNAME_MACHINE=alphaev68 ;;
-        esac
-	objdump --private-headers /bin/sh | grep ld.so.1 >/dev/null
-	if test "$?" = 0 ; then LIBC="libc1" ; else LIBC="" ; fi
-	echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC}
-	exit 0 ;;
-    parisc:Linux:*:* | hppa:Linux:*:*)
-	# Look for CPU level
-	case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in
-	  PA7*) echo hppa1.1-unknown-linux-gnu ;;
-	  PA8*) echo hppa2.0-unknown-linux-gnu ;;
-	  *)    echo hppa-unknown-linux-gnu ;;
-	esac
-	exit 0 ;;
-    parisc64:Linux:*:* | hppa64:Linux:*:*)
-	echo hppa64-unknown-linux-gnu
-	exit 0 ;;
-    s390:Linux:*:* | s390x:Linux:*:*)
-	echo ${UNAME_MACHINE}-ibm-linux
-	exit 0 ;;
-    sh64*:Linux:*:*)
-    	echo ${UNAME_MACHINE}-unknown-linux-gnu
-	exit 0 ;;
-    sh*:Linux:*:*)
-	echo ${UNAME_MACHINE}-unknown-linux-gnu
-	exit 0 ;;
-    sparc:Linux:*:* | sparc64:Linux:*:*)
-	echo ${UNAME_MACHINE}-unknown-linux-gnu
-	exit 0 ;;
-    x86_64:Linux:*:*)
-	echo x86_64-unknown-linux-gnu
-	exit 0 ;;
-    i*86:Linux:*:*)
-	# The BFD linker knows what the default object file format is, so
-	# first see if it will tell us. cd to the root directory to prevent
-	# problems with other programs or directories called `ld' in the path.
-	# Set LC_ALL=C to ensure ld outputs messages in English.
-	ld_supported_targets=`cd /; LC_ALL=C ld --help 2>&1 \
-			 | sed -ne '/supported targets:/!d
-				    s/[ 	][ 	]*/ /g
-				    s/.*supported targets: *//
-				    s/ .*//
-				    p'`
-        case "$ld_supported_targets" in
-	  elf32-i386)
-		TENTATIVE="${UNAME_MACHINE}-pc-linux-gnu"
-		;;
-	  a.out-i386-linux)
-		echo "${UNAME_MACHINE}-pc-linux-gnuaout"
-		exit 0 ;;
-	  coff-i386)
-		echo "${UNAME_MACHINE}-pc-linux-gnucoff"
-		exit 0 ;;
-	  "")
-		# Either a pre-BFD a.out linker (linux-gnuoldld) or
-		# one that does not give us useful --help.
-		echo "${UNAME_MACHINE}-pc-linux-gnuoldld"
-		exit 0 ;;
-	esac
-	# Determine whether the default compiler is a.out or elf
-	eval $set_cc_for_build
-	sed 's/^	//' << EOF >$dummy.c
-	#include <features.h>
-	#ifdef __ELF__
-	# ifdef __GLIBC__
-	#  if __GLIBC__ >= 2
-	LIBC=gnu
-	#  else
-	LIBC=gnulibc1
-	#  endif
-	# else
-	LIBC=gnulibc1
-	# endif
-	#else
-	#ifdef __INTEL_COMPILER
-	LIBC=gnu
-	#else
-	LIBC=gnuaout
-	#endif
-	#endif
-	#ifdef __dietlibc__
-	LIBC=dietlibc
-	#endif
-EOF
-	eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep ^LIBC=`
-	test x"${LIBC}" != x && echo "${UNAME_MACHINE}-pc-linux-${LIBC}" && exit 0
-	test x"${TENTATIVE}" != x && echo "${TENTATIVE}" && exit 0
-	;;
-    i*86:DYNIX/ptx:4*:*)
-	# ptx 4.0 does uname -s correctly, with DYNIX/ptx in there.
-	# earlier versions are messed up and put the nodename in both
-	# sysname and nodename.
-	echo i386-sequent-sysv4
-	exit 0 ;;
-    i*86:UNIX_SV:4.2MP:2.*)
-        # Unixware is an offshoot of SVR4, but it has its own version
-        # number series starting with 2...
-        # I am not positive that other SVR4 systems won't match this,
-	# I just have to hope.  -- rms.
-        # Use sysv4.2uw... so that sysv4* matches it.
-	echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION}
-	exit 0 ;;
-    i*86:OS/2:*:*)
-	# If we were able to find `uname', then EMX Unix compatibility
-	# is probably installed.
-	echo ${UNAME_MACHINE}-pc-os2-emx
-	exit 0 ;;
-    i*86:XTS-300:*:STOP)
-	echo ${UNAME_MACHINE}-unknown-stop
-	exit 0 ;;
-    i*86:atheos:*:*)
-	echo ${UNAME_MACHINE}-unknown-atheos
-	exit 0 ;;
-	i*86:syllable:*:*)
-	echo ${UNAME_MACHINE}-pc-syllable
-	exit 0 ;;
-    i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.0*:*)
-	echo i386-unknown-lynxos${UNAME_RELEASE}
-	exit 0 ;;
-    i*86:*DOS:*:*)
-	echo ${UNAME_MACHINE}-pc-msdosdjgpp
-	exit 0 ;;
-    i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*)
-	UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'`
-	if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then
-		echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL}
-	else
-		echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL}
-	fi
-	exit 0 ;;
-    i*86:*:5:[78]*)
-	case `/bin/uname -X | grep "^Machine"` in
-	    *486*)	     UNAME_MACHINE=i486 ;;
-	    *Pentium)	     UNAME_MACHINE=i586 ;;
-	    *Pent*|*Celeron) UNAME_MACHINE=i686 ;;
-	esac
-	echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION}
-	exit 0 ;;
-    i*86:*:3.2:*)
-	if test -f /usr/options/cb.name; then
-		UNAME_REL=`sed -n 's/.*Version //p' </usr/options/cb.name`
-		echo ${UNAME_MACHINE}-pc-isc$UNAME_REL
-	elif /bin/uname -X 2>/dev/null >/dev/null ; then
-		UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')`
-		(/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486
-		(/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \
-			&& UNAME_MACHINE=i586
-		(/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \
-			&& UNAME_MACHINE=i686
-		(/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \
-			&& UNAME_MACHINE=i686
-		echo ${UNAME_MACHINE}-pc-sco$UNAME_REL
-	else
-		echo ${UNAME_MACHINE}-pc-sysv32
-	fi
-	exit 0 ;;
-    pc:*:*:*)
-	# Left here for compatibility:
-        # uname -m prints for DJGPP always 'pc', but it prints nothing about
-        # the processor, so we play safe by assuming i386.
-	echo i386-pc-msdosdjgpp
-        exit 0 ;;
-    Intel:Mach:3*:*)
-	echo i386-pc-mach3
-	exit 0 ;;
-    paragon:*:*:*)
-	echo i860-intel-osf1
-	exit 0 ;;
-    i860:*:4.*:*) # i860-SVR4
-	if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then
-	  echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4
-	else # Add other i860-SVR4 vendors below as they are discovered.
-	  echo i860-unknown-sysv${UNAME_RELEASE}  # Unknown i860-SVR4
-	fi
-	exit 0 ;;
-    mini*:CTIX:SYS*5:*)
-	# "miniframe"
-	echo m68010-convergent-sysv
-	exit 0 ;;
-    mc68k:UNIX:SYSTEM5:3.51m)
-	echo m68k-convergent-sysv
-	exit 0 ;;
-    M680?0:D-NIX:5.3:*)
-	echo m68k-diab-dnix
-	exit 0 ;;
-    M68*:*:R3V[5678]*:*)
-	test -r /sysV68 && echo 'm68k-motorola-sysv' && exit 0 ;;
-    3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0)
-	OS_REL=''
-	test -r /etc/.relid \
-	&& OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
-	/bin/uname -p 2>/dev/null | grep 86 >/dev/null \
-	  && echo i486-ncr-sysv4.3${OS_REL} && exit 0
-	/bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \
-	  && echo i586-ncr-sysv4.3${OS_REL} && exit 0 ;;
-    3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*)
-        /bin/uname -p 2>/dev/null | grep 86 >/dev/null \
-          && echo i486-ncr-sysv4 && exit 0 ;;
-    m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*)
-	echo m68k-unknown-lynxos${UNAME_RELEASE}
-	exit 0 ;;
-    mc68030:UNIX_System_V:4.*:*)
-	echo m68k-atari-sysv4
-	exit 0 ;;
-    TSUNAMI:LynxOS:2.*:*)
-	echo sparc-unknown-lynxos${UNAME_RELEASE}
-	exit 0 ;;
-    rs6000:LynxOS:2.*:*)
-	echo rs6000-unknown-lynxos${UNAME_RELEASE}
-	exit 0 ;;
-    PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.0*:*)
-	echo powerpc-unknown-lynxos${UNAME_RELEASE}
-	exit 0 ;;
-    SM[BE]S:UNIX_SV:*:*)
-	echo mips-dde-sysv${UNAME_RELEASE}
-	exit 0 ;;
-    RM*:ReliantUNIX-*:*:*)
-	echo mips-sni-sysv4
-	exit 0 ;;
-    RM*:SINIX-*:*:*)
-	echo mips-sni-sysv4
-	exit 0 ;;
-    *:SINIX-*:*:*)
-	if uname -p 2>/dev/null >/dev/null ; then
-		UNAME_MACHINE=`(uname -p) 2>/dev/null`
-		echo ${UNAME_MACHINE}-sni-sysv4
-	else
-		echo ns32k-sni-sysv
-	fi
-	exit 0 ;;
-    PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort
-                      # says <Richard.M.Bartel at ccMail.Census.GOV>
-        echo i586-unisys-sysv4
-        exit 0 ;;
-    *:UNIX_System_V:4*:FTX*)
-	# From Gerald Hewes <hewes at openmarket.com>.
-	# How about differentiating between stratus architectures? -djm
-	echo hppa1.1-stratus-sysv4
-	exit 0 ;;
-    *:*:*:FTX*)
-	# From seanf at swdc.stratus.com.
-	echo i860-stratus-sysv4
-	exit 0 ;;
-    i*86:VOS:*:*)
-	# From Paul.Green at stratus.com.
-	echo ${UNAME_MACHINE}-stratus-vos
-	exit 0 ;;
-    *:VOS:*:*)
-	# From Paul.Green at stratus.com.
-	echo hppa1.1-stratus-vos
-	exit 0 ;;
-    mc68*:A/UX:*:*)
-	echo m68k-apple-aux${UNAME_RELEASE}
-	exit 0 ;;
-    news*:NEWS-OS:6*:*)
-	echo mips-sony-newsos6
-	exit 0 ;;
-    R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*)
-	if [ -d /usr/nec ]; then
-	        echo mips-nec-sysv${UNAME_RELEASE}
-	else
-	        echo mips-unknown-sysv${UNAME_RELEASE}
-	fi
-        exit 0 ;;
-    BeBox:BeOS:*:*)	# BeOS running on hardware made by Be, PPC only.
-	echo powerpc-be-beos
-	exit 0 ;;
-    BeMac:BeOS:*:*)	# BeOS running on Mac or Mac clone, PPC only.
-	echo powerpc-apple-beos
-	exit 0 ;;
-    BePC:BeOS:*:*)	# BeOS running on Intel PC compatible.
-	echo i586-pc-beos
-	exit 0 ;;
-    SX-4:SUPER-UX:*:*)
-	echo sx4-nec-superux${UNAME_RELEASE}
-	exit 0 ;;
-    SX-5:SUPER-UX:*:*)
-	echo sx5-nec-superux${UNAME_RELEASE}
-	exit 0 ;;
-    SX-6:SUPER-UX:*:*)
-	echo sx6-nec-superux${UNAME_RELEASE}
-	exit 0 ;;
-    Power*:Rhapsody:*:*)
-	echo powerpc-apple-rhapsody${UNAME_RELEASE}
-	exit 0 ;;
-    *:Rhapsody:*:*)
-	echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE}
-	exit 0 ;;
-    *:Darwin:*:*)
-	UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown
-	case $UNAME_PROCESSOR in
-	    *86) UNAME_PROCESSOR=i686 ;;
-	    unknown) UNAME_PROCESSOR=powerpc ;;
-	esac
-	echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE}
-	exit 0 ;;
-    *:procnto*:*:* | *:QNX:[0123456789]*:*)
-	UNAME_PROCESSOR=`uname -p`
-	if test "$UNAME_PROCESSOR" = "x86"; then
-		UNAME_PROCESSOR=i386
-		UNAME_MACHINE=pc
-	fi
-	echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE}
-	exit 0 ;;
-    *:QNX:*:4*)
-	echo i386-pc-qnx
-	exit 0 ;;
-    NSE-?:NONSTOP_KERNEL:*:*)
-	echo nse-tandem-nsk${UNAME_RELEASE}
-	exit 0 ;;
-    NSR-?:NONSTOP_KERNEL:*:*)
-	echo nsr-tandem-nsk${UNAME_RELEASE}
-	exit 0 ;;
-    *:NonStop-UX:*:*)
-	echo mips-compaq-nonstopux
-	exit 0 ;;
-    BS2000:POSIX*:*:*)
-	echo bs2000-siemens-sysv
-	exit 0 ;;
-    DS/*:UNIX_System_V:*:*)
-	echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE}
-	exit 0 ;;
-    *:Plan9:*:*)
-	# "uname -m" is not consistent, so use $cputype instead. 386
-	# is converted to i386 for consistency with other x86
-	# operating systems.
-	if test "$cputype" = "386"; then
-	    UNAME_MACHINE=i386
-	else
-	    UNAME_MACHINE="$cputype"
-	fi
-	echo ${UNAME_MACHINE}-unknown-plan9
-	exit 0 ;;
-    *:TOPS-10:*:*)
-	echo pdp10-unknown-tops10
-	exit 0 ;;
-    *:TENEX:*:*)
-	echo pdp10-unknown-tenex
-	exit 0 ;;
-    KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*)
-	echo pdp10-dec-tops20
-	exit 0 ;;
-    XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*)
-	echo pdp10-xkl-tops20
-	exit 0 ;;
-    *:TOPS-20:*:*)
-	echo pdp10-unknown-tops20
-	exit 0 ;;
-    *:ITS:*:*)
-	echo pdp10-unknown-its
-	exit 0 ;;
-    SEI:*:*:SEIUX)
-        echo mips-sei-seiux${UNAME_RELEASE}
-	exit 0 ;;
-    *:DragonFly:*:*)
-	echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`
-	exit 0 ;;
-    *:*VMS:*:*)
-    	UNAME_MACHINE=`(uname -p) 2>/dev/null`
-	case "${UNAME_MACHINE}" in
-	    A*) echo alpha-dec-vms && exit 0 ;;
-	    I*) echo ia64-dec-vms && exit 0 ;;
-	    V*) echo vax-dec-vms && exit 0 ;;
-	esac ;;
-    *:XENIX:*:SysV)
-	echo i386-pc-xenix
-	exit 0 ;;
-esac
-
-#echo '(No uname command or uname output not recognized.)' 1>&2
-#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2
-
-eval $set_cc_for_build
-cat >$dummy.c <<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"); 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 && $dummy && exit 0
-
-# Apollos put the system type in the environment.
-
-test -d /usr/apollo && { echo ${ISP}-apollo-${SYSTYPE}; exit 0; }
-
-# 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 0 ;;
-    c2*)
-	if getsysinfo -f scalar_acc
-	then echo c32-convex-bsd
-	else echo c2-convex-bsd
-	fi
-	exit 0 ;;
-    c34*)
-	echo c34-convex-bsd
-	exit 0 ;;
-    c38*)
-	echo c38-convex-bsd
-	exit 0 ;;
-    c4*)
-	echo c4-convex-bsd
-	exit 0 ;;
-    esac
-fi
-
-cat >&2 <<EOF
-$0: unable to guess system type
-
-This script, last modified $timestamp, has failed to recognize
-the operating system you are using. It is advised that you
-download the most up to date version of the config scripts from
-
-  http://savannah.gnu.org/cgi-bin/viewcvs/*checkout*/config/config/config.guess
-and
-  http://savannah.gnu.org/cgi-bin/viewcvs/*checkout*/config/config/config.sub
-
-If the version you run ($0) is already up to date, please
-send the following data and any information you think might be
-pertinent to <config-patches at gnu.org> in order to provide the needed
-information to handle your system.
-
-config.guess timestamp = $timestamp
-
-uname -m = `(uname -m) 2>/dev/null || echo unknown`
-uname -r = `(uname -r) 2>/dev/null || echo unknown`
-uname -s = `(uname -s) 2>/dev/null || echo unknown`
-uname -v = `(uname -v) 2>/dev/null || echo unknown`
-
-/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null`
-/bin/uname -X     = `(/bin/uname -X) 2>/dev/null`
-
-hostinfo               = `(hostinfo) 2>/dev/null`
-/bin/universe          = `(/bin/universe) 2>/dev/null`
-/usr/bin/arch -k       = `(/usr/bin/arch -k) 2>/dev/null`
-/bin/arch              = `(/bin/arch) 2>/dev/null`
-/usr/bin/oslevel       = `(/usr/bin/oslevel) 2>/dev/null`
-/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null`
-
-UNAME_MACHINE = ${UNAME_MACHINE}
-UNAME_RELEASE = ${UNAME_RELEASE}
-UNAME_SYSTEM  = ${UNAME_SYSTEM}
-UNAME_VERSION = ${UNAME_VERSION}
-EOF
-
-exit 1
-
-# Local variables:
-# eval: (add-hook 'write-file-hooks 'time-stamp)
-# time-stamp-start: "timestamp='"
-# time-stamp-format: "%:y-%02m-%02d"
-# time-stamp-end: "'"
-# End:
diff --git a/config.sub b/config.sub
deleted file mode 100755
index 87a1ee4..0000000
--- a/config.sub
+++ /dev/null
@@ -1,1569 +0,0 @@
-#! /bin/sh
-# Configuration validation subroutine script.
-#   Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
-#   2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
-
-timestamp='2005-04-22'
-
-# This file is (in principle) common to ALL GNU software.
-# The presence of a machine in this file suggests that SOME GNU software
-# can handle that machine.  It does not imply ALL GNU software can.
-#
-# This file is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330,
-# Boston, MA 02111-1307, USA.
-
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-# Please send patches to <config-patches at gnu.org>.  Submit a context
-# diff and a properly formatted ChangeLog entry.
-#
-# Configuration subroutine to validate and canonicalize a configuration type.
-# Supply the specified configuration type as an argument.
-# If it is invalid, we print an error message on stderr and exit with code 1.
-# Otherwise, we print the canonical config type on stdout and succeed.
-
-# This file is supposed to be the same for all GNU packages
-# and recognize all the CPU types, system types and aliases
-# that are meaningful with *any* GNU software.
-# Each package is responsible for reporting which valid configurations
-# it does not support.  The user should be able to distinguish
-# a failure to support a valid configuration from a meaningless
-# configuration.
-
-# The goal of this file is to map all the various variations of a given
-# machine specification into a single specification in the form:
-#	CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM
-# or in some cases, the newer four-part form:
-#	CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
-# It is wrong to echo any other type of specification.
-
-me=`echo "$0" | sed -e 's,.*/,,'`
-
-usage="\
-Usage: $0 [OPTION] CPU-MFR-OPSYS
-       $0 [OPTION] ALIAS
-
-Canonicalize a configuration name.
-
-Operation modes:
-  -h, --help         print this help, then exit
-  -t, --time-stamp   print date of last modification, then exit
-  -v, --version      print version number, then exit
-
-Report bugs and patches to <config-patches at gnu.org>."
-
-version="\
-GNU config.sub ($timestamp)
-
-Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005
-Free Software Foundation, Inc.
-
-This is free software; see the source for copying conditions.  There is NO
-warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
-
-help="
-Try \`$me --help' for more information."
-
-# Parse command line
-while test $# -gt 0 ; do
-  case $1 in
-    --time-stamp | --time* | -t )
-       echo "$timestamp" ; exit 0 ;;
-    --version | -v )
-       echo "$version" ; exit 0 ;;
-    --help | --h* | -h )
-       echo "$usage"; exit 0 ;;
-    -- )     # Stop option processing
-       shift; break ;;
-    - )	# Use stdin as input.
-       break ;;
-    -* )
-       echo "$me: invalid option $1$help"
-       exit 1 ;;
-
-    *local*)
-       # First pass through any local machine types.
-       echo $1
-       exit 0;;
-
-    * )
-       break ;;
-  esac
-done
-
-case $# in
- 0) echo "$me: missing argument$help" >&2
-    exit 1;;
- 1) ;;
- *) echo "$me: too many arguments$help" >&2
-    exit 1;;
-esac
-
-# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any).
-# Here we must recognize all the valid KERNEL-OS combinations.
-maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
-case $maybe_os in
-  nto-qnx* | linux-gnu* | linux-dietlibc | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | \
-  kfreebsd*-gnu* | knetbsd*-gnu* | netbsd*-gnu* | storm-chaos* | os2-emx* | rtmk-nova*)
-    os=-$maybe_os
-    basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
-    ;;
-  *)
-    basic_machine=`echo $1 | sed 's/-[^-]*$//'`
-    if [ $basic_machine != $1 ]
-    then os=`echo $1 | sed 's/.*-/-/'`
-    else os=; fi
-    ;;
-esac
-
-### Let's recognize common machines as not being operating systems so
-### that things like config.sub decstation-3100 work.  We also
-### recognize some manufacturers as not being operating systems, so we
-### can provide default operating systems below.
-case $os in
-	-sun*os*)
-		# Prevent following clause from handling this invalid input.
-		;;
-	-dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \
-	-att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \
-	-unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \
-	-convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\
-	-c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \
-	-harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \
-	-apple | -axis | -knuth | -cray)
-		os=
-		basic_machine=$1
-		;;
-	-sim | -cisco | -oki | -wec | -winbond)
-		os=
-		basic_machine=$1
-		;;
-	-scout)
-		;;
-	-wrs)
-		os=-vxworks
-		basic_machine=$1
-		;;
-	-chorusos*)
-		os=-chorusos
-		basic_machine=$1
-		;;
- 	-chorusrdb)
- 		os=-chorusrdb
-		basic_machine=$1
- 		;;
-	-hiux*)
-		os=-hiuxwe2
-		;;
-	-sco5)
-		os=-sco3.2v5
-		basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
-		;;
-	-sco4)
-		os=-sco3.2v4
-		basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
-		;;
-	-sco3.2.[4-9]*)
-		os=`echo $os | sed -e 's/sco3.2./sco3.2v/'`
-		basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
-		;;
-	-sco3.2v[4-9]*)
-		# Don't forget version if it is 3.2v4 or newer.
-		basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
-		;;
-	-sco*)
-		os=-sco3.2v2
-		basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
-		;;
-	-udk*)
-		basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
-		;;
-	-isc)
-		os=-isc2.2
-		basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
-		;;
-	-clix*)
-		basic_machine=clipper-intergraph
-		;;
-	-isc*)
-		basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
-		;;
-	-lynx*)
-		os=-lynxos
-		;;
-	-ptx*)
-		basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'`
-		;;
-	-windowsnt*)
-		os=`echo $os | sed -e 's/windowsnt/winnt/'`
-		;;
-	-psos*)
-		os=-psos
-		;;
-	-mint | -mint[0-9]*)
-		basic_machine=m68k-atari
-		os=-mint
-		;;
-esac
-
-# Decode aliases for certain CPU-COMPANY combinations.
-case $basic_machine in
-	# Recognize the basic CPU types without company name.
-	# Some are omitted here because they have special meanings below.
-	1750a | 580 \
-	| a29k \
-	| alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \
-	| alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \
-	| am33_2.0 \
-	| arc | arm | arm[bl]e | arme[lb] | armv[2345] | armv[345][lb] | avr \
-	| bfin \
-	| c4x | clipper \
-	| d10v | d30v | dlx | dsp16xx \
-	| fr30 | frv \
-	| h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
-	| i370 | i860 | i960 | ia64 \
-	| ip2k | iq2000 \
-	| m32r | m32rle | m68000 | m68k | m88k | maxq | mcore \
-	| mips | mipsbe | mipseb | mipsel | mipsle \
-	| mips16 \
-	| mips64 | mips64el \
-	| mips64vr | mips64vrel \
-	| mips64orion | mips64orionel \
-	| mips64vr4100 | mips64vr4100el \
-	| mips64vr4300 | mips64vr4300el \
-	| mips64vr5000 | mips64vr5000el \
-	| mipsisa32 | mipsisa32el \
-	| mipsisa32r2 | mipsisa32r2el \
-	| mipsisa64 | mipsisa64el \
-	| mipsisa64r2 | mipsisa64r2el \
-	| mipsisa64sb1 | mipsisa64sb1el \
-	| mipsisa64sr71k | mipsisa64sr71kel \
-	| mipstx39 | mipstx39el \
-	| mn10200 | mn10300 \
-	| msp430 \
-	| ns16k | ns32k \
-	| openrisc | or32 \
-	| pdp10 | pdp11 | pj | pjl \
-	| powerpc | powerpc64 | powerpc64le | powerpcle | ppcbe \
-	| pyramid \
-	| sh | sh[1234] | sh[23]e | sh[34]eb | shbe | shle | sh[1234]le | sh3ele \
-	| sh64 | sh64le \
-	| sparc | sparc64 | sparc64b | sparc86x | sparclet | sparclite \
-	| sparcv8 | sparcv9 | sparcv9b \
-	| strongarm \
-	| tahoe | thumb | tic4x | tic80 | tron \
-	| v850 | v850e \
-	| we32k \
-	| x86 | xscale | xscalee[bl] | xstormy16 | xtensa \
-	| z8k)
-		basic_machine=$basic_machine-unknown
-		;;
-	m6811 | m68hc11 | m6812 | m68hc12)
-		# Motorola 68HC11/12.
-		basic_machine=$basic_machine-unknown
-		os=-none
-		;;
-	m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k)
-		;;
-
-	# We use `pc' rather than `unknown'
-	# because (1) that's what they normally are, and
-	# (2) the word "unknown" tends to confuse beginning users.
-	i*86 | x86_64)
-	  basic_machine=$basic_machine-pc
-	  ;;
-	# Object if more than one company name word.
-	*-*-*)
-		echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
-		exit 1
-		;;
-	# Recognize the basic CPU types with company name.
-	580-* \
-	| a29k-* \
-	| alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \
-	| alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \
-	| alphapca5[67]-* | alpha64pca5[67]-* | arc-* \
-	| arm-*  | armbe-* | armle-* | armeb-* | armv*-* \
-	| avr-* \
-	| bfin-* | bs2000-* \
-	| c[123]* | c30-* | [cjt]90-* | c4x-* | c54x-* | c55x-* | c6x-* \
-	| clipper-* | craynv-* | cydra-* \
-	| d10v-* | d30v-* | dlx-* \
-	| elxsi-* \
-	| f30[01]-* | f700-* | fr30-* | frv-* | fx80-* \
-	| h8300-* | h8500-* \
-	| hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \
-	| i*86-* | i860-* | i960-* | ia64-* \
-	| ip2k-* | iq2000-* \
-	| m32r-* | m32rle-* \
-	| m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \
-	| m88110-* | m88k-* | maxq-* | mcore-* \
-	| mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \
-	| mips16-* \
-	| mips64-* | mips64el-* \
-	| mips64vr-* | mips64vrel-* \
-	| mips64orion-* | mips64orionel-* \
-	| mips64vr4100-* | mips64vr4100el-* \
-	| mips64vr4300-* | mips64vr4300el-* \
-	| mips64vr5000-* | mips64vr5000el-* \
-	| mipsisa32-* | mipsisa32el-* \
-	| mipsisa32r2-* | mipsisa32r2el-* \
-	| mipsisa64-* | mipsisa64el-* \
-	| mipsisa64r2-* | mipsisa64r2el-* \
-	| mipsisa64sb1-* | mipsisa64sb1el-* \
-	| mipsisa64sr71k-* | mipsisa64sr71kel-* \
-	| mipstx39-* | mipstx39el-* \
-	| mmix-* \
-	| msp430-* \
-	| none-* | np1-* | ns16k-* | ns32k-* \
-	| orion-* \
-	| pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \
-	| powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | ppcbe-* \
-	| pyramid-* \
-	| romp-* | rs6000-* \
-	| sh-* | sh[1234]-* | sh[23]e-* | sh[34]eb-* | shbe-* \
-	| shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \
-	| sparc-* | sparc64-* | sparc64b-* | sparc86x-* | sparclet-* \
-	| sparclite-* \
-	| sparcv8-* | sparcv9-* | sparcv9b-* | strongarm-* | sv1-* | sx?-* \
-	| tahoe-* | thumb-* \
-	| tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \
-	| tron-* \
-	| v850-* | v850e-* | vax-* \
-	| we32k-* \
-	| x86-* | x86_64-* | xps100-* | xscale-* | xscalee[bl]-* \
-	| xstormy16-* | xtensa-* \
-	| ymp-* \
-	| z8k-*)
-		;;
-	# Recognize the various machine names and aliases which stand
-	# for a CPU type and a company and sometimes even an OS.
-	386bsd)
-		basic_machine=i386-unknown
-		os=-bsd
-		;;
-	3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc)
-		basic_machine=m68000-att
-		;;
-	3b*)
-		basic_machine=we32k-att
-		;;
-	a29khif)
-		basic_machine=a29k-amd
-		os=-udi
-		;;
-    	abacus)
-		basic_machine=abacus-unknown
-		;;
-	adobe68k)
-		basic_machine=m68010-adobe
-		os=-scout
-		;;
-	alliant | fx80)
-		basic_machine=fx80-alliant
-		;;
-	altos | altos3068)
-		basic_machine=m68k-altos
-		;;
-	am29k)
-		basic_machine=a29k-none
-		os=-bsd
-		;;
-	amd64)
-		basic_machine=x86_64-pc
-		;;
-	amd64-*)
-		basic_machine=x86_64-`echo $basic_machine | sed 's/^[^-]*-//'`
-		;;
-	amdahl)
-		basic_machine=580-amdahl
-		os=-sysv
-		;;
-	amiga | amiga-*)
-		basic_machine=m68k-unknown
-		;;
-	amigaos | amigados)
-		basic_machine=m68k-unknown
-		os=-amigaos
-		;;
-	amigaunix | amix)
-		basic_machine=m68k-unknown
-		os=-sysv4
-		;;
-	apollo68)
-		basic_machine=m68k-apollo
-		os=-sysv
-		;;
-	apollo68bsd)
-		basic_machine=m68k-apollo
-		os=-bsd
-		;;
-	aux)
-		basic_machine=m68k-apple
-		os=-aux
-		;;
-	balance)
-		basic_machine=ns32k-sequent
-		os=-dynix
-		;;
-	c90)
-		basic_machine=c90-cray
-		os=-unicos
-		;;
-	convex-c1)
-		basic_machine=c1-convex
-		os=-bsd
-		;;
-	convex-c2)
-		basic_machine=c2-convex
-		os=-bsd
-		;;
-	convex-c32)
-		basic_machine=c32-convex
-		os=-bsd
-		;;
-	convex-c34)
-		basic_machine=c34-convex
-		os=-bsd
-		;;
-	convex-c38)
-		basic_machine=c38-convex
-		os=-bsd
-		;;
-	cray | j90)
-		basic_machine=j90-cray
-		os=-unicos
-		;;
-	craynv)
-		basic_machine=craynv-cray
-		os=-unicosmp
-		;;
-	cr16c)
-		basic_machine=cr16c-unknown
-		os=-elf
-		;;
-	crds | unos)
-		basic_machine=m68k-crds
-		;;
-	crisv32 | crisv32-* | etraxfs*)
-		basic_machine=crisv32-axis
-		;;
-	cris | cris-* | etrax*)
-		basic_machine=cris-axis
-		;;
-	crx)
-		basic_machine=crx-unknown
-		os=-elf
-		;;
-	da30 | da30-*)
-		basic_machine=m68k-da30
-		;;
-	decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn)
-		basic_machine=mips-dec
-		;;
-	decsystem10* | dec10*)
-		basic_machine=pdp10-dec
-		os=-tops10
-		;;
-	decsystem20* | dec20*)
-		basic_machine=pdp10-dec
-		os=-tops20
-		;;
-	delta | 3300 | motorola-3300 | motorola-delta \
-	      | 3300-motorola | delta-motorola)
-		basic_machine=m68k-motorola
-		;;
-	delta88)
-		basic_machine=m88k-motorola
-		os=-sysv3
-		;;
-	djgpp)
-		basic_machine=i586-pc
-		os=-msdosdjgpp
-		;;
-	dpx20 | dpx20-*)
-		basic_machine=rs6000-bull
-		os=-bosx
-		;;
-	dpx2* | dpx2*-bull)
-		basic_machine=m68k-bull
-		os=-sysv3
-		;;
-	ebmon29k)
-		basic_machine=a29k-amd
-		os=-ebmon
-		;;
-	elxsi)
-		basic_machine=elxsi-elxsi
-		os=-bsd
-		;;
-	encore | umax | mmax)
-		basic_machine=ns32k-encore
-		;;
-	es1800 | OSE68k | ose68k | ose | OSE)
-		basic_machine=m68k-ericsson
-		os=-ose
-		;;
-	fx2800)
-		basic_machine=i860-alliant
-		;;
-	genix)
-		basic_machine=ns32k-ns
-		;;
-	gmicro)
-		basic_machine=tron-gmicro
-		os=-sysv
-		;;
-	go32)
-		basic_machine=i386-pc
-		os=-go32
-		;;
-	h3050r* | hiux*)
-		basic_machine=hppa1.1-hitachi
-		os=-hiuxwe2
-		;;
-	h8300hms)
-		basic_machine=h8300-hitachi
-		os=-hms
-		;;
-	h8300xray)
-		basic_machine=h8300-hitachi
-		os=-xray
-		;;
-	h8500hms)
-		basic_machine=h8500-hitachi
-		os=-hms
-		;;
-	harris)
-		basic_machine=m88k-harris
-		os=-sysv3
-		;;
-	hp300-*)
-		basic_machine=m68k-hp
-		;;
-	hp300bsd)
-		basic_machine=m68k-hp
-		os=-bsd
-		;;
-	hp300hpux)
-		basic_machine=m68k-hp
-		os=-hpux
-		;;
-	hp3k9[0-9][0-9] | hp9[0-9][0-9])
-		basic_machine=hppa1.0-hp
-		;;
-	hp9k2[0-9][0-9] | hp9k31[0-9])
-		basic_machine=m68000-hp
-		;;
-	hp9k3[2-9][0-9])
-		basic_machine=m68k-hp
-		;;
-	hp9k6[0-9][0-9] | hp6[0-9][0-9])
-		basic_machine=hppa1.0-hp
-		;;
-	hp9k7[0-79][0-9] | hp7[0-79][0-9])
-		basic_machine=hppa1.1-hp
-		;;
-	hp9k78[0-9] | hp78[0-9])
-		# FIXME: really hppa2.0-hp
-		basic_machine=hppa1.1-hp
-		;;
-	hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893)
-		# FIXME: really hppa2.0-hp
-		basic_machine=hppa1.1-hp
-		;;
-	hp9k8[0-9][13679] | hp8[0-9][13679])
-		basic_machine=hppa1.1-hp
-		;;
-	hp9k8[0-9][0-9] | hp8[0-9][0-9])
-		basic_machine=hppa1.0-hp
-		;;
-	hppa-next)
-		os=-nextstep3
-		;;
-	hppaosf)
-		basic_machine=hppa1.1-hp
-		os=-osf
-		;;
-	hppro)
-		basic_machine=hppa1.1-hp
-		os=-proelf
-		;;
-	i370-ibm* | ibm*)
-		basic_machine=i370-ibm
-		;;
-# I'm not sure what "Sysv32" means.  Should this be sysv3.2?
-	i*86v32)
-		basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
-		os=-sysv32
-		;;
-	i*86v4*)
-		basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
-		os=-sysv4
-		;;
-	i*86v)
-		basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
-		os=-sysv
-		;;
-	i*86sol2)
-		basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
-		os=-solaris2
-		;;
-	i386mach)
-		basic_machine=i386-mach
-		os=-mach
-		;;
-	i386-vsta | vsta)
-		basic_machine=i386-unknown
-		os=-vsta
-		;;
-	iris | iris4d)
-		basic_machine=mips-sgi
-		case $os in
-		    -irix*)
-			;;
-		    *)
-			os=-irix4
-			;;
-		esac
-		;;
-	isi68 | isi)
-		basic_machine=m68k-isi
-		os=-sysv
-		;;
-	m88k-omron*)
-		basic_machine=m88k-omron
-		;;
-	magnum | m3230)
-		basic_machine=mips-mips
-		os=-sysv
-		;;
-	merlin)
-		basic_machine=ns32k-utek
-		os=-sysv
-		;;
-	mingw32)
-		basic_machine=i386-pc
-		os=-mingw32
-		;;
-	miniframe)
-		basic_machine=m68000-convergent
-		;;
-	*mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*)
-		basic_machine=m68k-atari
-		os=-mint
-		;;
-	mips3*-*)
-		basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`
-		;;
-	mips3*)
-		basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown
-		;;
-	monitor)
-		basic_machine=m68k-rom68k
-		os=-coff
-		;;
-	morphos)
-		basic_machine=powerpc-unknown
-		os=-morphos
-		;;
-	msdos)
-		basic_machine=i386-pc
-		os=-msdos
-		;;
-	mvs)
-		basic_machine=i370-ibm
-		os=-mvs
-		;;
-	ncr3000)
-		basic_machine=i486-ncr
-		os=-sysv4
-		;;
-	netbsd386)
-		basic_machine=i386-unknown
-		os=-netbsd
-		;;
-	netwinder)
-		basic_machine=armv4l-rebel
-		os=-linux
-		;;
-	news | news700 | news800 | news900)
-		basic_machine=m68k-sony
-		os=-newsos
-		;;
-	news1000)
-		basic_machine=m68030-sony
-		os=-newsos
-		;;
-	news-3600 | risc-news)
-		basic_machine=mips-sony
-		os=-newsos
-		;;
-	necv70)
-		basic_machine=v70-nec
-		os=-sysv
-		;;
-	next | m*-next )
-		basic_machine=m68k-next
-		case $os in
-		    -nextstep* )
-			;;
-		    -ns2*)
-		      os=-nextstep2
-			;;
-		    *)
-		      os=-nextstep3
-			;;
-		esac
-		;;
-	nh3000)
-		basic_machine=m68k-harris
-		os=-cxux
-		;;
-	nh[45]000)
-		basic_machine=m88k-harris
-		os=-cxux
-		;;
-	nindy960)
-		basic_machine=i960-intel
-		os=-nindy
-		;;
-	mon960)
-		basic_machine=i960-intel
-		os=-mon960
-		;;
-	nonstopux)
-		basic_machine=mips-compaq
-		os=-nonstopux
-		;;
-	np1)
-		basic_machine=np1-gould
-		;;
-	nsr-tandem)
-		basic_machine=nsr-tandem
-		;;
-	op50n-* | op60c-*)
-		basic_machine=hppa1.1-oki
-		os=-proelf
-		;;
-	or32 | or32-*)
-		basic_machine=or32-unknown
-		os=-coff
-		;;
-	os400)
-		basic_machine=powerpc-ibm
-		os=-os400
-		;;
-	OSE68000 | ose68000)
-		basic_machine=m68000-ericsson
-		os=-ose
-		;;
-	os68k)
-		basic_machine=m68k-none
-		os=-os68k
-		;;
-	pa-hitachi)
-		basic_machine=hppa1.1-hitachi
-		os=-hiuxwe2
-		;;
-	paragon)
-		basic_machine=i860-intel
-		os=-osf
-		;;
-	pbd)
-		basic_machine=sparc-tti
-		;;
-	pbb)
-		basic_machine=m68k-tti
-		;;
-	pc532 | pc532-*)
-		basic_machine=ns32k-pc532
-		;;
-	pentium | p5 | k5 | k6 | nexgen | viac3)
-		basic_machine=i586-pc
-		;;
-	pentiumpro | p6 | 6x86 | athlon | athlon_*)
-		basic_machine=i686-pc
-		;;
-	pentiumii | pentium2 | pentiumiii | pentium3)
-		basic_machine=i686-pc
-		;;
-	pentium4)
-		basic_machine=i786-pc
-		;;
-	pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*)
-		basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'`
-		;;
-	pentiumpro-* | p6-* | 6x86-* | athlon-*)
-		basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
-		;;
-	pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*)
-		basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
-		;;
-	pentium4-*)
-		basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'`
-		;;
-	pn)
-		basic_machine=pn-gould
-		;;
-	power)	basic_machine=power-ibm
-		;;
-	ppc)	basic_machine=powerpc-unknown
-		;;
-	ppc-*)	basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'`
-		;;
-	ppcle | powerpclittle | ppc-le | powerpc-little)
-		basic_machine=powerpcle-unknown
-		;;
-	ppcle-* | powerpclittle-*)
-		basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'`
-		;;
-	ppc64)	basic_machine=powerpc64-unknown
-		;;
-	ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'`
-		;;
-	ppc64le | powerpc64little | ppc64-le | powerpc64-little)
-		basic_machine=powerpc64le-unknown
-		;;
-	ppc64le-* | powerpc64little-*)
-		basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'`
-		;;
-	ps2)
-		basic_machine=i386-ibm
-		;;
-	pw32)
-		basic_machine=i586-unknown
-		os=-pw32
-		;;
-	rom68k)
-		basic_machine=m68k-rom68k
-		os=-coff
-		;;
-	rm[46]00)
-		basic_machine=mips-siemens
-		;;
-	rtpc | rtpc-*)
-		basic_machine=romp-ibm
-		;;
-	s390 | s390-*)
-		basic_machine=s390-ibm
-		;;
-	s390x | s390x-*)
-		basic_machine=s390x-ibm
-		;;
-	sa29200)
-		basic_machine=a29k-amd
-		os=-udi
-		;;
-	sb1)
-		basic_machine=mipsisa64sb1-unknown
-		;;
-	sb1el)
-		basic_machine=mipsisa64sb1el-unknown
-		;;
-	sei)
-		basic_machine=mips-sei
-		os=-seiux
-		;;
-	sequent)
-		basic_machine=i386-sequent
-		;;
-	sh)
-		basic_machine=sh-hitachi
-		os=-hms
-		;;
-	sh64)
-		basic_machine=sh64-unknown
-		;;
-	sparclite-wrs | simso-wrs)
-		basic_machine=sparclite-wrs
-		os=-vxworks
-		;;
-	sps7)
-		basic_machine=m68k-bull
-		os=-sysv2
-		;;
-	spur)
-		basic_machine=spur-unknown
-		;;
-	st2000)
-		basic_machine=m68k-tandem
-		;;
-	stratus)
-		basic_machine=i860-stratus
-		os=-sysv4
-		;;
-	sun2)
-		basic_machine=m68000-sun
-		;;
-	sun2os3)
-		basic_machine=m68000-sun
-		os=-sunos3
-		;;
-	sun2os4)
-		basic_machine=m68000-sun
-		os=-sunos4
-		;;
-	sun3os3)
-		basic_machine=m68k-sun
-		os=-sunos3
-		;;
-	sun3os4)
-		basic_machine=m68k-sun
-		os=-sunos4
-		;;
-	sun4os3)
-		basic_machine=sparc-sun
-		os=-sunos3
-		;;
-	sun4os4)
-		basic_machine=sparc-sun
-		os=-sunos4
-		;;
-	sun4sol2)
-		basic_machine=sparc-sun
-		os=-solaris2
-		;;
-	sun3 | sun3-*)
-		basic_machine=m68k-sun
-		;;
-	sun4)
-		basic_machine=sparc-sun
-		;;
-	sun386 | sun386i | roadrunner)
-		basic_machine=i386-sun
-		;;
-	sv1)
-		basic_machine=sv1-cray
-		os=-unicos
-		;;
-	symmetry)
-		basic_machine=i386-sequent
-		os=-dynix
-		;;
-	t3e)
-		basic_machine=alphaev5-cray
-		os=-unicos
-		;;
-	t90)
-		basic_machine=t90-cray
-		os=-unicos
-		;;
-	tic54x | c54x*)
-		basic_machine=tic54x-unknown
-		os=-coff
-		;;
-	tic55x | c55x*)
-		basic_machine=tic55x-unknown
-		os=-coff
-		;;
-	tic6x | c6x*)
-		basic_machine=tic6x-unknown
-		os=-coff
-		;;
-	tx39)
-		basic_machine=mipstx39-unknown
-		;;
-	tx39el)
-		basic_machine=mipstx39el-unknown
-		;;
-	toad1)
-		basic_machine=pdp10-xkl
-		os=-tops20
-		;;
-	tower | tower-32)
-		basic_machine=m68k-ncr
-		;;
-	tpf)
-		basic_machine=s390x-ibm
-		os=-tpf
-		;;
-	udi29k)
-		basic_machine=a29k-amd
-		os=-udi
-		;;
-	ultra3)
-		basic_machine=a29k-nyu
-		os=-sym1
-		;;
-	v810 | necv810)
-		basic_machine=v810-nec
-		os=-none
-		;;
-	vaxv)
-		basic_machine=vax-dec
-		os=-sysv
-		;;
-	vms)
-		basic_machine=vax-dec
-		os=-vms
-		;;
-	vpp*|vx|vx-*)
-		basic_machine=f301-fujitsu
-		;;
-	vxworks960)
-		basic_machine=i960-wrs
-		os=-vxworks
-		;;
-	vxworks68)
-		basic_machine=m68k-wrs
-		os=-vxworks
-		;;
-	vxworks29k)
-		basic_machine=a29k-wrs
-		os=-vxworks
-		;;
-	w65*)
-		basic_machine=w65-wdc
-		os=-none
-		;;
-	w89k-*)
-		basic_machine=hppa1.1-winbond
-		os=-proelf
-		;;
-	xbox)
-		basic_machine=i686-pc
-		os=-mingw32
-		;;
-	xps | xps100)
-		basic_machine=xps100-honeywell
-		;;
-	ymp)
-		basic_machine=ymp-cray
-		os=-unicos
-		;;
-	z8k-*-coff)
-		basic_machine=z8k-unknown
-		os=-sim
-		;;
-	none)
-		basic_machine=none-none
-		os=-none
-		;;
-
-# Here we handle the default manufacturer of certain CPU types.  It is in
-# some cases the only manufacturer, in others, it is the most popular.
-	w89k)
-		basic_machine=hppa1.1-winbond
-		;;
-	op50n)
-		basic_machine=hppa1.1-oki
-		;;
-	op60c)
-		basic_machine=hppa1.1-oki
-		;;
-	romp)
-		basic_machine=romp-ibm
-		;;
-	mmix)
-		basic_machine=mmix-knuth
-		;;
-	rs6000)
-		basic_machine=rs6000-ibm
-		;;
-	vax)
-		basic_machine=vax-dec
-		;;
-	pdp10)
-		# there are many clones, so DEC is not a safe bet
-		basic_machine=pdp10-unknown
-		;;
-	pdp11)
-		basic_machine=pdp11-dec
-		;;
-	we32k)
-		basic_machine=we32k-att
-		;;
-	sh3 | sh4 | sh[34]eb | sh[1234]le | sh[23]ele)
-		basic_machine=sh-unknown
-		;;
-	sh64)
-		basic_machine=sh64-unknown
-		;;
-	sparc | sparcv8 | sparcv9 | sparcv9b)
-		basic_machine=sparc-sun
-		;;
-	cydra)
-		basic_machine=cydra-cydrome
-		;;
-	orion)
-		basic_machine=orion-highlevel
-		;;
-	orion105)
-		basic_machine=clipper-highlevel
-		;;
-	mac | mpw | mac-mpw)
-		basic_machine=m68k-apple
-		;;
-	pmac | pmac-mpw)
-		basic_machine=powerpc-apple
-		;;
-	*-unknown)
-		# Make sure to match an already-canonicalized machine name.
-		;;
-	*)
-		echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
-		exit 1
-		;;
-esac
-
-# Here we canonicalize certain aliases for manufacturers.
-case $basic_machine in
-	*-digital*)
-		basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'`
-		;;
-	*-commodore*)
-		basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'`
-		;;
-	*)
-		;;
-esac
-
-# Decode manufacturer-specific aliases for certain operating systems.
-
-if [ x"$os" != x"" ]
-then
-case $os in
-        # First match some system type aliases
-        # that might get confused with valid system types.
-	# -solaris* is a basic system type, with this one exception.
-	-solaris1 | -solaris1.*)
-		os=`echo $os | sed -e 's|solaris1|sunos4|'`
-		;;
-	-solaris)
-		os=-solaris2
-		;;
-	-svr4*)
-		os=-sysv4
-		;;
-	-unixware*)
-		os=-sysv4.2uw
-		;;
-	-gnu/linux*)
-		os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'`
-		;;
-	# First accept the basic system types.
-	# The portable systems comes first.
-	# Each alternative MUST END IN A *, to match a version number.
-	# -sysv* is not here because it comes later, after sysvr4.
-	-gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \
-	      | -*vms* | -sco* | -esix* | -isc* | -aix* | -sunos | -sunos[34]*\
-	      | -hpux* | -unos* | -osf* | -luna* | -dgux* | -solaris* | -sym* \
-	      | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \
-	      | -aos* \
-	      | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \
-	      | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \
-	      | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* | -openbsd* \
-	      | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \
-	      | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \
-	      | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \
-	      | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \
-	      | -chorusos* | -chorusrdb* \
-	      | -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
-	      | -mingw32* | -linux-gnu* | -linux-uclibc* | -uxpv* | -beos* | -mpeix* | -udk* \
-	      | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \
-	      | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
-	      | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \
-	      | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \
-	      | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \
-	      | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly*)
-	# Remember, each alternative MUST END IN *, to match a version number.
-		;;
-	-qnx*)
-		case $basic_machine in
-		    x86-* | i*86-*)
-			;;
-		    *)
-			os=-nto$os
-			;;
-		esac
-		;;
-	-nto-qnx*)
-		;;
-	-nto*)
-		os=`echo $os | sed -e 's|nto|nto-qnx|'`
-		;;
-	-sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \
-	      | -windows* | -osx | -abug | -netware* | -os9* | -beos* \
-	      | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*)
-		;;
-	-mac*)
-		os=`echo $os | sed -e 's|mac|macos|'`
-		;;
-	-linux-dietlibc)
-		os=-linux-dietlibc
-		;;
-	-linux*)
-		os=`echo $os | sed -e 's|linux|linux-gnu|'`
-		;;
-	-sunos5*)
-		os=`echo $os | sed -e 's|sunos5|solaris2|'`
-		;;
-	-sunos6*)
-		os=`echo $os | sed -e 's|sunos6|solaris3|'`
-		;;
-	-opened*)
-		os=-openedition
-		;;
-        -os400*)
-		os=-os400
-		;;
-	-wince*)
-		os=-wince
-		;;
-	-osfrose*)
-		os=-osfrose
-		;;
-	-osf*)
-		os=-osf
-		;;
-	-utek*)
-		os=-bsd
-		;;
-	-dynix*)
-		os=-bsd
-		;;
-	-acis*)
-		os=-aos
-		;;
-	-atheos*)
-		os=-atheos
-		;;
-	-syllable*)
-		os=-syllable
-		;;
-	-386bsd)
-		os=-bsd
-		;;
-	-ctix* | -uts*)
-		os=-sysv
-		;;
-	-nova*)
-		os=-rtmk-nova
-		;;
-	-ns2 )
-		os=-nextstep2
-		;;
-	-nsk*)
-		os=-nsk
-		;;
-	# Preserve the version number of sinix5.
-	-sinix5.*)
-		os=`echo $os | sed -e 's|sinix|sysv|'`
-		;;
-	-sinix*)
-		os=-sysv4
-		;;
-        -tpf*)
-		os=-tpf
-		;;
-	-triton*)
-		os=-sysv3
-		;;
-	-oss*)
-		os=-sysv3
-		;;
-	-svr4)
-		os=-sysv4
-		;;
-	-svr3)
-		os=-sysv3
-		;;
-	-sysvr4)
-		os=-sysv4
-		;;
-	# This must come after -sysvr4.
-	-sysv*)
-		;;
-	-ose*)
-		os=-ose
-		;;
-	-es1800*)
-		os=-ose
-		;;
-	-xenix)
-		os=-xenix
-		;;
-	-*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
-		os=-mint
-		;;
-	-aros*)
-		os=-aros
-		;;
-	-kaos*)
-		os=-kaos
-		;;
-	-zvmoe)
-		os=-zvmoe
-		;;
-	-none)
-		;;
-	*)
-		# Get rid of the `-' at the beginning of $os.
-		os=`echo $os | sed 's/[^-]*-//'`
-		echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2
-		exit 1
-		;;
-esac
-else
-
-# Here we handle the default operating systems that come with various machines.
-# The value should be what the vendor currently ships out the door with their
-# machine or put another way, the most popular os provided with the machine.
-
-# Note that if you're going to try to match "-MANUFACTURER" here (say,
-# "-sun"), then you have to tell the case statement up towards the top
-# that MANUFACTURER isn't an operating system.  Otherwise, code above
-# will signal an error saying that MANUFACTURER isn't an operating
-# system, and we'll never get to this point.
-
-case $basic_machine in
-	*-acorn)
-		os=-riscix1.2
-		;;
-	arm*-rebel)
-		os=-linux
-		;;
-	arm*-semi)
-		os=-aout
-		;;
-    c4x-* | tic4x-*)
-        os=-coff
-        ;;
-	# This must come before the *-dec entry.
-	pdp10-*)
-		os=-tops20
-		;;
-	pdp11-*)
-		os=-none
-		;;
-	*-dec | vax-*)
-		os=-ultrix4.2
-		;;
-	m68*-apollo)
-		os=-domain
-		;;
-	i386-sun)
-		os=-sunos4.0.2
-		;;
-	m68000-sun)
-		os=-sunos3
-		# This also exists in the configure program, but was not the
-		# default.
-		# os=-sunos4
-		;;
-	m68*-cisco)
-		os=-aout
-		;;
-	mips*-cisco)
-		os=-elf
-		;;
-	mips*-*)
-		os=-elf
-		;;
-	or32-*)
-		os=-coff
-		;;
-	*-tti)	# must be before sparc entry or we get the wrong os.
-		os=-sysv3
-		;;
-	sparc-* | *-sun)
-		os=-sunos4.1.1
-		;;
-	*-be)
-		os=-beos
-		;;
-	*-ibm)
-		os=-aix
-		;;
-    	*-knuth)
-		os=-mmixware
-		;;
-	*-wec)
-		os=-proelf
-		;;
-	*-winbond)
-		os=-proelf
-		;;
-	*-oki)
-		os=-proelf
-		;;
-	*-hp)
-		os=-hpux
-		;;
-	*-hitachi)
-		os=-hiux
-		;;
-	i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent)
-		os=-sysv
-		;;
-	*-cbm)
-		os=-amigaos
-		;;
-	*-dg)
-		os=-dgux
-		;;
-	*-dolphin)
-		os=-sysv3
-		;;
-	m68k-ccur)
-		os=-rtu
-		;;
-	m88k-omron*)
-		os=-luna
-		;;
-	*-next )
-		os=-nextstep
-		;;
-	*-sequent)
-		os=-ptx
-		;;
-	*-crds)
-		os=-unos
-		;;
-	*-ns)
-		os=-genix
-		;;
-	i370-*)
-		os=-mvs
-		;;
-	*-next)
-		os=-nextstep3
-		;;
-	*-gould)
-		os=-sysv
-		;;
-	*-highlevel)
-		os=-bsd
-		;;
-	*-encore)
-		os=-bsd
-		;;
-	*-sgi)
-		os=-irix
-		;;
-	*-siemens)
-		os=-sysv4
-		;;
-	*-masscomp)
-		os=-rtu
-		;;
-	f30[01]-fujitsu | f700-fujitsu)
-		os=-uxpv
-		;;
-	*-rom68k)
-		os=-coff
-		;;
-	*-*bug)
-		os=-coff
-		;;
-	*-apple)
-		os=-macos
-		;;
-	*-atari*)
-		os=-mint
-		;;
-	*)
-		os=-none
-		;;
-esac
-fi
-
-# Here we handle the case where we know the os, and the CPU type, but not the
-# manufacturer.  We pick the logical manufacturer.
-vendor=unknown
-case $basic_machine in
-	*-unknown)
-		case $os in
-			-riscix*)
-				vendor=acorn
-				;;
-			-sunos*)
-				vendor=sun
-				;;
-			-aix*)
-				vendor=ibm
-				;;
-			-beos*)
-				vendor=be
-				;;
-			-hpux*)
-				vendor=hp
-				;;
-			-mpeix*)
-				vendor=hp
-				;;
-			-hiux*)
-				vendor=hitachi
-				;;
-			-unos*)
-				vendor=crds
-				;;
-			-dgux*)
-				vendor=dg
-				;;
-			-luna*)
-				vendor=omron
-				;;
-			-genix*)
-				vendor=ns
-				;;
-			-mvs* | -opened*)
-				vendor=ibm
-				;;
-			-os400*)
-				vendor=ibm
-				;;
-			-ptx*)
-				vendor=sequent
-				;;
-			-tpf*)
-				vendor=ibm
-				;;
-			-vxsim* | -vxworks* | -windiss*)
-				vendor=wrs
-				;;
-			-aux*)
-				vendor=apple
-				;;
-			-hms*)
-				vendor=hitachi
-				;;
-			-mpw* | -macos*)
-				vendor=apple
-				;;
-			-*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
-				vendor=atari
-				;;
-			-vos*)
-				vendor=stratus
-				;;
-		esac
-		basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"`
-		;;
-esac
-
-echo $basic_machine$os
-exit 0
-
-# Local variables:
-# eval: (add-hook 'write-file-hooks 'time-stamp)
-# time-stamp-start: "timestamp='"
-# time-stamp-format: "%:y-%02m-%02d"
-# time-stamp-end: "'"
-# End:
diff --git a/configure.ac b/configure.ac
index b21cdce..8b565b7 100644
--- a/configure.ac
+++ b/configure.ac
@@ -4,7 +4,8 @@
 
 
 AC_PREREQ(2.57)
-AC_INIT(setiathome_v7, 7.00, korpela at ssl.berkeley.edu)
+AC_INIT(setiathome_v7, 7.07, korpela at ssl.berkeley.edu)
+AC_CONFIG_MACRO_DIR([m4])
 svnrev="`svn info | grep Revision:`"
 
 if test -n "${svnrev}" ; then
@@ -54,10 +55,6 @@ if test -z "`echo ${LDFLAGS} | grep ${tmplib}`" ; then
   LDFLAGS="${LDFLAGS} -L${tmplib}"
 fi
 
-# set posix source on linux
-CFLAGS="-D_POSIX_C_SOURCE=1 ${CFLAGS}"
-CXXFLAGS="-D_POSIX_C_SOURCE=1 ${CXXFLAGS}"
-
 AC_ARG_ENABLE(intrinsics, 
     AS_HELP_STRING([--disable-intrinsics],
                    [disable use of intrinsics in SIMD code]))
@@ -161,6 +158,7 @@ PATH="/usr/xpg4/bin:${PATH}"
 AC_PROG_CXX
 AC_PROG_CXXCPP
 AM_PROG_CC_C_O
+AM_PROG_AS
 AC_PROG_AWK
 AC_PROG_LN_S
 AC_PATH_PROG(TR,[tr])
@@ -218,8 +216,8 @@ fi
 
 # Check libraries required or desired for seti_boinc app
 # Checks for libraries.
-APP_LDFLAGS="$LDSTATIC -L/usr/local/lib $LDFLAGS"
-APP_CFLAGS="-I/usr/local/include $CFLAGS"
+APP_LDFLAGS="$LDSTATIC $LDFLAGS"
+APP_CFLAGS="$CFLAGS"
 AC_CHECK_LIB([m], [sin],[
     AC_DEFINE([HAVE_LIBM],[1],[Define to 1 if you have the math library])
     APP_LIBS="-lm ${APP_LIBS}" 
@@ -237,6 +235,12 @@ AC_CHECK_LIB([fftw3], [fftwf_plan_dft_1d], [
 ],
 [],
 [-lm])
+AC_CHECK_LIB([cpufeatures], [android_getCpuFeatures], [
+    AC_DEFINE([HAVE_LIBCPUFEATURES],[1],[Define to 1 if you have the cpufeatures library])
+    APP_LIBS="-lcpufeatures ${APP_LIBS}"
+],
+[],
+[-lm])
 SAH_CHECK_ASMLIB
 APP_LIBS="${ASMLIB_LIBS} ${APP_LIBS}"
 APP_CFLAGS="${ASMLIB_CFLAGS} ${APP_CFLAGS}"
@@ -337,7 +341,7 @@ AC_LANG(C++)
 
 
 if test "${ac_cv_cxx_compiler_gnu}" = "yes" ; then
-  gcc_version_string="`g++ --version | head -1`"
+  gcc_version_string="`${CXX} --version | head -1`"
   AC_DEFINE_UNQUOTED([COMPILER_STRING],"$gcc_version_string",[Define to a string identifying your compiler])
 else if test -n "${CXX}" ; then
   AC_DEFINE_UNQUOTED([COMPILER_STRING],"$CXX",[Define to a string identifying your compiler])
@@ -367,7 +371,8 @@ AC_HEADER_STDC
 SAH_LARGEFILE_BREAKS_CXX
 SAH_HEADER_STDCXX
 AC_HEADER_SYS_WAIT
-AC_CHECK_HEADERS([fcntl.h inttypes.h limits.h memory.h alloca.h malloc.h stdlib.h string.h strings.h errno.h sys/types.h sys/ioctl.h sys/statvfs.h sys/time.h unistd.h dirent.h math.h float.h ieeefp.h floatingpoint.h complex.h fftw3.h setjmp.h signal.h mach/mach_time.h sys/param.h sys/systm.h machine/cpu.h])
+AC_HEADER_TIME
+AC_CHECK_HEADERS([fcntl.h inttypes.h limits.h memory.h alloca.h malloc.h stdlib.h string.h strings.h errno.h sys/time.h sys/types.h sys/ioctl.h sys/statvfs.h unistd.h dirent.h math.h float.h ieeefp.h floatingpoint.h complex.h fftw3.h setjmp.h signal.h mach/mach_time.h sys/param.h sys/systm.h machine/cpu.h cpu-features.h sys/cpu-features.h machine/cpu-features.h])
 save_cxxflags="${CXXFLAGS}"
 save_cppflags="${CPPFLAGS}"
 CXXFLAGS="${CXXFLAGS} -msse3"
@@ -403,15 +408,13 @@ AC_CACHE_SAVE
 AC_LANG(C)
 AC_FUNC_FORK
 AC_HEADER_MAJOR
-AC_FUNC_MALLOC
-AC_FUNC_REALLOC
 AC_FUNC_ALLOCA
 if test "${ac_cv_func_alloca_works}" = "yes" ; then
   ac_cv_func_alloca="yes"
 fi
 AC_FUNC_STAT
 AC_FUNC_STRFTIME
-AC_CHECK_FUNCS([ _aligned_malloc alloca _alloca __builtin_alloca memalign atexit exit _exit getcwd memset munmap putenv strchr strstr strcasestr atoll dlopen gethrtime mach_absolute_time get_cyclecount nanotime microtime gettimeofday sqrt floor sinf cosf sincos sincosf atanf isnan _isnan __isnan isnanf _isnanf __isnanf siglongjmp sigsetjmp sigaction sysv_signal bsd_signal ])
+AC_CHECK_FUNCS([ _aligned_malloc alloca _alloca __builtin_alloca memalign atexit exit _exit getcwd memset munmap putenv strchr strstr strcasestr atoll dlopen gethrtime mach_absolute_time get_cyclecount clock_gettime nanotime microtime gettimeofday sqrt floor sinf cosf sincos sincosf atanf isnan _isnan __isnan isnanf _isnanf __isnanf siglongjmp sigsetjmp sigaction sysv_signal bsd_signal ])
 SAH_CHECK_NAMESPACES
 AH_TEMPLATE([HAVE_STD_MIN],[Define to 1 if min is in namespace std::])
 AH_TEMPLATE([HAVE_STD_MAX],[Define to 1 if max is in namespace std::])
diff --git a/db/schema_master.cpp b/db/schema_master.cpp
index 51adfe0..fe2dd6c 100644
--- a/db/schema_master.cpp
+++ b/db/schema_master.cpp
@@ -5619,8 +5619,8 @@ std::string settings::print_xml(int full_subtables, int show_ids, int no_refs,co
 
 template <> const char * const db_table<workunit_grp>::table_name="workunit_grp";
 template <> const char * db_table<workunit_grp>::_search_tag=table_name;
-template <> const int db_table<workunit_grp>::_nfields=10;
-template <> const char * const db_table<workunit_grp>::column_names[10]={"id","tape_info","name","data_desc","receiver_cfg","recorder_cfg","splitter_cfg","analysis_cfg","sb_id","iq_modified"};
+template <> const int db_table<workunit_grp>::_nfields=11;
+template <> const char * const db_table<workunit_grp>::column_names[11]={"id","tape_info","name","data_desc","receiver_cfg","recorder_cfg","splitter_cfg","analysis_cfg","sb_id","iq_modified","alfa_filter_bank"};
 
 workunit_grp::workunit_grp() : 
 	db_table<workunit_grp>(*this,-1),
@@ -5632,7 +5632,8 @@ workunit_grp::workunit_grp() :
 	splitter_cfg(),
 	analysis_cfg(),
 	sb_id(0),
-	iq_modified(0)
+	iq_modified(0),
+	alfa_filter_bank(0)
 {
 	db_open();
 	name[0]=0;
@@ -5649,7 +5650,8 @@ workunit_grp::workunit_grp(const workunit_grp &a) :
 	splitter_cfg(a.splitter_cfg),
 	analysis_cfg(a.analysis_cfg),
 	sb_id(a.sb_id),
-	iq_modified(a.iq_modified)
+	iq_modified(a.iq_modified),
+	alfa_filter_bank(a.alfa_filter_bank)
 {
 	db_open();
 	strcpy(name,a.name);
@@ -5687,6 +5689,7 @@ workunit_grp &workunit_grp::operator =(const workunit_grp &a) {
 		analysis_cfg=a.analysis_cfg;
 		sb_id=a.sb_id;
 		iq_modified=a.iq_modified;
+		alfa_filter_bank=a.alfa_filter_bank;
 	strcpy(name,a.name);
 	}
 	return (*this);
@@ -5696,7 +5699,7 @@ workunit_grp &workunit_grp::operator =(const workunit_grp &a) {
 std::string workunit_grp::update_format() const
 {	std::ostringstream rv("");
 
-	for (int i=2;i<10;i++) rv << "?,";
+	for (int i=2;i<11;i++) rv << "?,";
 	rv << "?";
 	return rv.str();
 }
@@ -5709,7 +5712,7 @@ std::string workunit_grp::insert_format() const
 std::string workunit_grp::select_format() const
 {
 std::string rv("");
-for (int i=0; i<9;i++) rv+="?,";
+for (int i=0; i<10;i++) rv+="?,";
 rv+="?";
 return rv;
 }
@@ -5767,6 +5770,8 @@ std::string workunit_grp::print(int full_subtables, int show_ids, int no_refs) c
 	rv << sb_id;
 	rv << ',';
 	rv << iq_modified;
+	rv << ',';
+	rv << alfa_filter_bank;
 	return rv.str();
 }
 
@@ -5822,6 +5827,7 @@ std::string workunit_grp::print_xml(int full_subtables, int show_ids, int no_ref
 	}
 	rv << xml_indent() << "<sb_id>" << sb_id << "</sb_id>\n";
 	rv << xml_indent() << "<iq_modified>" << iq_modified << "</iq_modified>\n";
+	rv << xml_indent() << "<alfa_filter_bank>" << alfa_filter_bank << "</alfa_filter_bank>\n";
 	xml_indent(-2);
 	rv << xml_indent() << "</" << tag << ">\n";
 	return rv.str();
@@ -5878,6 +5884,12 @@ std::string workunit_grp::print_xml(int full_subtables, int show_ids, int no_ref
 	        std::istringstream in(sub.c_str()+pos);
 	        in >> iq_modified;
 	      }
+	    if (extract_xml_record(field,"alfa_filter_bank",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> alfa_filter_bank;
+	      }
 	      }
 	      }
 
@@ -5916,10 +5928,14 @@ std::string workunit_grp::print_xml(int full_subtables, int show_ids, int no_ref
 	        std::istringstream row(*(s[9]));
 	        row >> iq_modified;
 	    }
+	  {  
+	        std::istringstream row(*(s[10]));
+	        row >> alfa_filter_bank;
+	    }
 	      }
 
 	void workunit_grp::parse(const std::string &s) {
-	      SQL_ROW row(&s,10);
+	      SQL_ROW row(&s,11);
 	      parse(row);
 	      }
 
@@ -12393,3 +12409,2059 @@ std::string bad_data::print_xml(int full_subtables, int show_ids, int no_refs,co
 	      parse(row);
 	      }
 
+template <> const char * const db_table<spike_tinysky>::table_name="spike_tinysky";
+template <> const char * db_table<spike_tinysky>::_search_tag=table_name;
+template <> const int db_table<spike_tinysky>::_nfields=16;
+template <> const char * const db_table<spike_tinysky>::column_names[16]={"id","result_id","peak_power","mean_power","time","ra","decl","q_pix","freq","detection_freq","barycentric_freq","fft_len","chirp_rate","rfi_checked","rfi_found","reserved"};
+
+spike_tinysky::spike_tinysky() : 
+	db_table<spike_tinysky>(*this,-1),
+	id(0),
+	result_id(),
+	peak_power(0),
+	mean_power(0),
+	time(0),
+	ra(0),
+	decl(0),
+	q_pix(0),
+	freq(0),
+	detection_freq(0),
+	barycentric_freq(0),
+	fft_len(0),
+	chirp_rate(0),
+	rfi_checked(0),
+	rfi_found(0),
+	reserved(0)
+{
+	db_open();
+}
+
+
+spike_tinysky::spike_tinysky(const spike_tinysky &a) : 
+	db_table<spike_tinysky>(*this,-1),
+	id(a.id),
+	result_id(a.result_id),
+	peak_power(a.peak_power),
+	mean_power(a.mean_power),
+	time(a.time),
+	ra(a.ra),
+	decl(a.decl),
+	q_pix(a.q_pix),
+	freq(a.freq),
+	detection_freq(a.detection_freq),
+	barycentric_freq(a.barycentric_freq),
+	fft_len(a.fft_len),
+	chirp_rate(a.chirp_rate),
+	rfi_checked(a.rfi_checked),
+	rfi_found(a.rfi_found),
+	reserved(a.reserved)
+{
+	db_open();
+}
+
+
+spike_tinysky::spike_tinysky(const SQL_ROW &a) : 
+	db_table<spike_tinysky>(*this,-1)
+{
+	db_open();
+	parse(a);
+}
+
+
+spike_tinysky::spike_tinysky(const std::string &s,const char *tag) : 
+	db_table<spike_tinysky>(*this,-1)
+{
+	db_open();
+	if (xml_match_tag(s,tag)) {
+	  parse_xml(s,tag);
+	} else {
+	  parse(s);
+	}
+}
+
+
+spike_tinysky &spike_tinysky::operator =(const spike_tinysky &a) {
+	if (&a != this) {
+		id=a.id;
+		result_id=a.result_id;
+		peak_power=a.peak_power;
+		mean_power=a.mean_power;
+		time=a.time;
+		ra=a.ra;
+		decl=a.decl;
+		q_pix=a.q_pix;
+		freq=a.freq;
+		detection_freq=a.detection_freq;
+		barycentric_freq=a.barycentric_freq;
+		fft_len=a.fft_len;
+		chirp_rate=a.chirp_rate;
+		rfi_checked=a.rfi_checked;
+		rfi_found=a.rfi_found;
+		reserved=a.reserved;
+	}
+	return (*this);
+}
+
+
+std::string spike_tinysky::update_format() const
+{	std::ostringstream rv("");
+
+	for (int i=2;i<16;i++) rv << "?,";
+	rv << "?";
+	return rv.str();
+}
+
+
+std::string spike_tinysky::insert_format() const
+{	return std::string("?,")+update_format();
+}
+
+std::string spike_tinysky::select_format() const
+{
+std::string rv("");
+for (int i=0; i<15;i++) rv+="?,";
+rv+="?";
+return rv;
+}
+
+std::string spike_tinysky::print(int full_subtables, int show_ids, int no_refs) const
+{	std::ostringstream rv("");
+
+	rv.precision(14);
+	if (show_ids) rv << id;
+	rv << ',';
+	if (!no_refs) {
+	  if (full_subtables) {
+	    rv << result_id.print(full_subtables,show_ids,no_refs);
+	} else {
+	    rv << result_id.id;
+	  }
+	}
+	rv << ',';
+	rv << peak_power;
+	rv << ',';
+	rv << mean_power;
+	rv << ',';
+	rv << time;
+	rv << ',';
+	rv << ra;
+	rv << ',';
+	rv << decl;
+	rv << ',';
+	rv << q_pix;
+	rv << ',';
+	rv << freq;
+	rv << ',';
+	rv << detection_freq;
+	rv << ',';
+	rv << barycentric_freq;
+	rv << ',';
+	rv << fft_len;
+	rv << ',';
+	rv << chirp_rate;
+	rv << ',';
+	rv << rfi_checked;
+	rv << ',';
+	rv << rfi_found;
+	rv << ',';
+	rv << reserved;
+	return rv.str();
+}
+
+
+std::string spike_tinysky::print_xml(int full_subtables, int show_ids, int no_refs,const char *tag) const 
+{
+	std::ostringstream rv("");
+
+	rv.precision(14);
+	rv << xml_indent() << '<' << tag << ">\n";
+	xml_indent(2);
+	if (show_ids) rv << xml_indent() << "<id>" << id << "</id>\n";
+	if (!no_refs) {
+	  if (full_subtables) {
+	    rv << result_id.print_xml(full_subtables,show_ids,no_refs,"result_id");
+	} else {
+	    rv << xml_indent() << "<result_id><id>" << result_id.id << "</id></result_id>\n";
+	  }
+	}
+	rv << xml_indent() << "<peak_power>" << peak_power << "</peak_power>\n";
+	rv << xml_indent() << "<mean_power>" << mean_power << "</mean_power>\n";
+	rv << xml_indent() << "<time>" << time << "</time>\n";
+	rv << xml_indent() << "<ra>" << ra << "</ra>\n";
+	rv << xml_indent() << "<decl>" << decl << "</decl>\n";
+	rv << xml_indent() << "<q_pix>" << q_pix << "</q_pix>\n";
+	rv << xml_indent() << "<freq>" << freq << "</freq>\n";
+	rv << xml_indent() << "<detection_freq>" << detection_freq << "</detection_freq>\n";
+	rv << xml_indent() << "<barycentric_freq>" << barycentric_freq << "</barycentric_freq>\n";
+	rv << xml_indent() << "<fft_len>" << fft_len << "</fft_len>\n";
+	rv << xml_indent() << "<chirp_rate>" << chirp_rate << "</chirp_rate>\n";
+	rv << xml_indent() << "<rfi_checked>" << rfi_checked << "</rfi_checked>\n";
+	rv << xml_indent() << "<rfi_found>" << rfi_found << "</rfi_found>\n";
+	rv << xml_indent() << "<reserved>" << reserved << "</reserved>\n";
+	xml_indent(-2);
+	rv << xml_indent() << "</" << tag << ">\n";
+	return rv.str();
+}
+
+
+	void spike_tinysky::parse_xml(const std::string &s,const char *tag) {
+	  std::string field,sub;
+	  if (extract_xml_record(s,tag,field)) {
+	  std::string::size_type pos=0;
+	    if (extract_xml_record(field,"id",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> id;
+	      }
+	    if (extract_xml_record(field,"result_id",sub)) {
+	      result_id.parse_xml(sub,"result_id");
+	    }
+	    if (extract_xml_record(field,"peak_power",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> peak_power;
+	      }
+	    if (extract_xml_record(field,"mean_power",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> mean_power;
+	      }
+	    if (extract_xml_record(field,"time",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> time;
+	      }
+	    if (extract_xml_record(field,"ra",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> ra;
+	      }
+	    if (extract_xml_record(field,"decl",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> decl;
+	      }
+	    if (extract_xml_record(field,"q_pix",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> q_pix;
+	      }
+	    if (extract_xml_record(field,"freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> freq;
+	      }
+	    if (extract_xml_record(field,"detection_freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> detection_freq;
+	      }
+	    if (extract_xml_record(field,"barycentric_freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> barycentric_freq;
+	      }
+	    if (extract_xml_record(field,"fft_len",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> fft_len;
+	      }
+	    if (extract_xml_record(field,"chirp_rate",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> chirp_rate;
+	      }
+	    if (extract_xml_record(field,"rfi_checked",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> rfi_checked;
+	      }
+	    if (extract_xml_record(field,"rfi_found",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> rfi_found;
+	      }
+	    if (extract_xml_record(field,"reserved",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> reserved;
+	      }
+	      }
+	      }
+
+	void spike_tinysky::parse(const SQL_ROW &s) {
+	  {  
+	        std::istringstream row(*(s[0]));
+	        row >> id;
+	    }
+	  {  
+	  result_id.parse(SQL_ROW(s[1],0));
+	    }
+	  {  
+	        std::istringstream row(*(s[2]));
+	        row >> peak_power;
+	    }
+	  {  
+	        std::istringstream row(*(s[3]));
+	        row >> mean_power;
+	    }
+	  {  
+	        std::istringstream row(*(s[4]));
+	        row >> time;
+	    }
+	  {  
+	        std::istringstream row(*(s[5]));
+	        row >> ra;
+	    }
+	  {  
+	        std::istringstream row(*(s[6]));
+	        row >> decl;
+	    }
+	  {  
+	        std::istringstream row(*(s[7]));
+	        row >> q_pix;
+	    }
+	  {  
+	        std::istringstream row(*(s[8]));
+	        row >> freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[9]));
+	        row >> detection_freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[10]));
+	        row >> barycentric_freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[11]));
+	        row >> fft_len;
+	    }
+	  {  
+	        std::istringstream row(*(s[12]));
+	        row >> chirp_rate;
+	    }
+	  {  
+	        std::istringstream row(*(s[13]));
+	        row >> rfi_checked;
+	    }
+	  {  
+	        std::istringstream row(*(s[14]));
+	        row >> rfi_found;
+	    }
+	  {  
+	        std::istringstream row(*(s[15]));
+	        row >> reserved;
+	    }
+	      }
+
+	void spike_tinysky::parse(const std::string &s) {
+	      SQL_ROW row(&s,16);
+	      parse(row);
+	      }
+
+template <> const char * const db_table<gaussian_tinysky>::table_name="gaussian_tinysky";
+template <> const char * db_table<gaussian_tinysky>::_search_tag=table_name;
+template <> const int db_table<gaussian_tinysky>::_nfields=22;
+template <> const char * const db_table<gaussian_tinysky>::column_names[22]={"id","result_id","peak_power","mean_power","time","ra","decl","q_pix","freq","detection_freq","barycentric_freq","fft_len","chirp_rate","rfi_checked","rfi_found","reserved","sigma","chisqr","null_chisqr","score","max_power","pot"};
+
+gaussian_tinysky::gaussian_tinysky() : 
+	db_table<gaussian_tinysky>(*this,-1),
+	id(0),
+	result_id(),
+	peak_power(0),
+	mean_power(0),
+	time(0),
+	ra(0),
+	decl(0),
+	q_pix(0),
+	freq(0),
+	detection_freq(0),
+	barycentric_freq(0),
+	fft_len(0),
+	chirp_rate(0),
+	rfi_checked(0),
+	rfi_found(0),
+	reserved(0),
+	sigma(0),
+	chisqr(0),
+	null_chisqr(0),
+	score(0),
+	max_power(0),
+	pot((unsigned char *)0,0,_x_csv)
+{
+	db_open();
+}
+
+
+gaussian_tinysky::gaussian_tinysky(const gaussian_tinysky &a) : 
+	db_table<gaussian_tinysky>(*this,-1),
+	id(a.id),
+	result_id(a.result_id),
+	peak_power(a.peak_power),
+	mean_power(a.mean_power),
+	time(a.time),
+	ra(a.ra),
+	decl(a.decl),
+	q_pix(a.q_pix),
+	freq(a.freq),
+	detection_freq(a.detection_freq),
+	barycentric_freq(a.barycentric_freq),
+	fft_len(a.fft_len),
+	chirp_rate(a.chirp_rate),
+	rfi_checked(a.rfi_checked),
+	rfi_found(a.rfi_found),
+	reserved(a.reserved),
+	sigma(a.sigma),
+	chisqr(a.chisqr),
+	null_chisqr(a.null_chisqr),
+	score(a.score),
+	max_power(a.max_power),
+	pot(a.pot)
+{
+	db_open();
+}
+
+
+gaussian_tinysky::gaussian_tinysky(const SQL_ROW &a) : 
+	db_table<gaussian_tinysky>(*this,-1)
+{
+	db_open();
+	parse(a);
+}
+
+
+gaussian_tinysky::gaussian_tinysky(const std::string &s,const char *tag) : 
+	db_table<gaussian_tinysky>(*this,-1)
+{
+	db_open();
+	if (xml_match_tag(s,tag)) {
+	  parse_xml(s,tag);
+	} else {
+	  parse(s);
+	}
+}
+
+
+gaussian_tinysky &gaussian_tinysky::operator =(const gaussian_tinysky &a) {
+	if (&a != this) {
+		id=a.id;
+		result_id=a.result_id;
+		peak_power=a.peak_power;
+		mean_power=a.mean_power;
+		time=a.time;
+		ra=a.ra;
+		decl=a.decl;
+		q_pix=a.q_pix;
+		freq=a.freq;
+		detection_freq=a.detection_freq;
+		barycentric_freq=a.barycentric_freq;
+		fft_len=a.fft_len;
+		chirp_rate=a.chirp_rate;
+		rfi_checked=a.rfi_checked;
+		rfi_found=a.rfi_found;
+		reserved=a.reserved;
+		sigma=a.sigma;
+		chisqr=a.chisqr;
+		null_chisqr=a.null_chisqr;
+		score=a.score;
+		max_power=a.max_power;
+		pot=a.pot;
+	}
+	return (*this);
+}
+
+
+std::string gaussian_tinysky::update_format() const
+{	std::ostringstream rv("");
+
+	for (int i=2;i<22;i++) rv << "?,";
+	rv << "?";
+	return rv.str();
+}
+
+
+std::string gaussian_tinysky::insert_format() const
+{	return std::string("?,")+update_format();
+}
+
+std::string gaussian_tinysky::select_format() const
+{
+std::string rv("");
+for (int i=0; i<21;i++) rv+="?,";
+rv+="?";
+return rv;
+}
+
+std::string gaussian_tinysky::print(int full_subtables, int show_ids, int no_refs) const
+{	std::ostringstream rv("");
+
+	rv.precision(14);
+	if (show_ids) rv << id;
+	rv << ',';
+	if (!no_refs) {
+	  if (full_subtables) {
+	    rv << result_id.print(full_subtables,show_ids,no_refs);
+	} else {
+	    rv << result_id.id;
+	  }
+	}
+	rv << ',';
+	rv << peak_power;
+	rv << ',';
+	rv << mean_power;
+	rv << ',';
+	rv << time;
+	rv << ',';
+	rv << ra;
+	rv << ',';
+	rv << decl;
+	rv << ',';
+	rv << q_pix;
+	rv << ',';
+	rv << freq;
+	rv << ',';
+	rv << detection_freq;
+	rv << ',';
+	rv << barycentric_freq;
+	rv << ',';
+	rv << fft_len;
+	rv << ',';
+	rv << chirp_rate;
+	rv << ',';
+	rv << rfi_checked;
+	rv << ',';
+	rv << rfi_found;
+	rv << ',';
+	rv << reserved;
+	rv << ',';
+	rv << sigma;
+	rv << ',';
+	rv << chisqr;
+	rv << ',';
+	rv << null_chisqr;
+	rv << ',';
+	rv << score;
+	rv << ',';
+	rv << max_power;
+	rv << ',';
+	rv << "<BYTE len=" << std::max(pot.size()*2,(size_t)1) << ">" << pot.print_hex() ;
+	return rv.str();
+}
+
+
+std::string gaussian_tinysky::print_xml(int full_subtables, int show_ids, int no_refs,const char *tag) const 
+{
+	std::ostringstream rv("");
+
+	rv.precision(14);
+	rv << xml_indent() << '<' << tag << ">\n";
+	xml_indent(2);
+	if (show_ids) rv << xml_indent() << "<id>" << id << "</id>\n";
+	if (!no_refs) {
+	  if (full_subtables) {
+	    rv << result_id.print_xml(full_subtables,show_ids,no_refs,"result_id");
+	} else {
+	    rv << xml_indent() << "<result_id><id>" << result_id.id << "</id></result_id>\n";
+	  }
+	}
+	rv << xml_indent() << "<peak_power>" << peak_power << "</peak_power>\n";
+	rv << xml_indent() << "<mean_power>" << mean_power << "</mean_power>\n";
+	rv << xml_indent() << "<time>" << time << "</time>\n";
+	rv << xml_indent() << "<ra>" << ra << "</ra>\n";
+	rv << xml_indent() << "<decl>" << decl << "</decl>\n";
+	rv << xml_indent() << "<q_pix>" << q_pix << "</q_pix>\n";
+	rv << xml_indent() << "<freq>" << freq << "</freq>\n";
+	rv << xml_indent() << "<detection_freq>" << detection_freq << "</detection_freq>\n";
+	rv << xml_indent() << "<barycentric_freq>" << barycentric_freq << "</barycentric_freq>\n";
+	rv << xml_indent() << "<fft_len>" << fft_len << "</fft_len>\n";
+	rv << xml_indent() << "<chirp_rate>" << chirp_rate << "</chirp_rate>\n";
+	rv << xml_indent() << "<rfi_checked>" << rfi_checked << "</rfi_checked>\n";
+	rv << xml_indent() << "<rfi_found>" << rfi_found << "</rfi_found>\n";
+	rv << xml_indent() << "<reserved>" << reserved << "</reserved>\n";
+	rv << xml_indent() << "<sigma>" << sigma << "</sigma>\n";
+	rv << xml_indent() << "<chisqr>" << chisqr << "</chisqr>\n";
+	rv << xml_indent() << "<null_chisqr>" << null_chisqr << "</null_chisqr>\n";
+	rv << xml_indent() << "<score>" << score << "</score>\n";
+	rv << xml_indent() << "<max_power>" << max_power << "</max_power>\n";
+	if (pot.size()) {
+	  std::string enc_field=xml_encode_string(pot,pot.encoding);
+	  rv << xml_indent() << "<pot length=" << enc_field.size() << " encoding=\"" << xml_encoding_names[pot.encoding] << "\">"; 
+	  rv << enc_field << "</pot>\n";
+	}
+	xml_indent(-2);
+	rv << xml_indent() << "</" << tag << ">\n";
+	return rv.str();
+}
+
+
+	void gaussian_tinysky::parse_xml(const std::string &s,const char *tag) {
+	  std::string field,sub;
+	  if (extract_xml_record(s,tag,field)) {
+	  std::string::size_type pos=0;
+	    if (extract_xml_record(field,"id",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> id;
+	      }
+	    if (extract_xml_record(field,"result_id",sub)) {
+	      result_id.parse_xml(sub,"result_id");
+	    }
+	    if (extract_xml_record(field,"peak_power",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> peak_power;
+	      }
+	    if (extract_xml_record(field,"mean_power",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> mean_power;
+	      }
+	    if (extract_xml_record(field,"time",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> time;
+	      }
+	    if (extract_xml_record(field,"ra",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> ra;
+	      }
+	    if (extract_xml_record(field,"decl",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> decl;
+	      }
+	    if (extract_xml_record(field,"q_pix",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> q_pix;
+	      }
+	    if (extract_xml_record(field,"freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> freq;
+	      }
+	    if (extract_xml_record(field,"detection_freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> detection_freq;
+	      }
+	    if (extract_xml_record(field,"barycentric_freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> barycentric_freq;
+	      }
+	    if (extract_xml_record(field,"fft_len",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> fft_len;
+	      }
+	    if (extract_xml_record(field,"chirp_rate",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> chirp_rate;
+	      }
+	    if (extract_xml_record(field,"rfi_checked",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> rfi_checked;
+	      }
+	    if (extract_xml_record(field,"rfi_found",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> rfi_found;
+	      }
+	    if (extract_xml_record(field,"reserved",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> reserved;
+	      }
+	    if (extract_xml_record(field,"sigma",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> sigma;
+	      }
+	    if (extract_xml_record(field,"chisqr",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> chisqr;
+	      }
+	    if (extract_xml_record(field,"null_chisqr",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> null_chisqr;
+	      }
+	    if (extract_xml_record(field,"score",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> score;
+	      }
+	    if (extract_xml_record(field,"max_power",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> max_power;
+	      }
+	    if (extract_xml_record(field,"pot",sub)) {
+	        std::istringstream in(sub.c_str());
+	        in >> pot;
+	      }
+	      }
+	      }
+
+	void gaussian_tinysky::parse(const SQL_ROW &s) {
+	  {  
+	        std::istringstream row(*(s[0]));
+	        row >> id;
+	    }
+	  {  
+	  result_id.parse(SQL_ROW(s[1],0));
+	    }
+	  {  
+	        std::istringstream row(*(s[2]));
+	        row >> peak_power;
+	    }
+	  {  
+	        std::istringstream row(*(s[3]));
+	        row >> mean_power;
+	    }
+	  {  
+	        std::istringstream row(*(s[4]));
+	        row >> time;
+	    }
+	  {  
+	        std::istringstream row(*(s[5]));
+	        row >> ra;
+	    }
+	  {  
+	        std::istringstream row(*(s[6]));
+	        row >> decl;
+	    }
+	  {  
+	        std::istringstream row(*(s[7]));
+	        row >> q_pix;
+	    }
+	  {  
+	        std::istringstream row(*(s[8]));
+	        row >> freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[9]));
+	        row >> detection_freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[10]));
+	        row >> barycentric_freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[11]));
+	        row >> fft_len;
+	    }
+	  {  
+	        std::istringstream row(*(s[12]));
+	        row >> chirp_rate;
+	    }
+	  {  
+	        std::istringstream row(*(s[13]));
+	        row >> rfi_checked;
+	    }
+	  {  
+	        std::istringstream row(*(s[14]));
+	        row >> rfi_found;
+	    }
+	  {  
+	        std::istringstream row(*(s[15]));
+	        row >> reserved;
+	    }
+	  {  
+	        std::istringstream row(*(s[16]));
+	        row >> sigma;
+	    }
+	  {  
+	        std::istringstream row(*(s[17]));
+	        row >> chisqr;
+	    }
+	  {  
+	        std::istringstream row(*(s[18]));
+	        row >> null_chisqr;
+	    }
+	  {  
+	        std::istringstream row(*(s[19]));
+	        row >> score;
+	    }
+	  {  
+	        std::istringstream row(*(s[20]));
+	        row >> max_power;
+	    }
+	  {  
+	        pot=sqlblob<unsigned char>(*(s[21]));
+	    }
+	      }
+
+	void gaussian_tinysky::parse(const std::string &s) {
+	      SQL_ROW row(&s,22);
+	      parse(row);
+	      }
+
+template <> const char * const db_table<pulse_tinysky>::table_name="pulse_tinysky";
+template <> const char * db_table<pulse_tinysky>::_search_tag=table_name;
+template <> const int db_table<pulse_tinysky>::_nfields=22;
+template <> const char * const db_table<pulse_tinysky>::column_names[22]={"id","result_id","peak_power","mean_power","time","ra","decl","q_pix","freq","detection_freq","barycentric_freq","fft_len","chirp_rate","rfi_checked","rfi_found","reserved","period","snr","thresh","score","len_prof","pot"};
+
+pulse_tinysky::pulse_tinysky() : 
+	db_table<pulse_tinysky>(*this,-1),
+	id(0),
+	result_id(),
+	peak_power(0),
+	mean_power(0),
+	time(0),
+	ra(0),
+	decl(0),
+	q_pix(0),
+	freq(0),
+	detection_freq(0),
+	barycentric_freq(0),
+	fft_len(0),
+	chirp_rate(0),
+	rfi_checked(0),
+	rfi_found(0),
+	reserved(0),
+	period(0),
+	snr(0),
+	thresh(0),
+	score(0),
+	len_prof(0),
+	pot((unsigned char *)0,0,_x_csv)
+{
+	db_open();
+}
+
+
+pulse_tinysky::pulse_tinysky(const pulse_tinysky &a) : 
+	db_table<pulse_tinysky>(*this,-1),
+	id(a.id),
+	result_id(a.result_id),
+	peak_power(a.peak_power),
+	mean_power(a.mean_power),
+	time(a.time),
+	ra(a.ra),
+	decl(a.decl),
+	q_pix(a.q_pix),
+	freq(a.freq),
+	detection_freq(a.detection_freq),
+	barycentric_freq(a.barycentric_freq),
+	fft_len(a.fft_len),
+	chirp_rate(a.chirp_rate),
+	rfi_checked(a.rfi_checked),
+	rfi_found(a.rfi_found),
+	reserved(a.reserved),
+	period(a.period),
+	snr(a.snr),
+	thresh(a.thresh),
+	score(a.score),
+	len_prof(a.len_prof),
+	pot(a.pot)
+{
+	db_open();
+}
+
+
+pulse_tinysky::pulse_tinysky(const SQL_ROW &a) : 
+	db_table<pulse_tinysky>(*this,-1)
+{
+	db_open();
+	parse(a);
+}
+
+
+pulse_tinysky::pulse_tinysky(const std::string &s,const char *tag) : 
+	db_table<pulse_tinysky>(*this,-1)
+{
+	db_open();
+	if (xml_match_tag(s,tag)) {
+	  parse_xml(s,tag);
+	} else {
+	  parse(s);
+	}
+}
+
+
+pulse_tinysky &pulse_tinysky::operator =(const pulse_tinysky &a) {
+	if (&a != this) {
+		id=a.id;
+		result_id=a.result_id;
+		peak_power=a.peak_power;
+		mean_power=a.mean_power;
+		time=a.time;
+		ra=a.ra;
+		decl=a.decl;
+		q_pix=a.q_pix;
+		freq=a.freq;
+		detection_freq=a.detection_freq;
+		barycentric_freq=a.barycentric_freq;
+		fft_len=a.fft_len;
+		chirp_rate=a.chirp_rate;
+		rfi_checked=a.rfi_checked;
+		rfi_found=a.rfi_found;
+		reserved=a.reserved;
+		period=a.period;
+		snr=a.snr;
+		thresh=a.thresh;
+		score=a.score;
+		len_prof=a.len_prof;
+		pot=a.pot;
+	}
+	return (*this);
+}
+
+
+std::string pulse_tinysky::update_format() const
+{	std::ostringstream rv("");
+
+	for (int i=2;i<22;i++) rv << "?,";
+	rv << "?";
+	return rv.str();
+}
+
+
+std::string pulse_tinysky::insert_format() const
+{	return std::string("?,")+update_format();
+}
+
+std::string pulse_tinysky::select_format() const
+{
+std::string rv("");
+for (int i=0; i<21;i++) rv+="?,";
+rv+="?";
+return rv;
+}
+
+std::string pulse_tinysky::print(int full_subtables, int show_ids, int no_refs) const
+{	std::ostringstream rv("");
+
+	rv.precision(14);
+	if (show_ids) rv << id;
+	rv << ',';
+	if (!no_refs) {
+	  if (full_subtables) {
+	    rv << result_id.print(full_subtables,show_ids,no_refs);
+	} else {
+	    rv << result_id.id;
+	  }
+	}
+	rv << ',';
+	rv << peak_power;
+	rv << ',';
+	rv << mean_power;
+	rv << ',';
+	rv << time;
+	rv << ',';
+	rv << ra;
+	rv << ',';
+	rv << decl;
+	rv << ',';
+	rv << q_pix;
+	rv << ',';
+	rv << freq;
+	rv << ',';
+	rv << detection_freq;
+	rv << ',';
+	rv << barycentric_freq;
+	rv << ',';
+	rv << fft_len;
+	rv << ',';
+	rv << chirp_rate;
+	rv << ',';
+	rv << rfi_checked;
+	rv << ',';
+	rv << rfi_found;
+	rv << ',';
+	rv << reserved;
+	rv << ',';
+	rv << period;
+	rv << ',';
+	rv << snr;
+	rv << ',';
+	rv << thresh;
+	rv << ',';
+	rv << score;
+	rv << ',';
+	rv << len_prof;
+	rv << ',';
+	rv << "<BYTE len=" << std::max(pot.size()*2,(size_t)1) << ">" << pot.print_hex() ;
+	return rv.str();
+}
+
+
+std::string pulse_tinysky::print_xml(int full_subtables, int show_ids, int no_refs,const char *tag) const 
+{
+	std::ostringstream rv("");
+
+	rv.precision(14);
+	rv << xml_indent() << '<' << tag << ">\n";
+	xml_indent(2);
+	if (show_ids) rv << xml_indent() << "<id>" << id << "</id>\n";
+	if (!no_refs) {
+	  if (full_subtables) {
+	    rv << result_id.print_xml(full_subtables,show_ids,no_refs,"result_id");
+	} else {
+	    rv << xml_indent() << "<result_id><id>" << result_id.id << "</id></result_id>\n";
+	  }
+	}
+	rv << xml_indent() << "<peak_power>" << peak_power << "</peak_power>\n";
+	rv << xml_indent() << "<mean_power>" << mean_power << "</mean_power>\n";
+	rv << xml_indent() << "<time>" << time << "</time>\n";
+	rv << xml_indent() << "<ra>" << ra << "</ra>\n";
+	rv << xml_indent() << "<decl>" << decl << "</decl>\n";
+	rv << xml_indent() << "<q_pix>" << q_pix << "</q_pix>\n";
+	rv << xml_indent() << "<freq>" << freq << "</freq>\n";
+	rv << xml_indent() << "<detection_freq>" << detection_freq << "</detection_freq>\n";
+	rv << xml_indent() << "<barycentric_freq>" << barycentric_freq << "</barycentric_freq>\n";
+	rv << xml_indent() << "<fft_len>" << fft_len << "</fft_len>\n";
+	rv << xml_indent() << "<chirp_rate>" << chirp_rate << "</chirp_rate>\n";
+	rv << xml_indent() << "<rfi_checked>" << rfi_checked << "</rfi_checked>\n";
+	rv << xml_indent() << "<rfi_found>" << rfi_found << "</rfi_found>\n";
+	rv << xml_indent() << "<reserved>" << reserved << "</reserved>\n";
+	rv << xml_indent() << "<period>" << period << "</period>\n";
+	rv << xml_indent() << "<snr>" << snr << "</snr>\n";
+	rv << xml_indent() << "<thresh>" << thresh << "</thresh>\n";
+	rv << xml_indent() << "<score>" << score << "</score>\n";
+	rv << xml_indent() << "<len_prof>" << len_prof << "</len_prof>\n";
+	if (pot.size()) {
+	  std::string enc_field=xml_encode_string(pot,pot.encoding);
+	  rv << xml_indent() << "<pot length=" << enc_field.size() << " encoding=\"" << xml_encoding_names[pot.encoding] << "\">"; 
+	  rv << enc_field << "</pot>\n";
+	}
+	xml_indent(-2);
+	rv << xml_indent() << "</" << tag << ">\n";
+	return rv.str();
+}
+
+
+	void pulse_tinysky::parse_xml(const std::string &s,const char *tag) {
+	  std::string field,sub;
+	  if (extract_xml_record(s,tag,field)) {
+	  std::string::size_type pos=0;
+	    if (extract_xml_record(field,"id",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> id;
+	      }
+	    if (extract_xml_record(field,"result_id",sub)) {
+	      result_id.parse_xml(sub,"result_id");
+	    }
+	    if (extract_xml_record(field,"peak_power",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> peak_power;
+	      }
+	    if (extract_xml_record(field,"mean_power",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> mean_power;
+	      }
+	    if (extract_xml_record(field,"time",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> time;
+	      }
+	    if (extract_xml_record(field,"ra",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> ra;
+	      }
+	    if (extract_xml_record(field,"decl",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> decl;
+	      }
+	    if (extract_xml_record(field,"q_pix",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> q_pix;
+	      }
+	    if (extract_xml_record(field,"freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> freq;
+	      }
+	    if (extract_xml_record(field,"detection_freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> detection_freq;
+	      }
+	    if (extract_xml_record(field,"barycentric_freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> barycentric_freq;
+	      }
+	    if (extract_xml_record(field,"fft_len",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> fft_len;
+	      }
+	    if (extract_xml_record(field,"chirp_rate",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> chirp_rate;
+	      }
+	    if (extract_xml_record(field,"rfi_checked",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> rfi_checked;
+	      }
+	    if (extract_xml_record(field,"rfi_found",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> rfi_found;
+	      }
+	    if (extract_xml_record(field,"reserved",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> reserved;
+	      }
+	    if (extract_xml_record(field,"period",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> period;
+	      }
+	    if (extract_xml_record(field,"snr",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> snr;
+	      }
+	    if (extract_xml_record(field,"thresh",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> thresh;
+	      }
+	    if (extract_xml_record(field,"score",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> score;
+	      }
+	    if (extract_xml_record(field,"len_prof",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> len_prof;
+	      }
+	    if (extract_xml_record(field,"pot",sub)) {
+	        std::istringstream in(sub.c_str());
+	        in >> pot;
+	      }
+	      }
+	      }
+
+	void pulse_tinysky::parse(const SQL_ROW &s) {
+	  {  
+	        std::istringstream row(*(s[0]));
+	        row >> id;
+	    }
+	  {  
+	  result_id.parse(SQL_ROW(s[1],0));
+	    }
+	  {  
+	        std::istringstream row(*(s[2]));
+	        row >> peak_power;
+	    }
+	  {  
+	        std::istringstream row(*(s[3]));
+	        row >> mean_power;
+	    }
+	  {  
+	        std::istringstream row(*(s[4]));
+	        row >> time;
+	    }
+	  {  
+	        std::istringstream row(*(s[5]));
+	        row >> ra;
+	    }
+	  {  
+	        std::istringstream row(*(s[6]));
+	        row >> decl;
+	    }
+	  {  
+	        std::istringstream row(*(s[7]));
+	        row >> q_pix;
+	    }
+	  {  
+	        std::istringstream row(*(s[8]));
+	        row >> freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[9]));
+	        row >> detection_freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[10]));
+	        row >> barycentric_freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[11]));
+	        row >> fft_len;
+	    }
+	  {  
+	        std::istringstream row(*(s[12]));
+	        row >> chirp_rate;
+	    }
+	  {  
+	        std::istringstream row(*(s[13]));
+	        row >> rfi_checked;
+	    }
+	  {  
+	        std::istringstream row(*(s[14]));
+	        row >> rfi_found;
+	    }
+	  {  
+	        std::istringstream row(*(s[15]));
+	        row >> reserved;
+	    }
+	  {  
+	        std::istringstream row(*(s[16]));
+	        row >> period;
+	    }
+	  {  
+	        std::istringstream row(*(s[17]));
+	        row >> snr;
+	    }
+	  {  
+	        std::istringstream row(*(s[18]));
+	        row >> thresh;
+	    }
+	  {  
+	        std::istringstream row(*(s[19]));
+	        row >> score;
+	    }
+	  {  
+	        std::istringstream row(*(s[20]));
+	        row >> len_prof;
+	    }
+	  {  
+	        pot=sqlblob<unsigned char>(*(s[21]));
+	    }
+	      }
+
+	void pulse_tinysky::parse(const std::string &s) {
+	      SQL_ROW row(&s,22);
+	      parse(row);
+	      }
+
+template <> const char * const db_table<triplet_tinysky>::table_name="triplet_tinysky";
+template <> const char * db_table<triplet_tinysky>::_search_tag=table_name;
+template <> const int db_table<triplet_tinysky>::_nfields=17;
+template <> const char * const db_table<triplet_tinysky>::column_names[17]={"id","result_id","peak_power","mean_power","time","ra","decl","q_pix","freq","detection_freq","barycentric_freq","fft_len","chirp_rate","rfi_checked","rfi_found","reserved","period"};
+
+triplet_tinysky::triplet_tinysky() : 
+	db_table<triplet_tinysky>(*this,-1),
+	id(0),
+	result_id(),
+	peak_power(0),
+	mean_power(0),
+	time(0),
+	ra(0),
+	decl(0),
+	q_pix(0),
+	freq(0),
+	detection_freq(0),
+	barycentric_freq(0),
+	fft_len(0),
+	chirp_rate(0),
+	rfi_checked(0),
+	rfi_found(0),
+	reserved(0),
+	period(0)
+{
+	db_open();
+}
+
+
+triplet_tinysky::triplet_tinysky(const triplet_tinysky &a) : 
+	db_table<triplet_tinysky>(*this,-1),
+	id(a.id),
+	result_id(a.result_id),
+	peak_power(a.peak_power),
+	mean_power(a.mean_power),
+	time(a.time),
+	ra(a.ra),
+	decl(a.decl),
+	q_pix(a.q_pix),
+	freq(a.freq),
+	detection_freq(a.detection_freq),
+	barycentric_freq(a.barycentric_freq),
+	fft_len(a.fft_len),
+	chirp_rate(a.chirp_rate),
+	rfi_checked(a.rfi_checked),
+	rfi_found(a.rfi_found),
+	reserved(a.reserved),
+	period(a.period)
+{
+	db_open();
+}
+
+
+triplet_tinysky::triplet_tinysky(const SQL_ROW &a) : 
+	db_table<triplet_tinysky>(*this,-1)
+{
+	db_open();
+	parse(a);
+}
+
+
+triplet_tinysky::triplet_tinysky(const std::string &s,const char *tag) : 
+	db_table<triplet_tinysky>(*this,-1)
+{
+	db_open();
+	if (xml_match_tag(s,tag)) {
+	  parse_xml(s,tag);
+	} else {
+	  parse(s);
+	}
+}
+
+
+triplet_tinysky &triplet_tinysky::operator =(const triplet_tinysky &a) {
+	if (&a != this) {
+		id=a.id;
+		result_id=a.result_id;
+		peak_power=a.peak_power;
+		mean_power=a.mean_power;
+		time=a.time;
+		ra=a.ra;
+		decl=a.decl;
+		q_pix=a.q_pix;
+		freq=a.freq;
+		detection_freq=a.detection_freq;
+		barycentric_freq=a.barycentric_freq;
+		fft_len=a.fft_len;
+		chirp_rate=a.chirp_rate;
+		rfi_checked=a.rfi_checked;
+		rfi_found=a.rfi_found;
+		reserved=a.reserved;
+		period=a.period;
+	}
+	return (*this);
+}
+
+
+std::string triplet_tinysky::update_format() const
+{	std::ostringstream rv("");
+
+	for (int i=2;i<17;i++) rv << "?,";
+	rv << "?";
+	return rv.str();
+}
+
+
+std::string triplet_tinysky::insert_format() const
+{	return std::string("?,")+update_format();
+}
+
+std::string triplet_tinysky::select_format() const
+{
+std::string rv("");
+for (int i=0; i<16;i++) rv+="?,";
+rv+="?";
+return rv;
+}
+
+std::string triplet_tinysky::print(int full_subtables, int show_ids, int no_refs) const
+{	std::ostringstream rv("");
+
+	rv.precision(14);
+	if (show_ids) rv << id;
+	rv << ',';
+	if (!no_refs) {
+	  if (full_subtables) {
+	    rv << result_id.print(full_subtables,show_ids,no_refs);
+	} else {
+	    rv << result_id.id;
+	  }
+	}
+	rv << ',';
+	rv << peak_power;
+	rv << ',';
+	rv << mean_power;
+	rv << ',';
+	rv << time;
+	rv << ',';
+	rv << ra;
+	rv << ',';
+	rv << decl;
+	rv << ',';
+	rv << q_pix;
+	rv << ',';
+	rv << freq;
+	rv << ',';
+	rv << detection_freq;
+	rv << ',';
+	rv << barycentric_freq;
+	rv << ',';
+	rv << fft_len;
+	rv << ',';
+	rv << chirp_rate;
+	rv << ',';
+	rv << rfi_checked;
+	rv << ',';
+	rv << rfi_found;
+	rv << ',';
+	rv << reserved;
+	rv << ',';
+	rv << period;
+	return rv.str();
+}
+
+
+std::string triplet_tinysky::print_xml(int full_subtables, int show_ids, int no_refs,const char *tag) const 
+{
+	std::ostringstream rv("");
+
+	rv.precision(14);
+	rv << xml_indent() << '<' << tag << ">\n";
+	xml_indent(2);
+	if (show_ids) rv << xml_indent() << "<id>" << id << "</id>\n";
+	if (!no_refs) {
+	  if (full_subtables) {
+	    rv << result_id.print_xml(full_subtables,show_ids,no_refs,"result_id");
+	} else {
+	    rv << xml_indent() << "<result_id><id>" << result_id.id << "</id></result_id>\n";
+	  }
+	}
+	rv << xml_indent() << "<peak_power>" << peak_power << "</peak_power>\n";
+	rv << xml_indent() << "<mean_power>" << mean_power << "</mean_power>\n";
+	rv << xml_indent() << "<time>" << time << "</time>\n";
+	rv << xml_indent() << "<ra>" << ra << "</ra>\n";
+	rv << xml_indent() << "<decl>" << decl << "</decl>\n";
+	rv << xml_indent() << "<q_pix>" << q_pix << "</q_pix>\n";
+	rv << xml_indent() << "<freq>" << freq << "</freq>\n";
+	rv << xml_indent() << "<detection_freq>" << detection_freq << "</detection_freq>\n";
+	rv << xml_indent() << "<barycentric_freq>" << barycentric_freq << "</barycentric_freq>\n";
+	rv << xml_indent() << "<fft_len>" << fft_len << "</fft_len>\n";
+	rv << xml_indent() << "<chirp_rate>" << chirp_rate << "</chirp_rate>\n";
+	rv << xml_indent() << "<rfi_checked>" << rfi_checked << "</rfi_checked>\n";
+	rv << xml_indent() << "<rfi_found>" << rfi_found << "</rfi_found>\n";
+	rv << xml_indent() << "<reserved>" << reserved << "</reserved>\n";
+	rv << xml_indent() << "<period>" << period << "</period>\n";
+	xml_indent(-2);
+	rv << xml_indent() << "</" << tag << ">\n";
+	return rv.str();
+}
+
+
+	void triplet_tinysky::parse_xml(const std::string &s,const char *tag) {
+	  std::string field,sub;
+	  if (extract_xml_record(s,tag,field)) {
+	  std::string::size_type pos=0;
+	    if (extract_xml_record(field,"id",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> id;
+	      }
+	    if (extract_xml_record(field,"result_id",sub)) {
+	      result_id.parse_xml(sub,"result_id");
+	    }
+	    if (extract_xml_record(field,"peak_power",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> peak_power;
+	      }
+	    if (extract_xml_record(field,"mean_power",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> mean_power;
+	      }
+	    if (extract_xml_record(field,"time",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> time;
+	      }
+	    if (extract_xml_record(field,"ra",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> ra;
+	      }
+	    if (extract_xml_record(field,"decl",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> decl;
+	      }
+	    if (extract_xml_record(field,"q_pix",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> q_pix;
+	      }
+	    if (extract_xml_record(field,"freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> freq;
+	      }
+	    if (extract_xml_record(field,"detection_freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> detection_freq;
+	      }
+	    if (extract_xml_record(field,"barycentric_freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> barycentric_freq;
+	      }
+	    if (extract_xml_record(field,"fft_len",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> fft_len;
+	      }
+	    if (extract_xml_record(field,"chirp_rate",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> chirp_rate;
+	      }
+	    if (extract_xml_record(field,"rfi_checked",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> rfi_checked;
+	      }
+	    if (extract_xml_record(field,"rfi_found",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> rfi_found;
+	      }
+	    if (extract_xml_record(field,"reserved",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> reserved;
+	      }
+	    if (extract_xml_record(field,"period",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> period;
+	      }
+	      }
+	      }
+
+	void triplet_tinysky::parse(const SQL_ROW &s) {
+	  {  
+	        std::istringstream row(*(s[0]));
+	        row >> id;
+	    }
+	  {  
+	  result_id.parse(SQL_ROW(s[1],0));
+	    }
+	  {  
+	        std::istringstream row(*(s[2]));
+	        row >> peak_power;
+	    }
+	  {  
+	        std::istringstream row(*(s[3]));
+	        row >> mean_power;
+	    }
+	  {  
+	        std::istringstream row(*(s[4]));
+	        row >> time;
+	    }
+	  {  
+	        std::istringstream row(*(s[5]));
+	        row >> ra;
+	    }
+	  {  
+	        std::istringstream row(*(s[6]));
+	        row >> decl;
+	    }
+	  {  
+	        std::istringstream row(*(s[7]));
+	        row >> q_pix;
+	    }
+	  {  
+	        std::istringstream row(*(s[8]));
+	        row >> freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[9]));
+	        row >> detection_freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[10]));
+	        row >> barycentric_freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[11]));
+	        row >> fft_len;
+	    }
+	  {  
+	        std::istringstream row(*(s[12]));
+	        row >> chirp_rate;
+	    }
+	  {  
+	        std::istringstream row(*(s[13]));
+	        row >> rfi_checked;
+	    }
+	  {  
+	        std::istringstream row(*(s[14]));
+	        row >> rfi_found;
+	    }
+	  {  
+	        std::istringstream row(*(s[15]));
+	        row >> reserved;
+	    }
+	  {  
+	        std::istringstream row(*(s[16]));
+	        row >> period;
+	    }
+	      }
+
+	void triplet_tinysky::parse(const std::string &s) {
+	      SQL_ROW row(&s,17);
+	      parse(row);
+	      }
+
+template <> const char * const db_table<autocorr_tinysky>::table_name="autocorr_tinysky";
+template <> const char * db_table<autocorr_tinysky>::_search_tag=table_name;
+template <> const int db_table<autocorr_tinysky>::_nfields=17;
+template <> const char * const db_table<autocorr_tinysky>::column_names[17]={"id","result_id","peak_power","mean_power","time","ra","decl","q_pix","delay","freq","detection_freq","barycentric_freq","fft_len","chirp_rate","rfi_checked","rfi_found","reserved"};
+
+autocorr_tinysky::autocorr_tinysky() : 
+	db_table<autocorr_tinysky>(*this,-1),
+	id(0),
+	result_id(),
+	peak_power(0),
+	mean_power(0),
+	time(0),
+	ra(0),
+	decl(0),
+	q_pix(0),
+	delay(0),
+	freq(0),
+	detection_freq(0),
+	barycentric_freq(0),
+	fft_len(0),
+	chirp_rate(0),
+	rfi_checked(0),
+	rfi_found(0),
+	reserved(0)
+{
+	db_open();
+}
+
+
+autocorr_tinysky::autocorr_tinysky(const autocorr_tinysky &a) : 
+	db_table<autocorr_tinysky>(*this,-1),
+	id(a.id),
+	result_id(a.result_id),
+	peak_power(a.peak_power),
+	mean_power(a.mean_power),
+	time(a.time),
+	ra(a.ra),
+	decl(a.decl),
+	q_pix(a.q_pix),
+	delay(a.delay),
+	freq(a.freq),
+	detection_freq(a.detection_freq),
+	barycentric_freq(a.barycentric_freq),
+	fft_len(a.fft_len),
+	chirp_rate(a.chirp_rate),
+	rfi_checked(a.rfi_checked),
+	rfi_found(a.rfi_found),
+	reserved(a.reserved)
+{
+	db_open();
+}
+
+
+autocorr_tinysky::autocorr_tinysky(const SQL_ROW &a) : 
+	db_table<autocorr_tinysky>(*this,-1)
+{
+	db_open();
+	parse(a);
+}
+
+
+autocorr_tinysky::autocorr_tinysky(const std::string &s,const char *tag) : 
+	db_table<autocorr_tinysky>(*this,-1)
+{
+	db_open();
+	if (xml_match_tag(s,tag)) {
+	  parse_xml(s,tag);
+	} else {
+	  parse(s);
+	}
+}
+
+
+autocorr_tinysky &autocorr_tinysky::operator =(const autocorr_tinysky &a) {
+	if (&a != this) {
+		id=a.id;
+		result_id=a.result_id;
+		peak_power=a.peak_power;
+		mean_power=a.mean_power;
+		time=a.time;
+		ra=a.ra;
+		decl=a.decl;
+		q_pix=a.q_pix;
+		delay=a.delay;
+		freq=a.freq;
+		detection_freq=a.detection_freq;
+		barycentric_freq=a.barycentric_freq;
+		fft_len=a.fft_len;
+		chirp_rate=a.chirp_rate;
+		rfi_checked=a.rfi_checked;
+		rfi_found=a.rfi_found;
+		reserved=a.reserved;
+	}
+	return (*this);
+}
+
+
+std::string autocorr_tinysky::update_format() const
+{	std::ostringstream rv("");
+
+	for (int i=2;i<17;i++) rv << "?,";
+	rv << "?";
+	return rv.str();
+}
+
+
+std::string autocorr_tinysky::insert_format() const
+{	return std::string("?,")+update_format();
+}
+
+std::string autocorr_tinysky::select_format() const
+{
+std::string rv("");
+for (int i=0; i<16;i++) rv+="?,";
+rv+="?";
+return rv;
+}
+
+std::string autocorr_tinysky::print(int full_subtables, int show_ids, int no_refs) const
+{	std::ostringstream rv("");
+
+	rv.precision(14);
+	if (show_ids) rv << id;
+	rv << ',';
+	if (!no_refs) {
+	  if (full_subtables) {
+	    rv << result_id.print(full_subtables,show_ids,no_refs);
+	} else {
+	    rv << result_id.id;
+	  }
+	}
+	rv << ',';
+	rv << peak_power;
+	rv << ',';
+	rv << mean_power;
+	rv << ',';
+	rv << time;
+	rv << ',';
+	rv << ra;
+	rv << ',';
+	rv << decl;
+	rv << ',';
+	rv << q_pix;
+	rv << ',';
+	rv << delay;
+	rv << ',';
+	rv << freq;
+	rv << ',';
+	rv << detection_freq;
+	rv << ',';
+	rv << barycentric_freq;
+	rv << ',';
+	rv << fft_len;
+	rv << ',';
+	rv << chirp_rate;
+	rv << ',';
+	rv << rfi_checked;
+	rv << ',';
+	rv << rfi_found;
+	rv << ',';
+	rv << reserved;
+	return rv.str();
+}
+
+
+std::string autocorr_tinysky::print_xml(int full_subtables, int show_ids, int no_refs,const char *tag) const 
+{
+	std::ostringstream rv("");
+
+	rv.precision(14);
+	rv << xml_indent() << '<' << tag << ">\n";
+	xml_indent(2);
+	if (show_ids) rv << xml_indent() << "<id>" << id << "</id>\n";
+	if (!no_refs) {
+	  if (full_subtables) {
+	    rv << result_id.print_xml(full_subtables,show_ids,no_refs,"result_id");
+	} else {
+	    rv << xml_indent() << "<result_id><id>" << result_id.id << "</id></result_id>\n";
+	  }
+	}
+	rv << xml_indent() << "<peak_power>" << peak_power << "</peak_power>\n";
+	rv << xml_indent() << "<mean_power>" << mean_power << "</mean_power>\n";
+	rv << xml_indent() << "<time>" << time << "</time>\n";
+	rv << xml_indent() << "<ra>" << ra << "</ra>\n";
+	rv << xml_indent() << "<decl>" << decl << "</decl>\n";
+	rv << xml_indent() << "<q_pix>" << q_pix << "</q_pix>\n";
+	rv << xml_indent() << "<delay>" << delay << "</delay>\n";
+	rv << xml_indent() << "<freq>" << freq << "</freq>\n";
+	rv << xml_indent() << "<detection_freq>" << detection_freq << "</detection_freq>\n";
+	rv << xml_indent() << "<barycentric_freq>" << barycentric_freq << "</barycentric_freq>\n";
+	rv << xml_indent() << "<fft_len>" << fft_len << "</fft_len>\n";
+	rv << xml_indent() << "<chirp_rate>" << chirp_rate << "</chirp_rate>\n";
+	rv << xml_indent() << "<rfi_checked>" << rfi_checked << "</rfi_checked>\n";
+	rv << xml_indent() << "<rfi_found>" << rfi_found << "</rfi_found>\n";
+	rv << xml_indent() << "<reserved>" << reserved << "</reserved>\n";
+	xml_indent(-2);
+	rv << xml_indent() << "</" << tag << ">\n";
+	return rv.str();
+}
+
+
+	void autocorr_tinysky::parse_xml(const std::string &s,const char *tag) {
+	  std::string field,sub;
+	  if (extract_xml_record(s,tag,field)) {
+	  std::string::size_type pos=0;
+	    if (extract_xml_record(field,"id",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> id;
+	      }
+	    if (extract_xml_record(field,"result_id",sub)) {
+	      result_id.parse_xml(sub,"result_id");
+	    }
+	    if (extract_xml_record(field,"peak_power",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> peak_power;
+	      }
+	    if (extract_xml_record(field,"mean_power",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> mean_power;
+	      }
+	    if (extract_xml_record(field,"time",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> time;
+	      }
+	    if (extract_xml_record(field,"ra",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> ra;
+	      }
+	    if (extract_xml_record(field,"decl",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> decl;
+	      }
+	    if (extract_xml_record(field,"q_pix",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> q_pix;
+	      }
+	    if (extract_xml_record(field,"delay",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> delay;
+	      }
+	    if (extract_xml_record(field,"freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> freq;
+	      }
+	    if (extract_xml_record(field,"detection_freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> detection_freq;
+	      }
+	    if (extract_xml_record(field,"barycentric_freq",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> barycentric_freq;
+	      }
+	    if (extract_xml_record(field,"fft_len",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> fft_len;
+	      }
+	    if (extract_xml_record(field,"chirp_rate",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> chirp_rate;
+	      }
+	    if (extract_xml_record(field,"rfi_checked",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> rfi_checked;
+	      }
+	    if (extract_xml_record(field,"rfi_found",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> rfi_found;
+	      }
+	    if (extract_xml_record(field,"reserved",sub)) {
+	        pos=sub.find(">");
+	        do { pos++; } while(sub[pos]=='\n');
+	        std::istringstream in(sub.c_str()+pos);
+	        in >> reserved;
+	      }
+	      }
+	      }
+
+	void autocorr_tinysky::parse(const SQL_ROW &s) {
+	  {  
+	        std::istringstream row(*(s[0]));
+	        row >> id;
+	    }
+	  {  
+	  result_id.parse(SQL_ROW(s[1],0));
+	    }
+	  {  
+	        std::istringstream row(*(s[2]));
+	        row >> peak_power;
+	    }
+	  {  
+	        std::istringstream row(*(s[3]));
+	        row >> mean_power;
+	    }
+	  {  
+	        std::istringstream row(*(s[4]));
+	        row >> time;
+	    }
+	  {  
+	        std::istringstream row(*(s[5]));
+	        row >> ra;
+	    }
+	  {  
+	        std::istringstream row(*(s[6]));
+	        row >> decl;
+	    }
+	  {  
+	        std::istringstream row(*(s[7]));
+	        row >> q_pix;
+	    }
+	  {  
+	        std::istringstream row(*(s[8]));
+	        row >> delay;
+	    }
+	  {  
+	        std::istringstream row(*(s[9]));
+	        row >> freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[10]));
+	        row >> detection_freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[11]));
+	        row >> barycentric_freq;
+	    }
+	  {  
+	        std::istringstream row(*(s[12]));
+	        row >> fft_len;
+	    }
+	  {  
+	        std::istringstream row(*(s[13]));
+	        row >> chirp_rate;
+	    }
+	  {  
+	        std::istringstream row(*(s[14]));
+	        row >> rfi_checked;
+	    }
+	  {  
+	        std::istringstream row(*(s[15]));
+	        row >> rfi_found;
+	    }
+	  {  
+	        std::istringstream row(*(s[16]));
+	        row >> reserved;
+	    }
+	      }
+
+	void autocorr_tinysky::parse(const std::string &s) {
+	      SQL_ROW row(&s,17);
+	      parse(row);
+	      }
+
diff --git a/db/schema_master.h b/db/schema_master.h
index 6c6e134..3decfc8 100644
--- a/db/schema_master.h
+++ b/db/schema_master.h
@@ -563,6 +563,7 @@ class  workunit_grp  : public db_table<workunit_grp> {
 	db_reference<analysis_config,long> analysis_cfg;
 	long  sb_id;
 	long  iq_modified;
+	long  alfa_filter_bank;
 	workunit_grp();
 	workunit_grp(const workunit_grp &a);
 	workunit_grp(const SQL_ROW &a);
@@ -1228,4 +1229,193 @@ class  bad_data  : public db_table<bad_data> {
 };
 
 
+class  spike_tinysky  : public db_table<spike_tinysky> {
+  public:
+	sqlint8_t  id;
+	db_reference<result,sqlint8_t> result_id;
+	double  peak_power;
+	double  mean_power;
+	double  time;
+	double  ra;
+	double  decl;
+	sqlint8_t  q_pix;
+	double  freq;
+	double  detection_freq;
+	double  barycentric_freq;
+	long  fft_len;
+	double  chirp_rate;
+	long  rfi_checked;
+	long  rfi_found;
+	long  reserved;
+	spike_tinysky();
+	spike_tinysky(const spike_tinysky &a);
+	spike_tinysky(const SQL_ROW &a);
+	spike_tinysky(const std::string &s,const char *tag="spike_tinysky");
+	spike_tinysky &operator =(const spike_tinysky &a);
+	std::string update_format() const;
+	std::string insert_format() const;
+	std::string select_format() const;
+	std::string print(int full_subtables=0, int show_ids=1, int no_refs=0) const;
+	std::string print_xml(int full_subtables=1, int show_ids=0, int no_refs=0,const char *tag="spike_tinysky") const;
+	void parse(const SQL_ROW &s);
+	void parse(const std::string &s);
+	void parse_xml(const std::string &s,const char *tag="spike_tinysky");
+  private:
+};
+
+
+class  gaussian_tinysky  : public db_table<gaussian_tinysky> {
+  public:
+	sqlint8_t  id;
+	db_reference<result,sqlint8_t> result_id;
+	double  peak_power;
+	double  mean_power;
+	double  time;
+	double  ra;
+	double  decl;
+	sqlint8_t  q_pix;
+	double  freq;
+	double  detection_freq;
+	double  barycentric_freq;
+	long  fft_len;
+	double  chirp_rate;
+	long  rfi_checked;
+	long  rfi_found;
+	long  reserved;
+	double  sigma;
+	double  chisqr;
+	double  null_chisqr;
+	double  score;
+	double  max_power;
+	sqlblob<unsigned char>  pot;
+	gaussian_tinysky();
+	gaussian_tinysky(const gaussian_tinysky &a);
+	gaussian_tinysky(const SQL_ROW &a);
+	gaussian_tinysky(const std::string &s,const char *tag="gaussian_tinysky");
+	gaussian_tinysky &operator =(const gaussian_tinysky &a);
+	std::string update_format() const;
+	std::string insert_format() const;
+	std::string select_format() const;
+	std::string print(int full_subtables=0, int show_ids=1, int no_refs=0) const;
+	std::string print_xml(int full_subtables=1, int show_ids=0, int no_refs=0,const char *tag="gaussian_tinysky") const;
+	void parse(const SQL_ROW &s);
+	void parse(const std::string &s);
+	void parse_xml(const std::string &s,const char *tag="gaussian_tinysky");
+  private:
+};
+
+
+class  pulse_tinysky  : public db_table<pulse_tinysky> {
+  public:
+	sqlint8_t  id;
+	db_reference<result,sqlint8_t> result_id;
+	double  peak_power;
+	double  mean_power;
+	double  time;
+	double  ra;
+	double  decl;
+	sqlint8_t  q_pix;
+	double  freq;
+	double  detection_freq;
+	double  barycentric_freq;
+	long  fft_len;
+	double  chirp_rate;
+	long  rfi_checked;
+	long  rfi_found;
+	long  reserved;
+	double  period;
+	double  snr;
+	double  thresh;
+	double  score;
+	long  len_prof;
+	sqlblob<unsigned char>  pot;
+	pulse_tinysky();
+	pulse_tinysky(const pulse_tinysky &a);
+	pulse_tinysky(const SQL_ROW &a);
+	pulse_tinysky(const std::string &s,const char *tag="pulse_tinysky");
+	pulse_tinysky &operator =(const pulse_tinysky &a);
+	std::string update_format() const;
+	std::string insert_format() const;
+	std::string select_format() const;
+	std::string print(int full_subtables=0, int show_ids=1, int no_refs=0) const;
+	std::string print_xml(int full_subtables=1, int show_ids=0, int no_refs=0,const char *tag="pulse_tinysky") const;
+	void parse(const SQL_ROW &s);
+	void parse(const std::string &s);
+	void parse_xml(const std::string &s,const char *tag="pulse_tinysky");
+  private:
+};
+
+
+class  triplet_tinysky  : public db_table<triplet_tinysky> {
+  public:
+	sqlint8_t  id;
+	db_reference<result,sqlint8_t> result_id;
+	double  peak_power;
+	double  mean_power;
+	double  time;
+	double  ra;
+	double  decl;
+	sqlint8_t  q_pix;
+	double  freq;
+	double  detection_freq;
+	double  barycentric_freq;
+	long  fft_len;
+	double  chirp_rate;
+	long  rfi_checked;
+	long  rfi_found;
+	long  reserved;
+	double  period;
+	triplet_tinysky();
+	triplet_tinysky(const triplet_tinysky &a);
+	triplet_tinysky(const SQL_ROW &a);
+	triplet_tinysky(const std::string &s,const char *tag="triplet_tinysky");
+	triplet_tinysky &operator =(const triplet_tinysky &a);
+	std::string update_format() const;
+	std::string insert_format() const;
+	std::string select_format() const;
+	std::string print(int full_subtables=0, int show_ids=1, int no_refs=0) const;
+	std::string print_xml(int full_subtables=1, int show_ids=0, int no_refs=0,const char *tag="triplet_tinysky") const;
+	void parse(const SQL_ROW &s);
+	void parse(const std::string &s);
+	void parse_xml(const std::string &s,const char *tag="triplet_tinysky");
+  private:
+};
+
+
+class  autocorr_tinysky  : public db_table<autocorr_tinysky> {
+  public:
+	sqlint8_t  id;
+	db_reference<result,sqlint8_t> result_id;
+	double  peak_power;
+	double  mean_power;
+	double  time;
+	double  ra;
+	double  decl;
+	sqlint8_t  q_pix;
+	double  delay;
+	double  freq;
+	double  detection_freq;
+	double  barycentric_freq;
+	long  fft_len;
+	double  chirp_rate;
+	long  rfi_checked;
+	long  rfi_found;
+	long  reserved;
+	autocorr_tinysky();
+	autocorr_tinysky(const autocorr_tinysky &a);
+	autocorr_tinysky(const SQL_ROW &a);
+	autocorr_tinysky(const std::string &s,const char *tag="autocorr_tinysky");
+	autocorr_tinysky &operator =(const autocorr_tinysky &a);
+	std::string update_format() const;
+	std::string insert_format() const;
+	std::string select_format() const;
+	std::string print(int full_subtables=0, int show_ids=1, int no_refs=0) const;
+	std::string print_xml(int full_subtables=1, int show_ids=0, int no_refs=0,const char *tag="autocorr_tinysky") const;
+	void parse(const SQL_ROW &s);
+	void parse(const std::string &s);
+	void parse_xml(const std::string &s,const char *tag="autocorr_tinysky");
+  private:
+};
+
+
 #endif
diff --git a/db/schema_master.sql b/db/schema_master.sql
index 3ae7fe1..30f4203 100644
--- a/db/schema_master.sql
+++ b/db/schema_master.sql
@@ -276,7 +276,13 @@ create table  multiplet
     score float not null,
     num_detections integer not null,
     signal_ids list(int8 not null)
-  );
+  )
+   fragment by expression
+      (mod(id,4)=0) in page_8k_dbs5,
+      (mod(id,4)=1) in page_8k_dbs6,
+      (mod(id,4)=2) in page_8k_dbs7,
+      (mod(id,4)=3) in page_8k_dbs8
+      extent size 209714 next size 204714;
 
 create table  star 
   (
@@ -354,7 +360,7 @@ create table workunit_grp
     splitter_cfg integer references splitter_config,
     analysis_cfg integer references analysis_config,
     sb_id integer,
-    iq_modified integer
+    iq_modified integer,
     alfa_filter_bank smallint
   );
 
diff --git a/depcomp b/depcomp
deleted file mode 100755
index 51606f8..0000000
--- a/depcomp
+++ /dev/null
@@ -1,464 +0,0 @@
-#! /bin/sh
-
-# depcomp - compile a program generating dependencies as side-effects
-# Copyright 1999, 2000 Free Software Foundation, Inc.
-
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2, or (at your option)
-# any later version.
-
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-# GNU General Public License for more details.
-
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
-# 02111-1307, USA.
-
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-# Originally written by Alexandre Oliva <oliva at dcc.unicamp.br>.
-
-if test -z "$depmode" || test -z "$source" || test -z "$object"; then
-  echo "depcomp: Variables source, object and depmode must be set" 1>&2
-  exit 1
-fi
-# `libtool' can also be set to `yes' or `no'.
-
-if test -z "$depfile"; then
-   base=`echo "$object" | sed -e 's,^.*/,,' -e 's,\.\([^.]*\)$,.P\1,'`
-   dir=`echo "$object" | sed 's,/.*$,/,'`
-   if test "$dir" = "$object"; then
-      dir=
-   fi
-   # FIXME: should be _deps on DOS.
-   depfile="$dir.deps/$base"
-fi
-
-tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`}
-
-rm -f "$tmpdepfile"
-
-# Some modes work just like other modes, but use different flags.  We
-# parameterize here, but still list the modes in the big case below,
-# to make depend.m4 easier to write.  Note that we *cannot* use a case
-# here, because this file can only contain one case statement.
-if test "$depmode" = hp; then
-  # HP compiler uses -M and no extra arg.
-  gccflag=-M
-  depmode=gcc
-fi
-
-if test "$depmode" = dashXmstdout; then
-   # This is just like dashmstdout with a different argument.
-   dashmflag=-xM
-   depmode=dashmstdout
-fi
-
-case "$depmode" in
-gcc3)
-## gcc 3 implements dependency tracking that does exactly what
-## we want.  Yay!  Note: for some reason libtool 1.4 doesn't like
-## it if -MD -MP comes after the -MF stuff.  Hmm.
-  "$@" -MT "$object" -MD -MP -MF "$tmpdepfile"
-  stat=$?
-  if test $stat -eq 0; then :
-  else
-    rm -f "$tmpdepfile"
-    exit $stat
-  fi
-  mv "$tmpdepfile" "$depfile"
-  ;;
-
-gcc)
-## There are various ways to get dependency output from gcc.  Here's
-## why we pick this rather obscure method:
-## - Don't want to use -MD because we'd like the dependencies to end
-##   up in a subdir.  Having to rename by hand is ugly.
-##   (We might end up doing this anyway to support other compilers.)
-## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
-##   -MM, not -M (despite what the docs say).
-## - Using -M directly means running the compiler twice (even worse
-##   than renaming).
-  if test -z "$gccflag"; then
-    gccflag=-MD,
-  fi
-  "$@" -Wp,"$gccflag$tmpdepfile"
-  stat=$?
-  if test $stat -eq 0; then :
-  else
-    rm -f "$tmpdepfile"
-    exit $stat
-  fi
-  rm -f "$depfile"
-  echo "$object : \\" > "$depfile"
-  alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
-## The second -e expression handles DOS-style file names with drive letters.
-  sed -e 's/^[^:]*: / /' \
-      -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
-## This next piece of magic avoids the `deleted header file' problem.
-## The problem is that when a header file which appears in a .P file
-## is deleted, the dependency causes make to die (because there is
-## typically no way to rebuild the header).  We avoid this by adding
-## dummy dependencies for each header file.  Too bad gcc doesn't do
-## this for us directly.
-  tr ' ' '
-' < "$tmpdepfile" |
-## Some versions of gcc put a space before the `:'.  On the theory
-## that the space means something, we add a space to the output as
-## well.
-## Some versions of the HPUX 10.20 sed can't process this invocation
-## correctly.  Breaking it into two sed invocations is a workaround.
-    sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
-  rm -f "$tmpdepfile"
-  ;;
-
-hp)
-  # This case exists only to let depend.m4 do its work.  It works by
-  # looking at the text of this script.  This case will never be run,
-  # since it is checked for above.
-  exit 1
-  ;;
-
-sgi)
-  if test "$libtool" = yes; then
-    "$@" "-Wp,-MDupdate,$tmpdepfile"
-  else
-    "$@" -MDupdate "$tmpdepfile"
-  fi
-  stat=$?
-  if test $stat -eq 0; then :
-  else
-    rm -f "$tmpdepfile"
-    exit $stat
-  fi
-  rm -f "$depfile"
-
-  if test -f "$tmpdepfile"; then  # yes, the sourcefile depend on other files
-    echo "$object : \\" > "$depfile"
-
-    # Clip off the initial element (the dependent).  Don't try to be
-    # clever and replace this with sed code, as IRIX sed won't handle
-    # lines with more than a fixed number of characters (4096 in
-    # IRIX 6.2 sed, 8192 in IRIX 6.5).  We also remove comment lines;
-    # the IRIX cc adds comments like `#:fec' to the end of the
-    # dependency line.
-    tr ' ' '
-' < "$tmpdepfile" \
-    | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \
-    tr '
-' ' ' >> $depfile
-    echo >> $depfile
-
-    # The second pass generates a dummy entry for each header file.
-    tr ' ' '
-' < "$tmpdepfile" \
-   | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
-   >> $depfile
-  else
-    # The sourcefile does not contain any dependencies, so just
-    # store a dummy comment line, to avoid errors with the Makefile
-    # "include basename.Plo" scheme.
-    echo "#dummy" > "$depfile"
-  fi
-  rm -f "$tmpdepfile"
-  ;;
-
-aix)
-  # The C for AIX Compiler uses -M and outputs the dependencies
-  # in a .u file.  This file always lives in the current directory.
-  # Also, the AIX compiler puts `$object:' at the start of each line;
-  # $object doesn't have directory information.
-  stripped=`echo "$object" | sed -e 's,^.*/,,' -e 's/\(.*\)\..*$/\1/'`
-  tmpdepfile="$stripped.u"
-  outname="$stripped.o"
-  if test "$libtool" = yes; then
-    "$@" -Wc,-M
-  else
-    "$@" -M
-  fi
-
-  stat=$?
-  if test $stat -eq 0; then :
-  else
-    rm -f "$tmpdepfile"
-    exit $stat
-  fi
-
-  if test -f "$tmpdepfile"; then
-    # Each line is of the form `foo.o: dependent.h'.
-    # Do two passes, one to just change these to
-    # `$object: dependent.h' and one to simply `dependent.h:'.
-    sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile"
-    sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile"
-  else
-    # The sourcefile does not contain any dependencies, so just
-    # store a dummy comment line, to avoid errors with the Makefile
-    # "include basename.Plo" scheme.
-    echo "#dummy" > "$depfile"
-  fi
-  rm -f "$tmpdepfile"
-  ;;
-
-icc)
-  # Must come before tru64.
-
-  # Intel's C compiler understands `-MD -MF file'.  However
-  #    icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c
-  # will fill foo.d with something like
-  #    foo.o: sub/foo.c
-  #    foo.o: sub/foo.h
-  # which is wrong.  We want:
-  #    sub/foo.o: sub/foo.c
-  #    sub/foo.o: sub/foo.h
-  #    sub/foo.c:
-  #    sub/foo.h:
-
-  "$@" -MD -MF "$tmpdepfile"
-  stat=$?
-  if test $stat -eq 0; then :
-  else
-    rm -f "$tmpdepfile"
-    exit $stat
-  fi
-  rm -f "$depfile"
-  # Each line is of the form `foo.o: dependent.h'.
-  # Do two passes, one to just change these to
-  # `$object: dependent.h' and one to simply `dependent.h:'.
-  sed -e "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile"
-  sed -e "s,^[^:]*: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile"
-  rm -f "$tmpdepfile"
-  ;;
-
-tru64)
-   # The Tru64 compiler uses -MD to generate dependencies as a side
-   # effect.  `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'.
-   # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
-   # dependencies in `foo.d' instead, so we check for that too.
-   # Subdirectories are respected.
-   dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
-   test "x$dir" = "x$object" && dir=
-   base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
-
-   if test "$libtool" = yes; then
-      tmpdepfile1="$dir.libs/$base.lo.d"
-      tmpdepfile2="$dir.libs/$base.d"
-      "$@" -Wc,-MD
-   else
-      tmpdepfile1="$dir$base.o.d"
-      tmpdepfile2="$dir$base.d"
-      "$@" -MD
-   fi
-
-   stat=$?
-   if test $stat -eq 0; then :
-   else
-      rm -f "$tmpdepfile1" "$tmpdepfile2"
-      exit $stat
-   fi
-
-   if test -f "$tmpdepfile1"; then
-      tmpdepfile="$tmpdepfile1"
-   else
-      tmpdepfile="$tmpdepfile2"
-   fi
-   if test -f "$tmpdepfile"; then
-      sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
-      # That's a space and a tab in the [].
-      sed -e 's,^.*\.[a-z]*:[ 	]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
-   else
-      echo "#dummy" > "$depfile"
-   fi
-   rm -f "$tmpdepfile"
-   ;;
-
-#nosideeffect)
-  # This comment above is used by automake to tell side-effect
-  # dependency tracking mechanisms from slower ones.
-
-dashmstdout)
-  # Important note: in order to support this mode, a compiler *must*
-  # always write the proprocessed file to stdout, regardless of -o.
-  "$@" || exit $?
-
-  # Remove the call to Libtool.
-  if test "$libtool" = yes; then
-    while test $1 != '--mode=compile'; do
-      shift
-    done
-    shift
-  fi
-
-  # Remove `-o $object'.
-  IFS=" "
-  for arg
-  do
-    case $arg in
-    -o)
-      shift
-      ;;
-    $object)
-      shift
-      ;;
-    *)
-      set fnord "$@" "$arg"
-      shift # fnord
-      shift # $arg
-      ;;
-    esac
-  done
-
-  test -z "$dashmflag" && dashmflag=-M
-  # Require at least two characters before searching for `:'
-  # in the target name.  This is to cope with DOS-style filenames:
-  # a dependency such as `c:/foo/bar' could be seen as target `c' otherwise.
-  "$@" $dashmflag |
-    sed 's:^[  ]*[^: ][^:][^:]*\:[    ]*:'"$object"'\: :' > "$tmpdepfile"
-  rm -f "$depfile"
-  cat < "$tmpdepfile" > "$depfile"
-  tr ' ' '
-' < "$tmpdepfile" | \
-## Some versions of the HPUX 10.20 sed can't process this invocation
-## correctly.  Breaking it into two sed invocations is a workaround.
-    sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
-  rm -f "$tmpdepfile"
-  ;;
-
-dashXmstdout)
-  # This case only exists to satisfy depend.m4.  It is never actually
-  # run, as this mode is specially recognized in the preamble.
-  exit 1
-  ;;
-
-makedepend)
-  "$@" || exit $?
-  # Remove any Libtool call
-  if test "$libtool" = yes; then
-    while test $1 != '--mode=compile'; do
-      shift
-    done
-    shift
-  fi
-  # X makedepend
-  shift
-  cleared=no
-  for arg in "$@"; do
-    case $cleared in
-    no)
-      set ""; shift
-      cleared=yes ;;
-    esac
-    case "$arg" in
-    -D*|-I*)
-      set fnord "$@" "$arg"; shift ;;
-    # Strip any option that makedepend may not understand.  Remove
-    # the object too, otherwise makedepend will parse it as a source file.
-    -*|$object)
-      ;;
-    *)
-      set fnord "$@" "$arg"; shift ;;
-    esac
-  done
-  obj_suffix="`echo $object | sed 's/^.*\././'`"
-  touch "$tmpdepfile"
-  ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
-  rm -f "$depfile"
-  cat < "$tmpdepfile" > "$depfile"
-  sed '1,2d' "$tmpdepfile" | tr ' ' '
-' | \
-## Some versions of the HPUX 10.20 sed can't process this invocation
-## correctly.  Breaking it into two sed invocations is a workaround.
-    sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
-  rm -f "$tmpdepfile" "$tmpdepfile".bak
-  ;;
-
-cpp)
-  # Important note: in order to support this mode, a compiler *must*
-  # always write the proprocessed file to stdout.
-  "$@" || exit $?
-
-  # Remove the call to Libtool.
-  if test "$libtool" = yes; then
-    while test $1 != '--mode=compile'; do
-      shift
-    done
-    shift
-  fi
-
-  # Remove `-o $object'.
-  IFS=" "
-  for arg
-  do
-    case $arg in
-    -o)
-      shift
-      ;;
-    $object)
-      shift
-      ;;
-    *)
-      set fnord "$@" "$arg"
-      shift # fnord
-      shift # $arg
-      ;;
-    esac
-  done
-
-  "$@" -E |
-    sed -n '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' |
-    sed '$ s: \\$::' > "$tmpdepfile"
-  rm -f "$depfile"
-  echo "$object : \\" > "$depfile"
-  cat < "$tmpdepfile" >> "$depfile"
-  sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile"
-  rm -f "$tmpdepfile"
-  ;;
-
-msvisualcpp)
-  # Important note: in order to support this mode, a compiler *must*
-  # always write the proprocessed file to stdout, regardless of -o,
-  # because we must use -o when running libtool.
-  "$@" || exit $?
-  IFS=" "
-  for arg
-  do
-    case "$arg" in
-    "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI")
-	set fnord "$@"
-	shift
-	shift
-	;;
-    *)
-	set fnord "$@" "$arg"
-	shift
-	shift
-	;;
-    esac
-  done
-  "$@" -E |
-  sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::echo "`cygpath -u \\"\1\\"`":p' | sort | uniq > "$tmpdepfile"
-  rm -f "$depfile"
-  echo "$object : \\" > "$depfile"
-  . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::	\1 \\:p' >> "$depfile"
-  echo "	" >> "$depfile"
-  . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::\1\::p' >> "$depfile"
-  rm -f "$tmpdepfile"
-  ;;
-
-none)
-  exec "$@"
-  ;;
-
-*)
-  echo "Unknown depmode $depmode" 1>&2
-  exit 1
-  ;;
-esac
-
-exit 0
diff --git a/install-sh b/install-sh
deleted file mode 100644
index e9de238..0000000
--- a/install-sh
+++ /dev/null
@@ -1,251 +0,0 @@
-#!/bin/sh
-#
-# install - install a program, script, or datafile
-# This comes from X11R5 (mit/util/scripts/install.sh).
-#
-# Copyright 1991 by the Massachusetts Institute of Technology
-#
-# Permission to use, copy, modify, distribute, and sell this software and its
-# documentation for any purpose is hereby granted without fee, provided that
-# the above copyright notice appear in all copies and that both that
-# copyright notice and this permission notice appear in supporting
-# documentation, and that the name of M.I.T. not be used in advertising or
-# publicity pertaining to distribution of the software without specific,
-# written prior permission.  M.I.T. makes no representations about the
-# suitability of this software for any purpose.  It is provided "as is"
-# without express or implied warranty.
-#
-# Calling this script install-sh is preferred over install.sh, to prevent
-# `make' implicit rules from creating a file called install from it
-# when there is no Makefile.
-#
-# This script is compatible with the BSD install script, but was written
-# from scratch.  It can only install one file at a time, a restriction
-# shared with many OS's install programs.
-
-
-# set DOITPROG to echo to test this script
-
-# Don't use :- since 4.3BSD and earlier shells don't like it.
-doit="${DOITPROG-}"
-
-
-# put in absolute paths if you don't have them in your path; or use env. vars.
-
-mvprog="${MVPROG-mv}"
-cpprog="${CPPROG-cp}"
-chmodprog="${CHMODPROG-chmod}"
-chownprog="${CHOWNPROG-chown}"
-chgrpprog="${CHGRPPROG-chgrp}"
-stripprog="${STRIPPROG-strip}"
-rmprog="${RMPROG-rm}"
-mkdirprog="${MKDIRPROG-mkdir}"
-
-transformbasename=""
-transform_arg=""
-instcmd="$mvprog"
-chmodcmd="$chmodprog 0755"
-chowncmd=""
-chgrpcmd=""
-stripcmd=""
-rmcmd="$rmprog -f"
-mvcmd="$mvprog"
-src=""
-dst=""
-dir_arg=""
-
-while [ x"$1" != x ]; do
-    case $1 in
-	-c) instcmd="$cpprog"
-	    shift
-	    continue;;
-
-	-d) dir_arg=true
-	    shift
-	    continue;;
-
-	-m) chmodcmd="$chmodprog $2"
-	    shift
-	    shift
-	    continue;;
-
-	-o) chowncmd="$chownprog $2"
-	    shift
-	    shift
-	    continue;;
-
-	-g) chgrpcmd="$chgrpprog $2"
-	    shift
-	    shift
-	    continue;;
-
-	-s) stripcmd="$stripprog"
-	    shift
-	    continue;;
-
-	-t=*) transformarg=`echo $1 | sed 's/-t=//'`
-	    shift
-	    continue;;
-
-	-b=*) transformbasename=`echo $1 | sed 's/-b=//'`
-	    shift
-	    continue;;
-
-	*)  if [ x"$src" = x ]
-	    then
-		src=$1
-	    else
-		# this colon is to work around a 386BSD /bin/sh bug
-		:
-		dst=$1
-	    fi
-	    shift
-	    continue;;
-    esac
-done
-
-if [ x"$src" = x ]
-then
-	echo "install:	no input file specified"
-	exit 1
-else
-	true
-fi
-
-if [ x"$dir_arg" != x ]; then
-	dst=$src
-	src=""
-	
-	if [ -d $dst ]; then
-		instcmd=:
-		chmodcmd=""
-	else
-		instcmd=mkdir
-	fi
-else
-
-# Waiting for this to be detected by the "$instcmd $src $dsttmp" command
-# might cause directories to be created, which would be especially bad 
-# if $src (and thus $dsttmp) contains '*'.
-
-	if [ -f $src -o -d $src ]
-	then
-		true
-	else
-		echo "install:  $src does not exist"
-		exit 1
-	fi
-	
-	if [ x"$dst" = x ]
-	then
-		echo "install:	no destination specified"
-		exit 1
-	else
-		true
-	fi
-
-# If destination is a directory, append the input filename; if your system
-# does not like double slashes in filenames, you may need to add some logic
-
-	if [ -d $dst ]
-	then
-		dst="$dst"/`basename $src`
-	else
-		true
-	fi
-fi
-
-## this sed command emulates the dirname command
-dstdir=`echo $dst | sed -e 's,[^/]*$,,;s,/$,,;s,^$,.,'`
-
-# Make sure that the destination directory exists.
-#  this part is taken from Noah Friedman's mkinstalldirs script
-
-# Skip lots of stat calls in the usual case.
-if [ ! -d "$dstdir" ]; then
-defaultIFS='	
-'
-IFS="${IFS-${defaultIFS}}"
-
-oIFS="${IFS}"
-# Some sh's can't handle IFS=/ for some reason.
-IFS='%'
-set - `echo ${dstdir} | sed -e 's@/@%@g' -e 's@^%@/@'`
-IFS="${oIFS}"
-
-pathcomp=''
-
-while [ $# -ne 0 ] ; do
-	pathcomp="${pathcomp}${1}"
-	shift
-
-	if [ ! -d "${pathcomp}" ] ;
-        then
-		$mkdirprog "${pathcomp}"
-	else
-		true
-	fi
-
-	pathcomp="${pathcomp}/"
-done
-fi
-
-if [ x"$dir_arg" != x ]
-then
-	$doit $instcmd $dst &&
-
-	if [ x"$chowncmd" != x ]; then $doit $chowncmd $dst; else true ; fi &&
-	if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dst; else true ; fi &&
-	if [ x"$stripcmd" != x ]; then $doit $stripcmd $dst; else true ; fi &&
-	if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dst; else true ; fi
-else
-
-# If we're going to rename the final executable, determine the name now.
-
-	if [ x"$transformarg" = x ] 
-	then
-		dstfile=`basename $dst`
-	else
-		dstfile=`basename $dst $transformbasename | 
-			sed $transformarg`$transformbasename
-	fi
-
-# don't allow the sed command to completely eliminate the filename
-
-	if [ x"$dstfile" = x ] 
-	then
-		dstfile=`basename $dst`
-	else
-		true
-	fi
-
-# Make a temp file name in the proper directory.
-
-	dsttmp=$dstdir/#inst.$$#
-
-# Move or copy the file name to the temp name
-
-	$doit $instcmd $src $dsttmp &&
-
-	trap "rm -f ${dsttmp}" 0 &&
-
-# and set any options; do chmod last to preserve setuid bits
-
-# If any of these fail, we abort the whole thing.  If we want to
-# ignore errors from any of these, just make sure not to ignore
-# errors from the above "$doit $instcmd $src $dsttmp" command.
-
-	if [ x"$chowncmd" != x ]; then $doit $chowncmd $dsttmp; else true;fi &&
-	if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dsttmp; else true;fi &&
-	if [ x"$stripcmd" != x ]; then $doit $stripcmd $dsttmp; else true;fi &&
-	if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dsttmp; else true;fi &&
-
-# Now rename the file to the real destination.
-
-	$doit $rmcmd -f $dstdir/$dstfile &&
-	$doit $mvcmd $dsttmp $dstdir/$dstfile 
-
-fi &&
-
-
-exit 0
diff --git a/ltmain.sh b/ltmain.sh
deleted file mode 100644
index cefb69d..0000000
--- a/ltmain.sh
+++ /dev/null
@@ -1,6496 +0,0 @@
-# ltmain.sh - Provide generalized library-building support services.
-# NOTE: Changing this file will not affect anything until you rerun configure.
-#
-# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005
-# Free Software Foundation, Inc.
-# Originally by Gordon Matzigkeit <gord at gnu.ai.mit.edu>, 1996
-#
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful, but
-# WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-# General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-#
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-basename="s,^.*/,,g"
-
-# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh
-# is ksh but when the shell is invoked as "sh" and the current value of
-# the _XPG environment variable is not equal to 1 (one), the special
-# positional parameter $0, within a function call, is the name of the
-# function.
-progpath="$0"
-
-# The name of this program:
-progname=`echo "$progpath" | $SED $basename`
-modename="$progname"
-
-# Global variables:
-EXIT_SUCCESS=0
-EXIT_FAILURE=1
-
-PROGRAM=ltmain.sh
-PACKAGE=libtool
-VERSION=1.5.16
-TIMESTAMP=" (1.1220.2.234 2005/04/24 17:45:58)"
-
-# See if we are running on zsh, and set the options which allow our
-# commands through without removal of \ escapes.
-if test -n "${ZSH_VERSION+set}" ; then
-  setopt NO_GLOB_SUBST
-fi
-
-# Check that we have a working $echo.
-if test "X$1" = X--no-reexec; then
-  # Discard the --no-reexec flag, and continue.
-  shift
-elif test "X$1" = X--fallback-echo; then
-  # Avoid inline document here, it may be left over
-  :
-elif test "X`($echo '\t') 2>/dev/null`" = 'X\t'; then
-  # Yippee, $echo works!
-  :
-else
-  # Restart under the correct shell, and then maybe $echo will work.
-  exec $SHELL "$progpath" --no-reexec ${1+"$@"}
-fi
-
-if test "X$1" = X--fallback-echo; then
-  # used as fallback echo
-  shift
-  cat <<EOF
-$*
-EOF
-  exit $EXIT_SUCCESS
-fi
-
-default_mode=
-help="Try \`$progname --help' for more information."
-magic="%%%MAGIC variable%%%"
-mkdir="mkdir"
-mv="mv -f"
-rm="rm -f"
-
-# 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'
-# test EBCDIC or ASCII
-case `echo A|tr A '\301'` in
- A) # EBCDIC based system
-  SP2NL="tr '\100' '\n'"
-  NL2SP="tr '\r\n' '\100\100'"
-  ;;
- *) # Assume ASCII based system
-  SP2NL="tr '\040' '\012'"
-  NL2SP="tr '\015\012' '\040\040'"
-  ;;
-esac
-
-# NLS nuisances.
-# Only set LANG and LC_ALL to C if already set.
-# These must not be set unconditionally because not all systems understand
-# e.g. LANG=C (notably SCO).
-# We save the old values to restore during execute mode.
-if test "${LC_ALL+set}" = set; then
-  save_LC_ALL="$LC_ALL"; LC_ALL=C; export LC_ALL
-fi
-if test "${LANG+set}" = set; then
-  save_LANG="$LANG"; LANG=C; export LANG
-fi
-
-# Make sure IFS has a sensible default
-lt_nl='
-'
-IFS=" 	$lt_nl"
-
-if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then
-  $echo "$modename: not configured to build any kind of library" 1>&2
-  $echo "Fatal configuration error.  See the $PACKAGE docs for more information." 1>&2
-  exit $EXIT_FAILURE
-fi
-
-# Global variables.
-mode=$default_mode
-nonopt=
-prev=
-prevopt=
-run=
-show="$echo"
-show_help=
-execute_dlfiles=
-lo2o="s/\\.lo\$/.${objext}/"
-o2lo="s/\\.${objext}\$/.lo/"
-quote_scanset='[[~#^*{};<>?'"'"' 	]'
-
-#####################################
-# Shell function definitions:
-# This seems to be the best place for them
-
-# func_win32_libid arg
-# return the library type of file 'arg'
-#
-# Need a lot of goo to handle *both* DLLs and import libs
-# Has to be a shell function in order to 'eat' the argument
-# that is supplied when $file_magic_command is called.
-func_win32_libid ()
-{
-  win32_libid_type="unknown"
-  win32_fileres=`file -L $1 2>/dev/null`
-  case $win32_fileres in
-  *ar\ archive\ import\ library*) # definitely import
-    win32_libid_type="x86 archive import"
-    ;;
-  *ar\ archive*) # could be an import, or static
-    if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | \
-      $EGREP -e 'file format pe-i386(.*architecture: i386)?' >/dev/null ; then
-      win32_nmres=`eval $NM -f posix -A $1 | \
-	sed -n -e '1,100{/ I /{x;/import/!{s/^/import/;h;p;};x;};}'`
-      if test "X$win32_nmres" = "Ximport" ; then
-        win32_libid_type="x86 archive import"
-      else
-        win32_libid_type="x86 archive static"
-      fi
-    fi
-    ;;
-  *DLL*)
-    win32_libid_type="x86 DLL"
-    ;;
-  *executable*) # but shell scripts are "executable" too...
-    case $win32_fileres in
-    *MS\ Windows\ PE\ Intel*)
-      win32_libid_type="x86 DLL"
-      ;;
-    esac
-    ;;
-  esac
-  $echo $win32_libid_type
-}
-
-
-# func_infer_tag arg
-# Infer tagged configuration to use if any are available and
-# if one wasn't chosen via the "--tag" command line option.
-# Only attempt this if the compiler in the base compile
-# command doesn't match the default compiler.
-# arg is usually of the form 'gcc ...'
-func_infer_tag ()
-{
-    if test -n "$available_tags" && test -z "$tagname"; then
-      CC_quoted=
-      for arg in $CC; do
-	case $arg in
-	  *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	  arg="\"$arg\""
-	  ;;
-	esac
-	CC_quoted="$CC_quoted $arg"
-      done
-      case $@ in
-      # Blanks in the command may have been stripped by the calling shell,
-      # but not from the CC environment variable when configure was run.
-      " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*) ;;
-      # Blanks at the start of $base_compile will cause this to fail
-      # if we don't check for them as well.
-      *)
-	for z in $available_tags; do
-	  if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then
-	    # Evaluate the configuration.
-	    eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`"
-	    CC_quoted=
-	    for arg in $CC; do
-	    # Double-quote args containing other shell metacharacters.
-	    case $arg in
-	      *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	      arg="\"$arg\""
-	      ;;
-	    esac
-	    CC_quoted="$CC_quoted $arg"
-	  done
-	    case "$@ " in
-	      " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*)
-	      # The compiler in the base compile command matches
-	      # the one in the tagged configuration.
-	      # Assume this is the tagged configuration we want.
-	      tagname=$z
-	      break
-	      ;;
-	    esac
-	  fi
-	done
-	# If $tagname still isn't set, then no tagged configuration
-	# was found and let the user know that the "--tag" command
-	# line option must be used.
-	if test -z "$tagname"; then
-	  $echo "$modename: unable to infer tagged configuration"
-	  $echo "$modename: specify a tag with \`--tag'" 1>&2
-	  exit $EXIT_FAILURE
-#        else
-#          $echo "$modename: using $tagname tagged configuration"
-	fi
-	;;
-      esac
-    fi
-}
-
-
-# func_extract_an_archive dir oldlib
-func_extract_an_archive ()
-{
-    f_ex_an_ar_dir="$1"; shift
-    f_ex_an_ar_oldlib="$1"
-
-    $show "(cd $f_ex_an_ar_dir && $AR x $f_ex_an_ar_oldlib)"
-    $run eval "(cd \$f_ex_an_ar_dir && $AR x \$f_ex_an_ar_oldlib)" || exit $?
-    if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then
-     :
-    else
-      $echo "$modename: ERROR: object name conflicts: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" 1>&2
-      exit $EXIT_FAILURE
-    fi
-}
-
-# func_extract_archives gentop oldlib ...
-func_extract_archives ()
-{
-    my_gentop="$1"; shift
-    my_oldlibs=${1+"$@"}
-    my_oldobjs=""
-    my_xlib=""
-    my_xabs=""
-    my_xdir=""
-    my_status=""
-
-    $show "${rm}r $my_gentop"
-    $run ${rm}r "$my_gentop"
-    $show "$mkdir $my_gentop"
-    $run $mkdir "$my_gentop"
-    my_status=$?
-    if test "$my_status" -ne 0 && test ! -d "$my_gentop"; then
-      exit $my_status
-    fi
-
-    for my_xlib in $my_oldlibs; do
-      # Extract the objects.
-      case $my_xlib in
-	[\\/]* | [A-Za-z]:[\\/]*) my_xabs="$my_xlib" ;;
-	*) my_xabs=`pwd`"/$my_xlib" ;;
-      esac
-      my_xlib=`$echo "X$my_xlib" | $Xsed -e 's%^.*/%%'`
-      my_xdir="$my_gentop/$my_xlib"
-
-      $show "${rm}r $my_xdir"
-      $run ${rm}r "$my_xdir"
-      $show "$mkdir $my_xdir"
-      $run $mkdir "$my_xdir"
-      status=$?
-      if test "$status" -ne 0 && test ! -d "$my_xdir"; then
-	exit $status
-      fi
-      case $host in
-      *-darwin*)
-	$show "Extracting $my_xabs"
-	# Do not bother doing anything if just a dry run
-	if test -z "$run"; then
-	  darwin_orig_dir=`pwd`
-	  cd $my_xdir || exit $?
-	  darwin_archive=$my_xabs
-	  darwin_curdir=`pwd`
-	  darwin_base_archive=`$echo "X$darwin_archive" | $Xsed -e 's%^.*/%%'`
-	  darwin_arches=`lipo -info "$darwin_archive" 2>/dev/null | $EGREP Architectures 2>/dev/null`
-	  if test -n "$darwin_arches"; then 
-	    darwin_arches=`echo "$darwin_arches" | $SED -e 's/.*are://'`
-	    darwin_arch=
-	    $show "$darwin_base_archive has multiple architectures $darwin_arches"
-	    for darwin_arch in  $darwin_arches ; do
-	      mkdir -p "unfat-$$/${darwin_base_archive}-${darwin_arch}"
-	      lipo -thin $darwin_arch -output "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" "${darwin_archive}"
-	      cd "unfat-$$/${darwin_base_archive}-${darwin_arch}"
-	      func_extract_an_archive "`pwd`" "${darwin_base_archive}"
-	      cd "$darwin_curdir"
-	      $rm "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}"
-	    done # $darwin_arches
-      ## Okay now we have a bunch of thin objects, gotta fatten them up :)
-	    darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print| xargs basename | sort -u | $NL2SP`
-	    darwin_file=
-	    darwin_files=
-	    for darwin_file in $darwin_filelist; do
-	      darwin_files=`find unfat-$$ -name $darwin_file -print | $NL2SP`
-	      lipo -create -output "$darwin_file" $darwin_files
-	    done # $darwin_filelist
-	    ${rm}r unfat-$$
-	    cd "$darwin_orig_dir"
-	  else
-	    cd "$darwin_orig_dir"
- 	    func_extract_an_archive "$my_xdir" "$my_xabs"
-	  fi # $darwin_arches
-	fi # $run
-      ;;
-      *)
-        func_extract_an_archive "$my_xdir" "$my_xabs"
-        ;;
-      esac
-      my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | $NL2SP`
-    done
-    func_extract_archives_result="$my_oldobjs"
-}
-# End of Shell function definitions
-#####################################
-
-# Darwin sucks
-eval std_shrext=\"$shrext_cmds\"
-
-# Parse our command line options once, thoroughly.
-while test "$#" -gt 0
-do
-  arg="$1"
-  shift
-
-  case $arg in
-  -*=*) optarg=`$echo "X$arg" | $Xsed -e 's/[-_a-zA-Z0-9]*=//'` ;;
-  *) optarg= ;;
-  esac
-
-  # If the previous option needs an argument, assign it.
-  if test -n "$prev"; then
-    case $prev in
-    execute_dlfiles)
-      execute_dlfiles="$execute_dlfiles $arg"
-      ;;
-    tag)
-      tagname="$arg"
-      preserve_args="${preserve_args}=$arg"
-
-      # Check whether tagname contains only valid characters
-      case $tagname in
-      *[!-_A-Za-z0-9,/]*)
-	$echo "$progname: invalid tag name: $tagname" 1>&2
-	exit $EXIT_FAILURE
-	;;
-      esac
-
-      case $tagname in
-      CC)
-	# Don't test for the "default" C tag, as we know, it's there, but
-	# not specially marked.
-	;;
-      *)
-	if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$" < "$progpath" > /dev/null; then
-	  taglist="$taglist $tagname"
-	  # Evaluate the configuration.
-	  eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$tagname'$/,/^# ### END LIBTOOL TAG CONFIG: '$tagname'$/p' < $progpath`"
-	else
-	  $echo "$progname: ignoring unknown tag $tagname" 1>&2
-	fi
-	;;
-      esac
-      ;;
-    *)
-      eval "$prev=\$arg"
-      ;;
-    esac
-
-    prev=
-    prevopt=
-    continue
-  fi
-
-  # Have we seen a non-optional argument yet?
-  case $arg in
-  --help)
-    show_help=yes
-    ;;
-
-  --version)
-    $echo "$PROGRAM (GNU $PACKAGE) $VERSION$TIMESTAMP"
-    $echo
-    $echo "Copyright (C) 2005  Free Software Foundation, Inc."
-    $echo "This is free software; see the source for copying conditions.  There is NO"
-    $echo "warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
-    exit $?
-    ;;
-
-  --config)
-    ${SED} -e '1,/^# ### BEGIN LIBTOOL CONFIG/d' -e '/^# ### END LIBTOOL CONFIG/,$d' $progpath
-    # Now print the configurations for the tags.
-    for tagname in $taglist; do
-      ${SED} -n -e "/^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$/,/^# ### END LIBTOOL TAG CONFIG: $tagname$/p" < "$progpath"
-    done
-    exit $?
-    ;;
-
-  --debug)
-    $echo "$progname: enabling shell trace mode"
-    set -x
-    preserve_args="$preserve_args $arg"
-    ;;
-
-  --dry-run | -n)
-    run=:
-    ;;
-
-  --features)
-    $echo "host: $host"
-    if test "$build_libtool_libs" = yes; then
-      $echo "enable shared libraries"
-    else
-      $echo "disable shared libraries"
-    fi
-    if test "$build_old_libs" = yes; then
-      $echo "enable static libraries"
-    else
-      $echo "disable static libraries"
-    fi
-    exit $?
-    ;;
-
-  --finish) mode="finish" ;;
-
-  --mode) prevopt="--mode" prev=mode ;;
-  --mode=*) mode="$optarg" ;;
-
-  --preserve-dup-deps) duplicate_deps="yes" ;;
-
-  --quiet | --silent)
-    show=:
-    preserve_args="$preserve_args $arg"
-    ;;
-
-  --tag) prevopt="--tag" prev=tag ;;
-  --tag=*)
-    set tag "$optarg" ${1+"$@"}
-    shift
-    prev=tag
-    preserve_args="$preserve_args --tag"
-    ;;
-
-  -dlopen)
-    prevopt="-dlopen"
-    prev=execute_dlfiles
-    ;;
-
-  -*)
-    $echo "$modename: unrecognized option \`$arg'" 1>&2
-    $echo "$help" 1>&2
-    exit $EXIT_FAILURE
-    ;;
-
-  *)
-    nonopt="$arg"
-    break
-    ;;
-  esac
-done
-
-if test -n "$prevopt"; then
-  $echo "$modename: option \`$prevopt' requires an argument" 1>&2
-  $echo "$help" 1>&2
-  exit $EXIT_FAILURE
-fi
-
-# If this variable is set in any of the actions, the command in it
-# will be execed at the end.  This prevents here-documents from being
-# left over by shells.
-exec_cmd=
-
-if test -z "$show_help"; then
-
-  # Infer the operation mode.
-  if test -z "$mode"; then
-    $echo "*** Warning: inferring the mode of operation is deprecated." 1>&2
-    $echo "*** Future versions of Libtool will require --mode=MODE be specified." 1>&2
-    case $nonopt in
-    *cc | cc* | *++ | gcc* | *-gcc* | g++* | xlc*)
-      mode=link
-      for arg
-      do
-	case $arg in
-	-c)
-	   mode=compile
-	   break
-	   ;;
-	esac
-      done
-      ;;
-    *db | *dbx | *strace | *truss)
-      mode=execute
-      ;;
-    *install*|cp|mv)
-      mode=install
-      ;;
-    *rm)
-      mode=uninstall
-      ;;
-    *)
-      # If we have no mode, but dlfiles were specified, then do execute mode.
-      test -n "$execute_dlfiles" && mode=execute
-
-      # Just use the default operation mode.
-      if test -z "$mode"; then
-	if test -n "$nonopt"; then
-	  $echo "$modename: warning: cannot infer operation mode from \`$nonopt'" 1>&2
-	else
-	  $echo "$modename: warning: cannot infer operation mode without MODE-ARGS" 1>&2
-	fi
-      fi
-      ;;
-    esac
-  fi
-
-  # Only execute mode is allowed to have -dlopen flags.
-  if test -n "$execute_dlfiles" && test "$mode" != execute; then
-    $echo "$modename: unrecognized option \`-dlopen'" 1>&2
-    $echo "$help" 1>&2
-    exit $EXIT_FAILURE
-  fi
-
-  # Change the help message to a mode-specific one.
-  generic_help="$help"
-  help="Try \`$modename --help --mode=$mode' for more information."
-
-  # These modes are in order of execution frequency so that they run quickly.
-  case $mode in
-  # libtool compile mode
-  compile)
-    modename="$modename: compile"
-    # Get the compilation command and the source file.
-    base_compile=
-    srcfile="$nonopt"  #  always keep a non-empty value in "srcfile"
-    suppress_opt=yes
-    suppress_output=
-    arg_mode=normal
-    libobj=
-    later=
-
-    for arg
-    do
-      case "$arg_mode" in
-      arg  )
-	# do not "continue".  Instead, add this to base_compile
-	lastarg="$arg"
-	arg_mode=normal
-	;;
-
-      target )
-	libobj="$arg"
-	arg_mode=normal
-	continue
-	;;
-
-      normal )
-	# Accept any command-line options.
-	case $arg in
-	-o)
-	  if test -n "$libobj" ; then
-	    $echo "$modename: you cannot specify \`-o' more than once" 1>&2
-	    exit $EXIT_FAILURE
-	  fi
-	  arg_mode=target
-	  continue
-	  ;;
-
-	-static | -prefer-pic | -prefer-non-pic)
-	  later="$later $arg"
-	  continue
-	  ;;
-
-	-no-suppress)
-	  suppress_opt=no
-	  continue
-	  ;;
-
-	-Xcompiler)
-	  arg_mode=arg  #  the next one goes into the "base_compile" arg list
-	  continue      #  The current "srcfile" will either be retained or
-	  ;;            #  replaced later.  I would guess that would be a bug.
-
-	-Wc,*)
-	  args=`$echo "X$arg" | $Xsed -e "s/^-Wc,//"`
-	  lastarg=
-	  save_ifs="$IFS"; IFS=','
- 	  for arg in $args; do
-	    IFS="$save_ifs"
-
-	    # Double-quote args containing other shell metacharacters.
-	    # Many Bourne shells cannot handle close brackets correctly
-	    # in scan sets, so we specify it separately.
-	    case $arg in
-	      *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	      arg="\"$arg\""
-	      ;;
-	    esac
-	    lastarg="$lastarg $arg"
-	  done
-	  IFS="$save_ifs"
-	  lastarg=`$echo "X$lastarg" | $Xsed -e "s/^ //"`
-
-	  # Add the arguments to base_compile.
-	  base_compile="$base_compile $lastarg"
-	  continue
-	  ;;
-
-	* )
-	  # Accept the current argument as the source file.
-	  # The previous "srcfile" becomes the current argument.
-	  #
-	  lastarg="$srcfile"
-	  srcfile="$arg"
-	  ;;
-	esac  #  case $arg
-	;;
-      esac    #  case $arg_mode
-
-      # Aesthetically quote the previous argument.
-      lastarg=`$echo "X$lastarg" | $Xsed -e "$sed_quote_subst"`
-
-      case $lastarg in
-      # Double-quote args containing other shell metacharacters.
-      # Many Bourne shells cannot handle close brackets correctly
-      # in scan sets, and some SunOS ksh mistreat backslash-escaping
-      # in scan sets (worked around with variable expansion),
-      # and furthermore cannot handle '|' '&' '(' ')' in scan sets 
-      # at all, so we specify them separately.
-      *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	lastarg="\"$lastarg\""
-	;;
-      esac
-
-      base_compile="$base_compile $lastarg"
-    done # for arg
-
-    case $arg_mode in
-    arg)
-      $echo "$modename: you must specify an argument for -Xcompile"
-      exit $EXIT_FAILURE
-      ;;
-    target)
-      $echo "$modename: you must specify a target with \`-o'" 1>&2
-      exit $EXIT_FAILURE
-      ;;
-    *)
-      # Get the name of the library object.
-      [ -z "$libobj" ] && libobj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%'`
-      ;;
-    esac
-
-    # Recognize several different file suffixes.
-    # If the user specifies -o file.o, it is replaced with file.lo
-    xform='[cCFSifmso]'
-    case $libobj in
-    *.ada) xform=ada ;;
-    *.adb) xform=adb ;;
-    *.ads) xform=ads ;;
-    *.asm) xform=asm ;;
-    *.c++) xform=c++ ;;
-    *.cc) xform=cc ;;
-    *.ii) xform=ii ;;
-    *.class) xform=class ;;
-    *.cpp) xform=cpp ;;
-    *.cxx) xform=cxx ;;
-    *.f90) xform=f90 ;;
-    *.for) xform=for ;;
-    *.java) xform=java ;;
-    esac
-
-    libobj=`$echo "X$libobj" | $Xsed -e "s/\.$xform$/.lo/"`
-
-    case $libobj in
-    *.lo) obj=`$echo "X$libobj" | $Xsed -e "$lo2o"` ;;
-    *)
-      $echo "$modename: cannot determine name of library object from \`$libobj'" 1>&2
-      exit $EXIT_FAILURE
-      ;;
-    esac
-
-    func_infer_tag $base_compile
-
-    for arg in $later; do
-      case $arg in
-      -static)
-	build_old_libs=yes
-	continue
-	;;
-
-      -prefer-pic)
-	pic_mode=yes
-	continue
-	;;
-
-      -prefer-non-pic)
-	pic_mode=no
-	continue
-	;;
-      esac
-    done
-
-    qlibobj=`$echo "X$libobj" | $Xsed -e "$sed_quote_subst"`
-    case $qlibobj in
-      *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	qlibobj="\"$qlibobj\"" ;;
-    esac
-    if test "X$libobj" != "X$qlibobj"; then
-	$echo "$modename: libobj name \`$libobj' may not contain shell special characters."
-	exit $EXIT_FAILURE
-    fi
-    objname=`$echo "X$obj" | $Xsed -e 's%^.*/%%'`
-    xdir=`$echo "X$obj" | $Xsed -e 's%/[^/]*$%%'`
-    if test "X$xdir" = "X$obj"; then
-      xdir=
-    else
-      xdir=$xdir/
-    fi
-    lobj=${xdir}$objdir/$objname
-
-    if test -z "$base_compile"; then
-      $echo "$modename: you must specify a compilation command" 1>&2
-      $echo "$help" 1>&2
-      exit $EXIT_FAILURE
-    fi
-
-    # Delete any leftover library objects.
-    if test "$build_old_libs" = yes; then
-      removelist="$obj $lobj $libobj ${libobj}T"
-    else
-      removelist="$lobj $libobj ${libobj}T"
-    fi
-
-    $run $rm $removelist
-    trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15
-
-    # On Cygwin there's no "real" PIC flag so we must build both object types
-    case $host_os in
-    cygwin* | mingw* | pw32* | os2*)
-      pic_mode=default
-      ;;
-    esac
-    if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then
-      # non-PIC code in shared libraries is not supported
-      pic_mode=default
-    fi
-
-    # Calculate the filename of the output object if compiler does
-    # not support -o with -c
-    if test "$compiler_c_o" = no; then
-      output_obj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%' -e 's%\.[^.]*$%%'`.${objext}
-      lockfile="$output_obj.lock"
-      removelist="$removelist $output_obj $lockfile"
-      trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15
-    else
-      output_obj=
-      need_locks=no
-      lockfile=
-    fi
-
-    # Lock this critical section if it is needed
-    # We use this script file to make the link, it avoids creating a new file
-    if test "$need_locks" = yes; then
-      until $run ln "$progpath" "$lockfile" 2>/dev/null; do
-	$show "Waiting for $lockfile to be removed"
-	sleep 2
-      done
-    elif test "$need_locks" = warn; then
-      if test -f "$lockfile"; then
-	$echo "\
-*** ERROR, $lockfile exists and contains:
-`cat $lockfile 2>/dev/null`
-
-This indicates that another process is trying to use the same
-temporary object file, and libtool could not work around it because
-your compiler does not support \`-c' and \`-o' together.  If you
-repeat this compilation, it may succeed, by chance, but you had better
-avoid parallel builds (make -j) in this platform, or get a better
-compiler."
-
-	$run $rm $removelist
-	exit $EXIT_FAILURE
-      fi
-      $echo "$srcfile" > "$lockfile"
-    fi
-
-    if test -n "$fix_srcfile_path"; then
-      eval srcfile=\"$fix_srcfile_path\"
-    fi
-    qsrcfile=`$echo "X$srcfile" | $Xsed -e "$sed_quote_subst"`
-    case $qsrcfile in
-      *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-      qsrcfile="\"$qsrcfile\"" ;;
-    esac
-
-    $run $rm "$libobj" "${libobj}T"
-
-    # Create a libtool object file (analogous to a ".la" file),
-    # but don't create it if we're doing a dry run.
-    test -z "$run" && cat > ${libobj}T <<EOF
-# $libobj - a libtool object file
-# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP
-#
-# Please DO NOT delete this file!
-# It is necessary for linking the library.
-
-# Name of the PIC object.
-EOF
-
-    # Only build a PIC object if we are building libtool libraries.
-    if test "$build_libtool_libs" = yes; then
-      # Without this assignment, base_compile gets emptied.
-      fbsd_hideous_sh_bug=$base_compile
-
-      if test "$pic_mode" != no; then
-	command="$base_compile $qsrcfile $pic_flag"
-      else
-	# Don't build PIC code
-	command="$base_compile $qsrcfile"
-      fi
-
-      if test ! -d "${xdir}$objdir"; then
-	$show "$mkdir ${xdir}$objdir"
-	$run $mkdir ${xdir}$objdir
-	status=$?
-	if test "$status" -ne 0 && test ! -d "${xdir}$objdir"; then
-	  exit $status
-	fi
-      fi
-
-      if test -z "$output_obj"; then
-	# Place PIC objects in $objdir
-	command="$command -o $lobj"
-      fi
-
-      $run $rm "$lobj" "$output_obj"
-
-      $show "$command"
-      if $run eval "$command"; then :
-      else
-	test -n "$output_obj" && $run $rm $removelist
-	exit $EXIT_FAILURE
-      fi
-
-      if test "$need_locks" = warn &&
-	 test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
-	$echo "\
-*** ERROR, $lockfile contains:
-`cat $lockfile 2>/dev/null`
-
-but it should contain:
-$srcfile
-
-This indicates that another process is trying to use the same
-temporary object file, and libtool could not work around it because
-your compiler does not support \`-c' and \`-o' together.  If you
-repeat this compilation, it may succeed, by chance, but you had better
-avoid parallel builds (make -j) in this platform, or get a better
-compiler."
-
-	$run $rm $removelist
-	exit $EXIT_FAILURE
-      fi
-
-      # Just move the object if needed, then go on to compile the next one
-      if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then
-	$show "$mv $output_obj $lobj"
-	if $run $mv $output_obj $lobj; then :
-	else
-	  error=$?
-	  $run $rm $removelist
-	  exit $error
-	fi
-      fi
-
-      # Append the name of the PIC object to the libtool object file.
-      test -z "$run" && cat >> ${libobj}T <<EOF
-pic_object='$objdir/$objname'
-
-EOF
-
-      # Allow error messages only from the first compilation.
-      if test "$suppress_opt" = yes; then
-        suppress_output=' >/dev/null 2>&1'
-      fi
-    else
-      # No PIC object so indicate it doesn't exist in the libtool
-      # object file.
-      test -z "$run" && cat >> ${libobj}T <<EOF
-pic_object=none
-
-EOF
-    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
-	# Don't build PIC code
-	command="$base_compile $qsrcfile"
-      else
-	command="$base_compile $qsrcfile $pic_flag"
-      fi
-      if test "$compiler_c_o" = yes; then
-	command="$command -o $obj"
-      fi
-
-      # Suppress compiler output if we already did a PIC compilation.
-      command="$command$suppress_output"
-      $run $rm "$obj" "$output_obj"
-      $show "$command"
-      if $run eval "$command"; then :
-      else
-	$run $rm $removelist
-	exit $EXIT_FAILURE
-      fi
-
-      if test "$need_locks" = warn &&
-	 test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
-	$echo "\
-*** ERROR, $lockfile contains:
-`cat $lockfile 2>/dev/null`
-
-but it should contain:
-$srcfile
-
-This indicates that another process is trying to use the same
-temporary object file, and libtool could not work around it because
-your compiler does not support \`-c' and \`-o' together.  If you
-repeat this compilation, it may succeed, by chance, but you had better
-avoid parallel builds (make -j) in this platform, or get a better
-compiler."
-
-	$run $rm $removelist
-	exit $EXIT_FAILURE
-      fi
-
-      # Just move the object if needed
-      if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then
-	$show "$mv $output_obj $obj"
-	if $run $mv $output_obj $obj; then :
-	else
-	  error=$?
-	  $run $rm $removelist
-	  exit $error
-	fi
-      fi
-
-      # Append the name of the non-PIC object the libtool object file.
-      # Only append if the libtool object file exists.
-      test -z "$run" && cat >> ${libobj}T <<EOF
-# Name of the non-PIC object.
-non_pic_object='$objname'
-
-EOF
-    else
-      # Append the name of the non-PIC object the libtool object file.
-      # Only append if the libtool object file exists.
-      test -z "$run" && cat >> ${libobj}T <<EOF
-# Name of the non-PIC object.
-non_pic_object=none
-
-EOF
-    fi
-
-    $run $mv "${libobj}T" "${libobj}"
-
-    # Unlock the critical section if it was locked
-    if test "$need_locks" != no; then
-      $run $rm "$lockfile"
-    fi
-
-    exit $EXIT_SUCCESS
-    ;;
-
-  # libtool link mode
-  link | relink)
-    modename="$modename: link"
-    case $host in
-    *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*)
-      # 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
-      # 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
-      # 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.
-      allow_undefined=yes
-      ;;
-    *)
-      allow_undefined=yes
-      ;;
-    esac
-    libtool_args="$nonopt"
-    base_compile="$nonopt $@"
-    compile_command="$nonopt"
-    finalize_command="$nonopt"
-
-    compile_rpath=
-    finalize_rpath=
-    compile_shlibpath=
-    finalize_shlibpath=
-    convenience=
-    old_convenience=
-    deplibs=
-    old_deplibs=
-    compiler_flags=
-    linker_flags=
-    dllsearchpath=
-    lib_search_path=`pwd`
-    inst_prefix_dir=
-
-    avoid_version=no
-    dlfiles=
-    dlprefiles=
-    dlself=no
-    export_dynamic=no
-    export_symbols=
-    export_symbols_regex=
-    generated=
-    libobjs=
-    ltlibs=
-    module=no
-    no_install=no
-    objs=
-    non_pic_objects=
-    precious_files_regex=
-    prefer_static_libs=no
-    preload=no
-    prev=
-    prevarg=
-    release=
-    rpath=
-    xrpath=
-    perm_rpath=
-    temp_rpath=
-    thread_safe=no
-    vinfo=
-    vinfo_number=no
-
-    func_infer_tag $base_compile
-
-    # We need to know -static, to get the right output filenames.
-    for arg
-    do
-      case $arg in
-      -all-static | -static)
-	if test "X$arg" = "X-all-static"; then
-	  if test "$build_libtool_libs" = yes && test -z "$link_static_flag"; then
-	    $echo "$modename: warning: complete static linking is impossible in this configuration" 1>&2
-	  fi
-	  if test -n "$link_static_flag"; then
-	    dlopen_self=$dlopen_self_static
-	  fi
-	else
-	  if test -z "$pic_flag" && test -n "$link_static_flag"; then
-	    dlopen_self=$dlopen_self_static
-	  fi
-	fi
-	build_libtool_libs=no
-	build_old_libs=yes
-	prefer_static_libs=yes
-	break
-	;;
-      esac
-    done
-
-    # See if our shared archives depend on static archives.
-    test -n "$old_archive_from_new_cmds" && build_old_libs=yes
-
-    # Go through the arguments, transforming them on the way.
-    while test "$#" -gt 0; do
-      arg="$1"
-      shift
-      case $arg in
-      *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	qarg=\"`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`\" ### testsuite: skip nested quoting test
-	;;
-      *) qarg=$arg ;;
-      esac
-      libtool_args="$libtool_args $qarg"
-
-      # If the previous option needs an argument, assign it.
-      if test -n "$prev"; then
-	case $prev in
-	output)
-	  compile_command="$compile_command @OUTPUT@"
-	  finalize_command="$finalize_command @OUTPUT@"
-	  ;;
-	esac
-
-	case $prev in
-	dlfiles|dlprefiles)
-	  if test "$preload" = no; then
-	    # Add the symbol object into the linking commands.
-	    compile_command="$compile_command @SYMFILE@"
-	    finalize_command="$finalize_command @SYMFILE@"
-	    preload=yes
-	  fi
-	  case $arg in
-	  *.la | *.lo) ;;  # We handle these cases below.
-	  force)
-	    if test "$dlself" = no; then
-	      dlself=needless
-	      export_dynamic=yes
-	    fi
-	    prev=
-	    continue
-	    ;;
-	  self)
-	    if test "$prev" = dlprefiles; then
-	      dlself=yes
-	    elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then
-	      dlself=yes
-	    else
-	      dlself=needless
-	      export_dynamic=yes
-	    fi
-	    prev=
-	    continue
-	    ;;
-	  *)
-	    if test "$prev" = dlfiles; then
-	      dlfiles="$dlfiles $arg"
-	    else
-	      dlprefiles="$dlprefiles $arg"
-	    fi
-	    prev=
-	    continue
-	    ;;
-	  esac
-	  ;;
-	expsyms)
-	  export_symbols="$arg"
-	  if test ! -f "$arg"; then
-	    $echo "$modename: symbol file \`$arg' does not exist"
-	    exit $EXIT_FAILURE
-	  fi
-	  prev=
-	  continue
-	  ;;
-	expsyms_regex)
-	  export_symbols_regex="$arg"
-	  prev=
-	  continue
-	  ;;
-	inst_prefix)
-	  inst_prefix_dir="$arg"
-	  prev=
-	  continue
-	  ;;
-	precious_regex)
-	  precious_files_regex="$arg"
-	  prev=
-	  continue
-	  ;;
-	release)
-	  release="-$arg"
-	  prev=
-	  continue
-	  ;;
-	objectlist)
-	  if test -f "$arg"; then
-	    save_arg=$arg
-	    moreargs=
-	    for fil in `cat $save_arg`
-	    do
-#	      moreargs="$moreargs $fil"
-	      arg=$fil
-	      # A libtool-controlled object.
-
-	      # Check to see that this really is a libtool object.
-	      if (${SED} -e '2q' $arg | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
-		pic_object=
-		non_pic_object=
-
-		# Read the .lo file
-		# If there is no directory component, then add one.
-		case $arg in
-		*/* | *\\*) . $arg ;;
-		*) . ./$arg ;;
-		esac
-
-		if test -z "$pic_object" || \
-		   test -z "$non_pic_object" ||
-		   test "$pic_object" = none && \
-		   test "$non_pic_object" = none; then
-		  $echo "$modename: cannot find name of object for \`$arg'" 1>&2
-		  exit $EXIT_FAILURE
-		fi
-
-		# Extract subdirectory from the argument.
-		xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
-		if test "X$xdir" = "X$arg"; then
-		  xdir=
-		else
-		  xdir="$xdir/"
-		fi
-
-		if test "$pic_object" != none; then
-		  # Prepend the subdirectory the object is found in.
-		  pic_object="$xdir$pic_object"
-
-		  if test "$prev" = dlfiles; then
-		    if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
-		      dlfiles="$dlfiles $pic_object"
-		      prev=
-		      continue
-		    else
-		      # If libtool objects are unsupported, then we need to preload.
-		      prev=dlprefiles
-		    fi
-		  fi
-
-		  # CHECK ME:  I think I busted this.  -Ossama
-		  if test "$prev" = dlprefiles; then
-		    # Preload the old-style object.
-		    dlprefiles="$dlprefiles $pic_object"
-		    prev=
-		  fi
-
-		  # A PIC object.
-		  libobjs="$libobjs $pic_object"
-		  arg="$pic_object"
-		fi
-
-		# Non-PIC object.
-		if test "$non_pic_object" != none; then
-		  # Prepend the subdirectory the object is found in.
-		  non_pic_object="$xdir$non_pic_object"
-
-		  # A standard non-PIC object
-		  non_pic_objects="$non_pic_objects $non_pic_object"
-		  if test -z "$pic_object" || test "$pic_object" = none ; then
-		    arg="$non_pic_object"
-		  fi
-		fi
-	      else
-		# Only an error if not doing a dry-run.
-		if test -z "$run"; then
-		  $echo "$modename: \`$arg' is not a valid libtool object" 1>&2
-		  exit $EXIT_FAILURE
-		else
-		  # Dry-run case.
-
-		  # Extract subdirectory from the argument.
-		  xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
-		  if test "X$xdir" = "X$arg"; then
-		    xdir=
-		  else
-		    xdir="$xdir/"
-		  fi
-
-		  pic_object=`$echo "X${xdir}${objdir}/${arg}" | $Xsed -e "$lo2o"`
-		  non_pic_object=`$echo "X${xdir}${arg}" | $Xsed -e "$lo2o"`
-		  libobjs="$libobjs $pic_object"
-		  non_pic_objects="$non_pic_objects $non_pic_object"
-		fi
-	      fi
-	    done
-	  else
-	    $echo "$modename: link input file \`$save_arg' does not exist"
-	    exit $EXIT_FAILURE
-	  fi
-	  arg=$save_arg
-	  prev=
-	  continue
-	  ;;
-	rpath | xrpath)
-	  # We need an absolute path.
-	  case $arg in
-	  [\\/]* | [A-Za-z]:[\\/]*) ;;
-	  *)
-	    $echo "$modename: only absolute run-paths are allowed" 1>&2
-	    exit $EXIT_FAILURE
-	    ;;
-	  esac
-	  if test "$prev" = rpath; then
-	    case "$rpath " in
-	    *" $arg "*) ;;
-	    *) rpath="$rpath $arg" ;;
-	    esac
-	  else
-	    case "$xrpath " in
-	    *" $arg "*) ;;
-	    *) xrpath="$xrpath $arg" ;;
-	    esac
-	  fi
-	  prev=
-	  continue
-	  ;;
-	xcompiler)
-	  compiler_flags="$compiler_flags $qarg"
-	  prev=
-	  compile_command="$compile_command $qarg"
-	  finalize_command="$finalize_command $qarg"
-	  continue
-	  ;;
-	xlinker)
-	  linker_flags="$linker_flags $qarg"
-	  compiler_flags="$compiler_flags $wl$qarg"
-	  prev=
-	  compile_command="$compile_command $wl$qarg"
-	  finalize_command="$finalize_command $wl$qarg"
-	  continue
-	  ;;
-	xcclinker)
-	  linker_flags="$linker_flags $qarg"
-	  compiler_flags="$compiler_flags $qarg"
-	  prev=
-	  compile_command="$compile_command $qarg"
-	  finalize_command="$finalize_command $qarg"
-	  continue
-	  ;;
-	shrext)
-  	  shrext_cmds="$arg"
-	  prev=
-	  continue
-	  ;;
-        darwin_framework)
-	  compiler_flags="$compiler_flags $arg"
-	  prev=
-	  continue
-	  ;;
-	*)
-	  eval "$prev=\"\$arg\""
-	  prev=
-	  continue
-	  ;;
-	esac
-      fi # test -n "$prev"
-
-      prevarg="$arg"
-
-      case $arg in
-      -all-static)
-	if test -n "$link_static_flag"; then
-	  compile_command="$compile_command $link_static_flag"
-	  finalize_command="$finalize_command $link_static_flag"
-	fi
-	continue
-	;;
-
-      -allow-undefined)
-	# FIXME: remove this flag sometime in the future.
-	$echo "$modename: \`-allow-undefined' is deprecated because it is the default" 1>&2
-	continue
-	;;
-
-      -avoid-version)
-	avoid_version=yes
-	continue
-	;;
-
-      -dlopen)
-	prev=dlfiles
-	continue
-	;;
-
-      -dlpreopen)
-	prev=dlprefiles
-	continue
-	;;
-
-      -export-dynamic)
-	export_dynamic=yes
-	continue
-	;;
-
-      -export-symbols | -export-symbols-regex)
-	if test -n "$export_symbols" || test -n "$export_symbols_regex"; then
-	  $echo "$modename: more than one -exported-symbols argument is not allowed"
-	  exit $EXIT_FAILURE
-	fi
-	if test "X$arg" = "X-export-symbols"; then
-	  prev=expsyms
-	else
-	  prev=expsyms_regex
-	fi
-	continue
-	;;
-
-      -framework)
-        prev=darwin_framework
-        compiler_flags="$compiler_flags $arg"
-        continue
-        ;;
-
-      -inst-prefix-dir)
-	prev=inst_prefix
-	continue
-	;;
-
-      # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:*
-      # so, if we see these flags be careful not to treat them like -L
-      -L[A-Z][A-Z]*:*)
-	case $with_gcc/$host in
-	no/*-*-irix* | /*-*-irix*)
-	  compile_command="$compile_command $arg"
-	  finalize_command="$finalize_command $arg"
-	  ;;
-	esac
-	continue
-	;;
-
-      -L*)
-	dir=`$echo "X$arg" | $Xsed -e 's/^-L//'`
-	# We need an absolute path.
-	case $dir in
-	[\\/]* | [A-Za-z]:[\\/]*) ;;
-	*)
-	  absdir=`cd "$dir" && pwd`
-	  if test -z "$absdir"; then
-	    $echo "$modename: cannot determine absolute directory name of \`$dir'" 1>&2
-	    exit $EXIT_FAILURE
-	  fi
-	  dir="$absdir"
-	  ;;
-	esac
-	case "$deplibs " in
-	*" -L$dir "*) ;;
-	*)
-	  deplibs="$deplibs -L$dir"
-	  lib_search_path="$lib_search_path $dir"
-	  ;;
-	esac
-	case $host in
-	*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*)
-	  case :$dllsearchpath: in
-	  *":$dir:"*) ;;
-	  *) dllsearchpath="$dllsearchpath:$dir";;
-	  esac
-	  ;;
-	esac
-	continue
-	;;
-
-      -l*)
-	if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then
-	  case $host in
-	  *-*-cygwin* | *-*-pw32* | *-*-beos*)
-	    # These systems don't actually have a C or math library (as such)
-	    continue
-	    ;;
-	  *-*-mingw* | *-*-os2*)
-	    # These systems don't actually have a C library (as such)
-	    test "X$arg" = "X-lc" && continue
-	    ;;
-	  *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
-	    # Do not include libc due to us having libc/libc_r.
-	    test "X$arg" = "X-lc" && continue
-	    ;;
-	  *-*-rhapsody* | *-*-darwin1.[012])
-	    # Rhapsody C and math libraries are in the System framework
-	    deplibs="$deplibs -framework System"
-	    continue
-	  esac
-	elif test "X$arg" = "X-lc_r"; then
-	 case $host in
-	 *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
-	   # Do not include libc_r directly, use -pthread flag.
-	   continue
-	   ;;
-	 esac
-	fi
-	deplibs="$deplibs $arg"
-	continue
-	;;
-
-      # Tru64 UNIX uses -model [arg] to determine the layout of C++
-      # classes, name mangling, and exception handling.
-      -model)
-	compile_command="$compile_command $arg"
-	compiler_flags="$compiler_flags $arg"
-	finalize_command="$finalize_command $arg"
-	prev=xcompiler
-	continue
-	;;
-
-     -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe)
-	compiler_flags="$compiler_flags $arg"
-	compile_command="$compile_command $arg"
-	finalize_command="$finalize_command $arg"
-	continue
-	;;
-
-      -module)
-	module=yes
-	continue
-	;;
-
-      # -64, -mips[0-9] enable 64-bit mode on the SGI compiler
-      # -r[0-9][0-9]* specifies the processor on the SGI compiler
-      # -xarch=*, -xtarget=* enable 64-bit mode on the Sun compiler
-      # +DA*, +DD* enable 64-bit mode on the HP compiler
-      # -q* pass through compiler args for the IBM compiler
-      # -m* pass through architecture-specific compiler args for GCC
-      -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*)
-
-	# Unknown arguments in both finalize_command and compile_command need
-	# to be aesthetically quoted because they are evaled later.
-	arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
-	case $arg in
-	*$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	  arg="\"$arg\""
-	  ;;
-	esac
-        compile_command="$compile_command $arg"
-        finalize_command="$finalize_command $arg"
-        if test "$with_gcc" = "yes" ; then
-          compiler_flags="$compiler_flags $arg"
-        fi
-        continue
-        ;;
-
-      -shrext)
-	prev=shrext
-	continue
-	;;
-
-      -no-fast-install)
-	fast_install=no
-	continue
-	;;
-
-      -no-install)
-	case $host in
-	*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*)
-	  # The PATH hackery in wrapper scripts is required on Windows
-	  # in order for the loader to find any dlls it needs.
-	  $echo "$modename: warning: \`-no-install' is ignored for $host" 1>&2
-	  $echo "$modename: warning: assuming \`-no-fast-install' instead" 1>&2
-	  fast_install=no
-	  ;;
-	*) no_install=yes ;;
-	esac
-	continue
-	;;
-
-      -no-undefined)
-	allow_undefined=no
-	continue
-	;;
-
-      -objectlist)
-	prev=objectlist
-	continue
-	;;
-
-      -o) prev=output ;;
-
-      -precious-files-regex)
-	prev=precious_regex
-	continue
-	;;
-
-      -release)
-	prev=release
-	continue
-	;;
-
-      -rpath)
-	prev=rpath
-	continue
-	;;
-
-      -R)
-	prev=xrpath
-	continue
-	;;
-
-      -R*)
-	dir=`$echo "X$arg" | $Xsed -e 's/^-R//'`
-	# We need an absolute path.
-	case $dir in
-	[\\/]* | [A-Za-z]:[\\/]*) ;;
-	*)
-	  $echo "$modename: only absolute run-paths are allowed" 1>&2
-	  exit $EXIT_FAILURE
-	  ;;
-	esac
-	case "$xrpath " in
-	*" $dir "*) ;;
-	*) xrpath="$xrpath $dir" ;;
-	esac
-	continue
-	;;
-
-      -static)
-	# The effects of -static are defined in a previous loop.
-	# We used to do the same as -all-static on platforms that
-	# didn't have a PIC flag, but the assumption that the effects
-	# would be equivalent was wrong.  It would break on at least
-	# Digital Unix and AIX.
-	continue
-	;;
-
-      -thread-safe)
-	thread_safe=yes
-	continue
-	;;
-
-      -version-info)
-	prev=vinfo
-	continue
-	;;
-      -version-number)
-	prev=vinfo
-	vinfo_number=yes
-	continue
-	;;
-
-      -Wc,*)
-	args=`$echo "X$arg" | $Xsed -e "$sed_quote_subst" -e 's/^-Wc,//'`
-	arg=
-	save_ifs="$IFS"; IFS=','
-	for flag in $args; do
-	  IFS="$save_ifs"
-	  case $flag in
-	    *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	    flag="\"$flag\""
-	    ;;
-	  esac
-	  arg="$arg $wl$flag"
-	  compiler_flags="$compiler_flags $flag"
-	done
-	IFS="$save_ifs"
-	arg=`$echo "X$arg" | $Xsed -e "s/^ //"`
-	;;
-
-      -Wl,*)
-	args=`$echo "X$arg" | $Xsed -e "$sed_quote_subst" -e 's/^-Wl,//'`
-	arg=
-	save_ifs="$IFS"; IFS=','
-	for flag in $args; do
-	  IFS="$save_ifs"
-	  case $flag in
-	    *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	    flag="\"$flag\""
-	    ;;
-	  esac
-	  arg="$arg $wl$flag"
-	  compiler_flags="$compiler_flags $wl$flag"
-	  linker_flags="$linker_flags $flag"
-	done
-	IFS="$save_ifs"
-	arg=`$echo "X$arg" | $Xsed -e "s/^ //"`
-	;;
-
-      -Xcompiler)
-	prev=xcompiler
-	continue
-	;;
-
-      -Xlinker)
-	prev=xlinker
-	continue
-	;;
-
-      -XCClinker)
-	prev=xcclinker
-	continue
-	;;
-
-      # Some other compiler flag.
-      -* | +*)
-	# Unknown arguments in both finalize_command and compile_command need
-	# to be aesthetically quoted because they are evaled later.
-	arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
-	case $arg in
-	*$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	  arg="\"$arg\""
-	  ;;
-	esac
-	;;
-
-      *.$objext)
-	# A standard object.
-	objs="$objs $arg"
-	;;
-
-      *.lo)
-	# A libtool-controlled object.
-
-	# Check to see that this really is a libtool object.
-	if (${SED} -e '2q' $arg | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
-	  pic_object=
-	  non_pic_object=
-
-	  # Read the .lo file
-	  # If there is no directory component, then add one.
-	  case $arg in
-	  */* | *\\*) . $arg ;;
-	  *) . ./$arg ;;
-	  esac
-
-	  if test -z "$pic_object" || \
-	     test -z "$non_pic_object" ||
-	     test "$pic_object" = none && \
-	     test "$non_pic_object" = none; then
-	    $echo "$modename: cannot find name of object for \`$arg'" 1>&2
-	    exit $EXIT_FAILURE
-	  fi
-
-	  # Extract subdirectory from the argument.
-	  xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
-	  if test "X$xdir" = "X$arg"; then
-	    xdir=
- 	  else
-	    xdir="$xdir/"
-	  fi
-
-	  if test "$pic_object" != none; then
-	    # Prepend the subdirectory the object is found in.
-	    pic_object="$xdir$pic_object"
-
-	    if test "$prev" = dlfiles; then
-	      if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
-		dlfiles="$dlfiles $pic_object"
-		prev=
-		continue
-	      else
-		# If libtool objects are unsupported, then we need to preload.
-		prev=dlprefiles
-	      fi
-	    fi
-
-	    # CHECK ME:  I think I busted this.  -Ossama
-	    if test "$prev" = dlprefiles; then
-	      # Preload the old-style object.
-	      dlprefiles="$dlprefiles $pic_object"
-	      prev=
-	    fi
-
-	    # A PIC object.
-	    libobjs="$libobjs $pic_object"
-	    arg="$pic_object"
-	  fi
-
-	  # Non-PIC object.
-	  if test "$non_pic_object" != none; then
-	    # Prepend the subdirectory the object is found in.
-	    non_pic_object="$xdir$non_pic_object"
-
-	    # A standard non-PIC object
-	    non_pic_objects="$non_pic_objects $non_pic_object"
-	    if test -z "$pic_object" || test "$pic_object" = none ; then
-	      arg="$non_pic_object"
-	    fi
-	  fi
-	else
-	  # Only an error if not doing a dry-run.
-	  if test -z "$run"; then
-	    $echo "$modename: \`$arg' is not a valid libtool object" 1>&2
-	    exit $EXIT_FAILURE
-	  else
-	    # Dry-run case.
-
-	    # Extract subdirectory from the argument.
-	    xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
-	    if test "X$xdir" = "X$arg"; then
-	      xdir=
-	    else
-	      xdir="$xdir/"
-	    fi
-
-	    pic_object=`$echo "X${xdir}${objdir}/${arg}" | $Xsed -e "$lo2o"`
-	    non_pic_object=`$echo "X${xdir}${arg}" | $Xsed -e "$lo2o"`
-	    libobjs="$libobjs $pic_object"
-	    non_pic_objects="$non_pic_objects $non_pic_object"
-	  fi
-	fi
-	;;
-
-      *.$libext)
-	# An archive.
-	deplibs="$deplibs $arg"
-	old_deplibs="$old_deplibs $arg"
-	continue
-	;;
-
-      *.la)
-	# A libtool-controlled library.
-
-	if test "$prev" = dlfiles; then
-	  # This library was specified with -dlopen.
-	  dlfiles="$dlfiles $arg"
-	  prev=
-	elif test "$prev" = dlprefiles; then
-	  # The library was specified with -dlpreopen.
-	  dlprefiles="$dlprefiles $arg"
-	  prev=
-	else
-	  deplibs="$deplibs $arg"
-	fi
-	continue
-	;;
-
-      # Some other compiler argument.
-      *)
-	# Unknown arguments in both finalize_command and compile_command need
-	# to be aesthetically quoted because they are evaled later.
-	arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
-	case $arg in
-	*$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	  arg="\"$arg\""
-	  ;;
-	esac
-	;;
-      esac # arg
-
-      # Now actually substitute the argument into the commands.
-      if test -n "$arg"; then
-	compile_command="$compile_command $arg"
-	finalize_command="$finalize_command $arg"
-      fi
-    done # argument parsing loop
-
-    if test -n "$prev"; then
-      $echo "$modename: the \`$prevarg' option requires an argument" 1>&2
-      $echo "$help" 1>&2
-      exit $EXIT_FAILURE
-    fi
-
-    if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then
-      eval arg=\"$export_dynamic_flag_spec\"
-      compile_command="$compile_command $arg"
-      finalize_command="$finalize_command $arg"
-    fi
-
-    oldlibs=
-    # calculate the name of the file, without its directory
-    outputname=`$echo "X$output" | $Xsed -e 's%^.*/%%'`
-    libobjs_save="$libobjs"
-
-    if test -n "$shlibpath_var"; then
-      # get the directories listed in $shlibpath_var
-      eval shlib_search_path=\`\$echo \"X\${$shlibpath_var}\" \| \$Xsed -e \'s/:/ /g\'\`
-    else
-      shlib_search_path=
-    fi
-    eval sys_lib_search_path=\"$sys_lib_search_path_spec\"
-    eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\"
-
-    output_objdir=`$echo "X$output" | $Xsed -e 's%/[^/]*$%%'`
-    if test "X$output_objdir" = "X$output"; then
-      output_objdir="$objdir"
-    else
-      output_objdir="$output_objdir/$objdir"
-    fi
-    # Create the object directory.
-    if test ! -d "$output_objdir"; then
-      $show "$mkdir $output_objdir"
-      $run $mkdir $output_objdir
-      status=$?
-      if test "$status" -ne 0 && test ! -d "$output_objdir"; then
-	exit $status
-      fi
-    fi
-
-    # Determine the type of output
-    case $output in
-    "")
-      $echo "$modename: you must specify an output file" 1>&2
-      $echo "$help" 1>&2
-      exit $EXIT_FAILURE
-      ;;
-    *.$libext) linkmode=oldlib ;;
-    *.lo | *.$objext) linkmode=obj ;;
-    *.la) linkmode=lib ;;
-    *) linkmode=prog ;; # Anything else should be a program.
-    esac
-
-    case $host in
-    *cygwin* | *mingw* | *pw32*)
-      # don't eliminate duplications in $postdeps and $predeps
-      duplicate_compiler_generated_deps=yes
-      ;;
-    *)
-      duplicate_compiler_generated_deps=$duplicate_deps
-      ;;
-    esac
-    specialdeplibs=
-
-    libs=
-    # Find all interdependent deplibs by searching for libraries
-    # that are linked more than once (e.g. -la -lb -la)
-    for deplib in $deplibs; do
-      if test "X$duplicate_deps" = "Xyes" ; then
-	case "$libs " in
-	*" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
-	esac
-      fi
-      libs="$libs $deplib"
-    done
-
-    if test "$linkmode" = lib; then
-      libs="$predeps $libs $compiler_lib_search_path $postdeps"
-
-      # Compute libraries that are listed more than once in $predeps
-      # $postdeps and mark them as special (i.e., whose duplicates are
-      # not to be eliminated).
-      pre_post_deps=
-      if test "X$duplicate_compiler_generated_deps" = "Xyes" ; then
-	for pre_post_dep in $predeps $postdeps; do
-	  case "$pre_post_deps " in
-	  *" $pre_post_dep "*) specialdeplibs="$specialdeplibs $pre_post_deps" ;;
-	  esac
-	  pre_post_deps="$pre_post_deps $pre_post_dep"
-	done
-      fi
-      pre_post_deps=
-    fi
-
-    deplibs=
-    newdependency_libs=
-    newlib_search_path=
-    need_relink=no # whether we're linking any uninstalled libtool libraries
-    notinst_deplibs= # not-installed libtool libraries
-    notinst_path= # paths that contain not-installed libtool libraries
-    case $linkmode in
-    lib)
-	passes="conv link"
-	for file in $dlfiles $dlprefiles; do
-	  case $file in
-	  *.la) ;;
-	  *)
-	    $echo "$modename: libraries can \`-dlopen' only libtool libraries: $file" 1>&2
-	    exit $EXIT_FAILURE
-	    ;;
-	  esac
-	done
-	;;
-    prog)
-	compile_deplibs=
-	finalize_deplibs=
-	alldeplibs=no
-	newdlfiles=
-	newdlprefiles=
-	passes="conv scan dlopen dlpreopen link"
-	;;
-    *)  passes="conv"
-	;;
-    esac
-    for pass in $passes; do
-      if test "$linkmode,$pass" = "lib,link" ||
-	 test "$linkmode,$pass" = "prog,scan"; then
-	libs="$deplibs"
-	deplibs=
-      fi
-      if test "$linkmode" = prog; then
-	case $pass in
-	dlopen) libs="$dlfiles" ;;
-	dlpreopen) libs="$dlprefiles" ;;
-	link) libs="$deplibs %DEPLIBS% $dependency_libs" ;;
-	esac
-      fi
-      if test "$pass" = dlopen; then
-	# Collect dlpreopened libraries
-	save_deplibs="$deplibs"
-	deplibs=
-      fi
-      for deplib in $libs; do
-	lib=
-	found=no
-	case $deplib in
-	-mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe)
-	  if test "$linkmode,$pass" = "prog,link"; then
-	    compile_deplibs="$deplib $compile_deplibs"
-	    finalize_deplibs="$deplib $finalize_deplibs"
-	  else
-	    compiler_flags="$compiler_flags $deplib"
-	  fi
-	  continue
-	  ;;
-	-l*)
-	  if test "$linkmode" != lib && test "$linkmode" != prog; then
-	    $echo "$modename: warning: \`-l' is ignored for archives/objects" 1>&2
-	    continue
-	  fi
-	  name=`$echo "X$deplib" | $Xsed -e 's/^-l//'`
-	  for searchdir in $newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path; do
-	    for search_ext in .la $std_shrext .so .a; do
-	      # Search the libtool library
-	      lib="$searchdir/lib${name}${search_ext}"
-	      if test -f "$lib"; then
-		if test "$search_ext" = ".la"; then
-		  found=yes
-		else
-		  found=no
-		fi
-		break 2
-	      fi
-	    done
-	  done
-	  if test "$found" != yes; then
-	    # deplib doesn't seem to be a libtool library
-	    if test "$linkmode,$pass" = "prog,link"; then
-	      compile_deplibs="$deplib $compile_deplibs"
-	      finalize_deplibs="$deplib $finalize_deplibs"
-	    else
-	      deplibs="$deplib $deplibs"
-	      test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
-	    fi
-	    continue
-	  else # deplib is a libtool library
-	    # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib,
-	    # We need to do some special things here, and not later.
-	    if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
-	      case " $predeps $postdeps " in
-	      *" $deplib "*)
-		if (${SED} -e '2q' $lib |
-                    grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
-		  library_names=
-		  old_library=
-		  case $lib in
-		  */* | *\\*) . $lib ;;
-		  *) . ./$lib ;;
-		  esac
-		  for l in $old_library $library_names; do
-		    ll="$l"
-		  done
-		  if test "X$ll" = "X$old_library" ; then # only static version available
-		    found=no
-		    ladir=`$echo "X$lib" | $Xsed -e 's%/[^/]*$%%'`
-		    test "X$ladir" = "X$lib" && ladir="."
-		    lib=$ladir/$old_library
-		    if test "$linkmode,$pass" = "prog,link"; then
-		      compile_deplibs="$deplib $compile_deplibs"
-		      finalize_deplibs="$deplib $finalize_deplibs"
-		    else
-		      deplibs="$deplib $deplibs"
-		      test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
-		    fi
-		    continue
-		  fi
-		fi
-	        ;;
-	      *) ;;
-	      esac
-	    fi
-	  fi
-	  ;; # -l
-	-L*)
-	  case $linkmode in
-	  lib)
-	    deplibs="$deplib $deplibs"
-	    test "$pass" = conv && continue
-	    newdependency_libs="$deplib $newdependency_libs"
-	    newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`
-	    ;;
-	  prog)
-	    if test "$pass" = conv; then
-	      deplibs="$deplib $deplibs"
-	      continue
-	    fi
-	    if test "$pass" = scan; then
-	      deplibs="$deplib $deplibs"
-	    else
-	      compile_deplibs="$deplib $compile_deplibs"
-	      finalize_deplibs="$deplib $finalize_deplibs"
-	    fi
-	    newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`
-	    ;;
-	  *)
-	    $echo "$modename: warning: \`-L' is ignored for archives/objects" 1>&2
-	    ;;
-	  esac # linkmode
-	  continue
-	  ;; # -L
-	-R*)
-	  if test "$pass" = link; then
-	    dir=`$echo "X$deplib" | $Xsed -e 's/^-R//'`
-	    # Make sure the xrpath contains only unique directories.
-	    case "$xrpath " in
-	    *" $dir "*) ;;
-	    *) xrpath="$xrpath $dir" ;;
-	    esac
-	  fi
-	  deplibs="$deplib $deplibs"
-	  continue
-	  ;;
-	*.la) lib="$deplib" ;;
-	*.$libext)
-	  if test "$pass" = conv; then
-	    deplibs="$deplib $deplibs"
-	    continue
-	  fi
-	  case $linkmode in
-	  lib)
-	    valid_a_lib=no
-	    case $deplibs_check_method in
-	      match_pattern*)
-		set dummy $deplibs_check_method
-	        match_pattern_regex=`expr "$deplibs_check_method" : "$2 \(.*\)"`
-		if eval $echo \"$deplib\" 2>/dev/null \
-		    | $SED 10q \
-		    | $EGREP "$match_pattern_regex" > /dev/null; then
-		  valid_a_lib=yes
-		fi
-		;;
-	      pass_all)
-		valid_a_lib=yes
-		;;
-            esac
-	    if test "$valid_a_lib" != yes; then
-	      $echo
-	      $echo "*** Warning: Trying to link with static lib archive $deplib."
-	      $echo "*** I have the capability to make that library automatically link in when"
-	      $echo "*** you link to this library.  But I can only do this if you have a"
-	      $echo "*** shared version of the library, which you do not appear to have"
-	      $echo "*** because the file extensions .$libext of this argument makes me believe"
-	      $echo "*** that it is just a static archive that I should not used here."
-	    else
-	      $echo
-	      $echo "*** Warning: Linking the shared library $output against the"
-	      $echo "*** static library $deplib is not portable!"
-	      deplibs="$deplib $deplibs"
-	    fi
-	    continue
-	    ;;
-	  prog)
-	    if test "$pass" != link; then
-	      deplibs="$deplib $deplibs"
-	    else
-	      compile_deplibs="$deplib $compile_deplibs"
-	      finalize_deplibs="$deplib $finalize_deplibs"
-	    fi
-	    continue
-	    ;;
-	  esac # linkmode
-	  ;; # *.$libext
-	*.lo | *.$objext)
-	  if test "$pass" = conv; then
-	    deplibs="$deplib $deplibs"
-	  elif test "$linkmode" = prog; then
-	    if test "$pass" = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then
-	      # If there is no dlopen support or we're linking statically,
-	      # we need to preload.
-	      newdlprefiles="$newdlprefiles $deplib"
-	      compile_deplibs="$deplib $compile_deplibs"
-	      finalize_deplibs="$deplib $finalize_deplibs"
-	    else
-	      newdlfiles="$newdlfiles $deplib"
-	    fi
-	  fi
-	  continue
-	  ;;
-	%DEPLIBS%)
-	  alldeplibs=yes
-	  continue
-	  ;;
-	esac # case $deplib
-	if test "$found" = yes || test -f "$lib"; then :
-	else
-	  $echo "$modename: cannot find the library \`$lib'" 1>&2
-	  exit $EXIT_FAILURE
-	fi
-
-	# Check to see that this really is a libtool archive.
-	if (${SED} -e '2q' $lib | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
-	else
-	  $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
-	  exit $EXIT_FAILURE
-	fi
-
-	ladir=`$echo "X$lib" | $Xsed -e 's%/[^/]*$%%'`
-	test "X$ladir" = "X$lib" && ladir="."
-
-	dlname=
-	dlopen=
-	dlpreopen=
-	libdir=
-	library_names=
-	old_library=
-	# If the library was installed with an old release of libtool,
-	# it will not redefine variables installed, or shouldnotlink
-	installed=yes
-	shouldnotlink=no
-	avoidtemprpath=
-
-
-	# Read the .la file
-	case $lib in
-	*/* | *\\*) . $lib ;;
-	*) . ./$lib ;;
-	esac
-
-	if test "$linkmode,$pass" = "lib,link" ||
-	   test "$linkmode,$pass" = "prog,scan" ||
-	   { test "$linkmode" != prog && test "$linkmode" != lib; }; then
-	  test -n "$dlopen" && dlfiles="$dlfiles $dlopen"
-	  test -n "$dlpreopen" && dlprefiles="$dlprefiles $dlpreopen"
-	fi
-
-	if test "$pass" = conv; then
-	  # Only check for convenience libraries
-	  deplibs="$lib $deplibs"
-	  if test -z "$libdir"; then
-	    if test -z "$old_library"; then
-	      $echo "$modename: cannot find name of link library for \`$lib'" 1>&2
-	      exit $EXIT_FAILURE
-	    fi
-	    # It is a libtool convenience library, so add in its objects.
-	    convenience="$convenience $ladir/$objdir/$old_library"
-	    old_convenience="$old_convenience $ladir/$objdir/$old_library"
-	    tmp_libs=
-	    for deplib in $dependency_libs; do
-	      deplibs="$deplib $deplibs"
-              if test "X$duplicate_deps" = "Xyes" ; then
-	        case "$tmp_libs " in
-	        *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
-	        esac
-              fi
-	      tmp_libs="$tmp_libs $deplib"
-	    done
-	  elif test "$linkmode" != prog && test "$linkmode" != lib; then
-	    $echo "$modename: \`$lib' is not a convenience library" 1>&2
-	    exit $EXIT_FAILURE
-	  fi
-	  continue
-	fi # $pass = conv
-
-
-	# Get the name of the library we link against.
-	linklib=
-	for l in $old_library $library_names; do
-	  linklib="$l"
-	done
-	if test -z "$linklib"; then
-	  $echo "$modename: cannot find name of link library for \`$lib'" 1>&2
-	  exit $EXIT_FAILURE
-	fi
-
-	# This library was specified with -dlopen.
-	if test "$pass" = dlopen; then
-	  if test -z "$libdir"; then
-	    $echo "$modename: cannot -dlopen a convenience library: \`$lib'" 1>&2
-	    exit $EXIT_FAILURE
-	  fi
-	  if test -z "$dlname" ||
-	     test "$dlopen_support" != yes ||
-	     test "$build_libtool_libs" = no; then
-	    # If there is no dlname, no dlopen support or we're linking
-	    # statically, we need to preload.  We also need to preload any
-	    # dependent libraries so libltdl's deplib preloader doesn't
-	    # bomb out in the load deplibs phase.
-	    dlprefiles="$dlprefiles $lib $dependency_libs"
-	  else
-	    newdlfiles="$newdlfiles $lib"
-	  fi
-	  continue
-	fi # $pass = dlopen
-
-	# We need an absolute path.
-	case $ladir in
-	[\\/]* | [A-Za-z]:[\\/]*) abs_ladir="$ladir" ;;
-	*)
-	  abs_ladir=`cd "$ladir" && pwd`
-	  if test -z "$abs_ladir"; then
-	    $echo "$modename: warning: cannot determine absolute directory name of \`$ladir'" 1>&2
-	    $echo "$modename: passing it literally to the linker, although it might fail" 1>&2
-	    abs_ladir="$ladir"
-	  fi
-	  ;;
-	esac
-	laname=`$echo "X$lib" | $Xsed -e 's%^.*/%%'`
-
-	# Find the relevant object directory and library name.
-	if test "X$installed" = Xyes; then
-	  if test ! -f "$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then
-	    $echo "$modename: warning: library \`$lib' was moved." 1>&2
-	    dir="$ladir"
-	    absdir="$abs_ladir"
-	    libdir="$abs_ladir"
-	  else
-	    dir="$libdir"
-	    absdir="$libdir"
-	  fi
-	  test "X$hardcode_automatic" = Xyes && avoidtemprpath=yes
-	else
-	  if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then
-	    dir="$ladir"
-	    absdir="$abs_ladir"
-	    # Remove this search path later
-	    notinst_path="$notinst_path $abs_ladir"
-	  else
-	    dir="$ladir/$objdir"
-	    absdir="$abs_ladir/$objdir"
-	    # Remove this search path later
-	    notinst_path="$notinst_path $abs_ladir"
-	  fi
-	fi # $installed = yes
-	name=`$echo "X$laname" | $Xsed -e 's/\.la$//' -e 's/^lib//'`
-
-	# This library was specified with -dlpreopen.
-	if test "$pass" = dlpreopen; then
-	  if test -z "$libdir"; then
-	    $echo "$modename: cannot -dlpreopen a convenience library: \`$lib'" 1>&2
-	    exit $EXIT_FAILURE
-	  fi
-	  # Prefer using a static library (so that no silly _DYNAMIC symbols
-	  # are required to link).
-	  if test -n "$old_library"; then
-	    newdlprefiles="$newdlprefiles $dir/$old_library"
-	  # Otherwise, use the dlname, so that lt_dlopen finds it.
-	  elif test -n "$dlname"; then
-	    newdlprefiles="$newdlprefiles $dir/$dlname"
-	  else
-	    newdlprefiles="$newdlprefiles $dir/$linklib"
-	  fi
-	fi # $pass = dlpreopen
-
-	if test -z "$libdir"; then
-	  # Link the convenience library
-	  if test "$linkmode" = lib; then
-	    deplibs="$dir/$old_library $deplibs"
-	  elif test "$linkmode,$pass" = "prog,link"; then
-	    compile_deplibs="$dir/$old_library $compile_deplibs"
-	    finalize_deplibs="$dir/$old_library $finalize_deplibs"
-	  else
-	    deplibs="$lib $deplibs" # used for prog,scan pass
-	  fi
-	  continue
-	fi
-
-
-	if test "$linkmode" = prog && test "$pass" != link; then
-	  newlib_search_path="$newlib_search_path $ladir"
-	  deplibs="$lib $deplibs"
-
-	  linkalldeplibs=no
-	  if test "$link_all_deplibs" != no || test -z "$library_names" ||
-	     test "$build_libtool_libs" = no; then
-	    linkalldeplibs=yes
-	  fi
-
-	  tmp_libs=
-	  for deplib in $dependency_libs; do
-	    case $deplib in
-	    -L*) newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`;; ### testsuite: skip nested quoting test
-	    esac
-	    # Need to link against all dependency_libs?
-	    if test "$linkalldeplibs" = yes; then
-	      deplibs="$deplib $deplibs"
-	    else
-	      # Need to hardcode shared library paths
-	      # or/and link against static libraries
-	      newdependency_libs="$deplib $newdependency_libs"
-	    fi
-	    if test "X$duplicate_deps" = "Xyes" ; then
-	      case "$tmp_libs " in
-	      *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
-	      esac
-	    fi
-	    tmp_libs="$tmp_libs $deplib"
-	  done # for deplib
-	  continue
-	fi # $linkmode = prog...
-
-	if test "$linkmode,$pass" = "prog,link"; then
-	  if test -n "$library_names" &&
-	     { test "$prefer_static_libs" = no || test -z "$old_library"; }; then
-	    # We need to hardcode the library path
-	    if test -n "$shlibpath_var" && test -z "$avoidtemprpath" ; then
-	      # Make sure the rpath contains only unique directories.
-	      case "$temp_rpath " in
-	      *" $dir "*) ;;
-	      *" $absdir "*) ;;
-	      *) temp_rpath="$temp_rpath $dir" ;;
-	      esac
-	    fi
-
-	    # Hardcode the library path.
-	    # Skip directories that are in the system default run-time
-	    # search path.
-	    case " $sys_lib_dlsearch_path " in
-	    *" $absdir "*) ;;
-	    *)
-	      case "$compile_rpath " in
-	      *" $absdir "*) ;;
-	      *) compile_rpath="$compile_rpath $absdir"
-	      esac
-	      ;;
-	    esac
-	    case " $sys_lib_dlsearch_path " in
-	    *" $libdir "*) ;;
-	    *)
-	      case "$finalize_rpath " in
-	      *" $libdir "*) ;;
-	      *) finalize_rpath="$finalize_rpath $libdir"
-	      esac
-	      ;;
-	    esac
-	  fi # $linkmode,$pass = prog,link...
-
-	  if test "$alldeplibs" = yes &&
-	     { test "$deplibs_check_method" = pass_all ||
-	       { test "$build_libtool_libs" = yes &&
-		 test -n "$library_names"; }; }; then
-	    # We only need to search for static libraries
-	    continue
-	  fi
-	fi
-
-	link_static=no # Whether the deplib will be linked statically
-	if test -n "$library_names" &&
-	   { test "$prefer_static_libs" = no || test -z "$old_library"; }; then
-	  if test "$installed" = no; then
-	    notinst_deplibs="$notinst_deplibs $lib"
-	    need_relink=yes
-	  fi
-	  # This is a shared library
-
-	  # Warn about portability, can't link against -module's on
-	  # some systems (darwin)
-	  if test "$shouldnotlink" = yes && test "$pass" = link ; then
-	    $echo
-	    if test "$linkmode" = prog; then
-	      $echo "*** Warning: Linking the executable $output against the loadable module"
-	    else
-	      $echo "*** Warning: Linking the shared library $output against the loadable module"
-	    fi
-	    $echo "*** $linklib is not portable!"
-	  fi
-	  if test "$linkmode" = lib &&
-	     test "$hardcode_into_libs" = yes; then
-	    # Hardcode the library path.
-	    # Skip directories that are in the system default run-time
-	    # search path.
-	    case " $sys_lib_dlsearch_path " in
-	    *" $absdir "*) ;;
-	    *)
-	      case "$compile_rpath " in
-	      *" $absdir "*) ;;
-	      *) compile_rpath="$compile_rpath $absdir"
-	      esac
-	      ;;
-	    esac
-	    case " $sys_lib_dlsearch_path " in
-	    *" $libdir "*) ;;
-	    *)
-	      case "$finalize_rpath " in
-	      *" $libdir "*) ;;
-	      *) finalize_rpath="$finalize_rpath $libdir"
-	      esac
-	      ;;
-	    esac
-	  fi
-
-	  if test -n "$old_archive_from_expsyms_cmds"; then
-	    # figure out the soname
-	    set dummy $library_names
-	    realname="$2"
-	    shift; shift
-	    libname=`eval \\$echo \"$libname_spec\"`
-	    # use dlname if we got it. it's perfectly good, no?
-	    if test -n "$dlname"; then
-	      soname="$dlname"
-	    elif test -n "$soname_spec"; then
-	      # bleh windows
-	      case $host in
-	      *cygwin* | mingw*)
-		major=`expr $current - $age`
-		versuffix="-$major"
-		;;
-	      esac
-	      eval soname=\"$soname_spec\"
-	    else
-	      soname="$realname"
-	    fi
-
-	    # Make a new name for the extract_expsyms_cmds to use
-	    soroot="$soname"
-	    soname=`$echo $soroot | ${SED} -e 's/^.*\///'`
-	    newlib="libimp-`$echo $soname | ${SED} 's/^lib//;s/\.dll$//'`.a"
-
-	    # If the library has no export list, then create one now
-	    if test -f "$output_objdir/$soname-def"; then :
-	    else
-	      $show "extracting exported symbol list from \`$soname'"
-	      save_ifs="$IFS"; IFS='~'
-	      cmds=$extract_expsyms_cmds
-	      for cmd in $cmds; do
-		IFS="$save_ifs"
-		eval cmd=\"$cmd\"
-		$show "$cmd"
-		$run eval "$cmd" || exit $?
-	      done
-	      IFS="$save_ifs"
-	    fi
-
-	    # Create $newlib
-	    if test -f "$output_objdir/$newlib"; then :; else
-	      $show "generating import library for \`$soname'"
-	      save_ifs="$IFS"; IFS='~'
-	      cmds=$old_archive_from_expsyms_cmds
-	      for cmd in $cmds; do
-		IFS="$save_ifs"
-		eval cmd=\"$cmd\"
-		$show "$cmd"
-		$run eval "$cmd" || exit $?
-	      done
-	      IFS="$save_ifs"
-	    fi
-	    # make sure the library variables are pointing to the new library
-	    dir=$output_objdir
-	    linklib=$newlib
-	  fi # test -n "$old_archive_from_expsyms_cmds"
-
-	  if test "$linkmode" = prog || test "$mode" != relink; then
-	    add_shlibpath=
-	    add_dir=
-	    add=
-	    lib_linked=yes
-	    case $hardcode_action in
-	    immediate | unsupported)
-	      if test "$hardcode_direct" = no; then
-		add="$dir/$linklib"
-		case $host in
-		  *-*-sco3.2v5* ) add_dir="-L$dir" ;;
-		  *-*-darwin* )
-		    # if the lib is a module then we can not link against
-		    # it, someone is ignoring the new warnings I added
-		    if /usr/bin/file -L $add 2> /dev/null | $EGREP "bundle" >/dev/null ; then
-		      $echo "** Warning, lib $linklib is a module, not a shared library"
-		      if test -z "$old_library" ; then
-		        $echo
-		        $echo "** And there doesn't seem to be a static archive available"
-		        $echo "** The link will probably fail, sorry"
-		      else
-		        add="$dir/$old_library"
-		      fi
-		    fi
-		esac
-	      elif test "$hardcode_minus_L" = no; then
-		case $host in
-		*-*-sunos*) add_shlibpath="$dir" ;;
-		esac
-		add_dir="-L$dir"
-		add="-l$name"
-	      elif test "$hardcode_shlibpath_var" = no; then
-		add_shlibpath="$dir"
-		add="-l$name"
-	      else
-		lib_linked=no
-	      fi
-	      ;;
-	    relink)
-	      if test "$hardcode_direct" = yes; then
-		add="$dir/$linklib"
-	      elif test "$hardcode_minus_L" = yes; then
-		add_dir="-L$dir"
-		# Try looking first in the location we're being installed to.
-		if test -n "$inst_prefix_dir"; then
-		  case "$libdir" in
-		    [\\/]*)
-		      add_dir="$add_dir -L$inst_prefix_dir$libdir"
-		      ;;
-		  esac
-		fi
-		add="-l$name"
-	      elif test "$hardcode_shlibpath_var" = yes; then
-		add_shlibpath="$dir"
-		add="-l$name"
-	      else
-		lib_linked=no
-	      fi
-	      ;;
-	    *) lib_linked=no ;;
-	    esac
-
-	    if test "$lib_linked" != yes; then
-	      $echo "$modename: configuration error: unsupported hardcode properties"
-	      exit $EXIT_FAILURE
-	    fi
-
-	    if test -n "$add_shlibpath"; then
-	      case :$compile_shlibpath: in
-	      *":$add_shlibpath:"*) ;;
-	      *) compile_shlibpath="$compile_shlibpath$add_shlibpath:" ;;
-	      esac
-	    fi
-	    if test "$linkmode" = prog; then
-	      test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs"
-	      test -n "$add" && compile_deplibs="$add $compile_deplibs"
-	    else
-	      test -n "$add_dir" && deplibs="$add_dir $deplibs"
-	      test -n "$add" && deplibs="$add $deplibs"
-	      if test "$hardcode_direct" != yes && \
-		 test "$hardcode_minus_L" != yes && \
-		 test "$hardcode_shlibpath_var" = yes; then
-		case :$finalize_shlibpath: in
-		*":$libdir:"*) ;;
-		*) finalize_shlibpath="$finalize_shlibpath$libdir:" ;;
-		esac
-	      fi
-	    fi
-	  fi
-
-	  if test "$linkmode" = prog || test "$mode" = relink; then
-	    add_shlibpath=
-	    add_dir=
-	    add=
-	    # Finalize command for both is simple: just hardcode it.
-	    if test "$hardcode_direct" = yes; then
-	      add="$libdir/$linklib"
-	    elif test "$hardcode_minus_L" = yes; then
-	      add_dir="-L$libdir"
-	      add="-l$name"
-	    elif test "$hardcode_shlibpath_var" = yes; then
-	      case :$finalize_shlibpath: in
-	      *":$libdir:"*) ;;
-	      *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;;
-	      esac
-	      add="-l$name"
-	    elif test "$hardcode_automatic" = yes; then
-	      if test -n "$inst_prefix_dir" &&
-		 test -f "$inst_prefix_dir$libdir/$linklib" ; then
-	        add="$inst_prefix_dir$libdir/$linklib"
-	      else
-	        add="$libdir/$linklib"
-	      fi
-	    else
-	      # We cannot seem to hardcode it, guess we'll fake it.
-	      add_dir="-L$libdir"
-	      # Try looking first in the location we're being installed to.
-	      if test -n "$inst_prefix_dir"; then
-		case "$libdir" in
-		  [\\/]*)
-		    add_dir="$add_dir -L$inst_prefix_dir$libdir"
-		    ;;
-		esac
-	      fi
-	      add="-l$name"
-	    fi
-
-	    if test "$linkmode" = prog; then
-	      test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs"
-	      test -n "$add" && finalize_deplibs="$add $finalize_deplibs"
-	    else
-	      test -n "$add_dir" && deplibs="$add_dir $deplibs"
-	      test -n "$add" && deplibs="$add $deplibs"
-	    fi
-	  fi
-	elif test "$linkmode" = prog; then
-	  # Here we assume that one of hardcode_direct or hardcode_minus_L
-	  # is not unsupported.  This is valid on all known static and
-	  # shared platforms.
-	  if test "$hardcode_direct" != unsupported; then
-	    test -n "$old_library" && linklib="$old_library"
-	    compile_deplibs="$dir/$linklib $compile_deplibs"
-	    finalize_deplibs="$dir/$linklib $finalize_deplibs"
-	  else
-	    compile_deplibs="-l$name -L$dir $compile_deplibs"
-	    finalize_deplibs="-l$name -L$dir $finalize_deplibs"
-	  fi
-	elif test "$build_libtool_libs" = yes; then
-	  # Not a shared library
-	  if test "$deplibs_check_method" != pass_all; then
-	    # We're trying link a shared library against a static one
-	    # but the system doesn't support it.
-
-	    # Just print a warning and add the library to dependency_libs so
-	    # that the program can be linked against the static library.
-	    $echo
-	    $echo "*** Warning: This system can not link to static lib archive $lib."
-	    $echo "*** I have the capability to make that library automatically link in when"
-	    $echo "*** you link to this library.  But I can only do this if you have a"
-	    $echo "*** shared version of the library, which you do not appear to have."
-	    if test "$module" = yes; then
-	      $echo "*** But as you try to build a module library, libtool will still create "
-	      $echo "*** a static module, that should work as long as the dlopening application"
-	      $echo "*** is linked with the -dlopen flag to resolve symbols at runtime."
-	      if test -z "$global_symbol_pipe"; then
-		$echo
-		$echo "*** However, this would only work if libtool was able to extract symbol"
-		$echo "*** lists from a program, using \`nm' or equivalent, but libtool could"
-		$echo "*** not find such a program.  So, this module is probably useless."
-		$echo "*** \`nm' from GNU binutils and a full rebuild may help."
-	      fi
-	      if test "$build_old_libs" = no; then
-		build_libtool_libs=module
-		build_old_libs=yes
-	      else
-		build_libtool_libs=no
-	      fi
-	    fi
-	  else
-	    convenience="$convenience $dir/$old_library"
-	    old_convenience="$old_convenience $dir/$old_library"
-	    deplibs="$dir/$old_library $deplibs"
-	    link_static=yes
-	  fi
-	fi # link shared/static library?
-
-	if test "$linkmode" = lib; then
-	  if test -n "$dependency_libs" &&
-	     { test "$hardcode_into_libs" != yes ||
-	       test "$build_old_libs" = yes ||
-	       test "$link_static" = yes; }; then
-	    # Extract -R from dependency_libs
-	    temp_deplibs=
-	    for libdir in $dependency_libs; do
-	      case $libdir in
-	      -R*) temp_xrpath=`$echo "X$libdir" | $Xsed -e 's/^-R//'`
-		   case " $xrpath " in
-		   *" $temp_xrpath "*) ;;
-		   *) xrpath="$xrpath $temp_xrpath";;
-		   esac;;
-	      *) temp_deplibs="$temp_deplibs $libdir";;
-	      esac
-	    done
-	    dependency_libs="$temp_deplibs"
-	  fi
-
-	  newlib_search_path="$newlib_search_path $absdir"
-	  # Link against this library
-	  test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs"
-	  # ... and its dependency_libs
-	  tmp_libs=
-	  for deplib in $dependency_libs; do
-	    newdependency_libs="$deplib $newdependency_libs"
-	    if test "X$duplicate_deps" = "Xyes" ; then
-	      case "$tmp_libs " in
-	      *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
-	      esac
-	    fi
-	    tmp_libs="$tmp_libs $deplib"
-	  done
-
-	  if test "$link_all_deplibs" != no; then
-	    # Add the search paths of all dependency libraries
-	    for deplib in $dependency_libs; do
-	      case $deplib in
-	      -L*) path="$deplib" ;;
-	      *.la)
-		dir=`$echo "X$deplib" | $Xsed -e 's%/[^/]*$%%'`
-		test "X$dir" = "X$deplib" && dir="."
-		# We need an absolute path.
-		case $dir in
-		[\\/]* | [A-Za-z]:[\\/]*) absdir="$dir" ;;
-		*)
-		  absdir=`cd "$dir" && pwd`
-		  if test -z "$absdir"; then
-		    $echo "$modename: warning: cannot determine absolute directory name of \`$dir'" 1>&2
-		    absdir="$dir"
-		  fi
-		  ;;
-		esac
-		if grep "^installed=no" $deplib > /dev/null; then
-		  path="$absdir/$objdir"
-		else
-		  eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
-		  if test -z "$libdir"; then
-		    $echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2
-		    exit $EXIT_FAILURE
-		  fi
-		  if test "$absdir" != "$libdir"; then
-		    $echo "$modename: warning: \`$deplib' seems to be moved" 1>&2
-		  fi
-		  path="$absdir"
-		fi
-		depdepl=
-		case $host in
-		*-*-darwin*)
-		  # we do not want to link against static libs,
-		  # but need to link against shared
-		  eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib`
-		  if test -n "$deplibrary_names" ; then
-		    for tmp in $deplibrary_names ; do
-		      depdepl=$tmp
-		    done
-		    if test -f "$path/$depdepl" ; then
-		      depdepl="$path/$depdepl"
-		    fi
-		    # do not add paths which are already there
-		    case " $newlib_search_path " in
-		    *" $path "*) ;;
-		    *) newlib_search_path="$newlib_search_path $path";;
-		    esac
-		  fi
-		  path=""
-		  ;;
-		*)
-		  path="-L$path"
-		  ;;
-		esac
-		;;
-	      -l*)
-		case $host in
-		*-*-darwin*)
-		  # Again, we only want to link against shared libraries
-		  eval tmp_libs=`$echo "X$deplib" | $Xsed -e "s,^\-l,,"`
-		  for tmp in $newlib_search_path ; do
-		    if test -f "$tmp/lib$tmp_libs.dylib" ; then
-		      eval depdepl="$tmp/lib$tmp_libs.dylib"
-		      break
-		    fi
-		  done
-		  path=""
-		  ;;
-		*) continue ;;
-		esac
-		;;
-	      *) continue ;;
-	      esac
-	      case " $deplibs " in
-	      *" $path "*) ;;
-	      *) deplibs="$path $deplibs" ;;
-	      esac
-	      case " $deplibs " in
-	      *" $depdepl "*) ;;
-	      *) deplibs="$depdepl $deplibs" ;;
-	      esac
-	    done
-	  fi # link_all_deplibs != no
-	fi # linkmode = lib
-      done # for deplib in $libs
-      dependency_libs="$newdependency_libs"
-      if test "$pass" = dlpreopen; then
-	# Link the dlpreopened libraries before other libraries
-	for deplib in $save_deplibs; do
-	  deplibs="$deplib $deplibs"
-	done
-      fi
-      if test "$pass" != dlopen; then
-	if test "$pass" != conv; then
-	  # Make sure lib_search_path contains only unique directories.
-	  lib_search_path=
-	  for dir in $newlib_search_path; do
-	    case "$lib_search_path " in
-	    *" $dir "*) ;;
-	    *) lib_search_path="$lib_search_path $dir" ;;
-	    esac
-	  done
-	  newlib_search_path=
-	fi
-
-	if test "$linkmode,$pass" != "prog,link"; then
-	  vars="deplibs"
-	else
-	  vars="compile_deplibs finalize_deplibs"
-	fi
-	for var in $vars dependency_libs; do
-	  # Add libraries to $var in reverse order
-	  eval tmp_libs=\"\$$var\"
-	  new_libs=
-	  for deplib in $tmp_libs; do
-	    # FIXME: Pedantically, this is the right thing to do, so
-	    #        that some nasty dependency loop isn't accidentally
-	    #        broken:
-	    #new_libs="$deplib $new_libs"
-	    # Pragmatically, this seems to cause very few problems in
-	    # practice:
-	    case $deplib in
-	    -L*) new_libs="$deplib $new_libs" ;;
-	    -R*) ;;
-	    *)
-	      # And here is the reason: when a library appears more
-	      # than once as an explicit dependence of a library, or
-	      # is implicitly linked in more than once by the
-	      # compiler, it is considered special, and multiple
-	      # occurrences thereof are not removed.  Compare this
-	      # with having the same library being listed as a
-	      # dependency of multiple other libraries: in this case,
-	      # we know (pedantically, we assume) the library does not
-	      # need to be listed more than once, so we keep only the
-	      # last copy.  This is not always right, but it is rare
-	      # enough that we require users that really mean to play
-	      # such unportable linking tricks to link the library
-	      # using -Wl,-lname, so that libtool does not consider it
-	      # for duplicate removal.
-	      case " $specialdeplibs " in
-	      *" $deplib "*) new_libs="$deplib $new_libs" ;;
-	      *)
-		case " $new_libs " in
-		*" $deplib "*) ;;
-		*) new_libs="$deplib $new_libs" ;;
-		esac
-		;;
-	      esac
-	      ;;
-	    esac
-	  done
-	  tmp_libs=
-	  for deplib in $new_libs; do
-	    case $deplib in
-	    -L*)
-	      case " $tmp_libs " in
-	      *" $deplib "*) ;;
-	      *) tmp_libs="$tmp_libs $deplib" ;;
-	      esac
-	      ;;
-	    *) tmp_libs="$tmp_libs $deplib" ;;
-	    esac
-	  done
-	  eval $var=\"$tmp_libs\"
-	done # for var
-      fi
-      # Last step: remove runtime libs from dependency_libs
-      # (they stay in deplibs)
-      tmp_libs=
-      for i in $dependency_libs ; do
-	case " $predeps $postdeps $compiler_lib_search_path " in
-	*" $i "*)
-	  i=""
-	  ;;
-	esac
-	if test -n "$i" ; then
-	  tmp_libs="$tmp_libs $i"
-	fi
-      done
-      dependency_libs=$tmp_libs
-    done # for pass
-    if test "$linkmode" = prog; then
-      dlfiles="$newdlfiles"
-      dlprefiles="$newdlprefiles"
-    fi
-
-    case $linkmode in
-    oldlib)
-      if test -n "$deplibs"; then
-	$echo "$modename: warning: \`-l' and \`-L' are ignored for archives" 1>&2
-      fi
-
-      if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
-	$echo "$modename: warning: \`-dlopen' is ignored for archives" 1>&2
-      fi
-
-      if test -n "$rpath"; then
-	$echo "$modename: warning: \`-rpath' is ignored for archives" 1>&2
-      fi
-
-      if test -n "$xrpath"; then
-	$echo "$modename: warning: \`-R' is ignored for archives" 1>&2
-      fi
-
-      if test -n "$vinfo"; then
-	$echo "$modename: warning: \`-version-info/-version-number' is ignored for archives" 1>&2
-      fi
-
-      if test -n "$release"; then
-	$echo "$modename: warning: \`-release' is ignored for archives" 1>&2
-      fi
-
-      if test -n "$export_symbols" || test -n "$export_symbols_regex"; then
-	$echo "$modename: warning: \`-export-symbols' is ignored for archives" 1>&2
-      fi
-
-      # Now set the variables for building old libraries.
-      build_libtool_libs=no
-      oldlibs="$output"
-      objs="$objs$old_deplibs"
-      ;;
-
-    lib)
-      # Make sure we only generate libraries of the form `libNAME.la'.
-      case $outputname in
-      lib*)
-	name=`$echo "X$outputname" | $Xsed -e 's/\.la$//' -e 's/^lib//'`
-	eval shared_ext=\"$shrext_cmds\"
-	eval libname=\"$libname_spec\"
-	;;
-      *)
-	if test "$module" = no; then
-	  $echo "$modename: libtool library \`$output' must begin with \`lib'" 1>&2
-	  $echo "$help" 1>&2
-	  exit $EXIT_FAILURE
-	fi
-	if test "$need_lib_prefix" != no; then
-	  # Add the "lib" prefix for modules if required
-	  name=`$echo "X$outputname" | $Xsed -e 's/\.la$//'`
-	  eval shared_ext=\"$shrext_cmds\"
-	  eval libname=\"$libname_spec\"
-	else
-	  libname=`$echo "X$outputname" | $Xsed -e 's/\.la$//'`
-	fi
-	;;
-      esac
-
-      if test -n "$objs"; then
-	if test "$deplibs_check_method" != pass_all; then
-	  $echo "$modename: cannot build libtool library \`$output' from non-libtool objects on this host:$objs" 2>&1
-	  exit $EXIT_FAILURE
-	else
-	  $echo
-	  $echo "*** Warning: Linking the shared library $output against the non-libtool"
-	  $echo "*** objects $objs is not portable!"
-	  libobjs="$libobjs $objs"
-	fi
-      fi
-
-      if test "$dlself" != no; then
-	$echo "$modename: warning: \`-dlopen self' is ignored for libtool libraries" 1>&2
-      fi
-
-      set dummy $rpath
-      if test "$#" -gt 2; then
-	$echo "$modename: warning: ignoring multiple \`-rpath's for a libtool library" 1>&2
-      fi
-      install_libdir="$2"
-
-      oldlibs=
-      if test -z "$rpath"; then
-	if test "$build_libtool_libs" = yes; then
-	  # Building a libtool convenience library.
-	  # Some compilers have problems with a `.al' extension so
-	  # convenience libraries should have the same extension an
-	  # archive normally would.
-	  oldlibs="$output_objdir/$libname.$libext $oldlibs"
-	  build_libtool_libs=convenience
-	  build_old_libs=yes
-	fi
-
-	if test -n "$vinfo"; then
-	  $echo "$modename: warning: \`-version-info/-version-number' is ignored for convenience libraries" 1>&2
-	fi
-
-	if test -n "$release"; then
-	  $echo "$modename: warning: \`-release' is ignored for convenience libraries" 1>&2
-	fi
-      else
-
-	# Parse the version information argument.
-	save_ifs="$IFS"; IFS=':'
-	set dummy $vinfo 0 0 0
-	IFS="$save_ifs"
-
-	if test -n "$8"; then
-	  $echo "$modename: too many parameters to \`-version-info'" 1>&2
-	  $echo "$help" 1>&2
-	  exit $EXIT_FAILURE
-	fi
-
-	# convert absolute version numbers to libtool ages
-	# this retains compatibility with .la files and attempts
-	# to make the code below a bit more comprehensible
-
-	case $vinfo_number in
-	yes)
-	  number_major="$2"
-	  number_minor="$3"
-	  number_revision="$4"
-	  #
-	  # There are really only two kinds -- those that
-	  # use the current revision as the major version
-	  # and those that subtract age and use age as
-	  # a minor version.  But, then there is irix
-	  # which has an extra 1 added just for fun
-	  #
-	  case $version_type in
-	  darwin|linux|osf|windows)
-	    current=`expr $number_major + $number_minor`
-	    age="$number_minor"
-	    revision="$number_revision"
-	    ;;
-	  freebsd-aout|freebsd-elf|sunos)
-	    current="$number_major"
-	    revision="$number_minor"
-	    age="0"
-	    ;;
-	  irix|nonstopux)
-	    current=`expr $number_major + $number_minor - 1`
-	    age="$number_minor"
-	    revision="$number_minor"
-	    ;;
-	  esac
-	  ;;
-	no)
-	  current="$2"
-	  revision="$3"
-	  age="$4"
-	  ;;
-	esac
-
-	# Check that each of the things are valid numbers.
-	case $current in
-	0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
-	*)
-	  $echo "$modename: CURRENT \`$current' must be a nonnegative integer" 1>&2
-	  $echo "$modename: \`$vinfo' is not valid version information" 1>&2
-	  exit $EXIT_FAILURE
-	  ;;
-	esac
-
-	case $revision in
-	0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
-	*)
-	  $echo "$modename: REVISION \`$revision' must be a nonnegative integer" 1>&2
-	  $echo "$modename: \`$vinfo' is not valid version information" 1>&2
-	  exit $EXIT_FAILURE
-	  ;;
-	esac
-
-	case $age in
-	0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
-	*)
-	  $echo "$modename: AGE \`$age' must be a nonnegative integer" 1>&2
-	  $echo "$modename: \`$vinfo' is not valid version information" 1>&2
-	  exit $EXIT_FAILURE
-	  ;;
-	esac
-
-	if test "$age" -gt "$current"; then
-	  $echo "$modename: AGE \`$age' is greater than the current interface number \`$current'" 1>&2
-	  $echo "$modename: \`$vinfo' is not valid version information" 1>&2
-	  exit $EXIT_FAILURE
-	fi
-
-	# Calculate the version variables.
-	major=
-	versuffix=
-	verstring=
-	case $version_type in
-	none) ;;
-
-	darwin)
-	  # Like Linux, but with the current version available in
-	  # verstring for coding it into the library header
-	  major=.`expr $current - $age`
-	  versuffix="$major.$age.$revision"
-	  # Darwin ld doesn't like 0 for these options...
-	  minor_current=`expr $current + 1`
-	  verstring="${wl}-compatibility_version ${wl}$minor_current ${wl}-current_version ${wl}$minor_current.$revision"
-	  ;;
-
-	freebsd-aout)
-	  major=".$current"
-	  versuffix=".$current.$revision";
-	  ;;
-
-	freebsd-elf)
-	  major=".$current"
-	  versuffix=".$current";
-	  ;;
-
-	irix | nonstopux)
-	  major=`expr $current - $age + 1`
-
-	  case $version_type in
-	    nonstopux) verstring_prefix=nonstopux ;;
-	    *)         verstring_prefix=sgi ;;
-	  esac
-	  verstring="$verstring_prefix$major.$revision"
-
-	  # Add in all the interfaces that we are compatible with.
-	  loop=$revision
-	  while test "$loop" -ne 0; do
-	    iface=`expr $revision - $loop`
-	    loop=`expr $loop - 1`
-	    verstring="$verstring_prefix$major.$iface:$verstring"
-	  done
-
-	  # Before this point, $major must not contain `.'.
-	  major=.$major
-	  versuffix="$major.$revision"
-	  ;;
-
-	linux)
-	  major=.`expr $current - $age`
-	  versuffix="$major.$age.$revision"
-	  ;;
-
-	osf)
-	  major=.`expr $current - $age`
-	  versuffix=".$current.$age.$revision"
-	  verstring="$current.$age.$revision"
-
-	  # Add in all the interfaces that we are compatible with.
-	  loop=$age
-	  while test "$loop" -ne 0; do
-	    iface=`expr $current - $loop`
-	    loop=`expr $loop - 1`
-	    verstring="$verstring:${iface}.0"
-	  done
-
-	  # Make executables depend on our current version.
-	  verstring="$verstring:${current}.0"
-	  ;;
-
-	sunos)
-	  major=".$current"
-	  versuffix=".$current.$revision"
-	  ;;
-
-	windows)
-	  # Use '-' rather than '.', since we only want one
-	  # extension on DOS 8.3 filesystems.
-	  major=`expr $current - $age`
-	  versuffix="-$major"
-	  ;;
-
-	*)
-	  $echo "$modename: unknown library version type \`$version_type'" 1>&2
-	  $echo "Fatal configuration error.  See the $PACKAGE docs for more information." 1>&2
-	  exit $EXIT_FAILURE
-	  ;;
-	esac
-
-	# Clear the version info if we defaulted, and they specified a release.
-	if test -z "$vinfo" && test -n "$release"; then
-	  major=
-	  case $version_type in
-	  darwin)
-	    # we can't check for "0.0" in archive_cmds due to quoting
-	    # problems, so we reset it completely
-	    verstring=
-	    ;;
-	  *)
-	    verstring="0.0"
-	    ;;
-	  esac
-	  if test "$need_version" = no; then
-	    versuffix=
-	  else
-	    versuffix=".0.0"
-	  fi
-	fi
-
-	# Remove version info from name if versioning should be avoided
-	if test "$avoid_version" = yes && test "$need_version" = no; then
-	  major=
-	  versuffix=
-	  verstring=""
-	fi
-
-	# Check to see if the archive will have undefined symbols.
-	if test "$allow_undefined" = yes; then
-	  if test "$allow_undefined_flag" = unsupported; then
-	    $echo "$modename: warning: undefined symbols not allowed in $host shared libraries" 1>&2
-	    build_libtool_libs=no
-	    build_old_libs=yes
-	  fi
-	else
-	  # Don't allow undefined symbols.
-	  allow_undefined_flag="$no_undefined_flag"
-	fi
-      fi
-
-      if test "$mode" != relink; then
-	# Remove our outputs, but don't remove object files since they
-	# may have been created when compiling PIC objects.
-	removelist=
-	tempremovelist=`$echo "$output_objdir/*"`
-	for p in $tempremovelist; do
-	  case $p in
-	    *.$objext)
-	       ;;
-	    $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/${libname}${release}.*)
-	       if test "X$precious_files_regex" != "X"; then
-	         if echo $p | $EGREP -e "$precious_files_regex" >/dev/null 2>&1
-	         then
-		   continue
-		 fi
-	       fi
-	       removelist="$removelist $p"
-	       ;;
-	    *) ;;
-	  esac
-	done
-	if test -n "$removelist"; then
-	  $show "${rm}r $removelist"
-	  $run ${rm}r $removelist
-	fi
-      fi
-
-      # Now set the variables for building old libraries.
-      if test "$build_old_libs" = yes && test "$build_libtool_libs" != convenience ; then
-	oldlibs="$oldlibs $output_objdir/$libname.$libext"
-
-	# Transform .lo files to .o files.
-	oldobjs="$objs "`$echo "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}'$/d' -e "$lo2o" | $NL2SP`
-      fi
-
-      # Eliminate all temporary directories.
-      for path in $notinst_path; do
-	lib_search_path=`$echo "$lib_search_path " | ${SED} -e 's% $path % %g'`
-	deplibs=`$echo "$deplibs " | ${SED} -e 's% -L$path % %g'`
-	dependency_libs=`$echo "$dependency_libs " | ${SED} -e 's% -L$path % %g'`
-      done
-
-      if test -n "$xrpath"; then
-	# If the user specified any rpath flags, then add them.
-	temp_xrpath=
-	for libdir in $xrpath; do
-	  temp_xrpath="$temp_xrpath -R$libdir"
-	  case "$finalize_rpath " in
-	  *" $libdir "*) ;;
-	  *) finalize_rpath="$finalize_rpath $libdir" ;;
-	  esac
-	done
-	if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then
-	  dependency_libs="$temp_xrpath $dependency_libs"
-	fi
-      fi
-
-      # Make sure dlfiles contains only unique files that won't be dlpreopened
-      old_dlfiles="$dlfiles"
-      dlfiles=
-      for lib in $old_dlfiles; do
-	case " $dlprefiles $dlfiles " in
-	*" $lib "*) ;;
-	*) dlfiles="$dlfiles $lib" ;;
-	esac
-      done
-
-      # Make sure dlprefiles contains only unique files
-      old_dlprefiles="$dlprefiles"
-      dlprefiles=
-      for lib in $old_dlprefiles; do
-	case "$dlprefiles " in
-	*" $lib "*) ;;
-	*) dlprefiles="$dlprefiles $lib" ;;
-	esac
-      done
-
-      if test "$build_libtool_libs" = yes; then
-	if test -n "$rpath"; then
-	  case $host in
-	  *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos*)
-	    # these systems don't actually have a c library (as such)!
-	    ;;
-	  *-*-rhapsody* | *-*-darwin1.[012])
-	    # Rhapsody C library is in the System framework
-	    deplibs="$deplibs -framework System"
-	    ;;
-	  *-*-netbsd*)
-	    # Don't link with libc until the a.out ld.so is fixed.
-	    ;;
-	  *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
-	    # Do not include libc due to us having libc/libc_r.
-	    test "X$arg" = "X-lc" && continue
-	    ;;
- 	  *)
-	    # Add libc to deplibs on all other systems if necessary.
-	    if test "$build_libtool_need_lc" = "yes"; then
-	      deplibs="$deplibs -lc"
-	    fi
-	    ;;
-	  esac
-	fi
-
-	# Transform deplibs into only deplibs that can be linked in shared.
-	name_save=$name
-	libname_save=$libname
-	release_save=$release
-	versuffix_save=$versuffix
-	major_save=$major
-	# I'm not sure if I'm treating the release correctly.  I think
-	# release should show up in the -l (ie -lgmp5) so we don't want to
-	# add it in twice.  Is that correct?
-	release=""
-	versuffix=""
-	major=""
-	newdeplibs=
-	droppeddeps=no
-	case $deplibs_check_method in
-	pass_all)
-	  # Don't check for shared/static.  Everything works.
-	  # This might be a little naive.  We might want to check
-	  # whether the library exists or not.  But this is on
-	  # osf3 & osf4 and I'm not really sure... Just
-	  # implementing what was already the behavior.
-	  newdeplibs=$deplibs
-	  ;;
-	test_compile)
-	  # This code stresses the "libraries are programs" paradigm to its
-	  # limits. Maybe even breaks it.  We compile a program, linking it
-	  # against the deplibs as a proxy for the library.  Then we can check
-	  # whether they linked in statically or dynamically with ldd.
-	  $rm conftest.c
-	  cat > conftest.c <<EOF
-	  int main() { return 0; }
-EOF
-	  $rm conftest
-	  $LTCC -o conftest conftest.c $deplibs
-	  if test "$?" -eq 0 ; then
-	    ldd_output=`ldd conftest`
-	    for i in $deplibs; do
-	      name="`expr $i : '-l\(.*\)'`"
-	      # If $name is empty we are operating on a -L argument.
-              if test "$name" != "" && test "$name" -ne "0"; then
-		if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
-		  case " $predeps $postdeps " in
-		  *" $i "*)
-		    newdeplibs="$newdeplibs $i"
-		    i=""
-		    ;;
-		  esac
-	        fi
-		if test -n "$i" ; then
-		  libname=`eval \\$echo \"$libname_spec\"`
-		  deplib_matches=`eval \\$echo \"$library_names_spec\"`
-		  set dummy $deplib_matches
-		  deplib_match=$2
-		  if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
-		    newdeplibs="$newdeplibs $i"
-		  else
-		    droppeddeps=yes
-		    $echo
-		    $echo "*** Warning: dynamic linker does not accept needed library $i."
-		    $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 I believe you do not have"
-		    $echo "*** because a test_compile did reveal that the linker did not use it for"
-		    $echo "*** its dynamic dependency list that programs get resolved with at runtime."
-		  fi
-		fi
-	      else
-		newdeplibs="$newdeplibs $i"
-	      fi
-	    done
-	  else
-	    # Error occurred in the first compile.  Let's try to salvage
-	    # the situation: Compile a separate program for each library.
-	    for i in $deplibs; do
-	      name="`expr $i : '-l\(.*\)'`"
-	      # If $name is empty we are operating on a -L argument.
-              if test "$name" != "" && test "$name" != "0"; then
-		$rm conftest
-		$LTCC -o conftest conftest.c $i
-		# Did it work?
-		if test "$?" -eq 0 ; then
-		  ldd_output=`ldd conftest`
-		  if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
-		    case " $predeps $postdeps " in
-		    *" $i "*)
-		      newdeplibs="$newdeplibs $i"
-		      i=""
-		      ;;
-		    esac
-		  fi
-		  if test -n "$i" ; then
-		    libname=`eval \\$echo \"$libname_spec\"`
-		    deplib_matches=`eval \\$echo \"$library_names_spec\"`
-		    set dummy $deplib_matches
-		    deplib_match=$2
-		    if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
-		      newdeplibs="$newdeplibs $i"
-		    else
-		      droppeddeps=yes
-		      $echo
-		      $echo "*** Warning: dynamic linker does not accept needed library $i."
-		      $echo "*** I have the capability to make that library automatically link in when"
-		      $echo "*** you link to this library.  But I can only do this if you have a"
-		      $echo "*** shared version of the library, which you do not appear to have"
-		      $echo "*** because a test_compile did reveal that the linker did not use this one"
-		      $echo "*** as a dynamic dependency that programs can get resolved with at runtime."
-		    fi
-		  fi
-		else
-		  droppeddeps=yes
-		  $echo
-		  $echo "*** Warning!  Library $i is needed by this library but I was not able to"
-		  $echo "***  make it link in!  You will probably need to install it or some"
-		  $echo "*** library that it depends on before this library will be fully"
-		  $echo "*** functional.  Installing it before continuing would be even better."
-		fi
-	      else
-		newdeplibs="$newdeplibs $i"
-	      fi
-	    done
-	  fi
-	  ;;
-	file_magic*)
-	  set dummy $deplibs_check_method
-	  file_magic_regex=`expr "$deplibs_check_method" : "$2 \(.*\)"`
-	  for a_deplib in $deplibs; do
-	    name="`expr $a_deplib : '-l\(.*\)'`"
-	    # If $name is empty we are operating on a -L argument.
-            if test "$name" != "" && test  "$name" != "0"; then
-	      if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
-		case " $predeps $postdeps " in
-		*" $a_deplib "*)
-		  newdeplibs="$newdeplibs $a_deplib"
-		  a_deplib=""
-		  ;;
-		esac
-	      fi
-	      if test -n "$a_deplib" ; then
-		libname=`eval \\$echo \"$libname_spec\"`
-		for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
-		  potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
-		  for potent_lib in $potential_libs; do
-		      # Follow soft links.
-		      if ls -lLd "$potent_lib" 2>/dev/null \
-			 | grep " -> " >/dev/null; then
-			continue
-		      fi
-		      # The statement above tries to avoid entering an
-		      # endless loop below, in case of cyclic links.
-		      # We might still enter an endless loop, since a link
-		      # loop can be closed while we follow links,
-		      # but so what?
-		      potlib="$potent_lib"
-		      while test -h "$potlib" 2>/dev/null; do
-			potliblink=`ls -ld $potlib | ${SED} 's/.* -> //'`
-			case $potliblink in
-			[\\/]* | [A-Za-z]:[\\/]*) potlib="$potliblink";;
-			*) potlib=`$echo "X$potlib" | $Xsed -e 's,[^/]*$,,'`"$potliblink";;
-			esac
-		      done
-		      if eval $file_magic_cmd \"\$potlib\" 2>/dev/null \
-			 | ${SED} 10q \
-			 | $EGREP "$file_magic_regex" > /dev/null; then
-			newdeplibs="$newdeplibs $a_deplib"
-			a_deplib=""
-			break 2
-		      fi
-		  done
-		done
-	      fi
-	      if test -n "$a_deplib" ; then
-		droppeddeps=yes
-		$echo
-		$echo "*** Warning: linker path does not have real file for library $a_deplib."
-		$echo "*** I have the capability to make that library automatically link in when"
-		$echo "*** you link to this library.  But I can only do this if you have a"
-		$echo "*** shared version of the library, which you do not appear to have"
-		$echo "*** because I did check the linker path looking for a file starting"
-		if test -z "$potlib" ; then
-		  $echo "*** with $libname but no candidates were found. (...for file magic test)"
-		else
-		  $echo "*** with $libname and none of the candidates passed a file format test"
-		  $echo "*** using a file magic. Last file checked: $potlib"
-		fi
-	      fi
-	    else
-	      # Add a -L argument.
-	      newdeplibs="$newdeplibs $a_deplib"
-	    fi
-	  done # Gone through all deplibs.
-	  ;;
-	match_pattern*)
-	  set dummy $deplibs_check_method
-	  match_pattern_regex=`expr "$deplibs_check_method" : "$2 \(.*\)"`
-	  for a_deplib in $deplibs; do
-	    name="`expr $a_deplib : '-l\(.*\)'`"
-	    # If $name is empty we are operating on a -L argument.
-	    if test -n "$name" && test "$name" != "0"; then
-	      if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
-		case " $predeps $postdeps " in
-		*" $a_deplib "*)
-		  newdeplibs="$newdeplibs $a_deplib"
-		  a_deplib=""
-		  ;;
-		esac
-	      fi
-	      if test -n "$a_deplib" ; then
-		libname=`eval \\$echo \"$libname_spec\"`
-		for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
-		  potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
-		  for potent_lib in $potential_libs; do
-		    potlib="$potent_lib" # see symlink-check above in file_magic test
-		    if eval $echo \"$potent_lib\" 2>/dev/null \
-		        | ${SED} 10q \
-		        | $EGREP "$match_pattern_regex" > /dev/null; then
-		      newdeplibs="$newdeplibs $a_deplib"
-		      a_deplib=""
-		      break 2
-		    fi
-		  done
-		done
-	      fi
-	      if test -n "$a_deplib" ; then
-		droppeddeps=yes
-		$echo
-		$echo "*** Warning: linker path does not have real file for library $a_deplib."
-		$echo "*** I have the capability to make that library automatically link in when"
-		$echo "*** you link to this library.  But I can only do this if you have a"
-		$echo "*** shared version of the library, which you do not appear to have"
-		$echo "*** because I did check the linker path looking for a file starting"
-		if test -z "$potlib" ; then
-		  $echo "*** with $libname but no candidates were found. (...for regex pattern test)"
-		else
-		  $echo "*** with $libname and none of the candidates passed a file format test"
-		  $echo "*** using a regex pattern. Last file checked: $potlib"
-		fi
-	      fi
-	    else
-	      # Add a -L argument.
-	      newdeplibs="$newdeplibs $a_deplib"
-	    fi
-	  done # Gone through all deplibs.
-	  ;;
-	none | unknown | *)
-	  newdeplibs=""
-	  tmp_deplibs=`$echo "X $deplibs" | $Xsed -e 's/ -lc$//' \
-	    -e 's/ -[LR][^ ]*//g'`
-	  if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
-	    for i in $predeps $postdeps ; do
-	      # can't use Xsed below, because $i might contain '/'
-	      tmp_deplibs=`$echo "X $tmp_deplibs" | ${SED} -e "1s,^X,," -e "s,$i,,"`
-	    done
-	  fi
-	  if $echo "X $tmp_deplibs" | $Xsed -e 's/[ 	]//g' \
-	    | grep . >/dev/null; then
-	    $echo
-	    if test "X$deplibs_check_method" = "Xnone"; then
-	      $echo "*** Warning: inter-library dependencies are not supported in this platform."
-	    else
-	      $echo "*** Warning: inter-library dependencies are not known to be supported."
-	    fi
-	    $echo "*** All declared inter-library dependencies are being dropped."
-	    droppeddeps=yes
-	  fi
-	  ;;
-	esac
-	versuffix=$versuffix_save
-	major=$major_save
-	release=$release_save
-	libname=$libname_save
-	name=$name_save
-
-	case $host in
-	*-*-rhapsody* | *-*-darwin1.[012])
-	  # On Rhapsody replace the C library is the System framework
-	  newdeplibs=`$echo "X $newdeplibs" | $Xsed -e 's/ -lc / -framework System /'`
-	  ;;
-	esac
-
-	if test "$droppeddeps" = yes; then
-	  if test "$module" = yes; then
-	    $echo
-	    $echo "*** Warning: libtool could not satisfy all declared inter-library"
-	    $echo "*** dependencies of module $libname.  Therefore, libtool will create"
-	    $echo "*** a static module, that should work as long as the dlopening"
-	    $echo "*** application is linked with the -dlopen flag."
-	    if test -z "$global_symbol_pipe"; then
-	      $echo
-	      $echo "*** However, this would only work if libtool was able to extract symbol"
-	      $echo "*** lists from a program, using \`nm' or equivalent, but libtool could"
-	      $echo "*** not find such a program.  So, this module is probably useless."
-	      $echo "*** \`nm' from GNU binutils and a full rebuild may help."
-	    fi
-	    if test "$build_old_libs" = no; then
-	      oldlibs="$output_objdir/$libname.$libext"
-	      build_libtool_libs=module
-	      build_old_libs=yes
-	    else
-	      build_libtool_libs=no
-	    fi
-	  else
-	    $echo "*** The inter-library dependencies that have been dropped here will be"
-	    $echo "*** automatically added whenever a program is linked with this library"
-	    $echo "*** or is declared to -dlopen it."
-
-	    if test "$allow_undefined" = no; then
-	      $echo
-	      $echo "*** Since this library must not contain undefined symbols,"
-	      $echo "*** because either the platform does not support them or"
-	      $echo "*** it was explicitly requested with -no-undefined,"
-	      $echo "*** libtool will only create a static version of it."
-	      if test "$build_old_libs" = no; then
-		oldlibs="$output_objdir/$libname.$libext"
-		build_libtool_libs=module
-		build_old_libs=yes
-	      else
-		build_libtool_libs=no
-	      fi
-	    fi
-	  fi
-	fi
-	# Done checking deplibs!
-	deplibs=$newdeplibs
-      fi
-
-      # All the library-specific variables (install_libdir is set above).
-      library_names=
-      old_library=
-      dlname=
-
-      # Test again, we may have decided not to build it any more
-      if test "$build_libtool_libs" = yes; then
-	if test "$hardcode_into_libs" = yes; then
-	  # Hardcode the library paths
-	  hardcode_libdirs=
-	  dep_rpath=
-	  rpath="$finalize_rpath"
-	  test "$mode" != relink && rpath="$compile_rpath$rpath"
-	  for libdir in $rpath; do
-	    if test -n "$hardcode_libdir_flag_spec"; then
-	      if test -n "$hardcode_libdir_separator"; then
-		if test -z "$hardcode_libdirs"; then
-		  hardcode_libdirs="$libdir"
-		else
-		  # Just accumulate the unique libdirs.
-		  case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
-		  *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
-		    ;;
-		  *)
-		    hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
-		    ;;
-		  esac
-		fi
-	      else
-		eval flag=\"$hardcode_libdir_flag_spec\"
-		dep_rpath="$dep_rpath $flag"
-	      fi
-	    elif test -n "$runpath_var"; then
-	      case "$perm_rpath " in
-	      *" $libdir "*) ;;
-	      *) perm_rpath="$perm_rpath $libdir" ;;
-	      esac
-	    fi
-	  done
-	  # Substitute the hardcoded libdirs into the rpath.
-	  if test -n "$hardcode_libdir_separator" &&
-	     test -n "$hardcode_libdirs"; then
-	    libdir="$hardcode_libdirs"
-	    if test -n "$hardcode_libdir_flag_spec_ld"; then
-	      eval dep_rpath=\"$hardcode_libdir_flag_spec_ld\"
-	    else
-	      eval dep_rpath=\"$hardcode_libdir_flag_spec\"
-	    fi
-	  fi
-	  if test -n "$runpath_var" && test -n "$perm_rpath"; then
-	    # We should set the runpath_var.
-	    rpath=
-	    for dir in $perm_rpath; do
-	      rpath="$rpath$dir:"
-	    done
-	    eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var"
-	  fi
-	  test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs"
-	fi
-
-	shlibpath="$finalize_shlibpath"
-	test "$mode" != relink && shlibpath="$compile_shlibpath$shlibpath"
-	if test -n "$shlibpath"; then
-	  eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var"
-	fi
-
-	# Get the real and link names of the library.
-	eval shared_ext=\"$shrext_cmds\"
-	eval library_names=\"$library_names_spec\"
-	set dummy $library_names
-	realname="$2"
-	shift; shift
-
-	if test -n "$soname_spec"; then
-	  eval soname=\"$soname_spec\"
-	else
-	  soname="$realname"
-	fi
-	if test -z "$dlname"; then
-	  dlname=$soname
-	fi
-
-	lib="$output_objdir/$realname"
-	for link
-	do
-	  linknames="$linknames $link"
-	done
-
-	# Use standard objects if they are pic
-	test -z "$pic_flag" && libobjs=`$echo "X$libobjs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
-
-	# Prepare the list of exported symbols
-	if test -z "$export_symbols"; then
-	  if test "$always_export_symbols" = yes || test -n "$export_symbols_regex"; then
-	    $show "generating symbol list for \`$libname.la'"
-	    export_symbols="$output_objdir/$libname.exp"
-	    $run $rm $export_symbols
-	    cmds=$export_symbols_cmds
-	    save_ifs="$IFS"; IFS='~'
-	    for cmd in $cmds; do
-	      IFS="$save_ifs"
-	      eval cmd=\"$cmd\"
-	      if len=`expr "X$cmd" : ".*"` &&
-	       test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then
-	        $show "$cmd"
-	        $run eval "$cmd" || exit $?
-	        skipped_export=false
-	      else
-	        # The command line is too long to execute in one step.
-	        $show "using reloadable object file for export list..."
-	        skipped_export=:
-	      fi
-	    done
-	    IFS="$save_ifs"
-	    if test -n "$export_symbols_regex"; then
-	      $show "$EGREP -e \"$export_symbols_regex\" \"$export_symbols\" > \"${export_symbols}T\""
-	      $run eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
-	      $show "$mv \"${export_symbols}T\" \"$export_symbols\""
-	      $run eval '$mv "${export_symbols}T" "$export_symbols"'
-	    fi
-	  fi
-	fi
-
-	if test -n "$export_symbols" && test -n "$include_expsyms"; then
-	  $run eval '$echo "X$include_expsyms" | $SP2NL >> "$export_symbols"'
-	fi
-
-	tmp_deplibs=
-	for test_deplib in $deplibs; do
-		case " $convenience " in
-		*" $test_deplib "*) ;;
-		*)
-			tmp_deplibs="$tmp_deplibs $test_deplib"
-			;;
-		esac
-	done
-	deplibs="$tmp_deplibs"
-
-	if test -n "$convenience"; then
-	  if test -n "$whole_archive_flag_spec"; then
-	    save_libobjs=$libobjs
-	    eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
-	  else
-	    gentop="$output_objdir/${outputname}x"
-	    generated="$generated $gentop"
-
-	    func_extract_archives $gentop $convenience
-	    libobjs="$libobjs $func_extract_archives_result"
-	  fi
-	fi
-	
-	if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then
-	  eval flag=\"$thread_safe_flag_spec\"
-	  linker_flags="$linker_flags $flag"
-	fi
-
-	# Make a backup of the uninstalled library when relinking
-	if test "$mode" = relink; then
-	  $run eval '(cd $output_objdir && $rm ${realname}U && $mv $realname ${realname}U)' || exit $?
-	fi
-
-	# Do each of the archive commands.
-	if test "$module" = yes && test -n "$module_cmds" ; then
-	  if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
-	    eval test_cmds=\"$module_expsym_cmds\"
-	    cmds=$module_expsym_cmds
-	  else
-	    eval test_cmds=\"$module_cmds\"
-	    cmds=$module_cmds
-	  fi
-	else
-	if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then
-	  eval test_cmds=\"$archive_expsym_cmds\"
-	  cmds=$archive_expsym_cmds
-	else
-	  eval test_cmds=\"$archive_cmds\"
-	  cmds=$archive_cmds
-	  fi
-	fi
-
-	if test "X$skipped_export" != "X:" && len=`expr "X$test_cmds" : ".*"` &&
-	   test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then
-	  :
-	else
-	  # The command line is too long to link in one step, link piecewise.
-	  $echo "creating reloadable object files..."
-
-	  # Save the value of $output and $libobjs because we want to
-	  # use them later.  If we have whole_archive_flag_spec, we
-	  # want to use save_libobjs as it was before
-	  # whole_archive_flag_spec was expanded, because we can't
-	  # assume the linker understands whole_archive_flag_spec.
-	  # This may have to be revisited, in case too many
-	  # convenience libraries get linked in and end up exceeding
-	  # the spec.
-	  if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then
-	    save_libobjs=$libobjs
-	  fi
-	  save_output=$output
-	  output_la=`$echo "X$output" | $Xsed -e "$basename"`
-
-	  # Clear the reloadable object creation command queue and
-	  # initialize k to one.
-	  test_cmds=
-	  concat_cmds=
-	  objlist=
-	  delfiles=
-	  last_robj=
-	  k=1
-	  output=$output_objdir/$output_la-${k}.$objext
-	  # Loop over the list of objects to be linked.
-	  for obj in $save_libobjs
-	  do
-	    eval test_cmds=\"$reload_cmds $objlist $last_robj\"
-	    if test "X$objlist" = X ||
-	       { len=`expr "X$test_cmds" : ".*"` &&
-		 test "$len" -le "$max_cmd_len"; }; then
-	      objlist="$objlist $obj"
-	    else
-	      # The command $test_cmds is almost too long, add a
-	      # command to the queue.
-	      if test "$k" -eq 1 ; then
-		# The first file doesn't have a previous command to add.
-		eval concat_cmds=\"$reload_cmds $objlist $last_robj\"
-	      else
-		# All subsequent reloadable object files will link in
-		# the last one created.
-		eval concat_cmds=\"\$concat_cmds~$reload_cmds $objlist $last_robj\"
-	      fi
-	      last_robj=$output_objdir/$output_la-${k}.$objext
-	      k=`expr $k + 1`
-	      output=$output_objdir/$output_la-${k}.$objext
-	      objlist=$obj
-	      len=1
-	    fi
-	  done
-	  # Handle the remaining objects by creating one last
-	  # reloadable object file.  All subsequent reloadable object
-	  # files will link in the last one created.
-	  test -z "$concat_cmds" || concat_cmds=$concat_cmds~
-	  eval concat_cmds=\"\${concat_cmds}$reload_cmds $objlist $last_robj\"
-
-	  if ${skipped_export-false}; then
-	    $show "generating symbol list for \`$libname.la'"
-	    export_symbols="$output_objdir/$libname.exp"
-	    $run $rm $export_symbols
-	    libobjs=$output
-	    # Append the command to create the export file.
-	    eval concat_cmds=\"\$concat_cmds~$export_symbols_cmds\"
-          fi
-
-	  # Set up a command to remove the reloadable object files
-	  # after they are used.
-	  i=0
-	  while test "$i" -lt "$k"
-	  do
-	    i=`expr $i + 1`
-	    delfiles="$delfiles $output_objdir/$output_la-${i}.$objext"
-	  done
-
-	  $echo "creating a temporary reloadable object file: $output"
-
-	  # Loop through the commands generated above and execute them.
-	  save_ifs="$IFS"; IFS='~'
-	  for cmd in $concat_cmds; do
-	    IFS="$save_ifs"
-	    $show "$cmd"
-	    $run eval "$cmd" || exit $?
-	  done
-	  IFS="$save_ifs"
-
-	  libobjs=$output
-	  # Restore the value of output.
-	  output=$save_output
-
-	  if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then
-	    eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
-	  fi
-	  # Expand the library linking commands again to reset the
-	  # value of $libobjs for piecewise linking.
-
-	  # Do each of the archive commands.
-	  if test "$module" = yes && test -n "$module_cmds" ; then
-	    if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
-	      cmds=$module_expsym_cmds
-	    else
-	      cmds=$module_cmds
-	    fi
-	  else
-	  if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then
-	    cmds=$archive_expsym_cmds
-	  else
-	    cmds=$archive_cmds
-	    fi
-	  fi
-
-	  # Append the command to remove the reloadable object files
-	  # to the just-reset $cmds.
-	  eval cmds=\"\$cmds~\$rm $delfiles\"
-	fi
-	save_ifs="$IFS"; IFS='~'
-	for cmd in $cmds; do
-	  IFS="$save_ifs"
-	  eval cmd=\"$cmd\"
-	  $show "$cmd"
-	  $run eval "$cmd" || exit $?
-	done
-	IFS="$save_ifs"
-
-	# Restore the uninstalled library and exit
-	if test "$mode" = relink; then
-	  $run eval '(cd $output_objdir && $rm ${realname}T && $mv $realname ${realname}T && $mv "$realname"U $realname)' || exit $?
-	  exit $EXIT_SUCCESS
-	fi
-
-	# Create links to the real library.
-	for linkname in $linknames; do
-	  if test "$realname" != "$linkname"; then
-	    $show "(cd $output_objdir && $rm $linkname && $LN_S $realname $linkname)"
-	    $run eval '(cd $output_objdir && $rm $linkname && $LN_S $realname $linkname)' || exit $?
-	  fi
-	done
-
-	# If -module or -export-dynamic was specified, set the dlname.
-	if test "$module" = yes || test "$export_dynamic" = yes; then
-	  # On all known operating systems, these are identical.
-	  dlname="$soname"
-	fi
-      fi
-      ;;
-
-    obj)
-      if test -n "$deplibs"; then
-	$echo "$modename: warning: \`-l' and \`-L' are ignored for objects" 1>&2
-      fi
-
-      if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
-	$echo "$modename: warning: \`-dlopen' is ignored for objects" 1>&2
-      fi
-
-      if test -n "$rpath"; then
-	$echo "$modename: warning: \`-rpath' is ignored for objects" 1>&2
-      fi
-
-      if test -n "$xrpath"; then
-	$echo "$modename: warning: \`-R' is ignored for objects" 1>&2
-      fi
-
-      if test -n "$vinfo"; then
-	$echo "$modename: warning: \`-version-info' is ignored for objects" 1>&2
-      fi
-
-      if test -n "$release"; then
-	$echo "$modename: warning: \`-release' is ignored for objects" 1>&2
-      fi
-
-      case $output in
-      *.lo)
-	if test -n "$objs$old_deplibs"; then
-	  $echo "$modename: cannot build library object \`$output' from non-libtool objects" 1>&2
-	  exit $EXIT_FAILURE
-	fi
-	libobj="$output"
-	obj=`$echo "X$output" | $Xsed -e "$lo2o"`
-	;;
-      *)
-	libobj=
-	obj="$output"
-	;;
-      esac
-
-      # Delete the old objects.
-      $run $rm $obj $libobj
-
-      # Objects from convenience libraries.  This assumes
-      # single-version convenience libraries.  Whenever we create
-      # different ones for PIC/non-PIC, this we'll have to duplicate
-      # the extraction.
-      reload_conv_objs=
-      gentop=
-      # reload_cmds runs $LD directly, so let us get rid of
-      # -Wl from whole_archive_flag_spec
-      wl=
-
-      if test -n "$convenience"; then
-	if test -n "$whole_archive_flag_spec"; then
-	  eval reload_conv_objs=\"\$reload_objs $whole_archive_flag_spec\"
-	else
-	  gentop="$output_objdir/${obj}x"
-	  generated="$generated $gentop"
-
-	  func_extract_archives $gentop $convenience
-	  reload_conv_objs="$reload_objs $func_extract_archives_result"
-	fi
-      fi
-
-      # Create the old-style object.
-      reload_objs="$objs$old_deplibs "`$echo "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}$'/d' -e '/\.lib$/d' -e "$lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test
-
-      output="$obj"
-      cmds=$reload_cmds
-      save_ifs="$IFS"; IFS='~'
-      for cmd in $cmds; do
-	IFS="$save_ifs"
-	eval cmd=\"$cmd\"
-	$show "$cmd"
-	$run eval "$cmd" || exit $?
-      done
-      IFS="$save_ifs"
-
-      # Exit if we aren't doing a library object file.
-      if test -z "$libobj"; then
-	if test -n "$gentop"; then
-	  $show "${rm}r $gentop"
-	  $run ${rm}r $gentop
-	fi
-
-	exit $EXIT_SUCCESS
-      fi
-
-      if test "$build_libtool_libs" != yes; then
-	if test -n "$gentop"; then
-	  $show "${rm}r $gentop"
-	  $run ${rm}r $gentop
-	fi
-
-	# Create an invalid libtool object if no PIC, so that we don't
-	# accidentally link it into a program.
-	# $show "echo timestamp > $libobj"
-	# $run eval "echo timestamp > $libobj" || exit $?
-	exit $EXIT_SUCCESS
-      fi
-
-      if test -n "$pic_flag" || test "$pic_mode" != default; then
-	# Only do commands if we really have different PIC objects.
-	reload_objs="$libobjs $reload_conv_objs"
-	output="$libobj"
-	cmds=$reload_cmds
-	save_ifs="$IFS"; IFS='~'
-	for cmd in $cmds; do
-	  IFS="$save_ifs"
-	  eval cmd=\"$cmd\"
-	  $show "$cmd"
-	  $run eval "$cmd" || exit $?
-	done
-	IFS="$save_ifs"
-      fi
-
-      if test -n "$gentop"; then
-	$show "${rm}r $gentop"
-	$run ${rm}r $gentop
-      fi
-
-      exit $EXIT_SUCCESS
-      ;;
-
-    prog)
-      case $host in
-	*cygwin*) output=`$echo $output | ${SED} -e 's,.exe$,,;s,$,.exe,'` ;;
-      esac
-      if test -n "$vinfo"; then
-	$echo "$modename: warning: \`-version-info' is ignored for programs" 1>&2
-      fi
-
-      if test -n "$release"; then
-	$echo "$modename: warning: \`-release' is ignored for programs" 1>&2
-      fi
-
-      if test "$preload" = yes; then
-	if test "$dlopen_support" = unknown && test "$dlopen_self" = unknown &&
-	   test "$dlopen_self_static" = unknown; then
-	  $echo "$modename: warning: \`AC_LIBTOOL_DLOPEN' not used. Assuming no dlopen support."
-	fi
-      fi
-
-      case $host in
-      *-*-rhapsody* | *-*-darwin1.[012])
-	# On Rhapsody replace the C library is the System framework
-	compile_deplibs=`$echo "X $compile_deplibs" | $Xsed -e 's/ -lc / -framework System /'`
-	finalize_deplibs=`$echo "X $finalize_deplibs" | $Xsed -e 's/ -lc / -framework System /'`
-	;;
-      esac
-
-      case $host in
-      *darwin*)
-        # Don't allow lazy linking, it breaks C++ global constructors
-        if test "$tagname" = CXX ; then
-        compile_command="$compile_command ${wl}-bind_at_load"
-        finalize_command="$finalize_command ${wl}-bind_at_load"
-        fi
-        ;;
-      esac
-
-      compile_command="$compile_command $compile_deplibs"
-      finalize_command="$finalize_command $finalize_deplibs"
-
-      if test -n "$rpath$xrpath"; then
-	# If the user specified any rpath flags, then add them.
-	for libdir in $rpath $xrpath; do
-	  # This is the magic to use -rpath.
-	  case "$finalize_rpath " in
-	  *" $libdir "*) ;;
-	  *) finalize_rpath="$finalize_rpath $libdir" ;;
-	  esac
-	done
-      fi
-
-      # Now hardcode the library paths
-      rpath=
-      hardcode_libdirs=
-      for libdir in $compile_rpath $finalize_rpath; do
-	if test -n "$hardcode_libdir_flag_spec"; then
-	  if test -n "$hardcode_libdir_separator"; then
-	    if test -z "$hardcode_libdirs"; then
-	      hardcode_libdirs="$libdir"
-	    else
-	      # Just accumulate the unique libdirs.
-	      case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
-	      *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
-		;;
-	      *)
-		hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
-		;;
-	      esac
-	    fi
-	  else
-	    eval flag=\"$hardcode_libdir_flag_spec\"
-	    rpath="$rpath $flag"
-	  fi
-	elif test -n "$runpath_var"; then
-	  case "$perm_rpath " in
-	  *" $libdir "*) ;;
-	  *) perm_rpath="$perm_rpath $libdir" ;;
-	  esac
-	fi
-	case $host in
-	*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*)
-	  case :$dllsearchpath: in
-	  *":$libdir:"*) ;;
-	  *) dllsearchpath="$dllsearchpath:$libdir";;
-	  esac
-	  ;;
-	esac
-      done
-      # Substitute the hardcoded libdirs into the rpath.
-      if test -n "$hardcode_libdir_separator" &&
-	 test -n "$hardcode_libdirs"; then
-	libdir="$hardcode_libdirs"
-	eval rpath=\" $hardcode_libdir_flag_spec\"
-      fi
-      compile_rpath="$rpath"
-
-      rpath=
-      hardcode_libdirs=
-      for libdir in $finalize_rpath; do
-	if test -n "$hardcode_libdir_flag_spec"; then
-	  if test -n "$hardcode_libdir_separator"; then
-	    if test -z "$hardcode_libdirs"; then
-	      hardcode_libdirs="$libdir"
-	    else
-	      # Just accumulate the unique libdirs.
-	      case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
-	      *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
-		;;
-	      *)
-		hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
-		;;
-	      esac
-	    fi
-	  else
-	    eval flag=\"$hardcode_libdir_flag_spec\"
-	    rpath="$rpath $flag"
-	  fi
-	elif test -n "$runpath_var"; then
-	  case "$finalize_perm_rpath " in
-	  *" $libdir "*) ;;
-	  *) finalize_perm_rpath="$finalize_perm_rpath $libdir" ;;
-	  esac
-	fi
-      done
-      # Substitute the hardcoded libdirs into the rpath.
-      if test -n "$hardcode_libdir_separator" &&
-	 test -n "$hardcode_libdirs"; then
-	libdir="$hardcode_libdirs"
-	eval rpath=\" $hardcode_libdir_flag_spec\"
-      fi
-      finalize_rpath="$rpath"
-
-      if test -n "$libobjs" && test "$build_old_libs" = yes; then
-	# Transform all the library objects into standard objects.
-	compile_command=`$echo "X$compile_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
-	finalize_command=`$echo "X$finalize_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
-      fi
-
-      dlsyms=
-      if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
-	if test -n "$NM" && test -n "$global_symbol_pipe"; then
-	  dlsyms="${outputname}S.c"
-	else
-	  $echo "$modename: not configured to extract global symbols from dlpreopened files" 1>&2
-	fi
-      fi
-
-      if test -n "$dlsyms"; then
-	case $dlsyms in
-	"") ;;
-	*.c)
-	  # Discover the nlist of each of the dlfiles.
-	  nlist="$output_objdir/${outputname}.nm"
-
-	  $show "$rm $nlist ${nlist}S ${nlist}T"
-	  $run $rm "$nlist" "${nlist}S" "${nlist}T"
-
-	  # Parse the name list into a source file.
-	  $show "creating $output_objdir/$dlsyms"
-
-	  test -z "$run" && $echo > "$output_objdir/$dlsyms" "\
-/* $dlsyms - symbol resolution table for \`$outputname' dlsym emulation. */
-/* Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP */
-
-#ifdef __cplusplus
-extern \"C\" {
-#endif
-
-/* Prevent the only kind of declaration conflicts we can make. */
-#define lt_preloaded_symbols some_other_symbol
-
-/* External symbol declarations for the compiler. */\
-"
-
-	  if test "$dlself" = yes; then
-	    $show "generating symbol list for \`$output'"
-
-	    test -z "$run" && $echo ': @PROGRAM@ ' > "$nlist"
-
-	    # Add our own program objects to the symbol list.
-	    progfiles=`$echo "X$objs$old_deplibs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
-	    for arg in $progfiles; do
-	      $show "extracting global C symbols from \`$arg'"
-	      $run eval "$NM $arg | $global_symbol_pipe >> '$nlist'"
-	    done
-
-	    if test -n "$exclude_expsyms"; then
-	      $run eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T'
-	      $run eval '$mv "$nlist"T "$nlist"'
-	    fi
-
-	    if test -n "$export_symbols_regex"; then
-	      $run eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T'
-	      $run eval '$mv "$nlist"T "$nlist"'
-	    fi
-
-	    # Prepare the list of exported symbols
-	    if test -z "$export_symbols"; then
-	      export_symbols="$output_objdir/$outputname.exp"
-	      $run $rm $export_symbols
-	      $run eval "${SED} -n -e '/^: @PROGRAM@$/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"'
-	    else
-	      $run eval "${SED} -e 's/\([ ][.*^$]\)/\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"'
-	      $run eval 'grep -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T'
-	      $run eval 'mv "$nlist"T "$nlist"'
-	    fi
-	  fi
-
-	  for arg in $dlprefiles; do
-	    $show "extracting global C symbols from \`$arg'"
-	    name=`$echo "$arg" | ${SED} -e 's%^.*/%%'`
-	    $run eval '$echo ": $name " >> "$nlist"'
-	    $run eval "$NM $arg | $global_symbol_pipe >> '$nlist'"
-	  done
-
-	  if test -z "$run"; then
-	    # Make sure we have at least an empty file.
-	    test -f "$nlist" || : > "$nlist"
-
-	    if test -n "$exclude_expsyms"; then
-	      $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T
-	      $mv "$nlist"T "$nlist"
-	    fi
-
-	    # Try sorting and uniquifying the output.
-	    if grep -v "^: " < "$nlist" |
-		if sort -k 3 </dev/null >/dev/null 2>&1; then
-		  sort -k 3
-		else
-		  sort +2
-		fi |
-		uniq > "$nlist"S; then
-	      :
-	    else
-	      grep -v "^: " < "$nlist" > "$nlist"S
-	    fi
-
-	    if test -f "$nlist"S; then
-	      eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$dlsyms"'
-	    else
-	      $echo '/* NONE */' >> "$output_objdir/$dlsyms"
-	    fi
-
-	    $echo >> "$output_objdir/$dlsyms" "\
-
-#undef lt_preloaded_symbols
-
-#if defined (__STDC__) && __STDC__
-# define lt_ptr void *
-#else
-# define lt_ptr char *
-# define const
-#endif
-
-/* The mapping between symbol names and symbols. */
-"
-
-	    case $host in
-	    *cygwin* | *mingw* )
-	  $echo >> "$output_objdir/$dlsyms" "\
-/* DATA imports from DLLs on WIN32 can't be const, because
-   runtime relocations are performed -- see ld's documentation
-   on pseudo-relocs */
-struct {
-"
-	      ;;
-	    * )
-	  $echo >> "$output_objdir/$dlsyms" "\
-const struct {
-"
-	      ;;
-	    esac
-
-
-	  $echo >> "$output_objdir/$dlsyms" "\
-  const char *name;
-  lt_ptr address;
-}
-lt_preloaded_symbols[] =
-{\
-"
-
-	    eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$dlsyms"
-
-	    $echo >> "$output_objdir/$dlsyms" "\
-  {0, (lt_ptr) 0}
-};
-
-/* This works around a problem in FreeBSD linker */
-#ifdef FREEBSD_WORKAROUND
-static const void *lt_preloaded_setup() {
-  return lt_preloaded_symbols;
-}
-#endif
-
-#ifdef __cplusplus
-}
-#endif\
-"
-	  fi
-
-	  pic_flag_for_symtable=
-	  case $host in
-	  # compiling the symbol table file with pic_flag works around
-	  # a FreeBSD bug that causes programs to crash when -lm is
-	  # linked before any other PIC object.  But we must not use
-	  # pic_flag when linking with -static.  The problem exists in
-	  # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1.
-	  *-*-freebsd2*|*-*-freebsd3.0*|*-*-freebsdelf3.0*)
-	    case "$compile_command " in
-	    *" -static "*) ;;
-	    *) pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND";;
-	    esac;;
-	  *-*-hpux*)
-	    case "$compile_command " in
-	    *" -static "*) ;;
-	    *) pic_flag_for_symtable=" $pic_flag";;
-	    esac
-	  esac
-
-	  # Now compile the dynamic symbol file.
-	  $show "(cd $output_objdir && $LTCC -c$no_builtin_flag$pic_flag_for_symtable \"$dlsyms\")"
-	  $run eval '(cd $output_objdir && $LTCC -c$no_builtin_flag$pic_flag_for_symtable "$dlsyms")' || exit $?
-
-	  # Clean up the generated files.
-	  $show "$rm $output_objdir/$dlsyms $nlist ${nlist}S ${nlist}T"
-	  $run $rm "$output_objdir/$dlsyms" "$nlist" "${nlist}S" "${nlist}T"
-
-	  # Transform the symbol file into the correct name.
-	  compile_command=`$echo "X$compile_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%"`
-	  finalize_command=`$echo "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%"`
-	  ;;
-	*)
-	  $echo "$modename: unknown suffix for \`$dlsyms'" 1>&2
-	  exit $EXIT_FAILURE
-	  ;;
-	esac
-      else
-	# We keep going just in case the user didn't refer to
-	# lt_preloaded_symbols.  The linker will fail if global_symbol_pipe
-	# really was required.
-
-	# Nullify the symbol file.
-	compile_command=`$echo "X$compile_command" | $Xsed -e "s% @SYMFILE@%%"`
-	finalize_command=`$echo "X$finalize_command" | $Xsed -e "s% @SYMFILE@%%"`
-      fi
-
-      if test "$need_relink" = no || test "$build_libtool_libs" != yes; then
-	# Replace the output file specification.
-	compile_command=`$echo "X$compile_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'`
-	link_command="$compile_command$compile_rpath"
-
-	# We have no uninstalled library dependencies, so finalize right now.
-	$show "$link_command"
-	$run eval "$link_command"
-	status=$?
-
-	# Delete the generated files.
-	if test -n "$dlsyms"; then
-	  $show "$rm $output_objdir/${outputname}S.${objext}"
-	  $run $rm "$output_objdir/${outputname}S.${objext}"
-	fi
-
-	exit $status
-      fi
-
-      if test -n "$shlibpath_var"; then
-	# We should set the shlibpath_var
-	rpath=
-	for dir in $temp_rpath; do
-	  case $dir in
-	  [\\/]* | [A-Za-z]:[\\/]*)
-	    # Absolute path.
-	    rpath="$rpath$dir:"
-	    ;;
-	  *)
-	    # Relative path: add a thisdir entry.
-	    rpath="$rpath\$thisdir/$dir:"
-	    ;;
-	  esac
-	done
-	temp_rpath="$rpath"
-      fi
-
-      if test -n "$compile_shlibpath$finalize_shlibpath"; then
-	compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command"
-      fi
-      if test -n "$finalize_shlibpath"; then
-	finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command"
-      fi
-
-      compile_var=
-      finalize_var=
-      if test -n "$runpath_var"; then
-	if test -n "$perm_rpath"; then
-	  # We should set the runpath_var.
-	  rpath=
-	  for dir in $perm_rpath; do
-	    rpath="$rpath$dir:"
-	  done
-	  compile_var="$runpath_var=\"$rpath\$$runpath_var\" "
-	fi
-	if test -n "$finalize_perm_rpath"; then
-	  # We should set the runpath_var.
-	  rpath=
-	  for dir in $finalize_perm_rpath; do
-	    rpath="$rpath$dir:"
-	  done
-	  finalize_var="$runpath_var=\"$rpath\$$runpath_var\" "
-	fi
-      fi
-
-      if test "$no_install" = yes; then
-	# We don't need to create a wrapper script.
-	link_command="$compile_var$compile_command$compile_rpath"
-	# Replace the output file specification.
-	link_command=`$echo "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'`
-	# Delete the old output file.
-	$run $rm $output
-	# Link the executable and exit
-	$show "$link_command"
-	$run eval "$link_command" || exit $?
-	exit $EXIT_SUCCESS
-      fi
-
-      if test "$hardcode_action" = relink; then
-	# Fast installation is not supported
-	link_command="$compile_var$compile_command$compile_rpath"
-	relink_command="$finalize_var$finalize_command$finalize_rpath"
-
-	$echo "$modename: warning: this platform does not like uninstalled shared libraries" 1>&2
-	$echo "$modename: \`$output' will be relinked during installation" 1>&2
-      else
-	if test "$fast_install" != no; then
-	  link_command="$finalize_var$compile_command$finalize_rpath"
-	  if test "$fast_install" = yes; then
-	    relink_command=`$echo "X$compile_var$compile_command$compile_rpath" | $Xsed -e 's%@OUTPUT@%\$progdir/\$file%g'`
-	  else
-	    # fast_install is set to needless
-	    relink_command=
-	  fi
-	else
-	  link_command="$compile_var$compile_command$compile_rpath"
-	  relink_command="$finalize_var$finalize_command$finalize_rpath"
-	fi
-      fi
-
-      # Replace the output file specification.
-      link_command=`$echo "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'`
-
-      # Delete the old output files.
-      $run $rm $output $output_objdir/$outputname $output_objdir/lt-$outputname
-
-      $show "$link_command"
-      $run eval "$link_command" || exit $?
-
-      # Now create the wrapper script.
-      $show "creating $output"
-
-      # Quote the relink command for shipping.
-      if test -n "$relink_command"; then
-	# Preserve any variables that may affect compiler behavior
-	for var in $variables_saved_for_relink; do
-	  if eval test -z \"\${$var+set}\"; then
-	    relink_command="{ test -z \"\${$var+set}\" || unset $var || { $var=; export $var; }; }; $relink_command"
-	  elif eval var_value=\$$var; test -z "$var_value"; then
-	    relink_command="$var=; export $var; $relink_command"
-	  else
-	    var_value=`$echo "X$var_value" | $Xsed -e "$sed_quote_subst"`
-	    relink_command="$var=\"$var_value\"; export $var; $relink_command"
-	  fi
-	done
-	relink_command="(cd `pwd`; $relink_command)"
-	relink_command=`$echo "X$relink_command" | $Xsed -e "$sed_quote_subst"`
-      fi
-
-      # Quote $echo for shipping.
-      if test "X$echo" = "X$SHELL $progpath --fallback-echo"; then
-	case $progpath in
-	[\\/]* | [A-Za-z]:[\\/]*) qecho="$SHELL $progpath --fallback-echo";;
-	*) qecho="$SHELL `pwd`/$progpath --fallback-echo";;
-	esac
-	qecho=`$echo "X$qecho" | $Xsed -e "$sed_quote_subst"`
-      else
-	qecho=`$echo "X$echo" | $Xsed -e "$sed_quote_subst"`
-      fi
-
-      # Only actually do things if our run command is non-null.
-      if test -z "$run"; then
-	# win32 will think the script is a binary if it has
-	# a .exe suffix, so we strip it off here.
-	case $output in
-	  *.exe) output=`$echo $output|${SED} 's,.exe$,,'` ;;
-	esac
-	# test for cygwin because mv fails w/o .exe extensions
-	case $host in
-	  *cygwin*)
-	    exeext=.exe
-	    outputname=`$echo $outputname|${SED} 's,.exe$,,'` ;;
-	  *) exeext= ;;
-	esac
-	case $host in
-	  *cygwin* | *mingw* )
-	    cwrappersource=`$echo ${objdir}/lt-${outputname}.c`
-	    cwrapper=`$echo ${output}.exe`
-	    $rm $cwrappersource $cwrapper
-	    trap "$rm $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15
-
-	    cat > $cwrappersource <<EOF
-
-/* $cwrappersource - temporary wrapper executable for $objdir/$outputname
-   Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP
-
-   The $output program cannot be directly executed until all the libtool
-   libraries that it depends on are installed.
-
-   This wrapper executable should never be moved out of the build directory.
-   If it is, it will not operate correctly.
-
-   Currently, it simply execs the wrapper *script* "/bin/sh $output",
-   but could eventually absorb all of the scripts functionality and
-   exec $objdir/$outputname directly.
-*/
-EOF
-	    cat >> $cwrappersource<<"EOF"
-#include <stdio.h>
-#include <stdlib.h>
-#include <unistd.h>
-#include <malloc.h>
-#include <stdarg.h>
-#include <assert.h>
-
-#if defined(PATH_MAX)
-# define LT_PATHMAX PATH_MAX
-#elif defined(MAXPATHLEN)
-# define LT_PATHMAX MAXPATHLEN
-#else
-# define LT_PATHMAX 1024
-#endif
-
-#ifndef DIR_SEPARATOR
-#define DIR_SEPARATOR '/'
-#endif
-
-#if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \
-  defined (__OS2__)
-#define HAVE_DOS_BASED_FILE_SYSTEM
-#ifndef DIR_SEPARATOR_2
-#define DIR_SEPARATOR_2 '\\'
-#endif
-#endif
-
-#ifndef DIR_SEPARATOR_2
-# define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR)
-#else /* DIR_SEPARATOR_2 */
-# define IS_DIR_SEPARATOR(ch) \
-        (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2))
-#endif /* DIR_SEPARATOR_2 */
-
-#define XMALLOC(type, num)      ((type *) xmalloc ((num) * sizeof(type)))
-#define XFREE(stale) do { \
-  if (stale) { free ((void *) stale); stale = 0; } \
-} while (0)
-
-const char *program_name = NULL;
-
-void * xmalloc (size_t num);
-char * xstrdup (const char *string);
-char * basename (const char *name);
-char * fnqualify(const char *path);
-char * strendzap(char *str, const char *pat);
-void lt_fatal (const char *message, ...);
-
-int
-main (int argc, char *argv[])
-{
-  char **newargz;
-  int i;
-
-  program_name = (char *) xstrdup ((char *) basename (argv[0]));
-  newargz = XMALLOC(char *, argc+2);
-EOF
-
-	    cat >> $cwrappersource <<EOF
-  newargz[0] = "$SHELL";
-EOF
-
-	    cat >> $cwrappersource <<"EOF"
-  newargz[1] = fnqualify(argv[0]);
-  /* we know the script has the same name, without the .exe */
-  /* so make sure newargz[1] doesn't end in .exe */
-  strendzap(newargz[1],".exe");
-  for (i = 1; i < argc; i++)
-    newargz[i+1] = xstrdup(argv[i]);
-  newargz[argc+1] = NULL;
-EOF
-
-	    cat >> $cwrappersource <<EOF
-  execv("$SHELL",newargz);
-EOF
-
-	    cat >> $cwrappersource <<"EOF"
-}
-
-void *
-xmalloc (size_t num)
-{
-  void * p = (void *) malloc (num);
-  if (!p)
-    lt_fatal ("Memory exhausted");
-
-  return p;
-}
-
-char *
-xstrdup (const char *string)
-{
-  return string ? strcpy ((char *) xmalloc (strlen (string) + 1), string) : NULL
-;
-}
-
-char *
-basename (const char *name)
-{
-  const char *base;
-
-#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
-  /* Skip over the disk name in MSDOS pathnames. */
-  if (isalpha (name[0]) && name[1] == ':')
-    name += 2;
-#endif
-
-  for (base = name; *name; name++)
-    if (IS_DIR_SEPARATOR (*name))
-      base = name + 1;
-  return (char *) base;
-}
-
-char *
-fnqualify(const char *path)
-{
-  size_t size;
-  char *p;
-  char tmp[LT_PATHMAX + 1];
-
-  assert(path != NULL);
-
-  /* Is it qualified already? */
-#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
-  if (isalpha (path[0]) && path[1] == ':')
-    return xstrdup (path);
-#endif
-  if (IS_DIR_SEPARATOR (path[0]))
-    return xstrdup (path);
-
-  /* prepend the current directory */
-  /* doesn't handle '~' */
-  if (getcwd (tmp, LT_PATHMAX) == NULL)
-    lt_fatal ("getcwd failed");
-  size = strlen(tmp) + 1 + strlen(path) + 1; /* +2 for '/' and '\0' */
-  p = XMALLOC(char, size);
-  sprintf(p, "%s%c%s", tmp, DIR_SEPARATOR, path);
-  return p;
-}
-
-char *
-strendzap(char *str, const char *pat)
-{
-  size_t len, patlen;
-
-  assert(str != NULL);
-  assert(pat != NULL);
-
-  len = strlen(str);
-  patlen = strlen(pat);
-
-  if (patlen <= len)
-  {
-    str += len - patlen;
-    if (strcmp(str, pat) == 0)
-      *str = '\0';
-  }
-  return str;
-}
-
-static void
-lt_error_core (int exit_status, const char * mode,
-          const char * message, va_list ap)
-{
-  fprintf (stderr, "%s: %s: ", program_name, mode);
-  vfprintf (stderr, message, ap);
-  fprintf (stderr, ".\n");
-
-  if (exit_status >= 0)
-    exit (exit_status);
-}
-
-void
-lt_fatal (const char *message, ...)
-{
-  va_list ap;
-  va_start (ap, message);
-  lt_error_core (EXIT_FAILURE, "FATAL", message, ap);
-  va_end (ap);
-}
-EOF
-	  # we should really use a build-platform specific compiler
-	  # here, but OTOH, the wrappers (shell script and this C one)
-	  # are only useful if you want to execute the "real" binary.
-	  # Since the "real" binary is built for $host, then this
-	  # wrapper might as well be built for $host, too.
-	  $run $LTCC -s -o $cwrapper $cwrappersource
-	  ;;
-	esac
-	$rm $output
-	trap "$rm $output; exit $EXIT_FAILURE" 1 2 15
-
-	$echo > $output "\
-#! $SHELL
-
-# $output - temporary wrapper script for $objdir/$outputname
-# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP
-#
-# The $output program cannot be directly executed until all the libtool
-# libraries that it depends on are installed.
-#
-# This wrapper script should never be moved out of the build directory.
-# If it is, it will not operate correctly.
-
-# Sed substitution that helps us do robust quoting.  It backslashifies
-# metacharacters that are still active within double-quoted strings.
-Xsed='${SED} -e 1s/^X//'
-sed_quote_subst='$sed_quote_subst'
-
-# The HP-UX ksh and POSIX shell print the target directory to stdout
-# if CDPATH is set.
-(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
-
-relink_command=\"$relink_command\"
-
-# This environment variable determines our operation mode.
-if test \"\$libtool_install_magic\" = \"$magic\"; then
-  # install mode needs the following variable:
-  notinst_deplibs='$notinst_deplibs'
-else
-  # When we are sourced in execute mode, \$file and \$echo are already set.
-  if test \"\$libtool_execute_magic\" != \"$magic\"; then
-    echo=\"$qecho\"
-    file=\"\$0\"
-    # Make sure echo works.
-    if test \"X\$1\" = X--no-reexec; then
-      # Discard the --no-reexec flag, and continue.
-      shift
-    elif test \"X\`(\$echo '\t') 2>/dev/null\`\" = 'X\t'; then
-      # Yippee, \$echo works!
-      :
-    else
-      # Restart under the correct shell, and then maybe \$echo will work.
-      exec $SHELL \"\$0\" --no-reexec \${1+\"\$@\"}
-    fi
-  fi\
-"
-	$echo >> $output "\
-
-  # Find the directory that this script lives in.
-  thisdir=\`\$echo \"X\$file\" | \$Xsed -e 's%/[^/]*$%%'\`
-  test \"x\$thisdir\" = \"x\$file\" && thisdir=.
-
-  # Follow symbolic links until we get to the real thisdir.
-  file=\`ls -ld \"\$file\" | ${SED} -n 's/.*-> //p'\`
-  while test -n \"\$file\"; do
-    destdir=\`\$echo \"X\$file\" | \$Xsed -e 's%/[^/]*\$%%'\`
-
-    # If there was a directory component, then change thisdir.
-    if test \"x\$destdir\" != \"x\$file\"; then
-      case \"\$destdir\" in
-      [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;;
-      *) thisdir=\"\$thisdir/\$destdir\" ;;
-      esac
-    fi
-
-    file=\`\$echo \"X\$file\" | \$Xsed -e 's%^.*/%%'\`
-    file=\`ls -ld \"\$thisdir/\$file\" | ${SED} -n 's/.*-> //p'\`
-  done
-
-  # Try to get the absolute directory name.
-  absdir=\`cd \"\$thisdir\" && pwd\`
-  test -n \"\$absdir\" && thisdir=\"\$absdir\"
-"
-
-	if test "$fast_install" = yes; then
-	  $echo >> $output "\
-  program=lt-'$outputname'$exeext
-  progdir=\"\$thisdir/$objdir\"
-
-  if test ! -f \"\$progdir/\$program\" || \\
-     { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | ${SED} 1q\`; \\
-       test \"X\$file\" != \"X\$progdir/\$program\"; }; then
-
-    file=\"\$\$-\$program\"
-
-    if test ! -d \"\$progdir\"; then
-      $mkdir \"\$progdir\"
-    else
-      $rm \"\$progdir/\$file\"
-    fi"
-
-	  $echo >> $output "\
-
-    # relink executable if necessary
-    if test -n \"\$relink_command\"; then
-      if relink_command_output=\`eval \$relink_command 2>&1\`; then :
-      else
-	$echo \"\$relink_command_output\" >&2
-	$rm \"\$progdir/\$file\"
-	exit $EXIT_FAILURE
-      fi
-    fi
-
-    $mv \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null ||
-    { $rm \"\$progdir/\$program\";
-      $mv \"\$progdir/\$file\" \"\$progdir/\$program\"; }
-    $rm \"\$progdir/\$file\"
-  fi"
-	else
-	  $echo >> $output "\
-  program='$outputname'
-  progdir=\"\$thisdir/$objdir\"
-"
-	fi
-
-	$echo >> $output "\
-
-  if test -f \"\$progdir/\$program\"; then"
-
-	# Export our shlibpath_var if we have one.
-	if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
-	  $echo >> $output "\
-    # Add our own library path to $shlibpath_var
-    $shlibpath_var=\"$temp_rpath\$$shlibpath_var\"
-
-    # Some systems cannot cope with colon-terminated $shlibpath_var
-    # The second colon is a workaround for a bug in BeOS R4 sed
-    $shlibpath_var=\`\$echo \"X\$$shlibpath_var\" | \$Xsed -e 's/::*\$//'\`
-
-    export $shlibpath_var
-"
-	fi
-
-	# fixup the dll searchpath if we need to.
-	if test -n "$dllsearchpath"; then
-	  $echo >> $output "\
-    # Add the dll search path components to the executable PATH
-    PATH=$dllsearchpath:\$PATH
-"
-	fi
-
-	$echo >> $output "\
-    if test \"\$libtool_execute_magic\" != \"$magic\"; then
-      # Run the actual program with our arguments.
-"
-	case $host in
-	# Backslashes separate directories on plain windows
-	*-*-mingw | *-*-os2*)
-	  $echo >> $output "\
-      exec \$progdir\\\\\$program \${1+\"\$@\"}
-"
-	  ;;
-
-	*)
-	  $echo >> $output "\
-      exec \$progdir/\$program \${1+\"\$@\"}
-"
-	  ;;
-	esac
-	$echo >> $output "\
-      \$echo \"\$0: cannot exec \$program \${1+\"\$@\"}\"
-      exit $EXIT_FAILURE
-    fi
-  else
-    # The program doesn't exist.
-    \$echo \"\$0: error: \$progdir/\$program does not exist\" 1>&2
-    \$echo \"This script is just a wrapper for \$program.\" 1>&2
-    $echo \"See the $PACKAGE documentation for more information.\" 1>&2
-    exit $EXIT_FAILURE
-  fi
-fi\
-"
-	chmod +x $output
-      fi
-      exit $EXIT_SUCCESS
-      ;;
-    esac
-
-    # See if we need to build an old-fashioned archive.
-    for oldlib in $oldlibs; do
-
-      if test "$build_libtool_libs" = convenience; then
-	oldobjs="$libobjs_save"
-	addlibs="$convenience"
-	build_libtool_libs=no
-      else
-	if test "$build_libtool_libs" = module; then
-	  oldobjs="$libobjs_save"
-	  build_libtool_libs=no
-	else
-	  oldobjs="$old_deplibs $non_pic_objects"
-	fi
-	addlibs="$old_convenience"
-      fi
-
-      if test -n "$addlibs"; then
-	gentop="$output_objdir/${outputname}x"
-	generated="$generated $gentop"
-
-	func_extract_archives $gentop $addlibs
-	oldobjs="$oldobjs $func_extract_archives_result"
-      fi
-
-      # Do each command in the archive commands.
-      if test -n "$old_archive_from_new_cmds" && test "$build_libtool_libs" = yes; then
-       cmds=$old_archive_from_new_cmds
-      else
-	# POSIX demands no paths to be encoded in archives.  We have
-	# to avoid creating archives with duplicate basenames if we
-	# might have to extract them afterwards, e.g., when creating a
-	# static archive out of a convenience library, or when linking
-	# the entirety of a libtool archive into another (currently
-	# not supported by libtool).
-	if (for obj in $oldobjs
-	    do
-	      $echo "X$obj" | $Xsed -e 's%^.*/%%'
-	    done | sort | sort -uc >/dev/null 2>&1); then
-	  :
-	else
-	  $echo "copying selected object files to avoid basename conflicts..."
-
-	  if test -z "$gentop"; then
-	    gentop="$output_objdir/${outputname}x"
-	    generated="$generated $gentop"
-
-	    $show "${rm}r $gentop"
-	    $run ${rm}r "$gentop"
-	    $show "$mkdir $gentop"
-	    $run $mkdir "$gentop"
-	    status=$?
-	    if test "$status" -ne 0 && test ! -d "$gentop"; then
-	      exit $status
-	    fi
-	  fi
-
-	  save_oldobjs=$oldobjs
-	  oldobjs=
-	  counter=1
-	  for obj in $save_oldobjs
-	  do
-	    objbase=`$echo "X$obj" | $Xsed -e 's%^.*/%%'`
-	    case " $oldobjs " in
-	    " ") oldobjs=$obj ;;
-	    *[\ /]"$objbase "*)
-	      while :; do
-		# Make sure we don't pick an alternate name that also
-		# overlaps.
-		newobj=lt$counter-$objbase
-		counter=`expr $counter + 1`
-		case " $oldobjs " in
-		*[\ /]"$newobj "*) ;;
-		*) if test ! -f "$gentop/$newobj"; then break; fi ;;
-		esac
-	      done
-	      $show "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj"
-	      $run ln "$obj" "$gentop/$newobj" ||
-	      $run cp "$obj" "$gentop/$newobj"
-	      oldobjs="$oldobjs $gentop/$newobj"
-	      ;;
-	    *) oldobjs="$oldobjs $obj" ;;
-	    esac
-	  done
-	fi
-
-	eval cmds=\"$old_archive_cmds\"
-
-	if len=`expr "X$cmds" : ".*"` &&
-	     test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then
-	  cmds=$old_archive_cmds
-	else
-	  # the command line is too long to link in one step, link in parts
-	  $echo "using piecewise archive linking..."
-	  save_RANLIB=$RANLIB
-	  RANLIB=:
-	  objlist=
-	  concat_cmds=
-	  save_oldobjs=$oldobjs
-
-	  # Is there a better way of finding the last object in the list?
-	  for obj in $save_oldobjs
-	  do
-	    last_oldobj=$obj
-	  done
-	  for obj in $save_oldobjs
-	  do
-	    oldobjs="$objlist $obj"
-	    objlist="$objlist $obj"
-	    eval test_cmds=\"$old_archive_cmds\"
-	    if len=`expr "X$test_cmds" : ".*"` &&
-	       test "$len" -le "$max_cmd_len"; then
-	      :
-	    else
-	      # the above command should be used before it gets too long
-	      oldobjs=$objlist
-	      if test "$obj" = "$last_oldobj" ; then
-	        RANLIB=$save_RANLIB
-	      fi
-	      test -z "$concat_cmds" || concat_cmds=$concat_cmds~
-	      eval concat_cmds=\"\${concat_cmds}$old_archive_cmds\"
-	      objlist=
-	    fi
-	  done
-	  RANLIB=$save_RANLIB
-	  oldobjs=$objlist
-	  if test "X$oldobjs" = "X" ; then
-	    eval cmds=\"\$concat_cmds\"
-	  else
-	    eval cmds=\"\$concat_cmds~\$old_archive_cmds\"
-	  fi
-	fi
-      fi
-      save_ifs="$IFS"; IFS='~'
-      for cmd in $cmds; do
-        eval cmd=\"$cmd\"
-	IFS="$save_ifs"
-	$show "$cmd"
-	$run eval "$cmd" || exit $?
-      done
-      IFS="$save_ifs"
-    done
-
-    if test -n "$generated"; then
-      $show "${rm}r$generated"
-      $run ${rm}r$generated
-    fi
-
-    # Now create the libtool archive.
-    case $output in
-    *.la)
-      old_library=
-      test "$build_old_libs" = yes && old_library="$libname.$libext"
-      $show "creating $output"
-
-      # Preserve any variables that may affect compiler behavior
-      for var in $variables_saved_for_relink; do
-	if eval test -z \"\${$var+set}\"; then
-	  relink_command="{ test -z \"\${$var+set}\" || unset $var || { $var=; export $var; }; }; $relink_command"
-	elif eval var_value=\$$var; test -z "$var_value"; then
-	  relink_command="$var=; export $var; $relink_command"
-	else
-	  var_value=`$echo "X$var_value" | $Xsed -e "$sed_quote_subst"`
-	  relink_command="$var=\"$var_value\"; export $var; $relink_command"
-	fi
-      done
-      # Quote the link command for shipping.
-      relink_command="(cd `pwd`; $SHELL $progpath $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)"
-      relink_command=`$echo "X$relink_command" | $Xsed -e "$sed_quote_subst"`
-      if test "$hardcode_automatic" = yes ; then
-	relink_command=
-      fi
-
-
-      # Only create the output if not a dry run.
-      if test -z "$run"; then
-	for installed in no yes; do
-	  if test "$installed" = yes; then
-	    if test -z "$install_libdir"; then
-	      break
-	    fi
-	    output="$output_objdir/$outputname"i
-	    # Replace all uninstalled libtool libraries with the installed ones
-	    newdependency_libs=
-	    for deplib in $dependency_libs; do
-	      case $deplib in
-	      *.la)
-		name=`$echo "X$deplib" | $Xsed -e 's%^.*/%%'`
-		eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
-		if test -z "$libdir"; then
-		  $echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2
-		  exit $EXIT_FAILURE
-		fi
-		newdependency_libs="$newdependency_libs $libdir/$name"
-		;;
-	      *) newdependency_libs="$newdependency_libs $deplib" ;;
-	      esac
-	    done
-	    dependency_libs="$newdependency_libs"
-	    newdlfiles=
-	    for lib in $dlfiles; do
-	      name=`$echo "X$lib" | $Xsed -e 's%^.*/%%'`
-	      eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
-	      if test -z "$libdir"; then
-		$echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
-		exit $EXIT_FAILURE
-	      fi
-	      newdlfiles="$newdlfiles $libdir/$name"
-	    done
-	    dlfiles="$newdlfiles"
-	    newdlprefiles=
-	    for lib in $dlprefiles; do
-	      name=`$echo "X$lib" | $Xsed -e 's%^.*/%%'`
-	      eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
-	      if test -z "$libdir"; then
-		$echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
-		exit $EXIT_FAILURE
-	      fi
-	      newdlprefiles="$newdlprefiles $libdir/$name"
-	    done
-	    dlprefiles="$newdlprefiles"
-	  else
-	    newdlfiles=
-	    for lib in $dlfiles; do
-	      case $lib in
-		[\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
-		*) abs=`pwd`"/$lib" ;;
-	      esac
-	      newdlfiles="$newdlfiles $abs"
-	    done
-	    dlfiles="$newdlfiles"
-	    newdlprefiles=
-	    for lib in $dlprefiles; do
-	      case $lib in
-		[\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
-		*) abs=`pwd`"/$lib" ;;
-	      esac
-	      newdlprefiles="$newdlprefiles $abs"
-	    done
-	    dlprefiles="$newdlprefiles"
-	  fi
-	  $rm $output
-	  # place dlname in correct position for cygwin
-	  tdlname=$dlname
-	  case $host,$output,$installed,$module,$dlname in
-	    *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll) tdlname=../bin/$dlname ;;
-	  esac
-	  $echo > $output "\
-# $outputname - a libtool library file
-# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP
-#
-# Please DO NOT delete this file!
-# It is necessary for linking the library.
-
-# The name that we can dlopen(3).
-dlname='$tdlname'
-
-# Names of this library.
-library_names='$library_names'
-
-# The name of the static archive.
-old_library='$old_library'
-
-# Libraries that this one depends upon.
-dependency_libs='$dependency_libs'
-
-# Version information for $libname.
-current=$current
-age=$age
-revision=$revision
-
-# Is this an already installed library?
-installed=$installed
-
-# Should we warn about portability when linking against -modules?
-shouldnotlink=$module
-
-# Files to dlopen/dlpreopen
-dlopen='$dlfiles'
-dlpreopen='$dlprefiles'
-
-# Directory that this library needs to be installed in:
-libdir='$install_libdir'"
-	  if test "$installed" = no && test "$need_relink" = yes; then
-	    $echo >> $output "\
-relink_command=\"$relink_command\""
-	  fi
-	done
-      fi
-
-      # Do a symbolic link so that the libtool archive can be found in
-      # LD_LIBRARY_PATH before the program is installed.
-      $show "(cd $output_objdir && $rm $outputname && $LN_S ../$outputname $outputname)"
-      $run eval '(cd $output_objdir && $rm $outputname && $LN_S ../$outputname $outputname)' || exit $?
-      ;;
-    esac
-    exit $EXIT_SUCCESS
-    ;;
-
-  # libtool install mode
-  install)
-    modename="$modename: install"
-
-    # There may be an optional sh(1) argument at the beginning of
-    # install_prog (especially on Windows NT).
-    if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh ||
-       # Allow the use of GNU shtool's install command.
-       $echo "X$nonopt" | $Xsed | grep shtool > /dev/null; then
-      # Aesthetically quote it.
-      arg=`$echo "X$nonopt" | $Xsed -e "$sed_quote_subst"`
-      case $arg in
-      *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	arg="\"$arg\""
-	;;
-      esac
-      install_prog="$arg "
-      arg="$1"
-      shift
-    else
-      install_prog=
-      arg="$nonopt"
-    fi
-
-    # The real first argument should be the name of the installation program.
-    # Aesthetically quote it.
-    arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
-    case $arg in
-    *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-      arg="\"$arg\""
-      ;;
-    esac
-    install_prog="$install_prog$arg"
-
-    # We need to accept at least all the BSD install flags.
-    dest=
-    files=
-    opts=
-    prev=
-    install_type=
-    isdir=no
-    stripme=
-    for arg
-    do
-      if test -n "$dest"; then
-	files="$files $dest"
-	dest="$arg"
-	continue
-      fi
-
-      case $arg in
-      -d) isdir=yes ;;
-      -f) prev="-f" ;;
-      -g) prev="-g" ;;
-      -m) prev="-m" ;;
-      -o) prev="-o" ;;
-      -s)
-	stripme=" -s"
-	continue
-	;;
-      -*) ;;
-
-      *)
-	# If the previous option needed an argument, then skip it.
-	if test -n "$prev"; then
-	  prev=
-	else
-	  dest="$arg"
-	  continue
-	fi
-	;;
-      esac
-
-      # Aesthetically quote the argument.
-      arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
-      case $arg in
-      *$quote_scanset* | *]* | *\|* | *\&* | *\(* | *\)* | "")
-	arg="\"$arg\""
-	;;
-      esac
-      install_prog="$install_prog $arg"
-    done
-
-    if test -z "$install_prog"; then
-      $echo "$modename: you must specify an install program" 1>&2
-      $echo "$help" 1>&2
-      exit $EXIT_FAILURE
-    fi
-
-    if test -n "$prev"; then
-      $echo "$modename: the \`$prev' option requires an argument" 1>&2
-      $echo "$help" 1>&2
-      exit $EXIT_FAILURE
-    fi
-
-    if test -z "$files"; then
-      if test -z "$dest"; then
-	$echo "$modename: no file or destination specified" 1>&2
-      else
-	$echo "$modename: you must specify a destination" 1>&2
-      fi
-      $echo "$help" 1>&2
-      exit $EXIT_FAILURE
-    fi
-
-    # Strip any trailing slash from the destination.
-    dest=`$echo "X$dest" | $Xsed -e 's%/$%%'`
-
-    # Check to see that the destination is a directory.
-    test -d "$dest" && isdir=yes
-    if test "$isdir" = yes; then
-      destdir="$dest"
-      destname=
-    else
-      destdir=`$echo "X$dest" | $Xsed -e 's%/[^/]*$%%'`
-      test "X$destdir" = "X$dest" && destdir=.
-      destname=`$echo "X$dest" | $Xsed -e 's%^.*/%%'`
-
-      # Not a directory, so check to see that there is only one file specified.
-      set dummy $files
-      if test "$#" -gt 2; then
-	$echo "$modename: \`$dest' is not a directory" 1>&2
-	$echo "$help" 1>&2
-	exit $EXIT_FAILURE
-      fi
-    fi
-    case $destdir in
-    [\\/]* | [A-Za-z]:[\\/]*) ;;
-    *)
-      for file in $files; do
-	case $file in
-	*.lo) ;;
-	*)
-	  $echo "$modename: \`$destdir' must be an absolute directory name" 1>&2
-	  $echo "$help" 1>&2
-	  exit $EXIT_FAILURE
-	  ;;
-	esac
-      done
-      ;;
-    esac
-
-    # This variable tells wrapper scripts just to set variables rather
-    # than running their programs.
-    libtool_install_magic="$magic"
-
-    staticlibs=
-    future_libdirs=
-    current_libdirs=
-    for file in $files; do
-
-      # Do each installation.
-      case $file in
-      *.$libext)
-	# Do the static libraries later.
-	staticlibs="$staticlibs $file"
-	;;
-
-      *.la)
-	# Check to see that this really is a libtool archive.
-	if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
-	else
-	  $echo "$modename: \`$file' is not a valid libtool archive" 1>&2
-	  $echo "$help" 1>&2
-	  exit $EXIT_FAILURE
-	fi
-
-	library_names=
-	old_library=
-	relink_command=
-	# If there is no directory component, then add one.
-	case $file in
-	*/* | *\\*) . $file ;;
-	*) . ./$file ;;
-	esac
-
-	# Add the libdir to current_libdirs if it is the destination.
-	if test "X$destdir" = "X$libdir"; then
-	  case "$current_libdirs " in
-	  *" $libdir "*) ;;
-	  *) current_libdirs="$current_libdirs $libdir" ;;
-	  esac
-	else
-	  # Note the libdir as a future libdir.
-	  case "$future_libdirs " in
-	  *" $libdir "*) ;;
-	  *) future_libdirs="$future_libdirs $libdir" ;;
-	  esac
-	fi
-
-	dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'`/
-	test "X$dir" = "X$file/" && dir=
-	dir="$dir$objdir"
-
-	if test -n "$relink_command"; then
-	  # Determine the prefix the user has applied to our future dir.
-	  inst_prefix_dir=`$echo "$destdir" | $SED "s%$libdir\$%%"`
-
-	  # Don't allow the user to place us outside of our expected
-	  # location b/c this prevents finding dependent libraries that
-	  # are installed to the same prefix.
-	  # At present, this check doesn't affect windows .dll's that
-	  # are installed into $libdir/../bin (currently, that works fine)
-	  # but it's something to keep an eye on.
-	  if test "$inst_prefix_dir" = "$destdir"; then
-	    $echo "$modename: error: cannot install \`$file' to a directory not ending in $libdir" 1>&2
-	    exit $EXIT_FAILURE
-	  fi
-
-	  if test -n "$inst_prefix_dir"; then
-	    # Stick the inst_prefix_dir data into the link command.
-	    relink_command=`$echo "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"`
-	  else
-	    relink_command=`$echo "$relink_command" | $SED "s%@inst_prefix_dir@%%"`
-	  fi
-
-	  $echo "$modename: warning: relinking \`$file'" 1>&2
-	  $show "$relink_command"
-	  if $run eval "$relink_command"; then :
-	  else
-	    $echo "$modename: error: relink \`$file' with the above command before installing it" 1>&2
-	    exit $EXIT_FAILURE
-	  fi
-	fi
-
-	# See the names of the shared library.
-	set dummy $library_names
-	if test -n "$2"; then
-	  realname="$2"
-	  shift
-	  shift
-
-	  srcname="$realname"
-	  test -n "$relink_command" && srcname="$realname"T
-
-	  # Install the shared library and build the symlinks.
-	  $show "$install_prog $dir/$srcname $destdir/$realname"
-	  $run eval "$install_prog $dir/$srcname $destdir/$realname" || exit $?
-	  if test -n "$stripme" && test -n "$striplib"; then
-	    $show "$striplib $destdir/$realname"
-	    $run eval "$striplib $destdir/$realname" || exit $?
-	  fi
-
-	  if test "$#" -gt 0; then
-	    # Delete the old symlinks, and create new ones.
-	    for linkname
-	    do
-	      if test "$linkname" != "$realname"; then
-		$show "(cd $destdir && $rm $linkname && $LN_S $realname $linkname)"
-		$run eval "(cd $destdir && $rm $linkname && $LN_S $realname $linkname)"
-	      fi
-	    done
-	  fi
-
-	  # Do each command in the postinstall commands.
-	  lib="$destdir/$realname"
-	  cmds=$postinstall_cmds
-	  save_ifs="$IFS"; IFS='~'
-	  for cmd in $cmds; do
-	    IFS="$save_ifs"
-	    eval cmd=\"$cmd\"
-	    $show "$cmd"
-	    $run eval "$cmd" || exit $?
-	  done
-	  IFS="$save_ifs"
-	fi
-
-	# Install the pseudo-library for information purposes.
-	name=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
-	instname="$dir/$name"i
-	$show "$install_prog $instname $destdir/$name"
-	$run eval "$install_prog $instname $destdir/$name" || exit $?
-
-	# Maybe install the static library, too.
-	test -n "$old_library" && staticlibs="$staticlibs $dir/$old_library"
-	;;
-
-      *.lo)
-	# Install (i.e. copy) a libtool object.
-
-	# Figure out destination file name, if it wasn't already specified.
-	if test -n "$destname"; then
-	  destfile="$destdir/$destname"
-	else
-	  destfile=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
-	  destfile="$destdir/$destfile"
-	fi
-
-	# Deduce the name of the destination old-style object file.
-	case $destfile in
-	*.lo)
-	  staticdest=`$echo "X$destfile" | $Xsed -e "$lo2o"`
-	  ;;
-	*.$objext)
-	  staticdest="$destfile"
-	  destfile=
-	  ;;
-	*)
-	  $echo "$modename: cannot copy a libtool object to \`$destfile'" 1>&2
-	  $echo "$help" 1>&2
-	  exit $EXIT_FAILURE
-	  ;;
-	esac
-
-	# Install the libtool object if requested.
-	if test -n "$destfile"; then
-	  $show "$install_prog $file $destfile"
-	  $run eval "$install_prog $file $destfile" || exit $?
-	fi
-
-	# Install the old object if enabled.
-	if test "$build_old_libs" = yes; then
-	  # Deduce the name of the old-style object file.
-	  staticobj=`$echo "X$file" | $Xsed -e "$lo2o"`
-
-	  $show "$install_prog $staticobj $staticdest"
-	  $run eval "$install_prog \$staticobj \$staticdest" || exit $?
-	fi
-	exit $EXIT_SUCCESS
-	;;
-
-      *)
-	# Figure out destination file name, if it wasn't already specified.
-	if test -n "$destname"; then
-	  destfile="$destdir/$destname"
-	else
-	  destfile=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
-	  destfile="$destdir/$destfile"
-	fi
-
-	# If the file is missing, and there is a .exe on the end, strip it
-	# because it is most likely a libtool script we actually want to
-	# install
-	stripped_ext=""
-	case $file in
-	  *.exe)
-	    if test ! -f "$file"; then
-	      file=`$echo $file|${SED} 's,.exe$,,'`
-	      stripped_ext=".exe"
-	    fi
-	    ;;
-	esac
-
-	# Do a test to see if this is really a libtool program.
-	case $host in
-	*cygwin*|*mingw*)
-	    wrapper=`$echo $file | ${SED} -e 's,.exe$,,'`
-	    ;;
-	*)
-	    wrapper=$file
-	    ;;
-	esac
-	if (${SED} -e '4q' $wrapper | grep "^# Generated by .*$PACKAGE")>/dev/null 2>&1; then
-	  notinst_deplibs=
-	  relink_command=
-
-	  # To insure that "foo" is sourced, and not "foo.exe",
-	  # finese the cygwin/MSYS system by explicitly sourcing "foo."
-	  # which disallows the automatic-append-.exe behavior.
-	  case $build in
-	  *cygwin* | *mingw*) wrapperdot=${wrapper}. ;;
-	  *) wrapperdot=${wrapper} ;;
-	  esac
-	  # If there is no directory component, then add one.
-	  case $file in
-	  */* | *\\*) . ${wrapperdot} ;;
-	  *) . ./${wrapperdot} ;;
-	  esac
-
-	  # Check the variables that should have been set.
-	  if test -z "$notinst_deplibs"; then
-	    $echo "$modename: invalid libtool wrapper script \`$wrapper'" 1>&2
-	    exit $EXIT_FAILURE
-	  fi
-
-	  finalize=yes
-	  for lib in $notinst_deplibs; do
-	    # Check to see that each library is installed.
-	    libdir=
-	    if test -f "$lib"; then
-	      # If there is no directory component, then add one.
-	      case $lib in
-	      */* | *\\*) . $lib ;;
-	      *) . ./$lib ;;
-	      esac
-	    fi
-	    libfile="$libdir/"`$echo "X$lib" | $Xsed -e 's%^.*/%%g'` ### testsuite: skip nested quoting test
-	    if test -n "$libdir" && test ! -f "$libfile"; then
-	      $echo "$modename: warning: \`$lib' has not been installed in \`$libdir'" 1>&2
-	      finalize=no
-	    fi
-	  done
-
-	  relink_command=
-	  # To insure that "foo" is sourced, and not "foo.exe",
-	  # finese the cygwin/MSYS system by explicitly sourcing "foo."
-	  # which disallows the automatic-append-.exe behavior.
-	  case $build in
-	  *cygwin* | *mingw*) wrapperdot=${wrapper}. ;;
-	  *) wrapperdot=${wrapper} ;;
-	  esac
-	  # If there is no directory component, then add one.
-	  case $file in
-	  */* | *\\*) . ${wrapperdot} ;;
-	  *) . ./${wrapperdot} ;;
-	  esac
-
-	  outputname=
-	  if test "$fast_install" = no && test -n "$relink_command"; then
-	    if test "$finalize" = yes && test -z "$run"; then
-	      tmpdir="/tmp"
-	      test -n "$TMPDIR" && tmpdir="$TMPDIR"
-	      tmpdir="$tmpdir/libtool-$$"
-	      save_umask=`umask`
-	      umask 0077
-	      if $mkdir "$tmpdir"; then
-	        umask $save_umask
-	      else
-	        umask $save_umask
-		$echo "$modename: error: cannot create temporary directory \`$tmpdir'" 1>&2
-		continue
-	      fi
-	      file=`$echo "X$file$stripped_ext" | $Xsed -e 's%^.*/%%'`
-	      outputname="$tmpdir/$file"
-	      # Replace the output file specification.
-	      relink_command=`$echo "X$relink_command" | $Xsed -e 's%@OUTPUT@%'"$outputname"'%g'`
-
-	      $show "$relink_command"
-	      if $run eval "$relink_command"; then :
-	      else
-		$echo "$modename: error: relink \`$file' with the above command before installing it" 1>&2
-		${rm}r "$tmpdir"
-		continue
-	      fi
-	      file="$outputname"
-	    else
-	      $echo "$modename: warning: cannot relink \`$file'" 1>&2
-	    fi
-	  else
-	    # Install the binary that we compiled earlier.
-	    file=`$echo "X$file$stripped_ext" | $Xsed -e "s%\([^/]*\)$%$objdir/\1%"`
-	  fi
-	fi
-
-	# remove .exe since cygwin /usr/bin/install will append another
-	# one anyways
-	case $install_prog,$host in
-	*/usr/bin/install*,*cygwin*)
-	  case $file:$destfile in
-	  *.exe:*.exe)
-	    # this is ok
-	    ;;
-	  *.exe:*)
-	    destfile=$destfile.exe
-	    ;;
-	  *:*.exe)
-	    destfile=`$echo $destfile | ${SED} -e 's,.exe$,,'`
-	    ;;
-	  esac
-	  ;;
-	esac
-	$show "$install_prog$stripme $file $destfile"
-	$run eval "$install_prog\$stripme \$file \$destfile" || exit $?
-	test -n "$outputname" && ${rm}r "$tmpdir"
-	;;
-      esac
-    done
-
-    for file in $staticlibs; do
-      name=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
-
-      # Set up the ranlib parameters.
-      oldlib="$destdir/$name"
-
-      $show "$install_prog $file $oldlib"
-      $run eval "$install_prog \$file \$oldlib" || exit $?
-
-      if test -n "$stripme" && test -n "$old_striplib"; then
-	$show "$old_striplib $oldlib"
-	$run eval "$old_striplib $oldlib" || exit $?
-      fi
-
-      # Do each command in the postinstall commands.
-      cmds=$old_postinstall_cmds
-      save_ifs="$IFS"; IFS='~'
-      for cmd in $cmds; do
-	IFS="$save_ifs"
-	eval cmd=\"$cmd\"
-	$show "$cmd"
-	$run eval "$cmd" || exit $?
-      done
-      IFS="$save_ifs"
-    done
-
-    if test -n "$future_libdirs"; then
-      $echo "$modename: warning: remember to run \`$progname --finish$future_libdirs'" 1>&2
-    fi
-
-    if test -n "$current_libdirs"; then
-      # Maybe just do a dry run.
-      test -n "$run" && current_libdirs=" -n$current_libdirs"
-      exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs'
-    else
-      exit $EXIT_SUCCESS
-    fi
-    ;;
-
-  # libtool finish mode
-  finish)
-    modename="$modename: finish"
-    libdirs="$nonopt"
-    admincmds=
-
-    if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
-      for dir
-      do
-	libdirs="$libdirs $dir"
-      done
-
-      for libdir in $libdirs; do
-	if test -n "$finish_cmds"; then
-	  # Do each command in the finish commands.
-	  cmds=$finish_cmds
-	  save_ifs="$IFS"; IFS='~'
-	  for cmd in $cmds; do
-	    IFS="$save_ifs"
-	    eval cmd=\"$cmd\"
-	    $show "$cmd"
-	    $run eval "$cmd" || admincmds="$admincmds
-       $cmd"
-	  done
-	  IFS="$save_ifs"
-	fi
-	if test -n "$finish_eval"; then
-	  # Do the single finish_eval.
-	  eval cmds=\"$finish_eval\"
-	  $run eval "$cmds" || admincmds="$admincmds
-       $cmds"
-	fi
-      done
-    fi
-
-    # Exit here if they wanted silent mode.
-    test "$show" = : && exit $EXIT_SUCCESS
-
-    $echo "----------------------------------------------------------------------"
-    $echo "Libraries have been installed in:"
-    for libdir in $libdirs; do
-      $echo "   $libdir"
-    done
-    $echo
-    $echo "If you ever happen to want to link against installed libraries"
-    $echo "in a given directory, LIBDIR, you must either use libtool, and"
-    $echo "specify the full pathname of the library, or use the \`-LLIBDIR'"
-    $echo "flag during linking and do at least one of the following:"
-    if test -n "$shlibpath_var"; then
-      $echo "   - add LIBDIR to the \`$shlibpath_var' environment variable"
-      $echo "     during execution"
-    fi
-    if test -n "$runpath_var"; then
-      $echo "   - add LIBDIR to the \`$runpath_var' environment variable"
-      $echo "     during linking"
-    fi
-    if test -n "$hardcode_libdir_flag_spec"; then
-      libdir=LIBDIR
-      eval flag=\"$hardcode_libdir_flag_spec\"
-
-      $echo "   - use the \`$flag' linker flag"
-    fi
-    if test -n "$admincmds"; then
-      $echo "   - have your system administrator run these commands:$admincmds"
-    fi
-    if test -f /etc/ld.so.conf; then
-      $echo "   - have your system administrator add LIBDIR to \`/etc/ld.so.conf'"
-    fi
-    $echo
-    $echo "See any operating system documentation about shared libraries for"
-    $echo "more information, such as the ld(1) and ld.so(8) manual pages."
-    $echo "----------------------------------------------------------------------"
-    exit $EXIT_SUCCESS
-    ;;
-
-  # libtool execute mode
-  execute)
-    modename="$modename: execute"
-
-    # The first argument is the command name.
-    cmd="$nonopt"
-    if test -z "$cmd"; then
-      $echo "$modename: you must specify a COMMAND" 1>&2
-      $echo "$help"
-      exit $EXIT_FAILURE
-    fi
-
-    # Handle -dlopen flags immediately.
-    for file in $execute_dlfiles; do
-      if test ! -f "$file"; then
-	$echo "$modename: \`$file' is not a file" 1>&2
-	$echo "$help" 1>&2
-	exit $EXIT_FAILURE
-      fi
-
-      dir=
-      case $file in
-      *.la)
-	# Check to see that this really is a libtool archive.
-	if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
-	else
-	  $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
-	  $echo "$help" 1>&2
-	  exit $EXIT_FAILURE
-	fi
-
-	# Read the libtool library.
-	dlname=
-	library_names=
-
-	# If there is no directory component, then add one.
-	case $file in
-	*/* | *\\*) . $file ;;
-	*) . ./$file ;;
-	esac
-
-	# Skip this library if it cannot be dlopened.
-	if test -z "$dlname"; then
-	  # Warn if it was a shared library.
-	  test -n "$library_names" && $echo "$modename: warning: \`$file' was not linked with \`-export-dynamic'"
-	  continue
-	fi
-
-	dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'`
-	test "X$dir" = "X$file" && dir=.
-
-	if test -f "$dir/$objdir/$dlname"; then
-	  dir="$dir/$objdir"
-	else
-	  $echo "$modename: cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'" 1>&2
-	  exit $EXIT_FAILURE
-	fi
-	;;
-
-      *.lo)
-	# Just add the directory containing the .lo file.
-	dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'`
-	test "X$dir" = "X$file" && dir=.
-	;;
-
-      *)
-	$echo "$modename: warning \`-dlopen' is ignored for non-libtool libraries and objects" 1>&2
-	continue
-	;;
-      esac
-
-      # Get the absolute pathname.
-      absdir=`cd "$dir" && pwd`
-      test -n "$absdir" && dir="$absdir"
-
-      # Now add the directory to shlibpath_var.
-      if eval "test -z \"\$$shlibpath_var\""; then
-	eval "$shlibpath_var=\"\$dir\""
-      else
-	eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\""
-      fi
-    done
-
-    # This variable tells wrapper scripts just to set shlibpath_var
-    # rather than running their programs.
-    libtool_execute_magic="$magic"
-
-    # Check if any of the arguments is a wrapper script.
-    args=
-    for file
-    do
-      case $file in
-      -*) ;;
-      *)
-	# Do a test to see if this is really a libtool program.
-	if (${SED} -e '4q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
-	  # If there is no directory component, then add one.
-	  case $file in
-	  */* | *\\*) . $file ;;
-	  *) . ./$file ;;
-	  esac
-
-	  # Transform arg to wrapped name.
-	  file="$progdir/$program"
-	fi
-	;;
-      esac
-      # Quote arguments (to preserve shell metacharacters).
-      file=`$echo "X$file" | $Xsed -e "$sed_quote_subst"`
-      args="$args \"$file\""
-    done
-
-    if test -z "$run"; then
-      if test -n "$shlibpath_var"; then
-	# Export the shlibpath_var.
-	eval "export $shlibpath_var"
-      fi
-
-      # Restore saved environment variables
-      if test "${save_LC_ALL+set}" = set; then
-	LC_ALL="$save_LC_ALL"; export LC_ALL
-      fi
-      if test "${save_LANG+set}" = set; then
-	LANG="$save_LANG"; export LANG
-      fi
-
-      # Now prepare to actually exec the command.
-      exec_cmd="\$cmd$args"
-    else
-      # Display what would be done.
-      if test -n "$shlibpath_var"; then
-	eval "\$echo \"\$shlibpath_var=\$$shlibpath_var\""
-	$echo "export $shlibpath_var"
-      fi
-      $echo "$cmd$args"
-      exit $EXIT_SUCCESS
-    fi
-    ;;
-
-  # libtool clean and uninstall mode
-  clean | uninstall)
-    modename="$modename: $mode"
-    rm="$nonopt"
-    files=
-    rmforce=
-    exit_status=0
-
-    # This variable tells wrapper scripts just to set variables rather
-    # than running their programs.
-    libtool_install_magic="$magic"
-
-    for arg
-    do
-      case $arg in
-      -f) rm="$rm $arg"; rmforce=yes ;;
-      -*) rm="$rm $arg" ;;
-      *) files="$files $arg" ;;
-      esac
-    done
-
-    if test -z "$rm"; then
-      $echo "$modename: you must specify an RM program" 1>&2
-      $echo "$help" 1>&2
-      exit $EXIT_FAILURE
-    fi
-
-    rmdirs=
-
-    origobjdir="$objdir"
-    for file in $files; do
-      dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'`
-      if test "X$dir" = "X$file"; then
-	dir=.
-	objdir="$origobjdir"
-      else
-	objdir="$dir/$origobjdir"
-      fi
-      name=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
-      test "$mode" = uninstall && objdir="$dir"
-
-      # Remember objdir for removal later, being careful to avoid duplicates
-      if test "$mode" = clean; then
-	case " $rmdirs " in
-	  *" $objdir "*) ;;
-	  *) rmdirs="$rmdirs $objdir" ;;
-	esac
-      fi
-
-      # Don't error if the file doesn't exist and rm -f was used.
-      if (test -L "$file") >/dev/null 2>&1 \
-	|| (test -h "$file") >/dev/null 2>&1 \
-	|| test -f "$file"; then
-	:
-      elif test -d "$file"; then
-	exit_status=1
-	continue
-      elif test "$rmforce" = yes; then
-	continue
-      fi
-
-      rmfiles="$file"
-
-      case $name in
-      *.la)
-	# Possibly a libtool archive, so verify it.
-	if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
-	  . $dir/$name
-
-	  # Delete the libtool libraries and symlinks.
-	  for n in $library_names; do
-	    rmfiles="$rmfiles $objdir/$n"
-	  done
-	  test -n "$old_library" && rmfiles="$rmfiles $objdir/$old_library"
-	  test "$mode" = clean && rmfiles="$rmfiles $objdir/$name $objdir/${name}i"
-
-	  if test "$mode" = uninstall; then
-	    if test -n "$library_names"; then
-	      # Do each command in the postuninstall commands.
-	      cmds=$postuninstall_cmds
-	      save_ifs="$IFS"; IFS='~'
-	      for cmd in $cmds; do
-		IFS="$save_ifs"
-		eval cmd=\"$cmd\"
-		$show "$cmd"
-		$run eval "$cmd"
-		if test "$?" -ne 0 && test "$rmforce" != yes; then
-		  exit_status=1
-		fi
-	      done
-	      IFS="$save_ifs"
-	    fi
-
-	    if test -n "$old_library"; then
-	      # Do each command in the old_postuninstall commands.
-	      cmds=$old_postuninstall_cmds
-	      save_ifs="$IFS"; IFS='~'
-	      for cmd in $cmds; do
-		IFS="$save_ifs"
-		eval cmd=\"$cmd\"
-		$show "$cmd"
-		$run eval "$cmd"
-		if test "$?" -ne 0 && test "$rmforce" != yes; then
-		  exit_status=1
-		fi
-	      done
-	      IFS="$save_ifs"
-	    fi
-	    # FIXME: should reinstall the best remaining shared library.
-	  fi
-	fi
-	;;
-
-      *.lo)
-	# Possibly a libtool object, so verify it.
-	if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
-
-	  # Read the .lo file
-	  . $dir/$name
-
-	  # Add PIC object to the list of files to remove.
-	  if test -n "$pic_object" \
-	     && test "$pic_object" != none; then
-	    rmfiles="$rmfiles $dir/$pic_object"
-	  fi
-
-	  # Add non-PIC object to the list of files to remove.
-	  if test -n "$non_pic_object" \
-	     && test "$non_pic_object" != none; then
-	    rmfiles="$rmfiles $dir/$non_pic_object"
-	  fi
-	fi
-	;;
-
-      *)
-	if test "$mode" = clean ; then
-	  noexename=$name
-	  case $file in
-	  *.exe)
-	    file=`$echo $file|${SED} 's,.exe$,,'`
-	    noexename=`$echo $name|${SED} 's,.exe$,,'`
-	    # $file with .exe has already been added to rmfiles,
-	    # add $file without .exe
-	    rmfiles="$rmfiles $file"
-	    ;;
-	  esac
-	  # Do a test to see if this is a libtool program.
-	  if (${SED} -e '4q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
-	    relink_command=
-	    . $dir/$noexename
-
-	    # note $name still contains .exe if it was in $file originally
-	    # as does the version of $file that was added into $rmfiles
-	    rmfiles="$rmfiles $objdir/$name $objdir/${name}S.${objext}"
-	    if test "$fast_install" = yes && test -n "$relink_command"; then
-	      rmfiles="$rmfiles $objdir/lt-$name"
-	    fi
-	    if test "X$noexename" != "X$name" ; then
-	      rmfiles="$rmfiles $objdir/lt-${noexename}.c"
-	    fi
-	  fi
-	fi
-	;;
-      esac
-      $show "$rm $rmfiles"
-      $run $rm $rmfiles || exit_status=1
-    done
-    objdir="$origobjdir"
-
-    # Try to remove the ${objdir}s in the directories where we deleted files
-    for dir in $rmdirs; do
-      if test -d "$dir"; then
-	$show "rmdir $dir"
-	$run rmdir $dir >/dev/null 2>&1
-      fi
-    done
-
-    exit $exit_status
-    ;;
-
-  "")
-    $echo "$modename: you must specify a MODE" 1>&2
-    $echo "$generic_help" 1>&2
-    exit $EXIT_FAILURE
-    ;;
-  esac
-
-  if test -z "$exec_cmd"; then
-    $echo "$modename: invalid operation mode \`$mode'" 1>&2
-    $echo "$generic_help" 1>&2
-    exit $EXIT_FAILURE
-  fi
-fi # test -z "$show_help"
-
-if test -n "$exec_cmd"; then
-  eval exec $exec_cmd
-  exit $EXIT_FAILURE
-fi
-
-# We need to display help for each of the modes.
-case $mode in
-"") $echo \
-"Usage: $modename [OPTION]... [MODE-ARG]...
-
-Provide generalized library-building support services.
-
-    --config          show all configuration variables
-    --debug           enable verbose shell tracing
--n, --dry-run         display commands without modifying any files
-    --features        display basic configuration information and exit
-    --finish          same as \`--mode=finish'
-    --help            display this help message and exit
-    --mode=MODE       use operation mode MODE [default=inferred from MODE-ARGS]
-    --quiet           same as \`--silent'
-    --silent          don't print informational messages
-    --tag=TAG         use configuration variables from tag TAG
-    --version         print version information
-
-MODE must be one of the following:
-
-      clean           remove files from the build directory
-      compile         compile a source file into a libtool object
-      execute         automatically set library path, then run a program
-      finish          complete the installation of libtool libraries
-      install         install libraries or executables
-      link            create a library or an executable
-      uninstall       remove libraries from an installed directory
-
-MODE-ARGS vary depending on the MODE.  Try \`$modename --help --mode=MODE' for
-a more detailed description of MODE.
-
-Report bugs to <bug-libtool at gnu.org>."
-  exit $EXIT_SUCCESS
-  ;;
-
-clean)
-  $echo \
-"Usage: $modename [OPTION]... --mode=clean RM [RM-OPTION]... FILE...
-
-Remove files from the build directory.
-
-RM is the name of the program to use to delete files associated with each FILE
-(typically \`/bin/rm').  RM-OPTIONS are options (such as \`-f') to be passed
-to RM.
-
-If FILE is a libtool library, object or program, all the files associated
-with it are deleted. Otherwise, only FILE itself is deleted using RM."
-  ;;
-
-compile)
-  $echo \
-"Usage: $modename [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE
-
-Compile a source file into a libtool library object.
-
-This mode accepts the following additional options:
-
-  -o OUTPUT-FILE    set the output file name to OUTPUT-FILE
-  -prefer-pic       try to building PIC objects only
-  -prefer-non-pic   try to building non-PIC objects only
-  -static           always build a \`.o' file suitable for static linking
-
-COMPILE-COMMAND is a command to be used in creating a \`standard' object file
-from the given SOURCEFILE.
-
-The output file name is determined by removing the directory component from
-SOURCEFILE, then substituting the C source code suffix \`.c' with the
-library object suffix, \`.lo'."
-  ;;
-
-execute)
-  $echo \
-"Usage: $modename [OPTION]... --mode=execute COMMAND [ARGS]...
-
-Automatically set library path, then run a program.
-
-This mode accepts the following additional options:
-
-  -dlopen FILE      add the directory containing FILE to the library path
-
-This mode sets the library path environment variable according to \`-dlopen'
-flags.
-
-If any of the ARGS are libtool executable wrappers, then they are translated
-into their corresponding uninstalled binary, and any of their required library
-directories are added to the library path.
-
-Then, COMMAND is executed, with ARGS as arguments."
-  ;;
-
-finish)
-  $echo \
-"Usage: $modename [OPTION]... --mode=finish [LIBDIR]...
-
-Complete the installation of libtool libraries.
-
-Each LIBDIR is a directory that contains libtool libraries.
-
-The commands that this mode executes may require superuser privileges.  Use
-the \`--dry-run' option if you just want to see what would be executed."
-  ;;
-
-install)
-  $echo \
-"Usage: $modename [OPTION]... --mode=install INSTALL-COMMAND...
-
-Install executables or libraries.
-
-INSTALL-COMMAND is the installation command.  The first component should be
-either the \`install' or \`cp' program.
-
-The rest of the components are interpreted as arguments to that command (only
-BSD-compatible install options are recognized)."
-  ;;
-
-link)
-  $echo \
-"Usage: $modename [OPTION]... --mode=link LINK-COMMAND...
-
-Link object files or libraries together to form another library, or to
-create an executable program.
-
-LINK-COMMAND is a command using the C compiler that you would use to create
-a program from several object files.
-
-The following components of LINK-COMMAND are treated specially:
-
-  -all-static       do not do any dynamic linking at all
-  -avoid-version    do not add a version suffix if possible
-  -dlopen FILE      \`-dlpreopen' FILE if it cannot be dlopened at runtime
-  -dlpreopen FILE   link in FILE and add its symbols to lt_preloaded_symbols
-  -export-dynamic   allow symbols from OUTPUT-FILE to be resolved with dlsym(3)
-  -export-symbols SYMFILE
-		    try to export only the symbols listed in SYMFILE
-  -export-symbols-regex REGEX
-		    try to export only the symbols matching REGEX
-  -LLIBDIR          search LIBDIR for required installed libraries
-  -lNAME            OUTPUT-FILE requires the installed library libNAME
-  -module           build a library that can dlopened
-  -no-fast-install  disable the fast-install mode
-  -no-install       link a not-installable executable
-  -no-undefined     declare that a library does not refer to external symbols
-  -o OUTPUT-FILE    create OUTPUT-FILE from the specified objects
-  -objectlist FILE  Use a list of object files found in FILE to specify objects
-  -precious-files-regex REGEX
-                    don't remove output files matching REGEX
-  -release RELEASE  specify package release information
-  -rpath LIBDIR     the created library will eventually be installed in LIBDIR
-  -R[ ]LIBDIR       add LIBDIR to the runtime path of programs and libraries
-  -static           do not do any dynamic linking of libtool libraries
-  -version-info CURRENT[:REVISION[:AGE]]
-		    specify library version info [each variable defaults to 0]
-
-All other options (arguments beginning with \`-') are ignored.
-
-Every other argument is treated as a filename.  Files ending in \`.la' are
-treated as uninstalled libtool libraries, other files are standard or library
-object files.
-
-If the OUTPUT-FILE ends in \`.la', then a libtool library is created,
-only library objects (\`.lo' files) may be specified, and \`-rpath' is
-required, except when creating a convenience library.
-
-If OUTPUT-FILE ends in \`.a' or \`.lib', then a standard library is created
-using \`ar' and \`ranlib', or on Windows using \`lib'.
-
-If OUTPUT-FILE ends in \`.lo' or \`.${objext}', then a reloadable object file
-is created, otherwise an executable program is created."
-  ;;
-
-uninstall)
-  $echo \
-"Usage: $modename [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE...
-
-Remove libraries from an installation directory.
-
-RM is the name of the program to use to delete files associated with each FILE
-(typically \`/bin/rm').  RM-OPTIONS are options (such as \`-f') to be passed
-to RM.
-
-If FILE is a libtool library, all the files associated with it are deleted.
-Otherwise, only FILE itself is deleted using RM."
-  ;;
-
-*)
-  $echo "$modename: invalid operation mode \`$mode'" 1>&2
-  $echo "$help" 1>&2
-  exit $EXIT_FAILURE
-  ;;
-esac
-
-$echo
-$echo "Try \`$modename --help' for more information about other modes."
-
-exit $?
-
-# The TAGs below are defined such that we never get into a situation
-# in which we disable both kinds of libraries.  Given conflicting
-# choices, we go for a static library, that is the most portable,
-# since we can't tell whether shared libraries were disabled because
-# the user asked for that or because the platform doesn't support
-# them.  This is particularly important on AIX, because we don't
-# support having both static and shared libraries enabled at the same
-# time on that platform, so we default to a shared-only configuration.
-# If a disable-shared tag is given, we'll fallback to a static-only
-# configuration.  But we'll never go from static-only to shared-only.
-
-# ### BEGIN LIBTOOL TAG CONFIG: disable-shared
-build_libtool_libs=no
-build_old_libs=yes
-# ### END LIBTOOL TAG CONFIG: disable-shared
-
-# ### BEGIN LIBTOOL TAG CONFIG: disable-static
-build_old_libs=`case $build_libtool_libs in yes) $echo no;; *) $echo yes;; esac`
-# ### END LIBTOOL TAG CONFIG: disable-static
-
-# Local Variables:
-# mode:shell-script
-# sh-indentation:2
-# End:
diff --git a/m4/libtool.m4 b/m4/libtool.m4
deleted file mode 100644
index cb35506..0000000
--- a/m4/libtool.m4
+++ /dev/null
@@ -1,6163 +0,0 @@
-# libtool.m4 - Configure libtool for the host system. -*-Autoconf-*-
-## Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005
-## Free Software Foundation, Inc.
-## Originally by Gordon Matzigkeit <gord at gnu.ai.mit.edu>, 1996
-##
-## 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 47 AC_PROG_LIBTOOL
-
-
-# AC_PROVIDE_IFELSE(MACRO-NAME, IF-PROVIDED, IF-NOT-PROVIDED)
-# -----------------------------------------------------------
-# If this macro is not defined by Autoconf, define it here.
-m4_ifdef([AC_PROVIDE_IFELSE],
-         [],
-         [m4_define([AC_PROVIDE_IFELSE],
-	         [m4_ifdef([AC_PROVIDE_$1],
-		           [$2], [$3])])])
-
-
-# AC_PROG_LIBTOOL
-# ---------------
-AC_DEFUN([AC_PROG_LIBTOOL],
-[AC_REQUIRE([_AC_PROG_LIBTOOL])dnl
-dnl If AC_PROG_CXX has already been expanded, run AC_LIBTOOL_CXX
-dnl immediately, otherwise, hook it in at the end of AC_PROG_CXX.
-  AC_PROVIDE_IFELSE([AC_PROG_CXX],
-    [AC_LIBTOOL_CXX],
-    [define([AC_PROG_CXX], defn([AC_PROG_CXX])[AC_LIBTOOL_CXX
-  ])])
-dnl And a similar setup for Fortran 77 support
-  AC_PROVIDE_IFELSE([AC_PROG_F77],
-    [AC_LIBTOOL_F77],
-    [define([AC_PROG_F77], defn([AC_PROG_F77])[AC_LIBTOOL_F77
-])])
-
-dnl Quote A][M_PROG_GCJ so that aclocal doesn't bring it in needlessly.
-dnl If either AC_PROG_GCJ or A][M_PROG_GCJ have already been expanded, run
-dnl AC_LIBTOOL_GCJ immediately, otherwise, hook it in at the end of both.
-  AC_PROVIDE_IFELSE([AC_PROG_GCJ],
-    [AC_LIBTOOL_GCJ],
-    [AC_PROVIDE_IFELSE([A][M_PROG_GCJ],
-      [AC_LIBTOOL_GCJ],
-      [AC_PROVIDE_IFELSE([LT_AC_PROG_GCJ],
-	[AC_LIBTOOL_GCJ],
-      [ifdef([AC_PROG_GCJ],
-	     [define([AC_PROG_GCJ], defn([AC_PROG_GCJ])[AC_LIBTOOL_GCJ])])
-       ifdef([A][M_PROG_GCJ],
-	     [define([A][M_PROG_GCJ], defn([A][M_PROG_GCJ])[AC_LIBTOOL_GCJ])])
-       ifdef([LT_AC_PROG_GCJ],
-	     [define([LT_AC_PROG_GCJ],
-		defn([LT_AC_PROG_GCJ])[AC_LIBTOOL_GCJ])])])])
-])])# AC_PROG_LIBTOOL
-
-
-# _AC_PROG_LIBTOOL
-# ----------------
-AC_DEFUN([_AC_PROG_LIBTOOL],
-[AC_REQUIRE([AC_LIBTOOL_SETUP])dnl
-AC_BEFORE([$0],[AC_LIBTOOL_CXX])dnl
-AC_BEFORE([$0],[AC_LIBTOOL_F77])dnl
-AC_BEFORE([$0],[AC_LIBTOOL_GCJ])dnl
-
-# This can be used to rebuild libtool when needed
-LIBTOOL_DEPS="$ac_aux_dir/ltmain.sh"
-
-# Always use our own libtool.
-LIBTOOL='$(SHELL) $(top_builddir)/libtool'
-AC_SUBST(LIBTOOL)dnl
-
-# Prevent multiple expansion
-define([AC_PROG_LIBTOOL], [])
-])# _AC_PROG_LIBTOOL
-
-
-# AC_LIBTOOL_SETUP
-# ----------------
-AC_DEFUN([AC_LIBTOOL_SETUP],
-[AC_PREREQ(2.50)dnl
-AC_REQUIRE([AC_ENABLE_SHARED])dnl
-AC_REQUIRE([AC_ENABLE_STATIC])dnl
-AC_REQUIRE([AC_ENABLE_FAST_INSTALL])dnl
-AC_REQUIRE([AC_CANONICAL_HOST])dnl
-AC_REQUIRE([AC_CANONICAL_BUILD])dnl
-AC_REQUIRE([AC_PROG_CC])dnl
-AC_REQUIRE([AC_PROG_LD])dnl
-AC_REQUIRE([AC_PROG_LD_RELOAD_FLAG])dnl
-AC_REQUIRE([AC_PROG_NM])dnl
-
-AC_REQUIRE([AC_PROG_LN_S])dnl
-AC_REQUIRE([AC_DEPLIBS_CHECK_METHOD])dnl
-# Autoconf 2.13's AC_OBJEXT and AC_EXEEXT macros only works for C compilers!
-AC_REQUIRE([AC_OBJEXT])dnl
-AC_REQUIRE([AC_EXEEXT])dnl
-dnl
-
-AC_LIBTOOL_SYS_MAX_CMD_LEN
-AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE
-AC_LIBTOOL_OBJDIR
-
-AC_REQUIRE([_LT_AC_SYS_COMPILER])dnl
-_LT_AC_PROG_ECHO_BACKSLASH
-
-case $host_os in
-aix3*)
-  # AIX sometimes has problems with the GCC collect2 program.  For some
-  # reason, if we set the COLLECT_NAMES environment variable, the problems
-  # vanish in a puff of smoke.
-  if test "X${COLLECT_NAMES+set}" != Xset; then
-    COLLECT_NAMES=
-    export COLLECT_NAMES
-  fi
-  ;;
-esac
-
-# Sed substitution that helps us do robust quoting.  It backslashifies
-# metacharacters that are still active within double-quoted strings.
-Xsed='sed -e 1s/^X//'
-[sed_quote_subst='s/\([\\"\\`$\\\\]\)/\\\1/g']
-
-# Same as above, but do not quote variable references.
-[double_quote_subst='s/\([\\"\\`\\\\]\)/\\\1/g']
-
-# Sed substitution to delay expansion of an escaped shell variable in a
-# double_quote_subst'ed string.
-delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g'
-
-# Sed substitution to avoid accidental globbing in evaled expressions
-no_glob_subst='s/\*/\\\*/g'
-
-# Constants:
-rm="rm -f"
-
-# Global variables:
-default_ofile=libtool
-can_build_shared=yes
-
-# All known linkers require a `.a' archive for static linking (except M$VC,
-# which needs '.lib').
-libext=a
-ltmain="$ac_aux_dir/ltmain.sh"
-ofile="$default_ofile"
-with_gnu_ld="$lt_cv_prog_gnu_ld"
-
-AC_CHECK_TOOL(AR, ar, false)
-AC_CHECK_TOOL(RANLIB, ranlib, :)
-AC_CHECK_TOOL(STRIP, strip, :)
-
-old_CC="$CC"
-old_CFLAGS="$CFLAGS"
-
-# Set sane defaults for various variables
-test -z "$AR" && AR=ar
-test -z "$AR_FLAGS" && AR_FLAGS=cru
-test -z "$AS" && AS=as
-test -z "$CC" && CC=cc
-test -z "$LTCC" && LTCC=$CC
-test -z "$DLLTOOL" && DLLTOOL=dlltool
-test -z "$LD" && LD=ld
-test -z "$LN_S" && LN_S="ln -s"
-test -z "$MAGIC_CMD" && MAGIC_CMD=file
-test -z "$NM" && NM=nm
-test -z "$SED" && SED=sed
-test -z "$OBJDUMP" && OBJDUMP=objdump
-test -z "$RANLIB" && RANLIB=:
-test -z "$STRIP" && STRIP=:
-test -z "$ac_objext" && ac_objext=o
-
-# Determine commands to create old-style static archives.
-old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs$old_deplibs'
-old_postinstall_cmds='chmod 644 $oldlib'
-old_postuninstall_cmds=
-
-if test -n "$RANLIB"; then
-  case $host_os in
-  openbsd*)
-    old_postinstall_cmds="\$RANLIB -t \$oldlib~$old_postinstall_cmds"
-    ;;
-  *)
-    old_postinstall_cmds="\$RANLIB \$oldlib~$old_postinstall_cmds"
-    ;;
-  esac
-  old_archive_cmds="$old_archive_cmds~\$RANLIB \$oldlib"
-fi
-
-_LT_CC_BASENAME([$compiler])
-
-# Only perform the check for file, if the check method requires it
-case $deplibs_check_method in
-file_magic*)
-  if test "$file_magic_cmd" = '$MAGIC_CMD'; then
-    AC_PATH_MAGIC
-  fi
-  ;;
-esac
-
-AC_PROVIDE_IFELSE([AC_LIBTOOL_DLOPEN], enable_dlopen=yes, enable_dlopen=no)
-AC_PROVIDE_IFELSE([AC_LIBTOOL_WIN32_DLL],
-enable_win32_dll=yes, enable_win32_dll=no)
-
-AC_ARG_ENABLE([libtool-lock],
-    [AC_HELP_STRING([--disable-libtool-lock],
-	[avoid locking (might break parallel builds)])])
-test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes
-
-AC_ARG_WITH([pic],
-    [AC_HELP_STRING([--with-pic],
-	[try to use only PIC/non-PIC objects @<:@default=use both@:>@])],
-    [pic_mode="$withval"],
-    [pic_mode=default])
-test -z "$pic_mode" && pic_mode=default
-
-# Use C for the default configuration in the libtool script
-tagname=
-AC_LIBTOOL_LANG_C_CONFIG
-_LT_AC_TAGCONFIG
-])# AC_LIBTOOL_SETUP
-
-
-# _LT_AC_SYS_COMPILER
-# -------------------
-AC_DEFUN([_LT_AC_SYS_COMPILER],
-[AC_REQUIRE([AC_PROG_CC])dnl
-
-# If no C compiler was specified, use CC.
-LTCC=${LTCC-"$CC"}
-
-# Allow CC to be a program name with arguments.
-compiler=$CC
-])# _LT_AC_SYS_COMPILER
-
-
-# _LT_CC_BASENAME(CC)
-# -------------------
-# Calculate cc_basename.  Skip known compiler wrappers and cross-prefix.
-AC_DEFUN([_LT_CC_BASENAME],
-[for cc_temp in $1""; do
-  case $cc_temp in
-    compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;;
-    distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;;
-    \-*) ;;
-    *) break;;
-  esac
-done
-cc_basename=`$echo "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"`
-])
-
-
-# _LT_COMPILER_BOILERPLATE
-# ------------------------
-# Check for compiler boilerplate output or warnings with
-# the simple compiler test code.
-AC_DEFUN([_LT_COMPILER_BOILERPLATE],
-[ac_outfile=conftest.$ac_objext
-printf "$lt_simple_compile_test_code" >conftest.$ac_ext
-eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err
-_lt_compiler_boilerplate=`cat conftest.err`
-$rm conftest*
-])# _LT_COMPILER_BOILERPLATE
-
-
-# _LT_LINKER_BOILERPLATE
-# ----------------------
-# Check for linker boilerplate output or warnings with
-# the simple link test code.
-AC_DEFUN([_LT_LINKER_BOILERPLATE],
-[ac_outfile=conftest.$ac_objext
-printf "$lt_simple_link_test_code" >conftest.$ac_ext
-eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d' >conftest.err
-_lt_linker_boilerplate=`cat conftest.err`
-$rm conftest*
-])# _LT_LINKER_BOILERPLATE
-
-
-# _LT_AC_SYS_LIBPATH_AIX
-# ----------------------
-# Links a minimal program and checks the executable
-# for the system default hardcoded library path. In most cases,
-# this is /usr/lib:/lib, but when the MPI compilers are used
-# the location of the communication and MPI libs are included too.
-# If we don't find anything, use the default library path according
-# to the aix ld manual.
-AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX],
-[AC_LINK_IFELSE(AC_LANG_PROGRAM,[
-aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0  *\(.*\)$/\1/; p; }
-}'`
-# Check for a 64-bit object if we didn't find anything.
-if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0  *\(.*\)$/\1/; p; }
-}'`; fi],[])
-if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi
-])# _LT_AC_SYS_LIBPATH_AIX
-
-
-# _LT_AC_SHELL_INIT(ARG)
-# ----------------------
-AC_DEFUN([_LT_AC_SHELL_INIT],
-[ifdef([AC_DIVERSION_NOTICE],
-	     [AC_DIVERT_PUSH(AC_DIVERSION_NOTICE)],
-	 [AC_DIVERT_PUSH(NOTICE)])
-$1
-AC_DIVERT_POP
-])# _LT_AC_SHELL_INIT
-
-
-# _LT_AC_PROG_ECHO_BACKSLASH
-# --------------------------
-# Add some code to the start of the generated configure script which
-# will find an echo command which doesn't interpret backslashes.
-AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH],
-[_LT_AC_SHELL_INIT([
-# Check that we are running under the correct shell.
-SHELL=${CONFIG_SHELL-/bin/sh}
-
-case X$ECHO in
-X*--fallback-echo)
-  # Remove one level of quotation (which was required for Make).
-  ECHO=`echo "$ECHO" | sed 's,\\\\\[$]\\[$]0,'[$]0','`
-  ;;
-esac
-
-echo=${ECHO-echo}
-if test "X[$]1" = X--no-reexec; then
-  # Discard the --no-reexec flag, and continue.
-  shift
-elif test "X[$]1" = X--fallback-echo; then
-  # Avoid inline document here, it may be left over
-  :
-elif test "X`($echo '\t') 2>/dev/null`" = 'X\t' ; then
-  # Yippee, $echo works!
-  :
-else
-  # Restart under the correct shell.
-  exec $SHELL "[$]0" --no-reexec ${1+"[$]@"}
-fi
-
-if test "X[$]1" = X--fallback-echo; then
-  # used as fallback echo
-  shift
-  cat <<EOF
-[$]*
-EOF
-  exit 0
-fi
-
-# The HP-UX ksh and POSIX shell print the target directory to stdout
-# if CDPATH is set.
-(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
-
-if test -z "$ECHO"; then
-if test "X${echo_test_string+set}" != Xset; then
-# find a string as large as possible, as long as the shell can cope with it
-  for cmd in 'sed 50q "[$]0"' 'sed 20q "[$]0"' 'sed 10q "[$]0"' 'sed 2q "[$]0"' 'echo test'; do
-    # expected sizes: less than 2Kb, 1Kb, 512 bytes, 16 bytes, ...
-    if (echo_test_string="`eval $cmd`") 2>/dev/null &&
-       echo_test_string="`eval $cmd`" &&
-       (test "X$echo_test_string" = "X$echo_test_string") 2>/dev/null
-    then
-      break
-    fi
-  done
-fi
-
-if test "X`($echo '\t') 2>/dev/null`" = 'X\t' &&
-   echo_testing_string=`($echo "$echo_test_string") 2>/dev/null` &&
-   test "X$echo_testing_string" = "X$echo_test_string"; then
-  :
-else
-  # The Solaris, AIX, and Digital Unix default echo programs unquote
-  # backslashes.  This makes it impossible to quote backslashes using
-  #   echo "$something" | sed 's/\\/\\\\/g'
-  #
-  # So, first we look for a working echo in the user's PATH.
-
-  lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
-  for dir in $PATH /usr/ucb; do
-    IFS="$lt_save_ifs"
-    if (test -f $dir/echo || test -f $dir/echo$ac_exeext) &&
-       test "X`($dir/echo '\t') 2>/dev/null`" = 'X\t' &&
-       echo_testing_string=`($dir/echo "$echo_test_string") 2>/dev/null` &&
-       test "X$echo_testing_string" = "X$echo_test_string"; then
-      echo="$dir/echo"
-      break
-    fi
-  done
-  IFS="$lt_save_ifs"
-
-  if test "X$echo" = Xecho; then
-    # We didn't find a better echo, so look for alternatives.
-    if test "X`(print -r '\t') 2>/dev/null`" = 'X\t' &&
-       echo_testing_string=`(print -r "$echo_test_string") 2>/dev/null` &&
-       test "X$echo_testing_string" = "X$echo_test_string"; then
-      # This shell has a builtin print -r that does the trick.
-      echo='print -r'
-    elif (test -f /bin/ksh || test -f /bin/ksh$ac_exeext) &&
-	 test "X$CONFIG_SHELL" != X/bin/ksh; then
-      # If we have ksh, try running configure again with it.
-      ORIGINAL_CONFIG_SHELL=${CONFIG_SHELL-/bin/sh}
-      export ORIGINAL_CONFIG_SHELL
-      CONFIG_SHELL=/bin/ksh
-      export CONFIG_SHELL
-      exec $CONFIG_SHELL "[$]0" --no-reexec ${1+"[$]@"}
-    else
-      # Try using printf.
-      echo='printf %s\n'
-      if test "X`($echo '\t') 2>/dev/null`" = 'X\t' &&
-	 echo_testing_string=`($echo "$echo_test_string") 2>/dev/null` &&
-	 test "X$echo_testing_string" = "X$echo_test_string"; then
-	# Cool, printf works
-	:
-      elif echo_testing_string=`($ORIGINAL_CONFIG_SHELL "[$]0" --fallback-echo '\t') 2>/dev/null` &&
-	   test "X$echo_testing_string" = 'X\t' &&
-	   echo_testing_string=`($ORIGINAL_CONFIG_SHELL "[$]0" --fallback-echo "$echo_test_string") 2>/dev/null` &&
-	   test "X$echo_testing_string" = "X$echo_test_string"; then
-	CONFIG_SHELL=$ORIGINAL_CONFIG_SHELL
-	export CONFIG_SHELL
-	SHELL="$CONFIG_SHELL"
-	export SHELL
-	echo="$CONFIG_SHELL [$]0 --fallback-echo"
-      elif echo_testing_string=`($CONFIG_SHELL "[$]0" --fallback-echo '\t') 2>/dev/null` &&
-	   test "X$echo_testing_string" = 'X\t' &&
-	   echo_testing_string=`($CONFIG_SHELL "[$]0" --fallback-echo "$echo_test_string") 2>/dev/null` &&
-	   test "X$echo_testing_string" = "X$echo_test_string"; then
-	echo="$CONFIG_SHELL [$]0 --fallback-echo"
-      else
-	# maybe with a smaller string...
-	prev=:
-
-	for cmd in 'echo test' 'sed 2q "[$]0"' 'sed 10q "[$]0"' 'sed 20q "[$]0"' 'sed 50q "[$]0"'; do
-	  if (test "X$echo_test_string" = "X`eval $cmd`") 2>/dev/null
-	  then
-	    break
-	  fi
-	  prev="$cmd"
-	done
-
-	if test "$prev" != 'sed 50q "[$]0"'; then
-	  echo_test_string=`eval $prev`
-	  export echo_test_string
-	  exec ${ORIGINAL_CONFIG_SHELL-${CONFIG_SHELL-/bin/sh}} "[$]0" ${1+"[$]@"}
-	else
-	  # Oops.  We lost completely, so just stick with echo.
-	  echo=echo
-	fi
-      fi
-    fi
-  fi
-fi
-fi
-
-# Copy echo and quote the copy suitably for passing to libtool from
-# the Makefile, instead of quoting the original, which is used later.
-ECHO=$echo
-if test "X$ECHO" = "X$CONFIG_SHELL [$]0 --fallback-echo"; then
-   ECHO="$CONFIG_SHELL \\\$\[$]0 --fallback-echo"
-fi
-
-AC_SUBST(ECHO)
-])])# _LT_AC_PROG_ECHO_BACKSLASH
-
-
-# _LT_AC_LOCK
-# -----------
-AC_DEFUN([_LT_AC_LOCK],
-[AC_ARG_ENABLE([libtool-lock],
-    [AC_HELP_STRING([--disable-libtool-lock],
-	[avoid locking (might break parallel builds)])])
-test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes
-
-# Some flags need to be propagated to the compiler or linker for good
-# libtool support.
-case $host in
-ia64-*-hpux*)
-  # Find out which ABI we are using.
-  echo 'int i;' > conftest.$ac_ext
-  if AC_TRY_EVAL(ac_compile); then
-    case `/usr/bin/file conftest.$ac_objext` in
-    *ELF-32*)
-      HPUX_IA64_MODE="32"
-      ;;
-    *ELF-64*)
-      HPUX_IA64_MODE="64"
-      ;;
-    esac
-  fi
-  rm -rf conftest*
-  ;;
-*-*-irix6*)
-  # Find out which ABI we are using.
-  echo '[#]line __oline__ "configure"' > conftest.$ac_ext
-  if AC_TRY_EVAL(ac_compile); then
-   if test "$lt_cv_prog_gnu_ld" = yes; then
-    case `/usr/bin/file conftest.$ac_objext` in
-    *32-bit*)
-      LD="${LD-ld} -melf32bsmip"
-      ;;
-    *N32*)
-      LD="${LD-ld} -melf32bmipn32"
-      ;;
-    *64-bit*)
-      LD="${LD-ld} -melf64bmip"
-      ;;
-    esac
-   else
-    case `/usr/bin/file conftest.$ac_objext` in
-    *32-bit*)
-      LD="${LD-ld} -32"
-      ;;
-    *N32*)
-      LD="${LD-ld} -n32"
-      ;;
-    *64-bit*)
-      LD="${LD-ld} -64"
-      ;;
-    esac
-   fi
-  fi
-  rm -rf conftest*
-  ;;
-
-x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*|s390*-*linux*|sparc*-*linux*)
-  # Find out which ABI we are using.
-  echo 'int i;' > conftest.$ac_ext
-  if AC_TRY_EVAL(ac_compile); then
-    case "`/usr/bin/file conftest.o`" in
-    *32-bit*)
-      case $host in
-        x86_64-*linux*)
-          LD="${LD-ld} -m elf_i386"
-          ;;
-        ppc64-*linux*|powerpc64-*linux*)
-          LD="${LD-ld} -m elf32ppclinux"
-          ;;
-        s390x-*linux*)
-          LD="${LD-ld} -m elf_s390"
-          ;;
-        sparc64-*linux*)
-          LD="${LD-ld} -m elf32_sparc"
-          ;;
-      esac
-      ;;
-    *64-bit*)
-      case $host in
-        x86_64-*linux*)
-          LD="${LD-ld} -m elf_x86_64"
-          ;;
-        ppc*-*linux*|powerpc*-*linux*)
-          LD="${LD-ld} -m elf64ppc"
-          ;;
-        s390*-*linux*)
-          LD="${LD-ld} -m elf64_s390"
-          ;;
-        sparc*-*linux*)
-          LD="${LD-ld} -m elf64_sparc"
-          ;;
-      esac
-      ;;
-    esac
-  fi
-  rm -rf conftest*
-  ;;
-
-*-*-sco3.2v5*)
-  # On SCO OpenServer 5, we need -belf to get full-featured binaries.
-  SAVE_CFLAGS="$CFLAGS"
-  CFLAGS="$CFLAGS -belf"
-  AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf,
-    [AC_LANG_PUSH(C)
-     AC_TRY_LINK([],[],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no])
-     AC_LANG_POP])
-  if test x"$lt_cv_cc_needs_belf" != x"yes"; then
-    # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf
-    CFLAGS="$SAVE_CFLAGS"
-  fi
-  ;;
-AC_PROVIDE_IFELSE([AC_LIBTOOL_WIN32_DLL],
-[*-*-cygwin* | *-*-mingw* | *-*-pw32*)
-  AC_CHECK_TOOL(DLLTOOL, dlltool, false)
-  AC_CHECK_TOOL(AS, as, false)
-  AC_CHECK_TOOL(OBJDUMP, objdump, false)
-  ;;
-  ])
-esac
-
-need_locks="$enable_libtool_lock"
-
-])# _LT_AC_LOCK
-
-
-# AC_LIBTOOL_COMPILER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS,
-#		[OUTPUT-FILE], [ACTION-SUCCESS], [ACTION-FAILURE])
-# ----------------------------------------------------------------
-# Check whether the given compiler option works
-AC_DEFUN([AC_LIBTOOL_COMPILER_OPTION],
-[AC_REQUIRE([LT_AC_PROG_SED])
-AC_CACHE_CHECK([$1], [$2],
-  [$2=no
-  ifelse([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4])
-   printf "$lt_simple_compile_test_code" > conftest.$ac_ext
-   lt_compiler_flag="$3"
-   # Insert the option either (1) after the last *FLAGS variable, or
-   # (2) before a word containing "conftest.", or (3) at the end.
-   # Note that $ac_compile itself does not contain backslashes and begins
-   # with a dollar sign (not a hyphen), so the echo should work correctly.
-   # The option is referenced via a variable to avoid confusing sed.
-   lt_compile=`echo "$ac_compile" | $SED \
-   -e 's:.*FLAGS}? :&$lt_compiler_flag :; t' \
-   -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \
-   -e 's:$: $lt_compiler_flag:'`
-   (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD)
-   (eval "$lt_compile" 2>conftest.err)
-   ac_status=$?
-   cat conftest.err >&AS_MESSAGE_LOG_FD
-   echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD
-   if (exit $ac_status) && test -s "$ac_outfile"; then
-     # The compiler can only warn and ignore the option if not recognized
-     # So say no if there are warnings other than the usual output.
-     $echo "X$_lt_compiler_boilerplate" | $Xsed >conftest.exp
-     $SED '/^$/d' conftest.err >conftest.er2
-     if test ! -s conftest.err || diff conftest.exp conftest.er2 >/dev/null; then
-       $2=yes
-     fi
-   fi
-   $rm conftest*
-])
-
-if test x"[$]$2" = xyes; then
-    ifelse([$5], , :, [$5])
-else
-    ifelse([$6], , :, [$6])
-fi
-])# AC_LIBTOOL_COMPILER_OPTION
-
-
-# AC_LIBTOOL_LINKER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS,
-#                          [ACTION-SUCCESS], [ACTION-FAILURE])
-# ------------------------------------------------------------
-# Check whether the given compiler option works
-AC_DEFUN([AC_LIBTOOL_LINKER_OPTION],
-[AC_CACHE_CHECK([$1], [$2],
-  [$2=no
-   save_LDFLAGS="$LDFLAGS"
-   LDFLAGS="$LDFLAGS $3"
-   printf "$lt_simple_link_test_code" > conftest.$ac_ext
-   if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then
-     # The compiler can only warn and ignore the option if not recognized
-     # So say no if there are warnings
-     if test -s conftest.err; then
-       # Append any errors to the config.log.
-       cat conftest.err 1>&AS_MESSAGE_LOG_FD
-       $echo "X$_lt_linker_boilerplate" | $Xsed > conftest.exp
-       $SED '/^$/d' conftest.err >conftest.er2
-       if diff conftest.exp conftest.er2 >/dev/null; then
-         $2=yes
-       fi
-     else
-       $2=yes
-     fi
-   fi
-   $rm conftest*
-   LDFLAGS="$save_LDFLAGS"
-])
-
-if test x"[$]$2" = xyes; then
-    ifelse([$4], , :, [$4])
-else
-    ifelse([$5], , :, [$5])
-fi
-])# AC_LIBTOOL_LINKER_OPTION
-
-
-# AC_LIBTOOL_SYS_MAX_CMD_LEN
-# --------------------------
-AC_DEFUN([AC_LIBTOOL_SYS_MAX_CMD_LEN],
-[# find the maximum length of command line arguments
-AC_MSG_CHECKING([the maximum length of command line arguments])
-AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl
-  i=0
-  teststring="ABCD"
-
-  case $build_os in
-  msdosdjgpp*)
-    # On DJGPP, this test can blow up pretty badly due to problems in libc
-    # (any single argument exceeding 2000 bytes causes a buffer overrun
-    # during glob expansion).  Even if it were fixed, the result of this
-    # check would be larger than it should be.
-    lt_cv_sys_max_cmd_len=12288;    # 12K is about right
-    ;;
-
-  gnu*)
-    # Under GNU Hurd, this test is not required because there is
-    # no limit to the length of command line arguments.
-    # Libtool will interpret -1 as no limit whatsoever
-    lt_cv_sys_max_cmd_len=-1;
-    ;;
-
-  cygwin* | mingw*)
-    # On Win9x/ME, this test blows up -- it succeeds, but takes
-    # about 5 minutes as the teststring grows exponentially.
-    # Worse, since 9x/ME are not pre-emptively multitasking,
-    # you end up with a "frozen" computer, even though with patience
-    # the test eventually succeeds (with a max line length of 256k).
-    # Instead, let's just punt: use the minimum linelength reported by
-    # all of the supported platforms: 8192 (on NT/2K/XP).
-    lt_cv_sys_max_cmd_len=8192;
-    ;;
-
-  amigaos*)
-    # On AmigaOS with pdksh, this test takes hours, literally.
-    # So we just punt and use a minimum line length of 8192.
-    lt_cv_sys_max_cmd_len=8192;
-    ;;
-
-  netbsd* | freebsd* | openbsd* | darwin* | dragonfly*)
-    # This has been around since 386BSD, at least.  Likely further.
-    if test -x /sbin/sysctl; then
-      lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax`
-    elif test -x /usr/sbin/sysctl; then
-      lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax`
-    else
-      lt_cv_sys_max_cmd_len=65536 # usable default for *BSD
-    fi
-    # And add a safety zone
-    lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4`
-    lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3`
-    ;;
-  osf*)
-    # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure
-    # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not
-    # nice to cause kernel panics so lets avoid the loop below.
-    # First set a reasonable default.
-    lt_cv_sys_max_cmd_len=16384
-    # 
-    if test -x /sbin/sysconfig; then
-      case `/sbin/sysconfig -q proc exec_disable_arg_limit` in
-        *1*) lt_cv_sys_max_cmd_len=-1 ;;
-      esac
-    fi
-    ;;
-  *)
-    # If test is not a shell built-in, we'll probably end up computing a
-    # maximum length that is only half of the actual maximum length, but
-    # we can't tell.
-    SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}}
-    while (test "X"`$SHELL [$]0 --fallback-echo "X$teststring" 2>/dev/null` \
-	       = "XX$teststring") >/dev/null 2>&1 &&
-	    new_result=`expr "X$teststring" : ".*" 2>&1` &&
-	    lt_cv_sys_max_cmd_len=$new_result &&
-	    test $i != 17 # 1/2 MB should be enough
-    do
-      i=`expr $i + 1`
-      teststring=$teststring$teststring
-    done
-    teststring=
-    # Add a significant safety factor because C++ compilers can tack on massive
-    # amounts of additional arguments before passing them to the linker.
-    # It appears as though 1/2 is a usable value.
-    lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2`
-    ;;
-  esac
-])
-if test -n $lt_cv_sys_max_cmd_len ; then
-  AC_MSG_RESULT($lt_cv_sys_max_cmd_len)
-else
-  AC_MSG_RESULT(none)
-fi
-])# AC_LIBTOOL_SYS_MAX_CMD_LEN
-
-
-# _LT_AC_CHECK_DLFCN
-# --------------------
-AC_DEFUN([_LT_AC_CHECK_DLFCN],
-[AC_CHECK_HEADERS(dlfcn.h)dnl
-])# _LT_AC_CHECK_DLFCN
-
-
-# _LT_AC_TRY_DLOPEN_SELF (ACTION-IF-TRUE, ACTION-IF-TRUE-W-USCORE,
-#                           ACTION-IF-FALSE, ACTION-IF-CROSS-COMPILING)
-# ------------------------------------------------------------------
-AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF],
-[AC_REQUIRE([_LT_AC_CHECK_DLFCN])dnl
-if test "$cross_compiling" = yes; then :
-  [$4]
-else
-  lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
-  lt_status=$lt_dlunknown
-  cat > conftest.$ac_ext <<EOF
-[#line __oline__ "configure"
-#include "confdefs.h"
-
-#if HAVE_DLFCN_H
-#include <dlfcn.h>
-#endif
-
-#include <stdio.h>
-
-#ifdef RTLD_GLOBAL
-#  define LT_DLGLOBAL		RTLD_GLOBAL
-#else
-#  ifdef DL_GLOBAL
-#    define LT_DLGLOBAL		DL_GLOBAL
-#  else
-#    define LT_DLGLOBAL		0
-#  endif
-#endif
-
-/* We may have to define LT_DLLAZY_OR_NOW in the command line if we
-   find out it does not work in some platform. */
-#ifndef LT_DLLAZY_OR_NOW
-#  ifdef RTLD_LAZY
-#    define LT_DLLAZY_OR_NOW		RTLD_LAZY
-#  else
-#    ifdef DL_LAZY
-#      define LT_DLLAZY_OR_NOW		DL_LAZY
-#    else
-#      ifdef RTLD_NOW
-#        define LT_DLLAZY_OR_NOW	RTLD_NOW
-#      else
-#        ifdef DL_NOW
-#          define LT_DLLAZY_OR_NOW	DL_NOW
-#        else
-#          define LT_DLLAZY_OR_NOW	0
-#        endif
-#      endif
-#    endif
-#  endif
-#endif
-
-#ifdef __cplusplus
-extern "C" void exit (int);
-#endif
-
-void fnord() { int i=42;}
-int main ()
-{
-  void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW);
-  int status = $lt_dlunknown;
-
-  if (self)
-    {
-      if (dlsym (self,"fnord"))       status = $lt_dlno_uscore;
-      else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore;
-      /* dlclose (self); */
-    }
-
-    exit (status);
-}]
-EOF
-  if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext} 2>/dev/null; then
-    (./conftest; exit; ) 2>/dev/null
-    lt_status=$?
-    case x$lt_status in
-      x$lt_dlno_uscore) $1 ;;
-      x$lt_dlneed_uscore) $2 ;;
-      x$lt_unknown|x*) $3 ;;
-    esac
-  else :
-    # compilation failed
-    $3
-  fi
-fi
-rm -fr conftest*
-])# _LT_AC_TRY_DLOPEN_SELF
-
-
-# AC_LIBTOOL_DLOPEN_SELF
-# -------------------
-AC_DEFUN([AC_LIBTOOL_DLOPEN_SELF],
-[AC_REQUIRE([_LT_AC_CHECK_DLFCN])dnl
-if test "x$enable_dlopen" != xyes; then
-  enable_dlopen=unknown
-  enable_dlopen_self=unknown
-  enable_dlopen_self_static=unknown
-else
-  lt_cv_dlopen=no
-  lt_cv_dlopen_libs=
-
-  case $host_os in
-  beos*)
-    lt_cv_dlopen="load_add_on"
-    lt_cv_dlopen_libs=
-    lt_cv_dlopen_self=yes
-    ;;
-
-  mingw* | pw32*)
-    lt_cv_dlopen="LoadLibrary"
-    lt_cv_dlopen_libs=
-   ;;
-
-  cygwin*)
-    lt_cv_dlopen="dlopen"
-    lt_cv_dlopen_libs=
-   ;;
-
-  darwin*)
-  # if libdl is installed we need to link against it
-    AC_CHECK_LIB([dl], [dlopen],
-		[lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"],[
-    lt_cv_dlopen="dyld"
-    lt_cv_dlopen_libs=
-    lt_cv_dlopen_self=yes
-    ])
-   ;;
-
-  *)
-    AC_CHECK_FUNC([shl_load],
-	  [lt_cv_dlopen="shl_load"],
-      [AC_CHECK_LIB([dld], [shl_load],
-	    [lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-dld"],
-	[AC_CHECK_FUNC([dlopen],
-	      [lt_cv_dlopen="dlopen"],
-	  [AC_CHECK_LIB([dl], [dlopen],
-		[lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"],
-	    [AC_CHECK_LIB([svld], [dlopen],
-		  [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld"],
-	      [AC_CHECK_LIB([dld], [dld_link],
-		    [lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-dld"])
-	      ])
-	    ])
-	  ])
-	])
-      ])
-    ;;
-  esac
-
-  if test "x$lt_cv_dlopen" != xno; then
-    enable_dlopen=yes
-  else
-    enable_dlopen=no
-  fi
-
-  case $lt_cv_dlopen in
-  dlopen)
-    save_CPPFLAGS="$CPPFLAGS"
-    test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H"
-
-    save_LDFLAGS="$LDFLAGS"
-    eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\"
-
-    save_LIBS="$LIBS"
-    LIBS="$lt_cv_dlopen_libs $LIBS"
-
-    AC_CACHE_CHECK([whether a program can dlopen itself],
-	  lt_cv_dlopen_self, [dnl
-	  _LT_AC_TRY_DLOPEN_SELF(
-	    lt_cv_dlopen_self=yes, lt_cv_dlopen_self=yes,
-	    lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross)
-    ])
-
-    if test "x$lt_cv_dlopen_self" = xyes; then
-      LDFLAGS="$LDFLAGS $link_static_flag"
-      AC_CACHE_CHECK([whether a statically linked program can dlopen itself],
-    	  lt_cv_dlopen_self_static, [dnl
-	  _LT_AC_TRY_DLOPEN_SELF(
-	    lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=yes,
-	    lt_cv_dlopen_self_static=no,  lt_cv_dlopen_self_static=cross)
-      ])
-    fi
-
-    CPPFLAGS="$save_CPPFLAGS"
-    LDFLAGS="$save_LDFLAGS"
-    LIBS="$save_LIBS"
-    ;;
-  esac
-
-  case $lt_cv_dlopen_self in
-  yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;;
-  *) enable_dlopen_self=unknown ;;
-  esac
-
-  case $lt_cv_dlopen_self_static in
-  yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;;
-  *) enable_dlopen_self_static=unknown ;;
-  esac
-fi
-])# AC_LIBTOOL_DLOPEN_SELF
-
-
-# AC_LIBTOOL_PROG_CC_C_O([TAGNAME])
-# ---------------------------------
-# Check to see if options -c and -o are simultaneously supported by compiler
-AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O],
-[AC_REQUIRE([_LT_AC_SYS_COMPILER])dnl
-AC_CACHE_CHECK([if $compiler supports -c -o file.$ac_objext],
-  [_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)],
-  [_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)=no
-   $rm -r conftest 2>/dev/null
-   mkdir conftest
-   cd conftest
-   mkdir out
-   printf "$lt_simple_compile_test_code" > conftest.$ac_ext
-
-   lt_compiler_flag="-o out/conftest2.$ac_objext"
-   # Insert the option either (1) after the last *FLAGS variable, or
-   # (2) before a word containing "conftest.", or (3) at the end.
-   # Note that $ac_compile itself does not contain backslashes and begins
-   # with a dollar sign (not a hyphen), so the echo should work correctly.
-   lt_compile=`echo "$ac_compile" | $SED \
-   -e 's:.*FLAGS}? :&$lt_compiler_flag :; t' \
-   -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \
-   -e 's:$: $lt_compiler_flag:'`
-   (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD)
-   (eval "$lt_compile" 2>out/conftest.err)
-   ac_status=$?
-   cat out/conftest.err >&AS_MESSAGE_LOG_FD
-   echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD
-   if (exit $ac_status) && test -s out/conftest2.$ac_objext
-   then
-     # The compiler can only warn and ignore the option if not recognized
-     # So say no if there are warnings
-     $echo "X$_lt_compiler_boilerplate" | $Xsed > out/conftest.exp
-     $SED '/^$/d' out/conftest.err >out/conftest.er2
-     if test ! -s out/conftest.err || diff out/conftest.exp out/conftest.er2 >/dev/null; then
-       _LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes
-     fi
-   fi
-   chmod u+w .
-   $rm conftest*
-   # SGI C++ compiler will create directory out/ii_files/ for
-   # template instantiation
-   test -d out/ii_files && $rm out/ii_files/* && rmdir out/ii_files
-   $rm out/* && rmdir out
-   cd ..
-   rmdir conftest
-   $rm conftest*
-])
-])# AC_LIBTOOL_PROG_CC_C_O
-
-
-# AC_LIBTOOL_SYS_HARD_LINK_LOCKS([TAGNAME])
-# -----------------------------------------
-# Check to see if we can do hard links to lock some files if needed
-AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS],
-[AC_REQUIRE([_LT_AC_LOCK])dnl
-
-hard_links="nottested"
-if test "$_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)" = no && test "$need_locks" != no; then
-  # do not overwrite the value of need_locks provided by the user
-  AC_MSG_CHECKING([if we can lock with hard links])
-  hard_links=yes
-  $rm conftest*
-  ln conftest.a conftest.b 2>/dev/null && hard_links=no
-  touch conftest.a
-  ln conftest.a conftest.b 2>&5 || hard_links=no
-  ln conftest.a conftest.b 2>/dev/null && hard_links=no
-  AC_MSG_RESULT([$hard_links])
-  if test "$hard_links" = no; then
-    AC_MSG_WARN([`$CC' does not support `-c -o', so `make -j' may be unsafe])
-    need_locks=warn
-  fi
-else
-  need_locks=no
-fi
-])# AC_LIBTOOL_SYS_HARD_LINK_LOCKS
-
-
-# AC_LIBTOOL_OBJDIR
-# -----------------
-AC_DEFUN([AC_LIBTOOL_OBJDIR],
-[AC_CACHE_CHECK([for objdir], [lt_cv_objdir],
-[rm -f .libs 2>/dev/null
-mkdir .libs 2>/dev/null
-if test -d .libs; then
-  lt_cv_objdir=.libs
-else
-  # MS-DOS does not allow filenames that begin with a dot.
-  lt_cv_objdir=_libs
-fi
-rmdir .libs 2>/dev/null])
-objdir=$lt_cv_objdir
-])# AC_LIBTOOL_OBJDIR
-
-
-# AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH([TAGNAME])
-# ----------------------------------------------
-# Check hardcoding attributes.
-AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH],
-[AC_MSG_CHECKING([how to hardcode library paths into programs])
-_LT_AC_TAGVAR(hardcode_action, $1)=
-if test -n "$_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)" || \
-   test -n "$_LT_AC_TAGVAR(runpath_var, $1)" || \
-   test "X$_LT_AC_TAGVAR(hardcode_automatic, $1)" = "Xyes" ; then
-
-  # We can hardcode non-existant directories.
-  if test "$_LT_AC_TAGVAR(hardcode_direct, $1)" != no &&
-     # If the only mechanism to avoid hardcoding is shlibpath_var, we
-     # have to relink, otherwise we might link with an installed library
-     # when we should be linking with a yet-to-be-installed one
-     ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, $1)" != no &&
-     test "$_LT_AC_TAGVAR(hardcode_minus_L, $1)" != no; then
-    # Linking always hardcodes the temporary library directory.
-    _LT_AC_TAGVAR(hardcode_action, $1)=relink
-  else
-    # We can link without hardcoding, and we can hardcode nonexisting dirs.
-    _LT_AC_TAGVAR(hardcode_action, $1)=immediate
-  fi
-else
-  # We cannot hardcode anything, or else we can only hardcode existing
-  # directories.
-  _LT_AC_TAGVAR(hardcode_action, $1)=unsupported
-fi
-AC_MSG_RESULT([$_LT_AC_TAGVAR(hardcode_action, $1)])
-
-if test "$_LT_AC_TAGVAR(hardcode_action, $1)" = relink; then
-  # Fast installation is not supported
-  enable_fast_install=no
-elif test "$shlibpath_overrides_runpath" = yes ||
-     test "$enable_shared" = no; then
-  # Fast installation is not necessary
-  enable_fast_install=needless
-fi
-])# AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH
-
-
-# AC_LIBTOOL_SYS_LIB_STRIP
-# ------------------------
-AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP],
-[striplib=
-old_striplib=
-AC_MSG_CHECKING([whether stripping libraries is possible])
-if test -n "$STRIP" && $STRIP -V 2>&1 | grep "GNU strip" >/dev/null; then
-  test -z "$old_striplib" && old_striplib="$STRIP --strip-debug"
-  test -z "$striplib" && striplib="$STRIP --strip-unneeded"
-  AC_MSG_RESULT([yes])
-else
-# FIXME - insert some real tests, host_os isn't really good enough
-  case $host_os in
-   darwin*)
-       if test -n "$STRIP" ; then
-         striplib="$STRIP -x"
-         AC_MSG_RESULT([yes])
-       else
-  AC_MSG_RESULT([no])
-fi
-       ;;
-   *)
-  AC_MSG_RESULT([no])
-    ;;
-  esac
-fi
-])# AC_LIBTOOL_SYS_LIB_STRIP
-
-
-# AC_LIBTOOL_SYS_DYNAMIC_LINKER
-# -----------------------------
-# PORTME Fill in your ld.so characteristics
-AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER],
-[AC_MSG_CHECKING([dynamic linker characteristics])
-library_names_spec=
-libname_spec='lib$name'
-soname_spec=
-shrext_cmds=".so"
-postinstall_cmds=
-postuninstall_cmds=
-finish_cmds=
-finish_eval=
-shlibpath_var=
-shlibpath_overrides_runpath=unknown
-version_type=none
-dynamic_linker="$host_os ld.so"
-sys_lib_dlsearch_path_spec="/lib /usr/lib"
-if test "$GCC" = yes; then
-  sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"`
-  if echo "$sys_lib_search_path_spec" | grep ';' >/dev/null ; then
-    # if the path contains ";" then we assume it to be the separator
-    # otherwise default to the standard path separator (i.e. ":") - it is
-    # assumed that no part of a normal pathname contains ";" but that should
-    # okay in the real world where ";" in dirpaths is itself problematic.
-    sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'`
-  else
-    sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED  -e "s/$PATH_SEPARATOR/ /g"`
-  fi
-else
-  sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib"
-fi
-need_lib_prefix=unknown
-hardcode_into_libs=no
-
-# when you set need_version to no, make sure it does not cause -set_version
-# flags to be left without arguments
-need_version=unknown
-
-case $host_os in
-aix3*)
-  version_type=linux
-  library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a'
-  shlibpath_var=LIBPATH
-
-  # AIX 3 has no versioning support, so we append a major version to the name.
-  soname_spec='${libname}${release}${shared_ext}$major'
-  ;;
-
-aix4* | aix5*)
-  version_type=linux
-  need_lib_prefix=no
-  need_version=no
-  hardcode_into_libs=yes
-  if test "$host_cpu" = ia64; then
-    # AIX 5 supports IA64
-    library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}'
-    shlibpath_var=LD_LIBRARY_PATH
-  else
-    # With GCC up to 2.95.x, collect2 would create an import file
-    # for dependence libraries.  The import file would start with
-    # the line `#! .'.  This would cause the generated library to
-    # depend on `.', always an invalid library.  This was fixed in
-    # development snapshots of GCC prior to 3.0.
-    case $host_os in
-      aix4 | aix4.[[01]] | aix4.[[01]].*)
-      if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)'
-	   echo ' yes '
-	   echo '#endif'; } | ${CC} -E - | grep yes > /dev/null; then
-	:
-      else
-	can_build_shared=no
-      fi
-      ;;
-    esac
-    # AIX (on Power*) has no versioning support, so currently we can not hardcode correct
-    # soname into executable. Probably we can add versioning support to
-    # collect2, so additional links can be useful in future.
-    if test "$aix_use_runtimelinking" = yes; then
-      # If using run time linking (on AIX 4.2 or later) use lib<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
-      # We preserve .a as extension for shared libraries through AIX4.2
-      # and later when we are not doing run time linking.
-      library_names_spec='${libname}${release}.a $libname.a'
-      soname_spec='${libname}${release}${shared_ext}$major'
-    fi
-    shlibpath_var=LIBPATH
-  fi
-  ;;
-
-amigaos*)
-  library_names_spec='$libname.ixlibrary $libname.a'
-  # Create ${libname}_ixlibrary.a entries in /sys/libs.
-  finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$echo "X$lib" | $Xsed -e '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; test $rm /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done'
-  ;;
-
-beos*)
-  library_names_spec='${libname}${shared_ext}'
-  dynamic_linker="$host_os ld.so"
-  shlibpath_var=LIBRARY_PATH
-  ;;
-
-bsdi[[45]]*)
-  version_type=linux
-  need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
-  finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir'
-  shlibpath_var=LD_LIBRARY_PATH
-  sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib"
-  sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib"
-  # the default ld.so.conf also contains /usr/contrib/lib and
-  # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow
-  # libtool to hard-code these into programs
-  ;;
-
-cygwin* | mingw* | pw32*)
-  version_type=windows
-  shrext_cmds=".dll"
-  need_version=no
-  need_lib_prefix=no
-
-  case $GCC,$host_os in
-  yes,cygwin* | yes,mingw* | yes,pw32*)
-    library_names_spec='$libname.dll.a'
-    # DLL is installed to $(libdir)/../bin by postinstall_cmds
-    postinstall_cmds='base_file=`basename \${file}`~
-      dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~
-      dldir=$destdir/`dirname \$dlpath`~
-      test -d \$dldir || mkdir -p \$dldir~
-      $install_prog $dir/$dlname \$dldir/$dlname'
-    postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~
-      dlpath=$dir/\$dldll~
-       $rm \$dlpath'
-    shlibpath_overrides_runpath=yes
-
-    case $host_os in
-    cygwin*)
-      # Cygwin DLLs use 'cyg' prefix rather than 'lib'
-      soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
-      sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib"
-      ;;
-    mingw*)
-      # MinGW DLLs use traditional 'lib' prefix
-      soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
-      sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"`
-      if echo "$sys_lib_search_path_spec" | [grep ';[c-zC-Z]:/' >/dev/null]; then
-        # It is most probably a Windows format PATH printed by
-        # mingw gcc, but we are running on Cygwin. Gcc prints its search
-        # path with ; separators, and with drive letters. We can handle the
-        # drive letters (cygwin fileutils understands them), so leave them,
-        # especially as we might pass files found there to a mingw objdump,
-        # which wouldn't understand a cygwinified path. Ahh.
-        sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'`
-      else
-        sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED  -e "s/$PATH_SEPARATOR/ /g"`
-      fi
-      ;;
-    pw32*)
-      # pw32 DLLs use 'pw' prefix rather than 'lib'
-      library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
-      ;;
-    esac
-    ;;
-
-  *)
-    library_names_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext} $libname.lib'
-    ;;
-  esac
-  dynamic_linker='Win32 ld.exe'
-  # FIXME: first we should search . and the directory the executable is in
-  shlibpath_var=PATH
-  ;;
-
-darwin* | rhapsody*)
-  dynamic_linker="$host_os dyld"
-  version_type=darwin
-  need_lib_prefix=no
-  need_version=no
-  library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext'
-  soname_spec='${libname}${release}${major}$shared_ext'
-  shlibpath_overrides_runpath=yes
-  shlibpath_var=DYLD_LIBRARY_PATH
-  shrext_cmds='$(test .$module = .yes && echo .so || echo .dylib)'
-  # Apple's gcc prints 'gcc -print-search-dirs' doesn't operate the same.
-  if test "$GCC" = yes; then
-    sys_lib_search_path_spec=`$CC -print-search-dirs | tr "\n" "$PATH_SEPARATOR" | sed -e 's/libraries:/@libraries:/' | tr "@" "\n" | grep "^libraries:" | sed -e "s/^libraries://" -e "s,=/,/,g" -e "s,$PATH_SEPARATOR, ,g" -e "s,.*,& /lib /usr/lib /usr/local/lib,g"`
-  else
-    sys_lib_search_path_spec='/lib /usr/lib /usr/local/lib'
-  fi
-  sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib'
-  ;;
-
-dgux*)
-  version_type=linux
-  need_lib_prefix=no
-  need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext'
-  soname_spec='${libname}${release}${shared_ext}$major'
-  shlibpath_var=LD_LIBRARY_PATH
-  ;;
-
-freebsd1*)
-  dynamic_linker=no
-  ;;
-
-kfreebsd*-gnu)
-  version_type=linux
-  need_lib_prefix=no
-  need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
-  shlibpath_var=LD_LIBRARY_PATH
-  shlibpath_overrides_runpath=no
-  hardcode_into_libs=yes
-  dynamic_linker='GNU ld.so'
-  ;;
-
-freebsd* | dragonfly*)
-  # DragonFly does not have aout.  When/if they implement a new
-  # versioning mechanism, adjust this.
-  objformat=`test -x /usr/bin/objformat && /usr/bin/objformat || echo aout`
-  version_type=freebsd-$objformat
-  case $version_type in
-    freebsd-elf*)
-      library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
-      need_version=no
-      need_lib_prefix=no
-      ;;
-    freebsd-*)
-      library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix'
-      need_version=yes
-      ;;
-  esac
-  shlibpath_var=LD_LIBRARY_PATH
-  case $host_os in
-  freebsd2*)
-    shlibpath_overrides_runpath=yes
-    ;;
-  freebsd3.[[01]]* | freebsdelf3.[[01]]*)
-    shlibpath_overrides_runpath=yes
-    hardcode_into_libs=yes
-    ;;
-  *) # from 3.2 on
-    shlibpath_overrides_runpath=no
-    hardcode_into_libs=yes
-    ;;
-  esac
-  ;;
-
-gnu*)
-  version_type=linux
-  need_lib_prefix=no
-  need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
-  shlibpath_var=LD_LIBRARY_PATH
-  hardcode_into_libs=yes
-  ;;
-
-hpux9* | hpux10* | hpux11*)
-  # Give a soname corresponding to the major version so that dld.sl refuses to
-  # link against other versions.
-  version_type=sunos
-  need_lib_prefix=no
-  need_version=no
-  case "$host_cpu" in
-  ia64*)
-    shrext_cmds='.so'
-    hardcode_into_libs=yes
-    dynamic_linker="$host_os dld.so"
-    shlibpath_var=LD_LIBRARY_PATH
-    shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
-    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-    soname_spec='${libname}${release}${shared_ext}$major'
-    if test "X$HPUX_IA64_MODE" = X32; then
-      sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib"
-    else
-      sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64"
-    fi
-    sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
-    ;;
-   hppa*64*)
-     shrext_cmds='.sl'
-     hardcode_into_libs=yes
-     dynamic_linker="$host_os dld.sl"
-     shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH
-     shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
-     library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-     soname_spec='${libname}${release}${shared_ext}$major'
-     sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64"
-     sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
-     ;;
-   *)
-    shrext_cmds='.sl'
-    dynamic_linker="$host_os dld.sl"
-    shlibpath_var=SHLIB_PATH
-    shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH
-    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-    soname_spec='${libname}${release}${shared_ext}$major'
-    ;;
-  esac
-  # HP-UX runs *really* slowly unless shared libraries are mode 555.
-  postinstall_cmds='chmod 555 $lib'
-  ;;
-
-irix5* | irix6* | nonstopux*)
-  case $host_os in
-    nonstopux*) version_type=nonstopux ;;
-    *)
-	if test "$lt_cv_prog_gnu_ld" = yes; then
-		version_type=linux
-	else
-		version_type=irix
-	fi ;;
-  esac
-  need_lib_prefix=no
-  need_version=no
-  soname_spec='${libname}${release}${shared_ext}$major'
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}'
-  case $host_os in
-  irix5* | nonstopux*)
-    libsuff= shlibsuff=
-    ;;
-  *)
-    case $LD in # libtool.m4 will add one of these switches to LD
-    *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ")
-      libsuff= shlibsuff= libmagic=32-bit;;
-    *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ")
-      libsuff=32 shlibsuff=N32 libmagic=N32;;
-    *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ")
-      libsuff=64 shlibsuff=64 libmagic=64-bit;;
-    *) libsuff= shlibsuff= libmagic=never-match;;
-    esac
-    ;;
-  esac
-  shlibpath_var=LD_LIBRARY${shlibsuff}_PATH
-  shlibpath_overrides_runpath=no
-  sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}"
-  sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}"
-  hardcode_into_libs=yes
-  ;;
-
-# No shared lib support for Linux oldld, aout, or coff.
-linux*oldld* | linux*aout* | linux*coff*)
-  dynamic_linker=no
-  ;;
-
-# This must be Linux ELF.
-linux*)
-  version_type=linux
-  need_lib_prefix=no
-  need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
-  finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir'
-  shlibpath_var=LD_LIBRARY_PATH
-  shlibpath_overrides_runpath=no
-  # This implies no fast_install, which is unacceptable.
-  # Some rework will be needed to allow for fast_install
-  # before this can be enabled.
-  hardcode_into_libs=yes
-
-  # Append ld.so.conf contents to the search path
-  if test -f /etc/ld.so.conf; then
-    lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;s/[:,\t]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;/^$/d' | tr '\n' ' '`
-    sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra"
-  fi
-
-  # We used to test for /lib/ld.so.1 and disable shared libraries on
-  # powerpc, because MkLinux only supported shared libraries with the
-  # GNU dynamic linker.  Since this was broken with cross compilers,
-  # most powerpc-linux boxes support dynamic linking these days and
-  # people can always --disable-shared, the test was removed, and we
-  # assume the GNU/Linux dynamic linker is in use.
-  dynamic_linker='GNU/Linux ld.so'
-  ;;
-
-knetbsd*-gnu)
-  version_type=linux
-  need_lib_prefix=no
-  need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
-  shlibpath_var=LD_LIBRARY_PATH
-  shlibpath_overrides_runpath=no
-  hardcode_into_libs=yes
-  dynamic_linker='GNU ld.so'
-  ;;
-
-netbsd*)
-  version_type=sunos
-  need_lib_prefix=no
-  need_version=no
-  if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then
-    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
-    finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
-    dynamic_linker='NetBSD (a.out) ld.so'
-  else
-    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
-    soname_spec='${libname}${release}${shared_ext}$major'
-    dynamic_linker='NetBSD ld.elf_so'
-  fi
-  shlibpath_var=LD_LIBRARY_PATH
-  shlibpath_overrides_runpath=yes
-  hardcode_into_libs=yes
-  ;;
-
-newsos6)
-  version_type=linux
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  shlibpath_var=LD_LIBRARY_PATH
-  shlibpath_overrides_runpath=yes
-  ;;
-
-nto-qnx*)
-  version_type=linux
-  need_lib_prefix=no
-  need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
-  shlibpath_var=LD_LIBRARY_PATH
-  shlibpath_overrides_runpath=yes
-  ;;
-
-openbsd*)
-  version_type=sunos
-  need_lib_prefix=no
-  need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
-  finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
-  shlibpath_var=LD_LIBRARY_PATH
-  if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
-    case $host_os in
-      openbsd2.[[89]] | openbsd2.[[89]].*)
-	shlibpath_overrides_runpath=no
-	;;
-      *)
-	shlibpath_overrides_runpath=yes
-	;;
-      esac
-  else
-    shlibpath_overrides_runpath=yes
-  fi
-  ;;
-
-os2*)
-  libname_spec='$name'
-  shrext_cmds=".dll"
-  need_lib_prefix=no
-  library_names_spec='$libname${shared_ext} $libname.a'
-  dynamic_linker='OS/2 ld.exe'
-  shlibpath_var=LIBPATH
-  ;;
-
-osf3* | osf4* | osf5*)
-  version_type=osf
-  need_lib_prefix=no
-  need_version=no
-  soname_spec='${libname}${release}${shared_ext}$major'
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  shlibpath_var=LD_LIBRARY_PATH
-  sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib"
-  sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec"
-  ;;
-
-sco3.2v5*)
-  version_type=osf
-  soname_spec='${libname}${release}${shared_ext}$major'
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  shlibpath_var=LD_LIBRARY_PATH
-  ;;
-
-solaris*)
-  version_type=linux
-  need_lib_prefix=no
-  need_version=no
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
-  shlibpath_var=LD_LIBRARY_PATH
-  shlibpath_overrides_runpath=yes
-  hardcode_into_libs=yes
-  # ldd complains unless libraries are executable
-  postinstall_cmds='chmod +x $lib'
-  ;;
-
-sunos4*)
-  version_type=sunos
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
-  finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir'
-  shlibpath_var=LD_LIBRARY_PATH
-  shlibpath_overrides_runpath=yes
-  if test "$with_gnu_ld" = yes; then
-    need_lib_prefix=no
-  fi
-  need_version=yes
-  ;;
-
-sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*)
-  version_type=linux
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
-  shlibpath_var=LD_LIBRARY_PATH
-  case $host_vendor in
-    sni)
-      shlibpath_overrides_runpath=no
-      need_lib_prefix=no
-      export_dynamic_flag_spec='${wl}-Blargedynsym'
-      runpath_var=LD_RUN_PATH
-      ;;
-    siemens)
-      need_lib_prefix=no
-      ;;
-    motorola)
-      need_lib_prefix=no
-      need_version=no
-      shlibpath_overrides_runpath=no
-      sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib'
-      ;;
-  esac
-  ;;
-
-sysv4*MP*)
-  if test -d /usr/nec ;then
-    version_type=linux
-    library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}'
-    soname_spec='$libname${shared_ext}.$major'
-    shlibpath_var=LD_LIBRARY_PATH
-  fi
-  ;;
-
-uts4*)
-  version_type=linux
-  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
-  soname_spec='${libname}${release}${shared_ext}$major'
-  shlibpath_var=LD_LIBRARY_PATH
-  ;;
-
-*)
-  dynamic_linker=no
-  ;;
-esac
-AC_MSG_RESULT([$dynamic_linker])
-test "$dynamic_linker" = no && can_build_shared=no
-])# AC_LIBTOOL_SYS_DYNAMIC_LINKER
-
-
-# _LT_AC_TAGCONFIG
-# ----------------
-AC_DEFUN([_LT_AC_TAGCONFIG],
-[AC_ARG_WITH([tags],
-    [AC_HELP_STRING([--with-tags@<:@=TAGS@:>@],
-        [include additional configurations @<:@automatic@:>@])],
-    [tagnames="$withval"])
-
-if test -f "$ltmain" && test -n "$tagnames"; then
-  if test ! -f "${ofile}"; then
-    AC_MSG_WARN([output file `$ofile' does not exist])
-  fi
-
-  if test -z "$LTCC"; then
-    eval "`$SHELL ${ofile} --config | grep '^LTCC='`"
-    if test -z "$LTCC"; then
-      AC_MSG_WARN([output file `$ofile' does not look like a libtool script])
-    else
-      AC_MSG_WARN([using `LTCC=$LTCC', extracted from `$ofile'])
-    fi
-  fi
-
-  # Extract list of available tagged configurations in $ofile.
-  # Note that this assumes the entire list is on one line.
-  available_tags=`grep "^available_tags=" "${ofile}" | $SED -e 's/available_tags=\(.*$\)/\1/' -e 's/\"//g'`
-
-  lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
-  for tagname in $tagnames; do
-    IFS="$lt_save_ifs"
-    # Check whether tagname contains only valid characters
-    case `$echo "X$tagname" | $Xsed -e 's:[[-_ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890,/]]::g'` in
-    "") ;;
-    *)  AC_MSG_ERROR([invalid tag name: $tagname])
-	;;
-    esac
-
-    if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$" < "${ofile}" > /dev/null
-    then
-      AC_MSG_ERROR([tag name \"$tagname\" already exists])
-    fi
-
-    # Update the list of available tags.
-    if test -n "$tagname"; then
-      echo appending configuration tag \"$tagname\" to $ofile
-
-      case $tagname in
-      CXX)
-	if test -n "$CXX" && ( test "X$CXX" != "Xno" &&
-	    ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) ||
-	    (test "X$CXX" != "Xg++"))) ; then
-	  AC_LIBTOOL_LANG_CXX_CONFIG
-	else
-	  tagname=""
-	fi
-	;;
-
-      F77)
-	if test -n "$F77" && test "X$F77" != "Xno"; then
-	  AC_LIBTOOL_LANG_F77_CONFIG
-	else
-	  tagname=""
-	fi
-	;;
-
-      GCJ)
-	if test -n "$GCJ" && test "X$GCJ" != "Xno"; then
-	  AC_LIBTOOL_LANG_GCJ_CONFIG
-	else
-	  tagname=""
-	fi
-	;;
-
-      RC)
-	AC_LIBTOOL_LANG_RC_CONFIG
-	;;
-
-      *)
-	AC_MSG_ERROR([Unsupported tag name: $tagname])
-	;;
-      esac
-
-      # Append the new tag name to the list of available tags.
-      if test -n "$tagname" ; then
-      available_tags="$available_tags $tagname"
-    fi
-    fi
-  done
-  IFS="$lt_save_ifs"
-
-  # Now substitute the updated list of available tags.
-  if eval "sed -e 's/^available_tags=.*\$/available_tags=\"$available_tags\"/' \"$ofile\" > \"${ofile}T\""; then
-    mv "${ofile}T" "$ofile"
-    chmod +x "$ofile"
-  else
-    rm -f "${ofile}T"
-    AC_MSG_ERROR([unable to update list of available tagged configurations.])
-  fi
-fi
-])# _LT_AC_TAGCONFIG
-
-
-# AC_LIBTOOL_DLOPEN
-# -----------------
-# enable checks for dlopen support
-AC_DEFUN([AC_LIBTOOL_DLOPEN],
- [AC_BEFORE([$0],[AC_LIBTOOL_SETUP])
-])# AC_LIBTOOL_DLOPEN
-
-
-# AC_LIBTOOL_WIN32_DLL
-# --------------------
-# declare package support for building win32 dll's
-AC_DEFUN([AC_LIBTOOL_WIN32_DLL],
-[AC_BEFORE([$0], [AC_LIBTOOL_SETUP])
-])# AC_LIBTOOL_WIN32_DLL
-
-
-# AC_ENABLE_SHARED([DEFAULT])
-# ---------------------------
-# implement the --enable-shared flag
-# DEFAULT is either `yes' or `no'.  If omitted, it defaults to `yes'.
-AC_DEFUN([AC_ENABLE_SHARED],
-[define([AC_ENABLE_SHARED_DEFAULT], ifelse($1, no, no, yes))dnl
-AC_ARG_ENABLE([shared],
-    [AC_HELP_STRING([--enable-shared@<:@=PKGS@:>@],
-	[build shared libraries @<:@default=]AC_ENABLE_SHARED_DEFAULT[@:>@])],
-    [p=${PACKAGE-default}
-    case $enableval in
-    yes) enable_shared=yes ;;
-    no) enable_shared=no ;;
-    *)
-      enable_shared=no
-      # Look at the argument we got.  We use all the common list separators.
-      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
-      for pkg in $enableval; do
-	IFS="$lt_save_ifs"
-	if test "X$pkg" = "X$p"; then
-	  enable_shared=yes
-	fi
-      done
-      IFS="$lt_save_ifs"
-      ;;
-    esac],
-    [enable_shared=]AC_ENABLE_SHARED_DEFAULT)
-])# AC_ENABLE_SHARED
-
-
-# AC_DISABLE_SHARED
-# -----------------
-#- set the default shared flag to --disable-shared
-AC_DEFUN([AC_DISABLE_SHARED],
-[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
-AC_ENABLE_SHARED(no)
-])# AC_DISABLE_SHARED
-
-
-# AC_ENABLE_STATIC([DEFAULT])
-# ---------------------------
-# implement the --enable-static flag
-# DEFAULT is either `yes' or `no'.  If omitted, it defaults to `yes'.
-AC_DEFUN([AC_ENABLE_STATIC],
-[define([AC_ENABLE_STATIC_DEFAULT], ifelse($1, no, no, yes))dnl
-AC_ARG_ENABLE([static],
-    [AC_HELP_STRING([--enable-static@<:@=PKGS@:>@],
-	[build static libraries @<:@default=]AC_ENABLE_STATIC_DEFAULT[@:>@])],
-    [p=${PACKAGE-default}
-    case $enableval in
-    yes) enable_static=yes ;;
-    no) enable_static=no ;;
-    *)
-     enable_static=no
-      # Look at the argument we got.  We use all the common list separators.
-      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
-      for pkg in $enableval; do
-	IFS="$lt_save_ifs"
-	if test "X$pkg" = "X$p"; then
-	  enable_static=yes
-	fi
-      done
-      IFS="$lt_save_ifs"
-      ;;
-    esac],
-    [enable_static=]AC_ENABLE_STATIC_DEFAULT)
-])# AC_ENABLE_STATIC
-
-
-# AC_DISABLE_STATIC
-# -----------------
-# set the default static flag to --disable-static
-AC_DEFUN([AC_DISABLE_STATIC],
-[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
-AC_ENABLE_STATIC(no)
-])# AC_DISABLE_STATIC
-
-
-# AC_ENABLE_FAST_INSTALL([DEFAULT])
-# ---------------------------------
-# implement the --enable-fast-install flag
-# DEFAULT is either `yes' or `no'.  If omitted, it defaults to `yes'.
-AC_DEFUN([AC_ENABLE_FAST_INSTALL],
-[define([AC_ENABLE_FAST_INSTALL_DEFAULT], ifelse($1, no, no, yes))dnl
-AC_ARG_ENABLE([fast-install],
-    [AC_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@],
-    [optimize for fast installation @<:@default=]AC_ENABLE_FAST_INSTALL_DEFAULT[@:>@])],
-    [p=${PACKAGE-default}
-    case $enableval in
-    yes) enable_fast_install=yes ;;
-    no) enable_fast_install=no ;;
-    *)
-      enable_fast_install=no
-      # Look at the argument we got.  We use all the common list separators.
-      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
-      for pkg in $enableval; do
-	IFS="$lt_save_ifs"
-	if test "X$pkg" = "X$p"; then
-	  enable_fast_install=yes
-	fi
-      done
-      IFS="$lt_save_ifs"
-      ;;
-    esac],
-    [enable_fast_install=]AC_ENABLE_FAST_INSTALL_DEFAULT)
-])# AC_ENABLE_FAST_INSTALL
-
-
-# AC_DISABLE_FAST_INSTALL
-# -----------------------
-# set the default to --disable-fast-install
-AC_DEFUN([AC_DISABLE_FAST_INSTALL],
-[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
-AC_ENABLE_FAST_INSTALL(no)
-])# AC_DISABLE_FAST_INSTALL
-
-
-# AC_LIBTOOL_PICMODE([MODE])
-# --------------------------
-# implement the --with-pic flag
-# MODE is either `yes' or `no'.  If omitted, it defaults to `both'.
-AC_DEFUN([AC_LIBTOOL_PICMODE],
-[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
-pic_mode=ifelse($#,1,$1,default)
-])# AC_LIBTOOL_PICMODE
-
-
-# AC_PROG_EGREP
-# -------------
-# This is predefined starting with Autoconf 2.54, so this conditional
-# definition can be removed once we require Autoconf 2.54 or later.
-m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP],
-[AC_CACHE_CHECK([for egrep], [ac_cv_prog_egrep],
-   [if echo a | (grep -E '(a|b)') >/dev/null 2>&1
-    then ac_cv_prog_egrep='grep -E'
-    else ac_cv_prog_egrep='egrep'
-    fi])
- EGREP=$ac_cv_prog_egrep
- AC_SUBST([EGREP])
-])])
-
-
-# AC_PATH_TOOL_PREFIX
-# -------------------
-# find a file program which can recognise shared library
-AC_DEFUN([AC_PATH_TOOL_PREFIX],
-[AC_REQUIRE([AC_PROG_EGREP])dnl
-AC_MSG_CHECKING([for $1])
-AC_CACHE_VAL(lt_cv_path_MAGIC_CMD,
-[case $MAGIC_CMD in
-[[\\/*] |  ?:[\\/]*])
-  lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path.
-  ;;
-*)
-  lt_save_MAGIC_CMD="$MAGIC_CMD"
-  lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
-dnl $ac_dummy forces splitting on constant user-supplied paths.
-dnl POSIX.2 word splitting is done only on the output of word expansions,
-dnl not every word.  This closes a longstanding sh security hole.
-  ac_dummy="ifelse([$2], , $PATH, [$2])"
-  for ac_dir in $ac_dummy; do
-    IFS="$lt_save_ifs"
-    test -z "$ac_dir" && ac_dir=.
-    if test -f $ac_dir/$1; then
-      lt_cv_path_MAGIC_CMD="$ac_dir/$1"
-      if test -n "$file_magic_test_file"; then
-	case $deplibs_check_method in
-	"file_magic "*)
-	  file_magic_regex="`expr \"$deplibs_check_method\" : \"file_magic \(.*\)\"`"
-	  MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
-	  if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null |
-	    $EGREP "$file_magic_regex" > /dev/null; then
-	    :
-	  else
-	    cat <<EOF 1>&2
-
-*** Warning: the command libtool uses to detect shared libraries,
-*** $file_magic_cmd, produces output that libtool cannot recognize.
-*** The result is that libtool may fail to recognize shared libraries
-*** as such.  This will affect the creation of libtool libraries that
-*** depend on shared libraries, but programs linked with such libtool
-*** libraries will work regardless of this problem.  Nevertheless, you
-*** may want to report the problem to your system manager and/or to
-*** bug-libtool at gnu.org
-
-EOF
-	  fi ;;
-	esac
-      fi
-      break
-    fi
-  done
-  IFS="$lt_save_ifs"
-  MAGIC_CMD="$lt_save_MAGIC_CMD"
-  ;;
-esac])
-MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
-if test -n "$MAGIC_CMD"; then
-  AC_MSG_RESULT($MAGIC_CMD)
-else
-  AC_MSG_RESULT(no)
-fi
-])# AC_PATH_TOOL_PREFIX
-
-
-# AC_PATH_MAGIC
-# -------------
-# find a file program which can recognise a shared library
-AC_DEFUN([AC_PATH_MAGIC],
-[AC_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH)
-if test -z "$lt_cv_path_MAGIC_CMD"; then
-  if test -n "$ac_tool_prefix"; then
-    AC_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH)
-  else
-    MAGIC_CMD=:
-  fi
-fi
-])# AC_PATH_MAGIC
-
-
-# AC_PROG_LD
-# ----------
-# find the pathname to the GNU or non-GNU linker
-AC_DEFUN([AC_PROG_LD],
-[AC_ARG_WITH([gnu-ld],
-    [AC_HELP_STRING([--with-gnu-ld],
-	[assume the C compiler uses GNU ld @<:@default=no@:>@])],
-    [test "$withval" = no || with_gnu_ld=yes],
-    [with_gnu_ld=no])
-AC_REQUIRE([LT_AC_PROG_SED])dnl
-AC_REQUIRE([AC_PROG_CC])dnl
-AC_REQUIRE([AC_CANONICAL_HOST])dnl
-AC_REQUIRE([AC_CANONICAL_BUILD])dnl
-ac_prog=ld
-if test "$GCC" = yes; then
-  # Check if gcc -print-prog-name=ld gives a path.
-  AC_MSG_CHECKING([for ld used by $CC])
-  case $host in
-  *-*-mingw*)
-    # gcc leaves a trailing carriage return which upsets mingw
-    ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;;
-  *)
-    ac_prog=`($CC -print-prog-name=ld) 2>&5` ;;
-  esac
-  case $ac_prog in
-    # Accept absolute paths.
-    [[\\/]]* | ?:[[\\/]]*)
-      re_direlt='/[[^/]][[^/]]*/\.\./'
-      # Canonicalize the pathname of ld
-      ac_prog=`echo $ac_prog| $SED 's%\\\\%/%g'`
-      while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do
-	ac_prog=`echo $ac_prog| $SED "s%$re_direlt%/%"`
-      done
-      test -z "$LD" && LD="$ac_prog"
-      ;;
-  "")
-    # If it fails, then pretend we aren't using GCC.
-    ac_prog=ld
-    ;;
-  *)
-    # If it is relative, then search for the first ld in PATH.
-    with_gnu_ld=unknown
-    ;;
-  esac
-elif test "$with_gnu_ld" = yes; then
-  AC_MSG_CHECKING([for GNU ld])
-else
-  AC_MSG_CHECKING([for non-GNU ld])
-fi
-AC_CACHE_VAL(lt_cv_path_LD,
-[if test -z "$LD"; then
-  lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
-  for ac_dir in $PATH; do
-    IFS="$lt_save_ifs"
-    test -z "$ac_dir" && ac_dir=.
-    if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then
-      lt_cv_path_LD="$ac_dir/$ac_prog"
-      # Check to see if the program is GNU ld.  I'd rather use --version,
-      # but apparently some GNU ld's 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 "$with_gnu_ld" != yes && break
-	;;
-      esac
-    fi
-  done
-  IFS="$lt_save_ifs"
-else
-  lt_cv_path_LD="$LD" # Let the user override the test with a path.
-fi])
-LD="$lt_cv_path_LD"
-if test -n "$LD"; then
-  AC_MSG_RESULT($LD)
-else
-  AC_MSG_RESULT(no)
-fi
-test -z "$LD" && AC_MSG_ERROR([no acceptable ld found in \$PATH])
-AC_PROG_LD_GNU
-])# AC_PROG_LD
-
-
-# AC_PROG_LD_GNU
-# --------------
-AC_DEFUN([AC_PROG_LD_GNU],
-[AC_REQUIRE([AC_PROG_EGREP])dnl
-AC_CACHE_CHECK([if the linker ($LD) is GNU ld], lt_cv_prog_gnu_ld,
-[# I'd rather use --version here, but apparently some GNU ld's only accept -v.
-case `$LD -v 2>&1 </dev/null` in
-*GNU* | *'with BFD'*)
-  lt_cv_prog_gnu_ld=yes
-  ;;
-*)
-  lt_cv_prog_gnu_ld=no
-  ;;
-esac])
-with_gnu_ld=$lt_cv_prog_gnu_ld
-])# AC_PROG_LD_GNU
-
-
-# AC_PROG_LD_RELOAD_FLAG
-# ----------------------
-# find reload flag for linker
-#   -- PORTME Some linkers may need a different reload flag.
-AC_DEFUN([AC_PROG_LD_RELOAD_FLAG],
-[AC_CACHE_CHECK([for $LD option to reload object files],
-  lt_cv_ld_reload_flag,
-  [lt_cv_ld_reload_flag='-r'])
-reload_flag=$lt_cv_ld_reload_flag
-case $reload_flag in
-"" | " "*) ;;
-*) reload_flag=" $reload_flag" ;;
-esac
-reload_cmds='$LD$reload_flag -o $output$reload_objs'
-case $host_os in
-  darwin*)
-    if test "$GCC" = yes; then
-      reload_cmds='$CC -nostdlib ${wl}-r -o $output$reload_objs'
-    else
-      reload_cmds='$LD$reload_flag -o $output$reload_objs'
-    fi
-    ;;
-esac
-])# AC_PROG_LD_RELOAD_FLAG
-
-
-# AC_DEPLIBS_CHECK_METHOD
-# -----------------------
-# how to check for library dependencies
-#  -- PORTME fill in with the dynamic library characteristics
-AC_DEFUN([AC_DEPLIBS_CHECK_METHOD],
-[AC_CACHE_CHECK([how to recognise dependent libraries],
-lt_cv_deplibs_check_method,
-[lt_cv_file_magic_cmd='$MAGIC_CMD'
-lt_cv_file_magic_test_file=
-lt_cv_deplibs_check_method='unknown'
-# Need to set the preceding variable on all platforms that support
-# interlibrary dependencies.
-# 'none' -- dependencies not supported.
-# `unknown' -- same as none, but documents that we really don't know.
-# 'pass_all' -- all dependencies passed with no checks.
-# 'test_compile' -- check by making test program.
-# 'file_magic [[regex]]' -- check by looking for files in library path
-# which responds to the $file_magic_cmd with a given extended regex.
-# If you have `file' or equivalent on your system and you're not sure
-# whether `pass_all' will *always* work, you probably want this one.
-
-case $host_os in
-aix4* | aix5*)
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-
-beos*)
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-
-bsdi[[45]]*)
-  lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib)'
-  lt_cv_file_magic_cmd='/usr/bin/file -L'
-  lt_cv_file_magic_test_file=/shlib/libc.so
-  ;;
-
-cygwin*)
-  # func_win32_libid is a shell function defined in ltmain.sh
-  lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL'
-  lt_cv_file_magic_cmd='func_win32_libid'
-  ;;
-
-mingw* | pw32*)
-  # Base MSYS/MinGW do not provide the 'file' command needed by
-  # func_win32_libid shell function, so use a weaker test based on 'objdump'.
-  lt_cv_deplibs_check_method='file_magic file format pei*-i386(.*architecture: i386)?'
-  lt_cv_file_magic_cmd='$OBJDUMP -f'
-  ;;
-
-darwin* | rhapsody*)
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-
-freebsd* | kfreebsd*-gnu | dragonfly*)
-  if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then
-    case $host_cpu in
-    i*86 )
-      # Not sure whether the presence of OpenBSD here was a mistake.
-      # Let's accept both of them until this is cleared up.
-      lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[[3-9]]86 (compact )?demand paged shared library'
-      lt_cv_file_magic_cmd=/usr/bin/file
-      lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*`
-      ;;
-    esac
-  else
-    lt_cv_deplibs_check_method=pass_all
-  fi
-  ;;
-
-gnu*)
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-
-hpux10.20* | hpux11*)
-  lt_cv_file_magic_cmd=/usr/bin/file
-  case "$host_cpu" in
-  ia64*)
-    lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|ELF-[[0-9]][[0-9]]) shared object file - IA64'
-    lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so
-    ;;
-  hppa*64*)
-    [lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - PA-RISC [0-9].[0-9]']
-    lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl
-    ;;
-  *)
-    lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|PA-RISC[[0-9]].[[0-9]]) shared library'
-    lt_cv_file_magic_test_file=/usr/lib/libc.sl
-    ;;
-  esac
-  ;;
-
-irix5* | irix6* | nonstopux*)
-  case $LD in
-  *-32|*"-32 ") libmagic=32-bit;;
-  *-n32|*"-n32 ") libmagic=N32;;
-  *-64|*"-64 ") libmagic=64-bit;;
-  *) libmagic=never-match;;
-  esac
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-
-# This must be Linux ELF.
-linux*)
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-
-netbsd*)
-  if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then
-    lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$'
-  else
-    lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|_pic\.a)$'
-  fi
-  ;;
-
-newos6*)
-  lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (executable|dynamic lib)'
-  lt_cv_file_magic_cmd=/usr/bin/file
-  lt_cv_file_magic_test_file=/usr/lib/libnls.so
-  ;;
-
-nto-qnx*)
-  lt_cv_deplibs_check_method=unknown
-  ;;
-
-openbsd*)
-  if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
-    lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|\.so|_pic\.a)$'
-  else
-    lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$'
-  fi
-  ;;
-
-osf3* | osf4* | osf5*)
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-
-sco3.2v5*)
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-
-solaris*)
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-
-sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*)
-  case $host_vendor in
-  motorola)
-    lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib) M[[0-9]][[0-9]]* Version [[0-9]]'
-    lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*`
-    ;;
-  ncr)
-    lt_cv_deplibs_check_method=pass_all
-    ;;
-  sequent)
-    lt_cv_file_magic_cmd='/bin/file'
-    lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )'
-    ;;
-  sni)
-    lt_cv_file_magic_cmd='/bin/file'
-    lt_cv_deplibs_check_method="file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB dynamic lib"
-    lt_cv_file_magic_test_file=/lib/libc.so
-    ;;
-  siemens)
-    lt_cv_deplibs_check_method=pass_all
-    ;;
-  esac
-  ;;
-
-sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[[78]]* | unixware7* | sysv4*uw2*)
-  lt_cv_deplibs_check_method=pass_all
-  ;;
-esac
-])
-file_magic_cmd=$lt_cv_file_magic_cmd
-deplibs_check_method=$lt_cv_deplibs_check_method
-test -z "$deplibs_check_method" && deplibs_check_method=unknown
-])# AC_DEPLIBS_CHECK_METHOD
-
-
-# AC_PROG_NM
-# ----------
-# find the pathname to a BSD-compatible name lister
-AC_DEFUN([AC_PROG_NM],
-[AC_CACHE_CHECK([for BSD-compatible nm], lt_cv_path_NM,
-[if test -n "$NM"; then
-  # Let the user override the test.
-  lt_cv_path_NM="$NM"
-else
-  lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
-  for ac_dir in $PATH /usr/ccs/bin /usr/ucb /bin; do
-    IFS="$lt_save_ifs"
-    test -z "$ac_dir" && ac_dir=.
-    tmp_nm="$ac_dir/${ac_tool_prefix}nm"
-    if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then
-      # Check to see if the nm accepts a BSD-compat flag.
-      # Adding the `sed 1q' prevents false positives on HP-UX, which says:
-      #   nm: unknown option "B" ignored
-      # Tru64's nm complains that /dev/null is an invalid object file
-      case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in
-      */dev/null* | *'Invalid file or object type'*)
-	lt_cv_path_NM="$tmp_nm -B"
-	break
-        ;;
-      *)
-	case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in
-	*/dev/null*)
-	  lt_cv_path_NM="$tmp_nm -p"
-	  break
-	  ;;
-	*)
-	  lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but
-	  continue # so that we can try to find one that supports BSD flags
-	  ;;
-	esac
-      esac
-    fi
-  done
-  IFS="$lt_save_ifs"
-  test -z "$lt_cv_path_NM" && lt_cv_path_NM=nm
-fi])
-NM="$lt_cv_path_NM"
-])# AC_PROG_NM
-
-
-# AC_CHECK_LIBM
-# -------------
-# check for math library
-AC_DEFUN([AC_CHECK_LIBM],
-[AC_REQUIRE([AC_CANONICAL_HOST])dnl
-LIBM=
-case $host in
-*-*-beos* | *-*-cygwin* | *-*-pw32* | *-*-darwin*)
-  # These system don't have libm, or don't need it
-  ;;
-*-ncr-sysv4.3*)
-  AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM="-lmw")
-  AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm")
-  ;;
-*)
-  AC_CHECK_LIB(m, cos, LIBM="-lm")
-  ;;
-esac
-])# AC_CHECK_LIBM
-
-
-# AC_LIBLTDL_CONVENIENCE([DIRECTORY])
-# -----------------------------------
-# sets LIBLTDL to the link flags for the libltdl convenience library and
-# LTDLINCL to the include flags for the libltdl header and adds
-# --enable-ltdl-convenience to the configure arguments.  Note that LIBLTDL
-# and LTDLINCL are not AC_SUBSTed, nor is AC_CONFIG_SUBDIRS called.  If
-# DIRECTORY is not provided, it is assumed to be `libltdl'.  LIBLTDL will
-# be prefixed with '${top_builddir}/' and LTDLINCL will be prefixed with
-# '${top_srcdir}/' (note the single quotes!).  If your package is not
-# flat and you're not using automake, define top_builddir and
-# top_srcdir appropriately in the Makefiles.
-AC_DEFUN([AC_LIBLTDL_CONVENIENCE],
-[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
-  case $enable_ltdl_convenience in
-  no) AC_MSG_ERROR([this package needs a convenience libltdl]) ;;
-  "") enable_ltdl_convenience=yes
-      ac_configure_args="$ac_configure_args --enable-ltdl-convenience" ;;
-  esac
-  LIBLTDL='${top_builddir}/'ifelse($#,1,[$1],['libltdl'])/libltdlc.la
-  LTDLINCL='-I${top_srcdir}/'ifelse($#,1,[$1],['libltdl'])
-  # For backwards non-gettext consistent compatibility...
-  INCLTDL="$LTDLINCL"
-])# AC_LIBLTDL_CONVENIENCE
-
-
-# AC_LIBLTDL_INSTALLABLE([DIRECTORY])
-# -----------------------------------
-# sets LIBLTDL to the link flags for the libltdl installable library and
-# LTDLINCL to the include flags for the libltdl header and adds
-# --enable-ltdl-install to the configure arguments.  Note that LIBLTDL
-# and LTDLINCL are not AC_SUBSTed, nor is AC_CONFIG_SUBDIRS called.  If
-# DIRECTORY is not provided and an installed libltdl is not found, it is
-# assumed to be `libltdl'.  LIBLTDL will be prefixed with '${top_builddir}/'
-# and LTDLINCL will be prefixed with '${top_srcdir}/' (note the single
-# quotes!).  If your package is not flat and you're not using automake,
-# define top_builddir and top_srcdir appropriately in the Makefiles.
-# In the future, this macro may have to be called after AC_PROG_LIBTOOL.
-AC_DEFUN([AC_LIBLTDL_INSTALLABLE],
-[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl
-  AC_CHECK_LIB(ltdl, lt_dlinit,
-  [test x"$enable_ltdl_install" != xyes && enable_ltdl_install=no],
-  [if test x"$enable_ltdl_install" = xno; then
-     AC_MSG_WARN([libltdl not installed, but installation disabled])
-   else
-     enable_ltdl_install=yes
-   fi
-  ])
-  if test x"$enable_ltdl_install" = x"yes"; then
-    ac_configure_args="$ac_configure_args --enable-ltdl-install"
-    LIBLTDL='${top_builddir}/'ifelse($#,1,[$1],['libltdl'])/libltdl.la
-    LTDLINCL='-I${top_srcdir}/'ifelse($#,1,[$1],['libltdl'])
-  else
-    ac_configure_args="$ac_configure_args --enable-ltdl-install=no"
-    LIBLTDL="-lltdl"
-    LTDLINCL=
-  fi
-  # For backwards non-gettext consistent compatibility...
-  INCLTDL="$LTDLINCL"
-])# AC_LIBLTDL_INSTALLABLE
-
-
-# AC_LIBTOOL_CXX
-# --------------
-# enable support for C++ libraries
-AC_DEFUN([AC_LIBTOOL_CXX],
-[AC_REQUIRE([_LT_AC_LANG_CXX])
-])# AC_LIBTOOL_CXX
-
-
-# _LT_AC_LANG_CXX
-# ---------------
-AC_DEFUN([_LT_AC_LANG_CXX],
-[AC_REQUIRE([AC_PROG_CXX])
-AC_REQUIRE([_LT_AC_PROG_CXXCPP])
-_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}CXX])
-])# _LT_AC_LANG_CXX
-
-# _LT_AC_PROG_CXXCPP
-# ---------------
-AC_DEFUN([_LT_AC_PROG_CXXCPP],
-[
-AC_REQUIRE([AC_PROG_CXX])
-if test -n "$CXX" && ( test "X$CXX" != "Xno" &&
-    ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) ||
-    (test "X$CXX" != "Xg++"))) ; then
-  AC_PROG_CXXCPP
-fi
-])# _LT_AC_PROG_CXXCPP
-
-# AC_LIBTOOL_F77
-# --------------
-# enable support for Fortran 77 libraries
-AC_DEFUN([AC_LIBTOOL_F77],
-[AC_REQUIRE([_LT_AC_LANG_F77])
-])# AC_LIBTOOL_F77
-
-
-# _LT_AC_LANG_F77
-# ---------------
-AC_DEFUN([_LT_AC_LANG_F77],
-[AC_REQUIRE([AC_PROG_F77])
-_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}F77])
-])# _LT_AC_LANG_F77
-
-
-# AC_LIBTOOL_GCJ
-# --------------
-# enable support for GCJ libraries
-AC_DEFUN([AC_LIBTOOL_GCJ],
-[AC_REQUIRE([_LT_AC_LANG_GCJ])
-])# AC_LIBTOOL_GCJ
-
-
-# _LT_AC_LANG_GCJ
-# ---------------
-AC_DEFUN([_LT_AC_LANG_GCJ],
-[AC_PROVIDE_IFELSE([AC_PROG_GCJ],[],
-  [AC_PROVIDE_IFELSE([A][M_PROG_GCJ],[],
-    [AC_PROVIDE_IFELSE([LT_AC_PROG_GCJ],[],
-      [ifdef([AC_PROG_GCJ],[AC_REQUIRE([AC_PROG_GCJ])],
-	 [ifdef([A][M_PROG_GCJ],[AC_REQUIRE([A][M_PROG_GCJ])],
-	   [AC_REQUIRE([A][C_PROG_GCJ_OR_A][M_PROG_GCJ])])])])])])
-_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}GCJ])
-])# _LT_AC_LANG_GCJ
-
-
-# AC_LIBTOOL_RC
-# --------------
-# enable support for Windows resource files
-AC_DEFUN([AC_LIBTOOL_RC],
-[AC_REQUIRE([LT_AC_PROG_RC])
-_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}RC])
-])# AC_LIBTOOL_RC
-
-
-# AC_LIBTOOL_LANG_C_CONFIG
-# ------------------------
-# Ensure that the configuration vars for the C compiler are
-# suitably defined.  Those variables are subsequently used by
-# AC_LIBTOOL_CONFIG to write the compiler configuration to `libtool'.
-AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG], [_LT_AC_LANG_C_CONFIG])
-AC_DEFUN([_LT_AC_LANG_C_CONFIG],
-[lt_save_CC="$CC"
-AC_LANG_PUSH(C)
-
-# Source file extension for C test sources.
-ac_ext=c
-
-# Object file extension for compiled C test sources.
-objext=o
-_LT_AC_TAGVAR(objext, $1)=$objext
-
-# Code to be used in simple compile tests
-lt_simple_compile_test_code="int some_variable = 0;\n"
-
-# Code to be used in simple link tests
-lt_simple_link_test_code='int main(){return(0);}\n'
-
-_LT_AC_SYS_COMPILER
-
-# save warnings/boilerplate of simple test code
-_LT_COMPILER_BOILERPLATE
-_LT_LINKER_BOILERPLATE
-
-#
-# Check for any special shared library compilation flags.
-#
-_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)=
-if test "$GCC" = no; then
-  case $host_os in
-  sco3.2v5*)
-    _LT_AC_TAGVAR(lt_prog_cc_shlib, $1)='-belf'
-    ;;
-  esac
-fi
-if test -n "$_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)"; then
-  AC_MSG_WARN([`$CC' requires `$_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)' to build shared libraries])
-  if echo "$old_CC $old_CFLAGS " | grep "[[ 	]]$_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)[[ 	]]" >/dev/null; then :
-  else
-    AC_MSG_WARN([add `$_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)' to the CC or CFLAGS env variable and reconfigure])
-    _LT_AC_TAGVAR(lt_cv_prog_cc_can_build_shared, $1)=no
-  fi
-fi
-
-
-#
-# Check to make sure the static flag actually works.
-#
-AC_LIBTOOL_LINKER_OPTION([if $compiler static flag $_LT_AC_TAGVAR(lt_prog_compiler_static, $1) works],
-  _LT_AC_TAGVAR(lt_prog_compiler_static_works, $1),
-  $_LT_AC_TAGVAR(lt_prog_compiler_static, $1),
-  [],
-  [_LT_AC_TAGVAR(lt_prog_compiler_static, $1)=])
-
-
-## CAVEAT EMPTOR:
-## There is no encapsulation within the following macros, do not change
-## the running order or otherwise move them around unless you know exactly
-## what you are doing...
-AC_LIBTOOL_PROG_COMPILER_NO_RTTI($1)
-AC_LIBTOOL_PROG_COMPILER_PIC($1)
-AC_LIBTOOL_PROG_CC_C_O($1)
-AC_LIBTOOL_SYS_HARD_LINK_LOCKS($1)
-AC_LIBTOOL_PROG_LD_SHLIBS($1)
-AC_LIBTOOL_SYS_DYNAMIC_LINKER($1)
-AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH($1)
-AC_LIBTOOL_SYS_LIB_STRIP
-AC_LIBTOOL_DLOPEN_SELF($1)
-
-# Report which librarie types wil actually be built
-AC_MSG_CHECKING([if libtool supports shared libraries])
-AC_MSG_RESULT([$can_build_shared])
-
-AC_MSG_CHECKING([whether to build shared libraries])
-test "$can_build_shared" = "no" && enable_shared=no
-
-# On AIX, shared libraries and static libraries use the same namespace, and
-# are all built from PIC.
-case "$host_os" in
-aix3*)
-  test "$enable_shared" = yes && enable_static=no
-  if test -n "$RANLIB"; then
-    archive_cmds="$archive_cmds~\$RANLIB \$lib"
-    postinstall_cmds='$RANLIB $lib'
-  fi
-  ;;
-
-aix4* | aix5*)
-  if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
-    test "$enable_shared" = yes && enable_static=no
-  fi
-    ;;
-esac
-AC_MSG_RESULT([$enable_shared])
-
-AC_MSG_CHECKING([whether to build static libraries])
-# Make sure either enable_shared or enable_static is yes.
-test "$enable_shared" = yes || enable_static=yes
-AC_MSG_RESULT([$enable_static])
-
-AC_LIBTOOL_CONFIG($1)
-
-AC_LANG_POP
-CC="$lt_save_CC"
-])# AC_LIBTOOL_LANG_C_CONFIG
-
-
-# AC_LIBTOOL_LANG_CXX_CONFIG
-# --------------------------
-# Ensure that the configuration vars for the C compiler are
-# suitably defined.  Those variables are subsequently used by
-# AC_LIBTOOL_CONFIG to write the compiler configuration to `libtool'.
-AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG], [_LT_AC_LANG_CXX_CONFIG(CXX)])
-AC_DEFUN([_LT_AC_LANG_CXX_CONFIG],
-[AC_LANG_PUSH(C++)
-AC_REQUIRE([AC_PROG_CXX])
-AC_REQUIRE([_LT_AC_PROG_CXXCPP])
-
-_LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no
-_LT_AC_TAGVAR(allow_undefined_flag, $1)=
-_LT_AC_TAGVAR(always_export_symbols, $1)=no
-_LT_AC_TAGVAR(archive_expsym_cmds, $1)=
-_LT_AC_TAGVAR(export_dynamic_flag_spec, $1)=
-_LT_AC_TAGVAR(hardcode_direct, $1)=no
-_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)=
-_LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)=
-_LT_AC_TAGVAR(hardcode_libdir_separator, $1)=
-_LT_AC_TAGVAR(hardcode_minus_L, $1)=no
-_LT_AC_TAGVAR(hardcode_automatic, $1)=no
-_LT_AC_TAGVAR(module_cmds, $1)=
-_LT_AC_TAGVAR(module_expsym_cmds, $1)=
-_LT_AC_TAGVAR(link_all_deplibs, $1)=unknown
-_LT_AC_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds
-_LT_AC_TAGVAR(no_undefined_flag, $1)=
-_LT_AC_TAGVAR(whole_archive_flag_spec, $1)=
-_LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=no
-
-# Dependencies to place before and after the object being linked:
-_LT_AC_TAGVAR(predep_objects, $1)=
-_LT_AC_TAGVAR(postdep_objects, $1)=
-_LT_AC_TAGVAR(predeps, $1)=
-_LT_AC_TAGVAR(postdeps, $1)=
-_LT_AC_TAGVAR(compiler_lib_search_path, $1)=
-
-# Source file extension for C++ test sources.
-ac_ext=cc
-
-# Object file extension for compiled C++ test sources.
-objext=o
-_LT_AC_TAGVAR(objext, $1)=$objext
-
-# Code to be used in simple compile tests
-lt_simple_compile_test_code="int some_variable = 0;\n"
-
-# Code to be used in simple link tests
-lt_simple_link_test_code='int main(int, char *[]) { return(0); }\n'
-
-# ltmain only uses $CC for tagged configurations so make sure $CC is set.
-_LT_AC_SYS_COMPILER
-
-# save warnings/boilerplate of simple test code
-_LT_COMPILER_BOILERPLATE
-_LT_LINKER_BOILERPLATE
-
-# Allow CC to be a program name with arguments.
-lt_save_CC=$CC
-lt_save_LD=$LD
-lt_save_GCC=$GCC
-GCC=$GXX
-lt_save_with_gnu_ld=$with_gnu_ld
-lt_save_path_LD=$lt_cv_path_LD
-if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then
-  lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx
-else
-  unset lt_cv_prog_gnu_ld
-fi
-if test -n "${lt_cv_path_LDCXX+set}"; then
-  lt_cv_path_LD=$lt_cv_path_LDCXX
-else
-  unset lt_cv_path_LD
-fi
-test -z "${LDCXX+set}" || LD=$LDCXX
-CC=${CXX-"c++"}
-compiler=$CC
-_LT_AC_TAGVAR(compiler, $1)=$CC
-_LT_CC_BASENAME([$compiler])
-
-# We don't want -fno-exception wen compiling C++ code, so set the
-# no_builtin_flag separately
-if test "$GXX" = yes; then
-  _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin'
-else
-  _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=
-fi
-
-if test "$GXX" = yes; then
-  # Set up default GNU C++ configuration
-
-  AC_PROG_LD
-
-  # Check if GNU C++ uses GNU ld as the underlying linker, since the
-  # archiving commands below assume that GNU ld is being used.
-  if test "$with_gnu_ld" = yes; then
-    _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
-    _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
-
-    _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir'
-    _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
-
-    # If archive_cmds runs LD, not CC, wlarc should be empty
-    # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to
-    #     investigate it a little bit more. (MM)
-    wlarc='${wl}'
-
-    # ancient GNU ld didn't support --whole-archive et. al.
-    if eval "`$CC -print-prog-name=ld` --help 2>&1" | \
-	grep 'no-whole-archive' > /dev/null; then
-      _LT_AC_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
-    else
-      _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=
-    fi
-  else
-    with_gnu_ld=no
-    wlarc=
-
-    # A generic and very simple default shared library creation
-    # command for GNU C++ for the case where it uses the native
-    # linker, instead of GNU ld.  If possible, this setting should
-    # overridden to take advantage of the native linker features on
-    # the platform it is being used on.
-    _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib'
-  fi
-
-  # Commands to make compiler produce verbose output that lists
-  # what "hidden" libraries, object files and flags are used when
-  # linking a shared library.
-  output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"'
-
-else
-  GXX=no
-  with_gnu_ld=no
-  wlarc=
-fi
-
-# PORTME: fill in a description of your system's C++ link characteristics
-AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries])
-_LT_AC_TAGVAR(ld_shlibs, $1)=yes
-case $host_os in
-  aix3*)
-    # FIXME: insert proper C++ library support
-    _LT_AC_TAGVAR(ld_shlibs, $1)=no
-    ;;
-  aix4* | aix5*)
-    if test "$host_cpu" = ia64; then
-      # On IA64, the linker does run time linking by default, so we don't
-      # have to do anything special.
-      aix_use_runtimelinking=no
-      exp_sym_flag='-Bexport'
-      no_entry_flag=""
-    else
-      aix_use_runtimelinking=no
-
-      # Test if we are trying to use run time linking or normal
-      # AIX style linking. If -brtl is somewhere in LDFLAGS, we
-      # need to do runtime linking.
-      case $host_os in aix4.[[23]]|aix4.[[23]].*|aix5*)
-	for ld_flag in $LDFLAGS; do
-	  case $ld_flag in
-	  *-brtl*)
-	    aix_use_runtimelinking=yes
-	    break
-	    ;;
-	  esac
-	done
-      esac
-
-      exp_sym_flag='-bexport'
-      no_entry_flag='-bnoentry'
-    fi
-
-    # When large executables or shared objects are built, AIX ld can
-    # have problems creating the table of contents.  If linking a library
-    # or program results in "error TOC overflow" add -mminimal-toc to
-    # CXXFLAGS/CFLAGS for g++/gcc.  In the cases where that is not
-    # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS.
-
-    _LT_AC_TAGVAR(archive_cmds, $1)=''
-    _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-    _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=':'
-    _LT_AC_TAGVAR(link_all_deplibs, $1)=yes
-
-    if test "$GXX" = yes; then
-      case $host_os in aix4.[[012]]|aix4.[[012]].*)
-      # We only want to do this on AIX 4.2 and lower, the check
-      # below for broken collect2 doesn't work under 4.3+
-	collect2name=`${CC} -print-prog-name=collect2`
-	if test -f "$collect2name" && \
-	   strings "$collect2name" | grep resolve_lib_name >/dev/null
-	then
-	  # We have reworked collect2
-	  _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-	else
-	  # We have old collect2
-	  _LT_AC_TAGVAR(hardcode_direct, $1)=unsupported
-	  # It fails to find uninstalled libraries when the uninstalled
-	  # path is not listed in the libpath.  Setting hardcode_minus_L
-	  # to unsupported forces relinking
-	  _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes
-	  _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-	  _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=
-	fi
-      esac
-      shared_flag='-shared'
-      if test "$aix_use_runtimelinking" = yes; then
-	shared_flag="$shared_flag "'${wl}-G'
-      fi
-    else
-      # not using gcc
-      if test "$host_cpu" = ia64; then
-	# VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release
-	# chokes on -Wl,-G. The following line is correct:
-	shared_flag='-G'
-      else
-	if test "$aix_use_runtimelinking" = yes; then
-	  shared_flag='${wl}-G'
-	else
-	  shared_flag='${wl}-bM:SRE'
-	fi
-      fi
-    fi
-
-    # It seems that -bexpall does not export symbols beginning with
-    # underscore (_), so it is better to generate a list of symbols to export.
-    _LT_AC_TAGVAR(always_export_symbols, $1)=yes
-    if test "$aix_use_runtimelinking" = yes; then
-      # Warning - without using the other runtime loading flags (-brtl),
-      # -berok will link without error, but may produce a broken library.
-      _LT_AC_TAGVAR(allow_undefined_flag, $1)='-berok'
-      # Determine the default libpath from the value encoded in an empty executable.
-      _LT_AC_SYS_LIBPATH_AIX
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
-
-      _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols $shared_flag"
-     else
-      if test "$host_cpu" = ia64; then
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib'
-	_LT_AC_TAGVAR(allow_undefined_flag, $1)="-z nodefs"
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols"
-      else
-	# Determine the default libpath from the value encoded in an empty executable.
-	_LT_AC_SYS_LIBPATH_AIX
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
-	# Warning - without using the other run time loading flags,
-	# -berok will link without error, but may produce a broken library.
-	_LT_AC_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok'
-	_LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok'
-	# -bexpall does not export symbols beginning with underscore (_)
-	_LT_AC_TAGVAR(always_export_symbols, $1)=yes
-	# Exported symbols can be pulled into shared objects from archives
-	_LT_AC_TAGVAR(whole_archive_flag_spec, $1)=' '
-	_LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes
-	# This is similar to how AIX traditionally builds it's shared libraries.
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}-bE:$export_symbols ${wl}-bnoentry${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
-      fi
-    fi
-    ;;
-  chorus*)
-    case $cc_basename in
-      *)
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-    esac
-    ;;
-
-
-  cygwin* | mingw* | pw32*)
-    # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless,
-    # as there is no search path for DLLs.
-    _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-    _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported
-    _LT_AC_TAGVAR(always_export_symbols, $1)=no
-    _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
-
-    if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then
-      _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib'
-      # If the export-symbols file already is a .def file (1st line
-      # is EXPORTS), use it as is; otherwise, prepend...
-      _LT_AC_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
-	cp $export_symbols $output_objdir/$soname.def;
-      else
-	echo EXPORTS > $output_objdir/$soname.def;
-	cat $export_symbols >> $output_objdir/$soname.def;
-      fi~
-      $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib'
-    else
-      _LT_AC_TAGVAR(ld_shlibs, $1)=no
-    fi
-  ;;
-      darwin* | rhapsody*)
-        case "$host_os" in
-        rhapsody* | darwin1.[[012]])
-         _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-undefined ${wl}suppress'
-         ;;
-       *) # Darwin 1.3 on
-         if test -z ${MACOSX_DEPLOYMENT_TARGET} ; then
-           _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-flat_namespace ${wl}-undefined ${wl}suppress'
-         else
-           case ${MACOSX_DEPLOYMENT_TARGET} in
-             10.[[012]])
-               _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-flat_namespace ${wl}-undefined ${wl}suppress'
-               ;;
-             10.*)
-               _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-undefined ${wl}dynamic_lookup'
-               ;;
-           esac
-         fi
-         ;;
-        esac
-      _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no
-      _LT_AC_TAGVAR(hardcode_direct, $1)=no
-      _LT_AC_TAGVAR(hardcode_automatic, $1)=yes
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=unsupported
-      _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=''
-      _LT_AC_TAGVAR(link_all_deplibs, $1)=yes
-
-    if test "$GXX" = yes ; then
-      lt_int_apple_cc_single_mod=no
-      output_verbose_link_cmd='echo'
-      if $CC -dumpspecs 2>&1 | $EGREP 'single_module' >/dev/null ; then
-       lt_int_apple_cc_single_mod=yes
-      fi
-      if test "X$lt_int_apple_cc_single_mod" = Xyes ; then
-       _LT_AC_TAGVAR(archive_cmds, $1)='$CC -dynamiclib -single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring'
-      else
-          _LT_AC_TAGVAR(archive_cmds, $1)='$CC -r -keep_private_externs -nostdlib -o ${lib}-master.o $libobjs~$CC -dynamiclib $allow_undefined_flag -o $lib ${lib}-master.o $deplibs $compiler_flags -install_name $rpath/$soname $verstring'
-        fi
-        _LT_AC_TAGVAR(module_cmds, $1)='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags'
-        # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin ld's
-          if test "X$lt_int_apple_cc_single_mod" = Xyes ; then
-            _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[    ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -dynamiclib -single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}'
-          else
-            _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[    ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -r -keep_private_externs -nostdlib -o ${lib}-master.o $libobjs~$CC -dynamiclib $allow_undefined_flag -o $lib ${lib}-master.o $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}'
-          fi
-            _LT_AC_TAGVAR(module_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[    ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag  -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}'
-      else
-      case $cc_basename in
-        xlc*)
-         output_verbose_link_cmd='echo'
-          _LT_AC_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj ${wl}-single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $verstring'
-          _LT_AC_TAGVAR(module_cmds, $1)='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags'
-          # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin ld's
-          _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[    ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj ${wl}-single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}'
-          _LT_AC_TAGVAR(module_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[    ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag  -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}'
-          ;;
-       *)
-         _LT_AC_TAGVAR(ld_shlibs, $1)=no
-          ;;
-      esac
-      fi
-        ;;
-
-  dgux*)
-    case $cc_basename in
-      ec++*)
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-      ghcx*)
-	# Green Hills C++ Compiler
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-      *)
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-    esac
-    ;;
-  freebsd[[12]]*)
-    # C++ shared libraries reported to be fairly broken before switch to ELF
-    _LT_AC_TAGVAR(ld_shlibs, $1)=no
-    ;;
-  freebsd-elf*)
-    _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no
-    ;;
-  freebsd* | kfreebsd*-gnu | dragonfly*)
-    # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF
-    # conventions
-    _LT_AC_TAGVAR(ld_shlibs, $1)=yes
-    ;;
-  gnu*)
-    ;;
-  hpux9*)
-    _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
-    _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-    _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
-    _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-    _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH,
-				# but as the default
-				# location of the library.
-
-    case $cc_basename in
-    CC*)
-      # FIXME: insert proper C++ library support
-      _LT_AC_TAGVAR(ld_shlibs, $1)=no
-      ;;
-    aCC*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
-      # Commands to make compiler produce verbose output that lists
-      # what "hidden" libraries, object files and flags are used when
-      # linking a shared library.
-      #
-      # There doesn't appear to be a way to prevent this compiler from
-      # explicitly linking system object files so we need to strip them
-      # from the output so that they don't get included in the library
-      # dependencies.
-      output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | grep "[[-]]L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list'
-      ;;
-    *)
-      if test "$GXX" = yes; then
-        _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$CC -shared -nostdlib -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
-      else
-        # FIXME: insert proper C++ library support
-        _LT_AC_TAGVAR(ld_shlibs, $1)=no
-      fi
-      ;;
-    esac
-    ;;
-  hpux10*|hpux11*)
-    if test $with_gnu_ld = no; then
-      case "$host_cpu" in
-      hppa*64*)
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='+b $libdir'
-	_LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-        ;;
-      ia64*)
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-        ;;
-      *)
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
-	_LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-	_LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
-        ;;
-      esac
-    fi
-    case "$host_cpu" in
-    hppa*64*)
-      _LT_AC_TAGVAR(hardcode_direct, $1)=no
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-    ia64*)
-      _LT_AC_TAGVAR(hardcode_direct, $1)=no
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH,
-					      # but as the default
-					      # location of the library.
-      ;;
-    *)
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH,
-					      # but as the default
-					      # location of the library.
-      ;;
-    esac
-
-    case $cc_basename in
-      CC*)
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-      aCC*)
-	case "$host_cpu" in
-	hppa*64*|ia64*)
-	  _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname -o $lib $linker_flags $libobjs $deplibs'
-	  ;;
-	*)
-	  _LT_AC_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
-	  ;;
-	esac
-	# Commands to make compiler produce verbose output that lists
-	# what "hidden" libraries, object files and flags are used when
-	# linking a shared library.
-	#
-	# There doesn't appear to be a way to prevent this compiler from
-	# explicitly linking system object files so we need to strip them
-	# from the output so that they don't get included in the library
-	# dependencies.
-	output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | grep "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list'
-	;;
-      *)
-	if test "$GXX" = yes; then
-	  if test $with_gnu_ld = no; then
-	    case "$host_cpu" in
-	    ia64*|hppa*64*)
-	      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname -o $lib $linker_flags $libobjs $deplibs'
-	      ;;
-	    *)
-	      _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
-	      ;;
-	    esac
-	  fi
-	else
-	  # FIXME: insert proper C++ library support
-	  _LT_AC_TAGVAR(ld_shlibs, $1)=no
-	fi
-	;;
-    esac
-    ;;
-  irix5* | irix6*)
-    case $cc_basename in
-      CC*)
-	# SGI C++
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib'
-
-	# Archives containing C++ object files must be created using
-	# "CC -ar", where "CC" is the IRIX C++ compiler.  This is
-	# necessary to make sure instantiated templates are included
-	# in the archive.
-	_LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs'
-	;;
-      *)
-	if test "$GXX" = yes; then
-	  if test "$with_gnu_ld" = no; then
-	    _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
-	  else
-	    _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` -o $lib'
-	  fi
-	fi
-	_LT_AC_TAGVAR(link_all_deplibs, $1)=yes
-	;;
-    esac
-    _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-    _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-    ;;
-  linux*)
-    case $cc_basename in
-      KCC*)
-	# Kuck and Associates, Inc. (KAI) C++ Compiler
-
-	# KCC will only create a shared library if the output file
-	# ends with ".so" (or ".sl" for HP-UX), so rename the library
-	# to its proper name (with version) after linking.
-	_LT_AC_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib'
-	# Commands to make compiler produce verbose output that lists
-	# what "hidden" libraries, object files and flags are used when
-	# linking a shared library.
-	#
-	# There doesn't appear to be a way to prevent this compiler from
-	# explicitly linking system object files so we need to strip them
-	# from the output so that they don't get included in the library
-	# dependencies.
-	output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | grep "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list'
-
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath,$libdir'
-	_LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
-
-	# Archives containing C++ object files must be created using
-	# "CC -Bstatic", where "CC" is the KAI C++ compiler.
-	_LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs'
-	;;
-      icpc*)
-	# Intel C++
-	with_gnu_ld=yes
-	# version 8.0 and above of icpc choke on multiply defined symbols
-	# if we add $predep_objects and $postdep_objects, however 7.1 and
-	# earlier do not add the objects themselves.
-	case `$CC -V 2>&1` in
-	*"Version 7."*)
-  	  _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
-  	  _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
-	  ;;
-	*)  # Version 8.0 or newer
-	  tmp_idyn=
-	  case $host_cpu in
-	    ia64*) tmp_idyn=' -i_dynamic';;
-	  esac
-  	  _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	  _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
-	  ;;
-	esac
-	_LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-	_LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
-	_LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
-	;;
-      pgCC*)
-        # Portland Group C++ compiler
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib'
-  	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib'
-
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir'
-	_LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
-	_LT_AC_TAGVAR(whole_archive_flag_spec, $1)=''
-        ;;
-      cxx*)
-	# Compaq C++
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname  -o $lib ${wl}-retain-symbols-file $wl$export_symbols'
-
-	runpath_var=LD_RUN_PATH
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
-	_LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-
-	# Commands to make compiler produce verbose output that lists
-	# what "hidden" libraries, object files and flags are used when
-	# linking a shared library.
-	#
-	# There doesn't appear to be a way to prevent this compiler from
-	# explicitly linking system object files so we need to strip them
-	# from the output so that they don't get included in the library
-	# dependencies.
-	output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list'
-	;;
-    esac
-    ;;
-  lynxos*)
-    # FIXME: insert proper C++ library support
-    _LT_AC_TAGVAR(ld_shlibs, $1)=no
-    ;;
-  m88k*)
-    # FIXME: insert proper C++ library support
-    _LT_AC_TAGVAR(ld_shlibs, $1)=no
-    ;;
-  mvs*)
-    case $cc_basename in
-      cxx*)
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-      *)
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-    esac
-    ;;
-  netbsd*)
-    if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then
-      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable  -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags'
-      wlarc=
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-    fi
-    # Workaround some broken pre-1.5 toolchains
-    output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"'
-    ;;
-  openbsd2*)
-    # C++ shared libraries are fairly broken
-    _LT_AC_TAGVAR(ld_shlibs, $1)=no
-    ;;
-  openbsd*)
-    _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-    _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-    _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib'
-    _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-    if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
-      _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file,$export_symbols -o $lib'
-      _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
-      _LT_AC_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
-    fi
-    output_verbose_link_cmd='echo'
-    ;;
-  osf3*)
-    case $cc_basename in
-      KCC*)
-	# Kuck and Associates, Inc. (KAI) C++ Compiler
-
-	# KCC will only create a shared library if the output file
-	# ends with ".so" (or ".sl" for HP-UX), so rename the library
-	# to its proper name (with version) after linking.
-	_LT_AC_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
-
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-	_LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-
-	# Archives containing C++ object files must be created using
-	# "CC -Bstatic", where "CC" is the KAI C++ compiler.
-	_LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs'
-
-	;;
-      RCC*)
-	# Rational C++ 2.4.1
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-      cxx*)
-	_LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && echo ${wl}-set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib'
-
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-	_LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-
-	# Commands to make compiler produce verbose output that lists
-	# what "hidden" libraries, object files and flags are used when
-	# linking a shared library.
-	#
-	# There doesn't appear to be a way to prevent this compiler from
-	# explicitly linking system object files so we need to strip them
-	# from the output so that they don't get included in the library
-	# dependencies.
-	output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld" | grep -v "ld:"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list'
-	;;
-      *)
-	if test "$GXX" = yes && test "$with_gnu_ld" = no; then
-	  _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
-	  _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
-
-	  _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-	  _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-
-	  # Commands to make compiler produce verbose output that lists
-	  # what "hidden" libraries, object files and flags are used when
-	  # linking a shared library.
-	  output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"'
-
-	else
-	  # FIXME: insert proper C++ library support
-	  _LT_AC_TAGVAR(ld_shlibs, $1)=no
-	fi
-	;;
-    esac
-    ;;
-  osf4* | osf5*)
-    case $cc_basename in
-      KCC*)
-	# Kuck and Associates, Inc. (KAI) C++ Compiler
-
-	# KCC will only create a shared library if the output file
-	# ends with ".so" (or ".sl" for HP-UX), so rename the library
-	# to its proper name (with version) after linking.
-	_LT_AC_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
-
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-	_LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-
-	# Archives containing C++ object files must be created using
-	# the KAI C++ compiler.
-	_LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -o $oldlib $oldobjs'
-	;;
-      RCC*)
-	# Rational C++ 2.4.1
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-      cxx*)
-	_LT_AC_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib'
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~
-	  echo "-hidden">> $lib.exp~
-	  $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname -Wl,-input -Wl,$lib.exp  `test -n "$verstring" && echo -set_version	$verstring` -update_registry ${output_objdir}/so_locations -o $lib~
-	  $rm $lib.exp'
-
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
-	_LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-
-	# Commands to make compiler produce verbose output that lists
-	# what "hidden" libraries, object files and flags are used when
-	# linking a shared library.
-	#
-	# There doesn't appear to be a way to prevent this compiler from
-	# explicitly linking system object files so we need to strip them
-	# from the output so that they don't get included in the library
-	# dependencies.
-	output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld" | grep -v "ld:"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list'
-	;;
-      *)
-	if test "$GXX" = yes && test "$with_gnu_ld" = no; then
-	  _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
-	 _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
-
-	  _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-	  _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-
-	  # Commands to make compiler produce verbose output that lists
-	  # what "hidden" libraries, object files and flags are used when
-	  # linking a shared library.
-	  output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"'
-
-	else
-	  # FIXME: insert proper C++ library support
-	  _LT_AC_TAGVAR(ld_shlibs, $1)=no
-	fi
-	;;
-    esac
-    ;;
-  psos*)
-    # FIXME: insert proper C++ library support
-    _LT_AC_TAGVAR(ld_shlibs, $1)=no
-    ;;
-  sco*)
-    _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no
-    case $cc_basename in
-      CC*)
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-      *)
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-    esac
-    ;;
-  sunos4*)
-    case $cc_basename in
-      CC*)
-	# Sun C++ 4.x
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-      lcc*)
-	# Lucid
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-      *)
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-    esac
-    ;;
-  solaris*)
-    case $cc_basename in
-      CC*)
-	# Sun C++ 4.2, 5.x and Centerline C++
-	_LT_AC_TAGVAR(no_undefined_flag, $1)=' -zdefs'
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -nolib -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~
-	$CC -G${allow_undefined_flag} -nolib ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp'
-
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
-	_LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-	case $host_os in
-	  solaris2.[[0-5]] | solaris2.[[0-5]].*) ;;
-	  *)
-	    # The C++ compiler is used as linker so we must use $wl
-	    # flag to pass the commands to the underlying system
-	    # linker. We must also pass each convience library through
-	    # to the system linker between allextract/defaultextract.
-	    # The C++ compiler will combine linker options so we
-	    # cannot just pass the convience library names through
-	    # without $wl.
-	    # Supported since Solaris 2.6 (maybe 2.5.1?)
-	    _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}-z ${wl}defaultextract'
-	    ;;
-	esac
-	_LT_AC_TAGVAR(link_all_deplibs, $1)=yes
-
-	# Commands to make compiler produce verbose output that lists
-	# what "hidden" libraries, object files and flags are used when
-	# linking a shared library.
-	#
-	# There doesn't appear to be a way to prevent this compiler from
-	# explicitly linking system object files so we need to strip them
-	# from the output so that they don't get included in the library
-	# dependencies.
-	output_verbose_link_cmd='templist=`$CC -G $CFLAGS -v conftest.$objext 2>&1 | grep "\-[[LR]]"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list'
-
-	# Archives containing C++ object files must be created using
-	# "CC -xar", where "CC" is the Sun C++ compiler.  This is
-	# necessary to make sure instantiated templates are included
-	# in the archive.
-	_LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs'
-	;;
-      gcx*)
-	# Green Hills C++ Compiler
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
-
-	# The C++ compiler must be used to create the archive.
-	_LT_AC_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs'
-	;;
-      *)
-	# GNU C++ compiler with Solaris linker
-	if test "$GXX" = yes && test "$with_gnu_ld" = no; then
-	  _LT_AC_TAGVAR(no_undefined_flag, $1)=' ${wl}-z ${wl}defs'
-	  if $CC --version | grep -v '^2\.7' > /dev/null; then
-	    _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
-	    _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~
-		$CC -shared -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp'
-
-	    # Commands to make compiler produce verbose output that lists
-	    # what "hidden" libraries, object files and flags are used when
-	    # linking a shared library.
-	    output_verbose_link_cmd="$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\""
-	  else
-	    # g++ 2.7 appears to require `-G' NOT `-shared' on this
-	    # platform.
-	    _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
-	    _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~
-		$CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp'
-
-	    # Commands to make compiler produce verbose output that lists
-	    # what "hidden" libraries, object files and flags are used when
-	    # linking a shared library.
-	    output_verbose_link_cmd="$CC -G $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\""
-	  fi
-
-	  _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $wl$libdir'
-	fi
-	;;
-    esac
-    ;;
-  sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[[78]]* | unixware7*)
-    _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no
-    ;;
-  tandem*)
-    case $cc_basename in
-      NCC*)
-	# NonStop-UX NCC 3.20
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-      *)
-	# FIXME: insert proper C++ library support
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	;;
-    esac
-    ;;
-  vxworks*)
-    # FIXME: insert proper C++ library support
-    _LT_AC_TAGVAR(ld_shlibs, $1)=no
-    ;;
-  *)
-    # FIXME: insert proper C++ library support
-    _LT_AC_TAGVAR(ld_shlibs, $1)=no
-    ;;
-esac
-AC_MSG_RESULT([$_LT_AC_TAGVAR(ld_shlibs, $1)])
-test "$_LT_AC_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no
-
-_LT_AC_TAGVAR(GCC, $1)="$GXX"
-_LT_AC_TAGVAR(LD, $1)="$LD"
-
-## CAVEAT EMPTOR:
-## There is no encapsulation within the following macros, do not change
-## the running order or otherwise move them around unless you know exactly
-## what you are doing...
-AC_LIBTOOL_POSTDEP_PREDEP($1)
-AC_LIBTOOL_PROG_COMPILER_PIC($1)
-AC_LIBTOOL_PROG_CC_C_O($1)
-AC_LIBTOOL_SYS_HARD_LINK_LOCKS($1)
-AC_LIBTOOL_PROG_LD_SHLIBS($1)
-AC_LIBTOOL_SYS_DYNAMIC_LINKER($1)
-AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH($1)
-AC_LIBTOOL_SYS_LIB_STRIP
-AC_LIBTOOL_DLOPEN_SELF($1)
-
-AC_LIBTOOL_CONFIG($1)
-
-AC_LANG_POP
-CC=$lt_save_CC
-LDCXX=$LD
-LD=$lt_save_LD
-GCC=$lt_save_GCC
-with_gnu_ldcxx=$with_gnu_ld
-with_gnu_ld=$lt_save_with_gnu_ld
-lt_cv_path_LDCXX=$lt_cv_path_LD
-lt_cv_path_LD=$lt_save_path_LD
-lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld
-lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld
-])# AC_LIBTOOL_LANG_CXX_CONFIG
-
-# AC_LIBTOOL_POSTDEP_PREDEP([TAGNAME])
-# ------------------------
-# Figure out "hidden" library dependencies from verbose
-# compiler output when linking a shared library.
-# Parse the compiler output and extract the necessary
-# objects, libraries and library flags.
-AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP],[
-dnl we can't use the lt_simple_compile_test_code here,
-dnl because it contains code intended for an executable,
-dnl not a library.  It's possible we should let each
-dnl tag define a new lt_????_link_test_code variable,
-dnl but it's only used here...
-ifelse([$1],[],[cat > conftest.$ac_ext <<EOF
-int a;
-void foo (void) { a = 0; }
-EOF
-],[$1],[CXX],[cat > conftest.$ac_ext <<EOF
-class Foo
-{
-public:
-  Foo (void) { a = 0; }
-private:
-  int a;
-};
-EOF
-],[$1],[F77],[cat > conftest.$ac_ext <<EOF
-      subroutine foo
-      implicit none
-      integer*4 a
-      a=0
-      return
-      end
-EOF
-],[$1],[GCJ],[cat > conftest.$ac_ext <<EOF
-public class foo {
-  private int a;
-  public void bar (void) {
-    a = 0;
-  }
-};
-EOF
-])
-dnl Parse the compiler output and extract the necessary
-dnl objects, libraries and library flags.
-if AC_TRY_EVAL(ac_compile); then
-  # Parse the compiler output and extract the necessary
-  # objects, libraries and library flags.
-
-  # Sentinel used to keep track of whether or not we are before
-  # the conftest object file.
-  pre_test_object_deps_done=no
-
-  # The `*' in the case matches for architectures that use `case' in
-  # $output_verbose_cmd can trigger glob expansion during the loop
-  # eval without this substitution.
-  output_verbose_link_cmd="`$echo \"X$output_verbose_link_cmd\" | $Xsed -e \"$no_glob_subst\"`"
-
-  for p in `eval $output_verbose_link_cmd`; do
-    case $p in
-
-    -L* | -R* | -l*)
-       # Some compilers place space between "-{L,R}" and the path.
-       # Remove the space.
-       if test $p = "-L" \
-	  || test $p = "-R"; then
-	 prev=$p
-	 continue
-       else
-	 prev=
-       fi
-
-       if test "$pre_test_object_deps_done" = no; then
-	 case $p in
-	 -L* | -R*)
-	   # Internal compiler library paths should come after those
-	   # provided the user.  The postdeps already come after the
-	   # user supplied libs so there is no need to process them.
-	   if test -z "$_LT_AC_TAGVAR(compiler_lib_search_path, $1)"; then
-	     _LT_AC_TAGVAR(compiler_lib_search_path, $1)="${prev}${p}"
-	   else
-	     _LT_AC_TAGVAR(compiler_lib_search_path, $1)="${_LT_AC_TAGVAR(compiler_lib_search_path, $1)} ${prev}${p}"
-	   fi
-	   ;;
-	 # The "-l" case would never come before the object being
-	 # linked, so don't bother handling this case.
-	 esac
-       else
-	 if test -z "$_LT_AC_TAGVAR(postdeps, $1)"; then
-	   _LT_AC_TAGVAR(postdeps, $1)="${prev}${p}"
-	 else
-	   _LT_AC_TAGVAR(postdeps, $1)="${_LT_AC_TAGVAR(postdeps, $1)} ${prev}${p}"
-	 fi
-       fi
-       ;;
-
-    *.$objext)
-       # This assumes that the test object file only shows up
-       # once in the compiler output.
-       if test "$p" = "conftest.$objext"; then
-	 pre_test_object_deps_done=yes
-	 continue
-       fi
-
-       if test "$pre_test_object_deps_done" = no; then
-	 if test -z "$_LT_AC_TAGVAR(predep_objects, $1)"; then
-	   _LT_AC_TAGVAR(predep_objects, $1)="$p"
-	 else
-	   _LT_AC_TAGVAR(predep_objects, $1)="$_LT_AC_TAGVAR(predep_objects, $1) $p"
-	 fi
-       else
-	 if test -z "$_LT_AC_TAGVAR(postdep_objects, $1)"; then
-	   _LT_AC_TAGVAR(postdep_objects, $1)="$p"
-	 else
-	   _LT_AC_TAGVAR(postdep_objects, $1)="$_LT_AC_TAGVAR(postdep_objects, $1) $p"
-	 fi
-       fi
-       ;;
-
-    *) ;; # Ignore the rest.
-
-    esac
-  done
-
-  # Clean up.
-  rm -f a.out a.exe
-else
-  echo "libtool.m4: error: problem compiling $1 test program"
-fi
-
-$rm -f confest.$objext
-
-case " $_LT_AC_TAGVAR(postdeps, $1) " in
-*" -lc "*) _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no ;;
-esac
-])# AC_LIBTOOL_POSTDEP_PREDEP
-
-# AC_LIBTOOL_LANG_F77_CONFIG
-# ------------------------
-# Ensure that the configuration vars for the C compiler are
-# suitably defined.  Those variables are subsequently used by
-# AC_LIBTOOL_CONFIG to write the compiler configuration to `libtool'.
-AC_DEFUN([AC_LIBTOOL_LANG_F77_CONFIG], [_LT_AC_LANG_F77_CONFIG(F77)])
-AC_DEFUN([_LT_AC_LANG_F77_CONFIG],
-[AC_REQUIRE([AC_PROG_F77])
-AC_LANG_PUSH(Fortran 77)
-
-_LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no
-_LT_AC_TAGVAR(allow_undefined_flag, $1)=
-_LT_AC_TAGVAR(always_export_symbols, $1)=no
-_LT_AC_TAGVAR(archive_expsym_cmds, $1)=
-_LT_AC_TAGVAR(export_dynamic_flag_spec, $1)=
-_LT_AC_TAGVAR(hardcode_direct, $1)=no
-_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)=
-_LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)=
-_LT_AC_TAGVAR(hardcode_libdir_separator, $1)=
-_LT_AC_TAGVAR(hardcode_minus_L, $1)=no
-_LT_AC_TAGVAR(hardcode_automatic, $1)=no
-_LT_AC_TAGVAR(module_cmds, $1)=
-_LT_AC_TAGVAR(module_expsym_cmds, $1)=
-_LT_AC_TAGVAR(link_all_deplibs, $1)=unknown
-_LT_AC_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds
-_LT_AC_TAGVAR(no_undefined_flag, $1)=
-_LT_AC_TAGVAR(whole_archive_flag_spec, $1)=
-_LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=no
-
-# Source file extension for f77 test sources.
-ac_ext=f
-
-# Object file extension for compiled f77 test sources.
-objext=o
-_LT_AC_TAGVAR(objext, $1)=$objext
-
-# Code to be used in simple compile tests
-lt_simple_compile_test_code="      subroutine t\n      return\n      end\n"
-
-# Code to be used in simple link tests
-lt_simple_link_test_code="      program t\n      end\n"
-
-# ltmain only uses $CC for tagged configurations so make sure $CC is set.
-_LT_AC_SYS_COMPILER
-
-# save warnings/boilerplate of simple test code
-_LT_COMPILER_BOILERPLATE
-_LT_LINKER_BOILERPLATE
-
-# Allow CC to be a program name with arguments.
-lt_save_CC="$CC"
-CC=${F77-"f77"}
-compiler=$CC
-_LT_AC_TAGVAR(compiler, $1)=$CC
-_LT_CC_BASENAME([$compiler])
-
-AC_MSG_CHECKING([if libtool supports shared libraries])
-AC_MSG_RESULT([$can_build_shared])
-
-AC_MSG_CHECKING([whether to build shared libraries])
-test "$can_build_shared" = "no" && enable_shared=no
-
-# On AIX, shared libraries and static libraries use the same namespace, and
-# are all built from PIC.
-case "$host_os" in
-aix3*)
-  test "$enable_shared" = yes && enable_static=no
-  if test -n "$RANLIB"; then
-    archive_cmds="$archive_cmds~\$RANLIB \$lib"
-    postinstall_cmds='$RANLIB $lib'
-  fi
-  ;;
-aix4* | aix5*)
-  if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
-    test "$enable_shared" = yes && enable_static=no
-  fi
-  ;;
-esac
-AC_MSG_RESULT([$enable_shared])
-
-AC_MSG_CHECKING([whether to build static libraries])
-# Make sure either enable_shared or enable_static is yes.
-test "$enable_shared" = yes || enable_static=yes
-AC_MSG_RESULT([$enable_static])
-
-test "$_LT_AC_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no
-
-_LT_AC_TAGVAR(GCC, $1)="$G77"
-_LT_AC_TAGVAR(LD, $1)="$LD"
-
-AC_LIBTOOL_PROG_COMPILER_PIC($1)
-AC_LIBTOOL_PROG_CC_C_O($1)
-AC_LIBTOOL_SYS_HARD_LINK_LOCKS($1)
-AC_LIBTOOL_PROG_LD_SHLIBS($1)
-AC_LIBTOOL_SYS_DYNAMIC_LINKER($1)
-AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH($1)
-AC_LIBTOOL_SYS_LIB_STRIP
-
-
-AC_LIBTOOL_CONFIG($1)
-
-AC_LANG_POP
-CC="$lt_save_CC"
-])# AC_LIBTOOL_LANG_F77_CONFIG
-
-
-# AC_LIBTOOL_LANG_GCJ_CONFIG
-# --------------------------
-# Ensure that the configuration vars for the C compiler are
-# suitably defined.  Those variables are subsequently used by
-# AC_LIBTOOL_CONFIG to write the compiler configuration to `libtool'.
-AC_DEFUN([AC_LIBTOOL_LANG_GCJ_CONFIG], [_LT_AC_LANG_GCJ_CONFIG(GCJ)])
-AC_DEFUN([_LT_AC_LANG_GCJ_CONFIG],
-[AC_LANG_SAVE
-
-# Source file extension for Java test sources.
-ac_ext=java
-
-# Object file extension for compiled Java test sources.
-objext=o
-_LT_AC_TAGVAR(objext, $1)=$objext
-
-# Code to be used in simple compile tests
-lt_simple_compile_test_code="class foo {}\n"
-
-# Code to be used in simple link tests
-lt_simple_link_test_code='public class conftest { public static void main(String[[]] argv) {}; }\n'
-
-# ltmain only uses $CC for tagged configurations so make sure $CC is set.
-_LT_AC_SYS_COMPILER
-
-# save warnings/boilerplate of simple test code
-_LT_COMPILER_BOILERPLATE
-_LT_LINKER_BOILERPLATE
-
-# Allow CC to be a program name with arguments.
-lt_save_CC="$CC"
-CC=${GCJ-"gcj"}
-compiler=$CC
-_LT_AC_TAGVAR(compiler, $1)=$CC
-_LT_CC_BASENAME([$compiler])
-
-# GCJ did not exist at the time GCC didn't implicitly link libc in.
-_LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no
-
-_LT_AC_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds
-
-## CAVEAT EMPTOR:
-## There is no encapsulation within the following macros, do not change
-## the running order or otherwise move them around unless you know exactly
-## what you are doing...
-AC_LIBTOOL_PROG_COMPILER_NO_RTTI($1)
-AC_LIBTOOL_PROG_COMPILER_PIC($1)
-AC_LIBTOOL_PROG_CC_C_O($1)
-AC_LIBTOOL_SYS_HARD_LINK_LOCKS($1)
-AC_LIBTOOL_PROG_LD_SHLIBS($1)
-AC_LIBTOOL_SYS_DYNAMIC_LINKER($1)
-AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH($1)
-AC_LIBTOOL_SYS_LIB_STRIP
-AC_LIBTOOL_DLOPEN_SELF($1)
-
-AC_LIBTOOL_CONFIG($1)
-
-AC_LANG_RESTORE
-CC="$lt_save_CC"
-])# AC_LIBTOOL_LANG_GCJ_CONFIG
-
-
-# AC_LIBTOOL_LANG_RC_CONFIG
-# --------------------------
-# Ensure that the configuration vars for the Windows resource compiler are
-# suitably defined.  Those variables are subsequently used by
-# AC_LIBTOOL_CONFIG to write the compiler configuration to `libtool'.
-AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG], [_LT_AC_LANG_RC_CONFIG(RC)])
-AC_DEFUN([_LT_AC_LANG_RC_CONFIG],
-[AC_LANG_SAVE
-
-# Source file extension for RC test sources.
-ac_ext=rc
-
-# Object file extension for compiled RC test sources.
-objext=o
-_LT_AC_TAGVAR(objext, $1)=$objext
-
-# Code to be used in simple compile tests
-lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }\n'
-
-# Code to be used in simple link tests
-lt_simple_link_test_code="$lt_simple_compile_test_code"
-
-# ltmain only uses $CC for tagged configurations so make sure $CC is set.
-_LT_AC_SYS_COMPILER
-
-# save warnings/boilerplate of simple test code
-_LT_COMPILER_BOILERPLATE
-_LT_LINKER_BOILERPLATE
-
-# Allow CC to be a program name with arguments.
-lt_save_CC="$CC"
-CC=${RC-"windres"}
-compiler=$CC
-_LT_AC_TAGVAR(compiler, $1)=$CC
-_LT_CC_BASENAME([$compiler])
-_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes
-
-AC_LIBTOOL_CONFIG($1)
-
-AC_LANG_RESTORE
-CC="$lt_save_CC"
-])# AC_LIBTOOL_LANG_RC_CONFIG
-
-
-# AC_LIBTOOL_CONFIG([TAGNAME])
-# ----------------------------
-# If TAGNAME is not passed, then create an initial libtool script
-# with a default configuration from the untagged config vars.  Otherwise
-# add code to config.status for appending the configuration named by
-# TAGNAME from the matching tagged config vars.
-AC_DEFUN([AC_LIBTOOL_CONFIG],
-[# The else clause should only fire when bootstrapping the
-# libtool distribution, otherwise you forgot to ship ltmain.sh
-# with your package, and you will get complaints that there are
-# no rules to generate ltmain.sh.
-if test -f "$ltmain"; then
-  # See if we are running on zsh, and set the options which allow our commands through
-  # without removal of \ escapes.
-  if test -n "${ZSH_VERSION+set}" ; then
-    setopt NO_GLOB_SUBST
-  fi
-  # Now quote all the things that may contain metacharacters while being
-  # careful not to overquote the AC_SUBSTed values.  We take copies of the
-  # variables and quote the copies for generation of the libtool script.
-  for var in echo old_CC old_CFLAGS AR AR_FLAGS EGREP RANLIB LN_S LTCC NM \
-    SED SHELL STRIP \
-    libname_spec library_names_spec soname_spec extract_expsyms_cmds \
-    old_striplib striplib file_magic_cmd finish_cmds finish_eval \
-    deplibs_check_method reload_flag reload_cmds need_locks \
-    lt_cv_sys_global_symbol_pipe lt_cv_sys_global_symbol_to_cdecl \
-    lt_cv_sys_global_symbol_to_c_name_address \
-    sys_lib_search_path_spec sys_lib_dlsearch_path_spec \
-    old_postinstall_cmds old_postuninstall_cmds \
-    _LT_AC_TAGVAR(compiler, $1) \
-    _LT_AC_TAGVAR(CC, $1) \
-    _LT_AC_TAGVAR(LD, $1) \
-    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1) \
-    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1) \
-    _LT_AC_TAGVAR(lt_prog_compiler_static, $1) \
-    _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) \
-    _LT_AC_TAGVAR(export_dynamic_flag_spec, $1) \
-    _LT_AC_TAGVAR(thread_safe_flag_spec, $1) \
-    _LT_AC_TAGVAR(whole_archive_flag_spec, $1) \
-    _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1) \
-    _LT_AC_TAGVAR(old_archive_cmds, $1) \
-    _LT_AC_TAGVAR(old_archive_from_new_cmds, $1) \
-    _LT_AC_TAGVAR(predep_objects, $1) \
-    _LT_AC_TAGVAR(postdep_objects, $1) \
-    _LT_AC_TAGVAR(predeps, $1) \
-    _LT_AC_TAGVAR(postdeps, $1) \
-    _LT_AC_TAGVAR(compiler_lib_search_path, $1) \
-    _LT_AC_TAGVAR(archive_cmds, $1) \
-    _LT_AC_TAGVAR(archive_expsym_cmds, $1) \
-    _LT_AC_TAGVAR(postinstall_cmds, $1) \
-    _LT_AC_TAGVAR(postuninstall_cmds, $1) \
-    _LT_AC_TAGVAR(old_archive_from_expsyms_cmds, $1) \
-    _LT_AC_TAGVAR(allow_undefined_flag, $1) \
-    _LT_AC_TAGVAR(no_undefined_flag, $1) \
-    _LT_AC_TAGVAR(export_symbols_cmds, $1) \
-    _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1) \
-    _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1) \
-    _LT_AC_TAGVAR(hardcode_libdir_separator, $1) \
-    _LT_AC_TAGVAR(hardcode_automatic, $1) \
-    _LT_AC_TAGVAR(module_cmds, $1) \
-    _LT_AC_TAGVAR(module_expsym_cmds, $1) \
-    _LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1) \
-    _LT_AC_TAGVAR(exclude_expsyms, $1) \
-    _LT_AC_TAGVAR(include_expsyms, $1); do
-
-    case $var in
-    _LT_AC_TAGVAR(old_archive_cmds, $1) | \
-    _LT_AC_TAGVAR(old_archive_from_new_cmds, $1) | \
-    _LT_AC_TAGVAR(archive_cmds, $1) | \
-    _LT_AC_TAGVAR(archive_expsym_cmds, $1) | \
-    _LT_AC_TAGVAR(module_cmds, $1) | \
-    _LT_AC_TAGVAR(module_expsym_cmds, $1) | \
-    _LT_AC_TAGVAR(old_archive_from_expsyms_cmds, $1) | \
-    _LT_AC_TAGVAR(export_symbols_cmds, $1) | \
-    extract_expsyms_cmds | reload_cmds | finish_cmds | \
-    postinstall_cmds | postuninstall_cmds | \
-    old_postinstall_cmds | old_postuninstall_cmds | \
-    sys_lib_search_path_spec | sys_lib_dlsearch_path_spec)
-      # Double-quote double-evaled strings.
-      eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$double_quote_subst\" -e \"\$sed_quote_subst\" -e \"\$delay_variable_subst\"\`\\\""
-      ;;
-    *)
-      eval "lt_$var=\\\"\`\$echo \"X\$$var\" | \$Xsed -e \"\$sed_quote_subst\"\`\\\""
-      ;;
-    esac
-  done
-
-  case $lt_echo in
-  *'\[$]0 --fallback-echo"')
-    lt_echo=`$echo "X$lt_echo" | $Xsed -e 's/\\\\\\\[$]0 --fallback-echo"[$]/[$]0 --fallback-echo"/'`
-    ;;
-  esac
-
-ifelse([$1], [],
-  [cfgfile="${ofile}T"
-  trap "$rm \"$cfgfile\"; exit 1" 1 2 15
-  $rm -f "$cfgfile"
-  AC_MSG_NOTICE([creating $ofile])],
-  [cfgfile="$ofile"])
-
-  cat <<__EOF__ >> "$cfgfile"
-ifelse([$1], [],
-[#! $SHELL
-
-# `$echo "$cfgfile" | sed 's%^.*/%%'` - Provide generalized library-building support services.
-# Generated automatically by $PROGRAM (GNU $PACKAGE $VERSION$TIMESTAMP)
-# NOTE: Changes made to this file will be lost: look at ltmain.sh.
-#
-# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001
-# Free Software Foundation, Inc.
-#
-# This file is part of GNU Libtool:
-# Originally by Gordon Matzigkeit <gord at gnu.ai.mit.edu>, 1996
-#
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful, but
-# WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-# General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-#
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-# A sed program that does not truncate output.
-SED=$lt_SED
-
-# Sed that helps us avoid accidentally triggering echo(1) options like -n.
-Xsed="$SED -e 1s/^X//"
-
-# The HP-UX ksh and POSIX shell print the target directory to stdout
-# if CDPATH is set.
-(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
-
-# The names of the tagged configurations supported by this script.
-available_tags=
-
-# ### BEGIN LIBTOOL CONFIG],
-[# ### BEGIN LIBTOOL TAG CONFIG: $tagname])
-
-# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`:
-
-# Shell to use when invoking shell scripts.
-SHELL=$lt_SHELL
-
-# Whether or not to build shared libraries.
-build_libtool_libs=$enable_shared
-
-# Whether or not to build static libraries.
-build_old_libs=$enable_static
-
-# Whether or not to add -lc for building shared libraries.
-build_libtool_need_lc=$_LT_AC_TAGVAR(archive_cmds_need_lc, $1)
-
-# Whether or not to disallow shared libs when runtime libs are static
-allow_libtool_libs_with_static_runtimes=$_LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)
-
-# Whether or not to optimize for fast installation.
-fast_install=$enable_fast_install
-
-# The host system.
-host_alias=$host_alias
-host=$host
-host_os=$host_os
-
-# The build system.
-build_alias=$build_alias
-build=$build
-build_os=$build_os
-
-# An echo program that does not interpret backslashes.
-echo=$lt_echo
-
-# The archiver.
-AR=$lt_AR
-AR_FLAGS=$lt_AR_FLAGS
-
-# A C compiler.
-LTCC=$lt_LTCC
-
-# A language-specific compiler.
-CC=$lt_[]_LT_AC_TAGVAR(compiler, $1)
-
-# Is the compiler the GNU C compiler?
-with_gcc=$_LT_AC_TAGVAR(GCC, $1)
-
-# An ERE matcher.
-EGREP=$lt_EGREP
-
-# The linker used to build libraries.
-LD=$lt_[]_LT_AC_TAGVAR(LD, $1)
-
-# Whether we need hard or soft links.
-LN_S=$lt_LN_S
-
-# A BSD-compatible nm program.
-NM=$lt_NM
-
-# A symbol stripping program
-STRIP=$lt_STRIP
-
-# Used to examine libraries when file_magic_cmd begins "file"
-MAGIC_CMD=$MAGIC_CMD
-
-# Used on cygwin: DLL creation program.
-DLLTOOL="$DLLTOOL"
-
-# Used on cygwin: object dumper.
-OBJDUMP="$OBJDUMP"
-
-# Used on cygwin: assembler.
-AS="$AS"
-
-# The name of the directory that contains temporary libtool files.
-objdir=$objdir
-
-# How to create reloadable object files.
-reload_flag=$lt_reload_flag
-reload_cmds=$lt_reload_cmds
-
-# How to pass a linker flag through the compiler.
-wl=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_wl, $1)
-
-# Object file suffix (normally "o").
-objext="$ac_objext"
-
-# Old archive suffix (normally "a").
-libext="$libext"
-
-# Shared library suffix (normally ".so").
-shrext_cmds='$shrext_cmds'
-
-# Executable file suffix (normally "").
-exeext="$exeext"
-
-# Additional compiler flags for building library objects.
-pic_flag=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)
-pic_mode=$pic_mode
-
-# What is the maximum length of a command?
-max_cmd_len=$lt_cv_sys_max_cmd_len
-
-# Does compiler simultaneously support -c and -o options?
-compiler_c_o=$lt_[]_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)
-
-# Must we lock files when doing compilation?
-need_locks=$lt_need_locks
-
-# Do we need the lib prefix for modules?
-need_lib_prefix=$need_lib_prefix
-
-# Do we need a version for libraries?
-need_version=$need_version
-
-# Whether dlopen is supported.
-dlopen_support=$enable_dlopen
-
-# Whether dlopen of programs is supported.
-dlopen_self=$enable_dlopen_self
-
-# Whether dlopen of statically linked programs is supported.
-dlopen_self_static=$enable_dlopen_self_static
-
-# Compiler flag to prevent dynamic linking.
-link_static_flag=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_static, $1)
-
-# Compiler flag to turn off builtin functions.
-no_builtin_flag=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)
-
-# Compiler flag to allow reflexive dlopens.
-export_dynamic_flag_spec=$lt_[]_LT_AC_TAGVAR(export_dynamic_flag_spec, $1)
-
-# Compiler flag to generate shared objects directly from archives.
-whole_archive_flag_spec=$lt_[]_LT_AC_TAGVAR(whole_archive_flag_spec, $1)
-
-# Compiler flag to generate thread-safe objects.
-thread_safe_flag_spec=$lt_[]_LT_AC_TAGVAR(thread_safe_flag_spec, $1)
-
-# Library versioning type.
-version_type=$version_type
-
-# Format of library name prefix.
-libname_spec=$lt_libname_spec
-
-# List of archive names.  First name is the real one, the rest are links.
-# The last name is the one that the linker finds with -lNAME.
-library_names_spec=$lt_library_names_spec
-
-# The coded name of the library, if different from the real name.
-soname_spec=$lt_soname_spec
-
-# Commands used to build and install an old-style archive.
-RANLIB=$lt_RANLIB
-old_archive_cmds=$lt_[]_LT_AC_TAGVAR(old_archive_cmds, $1)
-old_postinstall_cmds=$lt_old_postinstall_cmds
-old_postuninstall_cmds=$lt_old_postuninstall_cmds
-
-# Create an old-style archive from a shared archive.
-old_archive_from_new_cmds=$lt_[]_LT_AC_TAGVAR(old_archive_from_new_cmds, $1)
-
-# Create a temporary old-style archive to link instead of a shared archive.
-old_archive_from_expsyms_cmds=$lt_[]_LT_AC_TAGVAR(old_archive_from_expsyms_cmds, $1)
-
-# Commands used to build and install a shared archive.
-archive_cmds=$lt_[]_LT_AC_TAGVAR(archive_cmds, $1)
-archive_expsym_cmds=$lt_[]_LT_AC_TAGVAR(archive_expsym_cmds, $1)
-postinstall_cmds=$lt_postinstall_cmds
-postuninstall_cmds=$lt_postuninstall_cmds
-
-# Commands used to build a loadable module (assumed same as above if empty)
-module_cmds=$lt_[]_LT_AC_TAGVAR(module_cmds, $1)
-module_expsym_cmds=$lt_[]_LT_AC_TAGVAR(module_expsym_cmds, $1)
-
-# Commands to strip libraries.
-old_striplib=$lt_old_striplib
-striplib=$lt_striplib
-
-# Dependencies to place before the objects being linked to create a
-# shared library.
-predep_objects=$lt_[]_LT_AC_TAGVAR(predep_objects, $1)
-
-# Dependencies to place after the objects being linked to create a
-# shared library.
-postdep_objects=$lt_[]_LT_AC_TAGVAR(postdep_objects, $1)
-
-# Dependencies to place before the objects being linked to create a
-# shared library.
-predeps=$lt_[]_LT_AC_TAGVAR(predeps, $1)
-
-# Dependencies to place after the objects being linked to create a
-# shared library.
-postdeps=$lt_[]_LT_AC_TAGVAR(postdeps, $1)
-
-# The library search path used internally by the compiler when linking
-# a shared library.
-compiler_lib_search_path=$lt_[]_LT_AC_TAGVAR(compiler_lib_search_path, $1)
-
-# Method to check whether dependent libraries are shared objects.
-deplibs_check_method=$lt_deplibs_check_method
-
-# Command to use when deplibs_check_method == file_magic.
-file_magic_cmd=$lt_file_magic_cmd
-
-# Flag that allows shared libraries with undefined symbols to be built.
-allow_undefined_flag=$lt_[]_LT_AC_TAGVAR(allow_undefined_flag, $1)
-
-# Flag that forces no undefined symbols.
-no_undefined_flag=$lt_[]_LT_AC_TAGVAR(no_undefined_flag, $1)
-
-# Commands used to finish a libtool library installation in a directory.
-finish_cmds=$lt_finish_cmds
-
-# Same as above, but a single script fragment to be evaled but not shown.
-finish_eval=$lt_finish_eval
-
-# Take the output of nm and produce a listing of raw symbols and C names.
-global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe
-
-# Transform the output of nm in a proper C declaration
-global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl
-
-# Transform the output of nm in a C name address pair
-global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address
-
-# This is the shared library runtime path variable.
-runpath_var=$runpath_var
-
-# This is the shared library path variable.
-shlibpath_var=$shlibpath_var
-
-# Is shlibpath searched before the hard-coded library search path?
-shlibpath_overrides_runpath=$shlibpath_overrides_runpath
-
-# How to hardcode a shared library path into an executable.
-hardcode_action=$_LT_AC_TAGVAR(hardcode_action, $1)
-
-# Whether we should hardcode library paths into libraries.
-hardcode_into_libs=$hardcode_into_libs
-
-# Flag to hardcode \$libdir into a binary during linking.
-# This must work even if \$libdir does not exist.
-hardcode_libdir_flag_spec=$lt_[]_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)
-
-# If ld is used when linking, flag to hardcode \$libdir into
-# a binary during linking. This must work even if \$libdir does
-# not exist.
-hardcode_libdir_flag_spec_ld=$lt_[]_LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)
-
-# Whether we need a single -rpath flag with a separated argument.
-hardcode_libdir_separator=$lt_[]_LT_AC_TAGVAR(hardcode_libdir_separator, $1)
-
-# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the
-# resulting binary.
-hardcode_direct=$_LT_AC_TAGVAR(hardcode_direct, $1)
-
-# Set to yes if using the -LDIR flag during linking hardcodes DIR into the
-# resulting binary.
-hardcode_minus_L=$_LT_AC_TAGVAR(hardcode_minus_L, $1)
-
-# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into
-# the resulting binary.
-hardcode_shlibpath_var=$_LT_AC_TAGVAR(hardcode_shlibpath_var, $1)
-
-# Set to yes if building a shared library automatically hardcodes DIR into the library
-# and all subsequent libraries and executables linked against it.
-hardcode_automatic=$_LT_AC_TAGVAR(hardcode_automatic, $1)
-
-# Variables whose values should be saved in libtool wrapper scripts and
-# restored at relink time.
-variables_saved_for_relink="$variables_saved_for_relink"
-
-# Whether libtool must link a program against all its dependency libraries.
-link_all_deplibs=$_LT_AC_TAGVAR(link_all_deplibs, $1)
-
-# Compile-time system search path for libraries
-sys_lib_search_path_spec=$lt_sys_lib_search_path_spec
-
-# Run-time system search path for libraries
-sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec
-
-# Fix the shell variable \$srcfile for the compiler.
-fix_srcfile_path="$_LT_AC_TAGVAR(fix_srcfile_path, $1)"
-
-# Set to yes if exported symbols are required.
-always_export_symbols=$_LT_AC_TAGVAR(always_export_symbols, $1)
-
-# The commands to list exported symbols.
-export_symbols_cmds=$lt_[]_LT_AC_TAGVAR(export_symbols_cmds, $1)
-
-# The commands to extract the exported symbol list from a shared archive.
-extract_expsyms_cmds=$lt_extract_expsyms_cmds
-
-# Symbols that should not be listed in the preloaded symbols.
-exclude_expsyms=$lt_[]_LT_AC_TAGVAR(exclude_expsyms, $1)
-
-# Symbols that must always be exported.
-include_expsyms=$lt_[]_LT_AC_TAGVAR(include_expsyms, $1)
-
-ifelse([$1],[],
-[# ### END LIBTOOL CONFIG],
-[# ### END LIBTOOL TAG CONFIG: $tagname])
-
-__EOF__
-
-ifelse([$1],[], [
-  case $host_os in
-  aix3*)
-    cat <<\EOF >> "$cfgfile"
-
-# AIX sometimes has problems with the GCC collect2 program.  For some
-# reason, if we set the COLLECT_NAMES environment variable, the problems
-# vanish in a puff of smoke.
-if test "X${COLLECT_NAMES+set}" != Xset; then
-  COLLECT_NAMES=
-  export COLLECT_NAMES
-fi
-EOF
-    ;;
-  esac
-
-  # We use sed instead of cat because bash on DJGPP gets confused if
-  # if finds mixed CR/LF and LF-only lines.  Since sed operates in
-  # text mode, it properly converts lines to CR/LF.  This bash problem
-  # is reportedly fixed, but why not run on old versions too?
-  sed '$q' "$ltmain" >> "$cfgfile" || (rm -f "$cfgfile"; exit 1)
-
-  mv -f "$cfgfile" "$ofile" || \
-    (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile")
-  chmod +x "$ofile"
-])
-else
-  # If there is no Makefile yet, we rely on a make rule to execute
-  # `config.status --recheck' to rerun these tests and create the
-  # libtool script then.
-  ltmain_in=`echo $ltmain | sed -e 's/\.sh$/.in/'`
-  if test -f "$ltmain_in"; then
-    test -f Makefile && make "$ltmain"
-  fi
-fi
-])# AC_LIBTOOL_CONFIG
-
-
-# AC_LIBTOOL_PROG_COMPILER_NO_RTTI([TAGNAME])
-# -------------------------------------------
-AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI],
-[AC_REQUIRE([_LT_AC_SYS_COMPILER])dnl
-
-_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=
-
-if test "$GCC" = yes; then
-  _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin'
-
-  AC_LIBTOOL_COMPILER_OPTION([if $compiler supports -fno-rtti -fno-exceptions],
-    lt_cv_prog_compiler_rtti_exceptions,
-    [-fno-rtti -fno-exceptions], [],
-    [_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)="$_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) -fno-rtti -fno-exceptions"])
-fi
-])# AC_LIBTOOL_PROG_COMPILER_NO_RTTI
-
-
-# AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE
-# ---------------------------------
-AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE],
-[AC_REQUIRE([AC_CANONICAL_HOST])
-AC_REQUIRE([AC_PROG_NM])
-AC_REQUIRE([AC_OBJEXT])
-# Check for command to grab the raw symbol name followed by C symbol from nm.
-AC_MSG_CHECKING([command to parse $NM output from $compiler object])
-AC_CACHE_VAL([lt_cv_sys_global_symbol_pipe],
-[
-# These are sane defaults that work on at least a few old systems.
-# [They come from Ultrix.  What could be older than Ultrix?!! ;)]
-
-# Character class describing NM global symbol codes.
-symcode='[[BCDEGRST]]'
-
-# Regexp to match symbols that can be accessed directly from C.
-sympat='\([[_A-Za-z]][[_A-Za-z0-9]]*\)'
-
-# Transform an extracted symbol line into a proper C declaration
-lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^. .* \(.*\)$/extern int \1;/p'"
-
-# Transform an extracted symbol line into symbol name and symbol address
-lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\) $/  {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode \([[^ ]]*\) \([[^ ]]*\)$/  {\"\2\", (lt_ptr) \&\2},/p'"
-
-# Define system-specific variables.
-case $host_os in
-aix*)
-  symcode='[[BCDT]]'
-  ;;
-cygwin* | mingw* | pw32*)
-  symcode='[[ABCDGISTW]]'
-  ;;
-hpux*) # Its linker distinguishes data from code symbols
-  if test "$host_cpu" = ia64; then
-    symcode='[[ABCDEGRST]]'
-  fi
-  lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'"
-  lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\) $/  {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/  {\"\2\", (lt_ptr) \&\2},/p'"
-  ;;
-linux*)
-  if test "$host_cpu" = ia64; then
-    symcode='[[ABCDGIRSTW]]'
-    lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'"
-    lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\) $/  {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/  {\"\2\", (lt_ptr) \&\2},/p'"
-  fi
-  ;;
-irix* | nonstopux*)
-  symcode='[[BCDEGRST]]'
-  ;;
-osf*)
-  symcode='[[BCDEGQRST]]'
-  ;;
-solaris* | sysv5*)
-  symcode='[[BDRT]]'
-  ;;
-sysv4)
-  symcode='[[DFNSTU]]'
-  ;;
-esac
-
-# Handle CRLF in mingw tool chain
-opt_cr=
-case $build_os in
-mingw*)
-  opt_cr=`echo 'x\{0,1\}' | tr x '\015'` # option cr in regexp
-  ;;
-esac
-
-# If we're using GNU nm, then use its standard symbol codes.
-case `$NM -V 2>&1` in
-*GNU* | *'with BFD'*)
-  symcode='[[ABCDGIRSTW]]' ;;
-esac
-
-# Try without a prefix undercore, then with it.
-for ac_symprfx in "" "_"; do
-
-  # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol.
-  symxfrm="\\1 $ac_symprfx\\2 \\2"
-
-  # Write the raw and C identifiers.
-  lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[ 	]]\($symcode$symcode*\)[[ 	]][[ 	]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'"
-
-  # Check to see that the pipe works correctly.
-  pipe_works=no
-
-  rm -f conftest*
-  cat > conftest.$ac_ext <<EOF
-#ifdef __cplusplus
-extern "C" {
-#endif
-char nm_test_var;
-void nm_test_func(){}
-#ifdef __cplusplus
-}
-#endif
-int main(){nm_test_var='a';nm_test_func();return(0);}
-EOF
-
-  if AC_TRY_EVAL(ac_compile); then
-    # Now try to grab the symbols.
-    nlist=conftest.nm
-    if AC_TRY_EVAL(NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $nlist) && test -s "$nlist"; then
-      # Try sorting and uniquifying the output.
-      if sort "$nlist" | uniq > "$nlist"T; then
-	mv -f "$nlist"T "$nlist"
-      else
-	rm -f "$nlist"T
-      fi
-
-      # Make sure that we snagged all the symbols we need.
-      if grep ' nm_test_var$' "$nlist" >/dev/null; then
-	if grep ' nm_test_func$' "$nlist" >/dev/null; then
-	  cat <<EOF > conftest.$ac_ext
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-EOF
-	  # Now generate the symbol file.
-	  eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | grep -v main >> conftest.$ac_ext'
-
-	  cat <<EOF >> conftest.$ac_ext
-#if defined (__STDC__) && __STDC__
-# define lt_ptr_t void *
-#else
-# define lt_ptr_t char *
-# define const
-#endif
-
-/* The mapping between symbol names and symbols. */
-const struct {
-  const char *name;
-  lt_ptr_t address;
-}
-lt_preloaded_symbols[[]] =
-{
-EOF
-	  $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/  {\"\2\", (lt_ptr_t) \&\2},/" < "$nlist" | grep -v main >> conftest.$ac_ext
-	  cat <<\EOF >> conftest.$ac_ext
-  {0, (lt_ptr_t) 0}
-};
-
-#ifdef __cplusplus
-}
-#endif
-EOF
-	  # Now try linking the two files.
-	  mv conftest.$ac_objext conftstm.$ac_objext
-	  lt_save_LIBS="$LIBS"
-	  lt_save_CFLAGS="$CFLAGS"
-	  LIBS="conftstm.$ac_objext"
-	  CFLAGS="$CFLAGS$_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)"
-	  if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext}; then
-	    pipe_works=yes
-	  fi
-	  LIBS="$lt_save_LIBS"
-	  CFLAGS="$lt_save_CFLAGS"
-	else
-	  echo "cannot find nm_test_func in $nlist" >&AS_MESSAGE_LOG_FD
-	fi
-      else
-	echo "cannot find nm_test_var in $nlist" >&AS_MESSAGE_LOG_FD
-      fi
-    else
-      echo "cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD
-    fi
-  else
-    echo "$progname: failed program was:" >&AS_MESSAGE_LOG_FD
-    cat conftest.$ac_ext >&5
-  fi
-  rm -f conftest* conftst*
-
-  # Do not use the global_symbol_pipe unless it works.
-  if test "$pipe_works" = yes; then
-    break
-  else
-    lt_cv_sys_global_symbol_pipe=
-  fi
-done
-])
-if test -z "$lt_cv_sys_global_symbol_pipe"; then
-  lt_cv_sys_global_symbol_to_cdecl=
-fi
-if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then
-  AC_MSG_RESULT(failed)
-else
-  AC_MSG_RESULT(ok)
-fi
-]) # AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE
-
-
-# AC_LIBTOOL_PROG_COMPILER_PIC([TAGNAME])
-# ---------------------------------------
-AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC],
-[_LT_AC_TAGVAR(lt_prog_compiler_wl, $1)=
-_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=
-_LT_AC_TAGVAR(lt_prog_compiler_static, $1)=
-
-AC_MSG_CHECKING([for $compiler option to produce PIC])
- ifelse([$1],[CXX],[
-  # C++ specific cases for pic, static, wl, etc.
-  if test "$GXX" = yes; then
-    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-    _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static'
-
-    case $host_os in
-    aix*)
-      # All AIX code is PIC.
-      if test "$host_cpu" = ia64; then
-	# AIX 5 now supports IA64 processor
-	_LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-      fi
-      ;;
-    amigaos*)
-      # FIXME: we need at least 68020 code to build shared libraries, but
-      # adding the `-m68020' flag to GCC prevents building anything better,
-      # like `-m68040'.
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4'
-      ;;
-    beos* | cygwin* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*)
-      # PIC is the default for these OSes.
-      ;;
-    mingw* | os2* | pw32*)
-      # This hack is so that the source file can tell whether it is being
-      # built for inclusion in a dll (and should export symbols for example).
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'
-      ;;
-    darwin* | rhapsody*)
-      # PIC is the default on this platform
-      # Common symbols not allowed in MH_DYLIB files
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common'
-      ;;
-    *djgpp*)
-      # DJGPP does not support shared libraries at all
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=
-      ;;
-    sysv4*MP*)
-      if test -d /usr/nec; then
-	_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic
-      fi
-      ;;
-    hpux*)
-      # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but
-      # not for PA HP-UX.
-      case "$host_cpu" in
-      hppa*64*|ia64*)
-	;;
-      *)
-	_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
-	;;
-      esac
-      ;;
-    *)
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
-      ;;
-    esac
-  else
-    case $host_os in
-      aix4* | aix5*)
-	# All AIX code is PIC.
-	if test "$host_cpu" = ia64; then
-	  # AIX 5 now supports IA64 processor
-	  _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-	else
-	  _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp'
-	fi
-	;;
-      chorus*)
-	case $cc_basename in
-	cxch68*)
-	  # Green Hills C++ Compiler
-	  # _LT_AC_TAGVAR(lt_prog_compiler_static, $1)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a"
-	  ;;
-	esac
-	;;
-       darwin*)
-         # PIC is the default on this platform
-         # Common symbols not allowed in MH_DYLIB files
-         case $cc_basename in
-           xlc*)
-           _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-qnocommon'
-           _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-           ;;
-         esac
-       ;;
-      dgux*)
-	case $cc_basename in
-	  ec++*)
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
-	    ;;
-	  ghcx*)
-	    # Green Hills C++ Compiler
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic'
-	    ;;
-	  *)
-	    ;;
-	esac
-	;;
-      freebsd* | kfreebsd*-gnu | dragonfly*)
-	# FreeBSD uses GNU C++
-	;;
-      hpux9* | hpux10* | hpux11*)
-	case $cc_basename in
-	  CC*)
-	    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-	    _LT_AC_TAGVAR(lt_prog_compiler_static, $1)="${ac_cv_prog_cc_wl}-a ${ac_cv_prog_cc_wl}archive"
-	    if test "$host_cpu" != ia64; then
-	      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='+Z'
-	    fi
-	    ;;
-	  aCC*)
-	    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-	    _LT_AC_TAGVAR(lt_prog_compiler_static, $1)="${ac_cv_prog_cc_wl}-a ${ac_cv_prog_cc_wl}archive"
-	    case "$host_cpu" in
-	    hppa*64*|ia64*)
-	      # +Z the default
-	      ;;
-	    *)
-	      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='+Z'
-	      ;;
-	    esac
-	    ;;
-	  *)
-	    ;;
-	esac
-	;;
-      irix5* | irix6* | nonstopux*)
-	case $cc_basename in
-	  CC*)
-	    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-	    _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
-	    # CC pic flag -KPIC is the default.
-	    ;;
-	  *)
-	    ;;
-	esac
-	;;
-      linux*)
-	case $cc_basename in
-	  KCC*)
-	    # KAI C++ Compiler
-	    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,'
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
-	    ;;
-	  icpc* | ecpc*)
-	    # Intel C++
-	    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
-	    _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static'
-	    ;;
-	  pgCC*)
-	    # Portland Group C++ compiler.
-	    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fpic'
-	    _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static'
-	    ;;
-	  cxx*)
-	    # Compaq C++
-	    # Make sure the PIC flag is empty.  It appears that all Alpha
-	    # Linux and Compaq Tru64 Unix objects are PIC.
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=
-	    _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
-	    ;;
-	  *)
-	    ;;
-	esac
-	;;
-      lynxos*)
-	;;
-      m88k*)
-	;;
-      mvs*)
-	case $cc_basename in
-	  cxx*)
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall'
-	    ;;
-	  *)
-	    ;;
-	esac
-	;;
-      netbsd*)
-	;;
-      osf3* | osf4* | osf5*)
-	case $cc_basename in
-	  KCC*)
-	    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,'
-	    ;;
-	  RCC*)
-	    # Rational C++ 2.4.1
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic'
-	    ;;
-	  cxx*)
-	    # Digital/Compaq C++
-	    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-	    # Make sure the PIC flag is empty.  It appears that all Alpha
-	    # Linux and Compaq Tru64 Unix objects are PIC.
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=
-	    _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
-	    ;;
-	  *)
-	    ;;
-	esac
-	;;
-      psos*)
-	;;
-      sco*)
-	case $cc_basename in
-	  CC*)
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
-	    ;;
-	  *)
-	    ;;
-	esac
-	;;
-      solaris*)
-	case $cc_basename in
-	  CC*)
-	    # Sun C++ 4.2, 5.x and Centerline C++
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
-	    _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-	    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld '
-	    ;;
-	  gcx*)
-	    # Green Hills C++ Compiler
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-PIC'
-	    ;;
-	  *)
-	    ;;
-	esac
-	;;
-      sunos4*)
-	case $cc_basename in
-	  CC*)
-	    # Sun C++ 4.x
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic'
-	    _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-	    ;;
-	  lcc*)
-	    # Lucid
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic'
-	    ;;
-	  *)
-	    ;;
-	esac
-	;;
-      tandem*)
-	case $cc_basename in
-	  NCC*)
-	    # NonStop-UX NCC 3.20
-	    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
-	    ;;
-	  *)
-	    ;;
-	esac
-	;;
-      unixware*)
-	;;
-      vxworks*)
-	;;
-      *)
-	_LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no
-	;;
-    esac
-  fi
-],
-[
-  if test "$GCC" = yes; then
-    _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-    _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static'
-
-    case $host_os in
-      aix*)
-      # All AIX code is PIC.
-      if test "$host_cpu" = ia64; then
-	# AIX 5 now supports IA64 processor
-	_LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-      fi
-      ;;
-
-    amigaos*)
-      # FIXME: we need at least 68020 code to build shared libraries, but
-      # adding the `-m68020' flag to GCC prevents building anything better,
-      # like `-m68040'.
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4'
-      ;;
-
-    beos* | cygwin* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*)
-      # PIC is the default for these OSes.
-      ;;
-
-    mingw* | pw32* | os2*)
-      # This hack is so that the source file can tell whether it is being
-      # built for inclusion in a dll (and should export symbols for example).
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'
-      ;;
-
-    darwin* | rhapsody*)
-      # PIC is the default on this platform
-      # Common symbols not allowed in MH_DYLIB files
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common'
-      ;;
-
-    msdosdjgpp*)
-      # Just because we use GCC doesn't mean we suddenly get shared libraries
-      # on systems that don't support them.
-      _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no
-      enable_shared=no
-      ;;
-
-    sysv4*MP*)
-      if test -d /usr/nec; then
-	_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic
-      fi
-      ;;
-
-    hpux*)
-      # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but
-      # not for PA HP-UX.
-      case "$host_cpu" in
-      hppa*64*|ia64*)
-	# +Z the default
-	;;
-      *)
-	_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
-	;;
-      esac
-      ;;
-
-    *)
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
-      ;;
-    esac
-  else
-    # PORTME Check for flag to pass linker flags through the system compiler.
-    case $host_os in
-    aix*)
-      _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-      if test "$host_cpu" = ia64; then
-	# AIX 5 now supports IA64 processor
-	_LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-      else
-	_LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp'
-      fi
-      ;;
-      darwin*)
-        # PIC is the default on this platform
-        # Common symbols not allowed in MH_DYLIB files
-       case $cc_basename in
-         xlc*)
-         _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-qnocommon'
-         _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-         ;;
-       esac
-       ;;
-
-    mingw* | pw32* | os2*)
-      # This hack is so that the source file can tell whether it is being
-      # built for inclusion in a dll (and should export symbols for example).
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'
-      ;;
-
-    hpux9* | hpux10* | hpux11*)
-      _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-      # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but
-      # not for PA HP-UX.
-      case "$host_cpu" in
-      hppa*64*|ia64*)
-	# +Z the default
-	;;
-      *)
-	_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='+Z'
-	;;
-      esac
-      # Is there a better lt_prog_compiler_static that works with the bundled CC?
-      _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive'
-      ;;
-
-    irix5* | irix6* | nonstopux*)
-      _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-      # PIC (with -KPIC) is the default.
-      _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
-      ;;
-
-    newsos6)
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
-      _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-      ;;
-
-    linux*)
-      case $cc_basename in
-      icc* | ecc*)
-	_LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-	_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
-	_LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static'
-        ;;
-      pgcc* | pgf77* | pgf90*)
-        # Portland Group compilers (*not* the Pentium gcc compiler,
-	# which looks to be a dead project)
-	_LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-	_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fpic'
-	_LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static'
-        ;;
-      ccc*)
-        _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-        # All Alpha code is PIC.
-        _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
-        ;;
-      esac
-      ;;
-
-    osf3* | osf4* | osf5*)
-      _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-      # All OSF/1 code is PIC.
-      _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
-      ;;
-
-    sco3.2v5*)
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-Kpic'
-      _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-dn'
-      ;;
-
-    solaris*)
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
-      _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-      case $cc_basename in
-      f77* | f90* | f95*)
-	_LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ';;
-      *)
-	_LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,';;
-      esac
-      ;;
-
-    sunos4*)
-      _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld '
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-PIC'
-      _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-      ;;
-
-    sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*)
-      _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
-      _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-      ;;
-
-    sysv4*MP*)
-      if test -d /usr/nec ;then
-	_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic'
-	_LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-      fi
-      ;;
-
-    unicos*)
-      _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
-      _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no
-      ;;
-
-    uts4*)
-      _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic'
-      _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
-      ;;
-
-    *)
-      _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no
-      ;;
-    esac
-  fi
-])
-AC_MSG_RESULT([$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)])
-
-#
-# Check to make sure the PIC flag actually works.
-#
-if test -n "$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)"; then
-  AC_LIBTOOL_COMPILER_OPTION([if $compiler PIC flag $_LT_AC_TAGVAR(lt_prog_compiler_pic, $1) works],
-    _LT_AC_TAGVAR(lt_prog_compiler_pic_works, $1),
-    [$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)ifelse([$1],[],[ -DPIC],[ifelse([$1],[CXX],[ -DPIC],[])])], [],
-    [case $_LT_AC_TAGVAR(lt_prog_compiler_pic, $1) in
-     "" | " "*) ;;
-     *) _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=" $_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)" ;;
-     esac],
-    [_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=
-     _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no])
-fi
-case "$host_os" in
-  # For platforms which do not support PIC, -DPIC is meaningless:
-  *djgpp*)
-    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=
-    ;;
-  *)
-    _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)="$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)ifelse([$1],[],[ -DPIC],[ifelse([$1],[CXX],[ -DPIC],[])])"
-    ;;
-esac
-])
-
-
-# AC_LIBTOOL_PROG_LD_SHLIBS([TAGNAME])
-# ------------------------------------
-# See if the linker supports building shared libraries.
-AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS],
-[AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries])
-ifelse([$1],[CXX],[
-  _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols'
-  case $host_os in
-  aix4* | aix5*)
-    # If we're using GNU nm, then we don't want the "-C" option.
-    # -C means demangle to AIX nm, but means don't demangle with GNU nm
-    if $NM -V 2>&1 | grep 'GNU' > /dev/null; then
-      _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols'
-    else
-      _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols'
-    fi
-    ;;
-  pw32*)
-    _LT_AC_TAGVAR(export_symbols_cmds, $1)="$ltdll_cmds"
-  ;;
-  cygwin* | mingw*)
-    _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]] /s/.* \([[^ ]]*\)/\1 DATA/;/^.* __nm__/s/^.* __nm__\([[^ ]]*\) [[^ ]]*/\1 DATA/;/^I /d;/^[[AITW]] /s/.* //'\'' | sort | uniq > $export_symbols'
-  ;;
-  *)
-    _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols'
-  ;;
-  esac
-],[
-  runpath_var=
-  _LT_AC_TAGVAR(allow_undefined_flag, $1)=
-  _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=no
-  _LT_AC_TAGVAR(archive_cmds, $1)=
-  _LT_AC_TAGVAR(archive_expsym_cmds, $1)=
-  _LT_AC_TAGVAR(old_archive_From_new_cmds, $1)=
-  _LT_AC_TAGVAR(old_archive_from_expsyms_cmds, $1)=
-  _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)=
-  _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=
-  _LT_AC_TAGVAR(thread_safe_flag_spec, $1)=
-  _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)=
-  _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)=
-  _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=
-  _LT_AC_TAGVAR(hardcode_direct, $1)=no
-  _LT_AC_TAGVAR(hardcode_minus_L, $1)=no
-  _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=unsupported
-  _LT_AC_TAGVAR(link_all_deplibs, $1)=unknown
-  _LT_AC_TAGVAR(hardcode_automatic, $1)=no
-  _LT_AC_TAGVAR(module_cmds, $1)=
-  _LT_AC_TAGVAR(module_expsym_cmds, $1)=
-  _LT_AC_TAGVAR(always_export_symbols, $1)=no
-  _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols'
-  # include_expsyms should be a list of space-separated symbols to be *always*
-  # included in the symbol list
-  _LT_AC_TAGVAR(include_expsyms, $1)=
-  # exclude_expsyms can be an extended regexp of symbols to exclude
-  # it will be wrapped by ` (' and `)$', so one must not match beginning or
-  # end of line.  Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc',
-  # as well as any symbol that contains `d'.
-  _LT_AC_TAGVAR(exclude_expsyms, $1)="_GLOBAL_OFFSET_TABLE_"
-  # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out
-  # platforms (ab)use it in PIC code, but their linkers get confused if
-  # the symbol is explicitly referenced.  Since portable code cannot
-  # rely on this symbol name, it's probably fine to never include it in
-  # preloaded symbol tables.
-  extract_expsyms_cmds=
-  # Just being paranoid about ensuring that cc_basename is set.
-  _LT_CC_BASENAME([$compiler])
-  case $host_os in
-  cygwin* | mingw* | pw32*)
-    # FIXME: the MSVC++ port hasn't been tested in a loooong time
-    # When not using gcc, we currently assume that we are using
-    # Microsoft Visual C++.
-    if test "$GCC" != yes; then
-      with_gnu_ld=no
-    fi
-    ;;
-  openbsd*)
-    with_gnu_ld=no
-    ;;
-  esac
-
-  _LT_AC_TAGVAR(ld_shlibs, $1)=yes
-  if test "$with_gnu_ld" = yes; then
-    # If archive_cmds runs LD, not CC, wlarc should be empty
-    wlarc='${wl}'
-    
-    # Set some defaults for GNU ld with shared library support. These
-    # are reset later if shared libraries are not supported. Putting them
-    # here allows them to be overridden if necessary.
-    runpath_var=LD_RUN_PATH
-    _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir'
-    _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
-    # ancient GNU ld didn't support --whole-archive et. al.
-    if $LD --help 2>&1 | grep 'no-whole-archive' > /dev/null; then
-	_LT_AC_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
-      else
-  	_LT_AC_TAGVAR(whole_archive_flag_spec, $1)=
-    fi
-    supports_anon_versioning=no
-    case `$LD -v 2>/dev/null` in
-      *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11
-      *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ...
-      *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ...
-      *\ 2.11.*) ;; # other 2.11 versions
-      *) supports_anon_versioning=yes ;;
-    esac
-    
-    # See if GNU ld supports shared libraries.
-    case $host_os in
-    aix3* | aix4* | aix5*)
-      # On AIX/PPC, the GNU linker is very broken
-      if test "$host_cpu" != ia64; then
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	cat <<EOF 1>&2
-
-*** Warning: the GNU linker, at least up to release 2.9.1, is reported
-*** to be unable to reliably create shared libraries on AIX.
-*** Therefore, libtool is disabling shared libraries support.  If you
-*** really care for shared libraries, you may want to modify your PATH
-*** so that a non-GNU linker is found, and then restart.
-
-EOF
-      fi
-      ;;
-
-    amigaos*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)'
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-      _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes
-
-      # Samuel A. Falvo II <kc5tja at dolphin.openprojects.net> reports
-      # that the semantics of dynamic libraries on AmigaOS, at least up
-      # to version 4, is to share data among multiple programs linked
-      # with the same dynamic library.  Since this doesn't match the
-      # behavior of shared libraries on other platforms, we can't use
-      # them.
-      _LT_AC_TAGVAR(ld_shlibs, $1)=no
-      ;;
-
-    beos*)
-      if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
-	_LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported
-	# Joseph Beckenbach <jrb3 at best.com> says some releases of gcc
-	# support --undefined.  This deserves some investigation.  FIXME
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-      else
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-      fi
-      ;;
-
-    cygwin* | mingw* | pw32*)
-      # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless,
-      # as there is no search path for DLLs.
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-      _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported
-      _LT_AC_TAGVAR(always_export_symbols, $1)=no
-      _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
-      _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]] /s/.* \([[^ ]]*\)/\1 DATA/'\'' | $SED -e '\''/^[[AITW]] /s/.* //'\'' | sort | uniq > $export_symbols'
-
-      if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then
-        _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib'
-	# If the export-symbols file already is a .def file (1st line
-	# is EXPORTS), use it as is; otherwise, prepend...
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
-	  cp $export_symbols $output_objdir/$soname.def;
-	else
-	  echo EXPORTS > $output_objdir/$soname.def;
-	  cat $export_symbols >> $output_objdir/$soname.def;
-	fi~
-	$CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000  ${wl}--out-implib,$lib'
-      else
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-      fi
-      ;;
-
-    linux*)
-      if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
-	tmp_addflag=
-	case $cc_basename,$host_cpu in
-	pgcc*)				# Portland Group C compiler
-	  _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=
-	  ;;
-	pgf77* | pgf90* )			# Portland Group f77 and f90 compilers
-	  _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=
-	  tmp_addflag=' -fpic -Mnomain' ;;
-	ecc*,ia64* | icc*,ia64*)		# Intel C compiler on ia64
-	  tmp_addflag=' -i_dynamic' ;;
-	efc*,ia64* | ifort*,ia64*)	# Intel Fortran compiler on ia64
-	  tmp_addflag=' -i_dynamic -nofor_main' ;;
-	ifc* | ifort*)			# Intel Fortran compiler
-	  tmp_addflag=' -nofor_main' ;;
-	esac
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-
-	if test $supports_anon_versioning = yes; then
-	  _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $output_objdir/$libname.ver~
-  cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
-  $echo "local: *; };" >> $output_objdir/$libname.ver~
-	  $CC -shared'"$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib'
-	fi
-      else
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-      fi
-      ;;
-
-    netbsd*)
-      if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then
-	_LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib'
-	wlarc=
-      else
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
-      fi
-      ;;
-
-    solaris* | sysv5*)
-      if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-	cat <<EOF 1>&2
-
-*** Warning: The releases 2.8.* of the GNU linker cannot reliably
-*** create shared libraries on Solaris systems.  Therefore, libtool
-*** is disabling shared libraries support.  We urge you to upgrade GNU
-*** binutils to release 2.9.1 or newer.  Another option is to modify
-*** your PATH or compiler configuration so that the native linker is
-*** used, and then restart.
-
-EOF
-      elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
-      else
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-      fi
-      ;;
-
-    sunos4*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags'
-      wlarc=
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-
-    *)
-      if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
-      else
-	_LT_AC_TAGVAR(ld_shlibs, $1)=no
-      fi
-      ;;
-    esac
-
-    if test "$_LT_AC_TAGVAR(ld_shlibs, $1)" = no; then
-      runpath_var=
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)=
-      _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)=
-      _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=
-    fi
-  else
-    # PORTME fill in a description of your system's linker (not GNU ld)
-    case $host_os in
-    aix3*)
-      _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported
-      _LT_AC_TAGVAR(always_export_symbols, $1)=yes
-      _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname'
-      # Note: this linker hardcodes the directories in LIBPATH if there
-      # are no directories specified by -L.
-      _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes
-      if test "$GCC" = yes && test -z "$link_static_flag"; then
-	# Neither direct hardcoding nor static linking is supported with a
-	# broken collect2.
-	_LT_AC_TAGVAR(hardcode_direct, $1)=unsupported
-      fi
-      ;;
-
-    aix4* | aix5*)
-      if test "$host_cpu" = ia64; then
-	# On IA64, the linker does run time linking by default, so we don't
-	# have to do anything special.
-	aix_use_runtimelinking=no
-	exp_sym_flag='-Bexport'
-	no_entry_flag=""
-      else
-	# If we're using GNU nm, then we don't want the "-C" option.
-	# -C means demangle to AIX nm, but means don't demangle with GNU nm
-	if $NM -V 2>&1 | grep 'GNU' > /dev/null; then
-	  _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols'
-	else
-	  _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols'
-	fi
-	aix_use_runtimelinking=no
-
-	# Test if we are trying to use run time linking or normal
-	# AIX style linking. If -brtl is somewhere in LDFLAGS, we
-	# need to do runtime linking.
-	case $host_os in aix4.[[23]]|aix4.[[23]].*|aix5*)
-	  for ld_flag in $LDFLAGS; do
-  	  if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then
-  	    aix_use_runtimelinking=yes
-  	    break
-  	  fi
-	  done
-	esac
-
-	exp_sym_flag='-bexport'
-	no_entry_flag='-bnoentry'
-      fi
-
-      # When large executables or shared objects are built, AIX ld can
-      # have problems creating the table of contents.  If linking a library
-      # or program results in "error TOC overflow" add -mminimal-toc to
-      # CXXFLAGS/CFLAGS for g++/gcc.  In the cases where that is not
-      # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS.
-
-      _LT_AC_TAGVAR(archive_cmds, $1)=''
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=':'
-      _LT_AC_TAGVAR(link_all_deplibs, $1)=yes
-
-      if test "$GCC" = yes; then
-	case $host_os in aix4.[[012]]|aix4.[[012]].*)
-	# We only want to do this on AIX 4.2 and lower, the check
-	# below for broken collect2 doesn't work under 4.3+
-	  collect2name=`${CC} -print-prog-name=collect2`
-	  if test -f "$collect2name" && \
-  	   strings "$collect2name" | grep resolve_lib_name >/dev/null
-	  then
-  	  # We have reworked collect2
-  	  _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-	  else
-  	  # We have old collect2
-  	  _LT_AC_TAGVAR(hardcode_direct, $1)=unsupported
-  	  # It fails to find uninstalled libraries when the uninstalled
-  	  # path is not listed in the libpath.  Setting hardcode_minus_L
-  	  # to unsupported forces relinking
-  	  _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes
-  	  _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-  	  _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=
-	  fi
-	esac
-	shared_flag='-shared'
-	if test "$aix_use_runtimelinking" = yes; then
-	  shared_flag="$shared_flag "'${wl}-G'
-	fi
-      else
-	# not using gcc
-	if test "$host_cpu" = ia64; then
-  	# VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release
-  	# chokes on -Wl,-G. The following line is correct:
-	  shared_flag='-G'
-	else
-  	if test "$aix_use_runtimelinking" = yes; then
-	    shared_flag='${wl}-G'
-	  else
-	    shared_flag='${wl}-bM:SRE'
-  	fi
-	fi
-      fi
-
-      # It seems that -bexpall does not export symbols beginning with
-      # underscore (_), so it is better to generate a list of symbols to export.
-      _LT_AC_TAGVAR(always_export_symbols, $1)=yes
-      if test "$aix_use_runtimelinking" = yes; then
-	# Warning - without using the other runtime loading flags (-brtl),
-	# -berok will link without error, but may produce a broken library.
-	_LT_AC_TAGVAR(allow_undefined_flag, $1)='-berok'
-       # Determine the default libpath from the value encoded in an empty executable.
-       _LT_AC_SYS_LIBPATH_AIX
-       _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols $shared_flag"
-       else
-	if test "$host_cpu" = ia64; then
-	  _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib'
-	  _LT_AC_TAGVAR(allow_undefined_flag, $1)="-z nodefs"
-	  _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols"
-	else
-	 # Determine the default libpath from the value encoded in an empty executable.
-	 _LT_AC_SYS_LIBPATH_AIX
-	 _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
-	  # Warning - without using the other run time loading flags,
-	  # -berok will link without error, but may produce a broken library.
-	  _LT_AC_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok'
-	  _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok'
-	  # -bexpall does not export symbols beginning with underscore (_)
-	  _LT_AC_TAGVAR(always_export_symbols, $1)=yes
-	  # Exported symbols can be pulled into shared objects from archives
-	  _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=' '
-	  _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes
-	  # This is similar to how AIX traditionally builds it's shared libraries.
-	  _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}-bE:$export_symbols ${wl}-bnoentry${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
-	fi
-      fi
-      ;;
-
-    amigaos*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)'
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-      _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes
-      # see comment about different semantics on the GNU ld section
-      _LT_AC_TAGVAR(ld_shlibs, $1)=no
-      ;;
-
-    bsdi[[45]]*)
-      _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)=-rdynamic
-      ;;
-
-    cygwin* | mingw* | pw32*)
-      # When not using gcc, we currently assume that we are using
-      # Microsoft Visual C++.
-      # hardcode_libdir_flag_spec is actually meaningless, as there is
-      # no search path for DLLs.
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)=' '
-      _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported
-      # Tell ltmain to make .lib files, not .a files.
-      libext=lib
-      # Tell ltmain to make .dll files, not .so files.
-      shrext_cmds=".dll"
-      # FIXME: Setting linknames here is a bad hack.
-      _LT_AC_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `echo "$deplibs" | $SED -e '\''s/ -lc$//'\''` -link -dll~linknames='
-      # The linker will automatically build a .lib file if we build a DLL.
-      _LT_AC_TAGVAR(old_archive_From_new_cmds, $1)='true'
-      # FIXME: Should let the user specify the lib program.
-      _LT_AC_TAGVAR(old_archive_cmds, $1)='lib /OUT:$oldlib$oldobjs$old_deplibs'
-      _LT_AC_TAGVAR(fix_srcfile_path, $1)='`cygpath -w "$srcfile"`'
-      _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
-      ;;
-
-    darwin* | rhapsody*)
-      case "$host_os" in
-        rhapsody* | darwin1.[[012]])
-         _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-undefined ${wl}suppress'
-         ;;
-       *) # Darwin 1.3 on
-         if test -z ${MACOSX_DEPLOYMENT_TARGET} ; then
-           _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-flat_namespace ${wl}-undefined ${wl}suppress'
-         else
-           case ${MACOSX_DEPLOYMENT_TARGET} in
-             10.[[012]])
-               _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-flat_namespace ${wl}-undefined ${wl}suppress'
-               ;;
-             10.*)
-               _LT_AC_TAGVAR(allow_undefined_flag, $1)='${wl}-undefined ${wl}dynamic_lookup'
-               ;;
-           esac
-         fi
-         ;;
-      esac
-      _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no
-      _LT_AC_TAGVAR(hardcode_direct, $1)=no
-      _LT_AC_TAGVAR(hardcode_automatic, $1)=yes
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=unsupported
-      _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=''
-      _LT_AC_TAGVAR(link_all_deplibs, $1)=yes
-    if test "$GCC" = yes ; then
-    	output_verbose_link_cmd='echo'
-        _LT_AC_TAGVAR(archive_cmds, $1)='$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring'
-      _LT_AC_TAGVAR(module_cmds, $1)='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags'
-      # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin ld's
-      _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[    ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}'
-      _LT_AC_TAGVAR(module_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[    ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag  -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}'
-    else
-      case $cc_basename in
-        xlc*)
-         output_verbose_link_cmd='echo'
-         _LT_AC_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}`echo $rpath/$soname` $verstring'
-         _LT_AC_TAGVAR(module_cmds, $1)='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags'
-          # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin ld's
-         _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[    ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -qmkshrobj $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-install_name ${wl}$rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}'
-          _LT_AC_TAGVAR(module_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[    ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag  -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}'
-          ;;
-       *)
-         _LT_AC_TAGVAR(ld_shlibs, $1)=no
-          ;;
-      esac
-    fi
-      ;;
-
-    dgux*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-
-    freebsd1*)
-      _LT_AC_TAGVAR(ld_shlibs, $1)=no
-      ;;
-
-    # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor
-    # support.  Future versions do this automatically, but an explicit c++rt0.o
-    # does not break anything, and helps significantly (at the cost of a little
-    # extra space).
-    freebsd2.2*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o'
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-
-    # Unfortunately, older versions of FreeBSD 2 do not have this feature.
-    freebsd2*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-
-    # FreeBSD 3 and greater uses gcc -shared to do shared libraries.
-    freebsd* | kfreebsd*-gnu | dragonfly*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -o $lib $libobjs $deplibs $compiler_flags'
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-
-    hpux9*)
-      if test "$GCC" = yes; then
-	_LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
-      else
-	_LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
-      fi
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
-      _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-
-      # hardcode_minus_L: Not really in the search PATH,
-      # but as the default location of the library.
-      _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes
-      _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
-      ;;
-
-    hpux10* | hpux11*)
-      if test "$GCC" = yes -a "$with_gnu_ld" = no; then
-	case "$host_cpu" in
-	hppa*64*|ia64*)
-	  _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
-	  ;;
-	*)
-	  _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
-	  ;;
-	esac
-      else
-	case "$host_cpu" in
-	hppa*64*|ia64*)
-	  _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname -o $lib $libobjs $deplibs $linker_flags'
-	  ;;
-	*)
-	  _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'
-	  ;;
-	esac
-      fi
-      if test "$with_gnu_ld" = no; then
-	case "$host_cpu" in
-	hppa*64*)
-	  _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
-	  _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='+b $libdir'
-	  _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-	  _LT_AC_TAGVAR(hardcode_direct, $1)=no
-	  _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-	  ;;
-	ia64*)
-	  _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-	  _LT_AC_TAGVAR(hardcode_direct, $1)=no
-	  _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-
-	  # hardcode_minus_L: Not really in the search PATH,
-	  # but as the default location of the library.
-	  _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes
-	  ;;
-	*)
-	  _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
-	  _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-	  _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-	  _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
-
-	  # hardcode_minus_L: Not really in the search PATH,
-	  # but as the default location of the library.
-	  _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes
-	  ;;
-	esac
-      fi
-      ;;
-
-    irix5* | irix6* | nonstopux*)
-      if test "$GCC" = yes; then
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
-      else
-	_LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib'
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='-rpath $libdir'
-      fi
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-      _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-      _LT_AC_TAGVAR(link_all_deplibs, $1)=yes
-      ;;
-
-    netbsd*)
-      if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then
-	_LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'  # a.out
-      else
-	_LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared -o $lib $libobjs $deplibs $linker_flags'      # ELF
-      fi
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-
-    newsos6)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-      _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-
-    openbsd*)
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols'
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-	_LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
-      else
-       case $host_os in
-	 openbsd[[01]].* | openbsd2.[[0-7]] | openbsd2.[[0-7]].*)
-	   _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'
-	   _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
-	   ;;
-	 *)
-	   _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
-	   _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
-	   ;;
-       esac
-      fi
-      ;;
-
-    os2*)
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-      _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes
-      _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported
-      _LT_AC_TAGVAR(archive_cmds, $1)='$echo "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$echo "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$echo DATA >> $output_objdir/$libname.def~$echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~$echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def'
-      _LT_AC_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def'
-      ;;
-
-    osf3*)
-      if test "$GCC" = yes; then
-	_LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
-      else
-	_LT_AC_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
-	_LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib'
-      fi
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-      _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-      ;;
-
-    osf4* | osf5*)	# as osf3* with the addition of -msym flag
-      if test "$GCC" = yes; then
-	_LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
-      else
-	_LT_AC_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
-	_LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib'
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; echo "-hidden">> $lib.exp~
-	$LD -shared${allow_undefined_flag} -input $lib.exp $linker_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib~$rm $lib.exp'
-
-	# Both c and cxx compiler support -rpath directly
-	_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
-      fi
-      _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=:
-      ;;
-
-    sco3.2v5*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport'
-      runpath_var=LD_RUN_PATH
-      hardcode_runpath_var=yes
-      ;;
-
-    solaris*)
-      _LT_AC_TAGVAR(no_undefined_flag, $1)=' -z text'
-      if test "$GCC" = yes; then
-	wlarc='${wl}'
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~
-	  $CC -shared ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$rm $lib.exp'
-      else
-	wlarc=''
-	_LT_AC_TAGVAR(archive_cmds, $1)='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags'
-	_LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~
-  	$LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp'
-      fi
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      case $host_os in
-      solaris2.[[0-5]] | solaris2.[[0-5]].*) ;;
-      *)
- 	# The compiler driver will combine linker options so we
- 	# cannot just pass the convience library names through
- 	# without $wl, iff we do not link with $LD.
- 	# Luckily, gcc supports the same syntax we need for Sun Studio.
- 	# Supported since Solaris 2.6 (maybe 2.5.1?)
- 	case $wlarc in
- 	'')
- 	  _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' ;;
- 	*)
- 	  _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $echo \"$new_convenience\"` ${wl}-z ${wl}defaultextract' ;;
- 	esac ;;
-      esac
-      _LT_AC_TAGVAR(link_all_deplibs, $1)=yes
-      ;;
-
-    sunos4*)
-      if test "x$host_vendor" = xsequent; then
-	# Use $CC to link under sequent, because it throws in some extra .o
-	# files that make .init and .fini sections work.
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags'
-      else
-	_LT_AC_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags'
-      fi
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-
-    sysv4)
-      case $host_vendor in
-	sni)
-	  _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
-	  _LT_AC_TAGVAR(hardcode_direct, $1)=yes # is this really true???
-	;;
-	siemens)
-	  ## LD is ld it makes a PLAMLIB
-	  ## CC just makes a GrossModule.
-	  _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags'
-	  _LT_AC_TAGVAR(reload_cmds, $1)='$CC -r -o $output$reload_objs'
-	  _LT_AC_TAGVAR(hardcode_direct, $1)=no
-        ;;
-	motorola)
-	  _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
-	  _LT_AC_TAGVAR(hardcode_direct, $1)=no #Motorola manual says yes, but my tests say they lie
-	;;
-      esac
-      runpath_var='LD_RUN_PATH'
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-
-    sysv4.3*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='-Bexport'
-      ;;
-
-    sysv4*MP*)
-      if test -d /usr/nec; then
-	_LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
-	_LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-	runpath_var=LD_RUN_PATH
-	hardcode_runpath_var=yes
-	_LT_AC_TAGVAR(ld_shlibs, $1)=yes
-      fi
-      ;;
-
-    sysv4.2uw2*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags'
-      _LT_AC_TAGVAR(hardcode_direct, $1)=yes
-      _LT_AC_TAGVAR(hardcode_minus_L, $1)=no
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      hardcode_runpath_var=yes
-      runpath_var=LD_RUN_PATH
-      ;;
-
-   sysv5OpenUNIX8* | sysv5UnixWare7* |  sysv5uw[[78]]* | unixware7*)
-      _LT_AC_TAGVAR(no_undefined_flag, $1)='${wl}-z ${wl}text'
-      if test "$GCC" = yes; then
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
-      else
-	_LT_AC_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
-      fi
-      runpath_var='LD_RUN_PATH'
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-
-    sysv5*)
-      _LT_AC_TAGVAR(no_undefined_flag, $1)=' -z text'
-      # $CC -shared without GNU ld will not create a library from C++
-      # object files and a static libstdc++, better avoid it by now
-      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags'
-      _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~
-  		$LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp'
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)=
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      runpath_var='LD_RUN_PATH'
-      ;;
-
-    uts4*)
-      _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
-      _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
-      _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no
-      ;;
-
-    *)
-      _LT_AC_TAGVAR(ld_shlibs, $1)=no
-      ;;
-    esac
-  fi
-])
-AC_MSG_RESULT([$_LT_AC_TAGVAR(ld_shlibs, $1)])
-test "$_LT_AC_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no
-
-variables_saved_for_relink="PATH $shlibpath_var $runpath_var"
-if test "$GCC" = yes; then
-  variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH"
-fi
-
-#
-# Do we need to explicitly link libc?
-#
-case "x$_LT_AC_TAGVAR(archive_cmds_need_lc, $1)" in
-x|xyes)
-  # Assume -lc should be added
-  _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes
-
-  if test "$enable_shared" = yes && test "$GCC" = yes; then
-    case $_LT_AC_TAGVAR(archive_cmds, $1) in
-    *'~'*)
-      # FIXME: we may have to deal with multi-command sequences.
-      ;;
-    '$CC '*)
-      # Test whether the compiler implicitly links with -lc since on some
-      # systems, -lgcc has to come before -lc. If gcc already passes -lc
-      # to ld, don't add -lc before -lgcc.
-      AC_MSG_CHECKING([whether -lc should be explicitly linked in])
-      $rm conftest*
-      printf "$lt_simple_compile_test_code" > conftest.$ac_ext
-
-      if AC_TRY_EVAL(ac_compile) 2>conftest.err; then
-        soname=conftest
-        lib=conftest
-        libobjs=conftest.$ac_objext
-        deplibs=
-        wl=$_LT_AC_TAGVAR(lt_prog_compiler_wl, $1)
-        compiler_flags=-v
-        linker_flags=-v
-        verstring=
-        output_objdir=.
-        libname=conftest
-        lt_save_allow_undefined_flag=$_LT_AC_TAGVAR(allow_undefined_flag, $1)
-        _LT_AC_TAGVAR(allow_undefined_flag, $1)=
-        if AC_TRY_EVAL(_LT_AC_TAGVAR(archive_cmds, $1) 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1)
-        then
-	  _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no
-        else
-	  _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes
-        fi
-        _LT_AC_TAGVAR(allow_undefined_flag, $1)=$lt_save_allow_undefined_flag
-      else
-        cat conftest.err 1>&5
-      fi
-      $rm conftest*
-      AC_MSG_RESULT([$_LT_AC_TAGVAR(archive_cmds_need_lc, $1)])
-      ;;
-    esac
-  fi
-  ;;
-esac
-])# AC_LIBTOOL_PROG_LD_SHLIBS
-
-
-# _LT_AC_FILE_LTDLL_C
-# -------------------
-# Be careful that the start marker always follows a newline.
-AC_DEFUN([_LT_AC_FILE_LTDLL_C], [
-# /* ltdll.c starts here */
-# #define WIN32_LEAN_AND_MEAN
-# #include <windows.h>
-# #undef WIN32_LEAN_AND_MEAN
-# #include <stdio.h>
-#
-# #ifndef __CYGWIN__
-# #  ifdef __CYGWIN32__
-# #    define __CYGWIN__ __CYGWIN32__
-# #  endif
-# #endif
-#
-# #ifdef __cplusplus
-# extern "C" {
-# #endif
-# BOOL APIENTRY DllMain (HINSTANCE hInst, DWORD reason, LPVOID reserved);
-# #ifdef __cplusplus
-# }
-# #endif
-#
-# #ifdef __CYGWIN__
-# #include <cygwin/cygwin_dll.h>
-# DECLARE_CYGWIN_DLL( DllMain );
-# #endif
-# HINSTANCE __hDllInstance_base;
-#
-# BOOL APIENTRY
-# DllMain (HINSTANCE hInst, DWORD reason, LPVOID reserved)
-# {
-#   __hDllInstance_base = hInst;
-#   return TRUE;
-# }
-# /* ltdll.c ends here */
-])# _LT_AC_FILE_LTDLL_C
-
-
-# _LT_AC_TAGVAR(VARNAME, [TAGNAME])
-# ---------------------------------
-AC_DEFUN([_LT_AC_TAGVAR], [ifelse([$2], [], [$1], [$1_$2])])
-
-
-# old names
-AC_DEFUN([AM_PROG_LIBTOOL],   [AC_PROG_LIBTOOL])
-AC_DEFUN([AM_ENABLE_SHARED],  [AC_ENABLE_SHARED($@)])
-AC_DEFUN([AM_ENABLE_STATIC],  [AC_ENABLE_STATIC($@)])
-AC_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)])
-AC_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)])
-AC_DEFUN([AM_PROG_LD],        [AC_PROG_LD])
-AC_DEFUN([AM_PROG_NM],        [AC_PROG_NM])
-
-# This is just to silence aclocal about the macro not being used
-ifelse([AC_DISABLE_FAST_INSTALL])
-
-AC_DEFUN([LT_AC_PROG_GCJ],
-[AC_CHECK_TOOL(GCJ, gcj, no)
-  test "x${GCJFLAGS+set}" = xset || GCJFLAGS="-g -O2"
-  AC_SUBST(GCJFLAGS)
-])
-
-AC_DEFUN([LT_AC_PROG_RC],
-[AC_CHECK_TOOL(RC, windres, no)
-])
-
-############################################################
-# NOTE: This macro has been submitted for inclusion into   #
-#  GNU Autoconf as AC_PROG_SED.  When it is available in   #
-#  a released version of Autoconf we should remove this    #
-#  macro and use it instead.                               #
-############################################################
-# LT_AC_PROG_SED
-# --------------
-# Check for a fully-functional sed program, that truncates
-# as few characters as possible.  Prefer GNU sed if found.
-AC_DEFUN([LT_AC_PROG_SED],
-[AC_MSG_CHECKING([for a sed that does not truncate output])
-AC_CACHE_VAL(lt_cv_path_SED,
-[# Loop through the user's path and test for sed and gsed.
-# Then use that list of sed's as ones to test for truncation.
-as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
-for as_dir in $PATH
-do
-  IFS=$as_save_IFS
-  test -z "$as_dir" && as_dir=.
-  for lt_ac_prog in sed gsed; do
-    for ac_exec_ext in '' $ac_executable_extensions; do
-      if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then
-        lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext"
-      fi
-    done
-  done
-done
-lt_ac_max=0
-lt_ac_count=0
-# Add /usr/xpg4/bin/sed as it is typically found on Solaris
-# along with /bin/sed that truncates output.
-for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do
-  test ! -f $lt_ac_sed && continue
-  cat /dev/null > conftest.in
-  lt_ac_count=0
-  echo $ECHO_N "0123456789$ECHO_C" >conftest.in
-  # Check for GNU sed and select it if it is found.
-  if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then
-    lt_cv_path_SED=$lt_ac_sed
-    break
-  fi
-  while true; do
-    cat conftest.in conftest.in >conftest.tmp
-    mv conftest.tmp conftest.in
-    cp conftest.in conftest.nl
-    echo >>conftest.nl
-    $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break
-    cmp -s conftest.out conftest.nl || break
-    # 10000 chars as input seems more than enough
-    test $lt_ac_count -gt 10 && break
-    lt_ac_count=`expr $lt_ac_count + 1`
-    if test $lt_ac_count -gt $lt_ac_max; then
-      lt_ac_max=$lt_ac_count
-      lt_cv_path_SED=$lt_ac_sed
-    fi
-  done
-done
-])
-SED=$lt_cv_path_SED
-AC_MSG_RESULT([$SED])
-])
diff --git a/m4/sah_namespace.m4 b/m4/sah_namespace.m4
index 2108f8e..5ac7b73 100644
--- a/m4/sah_namespace.m4
+++ b/m4/sah_namespace.m4
@@ -35,6 +35,8 @@ AC_DEFUN([SAH_NS_TO_DEFN],[
 
 AC_DEFUN([SAH_CHECK_NAMESPACES],[
   AC_LANG_PUSH(C++)
+  sv_libs="${LIBS}"
+  LIBS=
   AC_CACHE_CHECK([for C++ namespaces],
     [sah_cv_have_namespaces],[
     AC_COMPILE_IFELSE([
@@ -51,11 +53,14 @@ AC_DEFUN([SAH_CHECK_NAMESPACES],[
   if test "${sah_cv_have_namespaces}" = "yes" ; then
     AC_DEFINE(HAVE_NAMESPACES,[1],[Define if your C++ compiler supports namespaces]) 
   fi
+  LIBS="${sv_libs}"
   AC_LANG_POP(C++)
 ])
 
 AC_DEFUN([SAH_FUNCS_IN_NAMESPACE],[
   AC_LANG_PUSH(C++)
+  sv_libs="${LIBS}"
+  LIBS=
   for func_name in $1 
   do
     func_name=m4_quote($func_name)
@@ -65,7 +70,7 @@ AC_DEFUN([SAH_FUNCS_IN_NAMESPACE],[
     ac_uc_defn=`echo HAVE_"$ac_namespace_upper"_$ac_func_upper`
     AC_CACHE_CHECK([for $func_name in namespace $t_ns],
       [sah_cv_func_$2_$ac_func_upper],[
-      AC_LINK_IFELSE(
+      AC_COMPILE_IFELSE(
 	[AC_LANG_PROGRAM([[
 	          #define CONFIG_TEST
 	          $sah_cxx_includes
@@ -86,6 +91,7 @@ AC_DEFUN([SAH_FUNCS_IN_NAMESPACE],[
 	["Define to 1 if $func_name is in namespace $t_ns::"  ])
     fi
   done
+  LIBS="${sv_libs}"
   AC_LANG_POP(C++)
 ])
 
diff --git a/missing b/missing
deleted file mode 100755
index 6a37006..0000000
--- a/missing
+++ /dev/null
@@ -1,336 +0,0 @@
-#! /bin/sh
-# Common stub for a few missing GNU programs while installing.
-# Copyright (C) 1996, 1997, 1999, 2000, 2002 Free Software Foundation, Inc.
-# Originally by Fran,cois Pinard <pinard at iro.umontreal.ca>, 1996.
-
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2, or (at your option)
-# any later version.
-
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-# GNU General Public License for more details.
-
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
-# 02111-1307, USA.
-
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-if test $# -eq 0; then
-  echo 1>&2 "Try \`$0 --help' for more information"
-  exit 1
-fi
-
-run=:
-
-# In the cases where this matters, `missing' is being run in the
-# srcdir already.
-if test -f configure.ac; then
-  configure_ac=configure.ac
-else
-  configure_ac=configure.in
-fi
-
-case "$1" in
---run)
-  # Try to run requested program, and just exit if it succeeds.
-  run=
-  shift
-  "$@" && exit 0
-  ;;
-esac
-
-# If it does not exist, or fails to run (possibly an outdated version),
-# try to emulate it.
-case "$1" in
-
-  -h|--h|--he|--hel|--help)
-    echo "\
-$0 [OPTION]... PROGRAM [ARGUMENT]...
-
-Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an
-error status if there is no known handling for PROGRAM.
-
-Options:
-  -h, --help      display this help and exit
-  -v, --version   output version information and exit
-  --run           try to run the given command, and emulate it if it fails
-
-Supported PROGRAM values:
-  aclocal      touch file \`aclocal.m4'
-  autoconf     touch file \`configure'
-  autoheader   touch file \`config.h.in'
-  automake     touch all \`Makefile.in' files
-  bison        create \`y.tab.[ch]', if possible, from existing .[ch]
-  flex         create \`lex.yy.c', if possible, from existing .c
-  help2man     touch the output file
-  lex          create \`lex.yy.c', if possible, from existing .c
-  makeinfo     touch the output file
-  tar          try tar, gnutar, gtar, then tar without non-portable flags
-  yacc         create \`y.tab.[ch]', if possible, from existing .[ch]"
-    ;;
-
-  -v|--v|--ve|--ver|--vers|--versi|--versio|--version)
-    echo "missing 0.4 - GNU automake"
-    ;;
-
-  -*)
-    echo 1>&2 "$0: Unknown \`$1' option"
-    echo 1>&2 "Try \`$0 --help' for more information"
-    exit 1
-    ;;
-
-  aclocal*)
-    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
-       # We have it, but it failed.
-       exit 1
-    fi
-
-    echo 1>&2 "\
-WARNING: \`$1' is missing on your system.  You should only need it if
-         you modified \`acinclude.m4' or \`${configure_ac}'.  You might want
-         to install the \`Automake' and \`Perl' packages.  Grab them from
-         any GNU archive site."
-    touch aclocal.m4
-    ;;
-
-  autoconf)
-    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
-       # We have it, but it failed.
-       exit 1
-    fi
-
-    echo 1>&2 "\
-WARNING: \`$1' is missing on your system.  You should only need it if
-         you modified \`${configure_ac}'.  You might want to install the
-         \`Autoconf' and \`GNU m4' packages.  Grab them from any GNU
-         archive site."
-    touch configure
-    ;;
-
-  autoheader)
-    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
-       # We have it, but it failed.
-       exit 1
-    fi
-
-    echo 1>&2 "\
-WARNING: \`$1' is missing on your system.  You should only need it if
-         you modified \`acconfig.h' or \`${configure_ac}'.  You might want
-         to install the \`Autoconf' and \`GNU m4' packages.  Grab them
-         from any GNU archive site."
-    files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}`
-    test -z "$files" && files="config.h"
-    touch_files=
-    for f in $files; do
-      case "$f" in
-      *:*) touch_files="$touch_files "`echo "$f" |
-				       sed -e 's/^[^:]*://' -e 's/:.*//'`;;
-      *) touch_files="$touch_files $f.in";;
-      esac
-    done
-    touch $touch_files
-    ;;
-
-  automake*)
-    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
-       # We have it, but it failed.
-       exit 1
-    fi
-
-    echo 1>&2 "\
-WARNING: \`$1' is missing on your system.  You should only need it if
-         you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'.
-         You might want to install the \`Automake' and \`Perl' packages.
-         Grab them from any GNU archive site."
-    find . -type f -name Makefile.am -print |
-	   sed 's/\.am$/.in/' |
-	   while read f; do touch "$f"; done
-    ;;
-
-  autom4te)
-    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
-       # We have it, but it failed.
-       exit 1
-    fi
-
-    echo 1>&2 "\
-WARNING: \`$1' is needed, and you do not seem to have it handy on your
-         system.  You might have modified some files without having the
-         proper tools for further handling them.
-         You can get \`$1Help2man' as part of \`Autoconf' from any GNU
-         archive site."
-
-    file=`echo "$*" | sed -n 's/.*--output[ =]*\([^ ]*\).*/\1/p'`
-    test -z "$file" && file=`echo "$*" | sed -n 's/.*-o[ ]*\([^ ]*\).*/\1/p'`
-    if test -f "$file"; then
-	touch $file
-    else
-	test -z "$file" || exec >$file
-	echo "#! /bin/sh"
-	echo "# Created by GNU Automake missing as a replacement of"
-	echo "#  $ $@"
-	echo "exit 0"
-	chmod +x $file
-	exit 1
-    fi
-    ;;
-
-  bison|yacc)
-    echo 1>&2 "\
-WARNING: \`$1' is missing on your system.  You should only need it if
-         you modified a \`.y' file.  You may need the \`Bison' package
-         in order for those modifications to take effect.  You can get
-         \`Bison' from any GNU archive site."
-    rm -f y.tab.c y.tab.h
-    if [ $# -ne 1 ]; then
-        eval LASTARG="\${$#}"
-	case "$LASTARG" in
-	*.y)
-	    SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'`
-	    if [ -f "$SRCFILE" ]; then
-	         cp "$SRCFILE" y.tab.c
-	    fi
-	    SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'`
-	    if [ -f "$SRCFILE" ]; then
-	         cp "$SRCFILE" y.tab.h
-	    fi
-	  ;;
-	esac
-    fi
-    if [ ! -f y.tab.h ]; then
-	echo >y.tab.h
-    fi
-    if [ ! -f y.tab.c ]; then
-	echo 'main() { return 0; }' >y.tab.c
-    fi
-    ;;
-
-  lex|flex)
-    echo 1>&2 "\
-WARNING: \`$1' is missing on your system.  You should only need it if
-         you modified a \`.l' file.  You may need the \`Flex' package
-         in order for those modifications to take effect.  You can get
-         \`Flex' from any GNU archive site."
-    rm -f lex.yy.c
-    if [ $# -ne 1 ]; then
-        eval LASTARG="\${$#}"
-	case "$LASTARG" in
-	*.l)
-	    SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'`
-	    if [ -f "$SRCFILE" ]; then
-	         cp "$SRCFILE" lex.yy.c
-	    fi
-	  ;;
-	esac
-    fi
-    if [ ! -f lex.yy.c ]; then
-	echo 'main() { return 0; }' >lex.yy.c
-    fi
-    ;;
-
-  help2man)
-    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
-       # We have it, but it failed.
-       exit 1
-    fi
-
-    echo 1>&2 "\
-WARNING: \`$1' is missing on your system.  You should only need it if
-	 you modified a dependency of a manual page.  You may need the
-	 \`Help2man' package in order for those modifications to take
-	 effect.  You can get \`Help2man' from any GNU archive site."
-
-    file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'`
-    if test -z "$file"; then
-	file=`echo "$*" | sed -n 's/.*--output=\([^ ]*\).*/\1/p'`
-    fi
-    if [ -f "$file" ]; then
-	touch $file
-    else
-	test -z "$file" || exec >$file
-	echo ".ab help2man is required to generate this page"
-	exit 1
-    fi
-    ;;
-
-  makeinfo)
-    if test -z "$run" && (makeinfo --version) > /dev/null 2>&1; then
-       # We have makeinfo, but it failed.
-       exit 1
-    fi
-
-    echo 1>&2 "\
-WARNING: \`$1' is missing on your system.  You should only need it if
-         you modified a \`.texi' or \`.texinfo' file, or any other file
-         indirectly affecting the aspect of the manual.  The spurious
-         call might also be the consequence of using a buggy \`make' (AIX,
-         DU, IRIX).  You might want to install the \`Texinfo' package or
-         the \`GNU make' package.  Grab either from any GNU archive site."
-    file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'`
-    if test -z "$file"; then
-      file=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'`
-      file=`sed -n '/^@setfilename/ { s/.* \([^ ]*\) *$/\1/; p; q; }' $file`
-    fi
-    touch $file
-    ;;
-
-  tar)
-    shift
-    if test -n "$run"; then
-      echo 1>&2 "ERROR: \`tar' requires --run"
-      exit 1
-    fi
-
-    # We have already tried tar in the generic part.
-    # Look for gnutar/gtar before invocation to avoid ugly error
-    # messages.
-    if (gnutar --version > /dev/null 2>&1); then
-       gnutar "$@" && exit 0
-    fi
-    if (gtar --version > /dev/null 2>&1); then
-       gtar "$@" && exit 0
-    fi
-    firstarg="$1"
-    if shift; then
-	case "$firstarg" in
-	*o*)
-	    firstarg=`echo "$firstarg" | sed s/o//`
-	    tar "$firstarg" "$@" && exit 0
-	    ;;
-	esac
-	case "$firstarg" in
-	*h*)
-	    firstarg=`echo "$firstarg" | sed s/h//`
-	    tar "$firstarg" "$@" && exit 0
-	    ;;
-	esac
-    fi
-
-    echo 1>&2 "\
-WARNING: I can't seem to be able to run \`tar' with the given arguments.
-         You may want to install GNU tar or Free paxutils, or check the
-         command line arguments."
-    exit 1
-    ;;
-
-  *)
-    echo 1>&2 "\
-WARNING: \`$1' is needed, and you do not seem to have it handy on your
-         system.  You might have modified some files without having the
-         proper tools for further handling them.  Check the \`README' file,
-         it often tells you about the needed prerequirements for installing
-         this package.  You may also peek at any GNU archive site, in case
-         some other package would contain this missing \`$1' program."
-    exit 1
-    ;;
-esac
-
-exit 0

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-boinc/boinc-app-seti.git



More information about the pkg-boinc-commits mailing list